To fix the hang problem

Dependencies:   FreescaleIAP SimpleDMA mbed-rtos mbed

Fork of CDMS_CODE by shubham c

Revision:
215:570251b23c7b
Parent:
213:867de6d350fa
Child:
216:93505a6f8db7
diff -r 867de6d350fa -r 570251b23c7b COM_POWER_OFF_TX.h
--- a/COM_POWER_OFF_TX.h	Sun Jul 03 09:26:42 2016 +0000
+++ b/COM_POWER_OFF_TX.h	Sun Jul 03 09:47:05 2016 +0000
@@ -1,136 +1,15 @@
-#define RESET_CDMS {\
-    Base_tc *RESET_tc = new Short_tc;\
-    RESET_tc->next_TC = NULL;\
-    PUTshort_or_long(RESET_tc,SHORT_TC_CODE);\
-    PUTcrc_pass(RESET_tc,0x1);\
-    PUTexec_status(RESET_tc,0);\
-    RESET_tc->TC_string[0] = 0x01;\
-    RESET_tc->TC_string[1] = 0x81;\
-    RESET_tc->TC_string[2] = 0x81;\
-    RESET_tc->TC_string[3] = 0x38;\
-    RESET_tc->TC_string[4] = 0;\
-    RESET_tc->TC_string[5] = 0;\
-    RESET_tc->TC_string[6] = 0;\
-    RESET_tc->TC_string[7] = 0;\
-    RESET_tc->TC_string[8] = 0;\
-    uint16_t crc16 = crc16_gen(RESET_tc->TC_string, 9);\
-    RESET_tc->TC_string[9]  = (crc16 & 0xFF00)>>8;\
-    RESET_tc->TC_string[10] = (crc16 & 0x00FF);\
-    Base_tm *tm_ptr = NULL;\
-    tm_ptr =  FCTN_CDMS_RLY_TMTC(RESET_tc);\
-    delete RESET_tc;\
-    /*DELETE THE TM AFTER USE*/\
-    Base_tm *del_tm = tm_ptr;\
-    while( del_tm != NULL ){\
-        Base_tm *temp = del_tm->next_TM;\
-        delete del_tm;\
-        del_tm = temp;\
-    }\
-}
-
-#define power_on_bae {\
-    Base_tc *power_on_BAE = new Short_tc;\
-    power_on_BAE->next_TC = NULL;\
-    PUTshort_or_long(power_on_BAE,SHORT_TC_CODE);\
-    PUTcrc_pass(power_on_BAE,0x1);\
-    PUTexec_status(power_on_BAE,0);\
-    power_on_BAE->TC_string[0] = 0x01;\
-    power_on_BAE->TC_string[1] = BAE_APID_SOURCE;\
-    power_on_BAE->TC_string[2] = BAE_SERVICE;\
-    power_on_BAE->TC_string[3] = BAE_POWER_ON_PID;\
-    power_on_BAE->TC_string[4] = 0;\
-    power_on_BAE->TC_string[5] = 0;\
-    power_on_BAE->TC_string[6] = 0;\
-    power_on_BAE->TC_string[7] = 0;\
-    power_on_BAE->TC_string[8] = 0;\
-    uint16_t crc16 = crc16_gen(power_on_BAE->TC_string, 9);\
-    power_on_BAE->TC_string[9]  = (crc16 & 0xFF00)>>8;\
-    power_on_BAE->TC_string[10] = (crc16 & 0x00FF);\
-    Base_tm *tm_ptr = NULL;\
-    tm_ptr =  FCTN_CDMS_RLY_TMTC(power_on_BAE);\
-    delete power_on_BAE;\
-    /*DELETE THE TM AFTER USE*/\
-    Base_tm *del_tm = tm_ptr;\
-    int overCount = 0;\
-    while( del_tm != NULL ){\
-        if( (overCount < TM_OVERFLOW_CONSTANT) ){\
-            Base_tm *temp = del_tm->next_TM;\
-            delete del_tm;\
-            del_tm = temp;\
-            ++overCount;\
-        }\
-        else{\
-            RESET_CDMS;\
-            break;\
-        }\
-    }\
-}
-
-#define resume_bcn {\
-    Base_tc *beacon_tc = new Long_tc;\
-    beacon_tc->next_TC = NULL;\
-    PUTshort_or_long(beacon_tc,LONG_TC_CODE);\
-    PUTcrc_pass(beacon_tc,0x1);\
-    PUTexec_status(beacon_tc,0);\
-    beacon_tc->TC_string[0] = 0x01;\
-    beacon_tc->TC_string[1] = BCN_APID_SOURCE;\
-    beacon_tc->TC_string[2] = BCN_SERVICE;\
-    beacon_tc->TC_string[3] = 0xE2;\
-    beacon_tc->TC_string[4] = 0x00;\
-    beacon_tc->TC_string[5] = 0;\
-    beacon_tc->TC_string[6] = 0;\
-    beacon_tc->TC_string[7] = 0;\
-    beacon_tc->TC_string[8] = 0;\
-    uint16_t crc16 = crc16_gen(beacon_tc->TC_string, 9);\
-    beacon_tc->TC_string[9]  = (crc16 & 0xFF00)>>8;\
-    beacon_tc->TC_string[10] = (crc16 & 0x00FF);\
-    for(int i = 11; i < 135; i++){\
-        beacon_tc->TC_string[i] = 0;\
-    }\
-    Base_tm *tm_ptr = NULL;\
-    tm_ptr =  FCTN_CDMS_RLY_TMTC(beacon_tc);\
-    delete beacon_tc;\
-    /*DELETE THE TM AFTER USE*/\
-    Base_tm *del_tm = tm_ptr;\
-    int overCount = 0;\
-    while( del_tm != NULL ){\
-        if( (overCount < TM_OVERFLOW_CONSTANT) ){\
-            Base_tm *temp = del_tm->next_TM;\
-            delete del_tm;\
-            del_tm = temp;\
-            ++overCount;\
-        }\
-        else{\
-            RESET_CDMS;\
-            break;\
-        }\
-    }\
-}
-
 #define COM_POWER_OFF_TX {\
     /*gPC.puts("Inside COM_POWER_OFF_TX\r\n");*/\
-    COM_TX_CNTRL = 0;\
+    /*PENDING: POWER OFF TRANSMITTER*/\
     RX1M.attach(&rx_read, Serial::RxIrq);\
     gFLAGS = gFLAGS & (~COM_MNG_TMTC_RUNNING_FLAG);\
-    RF_SW_CNTRL_BCN = 1;\
-    Thread::wait(25);\
-    RF_SW_CNTRL_BCN = 0;\
-    gFLAGS = gFLAGS | RF_SW_STATUS_FLAG;\
-    if( gFLAGS & COM_AUTO_POWER_OFF_BAE_FLAG ){\
-        power_on_bae;\
-        gFLAGS = gFLAGS | BAE_SW_EN_FLAG;\
-        gFLAGS & (~COM_AUTO_POWER_OFF_BAE_FLAG);\
-        resume_bcn;\
-    }\
-    else{\
-        if( gFLAGS & BAE_SW_EN_FLAG ){\
-            resume_bcn;\
-        }\
-    }\
+    /*PENDING: SWITCH RF RELAY TO BEACON*/\
+    /*PENDING: RF_SW_STATUS = RF_BCN*/\
+    /*PENDING: POWER ON BAE*/\
+    /*PENDING: SET BAE SW_EN_STATUS*/\
+    /*PENDING: RESUME BEACON*/\
     gFLAGS = gFLAGS & (~COM_PA_HOT_FLAG);\
-    gFLAGS = gFLAGS & (~COM_PA_OC_FLAG);\
     gCOM_PA_COOLING_TIMEOUT.detach();\
     gFLAGS = gFLAGS & (~COM_TX_FLAG);\
-    gFLAGS = gFLAGS & (~COM_SESSION_TIMEOUT_FLAG);\
-    /*gPC.puts("completed com_power_off tx\r\n");*/\
+    /*gPC.puts("ompleted com_power_off tx\r\n");*/\
 }
\ No newline at end of file