Okundu Omeni
/
wifi-https-ble-sm-uart-atcmd-5-13-1
this is using the mbed os version 5-13-1
Diff: source/ATCmdManager.cpp
- Branch:
- PassingRegression
- Revision:
- 118:8df0e9c2ee3f
- Parent:
- 117:8fd05113efc1
- Child:
- 119:8d939a902333
diff -r 8fd05113efc1 -r 8df0e9c2ee3f source/ATCmdManager.cpp --- a/source/ATCmdManager.cpp Sun May 19 16:22:59 2019 +0000 +++ b/source/ATCmdManager.cpp Sat May 25 16:25:42 2019 +0000 @@ -1,6 +1,5 @@ #include "debug.h" #include "ATCmdManager.h" -#include "common_config.h" #include "common_types.h" #include "main.h" #include "http_request.h" @@ -18,6 +17,10 @@ Queue<wifi_data_msg_t, PQDSZ> *aT2WiFiDataQueue, MemoryPool<at_data_msg_t, PQDSZ> *wiFi2ATDatamPool, Queue<at_data_msg_t, PQDSZ> *wiFi2ATDataQueue, + MemoryPool<at_ble_msg_t, PQDSZ_BLE> *aT2BleDatamPool, + Queue<at_ble_msg_t, PQDSZ_BLE> *aT2BleDataQueue, + MemoryPool<ble_at_msg_t, PQDSZ_BLE> *ble2ATDatamPool, + Queue<ble_at_msg_t, PQDSZ_BLE> *ble2ATDataQueue, bool debug) : _serial(tx, rx, DEFAULT_BAUD_RATE), @@ -35,8 +38,11 @@ _wiFi2ATDatamPool(wiFi2ATDatamPool), _wiFi2ATDataQueue(wiFi2ATDataQueue), - - _parser(&_serial) + _aT2BleDatamPool(aT2BleDatamPool), + _aT2BleDataQueue(aT2BleDataQueue), + _ble2ATDatamPool(ble2ATDatamPool), + _ble2ATDataQueue(ble2ATDataQueue), + _parser(&_serial) { @@ -50,6 +56,8 @@ _parser.oob("AT\r", callback(this, &ATCmdManager::_oob_ok_hdlr)); _parser.oob("ATE0", callback(this, &ATCmdManager::_oob_echo_off)); _parser.oob("ATE1", callback(this, &ATCmdManager::_oob_echo_on)); + _parser.oob("ATE2", callback(this, &ATCmdManager::_oob_debug_logs_on)); + _parser.oob("ATE3", callback(this, &ATCmdManager::_oob_debug_logs_off)); _parser.oob("AT+UMRS", callback(this, &ATCmdManager::_oob_uart_setup)); _parser.oob("ATO", callback(this, &ATCmdManager::_oob_data_mode)); @@ -89,6 +97,8 @@ //_event_queue.call_in(10, &print_heap_and_isr_stack_info); //print_heap_and_isr_stack_info(); //_event_queue.call_every(3600000,&print_memory_info); + lastHttpRespTime = Kernel::get_ms_count(); + lastCloudMsgType = 0x00; _event_queue.call_every(10000,&blinkLEDs); #ifdef BOX_UBLOX_DEMO_TESTING check_for_at_cmd = false; @@ -236,6 +246,15 @@ at_resp = AT_RESP_NONE; break; } + case AT_BLE_RESPONSE: + { + // AT Event state + dbg_printf(LOG, "\n [ATCMD MAN] BLE RESPONSE RECEIVED!!\r\n"); + respStr = (char *) resp_data->buffer; + sendBleDataEvent(respStr, resp_data->dataLen); + at_resp = AT_RESP_NONE; + break; + } default: //UNKNOWN response state dbg_printf(LOG, "\n [ATCMD MAN] UNKNOWN RESPONSE RECEIVED!!\r\n"); @@ -443,6 +462,14 @@ #ifdef FULL_DEBUG_ENABLED dbg_printf(LOG, "\nLen = %d\n", bodyLen); #endif + uint32_t msecsSinceLastMsg = Kernel::get_ms_count() - lastHttpRespTime; + if((lastCloudMsgType == BAR_DB_MSGTYPE || lastCloudMsgType == REC_DB_MSGTYPE) && + lastCloudMsgType == (uint8_t) bodyPtr[8] && + (msecsSinceLastMsg < CLOUD_RETRY_TIME_MS )) + { + return false; + } + lastCloudMsgType = (uint8_t) bodyPtr[8]; // pick out the MSGTYPE byte from payload http_req->body = (uint8_t *) outPtr; memcpy(outPtr, bodyPtr, bodyLen); if(bodyLen > 10){ @@ -463,7 +490,7 @@ wifiStateControl = AT_HTTPS_RESP_DOWNLOAD; return true; } - return true; + return false; } // OOB processing void ATCmdManager::_process_oob(uint32_t timeout, bool all){ @@ -516,7 +543,13 @@ rx_buf_ptr = (uint8_t *) malloc (pLen); // we already read 2 bytes from payload but expect 1 stop byte rx_buf_ptr[pLen-1] = 0x00; // clear last byte so the readback value is as expected n = _parser.read((char *)rx_buf_ptr, pLen); - if(n == -1) break; // timeout! + if(n == -1) + { + dbg_printf(LOG, "Timeout while reading message payload bytes - expected %d!\r\n", pLen); + free(rx_buf_ptr); // make sure to free buffer + rx_buf_ptr = NULL; + break; // timeout! + } dbg_printf(LOG, "%d bytes read - expected %d!\n", n, pLen); printBufferInHex(rx_buf_ptr, pLen); dbg_printf(LOG, "rx_buf_ptr[pLen-1] = %0x\n",rx_buf_ptr[pLen-1]); @@ -720,6 +753,23 @@ } + +void ATCmdManager::_oob_debug_logs_on() +{ + initialise_debug(LOG | ERR | TXT | DBG); + dbg_printf(LOG, "\n Received ATE2 OOB command!!\n"); + dbg_printf(LOG, "\n debug logs ON!!\n"); + sendAtConfirmation(OK_RESP); //_parser.send(OK_RESP); +} + +void ATCmdManager::_oob_debug_logs_off() +{ + dbg_printf(LOG, "\n Received ATE3 OOB command!!\n"); + dbg_printf(LOG, "\n turning debug logs OFF!!\n"); + initialise_debug(NONE); + sendAtConfirmation(OK_RESP); //_parser.send(OK_RESP); +} + void ATCmdManager::_oob_data_mode(){ dbg_printf(LOG, "\n Received EDM mode command!!\n"); int dmode; @@ -773,12 +823,12 @@ } void ATCmdManager::_oob_get_ble_role(){ + trigger_start_BLE(); dbg_printf(LOG, "\n Received get BLE role command!!\n"); sendAtConfirmation("+UBTLE:2\r\nOK\r\n"); //_parser.send(OK_RESP); } void ATCmdManager::_oob_ena_ble_peri(){ - trigger_start_BLE(); dbg_printf(LOG, "\n Received enable BLE Peripheral command!!\n"); sendAtConfirmation(OK_RESP); //_parser.send(OK_RESP); } @@ -1190,6 +1240,31 @@ } +void ATCmdManager::sendBleDataEvent(const char *buf, int len) +{ + _smutex.lock(); + switch(dataMode){ + case AT_CMD_DATA_MODE: + _parser.send(buf); + break; + case AT_STD_DATA_MODE: + _parser.send(buf); + break; + case AT_EXT_DATA_MODE: + { + outputEDMdata((const uint8_t *) buf, len, DATA_MSG_ID, EVENT_MSG_TYPE, BLE_CHANNEL); + break; + } + default: + _parser.send(buf); + break; + } + _smutex.unlock(); + _wiFi2ATDatamPool->free(resp_data); + resp_data = NULL; +} + + void ATCmdManager::sendConnectEvent(const uint8_t *buf, int len) { switch(dataMode){ @@ -1252,4 +1327,5 @@ EVENT_MSG_TYPE, WIFI_CHANNEL); _wiFi2ATDatamPool->free(resp_data); resp_data = NULL; + lastHttpRespTime = Kernel::get_ms_count(); }