esp32之wifi状态机

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/fengfeng0328/article/details/82824499

对于esp32模组来说,wifi是重中之重,没有wifi的esp32绝对是个大冷门,下面来探讨一下esp32wifi的工作原理:

分析代码,路径esp-idf/examples/wifi/simple_wifi

    #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_loop.h"
    #include "esp_log.h"
    #include "nvs_flash.h"
     
    #include "lwip/err.h"
    #include "lwip/sys.h"
     
    /* The examples use simple WiFi configuration that you can set via
       'make menuconfig'.
       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_MODE_AP   CONFIG_ESP_WIFI_MODE_AP //TRUE:AP FALSE:STA
    #define EXAMPLE_ESP_WIFI_SSID      CONFIG_ESP_WIFI_SSID
    #define EXAMPLE_ESP_WIFI_PASS      CONFIG_ESP_WIFI_PASSWORD
    #define EXAMPLE_MAX_STA_CONN       CONFIG_MAX_STA_CONN
     
    /* FreeRTOS event group to signal when we are connected*/
    static EventGroupHandle_t 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 = "simple wifi";
     
    static esp_err_t event_handler(void *ctx, system_event_t *event)
    {
        switch(event->event_id) {
        case SYSTEM_EVENT_STA_START:
            esp_wifi_connect();
            break;
        case SYSTEM_EVENT_STA_GOT_IP:
            ESP_LOGI(TAG, "got ip:%s",
                     ip4addr_ntoa(&event->event_info.got_ip.ip_info.ip));
            xEventGroupSetBits(wifi_event_group, WIFI_CONNECTED_BIT);
            break;
        case SYSTEM_EVENT_AP_STACONNECTED:
            ESP_LOGI(TAG, "station:"MACSTR" join, AID=%d",
                     MAC2STR(event->event_info.sta_connected.mac),
                     event->event_info.sta_connected.aid);
            break;
        case SYSTEM_EVENT_AP_STADISCONNECTED:
            ESP_LOGI(TAG, "station:"MACSTR"leave, AID=%d",
                     MAC2STR(event->event_info.sta_disconnected.mac),
                     event->event_info.sta_disconnected.aid);
            break;
        case SYSTEM_EVENT_STA_DISCONNECTED:
            esp_wifi_connect();
            xEventGroupClearBits(wifi_event_group, WIFI_CONNECTED_BIT);
            break;
        default:
            break;
        }
        return ESP_OK;
    }
     
    void wifi_init_softap()
    {
        wifi_event_group = xEventGroupCreate();
     
        tcpip_adapter_init();
        ESP_ERROR_CHECK(esp_event_loop_init(event_handler, NULL));
     
        wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT();
        ESP_ERROR_CHECK(esp_wifi_init(&cfg));
        wifi_config_t wifi_config = {
            .ap = {
                .ssid = EXAMPLE_ESP_WIFI_SSID,
                .ssid_len = strlen(EXAMPLE_ESP_WIFI_SSID),
                .password = EXAMPLE_ESP_WIFI_PASS,
                .max_connection = EXAMPLE_MAX_STA_CONN,
                .authmode = WIFI_AUTH_WPA_WPA2_PSK
            },
        };
        if (strlen(EXAMPLE_ESP_WIFI_PASS) == 0) {
            wifi_config.ap.authmode = WIFI_AUTH_OPEN;
        }
     
        ESP_ERROR_CHECK(esp_wifi_set_mode(WIFI_MODE_AP));
        ESP_ERROR_CHECK(esp_wifi_set_config(ESP_IF_WIFI_AP, &wifi_config));
        ESP_ERROR_CHECK(esp_wifi_start());
     
        ESP_LOGI(TAG, "wifi_init_softap finished.SSID:%s password:%s",
                 EXAMPLE_ESP_WIFI_SSID, EXAMPLE_ESP_WIFI_PASS);
    }
     
    void wifi_init_sta()
    {
        wifi_event_group = xEventGroupCreate();
     
        tcpip_adapter_init();
        ESP_ERROR_CHECK(esp_event_loop_init(event_handler, NULL) );
     
        wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT();
        ESP_ERROR_CHECK(esp_wifi_init(&cfg));
        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);
    }
     
    void app_main()
    {
        //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);
        
    #if EXAMPLE_ESP_WIFI_MODE_AP
        ESP_LOGI(TAG, "ESP_WIFI_MODE_AP");
        wifi_init_softap();
    #else
        ESP_LOGI(TAG, "ESP_WIFI_MODE_STA");
        wifi_init_sta();
    #endif /*EXAMPLE_ESP_WIFI_MODE_AP*/
     
    }

这代码的功能是开启一个wifi热点,可选择AP模式或STA模式,代码的调用也是非常简单的,我就不一一分析了,我直接把API调用流程图放过来,一看便清楚:

按一定的流程调用一些API,期间需要自己设定一些自定义参数,如SSID,PASSWD等

接下来分析一下esp32wifi状态机工作原理,注意:esp32wifi底层驱动是不开源的,这也是很多芯片厂商一贯的作法,因为开源了底层驱动,基本上也就开源了硬件参数,产品很容易被有心人复制或者盗版,以下是esp32wifi状态机工作原理的流程图:

可以得出结论:

1.用户自定义状态机回调函数

2.回调函数作为形参的方式传递给esp_event_loop_init(event_handler,NULL)函数

3.创建任务esp_event_loop_task一直监测状态机状态,当底层驱动传递过来新状态时,自定义函数得到回调

 

就这样分析完esp32状态机的工作原理,有兴趣的可以根据上述图表跟进源码
————————————————
版权声明:本文为CSDN博主「物联网研究室」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/fengfeng0328/article/details/82824499

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ESP32 WiFi透传是指通过ESP32模块实现无线数据传输的功能。ESP32是一款集成了WiFi和蓝牙功能的微控制器,其强大的处理能力和丰富的通信接口使其成为物联网和无线通信领域的热门选择。 在进行ESP32 WiFi透传时,首先需要将ESP32作为一个WiFi模块连接到局域网中的无线网络。ESP32可以通过接入点模式或者客户端模式连接到无线网络,可以设置连接名称和密码进行认证。 一旦ESP32与无线网络连接成功,它就可以作为一个网络设备,通过WiFi透传来传输数据。在透传模式下,ESP32可以通过TCP或者UDP协议与其他设备进行通信。它可以充当服务器或者客户端,接收或者发送数据。 ESP32透传的应用非常广泛。它可以作为物联网设备的数据传输通道,将传感器数据、设备状态或者控制命令发送到云平台或者其他设备。同时,它也可以作为远程控制的接收端,接收来自手机或者计算机的指令,并按照指令进行相应的操作。 ESP32 WiFi透传的实现也非常方便。使用ESP-IDF或者Arduino框架,开发人员可以很容易地编写代码来控制ESP32WiFi功能,并实现数据的收发。同时,许多第三方库和例程也可用于快速开发,进一步简化了开发过程。 总而言之,ESP32 WiFi透传是一种使用ESP32模块进行无线数据传输的技术。它通过连接到无线网络,并通过WiFi透传的方式实现数据的收发。这一功能的广泛应用和便捷实现,使得ESP32在物联网和无线通信领域具有广阔的应用前景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值