To fix the hang problem

Dependencies:   FreescaleIAP SimpleDMA mbed-rtos mbed

Fork of CDMS_CODE by shubham c

CDMS_HK.h

Committer:
shreeshas95
Date:
2016-01-29
Revision:
104:a50ae79ca36e
Parent:
103:b55559925dc1
Child:
105:5ce0337e7c15

File content as of revision 104:a50ae79ca36e:

//#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(void const *args)
{
//    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();
}