To fix the hang problem

Dependencies:   FreescaleIAP SimpleDMA mbed-rtos mbed

Fork of CDMS_CODE by shubham c

Revision:
103:b55559925dc1
Child:
104:a50ae79ca36e
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/CDMS_HK.h	Fri Jan 29 17:36:10 2016 +0000
@@ -0,0 +1,203 @@
+//#include "cdms_rtc.h"
+#include "pinconfig.h"
+
+void FCTN_CDMS_HK_MAIN();
+void FCTN_CDMS_HK();
+//extern uint8_t CDMS_HK_STATUS;
+//extern uint8_t Power_level;
+//extern uint8_t Att_level;
+//extern char CDMS_HK[8];
+
+Serial hk_cdms(USBTX, USBRX);
+
+AnalogIn TempInput(PIN27); // Input from Current Multiplexer
+AnalogIn CDMS_temp_sensor(PIN53);
+
+DigitalOut SelectLinec3 (PIN79); // MSB of Select Lines
+DigitalOut SelectLinec2 (PIN78);
+DigitalOut SelectLinec1 (PIN77);
+DigitalOut SelectLinec0 (PIN76); // LSB of Select Lines
+
+void FCTN_CDMS_HK_MAIN()
+{
+//    CDMS_HK_STATUS=(CDMS_HK_STATUS)|(HK_MAIN_STATUS);
+    FCTN_CDMS_HK;
+    hk_cdms.printf(" \r\nCDMS HK entered Verify COM RX RSSI >0.4 \r\n");
+   
+    int HK_I2C;
+    char BAE_HK[73];
+    FCTN_I2C_READ(BAE_HK,73);
+    printf("BAE_HK=%s",BAE_HK);
+    /*if(HK_I2C==0)
+    {
+        if(Power_level!=0)
+        {
+            printf("Update Power_level to 0 in Flash");
+        }
+        Att_level=0;
+        CDMS_HK_STATUS=(CDMS_HK_STATUS)|(HK_BAE_ERR_I2C);
+        CDMS_HK_STATUS=(CDMS_HK_STATUS)&(~(HK_MAIN_STATUS));
+    }**/
+        uint8_t CDMS_quant[17];
+        // printf("BAE HK is %s",BAE_HK);
+        for(int i=0;i<16;i++)
+        {
+           CDMS_quant[i]= (uint8_t)quant_data.temp_quant[i];
+        }
+        CDMS_quant[16]= (uint8_t)quant_data.CDMS_temp_quant;
+        uint64_t time=0x00;//replace with rtc function
+        char tree[61];
+        hk_cdms.printf("i am done\r\n");
+        uint8_t data[512];
+        for(int i=0;i<512;i++)
+        {
+            data[i]=0x00;
+        }
+        tree[0]=(char)(time>>(56))&(0xFF);
+        tree[1]=(char)(time>>(48))&(0xFF);
+        tree[2]=(char)(time>>(40))&(0xFF);
+        tree[3]=(char)(time>>(32))&(0xFF);
+        tree[4]=(char)(time>>(24))&(0xFF);
+        tree[5]=(char)(time>>(16))&(0xFF);
+        tree[6]=(char)(time>>(8))&(0xFF);
+        tree[7]=(char)(time)&(0xFF);
+        for(int i=0;i<73;i++)
+        {
+            tree[i+8]=BAE_HK[i];
+        }
+        printf("Hope u r alive \r\n");
+        for(int i=0;i<81;i++)
+        {
+            data[i]=(uint8_t)tree[i];
+        }
+        for(int i=81;i<98;i++)
+        {
+            data[i]=CDMS_quant[i];
+        }
+        for(int i=0;i<512;i++)
+        {
+            printf("%d",data[i]);
+        }
+        uint8_t fsc=FCTN_SD_MNGR(0x3);
+        printf("FSC where SD is written is %d\r\n",fsc);
+        int a=SD_WRITE(data,0x00000012,0x3);
+        printf("Result of writing is %d \r\n",a);
+        //BCN long frame ???
+        //CDMS_HK_STATUS=(CDMS_HK_STATUS)&(~(HK_MAIN_STATUS));
+        hk_cdms.printf("CDMS executed succesfully\r\n");
+}
+
+
+
+int quantiz(float start,float step,float x)
+{
+    int y=(x-start)/step;
+    if(y<=0)y=0;
+    if(y>=255)y=255;
+    return y;
+}
+
+
+
+void saveMin(char x,char y){
+    if(y<x){
+        x=y;
+    }
+
+}
+void saveMax(char x,char y){
+    if (y>x)
+    {
+       x=y;
+    }
+}
+void minMaxHkData(){
+   
+  
+   
+    if(firstCount==true){
+        for (int i = 0; i < 16; ++i){   
+        min_max_data.temp_min[i] = quant_data.temp_quant[i];
+        min_max_data.temp_max[i] = quant_data.temp_quant[i];
+        }
+
+        min_max_data.CDMS_temp_min=quant_data.CDMS_temp_quant;
+        min_max_data.CDMS_temp_max=quant_data.CDMS_temp_quant;
+   
+      
+    }
+    else {
+        for (int i = 0; i < 16; ++i)
+        {
+            saveMin(min_max_data.temp_min[i],quant_data.temp_quant[i]);
+            saveMax(min_max_data.temp_max[i],quant_data.temp_quant[i]);
+        }
+               
+        saveMin(min_max_data.CDMS_temp_min,quant_data.CDMS_temp_quant);
+        saveMax(min_max_data.CDMS_temp_max,quant_data.CDMS_temp_quant);
+           
+       
+    }  
+    firstCount=false;
+}
+
+void FCTN_CDMS_HK()
+{
+  
+    int Iteration=0;
+
+    SelectLinec0=0;
+    SelectLinec1=0;
+    SelectLinec2=0;
+    SelectLinec3=0;
+
+    for(Iteration=0; Iteration<16; Iteration++){
+
+        actual_data.temp_actual[Iteration]=TempInput.read();
+
+        SelectLinec0=!(SelectLinec0);
+        if(Iteration%2==1)
+            SelectLinec1=!(SelectLinec1);
+        if(Iteration%4==3)
+            SelectLinec2=!(SelectLinec2);
+        if(Iteration%8==7)
+             SelectLinec3=!(SelectLinec3);
+    }
+
+actual_data.CDMS_temp_actual=(-90.7*3.3*CDMS_temp_sensor.read())+190.1543;
+   
+    for(Iteration=0;Iteration<16;Iteration++){
+
+        if(Iteration<14){
+
+            actual_data.temp_actual[Iteration]=actual_data.temp_actual[Iteration]*3.3;
+            int resistance;      
+            
+            resistance=24000*actual_data.temp_actual[Iteration]/(3.3-actual_data.temp_actual[Iteration]);
+            if(actual_data.temp_actual[Iteration]>1.47)
+            {
+                actual_data.temp_actual[Iteration]=3694/log(24.032242*resistance);
+            }
+            else{
+               
+                actual_data.temp_actual[Iteration]=3365.4/log(7.60573*resistance);
+            }
+        }
+        else
+            actual_data.temp_actual[Iteration]=(-90.7*3.3*actual_data.temp_actual[Iteration])+190.1543;
+    }
+
+    for(Iteration=0;Iteration<16;Iteration++){
+
+        if(Iteration<14){
+
+            quant_data.temp_quant[Iteration]=quantiz(tstart_thermistor,tstep_thermistor,actual_data.temp_actual[Iteration]);
+        }
+        else
+            quant_data.temp_quant[Iteration]=quantiz(tstart,tstep,actual_data.temp_actual[Iteration]);
+    }
+
+    quant_data.CDMS_temp_quant=quantiz(tstart,tstep,actual_data.CDMS_temp_actual);
+
+    minMaxHkData();
+}
\ No newline at end of file