BLE Transmitter not working

Fork of Dealer_23Feb by kumar singh

Committer:
NarendraSingh
Date:
Wed Feb 22 14:59:59 2017 +0000
Revision:
21:a5fb0ae94dc6
Parent:
20:f812f85cf97e
Child:
22:c2f034a13108
echo printing

Who changed what in which revision?

UserRevisionLine numberNew contents of line
emilmont 1:491820ee784d 1 #include "mbed.h"
NarendraSingh 11:77e595130230 2 #include "rtos.h"
NarendraSingh 11:77e595130230 3 #include "OBD.h"
NarendraSingh 11:77e595130230 4 #include "Lora.h"
NarendraSingh 11:77e595130230 5 #include "Accelerometer.h"
NarendraSingh 11:77e595130230 6 #include "Beacon.h"
NarendraSingh 11:77e595130230 7 #include "main.h"
NarendraSingh 11:77e595130230 8
NarendraSingh 11:77e595130230 9 //Datatype typecasting
NarendraSingh 11:77e595130230 10 typedef unsigned char uint8;
NarendraSingh 11:77e595130230 11 typedef unsigned int uint16;
NarendraSingh 11:77e595130230 12
NarendraSingh 16:7703b9d92326 13 uint8 OBD_Plug_In_Status = FALSE;
NarendraSingh 16:7703b9d92326 14
NarendraSingh 16:7703b9d92326 15 //peripheral connection
emilmont 1:491820ee784d 16 DigitalOut led1(LED1);
emilmont 1:491820ee784d 17 DigitalOut led2(LED2);
NarendraSingh 11:77e595130230 18
NarendraSingh 11:77e595130230 19 //Configure Serial port
NarendraSingh 16:7703b9d92326 20 RawSerial LORA_UART(PA_0, PA_1);//USART4_TX->PA_0,USART4_RX->PA_1 : Used for Lora module command sending and reception from gateway
NarendraSingh 17:758fb8454ab0 21 RawSerial pc1(PA_14, PA_15);//USART1_TX->PA_9,USART1_RX->PA_10 : Used for debugging purpose only
NarendraSingh 19:886d50ecc718 22 RawSerial DEBUG_UART(PA_14, PA_15);//USART1_TX->PA_9,USART1_RX->PA_10 : Used for debugging purpose only
NarendraSingh 16:7703b9d92326 23 RawSerial Beacon_UART(PC_4, PC_5);//USART3_TX->PC4,USART3_RX->PC_5 : Used for sending command to beacon module
NarendraSingh 16:7703b9d92326 24 RawSerial BLE_RECEIVER_UART(PA_9, PA_10);//USART1_TX->PA_0,USART1_RX->PA_1 : Used for Lora module command sending and reception from gateway
NarendraSingh 16:7703b9d92326 25
NarendraSingh 16:7703b9d92326 26 //InterruptIn OBD_PLUGIN_INTERRUPT_PIN(PC_13);
NarendraSingh 21:a5fb0ae94dc6 27 InterruptIn CheckIn_Interrupt(PB_7);//(PC_13);
NarendraSingh 16:7703b9d92326 28
NarendraSingh 16:7703b9d92326 29 uint8 Ticker_Count = 0; //Variable to count for timer overflows
NarendraSingh 16:7703b9d92326 30
NarendraSingh 16:7703b9d92326 31 uint8 OBD_Plugin_Detected = FALSE;
NarendraSingh 16:7703b9d92326 32
NarendraSingh 16:7703b9d92326 33 //Create Object for structure of Lora Packet to be sent
NarendraSingh 11:77e595130230 34
NarendraSingh 16:7703b9d92326 35 static uint16 Calculate_Wheels_RPM(uint8* Buffer);
NarendraSingh 16:7703b9d92326 36 void flip_Packet_Sending_Flag();
NarendraSingh 16:7703b9d92326 37 void Lora_Periodic_Packet_Sending_thread(void const *args);
NarendraSingh 11:77e595130230 38
NarendraSingh 16:7703b9d92326 39 void Lora_Rcvd_Cmd_Processing_thread(void);// const *args);
NarendraSingh 16:7703b9d92326 40 void Enable_CheckIN_Packet_Sending();
NarendraSingh 16:7703b9d92326 41
NarendraSingh 16:7703b9d92326 42 const char GET_RSSI[]= {0x41,0x54,0x01,0x01,0x0D,0x0A};
NarendraSingh 11:77e595130230 43 /*************************Accelerometer related definitions***********************************/
NarendraSingh 11:77e595130230 44 //Accelerometer related definitions
NarendraSingh 13:8955f2e95021 45
NarendraSingh 11:77e595130230 46 #define DOUBLE_TAP_INTERRUPT 0x20
NarendraSingh 11:77e595130230 47 #define ACTIVITY_INTERRUPT 0x10
NarendraSingh 11:77e595130230 48 #define INACTIVITY_INTERRUPT 0x08
NarendraSingh 11:77e595130230 49
NarendraSingh 16:7703b9d92326 50 #define TAP_THRESHOLD 75
NarendraSingh 11:77e595130230 51 #define ACTIVITY_THRESHOLD 64 // THRES_ACT register value 62.5mg/LSB , therfore value 32 indicates 2g activity
NarendraSingh 11:77e595130230 52 #define INACTIVITY_THRESHOLD 50
NarendraSingh 11:77e595130230 53
NarendraSingh 11:77e595130230 54 #define DUR_TIME 0x15 // DUR Register value providing maximum time to be held to generate an interrupt
NarendraSingh 11:77e595130230 55 #define LATENT_TIME 0x15 // The interrupt latency
NarendraSingh 11:77e595130230 56 #define WINDOW_TIME 0x45 // The time of the interrupt window in which the next tap will be detected
NarendraSingh 11:77e595130230 57 #define INACTIVITY_VALIDATION_TIME 5 // The time until which the acceleration must be held below the inactivity threshold to generate an inactvity interrupt
NarendraSingh 16:7703b9d92326 58 // Here the value 5 indicates literally 5 secs
NarendraSingh 11:77e595130230 59 #define X_AXIS_OFFSET 0x7F
NarendraSingh 11:77e595130230 60 #define Y_AXIS_OFFSET 0x7F
NarendraSingh 11:77e595130230 61 #define Z_AXIS_OFFSET 0x05
NarendraSingh 11:77e595130230 62
NarendraSingh 17:758fb8454ab0 63 Serial pc(USBTX, USBRX);
NarendraSingh 16:7703b9d92326 64 I2C i2c(PB_9, PB_8);
NarendraSingh 11:77e595130230 65
NarendraSingh 16:7703b9d92326 66 InterruptIn activity(PB_0);
NarendraSingh 11:77e595130230 67 InterruptIn inactivity(PA_4); // As for now only this is used
NarendraSingh 11:77e595130230 68 DigitalOut led(LED1);
NarendraSingh 11:77e595130230 69
NarendraSingh 11:77e595130230 70 const int slave_address_acc = 0xA6;
NarendraSingh 11:77e595130230 71 char axis_data[6] = {0,0,0,0,0,0};
NarendraSingh 11:77e595130230 72
NarendraSingh 11:77e595130230 73 char interrupt_source[2];
NarendraSingh 11:77e595130230 74 char axis_data_start_address[2] = {0x32, 0};
NarendraSingh 11:77e595130230 75 char intr_source_address[2] = {0x30, 0};
NarendraSingh 11:77e595130230 76 char all_interrupt_clear_command[2] = {0x2E, 0x00};
NarendraSingh 11:77e595130230 77 char all_interrupt_enable_command[2] = {0x2E, 0x38};
NarendraSingh 11:77e595130230 78 char activity_interrupt_disable_command[2] = {0x2E, 0x08};
NarendraSingh 11:77e595130230 79 char inactivity_interrupt_disable_command[2] = {0x2E, 0x30};
NarendraSingh 11:77e595130230 80 char accelerometer_status_registered = 0;
NarendraSingh 11:77e595130230 81 unsigned int interrupt_source_duplicate;
NarendraSingh 11:77e595130230 82
NarendraSingh 11:77e595130230 83 char threshold_offset_command[5];
NarendraSingh 11:77e595130230 84 char act_inact_time_config_command[8];
NarendraSingh 11:77e595130230 85 char interrupt_enable_command[3];
NarendraSingh 11:77e595130230 86 char tap_axis_enable_command[2];
NarendraSingh 11:77e595130230 87 char baud_rate_command[2];
NarendraSingh 11:77e595130230 88 char data_format_command[2];
NarendraSingh 11:77e595130230 89 char measure_bit_on_command[2];
NarendraSingh 11:77e595130230 90
NarendraSingh 11:77e595130230 91
NarendraSingh 11:77e595130230 92 unsigned char vehicle_speed = 25; // Kmph
NarendraSingh 11:77e595130230 93 unsigned char current_speed, previous_speed, speed_threshold = 10; // Kmph
NarendraSingh 11:77e595130230 94
NarendraSingh 11:77e595130230 95 unsigned char x_axis, y_axis, z_axis;
NarendraSingh 11:77e595130230 96
NarendraSingh 11:77e595130230 97 unsigned char Motion_Detect_Status = FALSE;
NarendraSingh 11:77e595130230 98 uint8 OBD_PlugInOut_IOC_Status = FALSE;
NarendraSingh 11:77e595130230 99 unsigned char Motion_Type_Detected = MOTION_TYPE_UNKNOWN; //By default set motion type as unknown
NarendraSingh 11:77e595130230 100 void Accelerometer_Process_thread();//void const *args) ;
NarendraSingh 11:77e595130230 101
NarendraSingh 16:7703b9d92326 102 #define BLE_RECEIVER_UART_RX_Size 100
NarendraSingh 16:7703b9d92326 103 uint8 BLE_RxBuffer_End_Pos = 0;
NarendraSingh 16:7703b9d92326 104 char BLE_Receiver_UART_RX_Buffer[BLE_RECEIVER_UART_RX_Size];
NarendraSingh 13:8955f2e95021 105
NarendraSingh 11:77e595130230 106 //This function is Interrupt routine for detecting motion(acceleartion), i.e. either starts from rest/vehicle stops afeter running or if sudden jurk is detected
NarendraSingh 11:77e595130230 107 void interrupt_activity_inactivity()
NarendraSingh 16:7703b9d92326 108 {
NarendraSingh 16:7703b9d92326 109 i2c.write(slave_address_acc, all_interrupt_clear_command, 2);
NarendraSingh 16:7703b9d92326 110 Motion_Detect_Status = TRUE;
NarendraSingh 11:77e595130230 111 }
NarendraSingh 13:8955f2e95021 112
NarendraSingh 13:8955f2e95021 113
NarendraSingh 16:7703b9d92326 114 /************************************************************************/
NarendraSingh 11:77e595130230 115 uint8 Command_Sent[100];
NarendraSingh 11:77e595130230 116 uint8 Command_Length_Sent;
NarendraSingh 12:6107b32b0729 117 uint8 Checkin_Detect_Status = FALSE;
NarendraSingh 11:77e595130230 118 void Extract_Received_Lora_Response(void);
NarendraSingh 16:7703b9d92326 119
NarendraSingh 16:7703b9d92326 120 char previous_state = 0;
NarendraSingh 16:7703b9d92326 121 char current_state = 0;
NarendraSingh 16:7703b9d92326 122
NarendraSingh 16:7703b9d92326 123 uint8 OBD_PlugIN_State=0;
NarendraSingh 16:7703b9d92326 124 uint8 OBD_PlugIN_State1=0;
NarendraSingh 16:7703b9d92326 125 uint8 OBD_PlugIN_State2=0;
NarendraSingh 16:7703b9d92326 126 uint8 OBD_PlugIN_Temp_State=1;
NarendraSingh 16:7703b9d92326 127
NarendraSingh 16:7703b9d92326 128 void OBD_Plug_IN_Interrupt()
NarendraSingh 16:7703b9d92326 129 {
NarendraSingh 17:758fb8454ab0 130 if(OBD_PlugIN_State1!=OBD_PlugIN_Temp_State) {
NarendraSingh 16:7703b9d92326 131 OBD_PlugIN_State1=1;
NarendraSingh 16:7703b9d92326 132 OBD_PlugIN_State=!OBD_PlugIN_State;
NarendraSingh 16:7703b9d92326 133 OBD_PlugIN_Temp_State=OBD_PlugIN_State;
NarendraSingh 16:7703b9d92326 134 OBD_PlugInOut_IOC_Status = TRUE;
NarendraSingh 16:7703b9d92326 135 }
NarendraSingh 16:7703b9d92326 136 }
NarendraSingh 17:758fb8454ab0 137
NarendraSingh 16:7703b9d92326 138 void OBD_Plug_OUT_Interrupt()
NarendraSingh 16:7703b9d92326 139 {
NarendraSingh 17:758fb8454ab0 140 if(OBD_PlugIN_State2!=OBD_PlugIN_Temp_State) {
NarendraSingh 16:7703b9d92326 141 OBD_PlugIN_State2=0;
NarendraSingh 16:7703b9d92326 142 OBD_PlugIN_State=!OBD_PlugIN_State;
NarendraSingh 16:7703b9d92326 143 OBD_PlugIN_Temp_State=OBD_PlugIN_State;
NarendraSingh 16:7703b9d92326 144 OBD_PlugInOut_IOC_Status = TRUE;
NarendraSingh 17:758fb8454ab0 145 }
NarendraSingh 16:7703b9d92326 146 }
NarendraSingh 16:7703b9d92326 147
NarendraSingh 16:7703b9d92326 148 //This function is Interrupt routine for detecting OBD Plugin and Out
NarendraSingh 11:77e595130230 149 void Handle_CheckIn_Interrupt()
NarendraSingh 16:7703b9d92326 150 {
NarendraSingh 11:77e595130230 151 OBD_PlugInOut_IOC_Status = TRUE;
NarendraSingh 17:758fb8454ab0 152 pc.printf("Movement_Detected");
NarendraSingh 11:77e595130230 153 }
NarendraSingh 11:77e595130230 154
NarendraSingh 16:7703b9d92326 155 //Declare Ticker for sending lora packet
NarendraSingh 16:7703b9d92326 156 Ticker Lora_Packet_Sending_Ticker;
NarendraSingh 16:7703b9d92326 157 void flip_Packet_Sending_Flag(void)
NarendraSingh 16:7703b9d92326 158 {
NarendraSingh 16:7703b9d92326 159 //flip function
NarendraSingh 16:7703b9d92326 160 if(Ticker_Count < 5) {
NarendraSingh 11:77e595130230 161 Ticker_Count++;
NarendraSingh 16:7703b9d92326 162 } else {
NarendraSingh 11:77e595130230 163 Ticker_Count = 0;
NarendraSingh 11:77e595130230 164 Send_Lora_Packet_Flag = TRUE;
NarendraSingh 11:77e595130230 165 }
NarendraSingh 16:7703b9d92326 166 }
NarendraSingh 11:77e595130230 167
NarendraSingh 11:77e595130230 168 // called every time a byte is received from lora module.
NarendraSingh 11:77e595130230 169 void Lora_onDataRx()
NarendraSingh 11:77e595130230 170 {
NarendraSingh 16:7703b9d92326 171 while (LORA_UART.readable()) {
NarendraSingh 16:7703b9d92326 172 // while there is data waiting
NarendraSingh 11:77e595130230 173 LORA_UART_RX_Buffer[Lora_RxBuffer_End_Pos++] = LORA_UART.getc(); // put it in the buffer
NarendraSingh 20:f812f85cf97e 174 //pc1.putc(LORA_UART_RX_Buffer[Lora_RxBuffer_End_Pos-1]);
NarendraSingh 16:7703b9d92326 175 if(Lora_RxBuffer_End_Pos >= LORA_UART_RX_Size) {
NarendraSingh 11:77e595130230 176 // BUFFER OVERFLOW. What goes here depends on how you want to cope with that situation.
NarendraSingh 11:77e595130230 177 // For now just throw everything away.
NarendraSingh 11:77e595130230 178 Lora_RxBuffer_End_Pos = 0;
NarendraSingh 11:77e595130230 179 }
emilmont 1:491820ee784d 180 }
NarendraSingh 16:7703b9d92326 181 }
NarendraSingh 11:77e595130230 182
NarendraSingh 11:77e595130230 183 // called every time a byte is received from Beacon Module.
NarendraSingh 11:77e595130230 184 void Beacon_onDataRx()
NarendraSingh 11:77e595130230 185 {
NarendraSingh 16:7703b9d92326 186 while (Beacon_UART.readable()) {
NarendraSingh 16:7703b9d92326 187 // while there is data waiting
NarendraSingh 11:77e595130230 188 Beacon_RX_Buffer[Beacon_RxBuffer_End_Pos++] = Beacon_UART.getc(); // put it in the buffer
NarendraSingh 21:a5fb0ae94dc6 189 //pc1.putc(Beacon_RX_Buffer[Beacon_RxBuffer_End_Pos-1]);
NarendraSingh 16:7703b9d92326 190 if(Beacon_RxBuffer_End_Pos >= 100) {
NarendraSingh 11:77e595130230 191 // BUFFER OVERFLOW. What goes here depends on how you want to cope with that situation.
NarendraSingh 11:77e595130230 192 // For now just throw everything away.
NarendraSingh 11:77e595130230 193 Beacon_RxBuffer_End_Pos = 0;
NarendraSingh 11:77e595130230 194 }
emilmont 1:491820ee784d 195 }
emilmont 1:491820ee784d 196 }
NarendraSingh 11:77e595130230 197
NarendraSingh 16:7703b9d92326 198 void BLE_Receiver_onDataRx(void)
NarendraSingh 13:8955f2e95021 199 {
NarendraSingh 16:7703b9d92326 200 while (BLE_RECEIVER_UART.readable()) {
NarendraSingh 16:7703b9d92326 201 // while there is data waiting
NarendraSingh 13:8955f2e95021 202 BLE_Receiver_UART_RX_Buffer[BLE_RxBuffer_End_Pos++] = BLE_RECEIVER_UART.getc(); // put it in the buffer
NarendraSingh 21:a5fb0ae94dc6 203 pc1.putc(BLE_Receiver_UART_RX_Buffer[BLE_RxBuffer_End_Pos-1]);
NarendraSingh 16:7703b9d92326 204 if(BLE_RxBuffer_End_Pos >= BLE_RECEIVER_UART_RX_Size) {
NarendraSingh 13:8955f2e95021 205 // BUFFER OVERFLOW. What goes here depends on how you want to cope with that situation.
NarendraSingh 13:8955f2e95021 206 // For now just throw everything away.
NarendraSingh 13:8955f2e95021 207 BLE_RxBuffer_End_Pos = 0;
NarendraSingh 13:8955f2e95021 208 }
NarendraSingh 12:6107b32b0729 209 }
NarendraSingh 16:7703b9d92326 210 }
NarendraSingh 16:7703b9d92326 211
NarendraSingh 16:7703b9d92326 212 int main()
NarendraSingh 11:77e595130230 213 {
NarendraSingh 17:758fb8454ab0 214 pc1.baud(115200);
NarendraSingh 16:7703b9d92326 215 BLE_RECEIVER_UART.baud(115200);
NarendraSingh 17:758fb8454ab0 216 pc1.printf("%s","Debugging started");
NarendraSingh 16:7703b9d92326 217 BLE_RECEIVER_UART.attach(&BLE_Receiver_onDataRx, Serial::RxIrq);
NarendraSingh 11:77e595130230 218 LORA_UART.attach(&Lora_onDataRx, Serial::RxIrq);
NarendraSingh 17:758fb8454ab0 219
NarendraSingh 11:77e595130230 220 //Create a thread to read vehicle data
NarendraSingh 11:77e595130230 221 //Thread OBD_thread(OBD_Rcvd_Cmd_Processing_thread);
NarendraSingh 11:77e595130230 222
NarendraSingh 11:77e595130230 223 Lora_Packet_Sending_Ticker.attach(&flip_Packet_Sending_Flag, 3.0); // call flip_Packet_Sending_Flag function every 5 seconds
NarendraSingh 11:77e595130230 224
NarendraSingh 11:77e595130230 225 // OBD_PLUGIN_INTERRUPT_PIN.rise(&Enable_CheckIN_Packet_Sending); // call toggle function on the rising edge
NarendraSingh 11:77e595130230 226 //led2_thread is executing concurrently with main at this point
NarendraSingh 16:7703b9d92326 227 CheckIn_Interrupt.fall(&OBD_Plug_IN_Interrupt);
NarendraSingh 16:7703b9d92326 228 CheckIn_Interrupt.rise(&OBD_Plug_OUT_Interrupt);
NarendraSingh 11:77e595130230 229 inactivity.rise(interrupt_activity_inactivity); // Attach the address of interrupt_activity_inactivity function to rising edge
NarendraSingh 19:886d50ecc718 230 Initialize_Beacon_Module();
NarendraSingh 20:f812f85cf97e 231 pc1.printf("%s","Transmitter MAC ID received");
NarendraSingh 11:77e595130230 232 Lora_Periodic_Packet_Sending(); //Infinite loop for sending and receiving lora response, no return from here
NarendraSingh 16:7703b9d92326 233 }
NarendraSingh 13:8955f2e95021 234
NarendraSingh 16:7703b9d92326 235 //Function to be called when Interrupt is genearted for motion sensing, checkin
NarendraSingh 16:7703b9d92326 236 void Initialize_Packets_Sent_Count(void)
NarendraSingh 16:7703b9d92326 237 {
NarendraSingh 11:77e595130230 238 Motion_Packet_Sent_Count = 0x00;
NarendraSingh 11:77e595130230 239 CheckIN_Packet_Sent_Count = 0x00;
NarendraSingh 16:7703b9d92326 240 }
NarendraSingh 16:7703b9d92326 241
NarendraSingh 16:7703b9d92326 242 uint8 Status_Packet_Wait_Count = 0;
NarendraSingh 16:7703b9d92326 243 void Lora_Periodic_Packet_Sending()
NarendraSingh 11:77e595130230 244 {
NarendraSingh 17:758fb8454ab0 245 pc1.printf("Periodic packet sending intiialized");
NarendraSingh 11:77e595130230 246 Set_Up_Lora_Network_Configuration();
NarendraSingh 16:7703b9d92326 247 Initialize_lora_Packets();
NarendraSingh 19:886d50ecc718 248 Send_Lora_Packet_Flag = TRUE;
NarendraSingh 16:7703b9d92326 249 while (true) {
NarendraSingh 16:7703b9d92326 250 if(Packet_Type_To_Send == HEARTBEAT_TYPE_PACKET) { //check if packet to be sent is Heartbeat packet
NarendraSingh 16:7703b9d92326 251 if(Send_Lora_Packet_Flag) { //Check if packet sending is enabled, Packet should be sent only when enabled after timeout period
NarendraSingh 12:6107b32b0729 252 Status_Packet_Wait_Count++;
NarendraSingh 21:a5fb0ae94dc6 253 if(Status_Packet_Wait_Count < 4) {
NarendraSingh 21:a5fb0ae94dc6 254 Send_RSSI_Request_Command(GET_RSSI);
NarendraSingh 21:a5fb0ae94dc6 255 pc1.printf("Sending heartbeat packet"); //call function to send periodic motion packet
NarendraSingh 12:6107b32b0729 256 Send_HeartBeat_Packet(); //call function to send heartbeat packet
NarendraSingh 17:758fb8454ab0 257 pc.printf("Sent HeartBeat Packet");
NarendraSingh 12:6107b32b0729 258 AT_Response_Receive_Status = FAILURE;
NarendraSingh 12:6107b32b0729 259 while(AT_Response_Receive_Status)
NarendraSingh 12:6107b32b0729 260 Get_Lora_Response();
NarendraSingh 12:6107b32b0729 261 Send_Lora_Packet_Flag = FALSE;
NarendraSingh 21:a5fb0ae94dc6 262 //pc1.printf("Heartbeat Packet Response Received");
NarendraSingh 21:a5fb0ae94dc6 263 } else if(Status_Packet_Wait_Count >= 6){
NarendraSingh 20:f812f85cf97e 264 //Send_RSSI_Request_Command(GET_RSSI);
NarendraSingh 12:6107b32b0729 265 Status_Packet_Wait_Count = 0;
NarendraSingh 21:a5fb0ae94dc6 266 pc1.printf("Sending Vehicle status packets"); //call function to send periodic motion packet
NarendraSingh 13:8955f2e95021 267 Send_Vehicle_Status_Packet(); //call function to send heartbeat packet
NarendraSingh 21:a5fb0ae94dc6 268 pc1.printf("Sent Vehicle Status Packet");
NarendraSingh 19:886d50ecc718 269 //AT_Response_Receive_Status = FAILURE;
NarendraSingh 21:a5fb0ae94dc6 270 // while(AT_Response_Receive_Status)
NarendraSingh 19:886d50ecc718 271 // Get_Lora_Response();
NarendraSingh 12:6107b32b0729 272 Send_Lora_Packet_Flag = FALSE;
NarendraSingh 20:f812f85cf97e 273 //pc1.printf("Status Packet Response Received");
NarendraSingh 12:6107b32b0729 274 }
NarendraSingh 11:77e595130230 275 }
NarendraSingh 16:7703b9d92326 276 } else if(Packet_Type_To_Send == MOTION_TYPE_PACKET) { //check if packet to be sent is motion packet
NarendraSingh 16:7703b9d92326 277 if(Send_Lora_Packet_Flag) { //Check if packet sending isd enabled, Packet should be sent only when enabled after timeout period
NarendraSingh 21:a5fb0ae94dc6 278 //Send_RSSI_Request_Command(GET_RSSI);
NarendraSingh 21:a5fb0ae94dc6 279 pc1.printf("Sending Motion Packet"); //call function to send periodic motion packet
NarendraSingh 11:77e595130230 280 Send_Motion_Packet();
NarendraSingh 17:758fb8454ab0 281 pc1.printf("Sent Motion Packet"); //call function to send periodic motion packet
NarendraSingh 11:77e595130230 282 AT_Response_Receive_Status = FAILURE;
NarendraSingh 11:77e595130230 283 while(AT_Response_Receive_Status)
NarendraSingh 11:77e595130230 284 Get_Lora_Response();
NarendraSingh 17:758fb8454ab0 285 pc1.printf("Motion Packet Response Received");
NarendraSingh 11:77e595130230 286 Send_Lora_Packet_Flag = FALSE;
NarendraSingh 16:7703b9d92326 287 if(Motion_Packet_Sent_Count >= 5) { //Stop Sending Motion Packets if after sending for 2 minute
NarendraSingh 17:758fb8454ab0 288 pc1.printf("Packet Type Sending Changed to HeartBeat");
NarendraSingh 11:77e595130230 289 Motion_Packet_Sent_Count = 0;
NarendraSingh 11:77e595130230 290 Packet_Type_To_Send = HEARTBEAT_TYPE_PACKET; //Set Packet type to send as heartbeat packet
NarendraSingh 16:7703b9d92326 291 Lora_Packet_Sending_Ticker.detach(); //destroy ticker
NarendraSingh 11:77e595130230 292 Lora_Packet_Sending_Ticker.attach(&flip_Packet_Sending_Flag, 10.0); //create new ticker
NarendraSingh 11:77e595130230 293 }
NarendraSingh 16:7703b9d92326 294 }
NarendraSingh 16:7703b9d92326 295 } else if(Packet_Type_To_Send == CHECKIN_TYPE_PACKET) { //check if packet to be sent is Checkin packet
NarendraSingh 16:7703b9d92326 296 if(Send_Lora_Packet_Flag) { //Check if packet sending isd enabled, Packet should be sent only when enabled after timeout period
NarendraSingh 19:886d50ecc718 297 Send_Lora_Packet_Flag = FALSE;
NarendraSingh 21:a5fb0ae94dc6 298 //pc1.printf("Sent Beacon ID request");
NarendraSingh 20:f812f85cf97e 299 // Send_RSSI_Request_Command(GET_RSSI);
NarendraSingh 19:886d50ecc718 300 if(OBD_PlugIN_State)
NarendraSingh 19:886d50ecc718 301 {
NarendraSingh 21:a5fb0ae94dc6 302 pc1.printf("Sening Checkin Packet");
NarendraSingh 19:886d50ecc718 303 Send_CheckIN_Packet(); //call function to send periodic checkIn packet
NarendraSingh 19:886d50ecc718 304 pc1.printf("Sent Checkin Packet");
NarendraSingh 21:a5fb0ae94dc6 305 Process_Beacon_Command_Received(SET_VIRTUAL_PACKET_UUID);
NarendraSingh 21:a5fb0ae94dc6 306 Process_Beacon_Command_Received(SOFT_REBOOT1);
NarendraSingh 19:886d50ecc718 307 }
NarendraSingh 19:886d50ecc718 308 else
NarendraSingh 19:886d50ecc718 309 {
NarendraSingh 21:a5fb0ae94dc6 310 pc1.printf("Sending Checkout Packet");
NarendraSingh 19:886d50ecc718 311 Send_CheckOUT_Packet();
NarendraSingh 19:886d50ecc718 312 pc1.printf("Sent CheckOut Packet");
NarendraSingh 21:a5fb0ae94dc6 313 Process_Beacon_Command_Received(SET_VIRTUAL_PACKET_UUID2);
NarendraSingh 21:a5fb0ae94dc6 314 Process_Beacon_Command_Received(SOFT_REBOOT1);
NarendraSingh 19:886d50ecc718 315 }
NarendraSingh 11:77e595130230 316 AT_Response_Receive_Status = FAILURE;
NarendraSingh 11:77e595130230 317 while(AT_Response_Receive_Status)
NarendraSingh 11:77e595130230 318 Get_Lora_Response();
NarendraSingh 16:7703b9d92326 319 if(CheckIN_Packet_Sent_Count >= 5) { //Stop Sending Motion Packets if after sending for 2 minute
NarendraSingh 17:758fb8454ab0 320 pc1.printf("Packet Type Sending Changed to HeartBeat");
NarendraSingh 20:f812f85cf97e 321 CheckIN_Packet_Sent_Count = 0;
NarendraSingh 20:f812f85cf97e 322 Packet_Type_To_Send = HEARTBEAT_TYPE_PACKET; //Set Packet type to send as heartbeat packet
NarendraSingh 20:f812f85cf97e 323 Initialize_Packets_Sent_Count();
NarendraSingh 11:77e595130230 324 }
NarendraSingh 11:77e595130230 325 }
NarendraSingh 16:7703b9d92326 326 }
NarendraSingh 16:7703b9d92326 327 if(OBD_PlugInOut_IOC_Status) { //Check if Accelerometer Interrupt is generated
NarendraSingh 13:8955f2e95021 328 //Enable_CheckIN_Packet_Sending();
NarendraSingh 11:77e595130230 329 //Get_Acceleration_Type();
NarendraSingh 21:a5fb0ae94dc6 330 // Process_Beacon_Command_Received(SET_VIRTUAL_PACKET_UUID);
NarendraSingh 21:a5fb0ae94dc6 331 // Process_Beacon_Command_Received(SOFT_REBOOT1);
NarendraSingh 11:77e595130230 332 OBD_PlugInOut_IOC_Status = FALSE;
NarendraSingh 13:8955f2e95021 333 Packet_Type_To_Send = CHECKIN_TYPE_PACKET;
NarendraSingh 13:8955f2e95021 334 Send_Lora_Packet_Flag = TRUE;
NarendraSingh 19:886d50ecc718 335 CheckIN_Packet_Sent_Count = 0;
NarendraSingh 21:a5fb0ae94dc6 336 CheckIN_Lora_Packet.Sequence_No = 0x00; //Reset counter
NarendraSingh 21:a5fb0ae94dc6 337 CheckOUT_Packet.Sequence_No = 0x00; //Reset counter
NarendraSingh 16:7703b9d92326 338 wait(1); //wait for 1sec to avoid detecting plugin debounce
NarendraSingh 11:77e595130230 339 }
NarendraSingh 16:7703b9d92326 340 if(Motion_Detect_Status) { //Check if Accelerometer Interrupt is generated
NarendraSingh 21:a5fb0ae94dc6 341 Motion_Lora_Packet.Sequence_No = 0x00; //Reset counter
NarendraSingh 11:77e595130230 342 Get_Acceleration_Type();
NarendraSingh 11:77e595130230 343 Motion_Detect_Status = FALSE;
NarendraSingh 11:77e595130230 344 }
NarendraSingh 16:7703b9d92326 345 }
NarendraSingh 11:77e595130230 346 }
NarendraSingh 11:77e595130230 347
NarendraSingh 11:77e595130230 348 void Get_Acceleration_Type(void)
NarendraSingh 11:77e595130230 349 {
NarendraSingh 11:77e595130230 350 Packet_Type_To_Send = MOTION_TYPE_PACKET; //whenever acceleration is detected change the packet type to be sent to motion type
NarendraSingh 16:7703b9d92326 351 Lora_Packet_Sending_Ticker.detach(); //destroy ticker
NarendraSingh 11:77e595130230 352 Lora_Packet_Sending_Ticker.attach(&flip_Packet_Sending_Flag, 5.0); //create new ticker, time inetrval value to be changed
NarendraSingh 11:77e595130230 353 Send_Lora_Packet_Flag = 1; //set flag to send motion packet as soon as motion is detecetd
NarendraSingh 11:77e595130230 354 Motion_Lora_Packet.Acceleration_Type = Motion_Type_Detected; //Read Type of motion deteceted
NarendraSingh 11:77e595130230 355 //write code to read acceleration value for every 10sec after any of the acceleration is found
NarendraSingh 11:77e595130230 356 }
NarendraSingh 19:886d50ecc718 357
NarendraSingh 13:8955f2e95021 358 /*
NarendraSingh 11:77e595130230 359 //This function is used to enable checkin packet sending once OBD device is plugged in
NarendraSingh 16:7703b9d92326 360 void Enable_CheckIN_Packet_Sending()
NarendraSingh 11:77e595130230 361 {
NarendraSingh 12:6107b32b0729 362 // Enable_CheckIN_Packet_Sending = TRUE; //set status to true
NarendraSingh 13:8955f2e95021 363 if(Command_Received[0] == 0xFE) //check start of frame of packet received. every packet must start with 0xFE
NarendraSingh 11:77e595130230 364 {
NarendraSingh 11:77e595130230 365 if(Calculate_Lora_Frame_FCS((Command_Received + 1),(Command_Length + 1)) == (Command_Received[Command_Length + 2])) //Check for packet inegrity by checking FCS
NarendraSingh 11:77e595130230 366 {
NarendraSingh 11:77e595130230 367 if((Command_Received[0] == SET_BEACON_CMD0) && (Command_Received[1] == SET_BEACON_CMD1)) //Check if command is received for setting beacon parameters
NarendraSingh 11:77e595130230 368 {
NarendraSingh 11:77e595130230 369 Process_Beacon_Command_Received((Command_Received + 2));
NarendraSingh 11:77e595130230 370 }
NarendraSingh 11:77e595130230 371 }
NarendraSingh 13:8955f2e95021 372 }
NarendraSingh 15:a448e955b8f3 373 } */
NarendraSingh 15:a448e955b8f3 374
NarendraSingh 16:7703b9d92326 375 void Send_RSSI_Request_Command(const char* Command_To_Send)
NarendraSingh 15:a448e955b8f3 376 {
NarendraSingh 15:a448e955b8f3 377 BLE_RECEIVER_UART.printf(Command_To_Send);
NarendraSingh 16:7703b9d92326 378 Get_Fixed_Beacon_RSSI();
NarendraSingh 15:a448e955b8f3 379 }
NarendraSingh 15:a448e955b8f3 380
NarendraSingh 16:7703b9d92326 381 void Get_Fixed_Beacon_RSSI(void)
NarendraSingh 15:a448e955b8f3 382 {
NarendraSingh 16:7703b9d92326 383 uint8 i;
NarendraSingh 16:7703b9d92326 384 uint8 Temp_Pos=0;
NarendraSingh 19:886d50ecc718 385 /*Fixed_Beacon_Packet.Parking1_Beacon_ID[0] = 0xA0;
NarendraSingh 16:7703b9d92326 386 Fixed_Beacon_Packet.Parking1_Beacon_ID[1] = 0xAC;
NarendraSingh 16:7703b9d92326 387 Fixed_Beacon_Packet.Parking1_Beacon_ID[2] = 0x51;
NarendraSingh 16:7703b9d92326 388 Fixed_Beacon_Packet.Parking1_Beacon_ID[3] = 0x3F;
NarendraSingh 16:7703b9d92326 389 Fixed_Beacon_Packet.Parking1_Beacon_ID[4] = 0x91;
NarendraSingh 16:7703b9d92326 390 Fixed_Beacon_Packet.Parking1_Beacon_ID[5] = 0xE0;
NarendraSingh 16:7703b9d92326 391 Fixed_Beacon_Packet.Parking1_Beacon_Signal_Strength = 0xC3;
NarendraSingh 16:7703b9d92326 392 Fixed_Beacon_Packet.Parking2_Beacon_ID[0] = 0xDC;
NarendraSingh 16:7703b9d92326 393 Fixed_Beacon_Packet.Parking2_Beacon_ID[1] = 0xA3;
NarendraSingh 16:7703b9d92326 394 Fixed_Beacon_Packet.Parking2_Beacon_ID[2] = 0x6D;
NarendraSingh 16:7703b9d92326 395 Fixed_Beacon_Packet.Parking2_Beacon_ID[3] = 0x30;
NarendraSingh 16:7703b9d92326 396 Fixed_Beacon_Packet.Parking2_Beacon_ID[4] = 0x38;
NarendraSingh 16:7703b9d92326 397 Fixed_Beacon_Packet.Parking2_Beacon_ID[5] = 0xDF;
NarendraSingh 16:7703b9d92326 398 Fixed_Beacon_Packet.Parking2_Beacon_Signal_Strength = 0xB4;
NarendraSingh 16:7703b9d92326 399 Fixed_Beacon_Packet.Parking3_Beacon_ID[0] = 0x6C;
NarendraSingh 16:7703b9d92326 400 Fixed_Beacon_Packet.Parking3_Beacon_ID[1] = 0x29;
NarendraSingh 16:7703b9d92326 401 Fixed_Beacon_Packet.Parking3_Beacon_ID[2] = 0xB6;
NarendraSingh 16:7703b9d92326 402 Fixed_Beacon_Packet.Parking3_Beacon_ID[3] = 0x27;
NarendraSingh 16:7703b9d92326 403 Fixed_Beacon_Packet.Parking3_Beacon_ID[4] = 0x3A;
NarendraSingh 16:7703b9d92326 404 Fixed_Beacon_Packet.Parking3_Beacon_ID[5] = 0xC9;
NarendraSingh 16:7703b9d92326 405 Fixed_Beacon_Packet.Parking3_Beacon_Signal_Strength = 0xB0;
NarendraSingh 19:886d50ecc718 406 */
NarendraSingh 21:a5fb0ae94dc6 407 pc1.printf("Reading MACID from Receiver");
NarendraSingh 17:758fb8454ab0 408 while(true)
NarendraSingh 15:a448e955b8f3 409 {
NarendraSingh 21:a5fb0ae94dc6 410 wait_ms(2);
NarendraSingh 21:a5fb0ae94dc6 411 if(Temp_Pos <= BLE_RxBuffer_End_Pos)
NarendraSingh 15:a448e955b8f3 412 {
NarendraSingh 17:758fb8454ab0 413 if(BLE_Receiver_UART_RX_Buffer[Temp_Pos] == 0x0D)
NarendraSingh 16:7703b9d92326 414 {
NarendraSingh 17:758fb8454ab0 415 if(BLE_Receiver_UART_RX_Buffer[Temp_Pos+1] == 0x0A)
NarendraSingh 16:7703b9d92326 416 {
NarendraSingh 16:7703b9d92326 417 Temp_Pos = 2;
NarendraSingh 21:a5fb0ae94dc6 418 //pc1.printf("Fixed Beacon1 MAC ID");
NarendraSingh 16:7703b9d92326 419 for(i=0; i<6; i++)
NarendraSingh 21:a5fb0ae94dc6 420 {
NarendraSingh 21:a5fb0ae94dc6 421 Fixed_Beacon_Packet.Parking1_Beacon_ID[i] = BLE_Receiver_UART_RX_Buffer[Temp_Pos++];
NarendraSingh 21:a5fb0ae94dc6 422 pc1.putc(Fixed_Beacon_Packet.Parking1_Beacon_ID[i]);
NarendraSingh 21:a5fb0ae94dc6 423 }
NarendraSingh 19:886d50ecc718 424 Temp_Pos+=2;
NarendraSingh 16:7703b9d92326 425 Fixed_Beacon_Packet.Parking1_Beacon_Signal_Strength = BLE_Receiver_UART_RX_Buffer[Temp_Pos++];
NarendraSingh 21:a5fb0ae94dc6 426 //pc1.printf("Fixed Beacon2 MAC ID");
NarendraSingh 16:7703b9d92326 427 for(i=0; i<6; i++)
NarendraSingh 21:a5fb0ae94dc6 428 {
NarendraSingh 16:7703b9d92326 429 Fixed_Beacon_Packet.Parking2_Beacon_ID[i] = BLE_Receiver_UART_RX_Buffer[Temp_Pos++];
NarendraSingh 21:a5fb0ae94dc6 430 pc1.putc(Fixed_Beacon_Packet.Parking2_Beacon_ID[i]);
NarendraSingh 21:a5fb0ae94dc6 431 }
NarendraSingh 19:886d50ecc718 432 Temp_Pos+=2;
NarendraSingh 16:7703b9d92326 433 Fixed_Beacon_Packet.Parking2_Beacon_Signal_Strength = BLE_Receiver_UART_RX_Buffer[Temp_Pos++];
NarendraSingh 21:a5fb0ae94dc6 434 //pc1.printf("Fixed Beacon3 MAC ID");
NarendraSingh 16:7703b9d92326 435 for(i=0; i<6; i++)
NarendraSingh 21:a5fb0ae94dc6 436 {
NarendraSingh 21:a5fb0ae94dc6 437 Fixed_Beacon_Packet.Parking3_Beacon_ID[i] = BLE_Receiver_UART_RX_Buffer[Temp_Pos++];
NarendraSingh 21:a5fb0ae94dc6 438 pc1.putc(Fixed_Beacon_Packet.Parking3_Beacon_ID[i]);
NarendraSingh 21:a5fb0ae94dc6 439 }
NarendraSingh 19:886d50ecc718 440 Temp_Pos+=2;
NarendraSingh 16:7703b9d92326 441 Fixed_Beacon_Packet.Parking3_Beacon_Signal_Strength = BLE_Receiver_UART_RX_Buffer[Temp_Pos++];
NarendraSingh 21:a5fb0ae94dc6 442 BLE_RxBuffer_End_Pos = 0x00; //Start Next adat at 0th location
NarendraSingh 16:7703b9d92326 443 break;
NarendraSingh 16:7703b9d92326 444 }
NarendraSingh 16:7703b9d92326 445 Temp_Pos++;
NarendraSingh 15:a448e955b8f3 446 }
NarendraSingh 16:7703b9d92326 447 else
NarendraSingh 16:7703b9d92326 448 Temp_Pos++;
NarendraSingh 15:a448e955b8f3 449 }
NarendraSingh 15:a448e955b8f3 450 else
NarendraSingh 16:7703b9d92326 451 Temp_Pos = 0x00;
NarendraSingh 19:886d50ecc718 452 }
NarendraSingh 21:a5fb0ae94dc6 453 pc1.printf("Reading MACID finished");
NarendraSingh 15:a448e955b8f3 454 }