Okundu Omeni
/
wifi-https-ble-sm-uart-atcmd-5-13-1
this is using the mbed os version 5-13-1
source/ATCmdManager.cpp
- Committer:
- ocomeni
- Date:
- 2019-03-21
- Revision:
- 80:e8f0e92e3ac9
- Parent:
- 79:a2187bbfa407
- Child:
- 81:637a87eb8170
File content as of revision 80:e8f0e92e3ac9:
#include "ATCmdManager.h" #include "common_config.h" #include "common_types.h" ATCmdManager::ATCmdManager(PinName tx, PinName rx, SMDevicePeripheral *blePeripheral, events::EventQueue &event_queue, WiFiManager *wifi, MemoryPool<wifi_cmd_message_t, 16> *aT2WiFimPool, Queue<wifi_cmd_message_t, 16> *aT2WiFiCmdQueue, MemoryPool<wifi_cmd_message_t, 16> *wiFi2ATmPool, Queue<wifi_cmd_message_t, 16> *wiFi2ATCmdQueue, MemoryPool<wifi_data_msg_t, 4> *aT2WiFiDatamPool, Queue<wifi_data_msg_t, 4> *aT2WiFiDataQueue, MemoryPool<wifi_data_msg_t, 4> *wiFi2ATDatamPool, Queue<wifi_data_msg_t, 4> *wiFi2ATDataQueue, bool debug) : _serial(tx, rx, DEFAULT_BAUD_RATE), blePeripheral(blePeripheral), _event_queue(event_queue), wiFiManager(wiFiManager), _aT2WiFimPool(aT2WiFimPool), _aT2WiFiCmdQueue(aT2WiFiCmdQueue), _wiFi2ATmPool(wiFi2ATmPool), _wiFi2ATCmdQueue(wiFi2ATCmdQueue), _aT2WiFiDatamPool(aT2WiFiDatamPool), _aT2WiFiDataQueue(aT2WiFiDataQueue), _wiFi2ATDatamPool(wiFi2ATDatamPool), _wiFi2ATDataQueue(wiFi2ATDataQueue), _parser(&_serial) { // constructor _serial.set_baud(DEFAULT_BAUD_RATE); _parser.debug_on(debug); _parser.set_delimiter("\r\n"); _parser.send("+STARTUP"); _parser.oob("ATE0", callback(this, &ATCmdManager::_oob_echo_off)); _parser.oob("ATE1", callback(this, &ATCmdManager::_oob_echo_on)); _parser.oob("AT+UMRS", callback(this, &ATCmdManager::_oob_uart_setup)); _parser.oob("ATO", callback(this, &ATCmdManager::_oob_data_mode)); _parser.oob("AT+UMLA", callback(this, &ATCmdManager::_oob_get_mac_addr)); _parser.oob("AT+UBTLE?", callback(this, &ATCmdManager::_oob_get_ble_role)); _parser.oob("AT+UBTLE=2", callback(this, &ATCmdManager::_oob_ena_ble_peri)); _parser.oob("AT+CPWROFF", callback(this, &ATCmdManager::_oob_reboot)); _parser.oob("AT+CGMR", callback(this, &ATCmdManager::_oob_get_fw_ver)); _parser.oob("AT+UWSC=", callback(this, &ATCmdManager::_oob_scanWiFiNetworks)); _parser.oob("AT+UWSCA=", callback(this, &ATCmdManager::_oob_connect2WiFiNetwork)); //_parser.oob("ATE0", callback(this, &ATCmdManager::_oob_startup_hdlr)); printf("\n --- ATCmdManager constructor completed ---\n"); //AT+UMRS=230400,2,8,1,1,1 // AT+UBTLE } void ATCmdManager::runMain(){ while(true){ _process_oob(UBLOX_ODIN_W2_RECV_TIMEOUT, true); wait_ms(MAIN_LOOP_WAIT_TIME_MS); // allow BTLE to be } } // OOB processing void ATCmdManager::_process_oob(uint32_t timeout, bool all){ set_timeout(timeout); // Poll for inbound packets while (_parser.process_oob() && all) { } set_timeout(); } // OOB message handlers void ATCmdManager::_oob_startup_hdlr(){ } void ATCmdManager::_oob_bleRole_hdlr(){ } void ATCmdManager::_oob_wifiMode_err(){ } void ATCmdManager::_oob_conn_already(){ } void ATCmdManager::_oob_err(){ } void ATCmdManager::_oob_get_fw_ver() { } void ATCmdManager::_oob_uart_setup(){ int uOpts[NUM_UART_OPTIONS]; //if(_parser.recv("=%d,%d,%d,%d,%d,%d", &uOpts[0], &uOpts[1], &uOpts[2], &uOpts[3], &uOpts[4], &uOpts[5])) { if(_parser.scanf("=%d,%d,%d,%d,%d,%d", &uOpts[0], &uOpts[1], &uOpts[2], &uOpts[3], &uOpts[4], &uOpts[5]) >0) { printf("\nATCmdParser: Uart Options=%d,%d,%d,%d,%d,%d\n", uOpts[0], uOpts[1], uOpts[2], uOpts[3], uOpts[4], uOpts[5]); } else { printf("\nATCmdParser: Retrieving Uart Options failed"); } } void ATCmdManager::set_timeout(uint32_t timeout_ms) { _parser.set_timeout(timeout_ms); } void ATCmdManager::_oob_echo_off() { _smutex.lock(); printf("\n Received ATEO OOB command!!\n"); printf("\n turning echo OFF!!\n"); _parser.debug_on(false); _parser.send("OK\n"); _smutex.unlock(); } void ATCmdManager::_oob_echo_on() { _smutex.lock(); printf("\n Received ATE1 OOB command!!\n"); printf("\n turning echo ON!!\n"); _parser.debug_on(true); _parser.send("OK\n"); _smutex.unlock(); } void ATCmdManager::_oob_data_mode(){ int dataMode; _smutex.lock(); printf("\n Received EDM mode command!!\n"); if(_parser.scanf("%d", &dataMode) >0) { printf("\nATCmdParser: Data mode=%d\n", dataMode); switch(dataMode) { case 0: printf("\nATCmdParser: Command Mode request received"); break; case 1: printf("\nATCmdParser: Data Mode request received"); break; case 2: printf("\nATCmdParser: Extended data Mode request received"); break; default: printf("\nATCmdParser: ERROR - UNKNOWN DATA MODE RECEIVED!!! \n"); break; } } else { printf("\nATCmdParser: Retrieving Uart Options failed"); } _parser.send("OK\n"); _smutex.unlock(); } void ATCmdManager::_oob_get_mac_addr(){ int bleOrWifi; _smutex.lock(); if(_parser.scanf("=%d", &bleOrWifi) >0) { switch(bleOrWifi) { case 1: printf("\nATCmdParser: BLE MAC Address request received"); break; case 2: printf("\nATCmdParser: WiFi MAC Address request received"); break; default: printf("\nATCmdParser: ERROR - UNKNOWN MAC ADDRESS REQUEST RECEIVED!!! \n"); break; } } else { printf("\nATCmdParser: Retrieving Uart Options failed"); } _parser.send("OK\n"); _smutex.unlock(); } void ATCmdManager::_oob_get_ble_role(){ _smutex.lock(); printf("\n Received get BLE role command!!\n"); _parser.send("OK\n"); _smutex.unlock(); } void ATCmdManager::_oob_ena_ble_peri(){ _smutex.lock(); printf("\n Received enable BLE Peripheral command!!\n"); _parser.send("OK\n"); _smutex.unlock(); } void ATCmdManager::_oob_reboot(){ _smutex.lock(); printf("\n Received reboot command!!\n"); _parser.send("OK\n"); _parser.send("System Resetting....\n"); system_reset(); _smutex.unlock(); } const char * ATCmdManager::sec2str(nsapi_security_t sec) { switch (sec) { case NSAPI_SECURITY_NONE: return "None"; case NSAPI_SECURITY_WEP: return "WEP"; case NSAPI_SECURITY_WPA: return "WPA"; case NSAPI_SECURITY_WPA2: return "WPA2"; case NSAPI_SECURITY_WPA_WPA2: return "WPA/WPA2"; case NSAPI_SECURITY_UNKNOWN: default: return "Unknown"; } } bool ATCmdManager::queueWiFiCommand(wifi_cmd_t cmd){ wifi_cmd_message_t *wifiCmd = _aT2WiFimPool->alloc(); wifiCmd->wifi_cmd = cmd; _aT2WiFiCmdQueue->put(wifiCmd); return true; } void ATCmdManager::_oob_scanWiFiNetworks(){ _smutex.lock(); printf("\n Received scanWiFiNetworks command!!\n"); _parser.send("OK\n"); _smutex.unlock(); wifi_cmd_t cmd = WIFI_CMD_SCAN; // queue next command queueWiFiCommand(cmd); bool success; success = wiFiManager->setNextCommand(cmd); if(success){ printf("\n scan command successfully sent to wiFiManager!!\n"); } else { printf("\n ERROR: Failed to send scan command wiFiManager!!\n"); } return; /* call WiFi Scan in 20 ms */ //_event_queue.call_in( // 20, wiFiManager, // &WiFiManager::scanNetworks); //return; WiFiAccessPoint *ap; nsapi_size_or_error_t count; //count = wiFiManager->scanNetworks(); if (count <= 0) { _smutex.lock(); printf("scan() failed with return value: %d\n", count); _smutex.unlock(); return; } /* Limit number of network arbitrary to 15 */ count = count < 15 ? count : 15; ap = new WiFiAccessPoint[count]; count = wiFiManager->getAvailableAPs(ap, count); if (count <= 0) { printf("scan() failed with return value: %d\n", count); return; } for (int i = 0; i < count; i++) { printf("Network: %s secured: %s BSSID: %hhX:%hhX:%hhX:%hhx:%hhx:%hhx RSSI: %hhd Ch: %hhd\n", ap[i].get_ssid(), sec2str(ap[i].get_security()), ap[i].get_bssid()[0], ap[i].get_bssid()[1], ap[i].get_bssid()[2], ap[i].get_bssid()[3], ap[i].get_bssid()[4], ap[i].get_bssid()[5], ap[i].get_rssi(), ap[i].get_channel()); } printf("%d networks available.\n", count); delete[] ap; } void ATCmdManager::_oob_connect2WiFiNetwork() { wiFiManager->connect(); } void ATCmdManager::_oob_disconnectWiFiNetwork() { wiFiManager->disconnect(); }