To fix the hang problem

Dependencies:   FreescaleIAP SimpleDMA mbed-rtos mbed

Fork of CDMS_CODE by shubham c

DefinitionsAndGlobals.h

Committer:
chaithanyarss
Date:
2016-12-30
Revision:
333:cddef120cae3
Parent:
332:7d2431ce979f
Child:
338:d63eb331a67d

File content as of revision 333:cddef120cae3:

///639+................................++.300000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000002025555.
// **************DEFINITIONS*********************

#define dma 1

// COM_RX
    #define RX_TIMEOUT_LIMIT 0.5
    #define COM_RX_UART_TX PTE20    // For bypassing RX1M (SET BAUD RATE 1200) #define COM_RX_UART_TX USBTX
    #define COM_RX_UART_RX PTE21    // For bypassing RX1M (SET BAUD RATE 1200) #define COM_RX_UART_RX USBRX
    
    //#define COM_RX_UART_TX USBTX
    //#define COM_RX_UART_RX USBRX
    
// COMMON SPI
    #define SPI_MOSI PTE1
    #define SPI_MISO PTE3
    #define SPI_CLK PTE2
    #define SPI_CS_ADF PTA15
    #define SPI_CS_SDC PIN20
  //#define SPI_CS_RTC PIN26 // actual
     #define SPI_CS_RTC PIN60 // sbc with jumper v1.0
    
// COM_TX
    #define COM_TX_CONFIG_LIMIT 3
    #define COM_TX_TICKER_LIMIT 32

// ADF INTERRUPT
    #define ADF_IRQ PTA14
    
//I2C - Payload to CDMS (need to change while using CDMS hardware);
    I2C master(PIN32,PIN31);
    DigitalIn PL_I2C_Intr(PTC13);
    DigitalOut PL_I2C_GPIO(PTC1);
            
//I2C - CDMS to BAE
    //DigitalIn BAE_I2C_GPIO(PIN67);//PTB21 from bae to cdms
    //DigitalOut CDMS_I2C_GPIO(PIN39);//PTA5 from cdms to bae 
    
    #define SBC 1
    
    #if SBC
    DigitalOut CDMS_I2C_GPIO(PIN67,0);
    DigitalIn BAE_I2C_GPIO(PIN1);
    #endif
    
    #if !SBC
    DigitalIn BAE_I2C_GPIO(PIN67);
    DigitalOut CDMS_I2C_GPIO(PIN39,0);    
    #endif

// TC LIST
    #define TCL_STATE_INCOMPLETE 0x00
    #define TCL_STATE_ABORTED 0x01
    #define TCL_STATE_EXECUTING 0x02   
    #define TCL_STATE_COMPLETED 0x03

// LIST OF FLAGS
    #define UART_INT_FLAG 0x0001
    #define NEW_TC_RECEIVED 0x0002
    #define COM_SESSION_FLAG 0x0004
    #define COM_RX_FLAG 0x0008
    #define COM_MNG_TMTC_RUNNING_FLAG 0x0010
    #define COM_SESSION_VALIDITY 0x0020
    #define ALL_CRC_PASS_FLAG 0x0040
    #define COM_PA_HOT_FLAG 0x0080
    #define COM_PA_OC_FLAG 0x8000
    #define COM_TX_FLAG 0x0100
    #define COM_SESSION_TIMEOUT_FLAG 0x0200
    #define COM_AUTO_POWER_OFF_BAE_FLAG 0x0400
    #define BAE_SW_EN_FLAG 0x0800
    #define RF_SW_STATUS_FLAG 0x1000
    #define COM_INIT_STATUS_FLAG 0x2000
    #define COM_TX_STATUS_FLAG 0x4000

//RF relay STATUS
    #define RF_COM_TX 0
    #define RF_BCN 1

// COM_MNG_TMTC THREAD
    #define SESSION_TIME_LIMIT 1500
    #define COM_MNG_TMTC_SIGNAL_UART_INT 0x01
    #define COM_MNG_TMTC_SIGNAL_ADF_NSD 0x02
    #define COM_MNG_TMTC_SIGNAL_ADF_SD 0x03
    #define cdms_reset_timeout 345600000
    
// COM_MNG_TMTC
    #define COM_PA_COOLING_TIME_LIMIT 20
    #define COM_MAX_TC_LIMIT 256
    #define TM_ACK_CODE_INDEX 2
    #define CRC_FAIL_NACK_CODE 0x01
    
    // call sign
    #define PSC_CALLSIGN 0x00
    #define APID_CALLSIGN 0x00
    
    // max value of telecommands in a tcl
    #define TCL_OVERFLOW_CONSTANT 256
    #define TM_OVERFLOW_CONSTANT 256
    #define BYTE_OVERFLOW_CONSTANT 35000

    // starting value of packet sequence count at each pass 
    #define PSC_START_VALUE 1
    
    // APID list
    #define APID_COM 0
    #define APID_BAE 1
    #define APID_CDMS 2
    #define APID_SPEED 3
    
    //SERVICE
    #define SERVICE_OBOSC 0xB
    #define SERVICE_OBSRS 0xF
    
    // HIGH PRIORITY TC - priority list
    // not correct values here
    #define HPTC1 5
    #define HPTC2 6
    // Add more entries above
    
    // TMID list
    #define TMID_ACK_L1 0xA
    #define TMID_ACK_L234 0xB
    #define TMID_TCL 0x7
    #define TMID_CALL_SIGN 0xE

// OBOSC SERVICE SUBTYPE
    #define OBOSC_TCL_MAX_SHORT_SIZE 11
    #define OBOSC_LONG_TC_FIRST_HALF_SIZE 67
    #define OBOSC_LONG_TC_SECOND_HALF_SIZE 68
    #define OBOSC_TCL_TAG_LONG_FIRST_HALF 0x10
    #define OBOSC_TCL_TAG_LONG_SECOND_HALF 0x11

    #define OBOSC_SUB_DISABLE 0x01
    #define OBOSC_SUB_RETRY 0x05
    #define OBOSC_SUB_REP_TCLD 0x06
    #define OBOSC_SUB_REP_LE 0x0F
    #define OBOSC_SUB_RESET 0x07
    
// PAYLOAD or SCIENCE
    #define PAYLOAD_BUFFER_LENGTH 6723  // 6723
    #define PAY_SPI_MOSI PTE18
    #define PAY_SPI_MISO PTE19
    #define PAY_SPI_CLK PTE17
    #define PAY_SPI_CS PTE16
    #define SCIENCE_SIGNAL 0x04

//BEACON
    #define BCN_APID_SOURCE 0x41
    #define BCN_SERVICE 0x81
    
//BAE
    #define BAE_APID_SOURCE 0x81
    #define BAE_SERVICE 0x81
    #define BAE_POWER_ON_PID 0x13
    #define BAE_POWER_OFF_PID 0x23
    #define BAE_RESET_PID 0x33

//RF RELAY
    #define RF_RELAY_CNTRL_TX PTB7
    #define RF_RELAY_CNTRL_BCN PTB17 
    
//CDMS HK
#define HK_SIGNAL 0x05
#define COMRX_ALIVE 0x01
#define COMRX_DEAD 0x00
#define DEVICE_ENABLED 0x00
#define DEVICE_POWERED 0x01
#define DEVICE_OC_FAULT 0x02
#define DEVICE_DISABLED 0x03


    
// ****************GLOBAL VARIABLES******************

//Global 
Mutex gMutex;


// DEBUG
Serial gPC( USBTX, USBRX );
DigitalOut gLEDR(LED_RED);
DigitalOut gLEDG(LED_GREEN);

// COM_RX
RawSerial RX1M( COM_RX_UART_TX, COM_RX_UART_RX );
COM_RX_DATA_NODE *gRX_HEAD_DATA_NODE = NULL;
COM_RX_DATA_NODE *gRX_CURRENT_DATA_NODE = NULL;
// uint8_t *gRX_CURRENT_PTR = NULL;
uint32_t gRX_COUNT = 0;
uint16_t gTOTAL_RAW_BYTES = 0;
uint16_t gTOTAL_INCORRECT_SIZE_TC = 0x00;
uint16_t gTOTAL_CRC_FAIL_TC = 0x00;
uint16_t gTOTAL_REPEATED_TC = 0x00;

// COMMON SPI
SPI spi( SPI_MOSI, SPI_MISO, SPI_CLK );
DigitalOut gCS_ADF(SPI_CS_ADF);
DigitalOut cs_sd(SPI_CS_SDC);
DigitalOut gCS_RTC(SPI_CS_RTC);
Mutex SPI_mutex;

//I2C
Mutex BAE_I2C_mutex;

//RF Relay
DigitalOut RF_SW_CNTRL_BCN(RF_RELAY_CNTRL_BCN);
DigitalOut RF_SW_CNTRL_TX(RF_RELAY_CNTRL_TX);

//COM_RX
DigitalOut COM_RX_CNTRL(PIN72,1);
DigitalOut COM_TX_CNTRL(PIN56,1);
//DigitalIn COM_TX_OC_FAULT(PIN69);
DigitalIn COM_TX_OC_FAULT(PIN58);

// TC LIST
Base_tc* gHEAD_NODE_TCL = NULL;
Base_tc* gLAST_NODE_TCL = NULL;
uint8_t gMASTER_STATE = TCL_STATE_INCOMPLETE;
uint16_t gFLAGS = 0x0000;

// COM_MNG_TMTC THREAD
Thread* gCOM_MNG_TMTC_THREAD = NULL;
Timeout gRX_TIMEOUT;
Timeout gSESSION_TIMEOUT;
Timeout gCOM_RX_DISABLE;

// COM_MNG_TMTC
RtosTimer *sys_reset_cdms_timer;

// PA cooling timeout
Timeout gCOM_PA_COOLING_TIMEOUT;

// GS code for verification
const uint8_t gGSCODE[] = {0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};

uint8_t gTOTAL_VALID_TC = 0x00;
// USE LAST_L1_ACK FOR GENERATING REPORT
uint8_t gLAST_TM[TM_LONG_SIZE];
uint8_t gLAST_TM_SHORT_OR_LONG = SHORT_TM_CODE;

// PAYLOAD OR SCIENCE_THREAD
Thread* gSCIENCE_THREAD = NULL;
dmaSPISlave *gPAY_SPI;
uint8_t gPAYLOAD_BUFFER[PAYLOAD_BUFFER_LENGTH] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,44,1,44,1,44,1,44,1,44,1,44,1,188,2,188,2,188,2,188,2,88,2,88,2,88,2,88,2,100,0,100,0,200,0,200,0,244,1,244,1,88,2,88,2,208,2,208,2,246,0,246,0,10,0,250,0,250,0,250,0,120,0,0,0,172,13,0,0,184,11,0,0,160,15,0,0};
RtosTimer *PL_wo_dma;

// CALL SIGN TM
const uint8_t gCALL_SIGN_STRING[TM_SHORT_SIZE] = {0xE0, 0x00, 0x00, 0x00, 0x56, 0x55, 0x32, 0x4E, 0x43, 0x46, 0x00, 0xAC, 0x11};

//HK Thread
Thread* gHK_THREAD = NULL;
RtosTimer *HK_counter;

// CDMS HK
uint8_t CDMS_STANDBY;
uint8_t CDMS_HEALTH_DATA[128];
uint8_t CDMS_RAM[59] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
uint16_t GPIO_STATUS;
uint8_t CDMS_HK_MAIN_STATUS;    
uint8_t COMRX_STATUS;
uint8_t RTC_FAULTCOUNT = 0;
uint16_t SD_FAULTCOUNT = 0;
uint8_t SD_STATUS;
uint8_t BAE_FAULTCOUNT = 0;
uint8_t BAE_STATUS;
uint8_t PL_STATUS;
uint16_t PL_FAULTCOUNT = 0;
bool BAE_HK_I2C;
uint8_t RTC_STATUS;
float RSSI_VOLTAGE;
uint8_t COM_ADF_TMP = 0;
uint8_t COM_PA_IC_TMP = 0;

CDMS_HK_actual actual_data;
CDMS_HK_quant quant_data;
CDMS_HK_min_max min_max_data;
uint8_t MAX_COM_ADF_TMP;
uint8_t MIN_COM_ADF_TMP;
float MAX_RSSI_VOLTAGE;
float MIN_RSSI_VOLTAGE;
bool firstCount=true;

//GPIO PINS
DigitalIn V_A_PGOOD (PIN88);
DigitalIn V_B_PGOOD_1 (PIN6);
DigitalIn V_B_PGOOD_2 (PIN7);
DigitalIn V_C_PGOOD (PIN54);
DigitalIn COMRX_OC_FAULT (PIN68);
//DigitalIn COMTX_OC_FAULT (PIN69);
DigitalIn BAE_OC_FAULT (PIN92);
DigitalOut PL_GPIO_1_STATUS (PIN71); // PYLD EPS CNTRL Signal1 / PYLD_EPS_CNTRL_SIG1
DigitalOut PL_GPIO_2_STATUS (PIN81);//PYLD EPS CNTRL 2 / PYLD_EPS_CNTRL_2
DigitalOut PL_GPIO_3_STATUS (PIN80);// PYLD EPS CNTRL 3 / PYLD_EPS_CNTRL_3
DigitalIn PL_BEE_SW_OC_FAULT (PIN91);
DigitalIn PL_EPS_LATCH_SW_OC_FAULT (PIN5);
//DigitalOut EPS_V_C_EN_STATUS (PIN72,1);//COMM RX PWR CNTRL
//DigitalOut EPS_V_D_EN_STATUS (PIN56,1);//3V6_EN


DigitalIn SD_OC_FAULT (PIN90);
DigitalOut SD_SW_EN_DS (PIN97,1);//SD CARD SW EN/DIS or SD_CARD_SW_EN_DIS
DigitalOut BAE_SW_EN_DS (PIN47,1);//BAE_SW_EN_DIS
//DigitalOut TRXY_EN (PIN84);//TRXY EN
//DigitalOut TRZ_EN (PIN88);//TRZ EN
DigitalOut V_A_EN (PIN99,1);//TRZ FLT (no INTR capability)
DigitalIn sys_pwr_rst (PIN46);//PTD3

DigitalOut PYLD_DFF (PIN73);//PYLD_SW_PWR_EN_DIS
DigitalOut PYLD_DFF_CLK (PIN65);//PL_3V3_EN_CLK
DigitalOut PYLD_EPS_DFF_PWR (PIN64);//TPS_SW_PL_LAT_ENA_DIS
DigitalOut PYLD_EPS_DFF_PWR_CLK (PIN40);//PYLD_EPS_LATCH_CLK

DigitalOut RESET_TO_BAE(PIN93,1);//RESET_BAE_FROM_CDMS
DigitalOut RESET_TO_PYLD(PIN21,1);//RESET_PYLD

DigitalOut DMA_LED1(PIN61,0);
DigitalOut SCI_LED1(PIN62,0);

//SD HK
uint32_t FSC_CURRENT[6];
uint32_t FSC_OLD[6];
uint8_t SD_RD_ERROR;

//Time's
uint32_t TIME_LATEST_RTC;
uint32_t TIME_LATEST_I2C_BAE;
uint32_t TIME_LATEST_I2C_SPEED;
uint32_t TIME_LATEST_SD_WR;
uint32_t TIME_LATEST_SD_RD;
uint32_t TIME_LATEST_SPI_SPEED;

//Counter's
uint16_t CDMS_I2C_ERR_SPEED_COUNTER = 0;
uint16_t CDMS_I2C_ERR_BAE_COUNTER = 0;
uint16_t CDMS_HK_MAIN_COUNTER = 0;
uint16_t COMRX_RESET_COUNTER = 0;
uint16_t PL_MAIN_COUNTER = 0;
uint16_t PL_RCV_SC_DATA_COUNTER = 0;
uint16_t CDMS_WR_SD_FAULT_COUNTER = 0;
uint16_t SD_LIB_WRITES = 0;

//CDMS RAM parameters
uint8_t PL_INIT_STATUS = 0;
uint8_t PL_MAIN_status;
uint8_t PL_LOW_power;
uint8_t PL_STATE;
uint8_t PL_RCV_SC_DATA_STATUS = 0;
uint8_t COM_SESSION;
uint8_t COM_RX;
uint8_t RF_SW_STATUS;
uint8_t COM_TX;
uint8_t COM_TX_STATUS;
uint8_t COM_MNG_TMTC;
uint8_t EN_CDMS_HK = 1;
uint8_t EN_PL = 1;
uint8_t EN_RCV_SC = 1;
uint8_t CDMS_INIT_STATUS;
uint8_t CDMS_HK_STATUS;
uint8_t COM_RX_STATUS;
uint8_t CDMS_RTC_BL;


//CDMS FLASH parameters

uint8_t EPS_V_A_EN_STATUS;
//uint8_t BAE_SW_STATUS;
//uint8_t CDMS_SD_SW_STATUS;
//uint8_t PL_BEE_SW_STATUS;*
uint8_t PL_EPS_LATCH_SW_EN;
uint8_t RTC_INIT_STATUS;
uint8_t CDMS_RTC_DISABLE;
uint16_t CDMS_RESET_COUNTER;
uint32_t TIME_LATEST_CDSMS_RESET;
uint16_t COM_TC_BYTES_LIMIT;
uint8_t COM_RX_CURRENT_MAX;
uint8_t COM_RX_DISABLE_TIMEOUT;
uint8_t COM_PA_TMP_HIGH;
uint8_t COM_PA_RECOVERY_TIMEOUT;
uint8_t COM_SESSION_TIMEOUT = 1500;  //confirm with Anirudh 
uint8_t COM_RSSI_MIN;
uint16_t SD_LIB_BLK_CURRENT;

// Ambigouties
uint8_t EN_RTC = 0x01;