BLE fota Lamp Demo
Dependencies: mbed-rtos mbed mbed_fota_fan_control
Fork of mbed_fota_fan_control by
Diff: dialog_fota/app_task.cpp
- Revision:
- 5:e11b23f9aacc
- Parent:
- 4:60be78a172c2
- Child:
- 6:8dd20294b2aa
diff -r 60be78a172c2 -r e11b23f9aacc dialog_fota/app_task.cpp --- a/dialog_fota/app_task.cpp Wed Jun 24 08:50:07 2015 +0000 +++ b/dialog_fota/app_task.cpp Mon Jul 13 06:32:05 2015 +0000 @@ -1,5 +1,6 @@ #include "app_task.h" #include "app.h" +#include "fota_server_task.h" namespace sevencore_fota{ @@ -20,34 +21,38 @@ unsigned short src_id, BleMsgHandler* BMH) { - uint8_t len = strlen(APP_DIS_SW_REV); - + uint8_t len = strlen(APP_DIS_SW_REV); + if (param->status == CO_ERROR_NO_ERROR) { + char str[22] = "\nDIS SET DB\n"; + BMH->HostPcPrint(str); // Set Manufacturer Name value in the DB { uint8_t *msg; struct diss_set_char_val_req req_name; - unsigned short msg_size = 1+sizeof(ble_hdr)+sizeof(diss_set_char_val_req)+APP_DIS_MANUFACTURER_NAME_LEN; + unsigned short msg_size = 1+sizeof(ble_hdr)+sizeof(diss_set_char_val_req)-(STR_MAX_LEN-APP_DIS_MANUFACTURER_NAME_STR_LEN); + // Fill in the parameter structure req_name.char_code = DIS_MANUFACTURER_NAME_CHAR; - req_name.val_len = APP_DIS_MANUFACTURER_NAME_LEN; - memcpy(&req_name.val[0], APP_DIS_MANUFACTURER_NAME, APP_DIS_MANUFACTURER_NAME_LEN); - + req_name.val_len = APP_DIS_MANUFACTURER_NAME_STR_LEN; + memcpy(&req_name.val[0], APP_DIS_MANUFACTURER_NAME_STR, APP_DIS_MANUFACTURER_NAME_STR_LEN); + msg = new uint8_t[msg_size]; - BMH->BleMsgAlloc(DISS_SET_CHAR_VAL_REQ,TASK_DISS, TASK_GTL,sizeof(struct diss_set_char_val_req) + APP_DIS_MANUFACTURER_NAME_LEN,&req_name,msg ); - - // Send the message + BMH->BleMsgAlloc(DISS_SET_CHAR_VAL_REQ,TASK_DISS,TASK_GTL, + sizeof(struct diss_set_char_val_req)-(STR_MAX_LEN-APP_DIS_MANUFACTURER_NAME_STR_LEN),&req_name,msg); BMH->BleSendMsg(msg,msg_size); free(msg); + wait(0.5); + } // Set Model Number String value in the DB { uint8_t *msg; struct diss_set_char_val_req req_mod; - unsigned short msg_size = 1+sizeof(ble_hdr)+sizeof(diss_set_char_val_req); + unsigned short msg_size = 1+sizeof(ble_hdr)+sizeof(diss_set_char_val_req)-(STR_MAX_LEN-APP_DIS_MODEL_NB_STR_LEN); // Fill in the parameter structure req_mod.char_code = DIS_MODEL_NB_STR_CHAR; @@ -56,12 +61,35 @@ msg = new uint8_t[msg_size]; - BMH->BleMsgAlloc(DISS_SET_CHAR_VAL_REQ,TASK_DISS, TASK_GTL,sizeof(struct diss_set_char_val_req),&req_mod,msg ); + BMH->BleMsgAlloc(DISS_SET_CHAR_VAL_REQ,TASK_DISS, TASK_GTL, + sizeof(struct diss_set_char_val_req)-(STR_MAX_LEN-APP_DIS_MODEL_NB_STR_LEN),&req_mod,msg); // Send the message BMH->BleSendMsg(msg,msg_size); free(msg); + wait(0.5); } + + // Set Serial Number String value in the DB + { + uint8_t *msg; + struct diss_set_char_val_req req_ser; + unsigned short msg_size = 1+sizeof(ble_hdr)+sizeof(diss_set_char_val_req)-(STR_MAX_LEN-APP_DIS_SERIAL_NB_STR_LEN); + // Fill in the parameter structure + req_ser.char_code = DIS_SERIAL_NB_STR_CHAR; + req_ser.val_len = APP_DIS_SERIAL_NB_STR_LEN; + memcpy(&req_ser.val[0], APP_DIS_SERIAL_NB_STR, APP_DIS_SERIAL_NB_STR_LEN); + + msg = new uint8_t[msg_size]; + + BMH->BleMsgAlloc(DISS_SET_CHAR_VAL_REQ,TASK_DISS, TASK_GTL, + sizeof(struct diss_set_char_val_req)-(STR_MAX_LEN-APP_DIS_SERIAL_NB_STR_LEN),&req_ser,msg); + // Send the message + BMH->BleSendMsg(msg,msg_size); + free(msg); + wait(0.5); + } + /* // Set System ID value in the DB { uint8_t *msg; @@ -120,20 +148,141 @@ // Send the message BMH->BleSendMsg(msg, msg_size); free(msg); - } + }*/ } - /*if (app_env.state == APP_IDLE) + if (app_env.state == APP_IDLE) + { + char str[30] = "\nfota db create req!!\n"; + BMH->HostPcPrint(str); + //app_set_mode(BMH); + app_fota_server_db_create(BMH); + } + + return 0; +} + +int fota_server_create_db_cfm_handler(unsigned short msgid, + struct fota_server_create_db_cfm *param, + unsigned short dest_id, + unsigned short src_id, + BleMsgHandler* BMH) +{ + uint8_t fota_normal = 0; + uint8_t fota_normal_len = sizeof(fota_normal); + if (param->status == CO_ERROR_NO_ERROR) { - app_proxr_db_create(); - }*/ - app_set_mode(BMH); + // Initialization Firmware new Version Char ("00-00-00") + { + uint8_t *msg; + struct fota_server_set_char_val_req req_nv; + unsigned short msg_size = 1+sizeof(ble_hdr)+ sizeof(fota_server_set_char_val_req)-(18-APP_FOTA_SERVER_FIRMWARE_NEW_VERSION_LEN); + // Fill in the parameter structure + req_nv.char_code = FOTA_SERVER_FIRMWARE_NEW_VERSION_CHAR; + req_nv.val_len = APP_FOTA_SERVER_FIRMWARE_NEW_VERSION_LEN; + memcpy(&req_nv.val[0], APP_FOTA_SERVER_FIRMWARE_NEW_VERSION, APP_FOTA_SERVER_FIRMWARE_NEW_VERSION_LEN); + + msg = new uint8_t[msg_size]; + + BMH->BleMsgAlloc(FOTA_SERVER_SET_CHAR_VAL_REQ,TASK_FOTA_SERVER, TASK_GTL,sizeof(struct fota_server_set_char_val_req)-(18-APP_FOTA_SERVER_FIRMWARE_NEW_VERSION_LEN),&req_nv,msg ); + // Send the message + BMH->BleSendMsg(msg,msg_size); + free(msg); + } + + // Initialization Sequence Number Char ( = '0' ) + { + uint8_t *msg; + struct fota_server_set_char_val_req req_sn; + unsigned short msg_size = 1+sizeof(ble_hdr)+sizeof(fota_server_set_char_val_req)-(18-fota_normal_len); + + // Fill in the parameter structure + req_sn.char_code = FOTA_SERVER_SEQUENCE_NUMBER_CHAR; + req_sn.val_len = fota_normal_len; + memcpy(&req_sn.val[0], &fota_normal, fota_normal_len); + + msg = new uint8_t[msg_size]; + + BMH->BleMsgAlloc(FOTA_SERVER_SET_CHAR_VAL_REQ,TASK_FOTA_SERVER, TASK_GTL,sizeof(struct fota_server_set_char_val_req)-(18-fota_normal_len),&req_sn,msg ); + // Send the message + BMH->BleSendMsg(msg,msg_size); + free(msg); + } + + // Initialization Firmware Data Check Char ( = '0' ) + { + uint8_t *msg; + struct fota_server_set_char_val_req req_fdc; + unsigned short msg_size = 1+sizeof(ble_hdr)+sizeof(fota_server_set_char_val_req)-(18-fota_normal_len); + + // Fill in the parameter structure + req_fdc.char_code = FOTA_SERVER_FIRMWARE_DATA_CHECK_CHAR; + req_fdc.val_len = fota_normal_len; + memcpy(&req_fdc.val[0], &fota_normal, fota_normal_len); + + msg = new uint8_t[msg_size]; + + BMH->BleMsgAlloc(FOTA_SERVER_SET_CHAR_VAL_REQ,TASK_FOTA_SERVER, TASK_GTL,sizeof(struct fota_server_set_char_val_req)-(18-fota_normal_len),&req_fdc,msg ); + // Send the message + BMH->BleSendMsg(msg,msg_size); + free(msg); + } + + // Initialization Firmware Status Char ( = '0' ) + { + uint8_t *msg; + struct fota_server_set_char_val_req req_stat; + unsigned short msg_size = 1+sizeof(ble_hdr)+sizeof(fota_server_set_char_val_req)-(18-fota_normal_len); + + // Fill in the parameter structure + req_stat.char_code = FOTA_SERVER_FIRMWARE_STATUS_CHAR; + req_stat.val_len = fota_normal_len; + memcpy(&req_stat.val[0], &fota_normal, fota_normal_len); + + msg = new uint8_t[msg_size]; + + BMH->BleMsgAlloc(FOTA_SERVER_SET_CHAR_VAL_REQ,TASK_FOTA_SERVER, TASK_GTL,sizeof(struct fota_server_set_char_val_req)-(18-fota_normal_len),&req_stat,msg ); + // Send the message + BMH->BleSendMsg(msg,msg_size); + free(msg); + } + + // Initialization Reset Char ( = '0' ) + { + uint8_t *msg; + struct fota_server_set_char_val_req req_reset; + unsigned short msg_size = 1+sizeof(ble_hdr)+sizeof(fota_server_set_char_val_req)-(18-fota_normal_len); + + // Fill in the parameter structure + req_reset.char_code = FOTA_SERVER_RESET_CHAR; + req_reset.val_len = fota_normal_len; + memcpy(&req_reset.val[0], &fota_normal, fota_normal_len); + + msg = new uint8_t[msg_size]; + + BMH->BleMsgAlloc(FOTA_SERVER_SET_CHAR_VAL_REQ,TASK_FOTA_SERVER, TASK_GTL,sizeof(struct fota_server_set_char_val_req)-(18-fota_normal_len),&req_reset,msg ); + // Send the message + BMH->BleSendMsg(msg,msg_size); + free(msg); + } + + } + + if (app_env.state == APP_IDLE) + { + app_set_mode(BMH); + } return 0; } +void fota_server_data_flash_ind_handler(BleMsgHandler* BMH) +{ + BMH->ReceiveToSerialTest(); +} + int gapm_device_ready_ind_handler(unsigned short msgid, - void *param, + struct gap_ready_evt *param, unsigned short dest_id, unsigned short src_id, BleMsgHandler* BMH) @@ -156,7 +305,7 @@ // We are now in Connectable State if (dest_id == TASK_GTL) { - // app_env.state = APP_IDLE; + app_env.state = APP_IDLE; app_diss_db_create(BMH); } @@ -169,14 +318,62 @@ unsigned short src_id, BleMsgHandler* BMH) { - //app_env.state = APP_CONNECTABLE; - - //Sleep(100); - + app_env.state = APP_CONNECTABLE; + wait(1); app_adv_start(BMH); // start advertising return 0; } +int gapc_connection_req_ind_handler(uint16_t msgid, + struct gapc_connection_req_ind *param, + uint16_t dest_id, + uint16_t src_id, + BleMsgHandler* BMH) +{ + app_env.state = APP_CONNECTED; + + ble_dev device; + + // Retrieve the connection index from the GAPC task instance for the connection + device.conidx = KE_IDX_GET(src_id); + + // Retrieve the connection handle from the parameters + device.conhdl = param->conhdl; + + memcpy(device.adv_addr.addr, param->peer_addr.addr, sizeof(struct bd_addr)); + + + char str[30] = "\nDIS&FOTA ENABLE and CONFIRM\n"; + BMH->HostPcPrint(str); + + app_dis_enable(&device,BMH); + app_fota_server_enable(&device,BMH); + wait(0.5); + app_connect_confirm(GAP_AUTH_REQ_NO_MITM_NO_BOND,&device,BMH); + + + return 0; +} + +int gapc_disconnect_ind_handler(uint16_t msgid, + struct gapc_disconnect_ind *param, + uint16_t dest_id, + uint16_t src_id, + BleMsgHandler* BMH) +{ + char str[22] = "\nDevice Disconnected\n"; + BMH->HostPcPrint(str); + + app_send_disconnect(TASK_FOTA_SERVER, param->conhdl, param->reason, BMH); + app_env.state = APP_IDLE; + + wait(1); + app_set_mode(BMH); + + return 0; +} + + }//namespace