Legacy event loop

API Reference

Functions

esp_err_t esp_event_send(system_event_t *event)

Send a event to event task.

Other task/modules, such as the tcpip_adapter, can call this API to send an event to event task

备注

This API is part of the legacy event system. New code should use event library API in esp_event.h

参数

event – Event to send

返回

ESP_OK : succeed

返回

others : fail

esp_err_t esp_event_send_internal(esp_event_base_t event_base, int32_t event_id, void *event_data, size_t event_data_size, TickType_t ticks_to_wait)

Send a event to event task.

Other task/modules, such as the tcpip_adapter, can call this API to send an event to event task

备注

This API is used by WiFi Driver only.

参数
  • event_base[in] the event base that identifies the event

  • event_id[in] the event id that identifies the event

  • event_data[in] the data, specific to the event occurence, that gets passed to the handler

  • event_data_size[in] the size of the event data

  • ticks_to_wait[in] number of ticks to block on a full event queue

返回

ESP_OK : succeed

返回

others : fail

esp_err_t esp_event_process_default(system_event_t *event)

Default event handler for system events.

This function performs default handling of system events. When using esp_event_loop APIs, it is called automatically before invoking the user-provided callback function.

Applications which implement a custom event loop must call this function as part of event processing.

备注

This API is part of the legacy event system. New code should use event library API in esp_event.h

参数

event – pointer to event to be handled

返回

ESP_OK if an event was handled successfully

void esp_event_set_default_eth_handlers(void)

Install default event handlers for Ethernet interface.

备注

This API is part of the legacy event system. New code should use event library API in esp_event.h

void esp_event_set_default_wifi_handlers(void)

Install default event handlers for Wi-Fi interfaces (station and AP)

备注

This API is part of the legacy event system. New code should use event library API in esp_event.h

esp_err_t esp_event_loop_init(system_event_cb_t cb, void *ctx)

Initialize event loop.

Create the event handler and task

备注

This API is part of the legacy event system. New code should use event library API in esp_event.h

参数
  • cb – application specified event callback, it can be modified by call esp_event_set_cb

  • ctx – reserved for user

返回

  • ESP_OK: succeed

  • others: fail

system_event_cb_t esp_event_loop_set_cb(system_event_cb_t cb, void *ctx)

Set application specified event callback function.

Attention

1. If cb is NULL, means application don’t need to handle If cb is not NULL, it will be call when an event is received, after the default event callback is completed

备注

This API is part of the legacy event system. New code should use event library API in esp_event.h

参数
  • cb – application callback function

  • ctx – argument to be passed to callback

返回

old callback

Unions

union system_event_info_t
#include <esp_event_legacy.h>

Union of all possible system_event argument structures

Public Members

system_event_sta_connected_t connected

ESP32 station connected to AP

system_event_sta_disconnected_t disconnected

ESP32 station disconnected to AP

system_event_sta_scan_done_t scan_done

ESP32 station scan (APs) done

system_event_sta_authmode_change_t auth_change

the auth mode of AP ESP32 station connected to changed

system_event_sta_got_ip_t got_ip

ESP32 station got IP, first time got IP or when IP is changed

system_event_sta_wps_er_pin_t sta_er_pin

ESP32 station WPS enrollee mode PIN code received

system_event_sta_wps_fail_reason_t sta_er_fail_reason

ESP32 station WPS enrollee mode failed reason code received

system_event_sta_wps_er_success_t sta_er_success

ESP32 station WPS enrollee success

system_event_ap_staconnected_t sta_connected

a station connected to ESP32 soft-AP

system_event_ap_stadisconnected_t sta_disconnected

a station disconnected to ESP32 soft-AP

system_event_ap_probe_req_rx_t ap_probereqrecved

ESP32 soft-AP receive probe request packet

system_event_ftm_report_t ftm_report

Report of FTM procedure

system_event_ap_staipassigned_t ap_staipassigned

ESP32 soft-AP assign an IP to the station

system_event_got_ip6_t got_ip6

ESP32 station or ap or ethernet ipv6 addr state change to preferred

Structures

struct system_event_t

Event, as a tagged enum

Public Members

system_event_id_t event_id

event ID

system_event_info_t event_info

event information

Macros

SYSTEM_EVENT_AP_STA_GOT_IP6

Type Definitions

typedef wifi_event_sta_wps_fail_reason_t system_event_sta_wps_fail_reason_t

Argument structure of SYSTEM_EVENT_STA_WPS_ER_FAILED event

typedef wifi_event_sta_scan_done_t system_event_sta_scan_done_t

Argument structure of SYSTEM_EVENT_SCAN_DONE event

typedef wifi_event_sta_connected_t system_event_sta_connected_t

Argument structure of SYSTEM_EVENT_STA_CONNECTED event

typedef wifi_event_sta_disconnected_t system_event_sta_disconnected_t

Argument structure of SYSTEM_EVENT_STA_DISCONNECTED event

typedef wifi_event_sta_authmode_change_t system_event_sta_authmode_change_t

Argument structure of SYSTEM_EVENT_STA_AUTHMODE_CHANGE event

typedef wifi_event_sta_wps_er_pin_t system_event_sta_wps_er_pin_t

Argument structure of SYSTEM_EVENT_STA_WPS_ER_PIN event

typedef wifi_event_sta_wps_er_success_t system_event_sta_wps_er_success_t

Argument structure of SYSTEM_EVENT_STA_WPS_ER_PIN event

typedef wifi_event_ap_staconnected_t system_event_ap_staconnected_t

Argument structure of event

typedef wifi_event_ap_stadisconnected_t system_event_ap_stadisconnected_t

Argument structure of event

typedef wifi_event_ap_probe_req_rx_t system_event_ap_probe_req_rx_t

Argument structure of event

typedef wifi_event_ftm_report_t system_event_ftm_report_t

Argument structure of SYSTEM_EVENT_FTM_REPORT event

typedef ip_event_ap_staipassigned_t system_event_ap_staipassigned_t

Argument structure of event

typedef ip_event_got_ip_t system_event_sta_got_ip_t

Argument structure of event

typedef ip_event_got_ip6_t system_event_got_ip6_t

Argument structure of event

typedef esp_err_t (*system_event_handler_t)(esp_event_base_t event_base, int32_t event_id, void *event_data, size_t event_data_size, TickType_t ticks_to_wait)

Event handler function type

typedef esp_err_t (*system_event_cb_t)(void *ctx, system_event_t *event)

Application specified event callback function.

备注

This API is part of the legacy event system. New code should use event library API in esp_event.h

Param ctx

reserved for user

Param event

event type defined in this file

Return

  • ESP_OK: succeed

  • others: fail

Enumerations

enum system_event_id_t

System event types enumeration

Values:

enumerator SYSTEM_EVENT_WIFI_READY

ESP32 WiFi ready

enumerator SYSTEM_EVENT_SCAN_DONE

ESP32 finish scanning AP

enumerator SYSTEM_EVENT_STA_START

ESP32 station start

enumerator SYSTEM_EVENT_STA_STOP

ESP32 station stop

enumerator SYSTEM_EVENT_STA_CONNECTED

ESP32 station connected to AP

enumerator SYSTEM_EVENT_STA_DISCONNECTED

ESP32 station disconnected from AP

enumerator SYSTEM_EVENT_STA_AUTHMODE_CHANGE

the auth mode of AP connected by ESP32 station changed

enumerator SYSTEM_EVENT_STA_GOT_IP

ESP32 station got IP from connected AP

enumerator SYSTEM_EVENT_STA_LOST_IP

ESP32 station lost IP and the IP is reset to 0

enumerator SYSTEM_EVENT_STA_BSS_RSSI_LOW

ESP32 station connected BSS rssi goes below threshold

enumerator SYSTEM_EVENT_STA_WPS_ER_SUCCESS

ESP32 station wps succeeds in enrollee mode

enumerator SYSTEM_EVENT_STA_WPS_ER_FAILED

ESP32 station wps fails in enrollee mode

enumerator SYSTEM_EVENT_STA_WPS_ER_TIMEOUT

ESP32 station wps timeout in enrollee mode

enumerator SYSTEM_EVENT_STA_WPS_ER_PIN

ESP32 station wps pin code in enrollee mode

enumerator SYSTEM_EVENT_STA_WPS_ER_PBC_OVERLAP

ESP32 station wps overlap in enrollee mode

enumerator SYSTEM_EVENT_AP_START

ESP32 soft-AP start

enumerator SYSTEM_EVENT_AP_STOP

ESP32 soft-AP stop

enumerator SYSTEM_EVENT_AP_STACONNECTED

a station connected to ESP32 soft-AP

enumerator SYSTEM_EVENT_AP_STADISCONNECTED

a station disconnected from ESP32 soft-AP

enumerator SYSTEM_EVENT_AP_STAIPASSIGNED

ESP32 soft-AP assign an IP to a connected station

enumerator SYSTEM_EVENT_AP_PROBEREQRECVED

Receive probe request packet in soft-AP interface

enumerator SYSTEM_EVENT_ACTION_TX_STATUS

Receive status of Action frame transmitted

enumerator SYSTEM_EVENT_ROC_DONE

Indicates the completion of Remain-on-Channel operation status

enumerator SYSTEM_EVENT_STA_BEACON_TIMEOUT

ESP32 station beacon timeout

enumerator SYSTEM_EVENT_FTM_REPORT

Receive report of FTM procedure

enumerator SYSTEM_EVENT_GOT_IP6

ESP32 station or ap or ethernet interface v6IP addr is preferred

enumerator SYSTEM_EVENT_ETH_START

ESP32 ethernet start

enumerator SYSTEM_EVENT_ETH_STOP

ESP32 ethernet stop

enumerator SYSTEM_EVENT_ETH_CONNECTED

ESP32 ethernet phy link up

enumerator SYSTEM_EVENT_ETH_DISCONNECTED

ESP32 ethernet phy link down

enumerator SYSTEM_EVENT_ETH_GOT_IP

ESP32 ethernet got IP from connected AP

enumerator SYSTEM_EVENT_ETH_LOST_IP

ESP32 ethernet lost IP and the IP is reset to 0

enumerator SYSTEM_EVENT_MAX

Number of members in this enum