/*---------------------------------------------------------------------------* * Routine: WIFI_Associate *---------------------------------------------------------------------------* * Description: * Association and show result on the LCD * Inputs: * void * Outputs: * ATLIBGS_MSG_ID_E *---------------------------------------------------------------------------*/ ATLIBGS_MSG_ID_E WIFI_Associate(void) { ATLIBGS_MSG_ID_E rxMsgId = ATLIBGS_MSG_ID_NONE; static ATLIBGS_AUTHMODE_E WEPMode=ATLIBGS_AUTHMODE_OPEN_WEP; int retVal; DisplayLCD(LCD_LINE4, "wl_trycon.. "); /* Associate to a particular AP specified by SSID */ if (strlen(GNV_Setting.webprov.ssid) > 0) { rxMsgId = AtLibGs_Assoc(GNV_Setting.webprov.ssid,NULL,HOST_APP_AP_CHANNEL); } else { rxMsgId = AtLibGs_Assoc(HOST_APP_AP_SSID, NULL, HOST_APP_AP_CHANNEL); } if (ATLIBGS_MSG_ID_OK != rxMsgId) { /* Association error - we can retry */ if(GNV_Setting.webprov.security == ATLIBGS_PROVSECU_WEP) { if(WEPMode==ATLIBGS_AUTHMODE_OPEN_WEP) { rxMsgId = AtLibGs_SetAuthentictionMode(ATLIBGS_AUTHMODE_SHARED_WEP);// Potenially it's a WEP shared AP WEPMode=ATLIBGS_AUTHMODE_SHARED_WEP; } else { rxMsgId = AtLibGs_SetAuthentictionMode(ATLIBGS_AUTHMODE_OPEN_WEP);// Potenially it's a WEP shared AP WEPMode=ATLIBGS_AUTHMODE_OPEN_WEP; } } DisplayLCD(LCD_LINE4, "Assoc failed..."); MSTimerDelay(2000); DisplayLCD(LCD_LINE4, "Trying again..."); } else { /* Association success */ AtLibGs_SetNodeAssociationFlag(); DisplayLCD(LCD_LINE4, "wl_connect "); MSTimerDelay(2000); retVal = App_ConnectMqtt(); switch(retVal) { case 0: DisplayLCD(LCD_LINE5, "MQTT Connected"); break; case -1: DisplayLCD(LCD_LINE5, "MQTT packet error"); break; case -2: DisplayLCD(LCD_LINE5, "MQTT connack error"); break; } } return rxMsgId; }
/*---------------------------------------------------------------------------* * Routine: WIFI_init *---------------------------------------------------------------------------* * Description: * Initial setting + DHCP and show status on the LCD. * * Inputs: * void * Outputs: * ATLIBGS_MSG_ID_E *---------------------------------------------------------------------------*/ ATLIBGS_MSG_ID_E WIFI_init(int16_t showMessage) { ATLIBGS_MSG_ID_E rxMsgId = ATLIBGS_MSG_ID_NONE; char wifi_mac[20]; // Check the link #ifdef HOST_APP_DEBUG_ENABLE ConsolePrintf("Checking link\r\n"); #endif AtLibGs_Init(); // Wait for the banner MSTimerDelay(500); // Send command to check do { AtLibGs_FlushIncomingMessage(); DisplayLCD(LCD_LINE8, "Checking..."); rxMsgId = AtLibGs_Check(); } while (ATLIBGS_MSG_ID_OK != rxMsgId); do { rxMsgId = AtLibGs_SetEcho(0); // disable Echo }while (ATLIBGS_MSG_ID_OK != rxMsgId); do { rxMsgId = AtLibGs_Version(); // check the GS version }while (ATLIBGS_MSG_ID_OK != rxMsgId); // Get MAC Address & Show rxMsgId = AtLibGs_GetMAC(wifi_mac); if (rxMsgId == ATLIBGS_MSG_ID_OK) AtLibGs_ParseGetMacResponse(wifi_mac); memset(&wifi_mac[12], 0, 7); if (showMessage > 0) { DisplayLCD(LCD_LINE5, "MAC ADDRESS"); DisplayLCD(LCD_LINE6, (const uint8_t *)wifi_mac); DisplayLCD(LCD_LINE2, (const uint8_t *)AppVersion); MSTimerDelay(2000); DisplayLCD(LCD_LINE2, " "); } do { AtLibGs_FlushIncomingMessage(); DisplayLCD(LCD_LINE8, "Disassociate"); rxMsgId = AtLibGs_DisAssoc(); } while (ATLIBGS_MSG_ID_OK != rxMsgId); // Enable DHCP do { DisplayLCD(LCD_LINE8, "DHCP On..."); rxMsgId = AtLibGs_DHCPSet(1); } while (ATLIBGS_MSG_ID_OK != rxMsgId); if(strlen(GNV_Setting.webprov.ssid) > 0) { if(GNV_Setting.webprov.security == ATLIBGS_PROVSECU_WEP) { do { DisplayLCD(LCD_LINE8, " Setting WEP"); rxMsgId = AtLibGs_SetWEP1((int8_t*)GNV_Setting.webprov.password); } while (ATLIBGS_MSG_ID_OK != rxMsgId); DisplayLCD(LCD_LINE8, " WEP Set"); } else if(GNV_Setting.webprov.security == ATLIBGS_PROVSECU_WPA_PER) { do { DisplayLCD(LCD_LINE8, " Setting PSK"); rxMsgId = AtLibGs_CalcNStorePSK(GNV_Setting.webprov.ssid, GNV_Setting.webprov.password); } while (ATLIBGS_MSG_ID_OK != rxMsgId); DisplayLCD(LCD_LINE8, " PSK Set"); } else if(GNV_Setting.webprov.security == ATLIBGS_PROVSECU_WPA_ENT) { // Set AT+WAUTH=0 for WPA or WPA2 do { DisplayLCD(LCD_LINE8, " " ); rxMsgId = AtLibGs_SetAuthentictionMode(ATLIBGS_AUTHMODE_NONE_WPA); } while (ATLIBGS_MSG_ID_OK != rxMsgId); // Security Configuration do { DisplayLCD(LCD_LINE8, "Set Security"); rxMsgId = AtLibGs_SetSecurity(ATLIBGS_SMAUTO); } while (ATLIBGS_MSG_ID_OK != rxMsgId); } } else { #ifdef HOST_APP_SEC_WEP // Set AT+WAUTH=2 for WEP do { DisplayLCD(LCD_LINE8, " WEP AUTH " ); rxMsgId = AtLibGs_SetAuthentictionMode(2); } while (ATLIBGS_MSG_ID_OK != rxMsgId); // Set WEP do { rxMsgId = AtLibGs_SetWEP1(HOST_APP_AP_SEC_WEP); } while (ATLIBGS_MSG_ID_OK != rxMsgId); // Security Configuration do { rxMsgId = AtLibGs_SetSecurity(2); // WEP } while (ATLIBGS_MSG_ID_OK != rxMsgId); #endif #ifdef HOST_APP_SEC_PSK // Store the PSK value. This call takes might take few seconds to return do { DisplayLCD(LCD_LINE8, "Setting PSK"); rxMsgId = AtLibGs_CalcNStorePSK(HOST_APP_AP_SSID, HOST_APP_AP_SEC_PSK); } while (ATLIBGS_MSG_ID_OK != rxMsgId); #endif #ifdef HOST_APP_SEC_OPEN // Store the PSK value. This call takes might take few seconds to return do { DisplayLCD(LCD_LINE8, "No Security" ); rxMsgId = AtLibGs_SetAuthentictionMode(1); } while (ATLIBGS_MSG_ID_OK != rxMsgId); #endif #ifdef HOST_APP_WPA // Set AT+WAUTH=0 for WPA or WPA2 do { DisplayLCD(LCD_LINE8, " WPA " ); rxMsgId = AtLibGs_SetAuthentictionMode(0); } while (ATLIBGS_MSG_ID_OK != rxMsgId); // Store the PSK value. This call takes might take few seconds to return do { DisplayLCD(LCD_LINE8, "Setting PSK"); rxMsgId = AtLibGs_CalcNStorePSK(HOST_APP_AP_SSID, HOST_APP_AP_SEC_PSK); } while (ATLIBGS_MSG_ID_OK != rxMsgId); // Security Configuration do { DisplayLCD(LCD_LINE8, " WPA "); rxMsgId = AtLibGs_SetSecurity(4); } while (ATLIBGS_MSG_ID_OK != rxMsgId); #endif #ifdef HOST_APP_WPA2 // Set AT+WAUTH=0 for WPA or WPA2 do { DisplayLCD(LCD_LINE8, " WPA2 " ); rxMsgId = AtLibGs_SetAuthentictionMode(ATLIBGS_AUTHMODE_NONE_WPA); } while (ATLIBGS_MSG_ID_OK != rxMsgId); // Store the PSK value. This call takes might take few seconds to return do { DisplayLCD(LCD_LINE8, "Setting PSK"); rxMsgId = AtLibGs_CalcNStorePSK(HOST_APP_AP_SSID, HOST_APP_AP_SEC_PSK); } while (ATLIBGS_MSG_ID_OK != rxMsgId); // Security Configuration do { DisplayLCD(LCD_LINE8, " Set WPA "); rxMsgId = AtLibGs_SetSecurity(ATLIBGS_SMWPA2PSK); } while (ATLIBGS_MSG_ID_OK != rxMsgId); #endif } // Clear MAC Address and show WIFI DisplayLCD(LCD_LINE6, " WIFI "); DisplayLCD(LCD_LINE5, " "); return rxMsgId; }
ATLIBGS_MSG_ID_E WIFI_init(int16_t showMessage) { ATLIBGS_MSG_ID_E rxMsgId = ATLIBGS_MSG_ID_NONE; // Check the link #ifdef HOST_APP_DEBUG_ENABLE ConsolePrintf("Checking link\r\n"); #endif AtLibGs_Init(); // Wait for the banner MSTimerDelay(500); /* Send command to check */ do { AtLibGs_FlushIncomingMessage(); DisplayLCD(LCD_LINE4, "wl_check.. "); rxMsgId = AtLibGs_Check(); } while (ATLIBGS_MSG_ID_OK != rxMsgId); do { rxMsgId = AtLibGs_SetEcho(0); // disable Echo }while (ATLIBGS_MSG_ID_OK != rxMsgId); do { rxMsgId = AtLibGs_Version(); // check the GS version }while (ATLIBGS_MSG_ID_OK != rxMsgId); #if 0 if(strstr((const char *)MRBuffer, "2.3.")) // still debug why receive 2 extra bytes: ESC S { G_Extra2B = 2; } #endif do{ rxMsgId = AtLibGs_EnableRadio(1); // enable radio }while(rxMsgId != ATLIBGS_MSG_ID_OK); /* Get MAC Address & Show */ rxMsgId = AtLibGs_GetMAC(WiFiMAC); if (rxMsgId == ATLIBGS_MSG_ID_OK) AtLibGs_ParseGetMacResponse(WifiMAC); if (showMessage > 0) { DisplayLCD(LCD_LINE3, (const uint8_t *)WifiMAC); MSTimerDelay(2000); } do { AtLibGs_FlushIncomingMessage(); DisplayLCD(LCD_LINE4, "wl_disass.. "); rxMsgId = AtLibGs_DisAssoc(); } while (ATLIBGS_MSG_ID_OK != rxMsgId); // Enable DHCP do { DisplayLCD(LCD_LINE4, "wl_dhcpon.. "); rxMsgId = AtLibGs_DHCPSet(1); } while (ATLIBGS_MSG_ID_OK != rxMsgId); if(strlen(GNV_Setting.webprov.ssid) > 0) { if(GNV_Setting.webprov.security == ATLIBGS_PROVSECU_WEP) { do { DisplayLCD(LCD_LINE4, "wl_setwep.. "); rxMsgId = AtLibGs_SetWEP1((int8_t*)GNV_Setting.webprov.password); } while (ATLIBGS_MSG_ID_OK != rxMsgId); DisplayLCD(LCD_LINE4, "wl_wepset.. "); } else if(GNV_Setting.webprov.security == ATLIBGS_PROVSECU_WPA_PER) { do { DisplayLCD(LCD_LINE4, "wl_setpsk.. "); rxMsgId = AtLibGs_CalcNStorePSK(GNV_Setting.webprov.ssid, GNV_Setting.webprov.password); } while (ATLIBGS_MSG_ID_OK != rxMsgId); DisplayLCD(LCD_LINE4, "wl_pskset.. "); } else if(GNV_Setting.webprov.security == ATLIBGS_PROVSECU_WPA_ENT) { /* Set AT+WAUTH=0 for WPA or WPA2 */ do { DisplayLCD(LCD_LINE4, " " ); rxMsgId = AtLibGs_SetAuthentictionMode(ATLIBGS_AUTHMODE_NONE_WPA); } while (ATLIBGS_MSG_ID_OK != rxMsgId); /* Security Configuration */ do { DisplayLCD(LCD_LINE4, "wl_setsec.. "); rxMsgId = AtLibGs_SetSecurity(ATLIBGS_SMAUTO); } while (ATLIBGS_MSG_ID_OK != rxMsgId); } } else { #ifdef HOST_APP_SEC_WEP // Set AT+WAUTH=2 for WEP do { DisplayLCD(LCD_LINE4, "wl_wepauth.." ); rxMsgId = AtLibGs_SetAuthentictionMode(2); } while (ATLIBGS_MSG_ID_OK != rxMsgId); // Set WEP do { rxMsgId = AtLibGs_SetWEP1(HOST_APP_AP_SEC_WEP); } while (ATLIBGS_MSG_ID_OK != rxMsgId); /* Security Configuration */ do { rxMsgId = AtLibGs_SetSecurity(2); // WEP } while (ATLIBGS_MSG_ID_OK != rxMsgId); #endif #ifdef HOST_APP_SEC_PSK /* Store the PSK value. This call takes might take few seconds to return */ do { DisplayLCD(LCD_LINE4, "wl_setpsk.. "); rxMsgId = AtLibGs_CalcNStorePSK(HOST_APP_AP_SSID, HOST_APP_AP_SEC_PSK); } while (ATLIBGS_MSG_ID_OK != rxMsgId); #endif #ifdef HOST_APP_SEC_OPEN /* Store the PSK value. This call takes might take few seconds to return */ do { DisplayLCD(LCD_LINE4, "wl_nosec.. " ); rxMsgId = AtLibGs_SetAuthentictionMode(1); } while (ATLIBGS_MSG_ID_OK != rxMsgId); #endif #ifdef HOST_APP_WPA // Set AT+WAUTH=0 for WPA or WPA2 do { DisplayLCD(LCD_LINE4, "wl_wpa.. " ); rxMsgId = AtLibGs_SetAuthentictionMode(0); } while (ATLIBGS_MSG_ID_OK != rxMsgId); /* Store the PSK value. This call takes might take few seconds to return */ do { DisplayLCD(LCD_LINE4, "wl_setpsk.. "); rxMsgId = AtLibGs_CalcNStorePSK(HOST_APP_AP_SSID, HOST_APP_AP_SEC_PSK); } while (ATLIBGS_MSG_ID_OK != rxMsgId); /* Security Configuration */ do { DisplayLCD(LCD_LINE4, "wl_wpa.. "); rxMsgId = AtLibGs_SetSecurity(4); } while (ATLIBGS_MSG_ID_OK != rxMsgId); #endif #ifdef HOST_APP_WPA2 // Set AT+WAUTH=0 for WPA or WPA2 do { DisplayLCD(LCD_LINE4, "wl_wpa2.. " ); rxMsgId = AtLibGs_SetAuthentictionMode(ATLIBGS_AUTHMODE_NONE_WPA); } while (ATLIBGS_MSG_ID_OK != rxMsgId); /* Store the PSK value. This call takes might take few seconds to return */ do { DisplayLCD(LCD_LINE4, "wl_setpsk.. "); rxMsgId = AtLibGs_CalcNStorePSK(HOST_APP_AP_SSID, HOST_APP_AP_SEC_PSK); } while (ATLIBGS_MSG_ID_OK != rxMsgId); /* Security Configuration */ do { DisplayLCD(LCD_LINE4, "wl_setwpa.. "); rxMsgId = AtLibGs_SetSecurity(ATLIBGS_SMWPA2PSK); } while (ATLIBGS_MSG_ID_OK != rxMsgId); #endif } return rxMsgId; }