To fix the hang problem

Dependencies:   FreescaleIAP SimpleDMA mbed-rtos mbed

Fork of CDMS_CODE by shubham c

Revision:
251:c766afa330a3
Parent:
247:d0be0773b951
Child:
253:fd6696d91e74
Child:
255:642ea552ac77
--- a/CDMS_HK.h	Mon Jul 11 09:48:57 2016 +0000
+++ b/CDMS_HK.h	Mon Jul 11 12:30:41 2016 +0000
@@ -23,21 +23,28 @@
 DigitalOut SelectLinec1 (PIN77);
 DigitalOut SelectLinec0 (PIN76); // LSB of Select Lines
 
+Convolution CDMS_HEALTH;
+Convolution BAE_HEALTH;
+unsigned char CDMS_HK_FRAME[134] = {0};
+char BAE_HK[134] = {0};
+uint8_t convoluted_CDMS_HK[270];
+uint8_t interleave_CDMS_HK[288];
+uint8_t CDMS_HEALTH_FINAL[512] = {0};
+uint8_t convoluted_BAE_HK[270];
+uint8_t interleave_BAE_HK[288];
+uint8_t BAE_HEALTH_FINAL[512] = {0};
+unsigned char BAE_HK_FRAME[134] = {0};
+
+
+
 void FCTN_CDMS_HK_MAIN(void const *args)
 {
     while(1)
     {
     gPC.printf("Entering HK thread");
     gHK_THREAD->signal_wait(HK_SIGNAL);
-    unsigned char CDMS_HK_FRAME[134] = {0};
-    char BAE_HK[134] = {0};
-    uint8_t convoluted_CDMS_HK[270];
-    uint8_t interleave_CDMS_HK[288];
-    uint8_t CDMS_HEALTH_FINAL[512] = {0};
-    uint8_t convoluted_BAE_HK[270];
-    uint8_t interleave_BAE_HK[288];
-    uint8_t BAE_HEALTH_FINAL[512] = {0};
-    unsigned char BAE_HK_FRAME[134] = {0};
+
+    gMutex.lock();
 
     CDMS_HK_MAIN_STATUS = 0x01;
     CDMS_HK_MAIN_COUNTER++;
@@ -84,13 +91,12 @@
     uint16_t crc = crc16_gen(CDMS_HK_FRAME,132);      /*Adding CRC to TM frame*/
     CDMS_HK_FRAME[133] = crc;
     CDMS_HK_FRAME[132] = crc >> 8;
-
-    Convolution CDMS_HEALTH;
-    Convolution BAE_HEALTH;
-    //CDMS_HEALTH.convolutionEncode(CDMS_HK_FRAME , convoluted_CDMS_HK);
-    //CDMS_HEALTH.convolutionEncode(CDMS_HK_FRAME + 67, convoluted_CDMS_HK + 135);
-    //interleave(convoluted_CDMS_HK ,  interleave_CDMS_HK);
-    //interleave(convoluted_CDMS_HK +135, interleave_CDMS_HK + 144);
+    
+    exor(CDMS_HK_FRAME);
+    CDMS_HEALTH.convolutionEncode(CDMS_HK_FRAME , convoluted_CDMS_HK);
+    CDMS_HEALTH.convolutionEncode(CDMS_HK_FRAME + 67, convoluted_CDMS_HK + 135);
+    interleave(convoluted_CDMS_HK ,  interleave_CDMS_HK);
+    interleave(convoluted_CDMS_HK +135, interleave_CDMS_HK + 144);
     for(int i=0; i<288; i++)
         CDMS_HEALTH_FINAL[i] = interleave_CDMS_HK[i];
 
@@ -119,10 +125,11 @@
             crc = crc16_gen(BAE_HK_FRAME,132);               /*Adding CRC to TM frame*/
             BAE_HK_FRAME[133] = crc;
             BAE_HK_FRAME[132] = crc >> 8;
-            //BAE_HEALTH.convolutionEncode(BAE_HK_FRAME , convoluted_BAE_HK);
-            //BAE_HEALTH.convolutionEncode(BAE_HK_FRAME + 67, convoluted_BAE_HK + 135);
-            //interleave(convoluted_BAE_HK ,  interleave_BAE_HK);
-            //interleave(convoluted_BAE_HK +135, interleave_BAE_HK + 144);
+            exor(BAE_HK_FRAME);
+            BAE_HEALTH.convolutionEncode(BAE_HK_FRAME , convoluted_BAE_HK);
+            BAE_HEALTH.convolutionEncode(BAE_HK_FRAME + 67, convoluted_BAE_HK + 135);
+            interleave(convoluted_BAE_HK ,  interleave_BAE_HK);
+            interleave(convoluted_BAE_HK +135, interleave_BAE_HK + 144);
             for(int i=0; i<288; i++)
                 BAE_HEALTH_FINAL[i] = interleave_BAE_HK[i];
             //SD_WRITE(BAE_HEALTH_FINAL,FSC_CURRENT[5]+1,5);
@@ -146,6 +153,7 @@
     SC_HK_LBM_0[133] = crc >> 8;
     FCTN_I2C_WRITE((char *)SC_HK_LBM_0,135);
     gPC.printf("\rCompleted Beacon\n");
+    gMutex.unlock();
     }
 }