aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Embedded_SW/Embedded/Modules/Stubs_Handler/Stub_FPGARWReg.c
blob: 5dcabc5767f1ac2ca79fb492630cfa622d5a478d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
#include <Container.h>
#include <DataDef.h>
#include <PMR/Stubs/StubFpgaReadRegRequest.pb-c.h>
#include <PMR/Stubs/StubFpgaReadRegResponse.pb-c.h>
#include <PMR/Stubs/StubFpgaWriteRegRequest.pb-c.h>
#include <PMR/Stubs/StubFpgaWriteRegResponse.pb-c.h>

#include <stdbool.h>
#include <stdlib.h>
#include <stdio.h>
#include <stdint.h>
#include <string.h>
#include "inc/hw_memmap.h"
#include "inc/hw_types.h"
#include "inc/hw_uart.h"

#include "Drivers/USB_Communication/USBCDCD.h"


#include "MessageContainer.pb-c.h"

#include "Stub_Status.h"
#include "drivers/FPGA/FPGA.h"
#include "drivers/FPGA/FPGA_Comm.h"

#include "control/control.h"


void Stub_FpgaReadRegRequest(MessageContainer* requestContainer)
{
    uint32_t status = PASSED;

    MessageContainer responseContainer;

    StubFpgaReadRegRequest* request = stub_fpga_read_reg_request__unpack(NULL, requestContainer->data.len, requestContainer->data.data);

    StubFpgaReadRegResponse response =   STUB_FPGA_READ_REG_RESPONSE__INIT;

    status_response(status,&response.status, &response.statusword ,&response.has_statusword);

    if((request->address < FPGA1_BASE) || (request->address > (FPGA3_BASE | (0x3FF))))//TODO update the last add
    {
        status = FAILED;
    }
    else
    {
        volatile short *ptr;
        ptr = (volatile short *) (request->address);

        response.address = request->address;
        response.has_address = true;
        response.value = *ptr;
        response.has_value = true;
    }

    responseContainer = createContainer(MESSAGE_TYPE__StubFpgaReadRegResponse, requestContainer->token, true, &response, &stub_fpga_read_reg_response__pack, &stub_fpga_read_reg_response__get_packed_size);

    Write_status_response(status);

    //free(request);
    stub_fpga_read_reg_request__free_unpacked(request,NULL);
    //-------------------------------------------------------------------------------------------
    uint8_t* container_buffer = malloc(message_container__get_packed_size(&responseContainer));
    size_t container_size = message_container__pack(&responseContainer, container_buffer);
    free(responseContainer.data.data);
    SendChars((char*)container_buffer, container_size);
    //free(container_buffer);
    //free(requestContainer);

}
uint32_t value = 0,ctlId;
uint32_t ResetCallBackFunction(uint32_t IfIndex, uint32_t BusyFlag)
{
    SafeRemoveControlCallback(ctlId, ResetCallBackFunction );
    volatile short *ptr = (volatile short *)(FPGA3_BASE | 0x3D0);
    *ptr = (value & 0xFFFF);
    return OK;
}

void Stub_FpgaWriteRegRequest(MessageContainer* requestContainer)
{
    uint32_t status = PASSED;
    volatile short *ptr;

    MessageContainer responseContainer;

    StubFpgaWriteRegRequest* request = stub_fpga_write_reg_request__unpack(NULL, requestContainer->data.len, requestContainer->data.data);

    if((request->address < FPGA1_BASE) || (request->address > (FPGA3_BASE | (0x3FF))))//TODO update the last add
    {
        status = FAILED;
    }
    else
    {
        value = request->value;
        ptr = (volatile short *) (request->address);
        if (request->address == (FPGA3_BASE | 0x3D0))
        {
            ctlId = AddControlCallback("Reset", ResetCallBackFunction, 2* eOneSecond, TemplateDataReadCBFunction,ptr,ptr, 0 );
        }
        else
            *ptr = (request->value & 0xFFFF);
    }
    StubFpgaWriteRegResponse response =   STUB_FPGA_WRITE_REG_RESPONSE__INIT;

    status_response(status,&response.status, &response.statusword ,&response.has_statusword);

    responseContainer = createContainer(MESSAGE_TYPE__StubFpgaWriteRegResponse, requestContainer->token, true, &response, &stub_fpga_write_reg_response__pack, &stub_fpga_write_reg_response__get_packed_size);

    Write_status_response(status);

    //free(request);
    stub_fpga_write_reg_request__free_unpacked(request,NULL);
    //-------------------------------------------------------------------------------------------
    uint8_t* container_buffer = malloc(message_container__get_packed_size(&responseContainer));
    size_t container_size = message_container__pack(&responseContainer, container_buffer);
    free(responseContainer.data.data);
    SendChars((char*)container_buffer, container_size);
    //free(container_buffer);
    //free(requestContainer);

}