Repo for ESP32 Weather Station Development
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

96 lignes
3.1KB

  1. /*
  2. * wifi.c
  3. *
  4. * Created on: 21 Apr 2020
  5. * Author: Chris
  6. */
  7. #include "wifi.h"
  8. #define WIFI_CONNECTED_BIT BIT0
  9. #define WIFI_FAIL_BIT BIT1
  10. static EventGroupHandle_t s_wifi_event_group;
  11. static const char *TAG = "wifi station";
  12. static int s_retry_num = 0;
  13. static void event_handler(void* arg, esp_event_base_t event_base,
  14. int32_t event_id, void* event_data)
  15. {
  16. if (event_base == WIFI_EVENT && event_id == WIFI_EVENT_STA_START) {
  17. esp_wifi_connect();
  18. } else if (event_base == WIFI_EVENT && event_id == WIFI_EVENT_STA_DISCONNECTED) {
  19. if (s_retry_num < CONFIG_ESP_WIFI_RETRIES) {
  20. esp_wifi_connect();
  21. s_retry_num++;
  22. ESP_LOGI(TAG, "retry to connect to the AP");
  23. } else {
  24. xEventGroupSetBits(s_wifi_event_group, WIFI_FAIL_BIT);
  25. }
  26. ESP_LOGI(TAG,"connect to the AP fail");
  27. } else if (event_base == IP_EVENT && event_id == IP_EVENT_STA_GOT_IP) {
  28. ip_event_got_ip_t* event = (ip_event_got_ip_t*) event_data;
  29. ESP_LOGI(TAG, "got ip:%s",
  30. ip4addr_ntoa(&event->ip_info.ip));
  31. s_retry_num = 0;
  32. xEventGroupSetBits(s_wifi_event_group, WIFI_CONNECTED_BIT);
  33. }
  34. }
  35. void init_wifi_sta()
  36. {
  37. //Initialize NVS
  38. esp_err_t ret = nvs_flash_init();
  39. if (ret == ESP_ERR_NVS_NO_FREE_PAGES || ret == ESP_ERR_NVS_NEW_VERSION_FOUND) {
  40. ESP_ERROR_CHECK(nvs_flash_erase());
  41. ret = nvs_flash_init();
  42. }
  43. ESP_ERROR_CHECK(ret);
  44. s_wifi_event_group = xEventGroupCreate();
  45. tcpip_adapter_init();
  46. ESP_ERROR_CHECK(esp_event_loop_create_default());
  47. wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT();
  48. ESP_ERROR_CHECK(esp_wifi_init(&cfg));
  49. ESP_ERROR_CHECK(esp_event_handler_register(WIFI_EVENT, ESP_EVENT_ANY_ID, &event_handler, NULL));
  50. ESP_ERROR_CHECK(esp_event_handler_register(IP_EVENT, IP_EVENT_STA_GOT_IP, &event_handler, NULL));
  51. wifi_config_t wifi_config = {
  52. .sta = {
  53. .ssid = CONFIG_ESP_WIFI_SSID,
  54. .password = CONFIG_ESP_WIFI_PASSWORD
  55. },
  56. };
  57. ESP_ERROR_CHECK(esp_wifi_set_mode(WIFI_MODE_STA) );
  58. ESP_ERROR_CHECK(esp_wifi_set_config(ESP_IF_WIFI_STA, &wifi_config) );
  59. ESP_ERROR_CHECK(esp_wifi_start() );
  60. ESP_LOGI(TAG, "wifi_init_sta finished.");
  61. /* Waiting until either the connection is established (WIFI_CONNECTED_BIT) or connection failed for the maximum
  62. * number of re-tries (WIFI_FAIL_BIT). The bits are set by event_handler() (see above) */
  63. EventBits_t bits = xEventGroupWaitBits(s_wifi_event_group,
  64. WIFI_CONNECTED_BIT | WIFI_FAIL_BIT,
  65. pdFALSE,
  66. pdFALSE,
  67. portMAX_DELAY);
  68. //tcpip_adapter_set_ip_info(TCPIP_ADAPTER_IF_STA, &info);
  69. /* xEventGroupWaitBits() returns the bits before the call returned, hence we can test which event actually
  70. * happened. */
  71. if (bits & WIFI_CONNECTED_BIT) {
  72. ESP_LOGI(TAG, "connected to ap SSID:%s",
  73. CONFIG_ESP_WIFI_SSID);
  74. } else if (bits & WIFI_FAIL_BIT) {
  75. ESP_LOGI(TAG, "Failed to connect to SSID:%s",
  76. CONFIG_ESP_WIFI_SSID);
  77. } else {
  78. ESP_LOGE(TAG, "UNEXPECTED EVENT");
  79. }
  80. }