| 
									
										
										
										
											2019-06-26 01:03:55 +05:30
										 |  |  | /* Local Ctrl Example
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    This example code is in the Public Domain (or CC0 licensed, at your option.) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Unless required by applicable law or agreed to in writing, this | 
					
						
							|  |  |  |    software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR | 
					
						
							|  |  |  |    CONDITIONS OF ANY KIND, either express or implied. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #include "freertos/FreeRTOS.h"
 | 
					
						
							|  |  |  | #include "freertos/task.h"
 | 
					
						
							|  |  |  | #include "freertos/event_groups.h"
 | 
					
						
							|  |  |  | #include "esp_system.h"
 | 
					
						
							|  |  |  | #include "esp_wifi.h"
 | 
					
						
							|  |  |  | #include "esp_event.h"
 | 
					
						
							|  |  |  | #include "esp_log.h"
 | 
					
						
							|  |  |  | #include "nvs_flash.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "lwip/err.h"
 | 
					
						
							|  |  |  | #include "lwip/sys.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-02 09:01:20 +05:30
										 |  |  | /* The examples use WiFi configuration that you can set via 'idf.py menuconfig'.
 | 
					
						
							| 
									
										
										
										
											2019-06-26 01:03:55 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |    If you'd rather not, just change the below entries to strings with | 
					
						
							|  |  |  |    the config you want - ie #define EXAMPLE_WIFI_SSID "mywifissid" | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | #define EXAMPLE_ESP_WIFI_SSID      CONFIG_ESP_WIFI_SSID
 | 
					
						
							|  |  |  | #define EXAMPLE_ESP_WIFI_PASS      CONFIG_ESP_WIFI_PASSWORD
 | 
					
						
							|  |  |  | #define EXAMPLE_ESP_MAXIMUM_RETRY  CONFIG_ESP_MAXIMUM_RETRY
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* FreeRTOS event group to signal when we are connected*/ | 
					
						
							|  |  |  | static EventGroupHandle_t s_wifi_event_group; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* The event group allows multiple bits for each event, but we only care about one event
 | 
					
						
							|  |  |  |  * - are we connected to the AP with an IP? */ | 
					
						
							|  |  |  | const int WIFI_CONNECTED_BIT = BIT0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static const char *TAG = "local_ctrl_example"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int s_retry_num = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void event_handler(void* arg, esp_event_base_t event_base, | 
					
						
							|  |  |  |                                 int32_t event_id, void* event_data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (event_base == WIFI_EVENT && event_id == WIFI_EVENT_STA_START) { | 
					
						
							|  |  |  |         esp_wifi_connect(); | 
					
						
							|  |  |  |     } else if (event_base == WIFI_EVENT && event_id == WIFI_EVENT_STA_DISCONNECTED) { | 
					
						
							|  |  |  |         if (s_retry_num < EXAMPLE_ESP_MAXIMUM_RETRY) { | 
					
						
							|  |  |  |             esp_wifi_connect(); | 
					
						
							|  |  |  |             xEventGroupClearBits(s_wifi_event_group, WIFI_CONNECTED_BIT); | 
					
						
							|  |  |  |             s_retry_num++; | 
					
						
							|  |  |  |             ESP_LOGI(TAG, "retry to connect to the AP"); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         ESP_LOGI(TAG,"connect to the AP fail"); | 
					
						
							|  |  |  |     } else if (event_base == IP_EVENT && event_id == IP_EVENT_STA_GOT_IP) { | 
					
						
							|  |  |  |         ip_event_got_ip_t* event = (ip_event_got_ip_t*) event_data; | 
					
						
							| 
									
										
										
										
											2019-08-20 14:40:34 +02:00
										 |  |  |         ESP_LOGI(TAG, "got ip:" IPSTR, IP2STR(&event->ip_info.ip)); | 
					
						
							| 
									
										
										
										
											2019-06-26 01:03:55 +05:30
										 |  |  |         s_retry_num = 0; | 
					
						
							|  |  |  |         xEventGroupSetBits(s_wifi_event_group, WIFI_CONNECTED_BIT); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-16 16:33:30 +07:00
										 |  |  | void wifi_init_sta(void) | 
					
						
							| 
									
										
										
										
											2019-06-26 01:03:55 +05:30
										 |  |  | { | 
					
						
							|  |  |  |     s_wifi_event_group = xEventGroupCreate(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     tcpip_adapter_init(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_ERROR_CHECK(esp_event_loop_create_default()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT(); | 
					
						
							|  |  |  |     ESP_ERROR_CHECK(esp_wifi_init(&cfg)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_ERROR_CHECK(esp_event_handler_register(WIFI_EVENT, ESP_EVENT_ANY_ID, &event_handler, NULL)); | 
					
						
							|  |  |  |     ESP_ERROR_CHECK(esp_event_handler_register(IP_EVENT, IP_EVENT_STA_GOT_IP, &event_handler, NULL)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     wifi_config_t wifi_config = { | 
					
						
							|  |  |  |         .sta = { | 
					
						
							|  |  |  |             .ssid = EXAMPLE_ESP_WIFI_SSID, | 
					
						
							|  |  |  |             .password = EXAMPLE_ESP_WIFI_PASS | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     ESP_ERROR_CHECK(esp_wifi_set_mode(WIFI_MODE_STA) ); | 
					
						
							|  |  |  |     ESP_ERROR_CHECK(esp_wifi_set_config(ESP_IF_WIFI_STA, &wifi_config) ); | 
					
						
							|  |  |  |     ESP_ERROR_CHECK(esp_wifi_start() ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGI(TAG, "wifi_init_sta finished."); | 
					
						
							|  |  |  |     ESP_LOGI(TAG, "connect to ap SSID:%s password:%s", | 
					
						
							|  |  |  |              EXAMPLE_ESP_WIFI_SSID, EXAMPLE_ESP_WIFI_PASS); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Function responsible for configuring and starting the esp_local_ctrl service.
 | 
					
						
							|  |  |  |  * See local_ctrl_service.c for implementation */ | 
					
						
							|  |  |  | extern void start_esp_local_ctrl_service(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-16 16:33:30 +07:00
										 |  |  | void app_main(void) | 
					
						
							| 
									
										
										
										
											2019-06-26 01:03:55 +05:30
										 |  |  | { | 
					
						
							|  |  |  |     //Initialize NVS
 | 
					
						
							|  |  |  |     esp_err_t ret = nvs_flash_init(); | 
					
						
							|  |  |  |     if (ret == ESP_ERR_NVS_NO_FREE_PAGES || ret == ESP_ERR_NVS_NEW_VERSION_FOUND) { | 
					
						
							|  |  |  |       ESP_ERROR_CHECK(nvs_flash_erase()); | 
					
						
							|  |  |  |       ret = nvs_flash_init(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     ESP_ERROR_CHECK(ret); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGI(TAG, "ESP_WIFI_MODE_STA"); | 
					
						
							|  |  |  |     wifi_init_sta(); | 
					
						
							|  |  |  |     start_esp_local_ctrl_service(); | 
					
						
							|  |  |  | } |