Zephyr Project API 3.5.0
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
wifi.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018 Texas Instruments, Incorporated
3 * Copyright (c) 2023 Nordic Semiconductor ASA
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
20#ifndef ZEPHYR_INCLUDE_NET_WIFI_H_
21#define ZEPHYR_INCLUDE_NET_WIFI_H_
22
23#include <zephyr/sys/util.h> /* for ARRAY_SIZE */
24
25#define WIFI_COUNTRY_CODE_LEN 2
26
27#define WIFI_LISTEN_INTERVAL_MIN 0
28#define WIFI_LISTEN_INTERVAL_MAX 65535
29
30#ifdef __cplusplus
31extern "C" {
32#endif
33
57
59const char * const wifi_security_txt(enum wifi_security_type security);
60
69
70 __WIFI_MFP_AFTER_LAST,
71 WIFI_MFP_MAX = __WIFI_MFP_AFTER_LAST - 1,
73};
74
76const char * const wifi_mfp_txt(enum wifi_mfp_options mfp);
77
88
90 __WIFI_FREQ_BAND_AFTER_LAST,
92 WIFI_FREQ_BAND_MAX = __WIFI_FREQ_BAND_AFTER_LAST - 1,
95};
96
98const char * const wifi_band_txt(enum wifi_frequency_bands band);
99
100#define WIFI_SSID_MAX_LEN 32
101#define WIFI_PSK_MIN_LEN 8
102#define WIFI_PSK_MAX_LEN 64
103#define WIFI_SAE_PSWD_MAX_LEN 128
104#define WIFI_MAC_ADDR_LEN 6
105
106#define WIFI_CHANNEL_MIN 1
107#define WIFI_CHANNEL_MAX 233
108#define WIFI_CHANNEL_ANY 255
109
140
142const char * const wifi_state_txt(enum wifi_iface_state state);
143
166
168const char * const wifi_mode_txt(enum wifi_iface_mode mode);
169
193
194 __WIFI_LINK_MODE_AFTER_LAST,
195 WIFI_LINK_MODE_MAX = __WIFI_LINK_MODE_AFTER_LAST - 1,
198
200const char * const wifi_link_mode_txt(enum wifi_link_mode link_mode);
201
209
217
219const char * const wifi_ps_txt(enum wifi_ps ps_name);
220
225 /* This has to be configured before connecting to the AP,
226 * as support for ADDTS action frames is not available.
227 */
230};
231
233const char * const wifi_ps_mode_txt(enum wifi_ps_mode ps_mode);
234
235/* Interface index Min and Max values */
236#define WIFI_INTERFACE_INDEX_MIN 1
237#define WIFI_INTERFACE_INDEX_MAX 255
238
254
266
274
276const char * const wifi_twt_operation_txt(enum wifi_twt_operation twt_operation);
277
287
289const char * const wifi_twt_negotiation_type_txt(enum wifi_twt_negotiation_type twt_negotiation);
290
310
312const char * const wifi_twt_setup_cmd_txt(enum wifi_twt_setup_cmd twt_setup);
313
321
347
349static const char * const wifi_twt_err_code_tbl[] = {
350 [WIFI_TWT_FAIL_UNSPECIFIED] = "Unspecified",
351 [WIFI_TWT_FAIL_CMD_EXEC_FAIL] = "Command Execution failed",
353 "Operation not supported",
355 "Unable to get iface status",
357 "Device not connected",
358 [WIFI_TWT_FAIL_PEER_NOT_HE_CAPAB] = "Peer not HE capable",
359 [WIFI_TWT_FAIL_PEER_NOT_TWT_CAPAB] = "Peer not TWT capable",
361 "Operation already in progress",
363 "Invalid negotiated flow id",
365 "IP address not assigned",
367 "Flow already exists",
368};
372static inline const char *wifi_twt_get_err_code_str(int16_t err_no)
373{
374 if ((err_no) < (int16_t)ARRAY_SIZE(wifi_twt_err_code_tbl)) {
375 return wifi_twt_err_code_tbl[err_no];
376 }
377
378 return "<unknown>";
379}
380
394
402
404const char * const wifi_ps_wakeup_mode_txt(enum wifi_ps_wakeup_mode ps_wakeup_mode);
405
423
425static const char * const wifi_ps_param_config_err_code_tbl[] = {
426 [WIFI_PS_PARAM_FAIL_UNSPECIFIED] = "Unspecified",
427 [WIFI_PS_PARAM_FAIL_CMD_EXEC_FAIL] = "Command Execution failed",
429 "Operation not supported",
431 "Unable to get iface status",
433 "Cannot set parameters while device not connected",
435 "Cannot set parameters while device connected",
437 "Parameter out of range",
438};
442static inline const char *wifi_ps_get_config_err_code_str(int16_t err_no)
443{
444 if ((err_no) < (int16_t)ARRAY_SIZE(wifi_ps_param_config_err_code_tbl)) {
445 return wifi_ps_param_config_err_code_tbl[err_no];
446 }
447
448 return "<unknown>";
449}
450
451#ifdef __cplusplus
452}
453#endif
454
458#endif /* ZEPHYR_INCLUDE_NET_WIFI_H_ */
#define BIT(n)
Unsigned integer with bit position n set (signed in assembly language).
Definition util_macro.h:44
#define ARRAY_SIZE(array)
Number of elements in the given array.
Definition util.h:124
wifi_ps
Wi-Fi power save states.
Definition wifi.h:211
wifi_frequency_bands
IEEE 802.11 operational frequency bands (not exhaustive).
Definition wifi.h:81
wifi_mfp_options
IEEE 802.11w - Management frame protection.
Definition wifi.h:62
const char *const wifi_ps_txt(enum wifi_ps ps_name)
Helper function to get user-friendly ps name.
wifi_twt_setup_cmd
Wi-Fi Target Wake Time (TWT) setup commands.
Definition wifi.h:292
const char *const wifi_band_txt(enum wifi_frequency_bands band)
Helper function to get user-friendly frequency band name.
wifi_operational_modes
Wifi operational mode.
Definition wifi.h:240
wifi_twt_setup_resp_status
Wi-Fi Target Wake Time (TWT) negotiation status.
Definition wifi.h:315
wifi_iface_mode
Wi-Fi interface modes.
Definition wifi.h:148
wifi_twt_negotiation_type
Wi-Fi Target Wake Time (TWT) negotiation types.
Definition wifi.h:279
const char *const wifi_ps_wakeup_mode_txt(enum wifi_ps_wakeup_mode ps_wakeup_mode)
Helper function to get user-friendly ps wakeup mode name.
const char *const wifi_twt_negotiation_type_txt(enum wifi_twt_negotiation_type twt_negotiation)
Helper function to get user-friendly twt negotiation type name.
const char *const wifi_state_txt(enum wifi_iface_state state)
Helper function to get user-friendly interface state name.
static const char * wifi_ps_get_config_err_code_str(int16_t err_no)
Helper function to get user-friendly power save error code name.
Definition wifi.h:442
wifi_twt_fail_reason
Target Wake Time (TWT) error codes.
Definition wifi.h:323
wifi_iface_state
Wi-Fi interface states.
Definition wifi.h:114
wifi_filter
Mode filter settings.
Definition wifi.h:256
const char *const wifi_security_txt(enum wifi_security_type security)
Helper function to get user-friendly security type name.
const char *const wifi_ps_mode_txt(enum wifi_ps_mode ps_mode)
Helper function to get user-friendly ps mode name.
const char *const wifi_mode_txt(enum wifi_iface_mode mode)
Helper function to get user-friendly interface mode name.
static const char * wifi_twt_get_err_code_str(int16_t err_no)
Helper function to get user-friendly TWT error code name.
Definition wifi.h:372
wifi_link_mode
Wi-Fi link operating modes.
Definition wifi.h:174
wifi_ps_param_type
Wi-Fi power save parameters.
Definition wifi.h:382
wifi_ps_wakeup_mode
Wi-Fi power save modes.
Definition wifi.h:396
wifi_twt_operation
Wi-Fi Target Wake Time (TWT) operations.
Definition wifi.h:268
wifi_scan_type
Wi-Fi scanning types.
Definition wifi.h:203
const char *const wifi_link_mode_txt(enum wifi_link_mode link_mode)
Helper function to get user-friendly link mode name.
wifi_config_ps_param_fail_reason
Wi-Fi power save error codes.
Definition wifi.h:407
wifi_security_type
IEEE 802.11 security types.
Definition wifi.h:35
const char *const wifi_twt_setup_cmd_txt(enum wifi_twt_setup_cmd twt_setup)
Helper function to get user-friendly twt setup cmd name.
const char *const wifi_mfp_txt(enum wifi_mfp_options mfp)
Helper function to get user-friendly MFP name.
const char *const wifi_twt_operation_txt(enum wifi_twt_operation twt_operation)
Helper function to get user-friendly twt operation name.
wifi_ps_mode
Wi-Fi power save modes.
Definition wifi.h:222
@ WIFI_PS_ENABLED
Power save enabled.
Definition wifi.h:215
@ WIFI_PS_DISABLED
Power save disabled.
Definition wifi.h:213
@ WIFI_FREQ_BAND_6_GHZ
6 GHz band (Wi-Fi 6E, also extends to 7GHz).
Definition wifi.h:87
@ WIFI_FREQ_BAND_2_4_GHZ
2.4 GHz band.
Definition wifi.h:83
@ WIFI_FREQ_BAND_UNKNOWN
Invalid frequency band.
Definition wifi.h:94
@ WIFI_FREQ_BAND_5_GHZ
5 GHz band.
Definition wifi.h:85
@ WIFI_FREQ_BAND_MAX
Highest frequency band available.
Definition wifi.h:92
@ WIFI_MFP_DISABLE
MFP disabled.
Definition wifi.h:64
@ WIFI_MFP_OPTIONAL
MFP optional.
Definition wifi.h:66
@ WIFI_MFP_MAX
Definition wifi.h:71
@ WIFI_MFP_UNKNOWN
Definition wifi.h:72
@ WIFI_MFP_REQUIRED
MFP required.
Definition wifi.h:68
@ WIFI_TWT_SETUP_CMD_DEMAND
TWT setup demand (parameters can not be changed by AP)
Definition wifi.h:298
@ WIFI_TWT_SETUP_CMD_REQUEST
TWT setup request.
Definition wifi.h:294
@ WIFI_TWT_SETUP_CMD_ALTERNATE
TWT setup alternate (alternate parameters suggested by AP)
Definition wifi.h:304
@ WIFI_TWT_SETUP_CMD_GROUPING
TWT setup grouping (grouping of TWT flows)
Definition wifi.h:300
@ WIFI_TWT_SETUP_CMD_DICTATE
TWT setup dictate (parameters dictated by AP)
Definition wifi.h:306
@ WIFI_TWT_SETUP_CMD_SUGGEST
TWT setup suggest (parameters can be changed by AP)
Definition wifi.h:296
@ WIFI_TWT_SETUP_CMD_REJECT
TWT setup reject (parameters rejected by AP)
Definition wifi.h:308
@ WIFI_TWT_SETUP_CMD_ACCEPT
TWT setup accept (parameters accepted by AP)
Definition wifi.h:302
@ WIFI_TX_INJECTION_MODE
TX injection mode setting enable.
Definition wifi.h:246
@ WIFI_STA_MODE
STA mode setting enable.
Definition wifi.h:242
@ WIFI_AP_MODE
AP mode setting enable.
Definition wifi.h:250
@ WIFI_SOFTAP_MODE
Softap mode setting enable.
Definition wifi.h:252
@ WIFI_MONITOR_MODE
Monitor mode setting enable.
Definition wifi.h:244
@ WIFI_PROMISCUOUS_MODE
Promiscuous mode setting enable.
Definition wifi.h:248
@ WIFI_TWT_RESP_RECEIVED
TWT response received for TWT request.
Definition wifi.h:317
@ WIFI_TWT_RESP_NOT_RECEIVED
TWT response not received for TWT request.
Definition wifi.h:319
@ WIFI_MODE_AP
AP mode.
Definition wifi.h:154
@ WIFI_MODE_IBSS
IBSS (ad-hoc) station mode.
Definition wifi.h:152
@ WIFI_MODE_P2P_GO
P2P group owner mode.
Definition wifi.h:156
@ WIFI_MODE_MAX
Definition wifi.h:163
@ WIFI_MODE_P2P_GROUP_FORMATION
P2P group formation mode.
Definition wifi.h:158
@ WIFI_MODE_INFRA
Infrastructure station mode.
Definition wifi.h:150
@ WIFI_MODE_MESH
802.11s Mesh mode.
Definition wifi.h:160
@ WIFI_MODE_UNKNOWN
Definition wifi.h:164
@ WIFI_TWT_BROADCAST
TWT broadcast negotiation.
Definition wifi.h:283
@ WIFI_TWT_WAKE_TBTT
TWT wake TBTT negotiation.
Definition wifi.h:285
@ WIFI_TWT_INDIVIDUAL
TWT individual negotiation.
Definition wifi.h:281
@ WIFI_TWT_FAIL_IP_NOT_ASSIGNED
IP address not assigned or configured.
Definition wifi.h:343
@ WIFI_TWT_FAIL_INVALID_FLOW_ID
Invalid negotiated flow id.
Definition wifi.h:341
@ WIFI_TWT_FAIL_CMD_EXEC_FAIL
Command execution failed.
Definition wifi.h:327
@ WIFI_TWT_FAIL_OPERATION_NOT_SUPPORTED
Operation not supported.
Definition wifi.h:329
@ WIFI_TWT_FAIL_UNABLE_TO_GET_IFACE_STATUS
Unable to get interface status.
Definition wifi.h:331
@ WIFI_TWT_FAIL_PEER_NOT_HE_CAPAB
Peer not HE (802.11ax/Wi-Fi 6) capable.
Definition wifi.h:335
@ WIFI_TWT_FAIL_DEVICE_NOT_CONNECTED
Device not connected to AP.
Definition wifi.h:333
@ WIFI_TWT_FAIL_OPERATION_IN_PROGRESS
A TWT flow is already in progress.
Definition wifi.h:339
@ WIFI_TWT_FAIL_PEER_NOT_TWT_CAPAB
Peer not TWT capable.
Definition wifi.h:337
@ WIFI_TWT_FAIL_UNSPECIFIED
Unspecified error.
Definition wifi.h:325
@ WIFI_TWT_FAIL_FLOW_ALREADY_EXISTS
Flow already exists.
Definition wifi.h:345
@ WIFI_STATE_UNKNOWN
Definition wifi.h:138
@ WIFI_STATE_DISCONNECTED
Interface is disconnected.
Definition wifi.h:116
@ WIFI_STATE_GROUP_HANDSHAKE
Group Key exchange with a network is in progress.
Definition wifi.h:132
@ WIFI_STATE_INTERFACE_DISABLED
Interface is disabled (administratively).
Definition wifi.h:118
@ WIFI_STATE_4WAY_HANDSHAKE
4-way handshake with a network is in progress.
Definition wifi.h:130
@ WIFI_STATE_MAX
Definition wifi.h:137
@ WIFI_STATE_ASSOCIATED
Association with a network completed.
Definition wifi.h:128
@ WIFI_STATE_SCANNING
Interface is scanning for networks.
Definition wifi.h:122
@ WIFI_STATE_AUTHENTICATING
Authentication with a network is in progress.
Definition wifi.h:124
@ WIFI_STATE_COMPLETED
All authentication completed, ready to pass data.
Definition wifi.h:134
@ WIFI_STATE_ASSOCIATING
Association with a network is in progress.
Definition wifi.h:126
@ WIFI_STATE_INACTIVE
No enabled networks in the configuration.
Definition wifi.h:120
@ WIFI_PACKET_FILTER_MGMT
Support only sniffing of management packets.
Definition wifi.h:260
@ WIFI_PACKET_FILTER_ALL
Support management, data and control packet sniffing.
Definition wifi.h:258
@ WIFI_PACKET_FILTER_DATA
Support only sniffing of data packets.
Definition wifi.h:262
@ WIFI_PACKET_FILTER_CTRL
Support only sniffing of control packets.
Definition wifi.h:264
@ WIFI_6E
802.11ax 6GHz.
Definition wifi.h:190
@ WIFI_LINK_MODE_MAX
Definition wifi.h:195
@ WIFI_5
802.11ac.
Definition wifi.h:186
@ WIFI_0
802.11 (legacy).
Definition wifi.h:176
@ WIFI_7
802.11be.
Definition wifi.h:192
@ WIFI_4
802.11n.
Definition wifi.h:184
@ WIFI_2
802.11a.
Definition wifi.h:180
@ WIFI_6
802.11ax.
Definition wifi.h:188
@ WIFI_1
802.11b.
Definition wifi.h:178
@ WIFI_LINK_MODE_UNKNOWN
Definition wifi.h:196
@ WIFI_3
802.11g.
Definition wifi.h:182
@ WIFI_PS_PARAM_LISTEN_INTERVAL
Power save listen interval.
Definition wifi.h:386
@ WIFI_PS_PARAM_STATE
Power save state.
Definition wifi.h:384
@ WIFI_PS_PARAM_WAKEUP_MODE
Power save wakeup mode.
Definition wifi.h:388
@ WIFI_PS_PARAM_MODE
Power save mode.
Definition wifi.h:390
@ WIFI_PS_PARAM_TIMEOUT
Power save timeout.
Definition wifi.h:392
@ WIFI_PS_WAKEUP_MODE_LISTEN_INTERVAL
Listen interval based wakeup.
Definition wifi.h:400
@ WIFI_PS_WAKEUP_MODE_DTIM
DTIM based wakeup.
Definition wifi.h:398
@ WIFI_TWT_SETUP
TWT setup operation.
Definition wifi.h:270
@ WIFI_TWT_TEARDOWN
TWT teardown operation.
Definition wifi.h:272
@ WIFI_SCAN_TYPE_ACTIVE
Active scanning (default).
Definition wifi.h:205
@ WIFI_SCAN_TYPE_PASSIVE
Passive scanning.
Definition wifi.h:207
@ WIFI_PS_PARAM_FAIL_UNABLE_TO_GET_IFACE_STATUS
Unable to get interface status.
Definition wifi.h:415
@ WIFI_PS_PARAM_FAIL_UNSPECIFIED
Unspecified error.
Definition wifi.h:409
@ WIFI_PS_PARAM_FAIL_CMD_EXEC_FAIL
Command execution failed.
Definition wifi.h:411
@ WIFI_PS_PARAM_FAIL_DEVICE_NOT_CONNECTED
Device not connected to AP.
Definition wifi.h:417
@ WIFI_PS_PARAM_LISTEN_INTERVAL_RANGE_INVALID
Listen interval out of range.
Definition wifi.h:421
@ WIFI_PS_PARAM_FAIL_OPERATION_NOT_SUPPORTED
Parameter not supported.
Definition wifi.h:413
@ WIFI_PS_PARAM_FAIL_DEVICE_CONNECTED
Device already connected to AP.
Definition wifi.h:419
@ WIFI_SECURITY_TYPE_SAE
WPA3-SAE security.
Definition wifi.h:43
@ WIFI_SECURITY_TYPE_PSK_SHA256
WPA2-PSK-SHA256 security.
Definition wifi.h:41
@ WIFI_SECURITY_TYPE_PSK
WPA2-PSK security.
Definition wifi.h:39
@ WIFI_SECURITY_TYPE_WAPI
GB 15629.11-2003 WAPI security.
Definition wifi.h:45
@ WIFI_SECURITY_TYPE_WEP
WEP security.
Definition wifi.h:49
@ WIFI_SECURITY_TYPE_NONE
No security.
Definition wifi.h:37
@ WIFI_SECURITY_TYPE_WPA_PSK
WPA-PSK security.
Definition wifi.h:51
@ WIFI_SECURITY_TYPE_UNKNOWN
Definition wifi.h:55
@ WIFI_SECURITY_TYPE_EAP
EAP security - Enterprise.
Definition wifi.h:47
@ WIFI_SECURITY_TYPE_MAX
Definition wifi.h:54
@ WIFI_PS_MODE_WMM
WMM power save mode.
Definition wifi.h:229
@ WIFI_PS_MODE_LEGACY
Legacy power save mode.
Definition wifi.h:224
state
Definition parser_state.h:29
__INT16_TYPE__ int16_t
Definition stdint.h:73
Misc utilities.