Legacy event loop
API Reference
Header File
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 - Note - This API is part of the legacy event system. New code should use event library API in esp_event.h - Parameters
- event – Event to send 
- Returns
- ESP_OK : succeed 
- Returns
- 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 - Note - This API is used by WiFi Driver only. - Parameters
- 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 
 
- Returns
- ESP_OK : succeed 
- Returns
- 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. - Note - This API is part of the legacy event system. New code should use event library API in esp_event.h - Parameters
- event – pointer to event to be handled 
- Returns
- ESP_OK if an event was handled successfully 
 
- 
void esp_event_set_default_eth_handlers(void)
- Install default event handlers for Ethernet interface. - Note - 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) - Note - 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 - Note - This API is part of the legacy event system. New code should use event library API in esp_event.h - Parameters
- cb – application specified event callback, it can be modified by call esp_event_set_cb 
- ctx – reserved for user 
 
- Returns
- 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 
 - Note - This API is part of the legacy event system. New code should use event library API in esp_event.h - Parameters
- cb – application callback function 
- ctx – argument to be passed to callback 
 
- Returns
- 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 
 
- 
system_event_sta_connected_t connected
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 
 
- 
system_event_id_t event_id
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. - Note - 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 
 
- 
enumerator SYSTEM_EVENT_WIFI_READY