Team Fox / Mbed 2 deprecated BAE_QM_MAR9

Dependencies:   FreescaleIAP mbed-rtos mbed

Fork of workinQM_5thJan_azad by Team Fox

Committer:
lakshya
Date:
Mon Jul 04 04:29:59 2016 +0000
Revision:
33:76f2b8735501
Parent:
27:61c856be467e
Child:
34:1b41c34b12ea
Child:
39:670133e7ffd8
watch_dog to be implemented ; fine detailings

Who changed what in which revision?

UserRevisionLine numberNew contents of line
sakthipriya 0:7b4c00e3912f 1 #include "mbed.h"
sakthipriya 0:7b4c00e3912f 2 #include "rtos.h"
sakthipriya 0:7b4c00e3912f 3 #include "pin_config.h"
sakthipriya 0:7b4c00e3912f 4 #include "ACS.h"
sakthipriya 0:7b4c00e3912f 5 #include "EPS.h"
sakthipriya 0:7b4c00e3912f 6 #include "BCN.h"
sakthipriya 0:7b4c00e3912f 7 #include "TCTM.h"
Bragadeesh153 13:fb7facaf308b 8 #define tm_len 135
Bragadeesh153 13:fb7facaf308b 9 #define tc_len 11
sakthipriya 0:7b4c00e3912f 10 #define batt_heat_low 20
lakshya 22:950dbe9fbeb8 11 #define print 1
sakthipriya 9:194afacf7449 12
lakshya 33:76f2b8735501 13 #define DISABLE_WDOG 0;
lakshya 33:76f2b8735501 14
lakshya 33:76f2b8735501 15 void kick_WDOG()
lakshya 33:76f2b8735501 16 {
lakshya 33:76f2b8735501 17 SIM->SRVCOP=0x55;
lakshya 33:76f2b8735501 18 SIM->SRVCOP=0xAA;
lakshya 33:76f2b8735501 19 printf("\n\rkicked");
lakshya 33:76f2b8735501 20 }
lakshya 33:76f2b8735501 21
lakshya 33:76f2b8735501 22 void init_WDOG()
lakshya 33:76f2b8735501 23 {
lakshya 33:76f2b8735501 24 SIM->COPC=0x0C;
lakshya 33:76f2b8735501 25 kick_WDOG();
lakshya 33:76f2b8735501 26 }
lakshya 33:76f2b8735501 27
lakshya 20:949d13045431 28 DigitalOut time_wdog(PIN68);// for determining the time between code
lakshya 20:949d13045431 29
lakshya 19:79e69017c855 30 //**********************************************GLOBAL RTOS TIMER*********************************************************//
lakshya 19:79e69017c855 31 RtosTimer *BAE_STANDBY_STATUS_TIMER;
lakshya 19:79e69017c855 32
lakshya 20:949d13045431 33
lakshya 20:949d13045431 34 //bcn heater rtostimers=============================================================================
lakshya 20:949d13045431 35 RtosTimer *HTR_OFF=NULL;
lakshya 20:949d13045431 36 RtosTimer *HTR_CYCLE=NULL;
lakshya 20:949d13045431 37 RtosTimer *HTR_DLY=NULL;
lakshya 20:949d13045431 38
lakshya 33:76f2b8735501 39 //UPTIME TIMERS
lakshya 33:76f2b8735501 40 Timer BAE_uptime;
lakshya 33:76f2b8735501 41 Timer I2C_last;
lakshya 33:76f2b8735501 42
lakshya 33:76f2b8735501 43 void RETURN_UPTIME(float time, uint8_t *day,uint8_t *hour,uint8_t *min)
lakshya 33:76f2b8735501 44 {
lakshya 33:76f2b8735501 45 *day = time/(3600*24);
lakshya 33:76f2b8735501 46 time = (int)time % (3600*24);
lakshya 33:76f2b8735501 47 *hour = time/(3600);
lakshya 33:76f2b8735501 48 time = (int)time % (3600);
lakshya 33:76f2b8735501 49 *min = time/60;
lakshya 33:76f2b8735501 50 }
lakshya 33:76f2b8735501 51
lakshya 33:76f2b8735501 52 extern DigitalOut BTRY_HTR_ENABLE;
lakshya 20:949d13045431 53
lakshya 20:949d13045431 54 uint8_t HTR_CYCLE_COUNTS=0; //Count of heater cycles
lakshya 20:949d13045431 55 uint8_t HTR_CYCLE_START_DLY=0; //EPS_HTR_DLY_TIMER timer duration in minutes
lakshya 20:949d13045431 56 uint8_t HTR_ON_DURATION=0; //EPS_HTR_OFF timer duration in minutes
lakshya 20:949d13045431 57 uint16_t HTR_CYCLE_PERIOD =0; //EPS_HTR_CYCLE timer duration - MSB minutes, LSB seconds
lakshya 20:949d13045431 58 uint8_t HTR_CYCLE_COUNTER = 0 ;
lakshya 20:949d13045431 59
lakshya 20:949d13045431 60 uint32_t HTR_CYCLE_PERIOD_DECODER() //To convert HTR_CYCLE_PERIOD to millisecs
lakshya 20:949d13045431 61 {
lakshya 20:949d13045431 62 uint8_t PERIOD_mins, PERIOD_secs;
lakshya 20:949d13045431 63 //pc.printf("\n\r FCTN_HTR_CYCLE_PERIOD");
lakshya 20:949d13045431 64 PERIOD_secs = HTR_CYCLE_PERIOD;
lakshya 20:949d13045431 65 PERIOD_mins = HTR_CYCLE_PERIOD >> 8;
lakshya 20:949d13045431 66 uint32_t period = 1000*((int)PERIOD_mins * 60 + (int)PERIOD_secs);
lakshya 20:949d13045431 67
lakshya 20:949d13045431 68 return period;
lakshya 20:949d13045431 69 }
lakshya 20:949d13045431 70
lakshya 20:949d13045431 71 void FCTN_EPS_HTR_CYCLE(void const *arg)
lakshya 20:949d13045431 72 {
lakshya 33:76f2b8735501 73 BTRY_HTR_ENABLE = 1;//assuming its active high check
lakshya 20:949d13045431 74 //pc.printf("\n\r on kar diya");
lakshya 20:949d13045431 75 //pc.printf("\n\r FCTN_EPS_HTR_CYCLE");
lakshya 20:949d13045431 76 //tim.reset();
lakshya 20:949d13045431 77 //tim.start();
lakshya 20:949d13045431 78 //HTR_OFF->start(((uint32_t)HTR_ON_DURATION)*1000);
lakshya 20:949d13045431 79 HTR_OFF->start((int)HTR_ON_DURATION*60*1000);
lakshya 20:949d13045431 80 }
lakshya 20:949d13045431 81
lakshya 20:949d13045431 82 void FCTN_EPS_HTR_DLY(void const* arg)
lakshya 20:949d13045431 83 {
lakshya 33:76f2b8735501 84 BTRY_HTR_ENABLE = 1;
lakshya 20:949d13045431 85 HTR_CYCLE_COUNTER = 0;
lakshya 20:949d13045431 86 HTR_OFF->start(((int)HTR_ON_DURATION*60*1000));
lakshya 20:949d13045431 87 //pc.printf("\n\r on kar diya");
lakshya 20:949d13045431 88 //pc.printf("\n\r FCTN_EPS_HTR_DLY");
lakshya 20:949d13045431 89 //tim.start();
lakshya 20:949d13045431 90 HTR_CYCLE->start((uint32_t)HTR_CYCLE_PERIOD_DECODER);
lakshya 20:949d13045431 91 }
lakshya 20:949d13045431 92
lakshya 20:949d13045431 93 void FCTN_EPS_HTR_OFF(void const *arg)
lakshya 20:949d13045431 94 {
lakshya 33:76f2b8735501 95 BTRY_HTR_ENABLE = 0;
lakshya 20:949d13045431 96 //tim.stop();
lakshya 20:949d13045431 97 //pc.printf("\n\r off kar diya");
lakshya 20:949d13045431 98 //pc.printf("\n\r the timer value is %f",tim.read());
lakshya 20:949d13045431 99 //tim.reset();
lakshya 20:949d13045431 100 if(HTR_CYCLE_COUNTS != 0xFF)
lakshya 20:949d13045431 101 {
lakshya 20:949d13045431 102 HTR_CYCLE_COUNTER++;
lakshya 20:949d13045431 103 if( HTR_CYCLE_COUNTER == (int)HTR_CYCLE_COUNTS)//HTR_CYCLE_COUNTS )
lakshya 20:949d13045431 104 HTR_CYCLE->stop();
lakshya 20:949d13045431 105 }
lakshya 20:949d13045431 106 }
lakshya 20:949d13045431 107
lakshya 20:949d13045431 108 //====================================================================================================
lakshya 20:949d13045431 109
lakshya 20:949d13045431 110 //fctn to pass the data to bcn long type
lakshya 33:76f2b8735501 111 //uint8_t CDMS_HK_data[134]; now implemented as LONG_HK_data[0][134];
lakshya 33:76f2b8735501 112 uint8_t LONG_HK_data[2][134];
lakshya 20:949d13045431 113 void FCTN_CDMS_HK_TC(uint8_t tc[])
lakshya 20:949d13045431 114 {
lakshya 20:949d13045431 115 for(int i=0;i<134;i++)
lakshya 33:76f2b8735501 116 LONG_HK_data[0][i] = tc[i];
lakshya 20:949d13045431 117 }
lakshya 20:949d13045431 118
lakshya 20:949d13045431 119 uint8_t BAE_STANDBY=0x00;// as Bcn Acs Eps last three bits BAE order , 1 refer to switch off.
lakshya 20:949d13045431 120
lakshya 19:79e69017c855 121 void BAE_STANDBY_STATUS_RESET(const void* arg)
lakshya 19:79e69017c855 122 {
lakshya 19:79e69017c855 123 printf("\n\rBAE standby reset to 0x00");
lakshya 19:79e69017c855 124 BAE_STANDBY=0x00;
lakshya 19:79e69017c855 125 }
lakshya 19:79e69017c855 126
lakshya 20:949d13045431 127
lakshya 19:79e69017c855 128 /*no problem in first stopping and then starting even when for the first time*/
lakshya 19:79e69017c855 129 void BAE_STANDBY_TIMER_RESET()
lakshya 19:79e69017c855 130 {
lakshya 19:79e69017c855 131 BAE_STANDBY_STATUS_TIMER->stop();
lakshya 19:79e69017c855 132 BAE_STANDBY_STATUS_TIMER->start(30000);//20 min ie 20*60=1200 sec or 1200,000 milisec but for testing setting it to 30sec
lakshya 19:79e69017c855 133 }
lakshya 19:79e69017c855 134
lakshya 20:949d13045431 135 extern void gen_I_TM();
lakshya 20:949d13045431 136
lakshya 20:949d13045431 137 //*************** FLAGS ****************************//
sakthipriya 0:7b4c00e3912f 138 uint32_t BAE_STATUS = 0x00000000;
sakthipriya 0:7b4c00e3912f 139 uint32_t BAE_ENABLE = 0xFFFFFFFF;
sakthipriya 0:7b4c00e3912f 140
sakthipriya 5:bb592f3185cc 141 //i2c//
sakthipriya 5:bb592f3185cc 142 char data_send_flag = 'h';
lakshya 20:949d13045431 143 //uint8_t BAE_MNG_I2C_STATUS = 0;
sakthipriya 5:bb592f3185cc 144
lakshya 20:949d13045431 145 //BAE
lakshya 19:79e69017c855 146 uint8_t BAE_INIT_STATUS=0;
lakshya 20:949d13045431 147 uint8_t BAE_MNG_I2C_STATUS=0;
sakthipriya 0:7b4c00e3912f 148
sakthipriya 9:194afacf7449 149
lakshya 20:949d13045431 150 //ACS
sakthipriya 9:194afacf7449 151 uint8_t ACS_INIT_STATUS = 0;
sakthipriya 9:194afacf7449 152 uint8_t ACS_DATA_ACQ_STATUS = 0;
lakshya 20:949d13045431 153 uint8_t ACS_ATS_STATUS = 0x73;
sakthipriya 9:194afacf7449 154 uint8_t ACS_MAIN_STATUS = 0;
sakthipriya 9:194afacf7449 155 uint8_t ACS_STATUS = 0;
lakshya 20:949d13045431 156 uint8_t ACS_DETUMBLING_ALGO_TYPE = 0;
sakthipriya 9:194afacf7449 157 uint8_t ACS_ATS_ENABLE = 1;
sakthipriya 9:194afacf7449 158 uint8_t ACS_DATA_ACQ_ENABLE = 1;
lakshya 33:76f2b8735501 159 uint8_t ACS_STATE = 8;
lakshya 19:79e69017c855 160
lakshya 20:949d13045431 161 extern uint16_t ACS_MM_X_COMSN;
lakshya 20:949d13045431 162 extern uint16_t ACS_MM_Y_COMSN;
lakshya 20:949d13045431 163 extern uint16_t ACS_MG_X_COMSN;
lakshya 20:949d13045431 164 extern uint16_t ACS_MG_Y_COMSN;
lakshya 20:949d13045431 165 extern uint16_t ACS_MM_Z_COMSN;
lakshya 20:949d13045431 166 extern uint16_t ACS_MG_Z_COMSN;
lakshya 20:949d13045431 167
lakshya 27:61c856be467e 168 extern uint8_t controlmode_mms;
lakshya 27:61c856be467e 169
lakshya 20:949d13045431 170 //BCN
lakshya 18:3662058a7c10 171 extern uint8_t BCN_FEN;
lakshya 18:3662058a7c10 172 extern void FCTN_BCN_FEN(void const *args);
lakshya 20:949d13045431 173 extern void LONG_BCN_DATA(uint8_t* );
lakshya 20:949d13045431 174 extern uint16_t gencrc16_for_me();//for calculating the crc of baehk data before sendingkk as including crc causes problem
lakshya 33:76f2b8735501 175 extern DigitalOut BTRY_HTR_ENABLE;
lakshya 20:949d13045431 176
lakshya 20:949d13045431 177
lakshya 18:3662058a7c10 178 Timeout timeout_bcn;
lakshya 19:79e69017c855 179 /*long beacon data/sending*/
lakshya 19:79e69017c855 180 /*be sure it is created in bcn.cpp*/
sakthipriya 0:7b4c00e3912f 181
lakshya 20:949d13045431 182 //EPS
sakthipriya 9:194afacf7449 183 uint8_t EPS_INIT_STATUS = 0;
sakthipriya 9:194afacf7449 184 uint8_t EPS_BATTERY_GAUGE_STATUS = 0;
sakthipriya 9:194afacf7449 185 uint8_t EPS_MAIN_STATUS = 0;
lakshya 33:76f2b8735501 186 uint8_t EPS_BTRY_TMP_STATUS = 0;/// to be diss
sakthipriya 9:194afacf7449 187 uint8_t EPS_STATUS = 7; //invalid status
lakshya 33:76f2b8735501 188 uint8_t EPS_BTRY_HTR = 0;
sakthipriya 9:194afacf7449 189
lakshya 20:949d13045431 190 uint8_t EPS_BTRY_HTR_AUTO = 1;
lakshya 20:949d13045431 191 extern uint8_t EPS_SOC_LEVEL_12;
lakshya 20:949d13045431 192 extern uint8_t EPS_SOC_LEVEL_23;
lakshya 20:949d13045431 193 extern uint8_t EPS_BAT_TEMP_LOW;
lakshya 20:949d13045431 194 extern uint8_t EPS_BAT_TEMP_HIGH;
lakshya 20:949d13045431 195 extern uint8_t EPS_BAT_TEMP_DEFAULT;
lakshya 33:76f2b8735501 196 float EPS_BTRY_TMP_AVG;
lakshya 33:76f2b8735501 197 extern DigitalOut BTRY_HTR_ENABLE;
lakshya 33:76f2b8735501 198
lakshya 33:76f2b8735501 199 //extern void FCTN_BATTERYGAUGE_MAIN(float*Battery_parameters);
lakshya 20:949d13045431 200
lakshya 20:949d13045431 201
lakshya 20:949d13045431 202 //**********************GLOBAL DECLARATIONS********************************//
lakshya 20:949d13045431 203
lakshya 20:949d13045431 204 //CDMS
lakshya 20:949d13045431 205 //eps cdms fault
lakshya 20:949d13045431 206 uint8_t CDMS_SW_STATUS;
lakshya 20:949d13045431 207 DigitalOut CDMS_OC_FAULT(PIN79);
lakshya 20:949d13045431 208 bool CDMS_SW_ENABLE;
lakshya 20:949d13045431 209 int CDMS_FAULT_COUNTER = 0;
lakshya 20:949d13045431 210
lakshya 20:949d13045431 211
lakshya 20:949d13045431 212 //BAE new hk structure- everything has to changed based on this
lakshya 20:949d13045431 213 char BAE_chardata[74];
lakshya 33:76f2b8735501 214 // uint8_t LONG_HK_data[2][134];
lakshya 33:76f2b8735501 215 //uint8_t BAE_HK_data[134]; now known as LONG_HK_data[1][i];
lakshya 20:949d13045431 216 uint8_t BAE_RESET_COUNTER;// INITIALIZATION or do you want to initialize evertime the main is reset? or is it same
lakshya 20:949d13045431 217 uint16_t BAE_I2C_COUNTER = 0;//change/apply
lakshya 20:949d13045431 218 //uint8_t BAE_STANDBY=0x00;// as Bcn Acs Eps last three bits BAE order , 1 refer to switch off.
lakshya 20:949d13045431 219
lakshya 20:949d13045431 220 //BCN
lakshya 20:949d13045431 221 //uint16_t BCN_TX_MAIN_COUNTER = 0;
lakshya 20:949d13045431 222 uint8_t BCN_LONG_MSG_TYPE = 1;
sakthipriya 0:7b4c00e3912f 223
lakshya 20:949d13045431 224 DigitalOut BCN_TX_OC_FAULT(PIN80);
lakshya 20:949d13045431 225 int BCN_TX_FAULT_COUNTER;
lakshya 20:949d13045431 226
lakshya 20:949d13045431 227 //ACS
lakshya 20:949d13045431 228 uint16_t ACS_MAIN_COUNTER = 0;
lakshya 20:949d13045431 229
lakshya 20:949d13045431 230 //eps hw faults
lakshya 20:949d13045431 231 //uint8_t ACS_TR_Z_SW_STATUS;
lakshya 20:949d13045431 232 DigitalOut ACS_TR_Z_ENABLE(PIN40);
lakshya 20:949d13045431 233 DigitalOut ACS_TR_Z_OC_FAULT(PIN91);
lakshya 20:949d13045431 234 DigitalOut ACS_TR_Z_FAULT(PIN89); //Driver IC fault
lakshya 20:949d13045431 235 int ACS_TR_Z_FAULT_COUNTER = 0;
sakthipriya 0:7b4c00e3912f 236
lakshya 20:949d13045431 237 //uint8_t ACS_TR_XY_SW_STATUS;
lakshya 20:949d13045431 238 DigitalOut ACS_TR_XY_ENABLE(PIN71);
lakshya 20:949d13045431 239 DigitalOut ACS_TR_XY_OC_FAULT(PIN72);
lakshya 20:949d13045431 240 DigitalOut ACS_TR_XY_FAULT(PIN83); //Driver IC fault
lakshya 20:949d13045431 241 int ACS_TR_XY_FAULT_COUNTER = 0;
lakshya 20:949d13045431 242
lakshya 20:949d13045431 243 //bool ACS_ATS1_ENABLE;
lakshya 20:949d13045431 244 DigitalOut ACS_ATS1_OC_FAULT(PIN97);
lakshya 20:949d13045431 245 int ACS_ATS1_FAULT_COUNTER = 0;
lakshya 20:949d13045431 246
lakshya 20:949d13045431 247 //bool ACS_ATS2_ENABLE;
lakshya 20:949d13045431 248 DigitalOut ACS_ATS2_OC_FAULT(PIN5);
lakshya 20:949d13045431 249 int ACS_ATS2_FAULT_COUNTER;
lakshya 20:949d13045431 250
lakshya 20:949d13045431 251 //EPS
lakshya 20:949d13045431 252 int EPS_MAIN_COUNTER = 0;
lakshya 20:949d13045431 253
lakshya 20:949d13045431 254
lakshya 20:949d13045431 255 //GEN DEC FOR TESTING or to be DECIDED whre to ASSIGN HERE
sakthipriya 0:7b4c00e3912f 256 const int addr = 0x20; //slave address
sakthipriya 0:7b4c00e3912f 257 Timer t_rfsilence;
sakthipriya 0:7b4c00e3912f 258 Timer t_start;
lakshya 19:79e69017c855 259 /*defined as of now to check execution time*/
lakshya 19:79e69017c855 260 /*remember to remove them*/
lakshya 19:79e69017c855 261 Timer t_acs;
lakshya 19:79e69017c855 262 Timer t_eps;
lakshya 20:949d13045431 263 //Timer t_tc;
sakthipriya 7:a46a1dee4497 264 Timer t_tm;
sakthipriya 0:7b4c00e3912f 265 Serial pc(USBTX, USBRX);
sakthipriya 0:7b4c00e3912f 266 int power_flag_dummy=2;
sakthipriya 0:7b4c00e3912f 267 float data[6];
sakthipriya 0:7b4c00e3912f 268
lakshya 20:949d13045431 269
lakshya 20:949d13045431 270 //*************EXTERN PARA********
lakshya 20:949d13045431 271
lakshya 20:949d13045431 272 //BAE
lakshya 20:949d13045431 273
sakthipriya 1:446a959e36ce 274 extern BAE_HK_actual actual_data;
sakthipriya 1:446a959e36ce 275 extern BAE_HK_quant quant_data;
sakthipriya 1:446a959e36ce 276 extern BAE_HK_min_max bae_HK_minmax;
sakthipriya 1:446a959e36ce 277 extern BAE_HK_arch arch_data;
sakthipriya 0:7b4c00e3912f 278
lakshya 20:949d13045431 279
lakshya 20:949d13045431 280 //BCN
lakshya 20:949d13045431 281 extern uint8_t BCN_FEN;
lakshya 20:949d13045431 282 extern uint8_t BCN_TX_SW_STATUS;
lakshya 20:949d13045431 283 extern uint8_t BCN_SPND_TX;
lakshya 20:949d13045431 284
lakshya 20:949d13045431 285
lakshya 20:949d13045431 286 //TCTM
lakshya 20:949d13045431 287 extern uint8_t telemetry[135];
lakshya 20:949d13045431 288
lakshya 20:949d13045431 289
lakshya 20:949d13045431 290 //ACS
lakshya 20:949d13045431 291 extern uint8_t ACS_TR_Z_SW_STATUS;
lakshya 20:949d13045431 292 extern uint8_t ACS_TR_XY_SW_STATUS;
lakshya 20:949d13045431 293 extern float gyro_data[3];
lakshya 20:949d13045431 294 extern float mag_data[3];
lakshya 20:949d13045431 295 extern float moment[3];
lakshya 20:949d13045431 296 extern float b_old[3]; // Unit: Tesla
lakshya 20:949d13045431 297 extern float db[3];
lakshya 20:949d13045431 298 extern uint8_t flag_firsttime;
lakshya 20:949d13045431 299 extern uint8_t ACS_MAG_TIME_DELAY;
lakshya 20:949d13045431 300 extern uint8_t ACS_DEMAG_TIME_DELAY;
lakshya 20:949d13045431 301 extern uint16_t ACS_Z_FIXED_MOMENT;
lakshya 20:949d13045431 302
sakthipriya 5:bb592f3185cc 303 int write_ack = 1;
sakthipriya 5:bb592f3185cc 304 int read_ack = 1;
sakthipriya 0:7b4c00e3912f 305 char telecommand[tc_len];
lakshya 20:949d13045431 306
sakthipriya 5:bb592f3185cc 307
sakthipriya 5:bb592f3185cc 308 bool pf1check = 0;
sakthipriya 5:bb592f3185cc 309 bool pf2check = 0;
sakthipriya 5:bb592f3185cc 310 bool if1check = 0;
lakshya 14:a9588f443f1a 311 bool if2check = 0;
sakthipriya 0:7b4c00e3912f 312
lakshya 20:949d13045431 313 //ASSIGNING PINS//
sakthipriya 9:194afacf7449 314 DigitalOut ATS1_SW_ENABLE(PTC0); // enable of att sens2 switch
sakthipriya 9:194afacf7449 315 DigitalOut ATS2_SW_ENABLE(PTC16); // enable of att sens switch
sakthipriya 0:7b4c00e3912f 316 InterruptIn irpt_4m_mstr(PIN38); //I2c interrupt from CDMS
sakthipriya 0:7b4c00e3912f 317 DigitalOut irpt_2_mstr(PIN4); //I2C interrupt to CDMS
lakshya 14:a9588f443f1a 318 I2CSlave slave (PIN1,PIN2);///pin1 pin2
lakshya 20:949d13045431 319 //DigitalOut batt_heat(PIN96);
sakthipriya 0:7b4c00e3912f 320
sakthipriya 9:194afacf7449 321 //ATS1_SW_ENABLE = 0;
sakthipriya 0:7b4c00e3912f 322 PwmOut PWM1(PIN93); //x //Functions used to generate PWM signal
sakthipriya 0:7b4c00e3912f 323 PwmOut PWM2(PIN94); //y
sakthipriya 0:7b4c00e3912f 324 PwmOut PWM3(PIN95); //z //PWM output comes from pins p6
sakthipriya 0:7b4c00e3912f 325
sakthipriya 5:bb592f3185cc 326 //........faults
sakthipriya 5:bb592f3185cc 327 //Polled Faults
sakthipriya 5:bb592f3185cc 328 DigitalIn pf1(PIN5);//Attitude Sensor 1 OC bar fault signal
sakthipriya 5:bb592f3185cc 329 DigitalIn pf2(PIN97);//Attitude Sensor 2 OC bar fault signal
sakthipriya 5:bb592f3185cc 330 DigitalIn pf3(PIN83);//Fault Bar for TRXY driver
sakthipriya 5:bb592f3185cc 331
Bragadeesh153 13:fb7facaf308b 332 DigitalOut TRXY_SW(PIN71); //TR XY Switch
Bragadeesh153 13:fb7facaf308b 333 DigitalOut DRV_Z_EN(PIN88); //Sleep pin of driver z
sakthipriya 5:bb592f3185cc 334 DigitalOut TRZ_SW(PIN40); //TR Z Switch
lakshya 19:79e69017c855 335 DigitalOut CDMS_RESET(PIN7,1); // CDMS RESET
sakthipriya 5:bb592f3185cc 336 DigitalOut BCN_SW(PIN14); //Beacon switch
Bragadeesh153 13:fb7facaf308b 337 DigitalOut DRV_XY_EN(PIN82);
sakthipriya 0:7b4c00e3912f 338
lakshya 19:79e69017c855 339
lakshya 20:949d13045431 340
lakshya 20:949d13045431 341 //================================================================================
lakshya 20:949d13045431 342 //default flash array some filler bits added (detail in MMS file)
lakshya 27:61c856be467e 343 uint32_t ARR_INITIAL_VAL[8]={0x73582600,0x505A4141,0x1A1A1400,0x00000000,0x00000000,0x00000000,0xCBA20000,0x00000000};//to be done
lakshya 20:949d13045431 344
lakshya 20:949d13045431 345 void FLASH_INI()
lakshya 20:949d13045431 346 {
lakshya 20:949d13045431 347 uint32_t read[8];
lakshya 20:949d13045431 348 for(int i=0;i<8;i++)
lakshya 20:949d13045431 349 {
lakshya 20:949d13045431 350 read[i] = FCTN_BAE_RD_FLASH_ENTITY(i);
lakshya 22:950dbe9fbeb8 351 //printf("\n\r val is read after starting %x ",read[i]);
lakshya 20:949d13045431 352 }
lakshya 20:949d13045431 353
lakshya 20:949d13045431 354 if(read[0] == -1)
lakshya 20:949d13045431 355 for(int j=0;j<8;j++)
lakshya 20:949d13045431 356 {
lakshya 20:949d13045431 357 FCTN_BAE_WR_FLASH(j,ARR_INITIAL_VAL[j]);
lakshya 20:949d13045431 358 }
lakshya 20:949d13045431 359 else
lakshya 20:949d13045431 360 {
lakshya 20:949d13045431 361 for(int j=0;j<8;j++)
lakshya 20:949d13045431 362 {
lakshya 20:949d13045431 363 read[j] = FCTN_BAE_RD_FLASH_ENTITY(j);
lakshya 20:949d13045431 364 }
lakshya 20:949d13045431 365 ACS_ATS_STATUS = read[0]>>24;
lakshya 20:949d13045431 366 ACS_TR_XY_SW_STATUS = ((uint8_t)(read[0]>>22))&0x03;
lakshya 20:949d13045431 367 ACS_TR_Z_SW_STATUS = (read[0]>>20)&0x03;
lakshya 27:61c856be467e 368 ACS_STATE = (read[0]>>16)&0x0F;
lakshya 27:61c856be467e 369 ACS_DETUMBLING_ALGO_TYPE = (read[0]>>15)&0x01;
lakshya 27:61c856be467e 370 BCN_TX_SW_STATUS = ((uint8_t)(read[0]>>13))&0x03;
lakshya 27:61c856be467e 371 BCN_SPND_TX = ((uint8_t)(read[0]>>12))&0x01;
lakshya 27:61c856be467e 372 BCN_FEN = ((uint8_t)(read[0]>>11))&0x01;
lakshya 27:61c856be467e 373 BCN_LONG_MSG_TYPE = ((uint8_t)(read[0]>>10))&0x01;
lakshya 27:61c856be467e 374 EPS_BTRY_HTR_AUTO = ((uint8_t)(read[0]>>9))&0x03;//EPS_BATTERY_HEATER_ENABLE
lakshya 27:61c856be467e 375 //now one spares in telemetry[5]
lakshya 20:949d13045431 376
lakshya 20:949d13045431 377 //updating the reset counter
lakshya 20:949d13045431 378 BAE_RESET_COUNTER = ((uint8_t)(read[0]))+1;
lakshya 20:949d13045431 379 read[0]=(read[0]&0xffffff00) | (uint32_t)BAE_RESET_COUNTER;
lakshya 20:949d13045431 380 FCTN_BAE_WR_FLASH(0,read[0]);
lakshya 20:949d13045431 381
lakshya 20:949d13045431 382
lakshya 20:949d13045431 383 EPS_SOC_LEVEL_12 = (uint8_t)(read[1]>>24);
lakshya 20:949d13045431 384 EPS_SOC_LEVEL_23 = (uint8_t)(read[1]>>16);
lakshya 20:949d13045431 385 ACS_MAG_TIME_DELAY = (uint8_t)(read[1]>>8);
lakshya 20:949d13045431 386 ACS_DEMAG_TIME_DELAY = (uint8_t)read[1];
lakshya 20:949d13045431 387
lakshya 20:949d13045431 388 EPS_BAT_TEMP_LOW = (uint8_t)(read[2]>>24);
lakshya 20:949d13045431 389 EPS_BAT_TEMP_HIGH = (uint8_t)(read[2]>>16);
lakshya 20:949d13045431 390 EPS_BAT_TEMP_DEFAULT = (uint8_t)(read[2]>>8);
lakshya 20:949d13045431 391
lakshya 20:949d13045431 392 ACS_MM_X_COMSN = (uint16_t)(read[3]>>16);
lakshya 20:949d13045431 393 ACS_MM_Y_COMSN = (uint16_t)read[3];
lakshya 20:949d13045431 394
lakshya 20:949d13045431 395 ACS_MG_X_COMSN = (uint16_t)(read[4]>>16);
lakshya 20:949d13045431 396 ACS_MG_Y_COMSN = (uint16_t)read[4];
lakshya 20:949d13045431 397
lakshya 20:949d13045431 398 ACS_MM_Z_COMSN = (uint16_t)(read[5]>>16);
lakshya 20:949d13045431 399 ACS_MG_Z_COMSN = (uint16_t)read[5];
lakshya 20:949d13045431 400
lakshya 20:949d13045431 401 ACS_Z_FIXED_MOMENT = (uint16_t)(read[6]>>16);//assignvalues
lakshya 20:949d13045431 402
lakshya 20:949d13045431 403 }
lakshya 20:949d13045431 404
lakshya 20:949d13045431 405 }
lakshya 20:949d13045431 406 //================================================================================
lakshya 20:949d13045431 407
lakshya 20:949d13045431 408
lakshya 20:949d13045431 409
sakthipriya 0:7b4c00e3912f 410 /*****************************************************************Threads USed***********************************************************************************/
sakthipriya 0:7b4c00e3912f 411 Thread *ptr_t_i2c;
sakthipriya 0:7b4c00e3912f 412
lakshya 19:79e69017c855 413
sakthipriya 0:7b4c00e3912f 414 /*********************************************************FCTN HEADERS***********************************************************************************/
sakthipriya 0:7b4c00e3912f 415 void FCTN_ISR_I2C();
sakthipriya 0:7b4c00e3912f 416 void FCTN_TM();
sakthipriya 3:07e15677a75c 417 void F_ACS();
sakthipriya 3:07e15677a75c 418 void F_EPS();
sakthipriya 3:07e15677a75c 419 void F_BCN();
sakthipriya 0:7b4c00e3912f 420
lakshya 20:949d13045431 421 //I2C
lakshya 20:949d13045431 422 uint32_t pdir_tc1,pdir_tc2,pdir_tm1,pdir_tm2,pdir_ss1,pdir_ss2;//variables used to verify i2c working
lakshya 20:949d13045431 423 uint16_t crc16_check;
lakshya 20:949d13045431 424 void I2C_busreset()
lakshya 20:949d13045431 425 {
lakshya 20:949d13045431 426 PORTE->PCR[1] &= 0xfffffffb;
lakshya 20:949d13045431 427 PORTE->PCR[0] &= 0xfffffffb;
lakshya 20:949d13045431 428 I2C1->C1 &= 0x7f;
lakshya 20:949d13045431 429 SIM->SCGC4 &= 0xffffff7f;
lakshya 20:949d13045431 430 SIM->SCGC4 |= 0x00000080;
lakshya 20:949d13045431 431 I2C1->C1 |= 0x80;
lakshya 20:949d13045431 432 PORTE->PCR[1] |= 0x00000004;
lakshya 20:949d13045431 433 PORTE->PCR[0] |= 0x00000004;
lakshya 20:949d13045431 434 Thread::wait(1);
lakshya 20:949d13045431 435 }
lakshya 20:949d13045431 436
sakthipriya 0:7b4c00e3912f 437 //*******************************************ACS THREAD**************************************************//
sakthipriya 5:bb592f3185cc 438 uint8_t iterP1;
sakthipriya 5:bb592f3185cc 439 uint8_t iterP2;
sakthipriya 5:bb592f3185cc 440 uint8_t iterI1;
sakthipriya 5:bb592f3185cc 441 uint8_t iterI2;
sakthipriya 0:7b4c00e3912f 442
lakshya 20:949d13045431 443 //FLOAT TO UINT_8 CONVERSION FUNCTION
lakshya 20:949d13045431 444 extern uint8_t float_to_uint8(float min,float max,float val);
lakshya 20:949d13045431 445
lakshya 20:949d13045431 446 #define print 0
lakshya 20:949d13045431 447
sakthipriya 3:07e15677a75c 448 void F_ACS()
sakthipriya 0:7b4c00e3912f 449 {
lakshya 20:949d13045431 450 ACS_MAIN_COUNTER++;
lakshya 20:949d13045431 451 //time_wdog = 1;
lakshya 20:949d13045431 452 pc.printf("Entered ACS.\n\r");
lakshya 20:949d13045431 453
lakshya 20:949d13045431 454 ACS_MAIN_STATUS = 1; //set ACS_MAIN_STATUS flag
lakshya 20:949d13045431 455 FLAG();
sakthipriya 5:bb592f3185cc 456
lakshya 20:949d13045431 457 ACS_MAIN_COUNTER+=1;
sakthipriya 3:07e15677a75c 458
sakthipriya 0:7b4c00e3912f 459 PWM1 = 0; //clear pwm pins
sakthipriya 0:7b4c00e3912f 460 PWM2 = 0; //clear pwm pins
sakthipriya 0:7b4c00e3912f 461 PWM3 = 0; //clear pwm pins
lakshya 20:949d13045431 462
lakshya 20:949d13045431 463 wait_ms(ACS_DEMAG_TIME_DELAY);
lakshya 20:949d13045431 464 ACS_DATA_ACQ_STATUS = (uint8_t) FCTN_ATS_DATA_ACQ();
sakthipriya 0:7b4c00e3912f 465
lakshya 20:949d13045431 466 #if print
lakshya 20:949d13045431 467 printing the angular speed and magnetic field values
lakshya 20:949d13045431 468 pc.printf("gyro values\n\r");
lakshya 19:79e69017c855 469 for(int i=0; i<3; i++)
lakshya 20:949d13045431 470 {
lakshya 20:949d13045431 471 printf("%f\n\r",actual_data.AngularSpeed_actual[i]);
lakshya 20:949d13045431 472 }
lakshya 20:949d13045431 473
lakshya 19:79e69017c855 474 pc.printf("mag values\n\r");
lakshya 19:79e69017c855 475 for(int i=0; i<3; i++)
lakshya 20:949d13045431 476 {
lakshya 20:949d13045431 477 pc.printf("%f\n\r",actual_data.Bvalue_actual[i]);
lakshya 20:949d13045431 478 }
lakshya 20:949d13045431 479 #endif
lakshya 20:949d13045431 480
lakshya 20:949d13045431 481 for(int i=0;i<3;i++)
lakshya 19:79e69017c855 482 {
lakshya 20:949d13045431 483 mag_data[i] = actual_data.Bvalue_actual[i]/1000000;
lakshya 20:949d13045431 484 gyro_data[i] = actual_data.AngularSpeed_actual[i]*3.14159/180;
lakshya 20:949d13045431 485 }
lakshya 20:949d13045431 486
lakshya 20:949d13045431 487 if(ACS_STATE == 0) // check ACS_STATE = ACS_CONTROL_OFF?
lakshya 20:949d13045431 488 {
lakshya 20:949d13045431 489 #if print
lakshya 20:949d13045431 490 printf("\n\r acs control off\n");
lakshya 20:949d13045431 491 #endif
lakshya 20:949d13045431 492 ACS_STATUS = 0; // set ACS_STATUS = ACS_CONTROL_OFF
lakshya 20:949d13045431 493 ACS_MAIN_STATUS = 0;
lakshya 20:949d13045431 494 return;
lakshya 20:949d13045431 495 }
lakshya 20:949d13045431 496 else if(actual_data.power_mode<=2)
lakshya 20:949d13045431 497 {
lakshya 20:949d13045431 498 #if print
lakshya 20:949d13045431 499 printf("\n\r Low Power \n\r");
lakshya 20:949d13045431 500 #endif
lakshya 20:949d13045431 501 DRV_Z_EN = 0;
lakshya 20:949d13045431 502 DRV_XY_EN = 0;
lakshya 20:949d13045431 503 ACS_STATUS = 1; // set ACS_STATUS = ACS_LOW_POWER
lakshya 20:949d13045431 504 ACS_MAIN_STATUS = 0;
lakshya 20:949d13045431 505 return;
lakshya 20:949d13045431 506
lakshya 20:949d13045431 507 }
lakshya 20:949d13045431 508 else if(ACS_TR_Z_SW_STATUS != 1)
lakshya 20:949d13045431 509 {
lakshya 20:949d13045431 510 DRV_Z_EN = 0;
lakshya 20:949d13045431 511 DRV_XY_EN = 0;
lakshya 20:949d13045431 512 ACS_STATUS = 2; // set ACS_STAUS = ACS_TRZ_DISABLED
lakshya 20:949d13045431 513 ACS_MAIN_STATUS = 0;
lakshya 20:949d13045431 514 return;
lakshya 20:949d13045431 515 }
lakshya 20:949d13045431 516 else if(ACS_TR_XY_SW_STATUS != 1)
lakshya 20:949d13045431 517 {
lakshya 20:949d13045431 518 DRV_Z_EN = 1;
lakshya 20:949d13045431 519 DRV_XY_EN = 0;
lakshya 20:949d13045431 520 ACS_STATUS = 3; // set ACS_STAUS = ACS_TRXY_DISABLED , Z axis only
lakshya 20:949d13045431 521 moment[0] = 0;
lakshya 20:949d13045431 522 moment[1] = 0;
lakshya 20:949d13045431 523 moment[2] = ACS_Z_FIXED_MOMENT; // is a dummy value
lakshya 20:949d13045431 524
lakshya 20:949d13045431 525 FCTN_ACS_GENPWM_MAIN(moment) ;
lakshya 20:949d13045431 526 ACS_MAIN_STATUS = 0;
lakshya 20:949d13045431 527 return;
lakshya 19:79e69017c855 528 }
lakshya 20:949d13045431 529 else if((ACS_DATA_ACQ_STATUS == 0)||(ACS_DATA_ACQ_STATUS == 1))
lakshya 20:949d13045431 530 {
lakshya 20:949d13045431 531 DRV_Z_EN = 1;
lakshya 20:949d13045431 532 DRV_XY_EN = 0;
lakshya 20:949d13045431 533 ACS_STATUS = 3; // set Set ACS_STATUS = ACS_DATA_ACQN_FAILURE , Z axis only
lakshya 20:949d13045431 534
lakshya 20:949d13045431 535 moment[0] = 0;
lakshya 20:949d13045431 536 moment[1] = 0;
lakshya 20:949d13045431 537 moment[2] = ACS_Z_FIXED_MOMENT; // is a dummy value
lakshya 20:949d13045431 538
lakshya 20:949d13045431 539 FCTN_ACS_GENPWM_MAIN(moment) ;
lakshya 20:949d13045431 540 ACS_MAIN_STATUS = 0;
lakshya 20:949d13045431 541 return;
lakshya 20:949d13045431 542 }
lakshya 20:949d13045431 543 else if(ACS_STATE == 5)
lakshya 20:949d13045431 544 {
lakshya 20:949d13045431 545 DRV_Z_EN = 1;
lakshya 20:949d13045431 546 DRV_XY_EN = 0;
lakshya 20:949d13045431 547 ACS_STATUS = 3; // set ACS_STAUS = ACS_TRXY_DISABLED by ACS_STATE i.e Z axis only
sakthipriya 0:7b4c00e3912f 548
lakshya 20:949d13045431 549 moment[0] = 0;
lakshya 20:949d13045431 550 moment[1] = 0;
lakshya 20:949d13045431 551 moment[2] = ACS_Z_FIXED_MOMENT; // 1.3 is a dummy value
lakshya 20:949d13045431 552 FCTN_ACS_GENPWM_MAIN(moment) ;
lakshya 20:949d13045431 553
lakshya 20:949d13045431 554 ACS_MAIN_STATUS = 0;
lakshya 20:949d13045431 555 return;
lakshya 20:949d13045431 556 }
lakshya 20:949d13045431 557 else if(ACS_DATA_ACQ_STATUS == 2) // MM only is available
lakshya 20:949d13045431 558 {
lakshya 20:949d13045431 559 DRV_Z_EN = 1;
lakshya 20:949d13045431 560 DRV_XY_EN = 1;
lakshya 20:949d13045431 561
lakshya 20:949d13045431 562 ACS_STATUS = 4; // set Set ACS_STATUS = ACS_BDOT_CONTROL
lakshya 20:949d13045431 563 ACS_DETUMBLING_ALGO_TYPE = 0x01;
lakshya 20:949d13045431 564 FCTN_ACS_CNTRLALGO(moment,mag_data,gyro_data,0x00,0x01,ACS_DETUMBLING_ALGO_TYPE);
lakshya 27:61c856be467e 565 controlmode_mms=0x00;
lakshya 20:949d13045431 566 #if print
lakshya 20:949d13045431 567 printf("\n\r Moment values returned by control algo \n");
lakshya 20:949d13045431 568 #endif
lakshya 20:949d13045431 569 for(int i=0; i<3; i++)
sakthipriya 0:7b4c00e3912f 570 {
lakshya 20:949d13045431 571 printf("%f\t",moment[i]);
lakshya 19:79e69017c855 572 }
lakshya 20:949d13045431 573 FCTN_ACS_GENPWM_MAIN(moment) ;
lakshya 20:949d13045431 574 ACS_MAIN_STATUS = 0;
lakshya 20:949d13045431 575 return;
lakshya 20:949d13045431 576 }
lakshya 20:949d13045431 577 else if(ACS_STATE == 7) // Nominal mode
lakshya 20:949d13045431 578 {
lakshya 20:949d13045431 579 #if print
lakshya 20:949d13045431 580 printf("\n\r Nominal mode \n");
lakshya 20:949d13045431 581 #endif
lakshya 20:949d13045431 582 DRV_Z_EN = 1;
lakshya 20:949d13045431 583 DRV_XY_EN = 1;
lakshya 20:949d13045431 584 FCTN_ACS_CNTRLALGO(moment,mag_data,gyro_data,0x01,0x00,ACS_DETUMBLING_ALGO_TYPE);
lakshya 27:61c856be467e 585 controlmode_mms = 0x01;
lakshya 20:949d13045431 586 #if print
lakshya 20:949d13045431 587 printf("\n\r Moment values returned by control algo \n");
lakshya 20:949d13045431 588 #endif
lakshya 20:949d13045431 589 for(int i=0; i<3; i++)
sakthipriya 0:7b4c00e3912f 590 {
lakshya 20:949d13045431 591 printf("%f\t",moment[i]);
lakshya 20:949d13045431 592 }
lakshya 20:949d13045431 593 FCTN_ACS_GENPWM_MAIN(moment) ;
lakshya 20:949d13045431 594 ACS_MAIN_STATUS = 0;
lakshya 20:949d13045431 595 return;
lakshya 20:949d13045431 596 }
lakshya 20:949d13045431 597 else if(ACS_STATE == 8) // Auto Control
lakshya 20:949d13045431 598 {
lakshya 20:949d13045431 599 #if print
lakshya 20:949d13045431 600 printf("\n\r Auto control mode \n");
lakshya 20:949d13045431 601 #endif
lakshya 20:949d13045431 602 DRV_Z_EN = 1;
lakshya 20:949d13045431 603 DRV_XY_EN = 1;
lakshya 20:949d13045431 604 FCTN_ACS_CNTRLALGO(moment,mag_data,gyro_data,0x00,0x00,ACS_DETUMBLING_ALGO_TYPE);
lakshya 27:61c856be467e 605 controlmode_mms = 0x00;
lakshya 20:949d13045431 606 #if print
lakshya 20:949d13045431 607 printf("\n\r Moment values returned by control algo \n");
lakshya 20:949d13045431 608 for(int i=0; i<3; i++)
lakshya 19:79e69017c855 609 {
lakshya 20:949d13045431 610 printf("%f\t",moment[i]);
lakshya 20:949d13045431 611 }
lakshya 20:949d13045431 612 #endif
lakshya 20:949d13045431 613 FCTN_ACS_GENPWM_MAIN(moment) ;// set ACS_STATUS in function
lakshya 20:949d13045431 614 ACS_MAIN_STATUS = 0;
lakshya 20:949d13045431 615 return;
lakshya 20:949d13045431 616 }
lakshya 20:949d13045431 617 else if(ACS_STATE == 9) // Detumbling
lakshya 20:949d13045431 618 {
lakshya 20:949d13045431 619 DRV_Z_EN = 1;
lakshya 20:949d13045431 620 DRV_XY_EN = 1;
lakshya 20:949d13045431 621 FCTN_ACS_CNTRLALGO(moment,mag_data,gyro_data,0x00,0x01,ACS_DETUMBLING_ALGO_TYPE);
lakshya 27:61c856be467e 622 controlmode_mms = 0x00;
lakshya 20:949d13045431 623 FCTN_ACS_GENPWM_MAIN(moment) ;
lakshya 20:949d13045431 624 ACS_MAIN_STATUS = 0;
lakshya 20:949d13045431 625 return;
lakshya 20:949d13045431 626 }
lakshya 20:949d13045431 627 ACS_STATUS = 7; //INVALID_STATE
lakshya 20:949d13045431 628 DRV_Z_EN = 0;
lakshya 20:949d13045431 629 DRV_XY_EN = 0;
lakshya 20:949d13045431 630 ACS_MAIN_STATUS = 0; //clear ACS_MAIN_STATUS flag
lakshya 20:949d13045431 631 }
lakshya 19:79e69017c855 632
lakshya 19:79e69017c855 633
sakthipriya 0:7b4c00e3912f 634 //***************************************************EPS THREAD***********************************************//
sakthipriya 0:7b4c00e3912f 635
lakshya 33:76f2b8735501 636
sakthipriya 3:07e15677a75c 637 void F_EPS()
lakshya 20:949d13045431 638 {
lakshya 33:76f2b8735501 639 float eps_btry_temp;
lakshya 33:76f2b8735501 640 pc.printf("\n\rEntered EPS %f\n\r",t_start.read());
lakshya 33:76f2b8735501 641 EPS_MAIN_STATUS = 1; // Set EPS main status
lakshya 33:76f2b8735501 642 EPS_MAIN_COUNTER++;
lakshya 33:76f2b8735501 643 FCTN_BATT_TEMP_SENSOR_MAIN(actual_data.Batt_temp_actual);
lakshya 33:76f2b8735501 644 pc.printf("Battery temperature %f %f\n\r" ,actual_data.Batt_temp_actual[0], actual_data.Batt_temp_actual[1]);
lakshya 33:76f2b8735501 645 EPS_BTRY_TMP_AVG = ( actual_data.Batt_temp_actual[0] + actual_data.Batt_temp_actual[1] )/2.0;
lakshya 33:76f2b8735501 646 if(abs(actual_data.Batt_temp_actual[0] - actual_data.Batt_temp_actual[1]) > 10)
lakshya 33:76f2b8735501 647 {
lakshya 33:76f2b8735501 648 EPS_BTRY_TMP_STATUS = 0; //clear EPS_BTRY_TMP_STATUS
lakshya 33:76f2b8735501 649 eps_btry_temp = (float) EPS_BAT_TEMP_DEFAULT;
lakshya 33:76f2b8735501 650 }
lakshya 33:76f2b8735501 651 else
lakshya 33:76f2b8735501 652 {
lakshya 33:76f2b8735501 653 EPS_BTRY_TMP_STATUS = 1; //set EPS_BTRY_TMP_STATUS
lakshya 33:76f2b8735501 654 eps_btry_temp = EPS_BTRY_TMP_AVG;
lakshya 33:76f2b8735501 655 }
lakshya 33:76f2b8735501 656
lakshya 33:76f2b8735501 657 if(EPS_BTRY_HTR_AUTO == 0)
lakshya 33:76f2b8735501 658 EPS_STATUS = 1; //EPS_BATTERY_HEATER_DISABLED
lakshya 33:76f2b8735501 659 else if( EPS_BTRY_TMP_STATUS == 0 )
lakshya 33:76f2b8735501 660 {
lakshya 33:76f2b8735501 661 BTRY_HTR_ENABLE = 0;
lakshya 33:76f2b8735501 662 EPS_BTRY_HTR = 0;
lakshya 33:76f2b8735501 663 EPS_STATUS = 0; //Set EPS_ERR_BATTERY_TEMP
lakshya 33:76f2b8735501 664 }
lakshya 33:76f2b8735501 665 else
lakshya 33:76f2b8735501 666 {
lakshya 33:76f2b8735501 667 if( EPS_BTRY_HTR == 1 && eps_btry_temp >= EPS_BAT_TEMP_HIGH )
lakshya 33:76f2b8735501 668 {
lakshya 33:76f2b8735501 669 BTRY_HTR_ENABLE = 0;
lakshya 33:76f2b8735501 670 EPS_BTRY_HTR = 0;
lakshya 33:76f2b8735501 671 EPS_STATUS = 4; //Set EPS_BATTERY_HEATER_OFF
lakshya 33:76f2b8735501 672 }
lakshya 33:76f2b8735501 673 else if( EPS_BTRY_HTR == 0 && eps_btry_temp < EPS_BAT_TEMP_LOW )
lakshya 33:76f2b8735501 674 {
lakshya 33:76f2b8735501 675 BTRY_HTR_ENABLE = 1;
lakshya 33:76f2b8735501 676 EPS_BTRY_HTR = 1;
lakshya 33:76f2b8735501 677 EPS_STATUS = 5; //Set EPS_BATTERY_HEATER_ON
lakshya 33:76f2b8735501 678 }
lakshya 33:76f2b8735501 679 }
lakshya 33:76f2b8735501 680
lakshya 33:76f2b8735501 681 unsigned short statusreg = read(REG_STATUS);
lakshya 33:76f2b8735501 682 if( EPS_BATTERY_GAUGE_STATUS == 0 ) reset();
lakshya 33:76f2b8735501 683 if( read(REG_STATUS) & 0x0100 == 0x0100 ) //checking if Reset Indicator bit is set
lakshya 19:79e69017c855 684 {
lakshya 33:76f2b8735501 685 printf("REG_STATUS = %d\r\n",read(REG_STATUS));
lakshya 33:76f2b8735501 686 FCTN_BATTERYGAUGE_INIT();
lakshya 33:76f2b8735501 687 }
lakshya 33:76f2b8735501 688 int BTG_MAIN_FLAG = FCTN_BATTERYGAUGE_MAIN(actual_data.Batt_gauge_actual, eps_btry_temp);
lakshya 33:76f2b8735501 689 if( BTG_MAIN_FLAG == 0 ) //Data not received
lakshya 33:76f2b8735501 690 {
lakshya 33:76f2b8735501 691 actual_data.power_mode = 1;
lakshya 33:76f2b8735501 692 EPS_BATTERY_GAUGE_STATUS = 0; //clear EPS_BATTERY_GAUGE_STATUS
lakshya 33:76f2b8735501 693 }
lakshya 33:76f2b8735501 694 else
lakshya 33:76f2b8735501 695 {
lakshya 33:76f2b8735501 696 FCTN_EPS_POWERMODE(actual_data.Batt_gauge_actual[1]); //updating power level
lakshya 33:76f2b8735501 697 EPS_BATTERY_GAUGE_STATUS = 1; //set EPS_BATTERY_GAUGE_STATUS
lakshya 33:76f2b8735501 698 }
lakshya 33:76f2b8735501 699
lakshya 33:76f2b8735501 700 FCTN_HK_MAIN();
lakshya 33:76f2b8735501 701 // printf("\n\r here");
lakshya 33:76f2b8735501 702 FCTN_EPS_HANDLE_HW_FAULTS();
lakshya 33:76f2b8735501 703 FCTN_EPS_HANDLE_CDMS_FAULT();
lakshya 33:76f2b8735501 704 FCTN_APPEND_HKDATA();
lakshya 33:76f2b8735501 705 minMaxHkData();
lakshya 33:76f2b8735501 706 //printf("\n\r here");
lakshya 33:76f2b8735501 707 EPS_MAIN_STATUS = 0; // clear EPS main status
lakshya 33:76f2b8735501 708
sakthipriya 0:7b4c00e3912f 709 }
lakshya 33:76f2b8735501 710
lakshya 20:949d13045431 711
sakthipriya 0:7b4c00e3912f 712 //**************************************************BCN THREAD*******************************************************************//
sakthipriya 0:7b4c00e3912f 713
sakthipriya 3:07e15677a75c 714 void F_BCN()
sakthipriya 0:7b4c00e3912f 715 {
lakshya 20:949d13045431 716 pc.printf("\n\rEntered BCN %f\n",t_start.read());
lakshya 20:949d13045431 717 //BCN_TX_MAIN_COUNTER=+1;
lakshya 20:949d13045431 718 FCTN_BCN_TX_MAIN();
sakthipriya 0:7b4c00e3912f 719 }
sakthipriya 0:7b4c00e3912f 720
sakthipriya 0:7b4c00e3912f 721 //**************************************************TCTM THREAD*******************************************************************//
sakthipriya 0:7b4c00e3912f 722
sakthipriya 0:7b4c00e3912f 723 void T_TC(void const * args)
lakshya 19:79e69017c855 724 {
lakshya 20:949d13045431 725 while(1)
lakshya 19:79e69017c855 726 {
lakshya 20:949d13045431 727 Thread::signal_wait(0x4);
lakshya 20:949d13045431 728 //wait_us(200);// se if it can be changed//@Lakshya:It can't be changed :)
lakshya 20:949d13045431 729 wait_us(300);
lakshya 20:949d13045431 730 BAE_MNG_I2C_STATUS =1 ;
lakshya 33:76f2b8735501 731 I2C_last.reset();
lakshya 33:76f2b8735501 732 I2C_last.start();
lakshya 20:949d13045431 733 FLAG();
lakshya 20:949d13045431 734 //earlier BAE_I2CRX_STATUS=1;
lakshya 20:949d13045431 735 #if print
lakshya 20:949d13045431 736 printf("\n\rreached\n");
lakshya 20:949d13045431 737 #endif // can be between 38 to 15700
lakshya 20:949d13045431 738 if( slave.receive() == 0)
lakshya 20:949d13045431 739 {
lakshya 20:949d13045431 740 irpt_2_mstr = 0;
lakshya 20:949d13045431 741 data_send_flag = 'h';
lakshya 20:949d13045431 742 pc.printf("\n\rSlave not addressed");
lakshya 20:949d13045431 743 pc.printf("\n\rPTE->DIR = 0x%08X",pdir_ss1);
lakshya 20:949d13045431 744 slave.stop();
lakshya 20:949d13045431 745 pdir_ss1=PTE->PDIR; /////////edited
lakshya 20:949d13045431 746 if(((pdir_ss1 & 0x00000003)!=3)) //check if bus has freezed
lakshya 20:949d13045431 747 {
lakshya 20:949d13045431 748 I2C_busreset(); /////////edited
lakshya 19:79e69017c855 749 }
lakshya 20:949d13045431 750 /*pdir_ss2=PTE->PDIR;
lakshya 20:949d13045431 751 #if PRINT2
lakshya 20:949d13045431 752 pc.printf("\n\rPTE->DIR = 0x%08X",pdir_ss2);
lakshya 20:949d13045431 753 #endif*/
lakshya 20:949d13045431 754 #if print
lakshya 20:949d13045431 755 printf("\n\rnot send\n");
lakshya 20:949d13045431 756 #endif
lakshya 20:949d13045431 757 }
lakshya 20:949d13045431 758 else if( slave.receive() == 1) // slave writes to master
lakshya 20:949d13045431 759 {
lakshya 20:949d13045431 760 BAE_I2C_COUNTER++; //////////edited
lakshya 33:76f2b8735501 761 if(data_send_flag == 'h') //to be renamed as BAE_I2C_STATUS
lakshya 20:949d13045431 762 {
lakshya 20:949d13045431 763 irpt_2_mstr =1; //wait till cdms code is changed
lakshya 20:949d13045431 764 FCTN_APPEND_HKDATA();
lakshya 20:949d13045431 765 uint8_t i2c_count =0;
lakshya 20:949d13045431 766 //crc is already being added
lakshya 20:949d13045431 767 write_ack=slave.write((char*)BAE_chardata,134);
lakshya 20:949d13045431 768 Thread::wait(1); //for correct values of register to be updated
lakshya 20:949d13045431 769 pdir_tm1=PTE->PDIR;
lakshya 20:949d13045431 770 irpt_2_mstr = 0;
lakshya 20:949d13045431 771 if(write_ack==0)// wait till cdms code is changed
lakshya 20:949d13045431 772 {
lakshya 20:949d13045431 773 while(((pdir_tm1 & 0x00000003)!=3)&& i2c_count<10)
lakshya 20:949d13045431 774 {
lakshya 20:949d13045431 775 Thread::wait(1);
lakshya 20:949d13045431 776 pdir_tm1=PTE->PDIR;
lakshya 20:949d13045431 777 i2c_count++;
lakshya 20:949d13045431 778 }
lakshya 20:949d13045431 779 if(((pdir_tm1 & 0x00000003)==3))
lakshya 20:949d13045431 780 {
lakshya 20:949d13045431 781 pc.printf("\n\rWrite HK success");
lakshya 20:949d13045431 782 data_send_flag = 'h';
lakshya 20:949d13045431 783 //shoulddn't it be here
lakshya 20:949d13045431 784 irpt_2_mstr = 0; //////////edited
lakshya 20:949d13045431 785 }
lakshya 20:949d13045431 786 else
lakshya 20:949d13045431 787 {
lakshya 20:949d13045431 788 wait_ms(20); //should be atleast 7ms for correct operation but fix this value as 20ms
lakshya 20:949d13045431 789 I2C_busreset();
lakshya 20:949d13045431 790 }
lakshya 20:949d13045431 791 #if print
lakshya 20:949d13045431 792 pc.printf("\n\rgot interrupt\n");
lakshya 20:949d13045431 793 #endif
lakshya 20:949d13045431 794 }
lakshya 20:949d13045431 795 else
lakshya 20:949d13045431 796 {
lakshya 20:949d13045431 797 I2C_busreset();
lakshya 20:949d13045431 798 }
lakshya 20:949d13045431 799 i2c_count=0;
lakshya 20:949d13045431 800 }
lakshya 20:949d13045431 801 else//data_send_flag = "t" //else if(telecommand[1]&0xC0 == 't')
lakshya 20:949d13045431 802 {
lakshya 20:949d13045431 803 uint8_t i2c_count =0;
lakshya 20:949d13045431 804 write_ack=slave.write((char*)telemetry,134); ////////edited(size)
lakshya 20:949d13045431 805 Thread::wait(1); //for correct values of register to be updated
lakshya 20:949d13045431 806 pdir_tm1=PTE->PDIR;
lakshya 19:79e69017c855 807 irpt_2_mstr = 0;
lakshya 20:949d13045431 808 data_send_flag = 'h';
lakshya 20:949d13045431 809 if(write_ack==0)
lakshya 20:949d13045431 810 {
lakshya 20:949d13045431 811 while(((pdir_tm1 & 0x00000003)!=3)&& i2c_count<10)
lakshya 20:949d13045431 812 {
lakshya 20:949d13045431 813 Thread::wait(1);
lakshya 20:949d13045431 814 pdir_tm1=PTE->PDIR;
lakshya 20:949d13045431 815 i2c_count++;
lakshya 20:949d13045431 816 }
lakshya 20:949d13045431 817 if(((pdir_tm1 & 0x00000003)==3))
lakshya 20:949d13045431 818 {
lakshya 20:949d13045431 819 pc.printf("\n\rWrite TM success");
lakshya 20:949d13045431 820 }
lakshya 20:949d13045431 821 else
lakshya 20:949d13045431 822 {
lakshya 20:949d13045431 823 wait_ms(20); //should be atleast 7ms for correct operation but fix this value as 20ms
lakshya 20:949d13045431 824 I2C_busreset();
lakshya 20:949d13045431 825 }
lakshya 20:949d13045431 826 }
lakshya 20:949d13045431 827 else
lakshya 20:949d13045431 828 {
lakshya 20:949d13045431 829 I2C_busreset();
lakshya 20:949d13045431 830 }
lakshya 20:949d13045431 831 i2c_count=0;
lakshya 20:949d13045431 832 }
lakshya 20:949d13045431 833
lakshya 20:949d13045431 834 }
lakshya 20:949d13045431 835 else if( slave.receive()==3 || slave.receive()==2) // slave read
lakshya 20:949d13045431 836 {
lakshya 20:949d13045431 837 BAE_I2C_COUNTER++;
lakshya 20:949d13045431 838 uint8_t i2c_count = 0;
lakshya 20:949d13045431 839 read_ack=slave.read((char *)telecommand,11); //read() function returns acknowledgement
lakshya 20:949d13045431 840 Thread::wait(1);
lakshya 20:949d13045431 841 pdir_tc1=PTE->PDIR;
lakshya 20:949d13045431 842 if(read_ack==0) //read() says it was successful
lakshya 20:949d13045431 843 {
lakshya 20:949d13045431 844 while(((pdir_tc1 & 0x00000003)!=3)&& i2c_count<10)//checking if SDA and SCL lines are logic 0 and not more than 10 times(10ms)
lakshya 20:949d13045431 845 {
lakshya 20:949d13045431 846 Thread::wait(1);
lakshya 20:949d13045431 847 pdir_tc1=PTE->PDIR;
lakshya 20:949d13045431 848 i2c_count++;
lakshya 20:949d13045431 849 }
lakshya 20:949d13045431 850 if(((pdir_tc1 & 0x00000003)==3))
lakshya 20:949d13045431 851 {
lakshya 20:949d13045431 852 pc.printf("\n\n\rRead TC success");
lakshya 20:949d13045431 853 //if(telecommand[1]&0xC0 == 0x00)
lakshya 20:949d13045431 854 if(telecommand[0] == 0x00) /////////////edited
lakshya 20:949d13045431 855 FCTN_CDMS_HK_TC((uint8_t*) telecommand); /////////////edited
lakshya 20:949d13045431 856 //FCTN_TC_DECODE((uint8_t*) telecommand);
lakshya 20:949d13045431 857 else
lakshya 20:949d13045431 858 {
lakshya 20:949d13045431 859 FCTN_BAE_TM_TC((uint8_t*) telecommand);
lakshya 20:949d13045431 860 //telemetry = (char*)temp;
lakshya 20:949d13045431 861 data_send_flag = 't';
lakshya 20:949d13045431 862 //pc.printf("\n\r Telemetry Generation \n");
lakshya 20:949d13045431 863 irpt_2_mstr = 1;
lakshya 20:949d13045431 864 }
lakshya 20:949d13045431 865 }
lakshya 20:949d13045431 866 else //either or both of SDA and SCL lines low
lakshya 20:949d13045431 867 {
lakshya 20:949d13045431 868 I2C_busreset();
lakshya 20:949d13045431 869 // data_send_flag = 'i';
lakshya 20:949d13045431 870 gen_I_TM();
lakshya 20:949d13045431 871 data_send_flag = 't';
lakshya 20:949d13045431 872 //shouldn't it be here
lakshya 20:949d13045431 873 irpt_2_mstr = 1; /////////////added
lakshya 20:949d13045431 874 }
lakshya 20:949d13045431 875 }
lakshya 20:949d13045431 876 else //read() says it was not successful
lakshya 20:949d13045431 877 {
lakshya 20:949d13045431 878 I2C_busreset();
lakshya 20:949d13045431 879 //data_send_flag = 'i'; //'i' = invalid
lakshya 20:949d13045431 880 gen_I_TM();
lakshya 20:949d13045431 881 data_send_flag = 't';
lakshya 20:949d13045431 882 irpt_2_mstr = 1; /////////////added
lakshya 20:949d13045431 883 }
lakshya 20:949d13045431 884 i2c_count = 0;
lakshya 20:949d13045431 885 #if print
lakshya 20:949d13045431 886 pc.printf("\n\r time taken %d",t_tc.read_us());
lakshya 20:949d13045431 887 for(int i = 0; i<134; i++)
lakshya 20:949d13045431 888 pc.printf("%c", telemetry[i]);
lakshya 20:949d13045431 889 #endif
lakshya 20:949d13045431 890 }
lakshya 20:949d13045431 891 //was commented here now in txt file main_i2ccomment on desktp
lakshya 20:949d13045431 892 BAE_MNG_I2C_STATUS=0;
lakshya 20:949d13045431 893 FLAG();
lakshya 20:949d13045431 894 }
sakthipriya 0:7b4c00e3912f 895 }
sakthipriya 0:7b4c00e3912f 896 void FCTN_TM()
lakshya 20:949d13045431 897 {
sakthipriya 5:bb592f3185cc 898 data_send_flag = 't';
sakthipriya 0:7b4c00e3912f 899 pc.printf("\n\r Telemetry Generation \n");
sakthipriya 0:7b4c00e3912f 900 irpt_2_mstr = 1;
sakthipriya 0:7b4c00e3912f 901 }
sakthipriya 0:7b4c00e3912f 902
sakthipriya 0:7b4c00e3912f 903
sakthipriya 0:7b4c00e3912f 904 //******************************************************* I2C *******************************************************************//
sakthipriya 0:7b4c00e3912f 905
sakthipriya 0:7b4c00e3912f 906 void FCTN_I2C_ISR()
sakthipriya 0:7b4c00e3912f 907 {
lakshya 20:949d13045431 908 ptr_t_i2c->signal_set(0x4);
sakthipriya 0:7b4c00e3912f 909 }
sakthipriya 0:7b4c00e3912f 910
sakthipriya 0:7b4c00e3912f 911
sakthipriya 5:bb592f3185cc 912 //***********************************************************FAULTS***************************************************************//
sakthipriya 5:bb592f3185cc 913
sakthipriya 5:bb592f3185cc 914 uint8_t iter2=0,iter4 = 0;
sakthipriya 5:bb592f3185cc 915
sakthipriya 5:bb592f3185cc 916 void pollfault()
sakthipriya 5:bb592f3185cc 917 {
lakshya 20:949d13045431 918 if (pf1==0) // OC_ATS1
lakshya 20:949d13045431 919 {
lakshya 20:949d13045431 920 pf1check=1;
lakshya 20:949d13045431 921 actual_data.faultPoll_status |=0x01 ;
lakshya 20:949d13045431 922 ATS1_SW_ENABLE = 1; // turn off ats1 // to be turned on next cycle in ACS
lakshya 20:949d13045431 923 }
lakshya 20:949d13045431 924 else
lakshya 20:949d13045431 925 actual_data.faultPoll_status &= 0xFE;
sakthipriya 5:bb592f3185cc 926
lakshya 20:949d13045431 927 if(pf2==0)
lakshya 20:949d13045431 928 {
lakshya 20:949d13045431 929 pf2check=1;
lakshya 20:949d13045431 930 actual_data.faultPoll_status |=0x02 ;
lakshya 20:949d13045431 931 ATS2_SW_ENABLE = 1; // turn off ats2 // turn on in ACS
lakshya 20:949d13045431 932 }
lakshya 20:949d13045431 933 else
lakshya 20:949d13045431 934 actual_data.faultPoll_status &= 0xFD;
sakthipriya 5:bb592f3185cc 935
sakthipriya 5:bb592f3185cc 936 if (pf3==0)
lakshya 20:949d13045431 937 {
lakshya 20:949d13045431 938 actual_data.faultPoll_status |=0x04 ;
lakshya 20:949d13045431 939 DRV_XY_EN = 0;
lakshya 20:949d13045431 940 wait_us(1);
lakshya 20:949d13045431 941 DRV_XY_EN = 1;
lakshya 20:949d13045431 942 }
lakshya 20:949d13045431 943 else
lakshya 20:949d13045431 944 actual_data.faultPoll_status &= 0xFB;
sakthipriya 5:bb592f3185cc 945 }
sakthipriya 5:bb592f3185cc 946
sakthipriya 0:7b4c00e3912f 947 //------------------------------------------------------------------------------------------------------------------------------------------------
sakthipriya 0:7b4c00e3912f 948 //SCHEDULER
sakthipriya 0:7b4c00e3912f 949 //------------------------------------------------------------------------------------------------------------------------------------------------
lakshya 20:949d13045431 950
sakthipriya 0:7b4c00e3912f 951 uint8_t schedcount=1;
sakthipriya 0:7b4c00e3912f 952 void T_SC(void const *args)
sakthipriya 0:7b4c00e3912f 953 {
lakshya 20:949d13045431 954 #if print
lakshya 20:949d13045431 955 printf("\n\r in scheduler");
lakshya 20:949d13045431 956 #endif
lakshya 19:79e69017c855 957 /*if keeping thish many cases creates a problem then make 3 seperate flagvariable i.e bae_standby_acs so on that will make it easy.!!!*/
lakshya 33:76f2b8735501 958 if(schedcount == 13) //to reset the counter
sakthipriya 0:7b4c00e3912f 959 schedcount = 1;
sakthipriya 0:7b4c00e3912f 960 if(schedcount%1==0)
lakshya 20:949d13045431 961 {
lakshya 20:949d13045431 962 if( BAE_STANDBY!=0x02 && BAE_STANDBY!=0x03 && BAE_STANDBY!=0x06 && BAE_STANDBY!=0x07)
lakshya 20:949d13045431 963 {
lakshya 20:949d13045431 964 pc.printf("\nSTATE IS !!!!!! = %x !!\n",ACS_STATE);
lakshya 20:949d13045431 965 F_ACS();
lakshya 20:949d13045431 966 //time_wdog = 0;
lakshya 20:949d13045431 967 }
sakthipriya 0:7b4c00e3912f 968
lakshya 20:949d13045431 969 }
lakshya 33:76f2b8735501 970 if(schedcount%4==0)
lakshya 20:949d13045431 971 {
lakshya 20:949d13045431 972 if( BAE_STANDBY!=0x01 && BAE_STANDBY!=0x03 && BAE_STANDBY!=0x05 && BAE_STANDBY!=0x07)
lakshya 20:949d13045431 973 {
lakshya 20:949d13045431 974 //time_wdog = 1;
lakshya 20:949d13045431 975 F_EPS();
lakshya 20:949d13045431 976 }
lakshya 20:949d13045431 977 //time_wdog = 0;
lakshya 20:949d13045431 978 }
lakshya 33:76f2b8735501 979 if(schedcount%6==0)
lakshya 20:949d13045431 980 {
lakshya 22:950dbe9fbeb8 981 if(BAE_STANDBY!=0x04 && BAE_STANDBY!=0x05 && BAE_STANDBY!=0x06 && BAE_STANDBY!=0x07)
lakshya 20:949d13045431 982 // time_wdog = 0;
lakshya 22:950dbe9fbeb8 983 F_BCN();
lakshya 20:949d13045431 984 }
sakthipriya 0:7b4c00e3912f 985 schedcount++;
lakshya 20:949d13045431 986 #if print
lakshya 20:949d13045431 987 printf("\n\r exited scheduler h");
lakshya 20:949d13045431 988 printf("\n\r time taken %f",t_start.read());
lakshya 20:949d13045431 989 #endif
sakthipriya 0:7b4c00e3912f 990 }
sakthipriya 0:7b4c00e3912f 991
lakshya 20:949d13045431 992
sakthipriya 0:7b4c00e3912f 993 Timer t_flag;
lakshya 19:79e69017c855 994
lakshya 20:949d13045431 995
sakthipriya 0:7b4c00e3912f 996 void FLAG()
sakthipriya 0:7b4c00e3912f 997 {
lakshya 20:949d13045431 998
lakshya 20:949d13045431 999 //I2C
lakshya 20:949d13045431 1000 //if(BAE_MNG_I2C_STATUS == 1)
lakshya 20:949d13045431 1001 // BAE_STATUS = BAE_STATUS | 0x10000000;
lakshya 20:949d13045431 1002 //else if(BAE_MNG_I2C_STATUS == 0)
lakshya 20:949d13045431 1003 // BAE_STATUS &= 0xEFFFFFF;
lakshya 19:79e69017c855 1004
lakshya 19:79e69017c855 1005 //.............bae..................//
lakshya 19:79e69017c855 1006 if(BAE_INIT_STATUS == 1)
lakshya 19:79e69017c855 1007 BAE_STATUS = BAE_STATUS | 0x00000001; //BAE_STATUS |= 0x00000001;
lakshya 19:79e69017c855 1008 else if(BAE_INIT_STATUS == 0)
lakshya 19:79e69017c855 1009 BAE_STATUS &= 0xFFFFFFFE;
lakshya 19:79e69017c855 1010
lakshya 20:949d13045431 1011 if(BAE_MNG_I2C_STATUS == 1)
lakshya 19:79e69017c855 1012 BAE_STATUS = BAE_STATUS | 0x00000002;
lakshya 20:949d13045431 1013 if(BAE_MNG_I2C_STATUS == 0)
lakshya 19:79e69017c855 1014 BAE_STATUS &= 0xFFFFFFFD;
lakshya 20:949d13045431 1015
sakthipriya 0:7b4c00e3912f 1016 //.............acs..................//
sakthipriya 9:194afacf7449 1017 if(ACS_INIT_STATUS == 1)
sakthipriya 0:7b4c00e3912f 1018 BAE_STATUS = BAE_STATUS | 0x00000080; //set ACS_INIT_STATUS flag
sakthipriya 9:194afacf7449 1019 else if(ACS_INIT_STATUS == 0)
sakthipriya 0:7b4c00e3912f 1020 BAE_STATUS &= 0xFFFFFF7F; //clear ACS_INIT_STATUS flag
sakthipriya 0:7b4c00e3912f 1021
sakthipriya 9:194afacf7449 1022 if(ACS_DATA_ACQ_STATUS == 1)
sakthipriya 0:7b4c00e3912f 1023 BAE_STATUS =BAE_STATUS | 0x00000100; //set ACS_DATA_ACQ_STATUS flag
sakthipriya 9:194afacf7449 1024 else if(ACS_DATA_ACQ_STATUS == 0)
sakthipriya 0:7b4c00e3912f 1025 BAE_STATUS &= 0xFFFFFEFF; //clear ACS_DATA_ACQ_STATUS flag
sakthipriya 0:7b4c00e3912f 1026
sakthipriya 9:194afacf7449 1027 if(ACS_ATS_ENABLE == 1)
sakthipriya 0:7b4c00e3912f 1028 BAE_ENABLE |= 0x00000004;
sakthipriya 9:194afacf7449 1029 else if(ACS_ATS_ENABLE == 0)
sakthipriya 0:7b4c00e3912f 1030 BAE_ENABLE = BAE_ENABLE &0xFFFFFFFB | 0x00000004;
sakthipriya 0:7b4c00e3912f 1031
sakthipriya 0:7b4c00e3912f 1032 if(ACS_DATA_ACQ_STATUS == 'f')
sakthipriya 0:7b4c00e3912f 1033 BAE_STATUS |= 0x00000200;
sakthipriya 0:7b4c00e3912f 1034
sakthipriya 9:194afacf7449 1035 if(ACS_MAIN_STATUS == 1)
sakthipriya 0:7b4c00e3912f 1036 BAE_STATUS = (BAE_STATUS | 0x00001000); //set ACS_MAIN_STATUS flag
sakthipriya 9:194afacf7449 1037 else if(ACS_MAIN_STATUS == 0)
sakthipriya 0:7b4c00e3912f 1038 BAE_STATUS &= 0xFFFFEFFF; //clear ACS_MAIN_STATUS flag
sakthipriya 0:7b4c00e3912f 1039
sakthipriya 0:7b4c00e3912f 1040 if(ACS_STATUS == '0')
sakthipriya 0:7b4c00e3912f 1041 BAE_STATUS = (BAE_STATUS & 0xFFFF1FFF); // set ACS_STATUS = ACS_CONTROL_OFF
sakthipriya 0:7b4c00e3912f 1042 else if(ACS_STATUS == '1')
sakthipriya 0:7b4c00e3912f 1043 BAE_STATUS =(BAE_STATUS & 0xFFFF1FFF) | 0x00002000; // set ACS_STATUS = ACS_LOW_POWER
sakthipriya 0:7b4c00e3912f 1044 else if(ACS_STATUS == '2')
sakthipriya 0:7b4c00e3912f 1045 BAE_STATUS = (BAE_STATUS & 0xFFFF1FFF)| 0x00004000; // set ACS_STATUS = ACS_ZAXIS_MOMENT_ONLY
sakthipriya 0:7b4c00e3912f 1046 else if(ACS_STATUS == '3')
sakthipriya 0:7b4c00e3912f 1047 BAE_STATUS = (BAE_STATUS & 0xFFFF1FFF) | 0x00006000; // set ACS_STATUS = ACS_DATA_ACQ_FAILURE
sakthipriya 0:7b4c00e3912f 1048 else if(ACS_STATUS == '4')
sakthipriya 0:7b4c00e3912f 1049 BAE_STATUS = (BAE_STATUS & 0xFFFF1FFF) | 0x00008000; // set ACS_STATUS = ACS_NOMINAL_ONLY
sakthipriya 0:7b4c00e3912f 1050 else if(ACS_STATUS == '5')
sakthipriya 0:7b4c00e3912f 1051 BAE_STATUS =(BAE_STATUS & 0xFFFF1FFF) | 0x0000A000; // set ACS_STATUS = ACS_AUTO_CONTROL
sakthipriya 0:7b4c00e3912f 1052 else if(ACS_STATUS == '6')
sakthipriya 0:7b4c00e3912f 1053 BAE_STATUS =(BAE_STATUS & 0xFFFF1FFF) | 0x0000C000; // set ACS_STATUS = ACS_DETUMBLING_ONLY
sakthipriya 0:7b4c00e3912f 1054 else
sakthipriya 0:7b4c00e3912f 1055 BAE_STATUS =(BAE_STATUS & 0xFFFF1FFF) | 0x0000E000; // set ACS_STATUS = INVALID STATE
sakthipriya 0:7b4c00e3912f 1056
sakthipriya 0:7b4c00e3912f 1057 if(ACS_STATE == '0')
sakthipriya 0:7b4c00e3912f 1058 BAE_ENABLE = (BAE_ENABLE & 0xFFFFFF8F); //ACS_STATE = ACS_CONTROL_OFF
sakthipriya 0:7b4c00e3912f 1059 else if(ACS_STATE == '2')
sakthipriya 0:7b4c00e3912f 1060 BAE_ENABLE = ((BAE_ENABLE & 0xFFFFFF8F)| 0x00000020); // ACS_STATE = ACS_ZAXIS_MOMENT_ONLY
sakthipriya 0:7b4c00e3912f 1061 else if(ACS_STATE == '3')
sakthipriya 0:7b4c00e3912f 1062 BAE_ENABLE = ((BAE_ENABLE & 0xFFFFFF8F)| 0x00000030); // set ACS_STATUS = ACS_DATA_ACQ_FAILURE
sakthipriya 0:7b4c00e3912f 1063 else if(ACS_STATE == '4')
sakthipriya 0:7b4c00e3912f 1064 BAE_ENABLE = ((BAE_ENABLE & 0xFFFFFF8F)| 0x00000040); // ACS_STATE = ACS_NOMINAL_ONLY
sakthipriya 0:7b4c00e3912f 1065 else if(ACS_STATE == '5')
sakthipriya 0:7b4c00e3912f 1066 BAE_ENABLE = ((BAE_ENABLE & 0xFFFFFF8F)| 0x00000050); // ACS_STATE = ACS_AUTO_CONTROL
sakthipriya 0:7b4c00e3912f 1067 else if(ACS_STATE == '6')
sakthipriya 0:7b4c00e3912f 1068 BAE_ENABLE = ((BAE_ENABLE & 0xFFFFFF8F)| 0x00000060); //ACS_STATE = ACS_DETUMBLING_CONTROL
sakthipriya 0:7b4c00e3912f 1069
sakthipriya 0:7b4c00e3912f 1070 //...............eps......................//
lakshya 20:949d13045431 1071 if (EPS_INIT_STATUS==1) // Set EPS_INIT_STATUS
lakshya 20:949d13045431 1072 BAE_STATUS |= 0x00010000;
lakshya 20:949d13045431 1073 else if(EPS_INIT_STATUS==0) // Clear
lakshya 20:949d13045431 1074 BAE_STATUS &= 0xFFFEFFFF;
sakthipriya 5:bb592f3185cc 1075
sakthipriya 5:bb592f3185cc 1076
lakshya 20:949d13045431 1077 if (EPS_MAIN_STATUS==1) // Set EPS_MAIIN_STATUS
lakshya 20:949d13045431 1078 BAE_STATUS |= 0x00040000;
lakshya 20:949d13045431 1079 else if(EPS_MAIN_STATUS==0) // Clear
lakshya 20:949d13045431 1080 BAE_STATUS &= 0xFFFBFFFF;
sakthipriya 5:bb592f3185cc 1081
sakthipriya 5:bb592f3185cc 1082
lakshya 20:949d13045431 1083 if (EPS_BATTERY_GAUGE_STATUS==1) // Set EPS_BATTERY_GAUGE_STATUS
lakshya 20:949d13045431 1084 BAE_STATUS |= 0x00020000;
lakshya 20:949d13045431 1085 else if(EPS_BATTERY_GAUGE_STATUS==0) // Clear
lakshya 20:949d13045431 1086 BAE_STATUS &= 0xFFFDFFFF;
lakshya 20:949d13045431 1087
lakshya 33:76f2b8735501 1088 if (EPS_BTRY_TMP_STATUS==1) // Set EPS_BATTERY_TEMP_STATUS
lakshya 20:949d13045431 1089 BAE_STATUS |= 0x00080000;
lakshya 33:76f2b8735501 1090 else if(EPS_BTRY_TMP_STATUS==0) // Clear
lakshya 20:949d13045431 1091 BAE_STATUS &= 0xFFF7FFFF;
sakthipriya 5:bb592f3185cc 1092
lakshya 20:949d13045431 1093 if (EPS_STATUS==0)
lakshya 20:949d13045431 1094 BAE_STATUS = (BAE_STATUS & 0xFF8FFFFF); // Set EPS_ERR_BATTERY_TEMP
lakshya 20:949d13045431 1095 else if (EPS_STATUS==1)
lakshya 20:949d13045431 1096 BAE_STATUS = (BAE_STATUS & 0xFF8FFFFF)|0x00010000; // Set EPS_BATTERY_HEATER_DISABLED
lakshya 20:949d13045431 1097 else if (EPS_STATUS==2)
lakshya 20:949d13045431 1098 BAE_STATUS = (BAE_STATUS & 0xFF8FFFFF)|0x00020000; // Set EPS_ERR_HEATER_SWITCH_OFF
lakshya 20:949d13045431 1099 else if (EPS_STATUS==3)
lakshya 20:949d13045431 1100 BAE_STATUS = (BAE_STATUS & 0xFF8FFFFF)|0x00030000; // Set EPS_ERR_HEATER_SWITCH_ON
lakshya 20:949d13045431 1101 else if (EPS_STATUS==4)
lakshya 20:949d13045431 1102 BAE_STATUS = (BAE_STATUS & 0xFF8FFFFF)|0x00040000; // Set EPS_BATTERY_HEATER_OFF
lakshya 20:949d13045431 1103 else if (EPS_STATUS==5)
lakshya 20:949d13045431 1104 BAE_STATUS = (BAE_STATUS & 0xFF8FFFFF)|0x00050000; // Set EPS_BATTERY_HEATER_ON
sakthipriya 5:bb592f3185cc 1105
lakshya 20:949d13045431 1106 if(EPS_BTRY_HTR_AUTO == 1)
sakthipriya 5:bb592f3185cc 1107 BAE_ENABLE |= 0x00000080;
lakshya 20:949d13045431 1108 else if(EPS_BTRY_HTR_AUTO == 0)
sakthipriya 5:bb592f3185cc 1109 BAE_ENABLE = BAE_ENABLE &0xFFFFFF7;
sakthipriya 3:07e15677a75c 1110
lakshya 20:949d13045431 1111 #if print
lakshya 20:949d13045431 1112 pc.printf("\n\r BAE status %x BAE ENABLE %x ",BAE_STATUS,BAE_ENABLE);
lakshya 20:949d13045431 1113 #endif
lakshya 20:949d13045431 1114 }
sakthipriya 0:7b4c00e3912f 1115
sakthipriya 0:7b4c00e3912f 1116
sakthipriya 0:7b4c00e3912f 1117 void FCTN_BAE_INIT()
sakthipriya 0:7b4c00e3912f 1118 {
lakshya 20:949d13045431 1119 #if print
lakshya 20:949d13045431 1120 printf("\n\r Initialising BAE _________________________________________________________________________________");
lakshya 20:949d13045431 1121 #endif
lakshya 19:79e69017c855 1122 BAE_INIT_STATUS=1;
lakshya 19:79e69017c855 1123 FLAG();
lakshya 19:79e69017c855 1124
sakthipriya 3:07e15677a75c 1125 //..........intial status....//
Bragadeesh153 13:fb7facaf308b 1126 ACS_STATE = 4;
sakthipriya 9:194afacf7449 1127 ACS_ATS_ENABLE = 1;
sakthipriya 9:194afacf7449 1128 ACS_DATA_ACQ_ENABLE = 1;
lakshya 20:949d13045431 1129 EPS_BTRY_HTR_AUTO = 1;
Bragadeesh153 13:fb7facaf308b 1130 actual_data.power_mode=3;
lakshya 19:79e69017c855 1131
sakthipriya 9:194afacf7449 1132 //............intializing pins................//
sakthipriya 9:194afacf7449 1133 ATS1_SW_ENABLE = 0;
sakthipriya 9:194afacf7449 1134 ATS2_SW_ENABLE = 1;
Bragadeesh153 13:fb7facaf308b 1135
Bragadeesh153 13:fb7facaf308b 1136 DRV_XY_EN = 1;
Bragadeesh153 13:fb7facaf308b 1137 DRV_Z_EN = 1;
Bragadeesh153 13:fb7facaf308b 1138 TRZ_SW = 1;
Bragadeesh153 13:fb7facaf308b 1139 TRXY_SW = 1;
lakshya 20:949d13045431 1140
lakshya 20:949d13045431 1141 //time_wdog = 1;
sakthipriya 9:194afacf7449 1142
lakshya 19:79e69017c855 1143 //...........order mentioned in flow chart.................//
sakthipriya 3:07e15677a75c 1144 FCTN_ACS_INIT();
lakshya 17:fc782f7548c6 1145 FCTN_EPS_INIT();
lakshya 18:3662058a7c10 1146 FCTN_BCN_INIT();
lakshya 19:79e69017c855 1147
lakshya 27:61c856be467e 1148 //uint32_t data_flash=FCTN_BAE_RD_FLASH_ENTITY(0);/*sending the 0 entity as in mms tc/tm bae_reset_counter is present in first 32 bits */
lakshya 27:61c856be467e 1149 //uint32_t data_modify=data_flash & 0x000000FF;
lakshya 27:61c856be467e 1150 //data_modify +=1;
lakshya 27:61c856be467e 1151 //data_modify |=data_flash;
lakshya 27:61c856be467e 1152 //FCTN_BAE_WR_FLASH(0,data_modify);
lakshya 20:949d13045431 1153 #if print
lakshya 20:949d13045431 1154 printf("\n\rthe number of reset %d",data_modify);
lakshya 20:949d13045431 1155 #endif
lakshya 19:79e69017c855 1156 BAE_INIT_STATUS=0;
sakthipriya 0:7b4c00e3912f 1157 FLAG();
sakthipriya 0:7b4c00e3912f 1158 }
sakthipriya 0:7b4c00e3912f 1159
lakshya 20:949d13045431 1160
sakthipriya 0:7b4c00e3912f 1161 int main()
sakthipriya 0:7b4c00e3912f 1162 {
lakshya 33:76f2b8735501 1163 //BAE_uptime.reset();
lakshya 33:76f2b8735501 1164 BAE_uptime.start();
lakshya 20:949d13045431 1165 //time_wdog = 1;
lakshya 19:79e69017c855 1166 pc.printf("\n\r BAE Activated. Testing Version 1.2 \n");
lakshya 20:949d13045431 1167 //FLASH_INI();
sakthipriya 0:7b4c00e3912f 1168 FCTN_BAE_INIT();
lakshya 20:949d13045431 1169 //time_wdog = 0;
lakshya 20:949d13045431 1170
sakthipriya 0:7b4c00e3912f 1171 slave.address(addr);
sakthipriya 0:7b4c00e3912f 1172 irpt_2_mstr = 0;
sakthipriya 0:7b4c00e3912f 1173
sakthipriya 0:7b4c00e3912f 1174 ptr_t_i2c = new Thread(T_TC);
sakthipriya 0:7b4c00e3912f 1175 ptr_t_i2c->set_priority(osPriorityHigh);
sakthipriya 5:bb592f3185cc 1176
sakthipriya 0:7b4c00e3912f 1177 irpt_4m_mstr.enable_irq();
sakthipriya 0:7b4c00e3912f 1178 irpt_4m_mstr.rise(&FCTN_I2C_ISR);
lakshya 20:949d13045431 1179
sakthipriya 0:7b4c00e3912f 1180 RtosTimer t_sc_timer(T_SC,osTimerPeriodic); // Initiating the scheduler thread
lakshya 33:76f2b8735501 1181 t_sc_timer.start(5000);
sakthipriya 0:7b4c00e3912f 1182 t_start.start();
lakshya 20:949d13045431 1183 #if print
lakshya 20:949d13045431 1184 pc.printf("\n\rStarted scheduler %f\n\r",t_start.read());
lakshya 20:949d13045431 1185 #endif
lakshya 19:79e69017c855 1186 /*if one defines it dynamically then one has to take care that the destuct function is calle everytime BAE resets otheriwse it will lead to memory leakage*/
lakshya 20:949d13045431 1187 //BAE_STANDBY_STATUS_TIMER = new RtosTimer(BAE_STANDBY_STATUS_RESET,osTimerOnce);
lakshya 19:79e69017c855 1188 /*static allocation*/
lakshya 19:79e69017c855 1189 RtosTimer STANDBY_TIMER(BAE_STANDBY_STATUS_RESET,osTimerOnce);
lakshya 19:79e69017c855 1190 BAE_STANDBY_STATUS_TIMER=&STANDBY_TIMER;
lakshya 18:3662058a7c10 1191
lakshya 20:949d13045431 1192 RtosTimer bcn_start_timer(FCTN_BCN_FEN,osTimerOnce);
lakshya 20:949d13045431 1193 /*later change it to 30 min 1800 seconds*/
lakshya 20:949d13045431 1194 bcn_start_timer.start(20000);
lakshya 20:949d13045431 1195
lakshya 20:949d13045431 1196 //BCN HTR TIMERS
lakshya 20:949d13045431 1197 RtosTimer EPS_HTR_OFF_TIMER(FCTN_EPS_HTR_OFF, osTimerOnce);
lakshya 20:949d13045431 1198 HTR_OFF=&EPS_HTR_OFF_TIMER;
lakshya 20:949d13045431 1199
lakshya 20:949d13045431 1200 RtosTimer EPS_HTR_CYCLE_TIMER(FCTN_EPS_HTR_CYCLE);
lakshya 20:949d13045431 1201 HTR_CYCLE=&EPS_HTR_CYCLE_TIMER;
lakshya 20:949d13045431 1202
lakshya 20:949d13045431 1203 RtosTimer EPS_HTR_DLY_TIMER(FCTN_EPS_HTR_DLY,osTimerOnce);
lakshya 20:949d13045431 1204 HTR_DLY=&EPS_HTR_DLY_TIMER;
lakshya 20:949d13045431 1205
lakshya 20:949d13045431 1206 FLASH_INI();
lakshya 20:949d13045431 1207
lakshya 20:949d13045431 1208 while(1); //required to prevent main from terminating
lakshya 18:3662058a7c10 1209
lakshya 20:949d13045431 1210 }