mirror of
				https://github.com/0xFEEDC0DE64/arduino-esp32.git
				synced 2025-10-24 19:51:42 +02:00 
			
		
		
		
	Initial Commit
This commit is contained in:
		
							
								
								
									
										176
									
								
								tools/sdk/esp32/include/esp_wifi/esp32/include/phy_init_data.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								tools/sdk/esp32/include/esp_wifi/esp32/include/phy_init_data.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,176 @@ | ||||
| // Copyright 2016 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| // | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef PHY_INIT_DATA_H | ||||
| #define PHY_INIT_DATA_H /* don't use #pragma once here, we compile this file sometimes */ | ||||
| #include "esp_phy_init.h" | ||||
| #include "sdkconfig.h" | ||||
|  | ||||
| // constrain a value between 'low' and 'high', inclusive | ||||
| #define LIMIT(val, low, high) ((val < low) ? low : (val > high) ? high : val) | ||||
|  | ||||
| #define PHY_INIT_MAGIC "PHYINIT" | ||||
|  | ||||
| // define the lowest tx power as LOWEST_PHY_TX_POWER | ||||
| #define PHY_TX_POWER_LOWEST LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 0, 52) | ||||
| #define PHY_TX_POWER_OFFSET 44 | ||||
| #define PHY_TX_POWER_NUM    5 | ||||
|  | ||||
| #if CONFIG_ESP32_SUPPORT_MULTIPLE_PHY_INIT_DATA_BIN | ||||
| #define PHY_CRC_ALGORITHM 1 | ||||
| #define PHY_COUNTRY_CODE_LEN 2 | ||||
| #define PHY_INIT_DATA_TYPE_OFFSET 126 | ||||
| #define PHY_SUPPORT_MULTIPLE_BIN_OFFSET 125 | ||||
| #endif | ||||
| static const char phy_init_magic_pre[] = PHY_INIT_MAGIC; | ||||
|  | ||||
| /** | ||||
|  * @brief Structure containing default recommended PHY initialization parameters. | ||||
|  */ | ||||
| static const esp_phy_init_data_t phy_init_data= { { | ||||
|         3, | ||||
|         3, | ||||
|         0x05, | ||||
|         0x09, | ||||
|         0x06, | ||||
|         0x05, | ||||
|         0x03, | ||||
|         0x06, | ||||
|         0x05, | ||||
|         0x04, | ||||
|         0x06, | ||||
|         0x04, | ||||
|         0x05, | ||||
|         0x00, | ||||
|         0x00, | ||||
|         0x00, | ||||
|         0x00, | ||||
|         0x05, | ||||
|         0x09, | ||||
|         0x06, | ||||
|         0x05, | ||||
|         0x03, | ||||
|         0x06, | ||||
|         0x05, | ||||
|         0x00, | ||||
|         0x00, | ||||
|         0x00, | ||||
|         0x00, | ||||
|         0x00, | ||||
|         0x00, | ||||
|         0x00, | ||||
|         0x00, | ||||
|         0xfc, | ||||
|         0xfc, | ||||
|         0xfe, | ||||
|         0xf0, | ||||
|         0xf0, | ||||
|         0xf0, | ||||
|         0xe0, | ||||
|         0xe0, | ||||
|         0xe0, | ||||
|         0x18, | ||||
|         0x18, | ||||
|         0x18, | ||||
|         LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 40, 78), | ||||
|         LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 40, 72), | ||||
|         LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 40, 66), | ||||
|         LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 40, 60), | ||||
|         LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 40, 56), | ||||
|         LIMIT(CONFIG_ESP32_PHY_MAX_TX_POWER * 4, 40, 52), | ||||
|         0, | ||||
|         1, | ||||
|         1, | ||||
|         2, | ||||
|         2, | ||||
|         3, | ||||
|         4, | ||||
|         5, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
|         0, | ||||
| } }; | ||||
|  | ||||
| static const char phy_init_magic_post[] = PHY_INIT_MAGIC; | ||||
|  | ||||
| #if CONFIG_ESP32_SUPPORT_MULTIPLE_PHY_INIT_DATA_BIN | ||||
| /** | ||||
|  * @brief PHY init data control infomation structure    | ||||
|  */ | ||||
| typedef struct { | ||||
|     uint8_t control_info_checksum[4];     /*!< 4-byte control infomation checksum */ | ||||
|     uint8_t multiple_bin_checksum[4];     /*!< 4-byte multiple bin checksum */ | ||||
|     uint8_t check_algorithm;              /*!< check algorithm */ | ||||
|     uint8_t version;                      /*!< PHY init data bin version */ | ||||
|     uint8_t number;                       /*!< PHY init data bin number */ | ||||
|     uint8_t length[2];                    /*!< Length of each PHY init data bin */ | ||||
|     uint8_t reserved[19];                 /*!< 19-byte reserved  */ | ||||
| } __attribute__ ((packed)) phy_control_info_data_t; | ||||
|  | ||||
| /** | ||||
|  * @brief Country corresponds to PHY init data type structure | ||||
|  */ | ||||
| typedef struct { | ||||
|     char cc[PHY_COUNTRY_CODE_LEN]; | ||||
|     uint8_t type; | ||||
| } phy_country_to_bin_type_t; | ||||
| #endif | ||||
| #endif /* PHY_INIT_DATA_H */ | ||||
|  | ||||
							
								
								
									
										107
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_coexist.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_coexist.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| // Copyright 2015-2018 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| // | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef __ESP_COEXIST_H__ | ||||
| #define __ESP_COEXIST_H__ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include "esp_err.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief coex prefer value | ||||
|  */ | ||||
| typedef enum { | ||||
|     ESP_COEX_PREFER_WIFI = 0,       /*!< Prefer to WiFi, WiFi will have more opportunity to use RF */ | ||||
|     ESP_COEX_PREFER_BT,             /*!< Prefer to bluetooth, bluetooth will have more opportunity to use RF */ | ||||
|     ESP_COEX_PREFER_BALANCE,        /*!< Do balance of WiFi and bluetooth */ | ||||
|     ESP_COEX_PREFER_NUM,            /*!< Prefer value numbers */ | ||||
| } esp_coex_prefer_t; | ||||
|  | ||||
| /** | ||||
|  * @brief coex status type | ||||
|  */ | ||||
| typedef enum { | ||||
|     ESP_COEX_ST_TYPE_WIFI = 0, | ||||
|     ESP_COEX_ST_TYPE_BLE, | ||||
|     ESP_COEX_ST_TYPE_BT, | ||||
| } esp_coex_status_type_t; | ||||
|  | ||||
| #define ESP_COEX_BLE_ST_MESH_CONFIG        0x08 | ||||
| #define ESP_COEX_BLE_ST_MESH_TRAFFIC       0x10 | ||||
| #define ESP_COEX_BLE_ST_MESH_STANDBY       0x20 | ||||
|  | ||||
| #define ESP_COEX_BT_ST_A2DP_STREAMING      0x10 | ||||
| #define ESP_COEX_BT_ST_A2DP_PAUSED         0x20 | ||||
|  | ||||
| /** | ||||
|  * @brief Get software coexist version string | ||||
|  * | ||||
|  * @return : version string | ||||
|  */ | ||||
| const char *esp_coex_version_get(void); | ||||
|  | ||||
| /** | ||||
|  * @deprecated Use esp_coex_status_bit_set() and esp_coex_status_bit_clear() instead. | ||||
|  *  Set coexist preference of performance | ||||
|  *  For example, if prefer to bluetooth, then it will make A2DP(play audio via classic bt) | ||||
|  *  more smooth while wifi is runnning something. | ||||
|  *  If prefer to wifi, it will do similar things as prefer to bluetooth. | ||||
|  *  Default, it prefer to balance. | ||||
|  * | ||||
|  *  @param prefer : the prefer enumeration value | ||||
|  *  @return : ESP_OK - success, other - failed | ||||
|  */ | ||||
| esp_err_t esp_coex_preference_set(esp_coex_prefer_t prefer); | ||||
|  | ||||
| /** | ||||
|  * @brief Set coex schm status | ||||
|  * @param type : WIFI/BLE/BT | ||||
|  * @param status : WIFI/BLE/BT STATUS | ||||
|  * @return : ESP_OK - success, other - failed | ||||
|  */ | ||||
| esp_err_t esp_coex_status_bit_set(esp_coex_status_type_t type, uint32_t status); | ||||
|  | ||||
| /** | ||||
|  * @brief Clear coex schm status | ||||
|  * @param type : WIFI/BLE/BT | ||||
|  * @param status : WIFI/BLE/BT STATUS | ||||
|  * @return : ESP_OK - success, other - failed | ||||
|  */ | ||||
| esp_err_t esp_coex_status_bit_clear(esp_coex_status_type_t type, uint32_t status); | ||||
|  | ||||
| /** | ||||
|  * @brief Enable BLE connection dynamic priority | ||||
|  * @attention If the parameter is true, BLE connection performance will be better but WiFi performance  | ||||
|               will be poorer. And vice versa. | ||||
|  * @param low_interval : true - Increase BLE connection priority to be higher than WiFi's when BLE  | ||||
| *                               connection interval is less or equal than 50 ms. The default value  | ||||
| *                               is false. | ||||
|  *                       false - not increace | ||||
|  * @param high_interval : true - Increase BLE connection priority to be higher than WiFi's when BLE  | ||||
| *                                connection interval is more than 50 ms. The default value is true. | ||||
|  *                        false - not increace | ||||
|  * @return : ESP_OK - success, other - failed | ||||
|  */ | ||||
| esp_err_t esp_coex_ble_conn_dynamic_prio_enable(bool low_interval, bool high_interval); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #endif /* __ESP_COEXIST_H__ */ | ||||
| @@ -0,0 +1,59 @@ | ||||
| // Copyright 2019 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| // | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef __ESP_COEXIST_ADAPTER_H__ | ||||
| #define __ESP_COEXIST_ADAPTER_H__ | ||||
|  | ||||
| #include <stdarg.h> | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #define COEX_ADAPTER_VERSION  0x00000001 | ||||
| #define COEX_ADAPTER_MAGIC    0xDEADBEAF | ||||
|  | ||||
| #define COEX_ADAPTER_FUNCS_TIME_BLOCKING      0xffffffff | ||||
|  | ||||
| typedef struct { | ||||
|     int32_t _version; | ||||
|     void *(* _spin_lock_create)(void); | ||||
|     void (* _spin_lock_delete)(void *lock); | ||||
|     uint32_t (*_int_disable)(void *mux); | ||||
|     void (*_int_enable)(void *mux, uint32_t tmp); | ||||
|     void (*_task_yield_from_isr)(void); | ||||
|     void *(*_semphr_create)(uint32_t max, uint32_t init); | ||||
|     void (*_semphr_delete)(void *semphr); | ||||
|     int32_t (*_semphr_take_from_isr)(void *semphr, void *hptw); | ||||
|     int32_t (*_semphr_give_from_isr)(void *semphr, void *hptw); | ||||
|     int32_t (*_semphr_take)(void *semphr, uint32_t block_time_tick); | ||||
|     int32_t (*_semphr_give)(void *semphr); | ||||
|     int32_t (* _is_in_isr)(void); | ||||
|     void * (* _malloc_internal)(size_t size); | ||||
|     void (* _free)(void *p); | ||||
|     void (* _timer_disarm)(void *timer); | ||||
|     void (* _timer_done)(void *ptimer); | ||||
|     void (* _timer_setfn)(void *ptimer, void *pfunction, void *parg); | ||||
|     void (* _timer_arm_us)(void *ptimer, uint32_t us, bool repeat); | ||||
|     int64_t (* _esp_timer_get_time)(void); | ||||
|     int32_t _magic; | ||||
| } coex_adapter_funcs_t; | ||||
|  | ||||
| extern coex_adapter_funcs_t g_coex_adapter_funcs; | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* __ESP_COEXIST_ADAPTER_H__ */ | ||||
							
								
								
									
										177
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_coexist_internal.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										177
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_coexist_internal.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,177 @@ | ||||
| // Copyright 2018-2018 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| // | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef __ESP_COEXIST_INTERNAL_H__ | ||||
| #define __ESP_COEXIST_INTERNAL_H__ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include "esp_coexist_adapter.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| typedef enum { | ||||
|     COEX_PREFER_WIFI = 0, | ||||
|     COEX_PREFER_BT, | ||||
|     COEX_PREFER_BALANCE, | ||||
|     COEX_PREFER_NUM, | ||||
| } coex_prefer_t; | ||||
|  | ||||
| typedef void (* coex_func_cb_t)(uint32_t event, int sched_cnt); | ||||
|  | ||||
| /** | ||||
|  * @brief Pre-Init software coexist | ||||
|  *        extern function for internal use. | ||||
|  * | ||||
|  * @return Init ok or failed. | ||||
|  */ | ||||
| esp_err_t coex_pre_init(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Init software coexist | ||||
|  *        extern function for internal use. | ||||
|  * | ||||
|  * @return Init ok or failed. | ||||
|  */ | ||||
| esp_err_t coex_init(void); | ||||
|  | ||||
| /** | ||||
|  * @brief De-init software coexist | ||||
|  *        extern function for internal use. | ||||
|  */ | ||||
| void coex_deinit(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Pause software coexist | ||||
|  *        extern function for internal use. | ||||
|  */ | ||||
| void coex_pause(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Resume software coexist | ||||
|  *        extern function for internal use. | ||||
|  */ | ||||
| void coex_resume(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Get software coexist version string | ||||
|  *        extern function for internal use. | ||||
|  * @return : version string | ||||
|  */ | ||||
| const char *coex_version_get(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Coexist performance preference set from libbt.a | ||||
|  *        extern function for internal use. | ||||
|  * | ||||
|  *  @param prefer : the prefer enumeration value | ||||
|  *  @return : ESP_OK - success, other - failed | ||||
|  */ | ||||
| esp_err_t coex_preference_set(coex_prefer_t prefer); | ||||
|  | ||||
| /** | ||||
|  * @brief Get software coexist status. | ||||
|  * @return : software coexist status | ||||
|  */ | ||||
| uint32_t coex_status_get(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Set software coexist condition. | ||||
|  * @return : software coexist condition | ||||
|  */ | ||||
| void coex_condition_set(uint32_t type, bool dissatisfy); | ||||
|  | ||||
| /** | ||||
|  * @brief WiFi requests coexistence. | ||||
|  * | ||||
|  *  @param event : WiFi event | ||||
|  *  @param latency : WiFi will request coexistence after latency | ||||
|  *  @param duration : duration for WiFi to request coexistence | ||||
|  *  @return : 0 - success, other - failed | ||||
|  */ | ||||
| int coex_wifi_request(uint32_t event, uint32_t latency, uint32_t duration); | ||||
|  | ||||
| /** | ||||
|  * @brief WiFi release coexistence. | ||||
|  * | ||||
|  *  @param event : WiFi event | ||||
|  *  @return : 0 - success, other - failed | ||||
|  */ | ||||
| int coex_wifi_release(uint32_t event); | ||||
|  | ||||
| /** | ||||
|  * @brief Blue tooth requests coexistence. | ||||
|  * | ||||
|  *  @param event : blue tooth event | ||||
|  *  @param latency : blue tooth will request coexistence after latency | ||||
|  *  @param duration : duration for blue tooth to request coexistence | ||||
|  *  @return : 0 - success, other - failed | ||||
|  */ | ||||
| int coex_bt_request(uint32_t event, uint32_t latency, uint32_t duration); | ||||
|  | ||||
| /** | ||||
|  * @brief Blue tooth release coexistence. | ||||
|  * | ||||
|  *  @param event : blue tooth event | ||||
|  *  @return : 0 - success, other - failed | ||||
|  */ | ||||
| int coex_bt_release(uint32_t event); | ||||
|  | ||||
| /** | ||||
|  * @brief Register callback function for blue tooth. | ||||
|  * | ||||
|  *  @param cb : callback function | ||||
|  *  @return : 0 - success, other - failed | ||||
|  */ | ||||
| int coex_register_bt_cb(coex_func_cb_t cb); | ||||
|  | ||||
| /** | ||||
|  * @brief Lock before reset base band. | ||||
|  * | ||||
|  *  @return : lock value | ||||
|  */ | ||||
| uint32_t coex_bb_reset_lock(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Unlock after reset base band. | ||||
|  * | ||||
|  *  @param restore : lock value | ||||
|  */ | ||||
| void coex_bb_reset_unlock(uint32_t restore); | ||||
|  | ||||
| /** | ||||
|  * @brief Register coexistence adapter functions. | ||||
|  * | ||||
|  *  @param funcs : coexistence adapter functions | ||||
|  *  @return : ESP_OK - success, other - failed | ||||
|  */ | ||||
| esp_err_t esp_coex_adapter_register(coex_adapter_funcs_t *funcs); | ||||
|  | ||||
| /** | ||||
|   * @brief     Check the MD5 values of the coexistence adapter header files in IDF and WiFi library | ||||
|   * | ||||
|   * @attention 1. It is used for internal CI version check | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK : succeed | ||||
|   *     - ESP_WIFI_INVALID_ARG : MD5 check fail | ||||
|   */ | ||||
| esp_err_t esp_coex_adapter_funcs_md5_check(const char *md5); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* __ESP_COEXIST_INTERNAL_H__ */ | ||||
							
								
								
									
										1656
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_mesh.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1656
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_mesh.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										291
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_mesh_internal.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										291
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_mesh_internal.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,291 @@ | ||||
| // Copyright 2017-2018 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
|  | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef __ESP_MESH_INTERNAL_H__ | ||||
| #define __ESP_MESH_INTERNAL_H__ | ||||
|  | ||||
| #include "esp_err.h" | ||||
| #include "esp_mesh.h" | ||||
| #include "esp_wifi.h" | ||||
| #include "esp_wifi_types.h" | ||||
| #include "esp_private/wifi.h" | ||||
| #include "esp_wifi_crypto_types.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /******************************************************* | ||||
|  *                Constants | ||||
|  *******************************************************/ | ||||
|  | ||||
| /******************************************************* | ||||
|  *                Structures | ||||
|  *******************************************************/ | ||||
| typedef struct { | ||||
|     int scan;          /**< minimum scan times before being a root, default:10 */ | ||||
|     int vote;          /**< max vote times in self-healing, default:1000 */ | ||||
|     int fail;          /**< parent selection fail times, if the scan times reach this value, | ||||
|                             device will disconnect with associated children and join self-healing. default:60 */ | ||||
|     int monitor_ie;    /**< acceptable times of parent networking IE change before update its own networking IE. default:3 */ | ||||
| } mesh_attempts_t; | ||||
|  | ||||
| typedef struct { | ||||
|     int duration_ms;   /* parent weak RSSI monitor duration, if the RSSI continues to be weak during this duration_ms, | ||||
|                           device will search for a new parent. */ | ||||
|     int cnx_rssi;      /* RSSI threshold for keeping a good connection with parent. | ||||
|                           If set a value greater than -120 dBm, a timer will be armed to monitor parent RSSI at a period time of duration_ms. */ | ||||
|     int select_rssi;   /* RSSI threshold for parent selection. It should be a value greater than switch_rssi. */ | ||||
|     int switch_rssi;   /* Disassociate with current parent and switch to a new parent when the RSSI is greater than this set threshold. */ | ||||
|     int backoff_rssi;  /* RSSI threshold for connecting to the root */ | ||||
| } mesh_switch_parent_t; | ||||
|  | ||||
| typedef struct { | ||||
|     int high; | ||||
|     int medium; | ||||
|     int low; | ||||
| } mesh_rssi_threshold_t; | ||||
|  | ||||
| /** | ||||
|  * @brief Mesh networking IE | ||||
|  */ | ||||
| typedef struct { | ||||
|     /**< mesh networking IE head */ | ||||
|     uint8_t eid;             /**< element ID */ | ||||
|     uint8_t len;             /**< element length */ | ||||
|     uint8_t oui[3];          /**< organization identifier */ | ||||
|     /**< mesh networking IE content */ | ||||
|     uint8_t type;            /** ESP defined IE type */ | ||||
|     uint8_t encrypted : 1;   /**< whether mesh networking IE is encrypted */ | ||||
|     uint8_t version : 7;     /**< mesh networking IE version */ | ||||
|     /**< content */ | ||||
|     uint8_t mesh_type;       /**< mesh device type */ | ||||
|     uint8_t mesh_id[6];      /**< mesh ID */ | ||||
|     uint8_t layer_cap;       /**< max layer */ | ||||
|     uint8_t layer;           /**< current layer */ | ||||
|     uint8_t assoc_cap;       /**< max connections of mesh AP */ | ||||
|     uint8_t assoc;           /**< current connections */ | ||||
|     uint8_t leaf_cap;        /**< leaf capacity */ | ||||
|     uint8_t leaf_assoc;      /**< the number of current connected leaf */ | ||||
|     uint16_t root_cap;       /**< root capacity */ | ||||
|     uint16_t self_cap;       /**< self capacity */ | ||||
|     uint16_t layer2_cap;     /**< layer2 capacity */ | ||||
|     uint16_t scan_ap_num;    /**< the number of scanning APs */ | ||||
|     int8_t rssi;             /**< RSSI of the parent */ | ||||
|     int8_t router_rssi;      /**< RSSI of the router */ | ||||
|     uint8_t flag;            /**< flag of networking */ | ||||
|     uint8_t rc_addr[6];      /**< root address */ | ||||
|     int8_t rc_rssi;          /**< root RSSI */ | ||||
|     uint8_t vote_addr[6];    /**< voter address */ | ||||
|     int8_t vote_rssi;        /**< vote RSSI of the router */ | ||||
|     uint8_t vote_ttl;        /**< vote ttl */ | ||||
|     uint16_t votes;          /**< votes */ | ||||
|     uint16_t my_votes;       /**< my votes */ | ||||
|     uint8_t reason;          /**< reason */ | ||||
|     uint8_t child[6];        /**< child address */ | ||||
|     uint8_t toDS;            /**< toDS state */ | ||||
| } __attribute__((packed)) mesh_assoc_t; | ||||
|  | ||||
| /** | ||||
|  * @brief Mesh PS duties | ||||
|  */ | ||||
| typedef struct { | ||||
|     uint8_t device; | ||||
|     uint8_t parent; | ||||
|     struct { | ||||
|         bool used; | ||||
|         uint8_t duty; | ||||
|         uint8_t mac[6]; | ||||
|     } child[ESP_WIFI_MAX_CONN_NUM]; | ||||
| } esp_mesh_ps_duties_t; | ||||
|  | ||||
| /******************************************************* | ||||
|  *                Function Definitions | ||||
|  *******************************************************/ | ||||
| /** | ||||
|  * @brief      Set mesh softAP beacon interval | ||||
|  * | ||||
|  * @param[in]  interval  beacon interval (msecs) (100 msecs ~ 60000 msecs) | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  *    - ESP_FAIL | ||||
|  *    - ESP_ERR_WIFI_ARG | ||||
|  */ | ||||
| esp_err_t esp_mesh_set_beacon_interval(int interval_ms); | ||||
|  | ||||
| /** | ||||
|  * @brief      Get mesh softAP beacon interval | ||||
|  * | ||||
|  * @param[out] interval  beacon interval (msecs) | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  */ | ||||
| esp_err_t esp_mesh_get_beacon_interval(int *interval_ms); | ||||
|  | ||||
| /** | ||||
|  * @brief     Set attempts for mesh self-organized networking | ||||
|  * | ||||
|  * @param[in] attempts | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  *    - ESP_FAIL | ||||
|  */ | ||||
| esp_err_t esp_mesh_set_attempts(mesh_attempts_t *attempts); | ||||
|  | ||||
| /** | ||||
|  * @brief      Get attempts for mesh self-organized networking | ||||
|  * | ||||
|  * @param[out] attempts | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  *    - ESP_ERR_MESH_ARGUMENT | ||||
|  */ | ||||
| esp_err_t esp_mesh_get_attempts(mesh_attempts_t *attempts); | ||||
|  | ||||
| /** | ||||
|  * @brief      Set parameters for parent switch | ||||
|  * | ||||
|  * @param[in]  paras  parameters for parent switch | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  *    - ESP_ERR_MESH_ARGUMENT | ||||
|  */ | ||||
| esp_err_t esp_mesh_set_switch_parent_paras(mesh_switch_parent_t *paras); | ||||
|  | ||||
| /** | ||||
|  * @brief      Get parameters for parent switch | ||||
|  * | ||||
|  * @param[out] paras  parameters for parent switch | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  *    - ESP_ERR_MESH_ARGUMENT | ||||
|  */ | ||||
| esp_err_t esp_mesh_get_switch_parent_paras(mesh_switch_parent_t *paras); | ||||
|  | ||||
| /** | ||||
|  * @brief      Set RSSI threshold | ||||
|  *             - The default high RSSI threshold value is -78 dBm. | ||||
|  *             - The default medium RSSI threshold value is -82 dBm. | ||||
|  *             - The default low RSSI threshold value is -85 dBm. | ||||
|  * | ||||
|  * @param[in]  threshold  RSSI threshold | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  *    - ESP_ERR_MESH_ARGUMENT | ||||
|  */ | ||||
| esp_err_t esp_mesh_set_rssi_threshold(const mesh_rssi_threshold_t *threshold); | ||||
|  | ||||
| /** | ||||
|  * @brief      Get RSSI threshold | ||||
|  * | ||||
|  * @param[out] threshold  RSSI threshold | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  *    - ESP_ERR_MESH_ARGUMENT | ||||
|  */ | ||||
| esp_err_t esp_mesh_get_rssi_threshold(mesh_rssi_threshold_t *threshold); | ||||
|  | ||||
| /** | ||||
|  * @brief      Enable the minimum rate to 6 Mbps | ||||
|  * | ||||
|  * @attention  This API shall be called before Wi-Fi is started. | ||||
|  * | ||||
|  * @param[in]  is_6m  enable or not | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  */ | ||||
| esp_err_t esp_mesh_set_6m_rate(bool is_6m); | ||||
|  | ||||
| /** | ||||
|  * @brief      Print the number of txQ waiting | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  *    - ESP_FAIL | ||||
|  */ | ||||
| esp_err_t esp_mesh_print_txQ_waiting(void); | ||||
|  | ||||
| /** | ||||
|  * @brief      Print the number of rxQ waiting | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  *    - ESP_FAIL | ||||
|  */ | ||||
| esp_err_t esp_mesh_print_rxQ_waiting(void); | ||||
|  | ||||
| /** | ||||
|  * @brief      Set passive scan time | ||||
|  * | ||||
|  * @param[in]  interval_ms  passive scan time (msecs) | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  *    - ESP_FAIL | ||||
|  *    - ESP_ERR_ARGUMENT | ||||
|  */ | ||||
| esp_err_t esp_mesh_set_passive_scan_time(int time_ms); | ||||
|  | ||||
| /** | ||||
|  * @brief      Get passive scan time | ||||
|  * | ||||
|  * @return     interval_ms  passive scan time (msecs) | ||||
|  */ | ||||
| int esp_mesh_get_passive_scan_time(void); | ||||
|  | ||||
| /** | ||||
|  * @brief      Set announce interval | ||||
|  *             - The default short interval is 500 milliseconds. | ||||
|  *             - The default long interval is 3000 milliseconds. | ||||
|  * | ||||
|  * @param[in]  short_ms  shall be greater than the default value | ||||
|  * @param[in]  long_ms  shall be greater than the default value | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  */ | ||||
| esp_err_t esp_mesh_set_announce_interval(int short_ms, int long_ms); | ||||
|  | ||||
| /** | ||||
|  * @brief      Get announce interval | ||||
|  * | ||||
|  * @param[out] short_ms  short interval | ||||
|  * @param[out] long_ms  long interval | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  */ | ||||
| esp_err_t esp_mesh_get_announce_interval(int *short_ms, int *long_ms); | ||||
|  | ||||
| /** | ||||
|   * @brief      Get the running duties of device, parent and children | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK | ||||
|  */ | ||||
| esp_err_t esp_mesh_ps_get_duties(esp_mesh_ps_duties_t* ps_duties); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| #endif /* __ESP_MESH_INTERNAL_H__ */ | ||||
							
								
								
									
										317
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_now.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										317
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_now.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,317 @@ | ||||
| // Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
|  | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef __ESP_NOW_H__ | ||||
| #define __ESP_NOW_H__ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include "esp_err.h" | ||||
| #include "esp_wifi_types.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** \defgroup WiFi_APIs WiFi Related APIs | ||||
|   * @brief WiFi APIs | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup WiFi_APIs | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** \defgroup ESPNOW_APIs  ESPNOW APIs | ||||
|   * @brief ESP32 ESPNOW APIs | ||||
|   * | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup ESPNOW_APIs | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| #define ESP_ERR_ESPNOW_BASE         (ESP_ERR_WIFI_BASE + 100) /*!< ESPNOW error number base. */ | ||||
| #define ESP_ERR_ESPNOW_NOT_INIT     (ESP_ERR_ESPNOW_BASE + 1) /*!< ESPNOW is not initialized. */ | ||||
| #define ESP_ERR_ESPNOW_ARG          (ESP_ERR_ESPNOW_BASE + 2) /*!< Invalid argument */ | ||||
| #define ESP_ERR_ESPNOW_NO_MEM       (ESP_ERR_ESPNOW_BASE + 3) /*!< Out of memory */ | ||||
| #define ESP_ERR_ESPNOW_FULL         (ESP_ERR_ESPNOW_BASE + 4) /*!< ESPNOW peer list is full */ | ||||
| #define ESP_ERR_ESPNOW_NOT_FOUND    (ESP_ERR_ESPNOW_BASE + 5) /*!< ESPNOW peer is not found */ | ||||
| #define ESP_ERR_ESPNOW_INTERNAL     (ESP_ERR_ESPNOW_BASE + 6) /*!< Internal error */ | ||||
| #define ESP_ERR_ESPNOW_EXIST        (ESP_ERR_ESPNOW_BASE + 7) /*!< ESPNOW peer has existed */ | ||||
| #define ESP_ERR_ESPNOW_IF           (ESP_ERR_ESPNOW_BASE + 8) /*!< Interface error */ | ||||
|  | ||||
| #define ESP_NOW_ETH_ALEN             6         /*!< Length of ESPNOW peer MAC address */ | ||||
| #define ESP_NOW_KEY_LEN              16        /*!< Length of ESPNOW peer local master key */ | ||||
|  | ||||
| #define ESP_NOW_MAX_TOTAL_PEER_NUM   20        /*!< Maximum number of ESPNOW total peers */ | ||||
| #define ESP_NOW_MAX_ENCRYPT_PEER_NUM 6         /*!< Maximum number of ESPNOW encrypted peers */ | ||||
|  | ||||
| #define ESP_NOW_MAX_DATA_LEN         250       /*!< Maximum length of ESPNOW data which is sent very time */ | ||||
|  | ||||
| /** | ||||
|  * @brief Status of sending ESPNOW data . | ||||
|  */ | ||||
| typedef enum { | ||||
|     ESP_NOW_SEND_SUCCESS = 0,       /**< Send ESPNOW data successfully */ | ||||
|     ESP_NOW_SEND_FAIL,              /**< Send ESPNOW data fail */ | ||||
| } esp_now_send_status_t; | ||||
|  | ||||
| /** | ||||
|  * @brief ESPNOW peer information parameters. | ||||
|  */ | ||||
| typedef struct esp_now_peer_info { | ||||
|     uint8_t peer_addr[ESP_NOW_ETH_ALEN];    /**< ESPNOW peer MAC address that is also the MAC address of station or softap */ | ||||
|     uint8_t lmk[ESP_NOW_KEY_LEN];           /**< ESPNOW peer local master key that is used to encrypt data */ | ||||
|     uint8_t channel;                        /**< Wi-Fi channel that peer uses to send/receive ESPNOW data. If the value is 0, | ||||
|                                                  use the current channel which station or softap is on. Otherwise, it must be | ||||
|                                                  set as the channel that station or softap is on. */ | ||||
|     wifi_interface_t ifidx;                 /**< Wi-Fi interface that peer uses to send/receive ESPNOW data */ | ||||
|     bool encrypt;                           /**< ESPNOW data that this peer sends/receives is encrypted or not */ | ||||
|     void *priv;                             /**< ESPNOW peer private data */ | ||||
| } esp_now_peer_info_t; | ||||
|  | ||||
| /** | ||||
|  * @brief Number of ESPNOW peers which exist currently. | ||||
|  */ | ||||
| typedef struct esp_now_peer_num { | ||||
|     int total_num;                           /**< Total number of ESPNOW peers, maximum value is ESP_NOW_MAX_TOTAL_PEER_NUM */ | ||||
|     int encrypt_num;                         /**< Number of encrypted ESPNOW peers, maximum value is ESP_NOW_MAX_ENCRYPT_PEER_NUM */ | ||||
| } esp_now_peer_num_t; | ||||
|  | ||||
| /** | ||||
|   * @brief     Callback function of receiving ESPNOW data | ||||
|   * @param     mac_addr peer MAC address | ||||
|   * @param     data received data | ||||
|   * @param     data_len length of received data | ||||
|   */ | ||||
| typedef void (*esp_now_recv_cb_t)(const uint8_t *mac_addr, const uint8_t *data, int data_len); | ||||
|  | ||||
| /** | ||||
|   * @brief     Callback function of sending ESPNOW data | ||||
|   * @param     mac_addr peer MAC address | ||||
|   * @param     status status of sending ESPNOW data (succeed or fail) | ||||
|   */ | ||||
| typedef void (*esp_now_send_cb_t)(const uint8_t *mac_addr, esp_now_send_status_t status); | ||||
|  | ||||
| /** | ||||
|   * @brief     Initialize ESPNOW function | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_INTERNAL : Internal error | ||||
|   */ | ||||
| esp_err_t esp_now_init(void); | ||||
|  | ||||
| /** | ||||
|   * @brief     De-initialize ESPNOW function | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   */ | ||||
| esp_err_t esp_now_deinit(void); | ||||
|  | ||||
| /** | ||||
|   * @brief     Get the version of ESPNOW | ||||
|   * | ||||
|   * @param     version  ESPNOW version | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_ARG : invalid argument | ||||
|   */ | ||||
| esp_err_t esp_now_get_version(uint32_t *version); | ||||
|  | ||||
| /** | ||||
|   * @brief     Register callback function of receiving ESPNOW data | ||||
|   * | ||||
|   * @param     cb  callback function of receiving ESPNOW data | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   *          - ESP_ERR_ESPNOW_INTERNAL : internal error | ||||
|   */ | ||||
| esp_err_t esp_now_register_recv_cb(esp_now_recv_cb_t cb); | ||||
|  | ||||
| /** | ||||
|   * @brief     Unregister callback function of receiving ESPNOW data | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   */ | ||||
| esp_err_t esp_now_unregister_recv_cb(void); | ||||
|  | ||||
| /** | ||||
|   * @brief     Register callback function of sending ESPNOW data | ||||
|   * | ||||
|   * @param     cb  callback function of sending ESPNOW data | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   *          - ESP_ERR_ESPNOW_INTERNAL : internal error | ||||
|   */ | ||||
| esp_err_t esp_now_register_send_cb(esp_now_send_cb_t cb); | ||||
|  | ||||
| /** | ||||
|   * @brief     Unregister callback function of sending ESPNOW data | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   */ | ||||
| esp_err_t esp_now_unregister_send_cb(void); | ||||
|  | ||||
| /** | ||||
|   * @brief     Send ESPNOW data | ||||
|   * | ||||
|   * @attention 1. If peer_addr is not NULL, send data to the peer whose MAC address matches peer_addr | ||||
|   * @attention 2. If peer_addr is NULL, send data to all of the peers that are added to the peer list | ||||
|   * @attention 3. The maximum length of data must be less than ESP_NOW_MAX_DATA_LEN | ||||
|   * @attention 4. The buffer pointed to by data argument does not need to be valid after esp_now_send returns | ||||
|   * | ||||
|   * @param     peer_addr  peer MAC address | ||||
|   * @param     data  data to send | ||||
|   * @param     len  length of data | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   *          - ESP_ERR_ESPNOW_ARG : invalid argument | ||||
|   *          - ESP_ERR_ESPNOW_INTERNAL : internal error | ||||
|   *          - ESP_ERR_ESPNOW_NO_MEM : out of memory | ||||
|   *          - ESP_ERR_ESPNOW_NOT_FOUND : peer is not found | ||||
|   *          - ESP_ERR_ESPNOW_IF : current WiFi interface doesn't match that of peer | ||||
|   */ | ||||
| esp_err_t esp_now_send(const uint8_t *peer_addr, const uint8_t *data, size_t len); | ||||
|  | ||||
| /** | ||||
|   * @brief     Add a peer to peer list | ||||
|   * | ||||
|   * @param     peer  peer information | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   *          - ESP_ERR_ESPNOW_ARG : invalid argument | ||||
|   *          - ESP_ERR_ESPNOW_FULL : peer list is full | ||||
|   *          - ESP_ERR_ESPNOW_NO_MEM : out of memory | ||||
|   *          - ESP_ERR_ESPNOW_EXIST : peer has existed | ||||
|   */ | ||||
| esp_err_t esp_now_add_peer(const esp_now_peer_info_t *peer); | ||||
|  | ||||
| /** | ||||
|   * @brief     Delete a peer from peer list | ||||
|   * | ||||
|   * @param     peer_addr  peer MAC address | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   *          - ESP_ERR_ESPNOW_ARG : invalid argument | ||||
|   *          - ESP_ERR_ESPNOW_NOT_FOUND : peer is not found | ||||
|   */ | ||||
| esp_err_t esp_now_del_peer(const uint8_t *peer_addr); | ||||
|  | ||||
| /** | ||||
|   * @brief     Modify a peer | ||||
|   * | ||||
|   * @param     peer  peer information | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   *          - ESP_ERR_ESPNOW_ARG : invalid argument | ||||
|   *          - ESP_ERR_ESPNOW_FULL : peer list is full | ||||
|   */ | ||||
| esp_err_t esp_now_mod_peer(const esp_now_peer_info_t *peer); | ||||
|  | ||||
| /** | ||||
|   * @brief     Get a peer whose MAC address matches peer_addr from peer list | ||||
|   * | ||||
|   * @param     peer_addr  peer MAC address | ||||
|   * @param     peer  peer information | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   *          - ESP_ERR_ESPNOW_ARG : invalid argument | ||||
|   *          - ESP_ERR_ESPNOW_NOT_FOUND : peer is not found | ||||
|   */ | ||||
| esp_err_t esp_now_get_peer(const uint8_t *peer_addr, esp_now_peer_info_t *peer); | ||||
|  | ||||
| /** | ||||
|   * @brief     Fetch a peer from peer list | ||||
|   * | ||||
|   * @param     from_head  fetch from head of list or not | ||||
|   * @param     peer  peer information | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   *          - ESP_ERR_ESPNOW_ARG : invalid argument | ||||
|   *          - ESP_ERR_ESPNOW_NOT_FOUND : peer is not found | ||||
|   */ | ||||
| esp_err_t esp_now_fetch_peer(bool from_head, esp_now_peer_info_t *peer); | ||||
|  | ||||
| /** | ||||
|   * @brief     Peer exists or not | ||||
|   * | ||||
|   * @param     peer_addr  peer MAC address | ||||
|   * | ||||
|   * @return | ||||
|   *          - true : peer exists | ||||
|   *          - false : peer not exists | ||||
|   */ | ||||
| bool esp_now_is_peer_exist(const uint8_t *peer_addr); | ||||
|  | ||||
| /** | ||||
|   * @brief     Get the number of peers | ||||
|   * | ||||
|   * @param     num  number of peers | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   *          - ESP_ERR_ESPNOW_ARG : invalid argument | ||||
|   */ | ||||
| esp_err_t esp_now_get_peer_num(esp_now_peer_num_t *num); | ||||
|  | ||||
| /** | ||||
|   * @brief     Set the primary master key | ||||
|   * | ||||
|   * @param     pmk  primary master key | ||||
|   * | ||||
|   * @attention 1. primary master key is used to encrypt local master key | ||||
|   * | ||||
|   * @return | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_ESPNOW_NOT_INIT : ESPNOW is not initialized | ||||
|   *          - ESP_ERR_ESPNOW_ARG : invalid argument | ||||
|   */ | ||||
| esp_err_t esp_now_set_pmk(const uint8_t *pmk); | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* __ESP_NOW_H__ */ | ||||
							
								
								
									
										289
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_phy_init.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										289
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_phy_init.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,289 @@ | ||||
| // Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| // | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #pragma once | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| #include "esp_err.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @file PHY init parameters and API | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * @brief Structure holding PHY init parameters | ||||
|  */ | ||||
| typedef struct { | ||||
| 	uint8_t params[128];                    /*!< opaque PHY initialization parameters */ | ||||
| } esp_phy_init_data_t; | ||||
|  | ||||
| /** | ||||
|  * @brief Opaque PHY calibration data | ||||
|  */ | ||||
| typedef struct { | ||||
|     uint8_t version[4];                     /*!< PHY version */ | ||||
|     uint8_t mac[6];                         /*!< The MAC address of the station */ | ||||
|     uint8_t opaque[1894];                   /*!< calibration data */ | ||||
| } esp_phy_calibration_data_t; | ||||
|  | ||||
| typedef enum { | ||||
|     PHY_RF_CAL_PARTIAL = 0x00000000,        /*!< Do part of RF calibration. This should be used after power-on reset. */ | ||||
|     PHY_RF_CAL_NONE    = 0x00000001,        /*!< Don't do any RF calibration. This mode is only suggested to be used after deep sleep reset. */ | ||||
|     PHY_RF_CAL_FULL    = 0x00000002         /*!< Do full RF calibration. Produces best results, but also consumes a lot of time and current. Suggested to be used once. */ | ||||
| } esp_phy_calibration_mode_t; | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * @brief Modules for modem sleep  | ||||
|  */ | ||||
| typedef enum{ | ||||
|     MODEM_BLE_MODULE,              //!< BLE controller used | ||||
|     MODEM_CLASSIC_BT_MODULE,       //!< Classic BT controller used | ||||
|     MODEM_WIFI_STATION_MODULE,     //!< Wi-Fi Station used | ||||
|     MODEM_WIFI_SOFTAP_MODULE,      //!< Wi-Fi SoftAP used | ||||
|     MODEM_WIFI_SNIFFER_MODULE,     //!< Wi-Fi Sniffer used | ||||
|     MODEM_WIFI_NULL_MODULE,        //!< Wi-Fi Null mode used | ||||
|     MODEM_USER_MODULE,             //!< User used | ||||
|     MODEM_MODULE_COUNT             //!< Number of items | ||||
| }modem_sleep_module_t; | ||||
|  | ||||
| #if CONFIG_ESP32_SUPPORT_MULTIPLE_PHY_INIT_DATA_BIN | ||||
| /** | ||||
|  * @brief PHY init data type | ||||
|  */ | ||||
| typedef enum { | ||||
|     ESP_PHY_INIT_DATA_TYPE_DEFAULT = 0, | ||||
|     ESP_PHY_INIT_DATA_TYPE_SRRC, | ||||
|     ESP_PHY_INIT_DATA_TYPE_FCC, | ||||
|     ESP_PHY_INIT_DATA_TYPE_CE, | ||||
|     ESP_PHY_INIT_DATA_TYPE_NCC, | ||||
|     ESP_PHY_INIT_DATA_TYPE_KCC, | ||||
|     ESP_PHY_INIT_DATA_TYPE_MIC, | ||||
|     ESP_PHY_INIT_DATA_TYPE_IC, | ||||
|     ESP_PHY_INIT_DATA_TYPE_ACMA, | ||||
|     ESP_PHY_INIT_DATA_TYPE_ANATEL, | ||||
|     ESP_PHY_INIT_DATA_TYPE_ISED, | ||||
|     ESP_PHY_INIT_DATA_TYPE_WPC, | ||||
|     ESP_PHY_INIT_DATA_TYPE_OFCA, | ||||
|     ESP_PHY_INIT_DATA_TYPE_IFETEL, | ||||
|     ESP_PHY_INIT_DATA_TYPE_RCM, | ||||
|     ESP_PHY_INIT_DATA_TYPE_NUMBER, | ||||
| } phy_init_data_type_t; | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief Module WIFI mask for medem sleep | ||||
|  */ | ||||
| #define MODEM_BT_MASK   ((1<<MODEM_BLE_MODULE)          |   \ | ||||
|                          (1<<MODEM_CLASSIC_BT_MODULE)) | ||||
|  | ||||
| /** | ||||
|  * @brief Module WIFI mask for medem sleep | ||||
|  */ | ||||
| #define MODEM_WIFI_MASK ((1<<MODEM_WIFI_STATION_MODULE) |   \ | ||||
|                          (1<<MODEM_WIFI_SOFTAP_MODULE)  |   \ | ||||
|                          (1<<MODEM_WIFI_SNIFFER_MODULE) |   \ | ||||
|                          (1<<MODEM_WIFI_NULL_MODULE)) | ||||
|  | ||||
| /** | ||||
|  * @brief Modules needing to call phy_rf_init | ||||
|  */ | ||||
| typedef enum{ | ||||
|     PHY_BT_MODULE,          //!< Bluetooth used | ||||
|     PHY_WIFI_MODULE,        //!< Wi-Fi used | ||||
|     PHY_MODEM_MODULE,       //!< Modem sleep used | ||||
|     PHY_MODULE_COUNT        //!< Number of items | ||||
| }phy_rf_module_t; | ||||
|  | ||||
| /** | ||||
|  * @brief Get PHY init data | ||||
|  * | ||||
|  * If "Use a partition to store PHY init data" option is set in menuconfig, | ||||
|  * This function will load PHY init data from a partition. Otherwise, | ||||
|  * PHY init data will be compiled into the application itself, and this function | ||||
|  * will return a pointer to PHY init data located in read-only memory (DROM). | ||||
|  * | ||||
|  * If "Use a partition to store PHY init data" option is enabled, this function | ||||
|  * may return NULL if the data loaded from flash is not valid. | ||||
|  * | ||||
|  * @note Call esp_phy_release_init_data to release the pointer obtained using | ||||
|  * this function after the call to esp_wifi_init. | ||||
|  * | ||||
|  * @return pointer to PHY init data structure | ||||
|  */ | ||||
| const esp_phy_init_data_t* esp_phy_get_init_data(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Release PHY init data | ||||
|  * @param data  pointer to PHY init data structure obtained from | ||||
|  *              esp_phy_get_init_data function | ||||
|  */ | ||||
| void esp_phy_release_init_data(const esp_phy_init_data_t* data); | ||||
|  | ||||
| /** | ||||
|  * @brief Function called by esp_phy_init to load PHY calibration data | ||||
|  * | ||||
|  * This is a convenience function which can be used to load PHY calibration | ||||
|  * data from NVS. Data can be stored to NVS using esp_phy_store_cal_data_to_nvs | ||||
|  * function. | ||||
|  * | ||||
|  * If calibration data is not present in the NVS, or | ||||
|  * data is not valid (was obtained for a chip with a different MAC address, | ||||
|  * or obtained for a different version of software), this function will | ||||
|  * return an error. | ||||
|  * | ||||
|  * If "Initialize PHY in startup code" option is set in menuconfig, this | ||||
|  * function will be used to load calibration data. To provide a different | ||||
|  * mechanism for loading calibration data, disable | ||||
|  * "Initialize PHY in startup code" option in menuconfig and call esp_phy_init | ||||
|  * function from the application. For an example usage of esp_phy_init and | ||||
|  * this function, see esp_phy_store_cal_data_to_nvs function in cpu_start.c | ||||
|  * | ||||
|  * @param out_cal_data pointer to calibration data structure to be filled with | ||||
|  *                     loaded data. | ||||
|  * @return ESP_OK on success | ||||
|  */ | ||||
| esp_err_t esp_phy_load_cal_data_from_nvs(esp_phy_calibration_data_t* out_cal_data); | ||||
|  | ||||
| /** | ||||
|  * @brief Function called by esp_phy_init to store PHY calibration data | ||||
|  * | ||||
|  * This is a convenience function which can be used to store PHY calibration | ||||
|  * data to the NVS. Calibration data is returned by esp_phy_init function. | ||||
|  * Data saved using this function to the NVS can later be loaded using | ||||
|  * esp_phy_store_cal_data_to_nvs function. | ||||
|  * | ||||
|  * If "Initialize PHY in startup code" option is set in menuconfig, this | ||||
|  * function will be used to store calibration data. To provide a different | ||||
|  * mechanism for storing calibration data, disable | ||||
|  * "Initialize PHY in startup code" option in menuconfig and call esp_phy_init | ||||
|  * function from the application. | ||||
|  * | ||||
|  * @param cal_data pointer to calibration data which has to be saved. | ||||
|  * @return ESP_OK on success | ||||
|  */ | ||||
| esp_err_t esp_phy_store_cal_data_to_nvs(const esp_phy_calibration_data_t* cal_data); | ||||
|  | ||||
| /** | ||||
|  * @brief Erase PHY calibration data which is stored in the NVS | ||||
|  * | ||||
|  * This is a function which can be used to trigger full calibration as a last-resort remedy  | ||||
|  * if partial calibration is used. It can be called in the application based on some conditions  | ||||
|  * (e.g. an option provided in some diagnostic mode). | ||||
|  * | ||||
|  * @return ESP_OK on success | ||||
|  * @return others on fail. Please refer to NVS API return value error number. | ||||
|  */ | ||||
| esp_err_t esp_phy_erase_cal_data_in_nvs(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Initialize PHY and RF module | ||||
|  * | ||||
|  * PHY and RF module should be initialized in order to use WiFi or BT. | ||||
|  * Now PHY and RF initializing job is done automatically when start WiFi or BT. Users should not | ||||
|  * call this API in their application. | ||||
|  * | ||||
|  * @param init_data  PHY parameters. Default set of parameters can | ||||
|  *                   be obtained by calling esp_phy_get_default_init_data | ||||
|  *                   function. | ||||
|  * @param mode  Calibration mode (Full, partial, or no calibration) | ||||
|  * @param[inout] calibration_data | ||||
|  * @return ESP_OK on success. | ||||
|  * @return ESP_FAIL on fail. | ||||
|  */ | ||||
| esp_err_t esp_phy_rf_init(const esp_phy_init_data_t* init_data,esp_phy_calibration_mode_t mode,  | ||||
|         esp_phy_calibration_data_t* calibration_data, phy_rf_module_t module); | ||||
|  | ||||
| /** | ||||
|  * @brief De-initialize PHY and RF module | ||||
|  * | ||||
|  * PHY module should be de-initialized in order to shutdown WiFi or BT. | ||||
|  * Now PHY and RF de-initializing job is done automatically when stop WiFi or BT. Users should not | ||||
|  * call this API in their application. | ||||
|  * | ||||
|  * @return ESP_OK on success. | ||||
|  */ | ||||
| esp_err_t esp_phy_rf_deinit(phy_rf_module_t module); | ||||
|  | ||||
| /** | ||||
|  * @brief Load calibration data from NVS and initialize PHY and RF module | ||||
|  */ | ||||
| void esp_phy_load_cal_and_init(phy_rf_module_t module); | ||||
|  | ||||
| /** | ||||
|  * @brief Enable WiFi/BT common clock | ||||
|  * | ||||
|  */ | ||||
| void esp_phy_common_clock_enable(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Disable WiFi/BT common clock | ||||
|  * | ||||
|  */ | ||||
| void esp_phy_common_clock_disable(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Module requires to enter modem sleep | ||||
|  */ | ||||
| esp_err_t esp_modem_sleep_enter(modem_sleep_module_t module); | ||||
|  | ||||
| /** | ||||
|  * @brief Module requires to exit modem sleep | ||||
|  */ | ||||
| esp_err_t esp_modem_sleep_exit(modem_sleep_module_t module); | ||||
|  | ||||
| /** | ||||
|  * @brief Register module to make it be able to require to enter/exit modem sleep | ||||
|  *        Although the module has no sleep function, as long as the module use RF, | ||||
|  *        it must call esp_modem_sleep_regsiter. Otherwise, other modules with sleep | ||||
|  *        function will disable RF without checking the module which doesn't call | ||||
|  *        esp_modem_sleep_regsiter. | ||||
|  */ | ||||
| esp_err_t esp_modem_sleep_register(modem_sleep_module_t module); | ||||
|  | ||||
| /** | ||||
|  * @brief De-register module from modem sleep list  | ||||
|  */ | ||||
| esp_err_t esp_modem_sleep_deregister(modem_sleep_module_t module); | ||||
|  | ||||
| /** | ||||
|  * @brief            Get the time stamp when PHY/RF was switched on | ||||
|  * @return           return 0 if PHY/RF is never switched on. Otherwise return time in | ||||
|  *                   microsecond since boot when phy/rf was last switched on | ||||
| */ | ||||
| int64_t esp_phy_rf_get_on_ts(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Update the corresponding PHY init type according to the country code of Wi-Fi. | ||||
|  */ | ||||
| esp_err_t esp_phy_update_country_info(const char *country); | ||||
|  | ||||
| #if CONFIG_ESP32_SUPPORT_MULTIPLE_PHY_INIT_DATA_BIN | ||||
| /**  | ||||
|  * @brief Apply PHY init bin to PHY | ||||
|  * @return ESP_OK on success. | ||||
|  * @return ESP_FAIL on fail. | ||||
|  */ | ||||
| esp_err_t esp_phy_apply_phy_init_data(uint8_t *init_data); | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| @@ -0,0 +1,25 @@ | ||||
| // Copyright 2019 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef _ESP_WIFI_PRIVATE_H | ||||
| #define _ESP_WIFI_PRIVATE_H | ||||
|  | ||||
| #include "freertos/FreeRTOS.h" | ||||
| #include "freertos/queue.h" | ||||
| #include "sys/queue.h" | ||||
| #include "sdkconfig.h" | ||||
| #include "esp_wifi_crypto_types.h" | ||||
| #include "esp_private/wifi_os_adapter.h" | ||||
|  | ||||
|  | ||||
| #endif /* _ESP_WIFI_PRIVATE_H */ | ||||
| @@ -0,0 +1,25 @@ | ||||
| // Copyright 2019 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
|  | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef _ESP_WIFI_TYPES_PRIVATE_H | ||||
| #define _ESP_WIFI_TYPES_PRIVATE_H | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| #include "sys/queue.h" | ||||
| #include "esp_err.h" | ||||
| #include "esp_interface.h" | ||||
| #include "esp_event_base.h" | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										421
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_private/wifi.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										421
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_private/wifi.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,421 @@ | ||||
| // Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
|  | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| /* | ||||
|  * All the APIs declared here are internal only APIs, it can only be used by  | ||||
|  * espressif internal modules, such as SSC, LWIP, TCPIP adapter etc, espressif  | ||||
|  * customers are not recommended to use them. | ||||
|  * | ||||
|  * If someone really want to use specified APIs declared in here, please contact | ||||
|  * espressif AE/developer to make sure you know the limitations or risk of  | ||||
|  * the API, otherwise you may get unexpected behavior!!! | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| #ifndef __ESP_WIFI_INTERNAL_H__ | ||||
| #define __ESP_WIFI_INTERNAL_H__ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| #include "freertos/FreeRTOS.h" | ||||
| #include "freertos/queue.h" | ||||
| #include "sys/queue.h" | ||||
| #include "esp_err.h" | ||||
| #include "esp_wifi_types.h" | ||||
| #include "esp_event.h" | ||||
| #include "esp_wifi.h" | ||||
| #include "esp_smartconfig.h" | ||||
| #include "wifi_types.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| typedef struct { | ||||
|     QueueHandle_t handle; /**< FreeRTOS queue handler */ | ||||
|     void *storage;        /**< storage for FreeRTOS queue */ | ||||
| } wifi_static_queue_t; | ||||
|  | ||||
| /** | ||||
|   * @brief WiFi log level | ||||
|   * | ||||
|   */ | ||||
| typedef enum { | ||||
|     WIFI_LOG_ERROR = 0,   /*enabled by default*/ | ||||
|     WIFI_LOG_WARNING,     /*enabled by default*/ | ||||
|     WIFI_LOG_INFO,        /*enabled by default*/ | ||||
|     WIFI_LOG_DEBUG,       /*can be set in menuconfig*/ | ||||
|     WIFI_LOG_VERBOSE,     /*can be set in menuconfig*/ | ||||
| } wifi_log_level_t; | ||||
|    | ||||
| /** | ||||
|   * @brief WiFi log module definition | ||||
|   * | ||||
|   */ | ||||
| typedef enum { | ||||
|     WIFI_LOG_MODULE_ALL  = 0, /*all log modules */ | ||||
|     WIFI_LOG_MODULE_WIFI, /*logs related to WiFi*/ | ||||
|     WIFI_LOG_MODULE_COEX, /*logs related to WiFi and BT(or BLE) coexist*/ | ||||
|     WIFI_LOG_MODULE_MESH, /*logs related to Mesh*/ | ||||
| } wifi_log_module_t; | ||||
|  | ||||
| /** | ||||
|   * @brief WiFi log submodule definition | ||||
|   * | ||||
|   */ | ||||
| #define WIFI_LOG_SUBMODULE_ALL   (0)    /*all log submodules*/ | ||||
| #define WIFI_LOG_SUBMODULE_INIT  (1)    /*logs related to initialization*/ | ||||
| #define WIFI_LOG_SUBMODULE_IOCTL (1<<1) /*logs related to API calling*/ | ||||
| #define WIFI_LOG_SUBMODULE_CONN  (1<<2) /*logs related to connecting*/ | ||||
| #define WIFI_LOG_SUBMODULE_SCAN  (1<<3) /*logs related to scaning*/ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * @brief Initialize Wi-Fi Driver | ||||
|  *     Alloc resource for WiFi driver, such as WiFi control structure, RX/TX buffer, | ||||
|  *     WiFi NVS structure among others. | ||||
|  * | ||||
|  * For the most part, you need not call this function directly. It gets called | ||||
|  * from esp_wifi_init(). | ||||
|  * | ||||
|  * This function may be called, if you only need to initialize the Wi-Fi driver | ||||
|  * without having to use the network stack on top. | ||||
|  * | ||||
|  * @param  config provide WiFi init configuration | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK: succeed | ||||
|  *    - ESP_ERR_NO_MEM: out of memory | ||||
|  *    - others: refer to error code esp_err.h | ||||
|  */ | ||||
| esp_err_t esp_wifi_init_internal(const wifi_init_config_t *config); | ||||
|  | ||||
| /** | ||||
|  * @brief Deinitialize Wi-Fi Driver | ||||
|  *     Free resource for WiFi driver, such as WiFi control structure, RX/TX buffer, | ||||
|  *     WiFi NVS structure among others. | ||||
|  * | ||||
|  * For the most part, you need not call this function directly. It gets called | ||||
|  * from esp_wifi_deinit(). | ||||
|  * | ||||
|  * This function may be called, if you call esp_wifi_init_internal to initialize | ||||
|  * WiFi driver. | ||||
|  * | ||||
|  * @return | ||||
|  *    - ESP_OK: succeed | ||||
|  *    - others: refer to error code esp_err.h | ||||
|  */ | ||||
| esp_err_t esp_wifi_deinit_internal(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  get whether the wifi driver is allowed to transmit data or not | ||||
|   * | ||||
|   * @return | ||||
|   *     - true  : upper layer should stop to transmit data to wifi driver | ||||
|   *     - false : upper layer can transmit data to wifi driver | ||||
|   */ | ||||
| bool esp_wifi_internal_tx_is_stop(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  free the rx buffer which allocated by wifi driver | ||||
|   * | ||||
|   * @param  void* buffer: rx buffer pointer | ||||
|   */ | ||||
| void esp_wifi_internal_free_rx_buffer(void* buffer); | ||||
|  | ||||
| /** | ||||
|   * @brief  transmit the buffer via wifi driver | ||||
|   * | ||||
|   * @param  wifi_interface_t wifi_if : wifi interface id | ||||
|   * @param  void *buffer : the buffer to be tansmit | ||||
|   * @param  uint16_t len : the length of buffer | ||||
|   * | ||||
|   * @return | ||||
|   *    - ERR_OK  : Successfully transmit the buffer to wifi driver | ||||
|   *    - ERR_MEM : Out of memory | ||||
|   *    - ERR_IF : WiFi driver error | ||||
|   *    - ERR_ARG : Invalid argument | ||||
|   */ | ||||
| int esp_wifi_internal_tx(wifi_interface_t wifi_if, void *buffer, uint16_t len); | ||||
|  | ||||
| /** | ||||
|   * @brief     The WiFi RX callback function | ||||
|   * | ||||
|   *            Each time the WiFi need to forward the packets to high layer, the callback function will be called | ||||
|   */ | ||||
| typedef esp_err_t (*wifi_rxcb_t)(void *buffer, uint16_t len, void *eb); | ||||
|  | ||||
| /** | ||||
|   * @brief     Set the WiFi RX callback | ||||
|   * | ||||
|   * @attention 1. Currently we support only one RX callback for each interface | ||||
|   * | ||||
|   * @param     wifi_interface_t ifx : interface | ||||
|   * @param     wifi_rxcb_t fn : WiFi RX callback | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK : succeed | ||||
|   *     - others : fail | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_reg_rxcb(wifi_interface_t ifx, wifi_rxcb_t fn); | ||||
|  | ||||
| /** | ||||
|   * @brief     Notify WIFI driver that the station got ip successfully | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK : succeed | ||||
|   *     - others : fail | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_set_sta_ip(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  enable or disable transmitting WiFi MAC frame with fixed rate | ||||
|   * | ||||
|   * @attention 1. If fixed rate is enabled, both management and data frame are transmitted with fixed rate | ||||
|   * @attention 2. Make sure that the receiver is able to receive the frame with the fixed rate if you want the frame to be received | ||||
|   * | ||||
|   * @param  ifx : wifi interface | ||||
|   * @param  en : false - disable, true - enable | ||||
|   * @param  rate : PHY rate | ||||
|   * | ||||
|   * @return | ||||
|   *    - ERR_OK  : succeed | ||||
|   *    - ESP_ERR_WIFI_NOT_INIT: WiFi is not initialized by esp_wifi_init | ||||
|   *    - ESP_ERR_WIFI_NOT_STARTED: WiFi was not started by esp_wifi_start | ||||
|   *    - ESP_ERR_WIFI_IF : invalid WiFi interface | ||||
|   *    - ESP_ERR_INVALID_ARG : invalid rate | ||||
|   *    - ESP_ERR_NOT_SUPPORTED : do not support to set fixed rate if TX AMPDU is enabled | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_set_fix_rate(wifi_interface_t ifx, bool en, wifi_phy_rate_t rate); | ||||
|  | ||||
| /** | ||||
|   * @brief     Start SmartConfig, config ESP device to connect AP. You need to broadcast information by phone APP. | ||||
|   *            Device sniffer special packets from the air that containing SSID and password of target AP. | ||||
|   * | ||||
|   * @attention 1. This API can be called in station or softAP-station mode. | ||||
|   * @attention 2. Can not call esp_smartconfig_start twice before it finish, please call | ||||
|   *               esp_smartconfig_stop first. | ||||
|   * | ||||
|   * @param     config pointer to smartconfig start configure structure | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK: succeed | ||||
|   *     - others: fail | ||||
|   */ | ||||
| esp_err_t esp_smartconfig_internal_start(const smartconfig_start_config_t *config); | ||||
|  | ||||
| /** | ||||
|   * @brief     Stop SmartConfig, free the buffer taken by esp_smartconfig_start. | ||||
|   * | ||||
|   * @attention Whether connect to AP succeed or not, this API should be called to free | ||||
|   *            memory taken by smartconfig_start. | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK: succeed | ||||
|   *     - others: fail | ||||
|   */ | ||||
| esp_err_t esp_smartconfig_internal_stop(void); | ||||
|  | ||||
| /** | ||||
|   * @brief     Check the MD5 values of the OS adapter header files in IDF and WiFi library | ||||
|   * | ||||
|   * @attention 1. It is used for internal CI version check | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK : succeed | ||||
|   *     - ESP_WIFI_INVALID_ARG : MD5 check fail | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_osi_funcs_md5_check(const char *md5); | ||||
|  | ||||
| /** | ||||
|   * @brief     Check the MD5 values of the crypto types header files in IDF and WiFi library | ||||
|   * | ||||
|   * @attention 1. It is used for internal CI version check | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK : succeed | ||||
|   *     - ESP_WIFI_INVALID_ARG : MD5 check fail | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_crypto_funcs_md5_check(const char *md5); | ||||
|  | ||||
| /** | ||||
|   * @brief     Check the MD5 values of the esp_wifi_types.h in IDF and WiFi library | ||||
|   * | ||||
|   * @attention 1. It is used for internal CI version check | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK : succeed | ||||
|   *     - ESP_WIFI_INVALID_ARG : MD5 check fail | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_wifi_type_md5_check(const char *md5); | ||||
|  | ||||
| /** | ||||
|   * @brief     Check the MD5 values of the esp_wifi.h in IDF and WiFi library | ||||
|   * | ||||
|   * @attention 1. It is used for internal CI version check | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK : succeed | ||||
|   *     - ESP_WIFI_INVALID_ARG : MD5 check fail | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_esp_wifi_md5_check(const char *md5); | ||||
|  | ||||
| /** | ||||
|   * @brief     Allocate a chunk of memory for WiFi driver | ||||
|   * | ||||
|   * @attention This API is not used for DMA memory allocation. | ||||
|   * | ||||
|   * @param     size_t size : Size, in bytes, of the amount of memory to allocate | ||||
|   * | ||||
|   * @return    A pointer to the memory allocated on success, NULL on failure | ||||
|   */ | ||||
| void *wifi_malloc( size_t size ); | ||||
|  | ||||
| /** | ||||
|   * @brief     Reallocate a chunk of memory for WiFi driver | ||||
|   * | ||||
|   * @attention This API is not used for DMA memory allocation. | ||||
|   * | ||||
|   * @param     void * ptr  : Pointer to previously allocated memory, or NULL for a new allocation. | ||||
|   * @param     size_t size : Size, in bytes, of the amount of memory to allocate | ||||
|   * | ||||
|   * @return    A pointer to the memory allocated on success, NULL on failure | ||||
|   */ | ||||
| void *wifi_realloc( void *ptr, size_t size ); | ||||
|  | ||||
| /** | ||||
|   * @brief     Callocate memory for WiFi driver | ||||
|   * | ||||
|   * @attention This API is not used for DMA memory allocation. | ||||
|   * | ||||
|   * @param     size_t n    : Number of continuing chunks of memory to allocate | ||||
|   * @param     size_t size : Size, in bytes, of the amount of memory to allocate | ||||
|   * | ||||
|   * @return    A pointer to the memory allocated on success, NULL on failure | ||||
|   */ | ||||
| void *wifi_calloc( size_t n, size_t size ); | ||||
|  | ||||
| /** | ||||
|   * @brief     Update WiFi MAC time | ||||
|   * | ||||
|   * @param     uint32_t time_delta : time duration since the WiFi/BT common clock is disabled | ||||
|   * | ||||
|   * @return    Always returns ESP_OK | ||||
|   */ | ||||
| typedef esp_err_t (* wifi_mac_time_update_cb_t)( uint32_t time_delta ); | ||||
|  | ||||
| /** | ||||
|   * @brief     Update WiFi MAC time | ||||
|   * | ||||
|   * @param     uint32_t time_delta : time duration since the WiFi/BT common clock is disabled | ||||
|   * | ||||
|   * @return    Always returns ESP_OK | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_update_mac_time( uint32_t time_delta ); | ||||
|  | ||||
| /** | ||||
|   * @brief     Set current WiFi log level      | ||||
|   * | ||||
|   * @param     level   Log level. | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   *    - ESP_FAIL: level is invalid | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_set_log_level(wifi_log_level_t level); | ||||
|  | ||||
| /** | ||||
|   * @brief     Set current log module and submodule | ||||
|   * | ||||
|   * @param     module      Log module | ||||
|   * @param     submodule   Log submodule | ||||
|   * @param     enable      enable or disable | ||||
|   *            If module == 0 && enable == 0, all log modules are disabled. | ||||
|   *            If module == 0 && enable == 1, all log modules are enabled. | ||||
|   *            If submodule == 0 && enable == 0, all log submodules are disabled. | ||||
|   *            If submodule == 0 && enable == 1, all log submodules are enabled. | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   *    - ESP_ERR_WIFI_NOT_INIT: WiFi is not initialized by esp_wifi_init | ||||
|   *    - ESP_ERR_WIFI_ARG: invalid argument | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_set_log_mod(wifi_log_module_t module, uint32_t submodule, bool enable); | ||||
|  | ||||
| /** | ||||
|   * @brief     Get current WiFi log info      | ||||
|   * | ||||
|   * @param     log_level  the return log level. | ||||
|   * @param     log_mod    the return log module and submodule | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_get_log(wifi_log_level_t *log_level, uint32_t *log_mod); | ||||
|  | ||||
| /** | ||||
|   * @brief     A general API to set/get WiFi internal configuration, it's for debug only | ||||
|   * | ||||
|   * @param     cmd : ioctl command type | ||||
|   * @param     cfg : configuration for the command | ||||
|   * | ||||
|   * @return     | ||||
|   *    - ESP_OK: succeed | ||||
|   *    - others: failed | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_ioctl(int cmd, wifi_ioctl_config_t *cfg); | ||||
|  | ||||
| /** | ||||
|   * @brief     Get the user-configured channel info  | ||||
|   * | ||||
|   * @param     ifx : WiFi interface  | ||||
|   * @param     primary : store the configured primary channel  | ||||
|   * @param     second : store the configured second channel | ||||
|   * | ||||
|   * @return     | ||||
|   *    - ESP_OK: succeed | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_get_config_channel(wifi_interface_t ifx, uint8_t *primary, uint8_t *second); | ||||
|  | ||||
| /** | ||||
|   * @brief     Get the negotiated channel info after WiFi connection established  | ||||
|   * | ||||
|   * @param     ifx : WiFi interface  | ||||
|   * @param     aid : the connection number when a STA connects to the softAP     | ||||
|   * @param     primary : store the negotiated primary channel  | ||||
|   * @param     second : store the negotiated second channel | ||||
|   * @attention the aid param is only works when the ESP32 in softAP/softAP+STA mode  | ||||
|   * | ||||
|   * @return     | ||||
|   *    - ESP_OK: succeed | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_get_negotiated_channel(wifi_interface_t ifx, uint8_t aid, uint8_t *primary, uint8_t *second); | ||||
|  | ||||
| /** | ||||
|   * @brief     Get the negotiated bandwidth info after WiFi connection established  | ||||
|   * | ||||
|   * @param     ifx : WiFi interface  | ||||
|   * @param     bw : store the negotiated bandwidth  | ||||
|   * | ||||
|   * @return     | ||||
|   *    - ESP_OK: succeed | ||||
|   */ | ||||
| esp_err_t esp_wifi_internal_get_negotiated_bandwidth(wifi_interface_t ifx, uint8_t aid, uint8_t *bw); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* __ESP_WIFI_H__ */ | ||||
| @@ -0,0 +1,145 @@ | ||||
| // Copyright 2018 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| // | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef ESP_WIFI_OS_ADAPTER_H_ | ||||
| #define ESP_WIFI_OS_ADAPTER_H_ | ||||
|  | ||||
| #include <stdarg.h> | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #define ESP_WIFI_OS_ADAPTER_VERSION  0x00000006 | ||||
| #define ESP_WIFI_OS_ADAPTER_MAGIC    0xDEADBEAF | ||||
|  | ||||
| #define OSI_FUNCS_TIME_BLOCKING      0xffffffff | ||||
|  | ||||
| #define OSI_QUEUE_SEND_FRONT         0 | ||||
| #define OSI_QUEUE_SEND_BACK          1 | ||||
| #define OSI_QUEUE_SEND_OVERWRITE     2 | ||||
|  | ||||
| typedef struct { | ||||
|     int32_t _version; | ||||
|     void (*_set_isr)(int32_t n, void *f, void *arg); | ||||
|     void (*_ints_on)(uint32_t mask); | ||||
|     void (*_ints_off)(uint32_t mask); | ||||
|     void *(* _spin_lock_create)(void); | ||||
|     void (* _spin_lock_delete)(void *lock); | ||||
|     uint32_t (*_wifi_int_disable)(void *wifi_int_mux); | ||||
|     void (*_wifi_int_restore)(void *wifi_int_mux, uint32_t tmp); | ||||
|     void (*_task_yield_from_isr)(void); | ||||
|     void *(*_semphr_create)(uint32_t max, uint32_t init); | ||||
|     void (*_semphr_delete)(void *semphr); | ||||
|     int32_t (*_semphr_take)(void *semphr, uint32_t block_time_tick); | ||||
|     int32_t (*_semphr_give)(void *semphr); | ||||
|     void *(*_wifi_thread_semphr_get)(void); | ||||
|     void *(*_mutex_create)(void); | ||||
|     void *(*_recursive_mutex_create)(void); | ||||
|     void (*_mutex_delete)(void *mutex); | ||||
|     int32_t (*_mutex_lock)(void *mutex); | ||||
|     int32_t (*_mutex_unlock)(void *mutex); | ||||
|     void *(* _queue_create)(uint32_t queue_len, uint32_t item_size); | ||||
|     void (* _queue_delete)(void *queue); | ||||
|     int32_t (* _queue_send)(void *queue, void *item, uint32_t block_time_tick); | ||||
|     int32_t (* _queue_send_from_isr)(void *queue, void *item, void *hptw); | ||||
|     int32_t (* _queue_send_to_back)(void *queue, void *item, uint32_t block_time_tick); | ||||
|     int32_t (* _queue_send_to_front)(void *queue, void *item, uint32_t block_time_tick); | ||||
|     int32_t (* _queue_recv)(void *queue, void *item, uint32_t block_time_tick); | ||||
|     uint32_t (* _queue_msg_waiting)(void *queue); | ||||
|     void *(* _event_group_create)(void); | ||||
|     void (* _event_group_delete)(void *event); | ||||
|     uint32_t (* _event_group_set_bits)(void *event, uint32_t bits); | ||||
|     uint32_t (* _event_group_clear_bits)(void *event, uint32_t bits); | ||||
|     uint32_t (* _event_group_wait_bits)(void *event, uint32_t bits_to_wait_for, int32_t clear_on_exit, int32_t wait_for_all_bits, uint32_t block_time_tick); | ||||
|     int32_t (* _task_create_pinned_to_core)(void *task_func, const char *name, uint32_t stack_depth, void *param, uint32_t prio, void *task_handle, uint32_t core_id); | ||||
|     int32_t (* _task_create)(void *task_func, const char *name, uint32_t stack_depth, void *param, uint32_t prio, void *task_handle); | ||||
|     void (* _task_delete)(void *task_handle); | ||||
|     void (* _task_delay)(uint32_t tick); | ||||
|     int32_t (* _task_ms_to_tick)(uint32_t ms); | ||||
|     void *(* _task_get_current_task)(void); | ||||
|     int32_t (* _task_get_max_priority)(void); | ||||
|     void *(* _malloc)(uint32_t size); | ||||
|     void (* _free)(void *p); | ||||
|     int32_t (* _event_post)(const char* event_base, int32_t event_id, void* event_data, size_t event_data_size, uint32_t ticks_to_wait); | ||||
|     uint32_t (* _get_free_heap_size)(void); | ||||
|     uint32_t (* _rand)(void); | ||||
|     void (* _dport_access_stall_other_cpu_start_wrap)(void); | ||||
|     void (* _dport_access_stall_other_cpu_end_wrap)(void); | ||||
|     int32_t (* _phy_rf_deinit)(uint32_t module); | ||||
|     void (* _phy_load_cal_and_init)(uint32_t module); | ||||
| #if CONFIG_IDF_TARGET_ESP32 | ||||
|     void (* _phy_common_clock_enable)(void); | ||||
|     void (* _phy_common_clock_disable)(void); | ||||
| #endif | ||||
|     int32_t (* _phy_update_country_info)(const char* country); | ||||
|     int32_t (* _read_mac)(uint8_t* mac, uint32_t type); | ||||
|     void (* _timer_arm)(void *timer, uint32_t tmout, bool repeat); | ||||
|     void (* _timer_disarm)(void *timer); | ||||
|     void (* _timer_done)(void *ptimer); | ||||
|     void (* _timer_setfn)(void *ptimer, void *pfunction, void *parg); | ||||
|     void (* _timer_arm_us)(void *ptimer, uint32_t us, bool repeat); | ||||
|     void (* _wifi_reset_mac)(void); | ||||
|     void (* _wifi_clock_enable)(void); | ||||
|     void (* _wifi_clock_disable)(void); | ||||
|     int64_t (* _esp_timer_get_time)(void); | ||||
|     int32_t (* _nvs_set_i8)(uint32_t handle, const char* key, int8_t value); | ||||
|     int32_t (* _nvs_get_i8)(uint32_t handle, const char* key, int8_t* out_value); | ||||
|     int32_t (* _nvs_set_u8)(uint32_t handle, const char* key, uint8_t value); | ||||
|     int32_t (* _nvs_get_u8)(uint32_t handle, const char* key, uint8_t* out_value); | ||||
|     int32_t (* _nvs_set_u16)(uint32_t handle, const char* key, uint16_t value); | ||||
|     int32_t (* _nvs_get_u16)(uint32_t handle, const char* key, uint16_t* out_value); | ||||
|     int32_t (* _nvs_open)(const char* name, uint32_t open_mode, uint32_t *out_handle); | ||||
|     void (* _nvs_close)(uint32_t handle);  | ||||
|     int32_t (* _nvs_commit)(uint32_t handle); | ||||
|     int32_t (* _nvs_set_blob)(uint32_t handle, const char* key, const void* value, size_t length); | ||||
|     int32_t (* _nvs_get_blob)(uint32_t handle, const char* key, void* out_value, size_t* length); | ||||
|     int32_t (* _nvs_erase_key)(uint32_t handle, const char* key); | ||||
|     int32_t (* _get_random)(uint8_t *buf, size_t len); | ||||
|     int32_t (* _get_time)(void *t); | ||||
|     unsigned long (* _random)(void); | ||||
| #if CONFIG_IDF_TARGET_ESP32S2 | ||||
|     uint32_t (* _slowclk_cal_get)(void); | ||||
| #endif | ||||
|     void (* _log_write)(uint32_t level, const char* tag, const char* format, ...); | ||||
|     void (* _log_writev)(uint32_t level, const char* tag, const char* format, va_list args); | ||||
|     uint32_t (* _log_timestamp)(void); | ||||
|     void * (* _malloc_internal)(size_t size); | ||||
|     void * (* _realloc_internal)(void *ptr, size_t size); | ||||
|     void * (* _calloc_internal)(size_t n, size_t size); | ||||
|     void * (* _zalloc_internal)(size_t size); | ||||
|     void * (* _wifi_malloc)(size_t size); | ||||
|     void * (* _wifi_realloc)(void *ptr, size_t size); | ||||
|     void * (* _wifi_calloc)(size_t n, size_t size); | ||||
|     void * (* _wifi_zalloc)(size_t size); | ||||
|     void * (* _wifi_create_queue)(int32_t queue_len, int32_t item_size); | ||||
|     void (* _wifi_delete_queue)(void * queue); | ||||
|     int32_t (* _modem_sleep_enter)(uint32_t module); | ||||
|     int32_t (* _modem_sleep_exit)(uint32_t module); | ||||
|     int32_t (* _modem_sleep_register)(uint32_t module); | ||||
|     int32_t (* _modem_sleep_deregister)(uint32_t module); | ||||
|     uint32_t (* _coex_status_get)(void); | ||||
|     void (* _coex_condition_set)(uint32_t type, bool dissatisfy); | ||||
|     int32_t (* _coex_wifi_request)(uint32_t event, uint32_t latency, uint32_t duration); | ||||
|     int32_t (* _coex_wifi_release)(uint32_t event); | ||||
|     int32_t _magic; | ||||
| } wifi_osi_funcs_t; | ||||
|  | ||||
| extern wifi_osi_funcs_t g_wifi_osi_funcs; | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* ESP_WIFI_OS_ADAPTER_H_ */ | ||||
| @@ -0,0 +1,54 @@ | ||||
| // Copyright 2015-2019 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
|  | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef _WIFI_TYPES_H | ||||
| #define _WIFI_TYPES_H | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|   * @brief WiFi ioctl command type | ||||
|   * | ||||
|   */ | ||||
| typedef enum { | ||||
|     WIFI_IOCTL_SET_STA_HT2040_COEX = 1, /**< Set the configuration of STA's HT2040 coexist management */ | ||||
|     WIFI_IOCTL_GET_STA_HT2040_COEX,     /**< Get the configuration of STA's HT2040 coexist management */ | ||||
|     WIFI_IOCTL_MAX, | ||||
| } wifi_ioctl_cmd_t; | ||||
|  | ||||
| /** | ||||
|  * @brief Configuration for STA's HT2040 coexist management | ||||
|  * | ||||
|  */ | ||||
| typedef struct { | ||||
|     int enable;                         /**< Indicate whether STA's HT2040 coexist management is enabled or not */ | ||||
| } wifi_ht2040_coex_t; | ||||
|  | ||||
| /** | ||||
|   * @brief Configuration for WiFi ioctl | ||||
|   * | ||||
|   */ | ||||
| typedef struct { | ||||
|     union { | ||||
|         wifi_ht2040_coex_t ht2040_coex; /**< Configuration of STA's HT2040 coexist management */ | ||||
|     } data;                             /**< Configuration of ioctl command */ | ||||
| } wifi_ioctl_config_t; | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										146
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_smartconfig.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_smartconfig.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | ||||
| // Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| // | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef __ESP_SMARTCONFIG_H__ | ||||
| #define __ESP_SMARTCONFIG_H__ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| #include "esp_err.h" | ||||
| #include "esp_event_base.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| typedef enum { | ||||
|     SC_TYPE_ESPTOUCH = 0,       /**< protocol: ESPTouch */ | ||||
|     SC_TYPE_AIRKISS,            /**< protocol: AirKiss */ | ||||
|     SC_TYPE_ESPTOUCH_AIRKISS,   /**< protocol: ESPTouch and AirKiss */ | ||||
| } smartconfig_type_t; | ||||
|  | ||||
| /** Smartconfig event declarations */ | ||||
| typedef enum { | ||||
|     SC_EVENT_SCAN_DONE,                /*!< ESP32 station smartconfig has finished to scan for APs */ | ||||
|     SC_EVENT_FOUND_CHANNEL,            /*!< ESP32 station smartconfig has found the channel of the target AP */ | ||||
|     SC_EVENT_GOT_SSID_PSWD,            /*!< ESP32 station smartconfig got the SSID and password */ | ||||
|     SC_EVENT_SEND_ACK_DONE,            /*!< ESP32 station smartconfig has sent ACK to cellphone */ | ||||
| } smartconfig_event_t; | ||||
|  | ||||
| /** @brief smartconfig event base declaration */ | ||||
| ESP_EVENT_DECLARE_BASE(SC_EVENT); | ||||
|  | ||||
| /** Argument structure for SC_EVENT_GOT_SSID_PSWD event */ | ||||
| typedef struct { | ||||
|     uint8_t ssid[32];           /**< SSID of the AP. Null terminated string. */ | ||||
|     uint8_t password[64];       /**< Password of the AP. Null terminated string. */ | ||||
|     bool bssid_set;             /**< whether set MAC address of target AP or not. */ | ||||
|     uint8_t bssid[6];           /**< MAC address of target AP. */ | ||||
|     smartconfig_type_t type;    /**< Type of smartconfig(ESPTouch or AirKiss). */ | ||||
|     uint8_t token;              /**< Token from cellphone which is used to send ACK to cellphone. */ | ||||
|     uint8_t cellphone_ip[4];    /**< IP address of cellphone. */ | ||||
| } smartconfig_event_got_ssid_pswd_t; | ||||
|  | ||||
| /** Configure structure for esp_smartconfig_start */ | ||||
| typedef struct { | ||||
|     bool enable_log;            /**< Enable smartconfig logs. */ | ||||
| } smartconfig_start_config_t; | ||||
|  | ||||
| #define SMARTCONFIG_START_CONFIG_DEFAULT() { \ | ||||
|     .enable_log = false \ | ||||
| }; | ||||
|  | ||||
| /** | ||||
|   * @brief  Get the version of SmartConfig. | ||||
|   * | ||||
|   * @return | ||||
|   *     - SmartConfig version const char. | ||||
|   */ | ||||
| const char *esp_smartconfig_get_version(void); | ||||
|  | ||||
| /** | ||||
|   * @brief     Start SmartConfig, config ESP device to connect AP. You need to broadcast information by phone APP. | ||||
|   *            Device sniffer special packets from the air that containing SSID and password of target AP. | ||||
|   * | ||||
|   * @attention 1. This API can be called in station or softAP-station mode. | ||||
|   * @attention 2. Can not call esp_smartconfig_start twice before it finish, please call | ||||
|   *               esp_smartconfig_stop first. | ||||
|   * | ||||
|   * @param     config pointer to smartconfig start configure structure | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK: succeed | ||||
|   *     - others: fail | ||||
|   */ | ||||
| esp_err_t esp_smartconfig_start(const smartconfig_start_config_t *config); | ||||
|  | ||||
| /** | ||||
|   * @brief     Stop SmartConfig, free the buffer taken by esp_smartconfig_start. | ||||
|   * | ||||
|   * @attention Whether connect to AP succeed or not, this API should be called to free | ||||
|   *            memory taken by smartconfig_start. | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK: succeed | ||||
|   *     - others: fail | ||||
|   */ | ||||
| esp_err_t esp_smartconfig_stop(void); | ||||
|  | ||||
| /** | ||||
|   * @brief     Set timeout of SmartConfig process. | ||||
|   * | ||||
|   * @attention Timing starts from SC_STATUS_FIND_CHANNEL status. SmartConfig will restart if timeout. | ||||
|   * | ||||
|   * @param     time_s  range 15s~255s, offset:45s. | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK: succeed | ||||
|   *     - others: fail | ||||
|   */ | ||||
| esp_err_t esp_esptouch_set_timeout(uint8_t time_s); | ||||
|  | ||||
| /** | ||||
|   * @brief     Set protocol type of SmartConfig. | ||||
|   * | ||||
|   * @attention If users need to set the SmartConfig type, please set it before calling | ||||
|   *            esp_smartconfig_start. | ||||
|   * | ||||
|   * @param     type  Choose from the smartconfig_type_t. | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK: succeed | ||||
|   *     - others: fail | ||||
|   */ | ||||
| esp_err_t esp_smartconfig_set_type(smartconfig_type_t type); | ||||
|  | ||||
| /** | ||||
|   * @brief     Set mode of SmartConfig. default normal mode. | ||||
|   * | ||||
|   * @attention 1. Please call it before API esp_smartconfig_start. | ||||
|   * @attention 2. Fast mode have corresponding APP(phone). | ||||
|   * @attention 3. Two mode is compatible. | ||||
|   * | ||||
|   * @param     enable  false-disable(default); true-enable; | ||||
|   * | ||||
|   * @return | ||||
|   *     - ESP_OK: succeed | ||||
|   *     - others: fail | ||||
|   */ | ||||
| esp_err_t esp_smartconfig_fast_mode(bool enable); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										1069
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_wifi.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1069
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_wifi.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										404
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_wifi_crypto_types.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										404
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_wifi_crypto_types.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,404 @@ | ||||
| // Hardware crypto support Copyright 2017 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
|  | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
|  | ||||
| #ifndef __ESP_WIFI_CRYPTO_TYPES_H__ | ||||
| #define __ESP_WIFI_CRYPTO_TYPES_H__ | ||||
|  | ||||
| /* This is an internal API header for configuring the implementation used for WiFi cryptographic | ||||
|    operations. | ||||
|  | ||||
|    During normal operation, you don't need to use any of these types or functions in this header. | ||||
|    See esp_wifi.h & esp_wifi_types.h instead. | ||||
| */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #define ESP_WIFI_CRYPTO_VERSION 0x00000001 | ||||
|  | ||||
| /* | ||||
|  * Enumeration for hash operations. | ||||
|  * When WPA2 is connecting, this enum is used to | ||||
|  * request a hash algorithm via crypto_hash_xxx functions. | ||||
|  */ | ||||
| typedef enum { | ||||
|     ESP_CRYPTO_HASH_ALG_MD5, ESP_CRYPTO_HASH_ALG_SHA1, | ||||
|     ESP_CRYPTO_HASH_ALG_HMAC_MD5, ESP_CRYPTO_HASH_ALG_HMAC_SHA1, | ||||
|     ESP_CRYPTO_HASH_ALG_SHA256, ESP_CRYPTO_HASH_ALG_HMAC_SHA256 | ||||
| }esp_crypto_hash_alg_t; | ||||
|  | ||||
| /* | ||||
|  * Enumeration for block cipher operations. | ||||
|  * When WPA2 is connecting, this enum is used to request a block | ||||
|  * cipher algorithm via crypto_cipher_xxx functions. | ||||
|  */ | ||||
| typedef enum { | ||||
|     ESP_CRYPTO_CIPHER_NULL, ESP_CRYPTO_CIPHER_ALG_AES, ESP_CRYPTO_CIPHER_ALG_3DES, | ||||
|     ESP_CRYPTO_CIPHER_ALG_DES, ESP_CRYPTO_CIPHER_ALG_RC2, ESP_CRYPTO_CIPHER_ALG_RC4 | ||||
| } esp_crypto_cipher_alg_t; | ||||
|  | ||||
| /* | ||||
|  * This structure is about the algorithm when do crypto_hash operation, for detail,  | ||||
|  * please reference to the structure crypto_hash. | ||||
|  */ | ||||
| typedef struct crypto_hash esp_crypto_hash_t; | ||||
|  | ||||
| /* | ||||
|  * This structure is about the algorithm when do crypto_cipher operation, for detail,  | ||||
|  * please reference to the structure crypto_cipher. | ||||
|  */ | ||||
| typedef struct crypto_cipher esp_crypto_cipher_t; | ||||
|  | ||||
| /** | ||||
|   * @brief The AES callback function when do WPS connect.  | ||||
|   * | ||||
|   * @param key  Encryption key. | ||||
|   * @param iv  Encryption IV for CBC mode (16 bytes). | ||||
|   * @param data  Data to encrypt in-place. | ||||
|   * @param data_len  Length of data in bytes (must be divisible by 16) | ||||
|   */ | ||||
| typedef int (*esp_aes_128_encrypt_t)(const unsigned char *key, const unsigned char *iv, unsigned char *data, int data_len); | ||||
|  | ||||
| /** | ||||
|   * @brief The AES callback function when do WPS connect.  | ||||
|   * | ||||
|   * @param key  Decryption key. | ||||
|   * @param iv  Decryption IV for CBC mode (16 bytes). | ||||
|   * @param data  Data to decrypt in-place. | ||||
|   * @param data_len  Length of data in bytes (must be divisible by 16) | ||||
|   * | ||||
|   */ | ||||
| typedef int (*esp_aes_128_decrypt_t)(const unsigned char *key, const unsigned char *iv, unsigned char *data, int data_len); | ||||
|  | ||||
| /** | ||||
|   * @brief The AES callback function when do STA connect. | ||||
|   * | ||||
|   * @param kek  16-octet Key encryption key (KEK). | ||||
|   * @param n  Length of the plaintext key in 64-bit units; | ||||
|   * @param plain  Plaintext key to be wrapped, n * 64 bits | ||||
|   * @param cipher  Wrapped key, (n + 1) * 64 bits | ||||
|   * | ||||
|   */ | ||||
| typedef int (*esp_aes_wrap_t)(const unsigned char *kek, int n, const unsigned char *plain, unsigned char *cipher); | ||||
|  | ||||
| /** | ||||
|   * @brief The AES callback function when do STA connect. | ||||
|   * | ||||
|   * @param kek  16-octet Key decryption key (KEK). | ||||
|   * @param n  Length of the plaintext key in 64-bit units; | ||||
|   * @param cipher  Wrapped key to be unwrapped, (n + 1) * 64 bits | ||||
|   * @param plain  Plaintext key, n * 64 bits | ||||
|   * | ||||
|   */ | ||||
| typedef int (*esp_aes_unwrap_t)(const unsigned char *kek, int n, const unsigned char *cipher, unsigned char *plain); | ||||
|  | ||||
| /** | ||||
|   * @brief The SHA256 callback function when do WPS connect.  | ||||
|   * | ||||
|   * @param key  Key for HMAC operations. | ||||
|   * @param key_len  Length of the key in bytes. | ||||
|   * @param num_elem  Number of elements in the data vector. | ||||
|   * @param addr  Pointers to the data areas. | ||||
|   * @param len  Lengths of the data blocks. | ||||
|   * @param mac  Buffer for the hash (32 bytes). | ||||
|   * | ||||
|   */ | ||||
| typedef int (*esp_hmac_sha256_vector_t)(const unsigned char *key, int key_len, int num_elem, | ||||
| 			                   const unsigned char *addr[], const int *len, unsigned char *mac); | ||||
|  | ||||
| /** | ||||
|   * @brief The AES callback function when do STA connect. | ||||
|   * | ||||
|   * @param key  Key for PRF. | ||||
|   * @param key_len  Length of the key in bytes. | ||||
|   * @param label  A unique label for each purpose of the PRF. | ||||
|   * @param data  Extra data to bind into the key. | ||||
|   * @param data_len  Length of the data. | ||||
|   * @param buf  Buffer for the generated pseudo-random key.   | ||||
|   * @param buf_len  Number of bytes of key to generate. | ||||
|   * | ||||
|   */ | ||||
| typedef int (*esp_sha256_prf_t)(const unsigned char *key, int key_len, const char *label, | ||||
| 	                           const unsigned char *data, int data_len, unsigned char *buf, int buf_len); | ||||
|  | ||||
| /** | ||||
|  * @brief HMAC-MD5 over data buffer (RFC 2104)' | ||||
|  *  | ||||
|  * @key: Key for HMAC operations | ||||
|  * @key_len: Length of the key in bytes | ||||
|  * @data: Pointers to the data area | ||||
|  * @data_len: Length of the data area | ||||
|  * @mac: Buffer for the hash (16 bytes) | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  */ | ||||
| typedef int (*esp_hmac_md5_t)(const unsigned char *key, unsigned int key_len, const unsigned char *data,  | ||||
|                               unsigned int data_len, unsigned char *mac); | ||||
|  | ||||
| /** | ||||
|  * @brief HMAC-MD5 over data vector (RFC 2104) | ||||
|  *  | ||||
|  * @key: Key for HMAC operations | ||||
|  * @key_len: Length of the key in bytes | ||||
|  * @num_elem: Number of elements in the data vector | ||||
|  * @addr: Pointers to the data areas | ||||
|  * @len: Lengths of the data blocks | ||||
|  * @mac: Buffer for the hash (16 bytes) | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  */ | ||||
| typedef int (*esp_hmac_md5_vector_t)(const unsigned char *key, unsigned int key_len, unsigned int num_elem, | ||||
|                               const unsigned char *addr[], const unsigned int *len, unsigned char *mac); | ||||
|  | ||||
| /** | ||||
|  * @brief HMAC-SHA1 over data buffer (RFC 2104) | ||||
|  *  | ||||
|  * @key: Key for HMAC operations | ||||
|  * @key_len: Length of the key in bytes | ||||
|  * @data: Pointers to the data area | ||||
|  * @data_len: Length of the data area | ||||
|  * @mac: Buffer for the hash (20 bytes) | ||||
|  * Returns: 0 on success, -1 of failure | ||||
|  */ | ||||
| typedef int (*esp_hmac_sha1_t)(const unsigned char *key, unsigned int key_len, const unsigned char *data,  | ||||
|                               unsigned int data_len, unsigned char *mac); | ||||
|  | ||||
| /** | ||||
|  * @brief HMAC-SHA1 over data vector (RFC 2104) | ||||
|  *  | ||||
|  * @key: Key for HMAC operations | ||||
|  * @key_len: Length of the key in bytes | ||||
|  * @num_elem: Number of elements in the data vector | ||||
|  * @addr: Pointers to the data areas | ||||
|  * @len: Lengths of the data blocks | ||||
|  * @mac: Buffer for the hash (20 bytes) | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  */ | ||||
| typedef int (*esp_hmac_sha1_vector_t)(const unsigned char *key, unsigned int key_len, unsigned int num_elem, | ||||
|                               const unsigned char *addr[], const unsigned int *len, unsigned char *mac); | ||||
|  | ||||
| /** | ||||
|  * @brief SHA1-based Pseudo-Random Function (PRF) (IEEE 802.11i, 8.5.1.1) | ||||
|  *  | ||||
|  * @key: Key for PRF | ||||
|  * @key_len: Length of the key in bytes | ||||
|  * @label: A unique label for each purpose of the PRF | ||||
|  * @data: Extra data to bind into the key | ||||
|  * @data_len: Length of the data | ||||
|  * @buf: Buffer for the generated pseudo-random key | ||||
|  * @buf_len: Number of bytes of key to generate | ||||
|  * Returns: 0 on success, -1 of failure | ||||
|  * | ||||
|  * This function is used to derive new, cryptographically separate keys from a | ||||
|  * given key (e.g., PMK in IEEE 802.11i). | ||||
|  */ | ||||
| typedef int (*esp_sha1_prf_t)(const unsigned char *key, unsigned int key_len, const char *label, | ||||
|                               const unsigned char *data, unsigned int data_len, unsigned char *buf, unsigned int buf_len); | ||||
|  | ||||
| /** | ||||
|  * @brief SHA-1 hash for data vector | ||||
|  *  | ||||
|  * @num_elem: Number of elements in the data vector | ||||
|  * @addr: Pointers to the data areas | ||||
|  * @len: Lengths of the data blocks | ||||
|  * @mac: Buffer for the hash | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  */ | ||||
| typedef int (*esp_sha1_vector_t)(unsigned int num_elem, const unsigned char *addr[], const unsigned int *len,  | ||||
|                               unsigned char *mac); | ||||
|  | ||||
| /** | ||||
|  * @brief SHA1-based key derivation function (PBKDF2) for IEEE 802.11i | ||||
|  *  | ||||
|  * @passphrase: ASCII passphrase | ||||
|  * @ssid: SSID | ||||
|  * @ssid_len: SSID length in bytes | ||||
|  * @iterations: Number of iterations to run | ||||
|  * @buf: Buffer for the generated key | ||||
|  * @buflen: Length of the buffer in bytes | ||||
|  * Returns: 0 on success, -1 of failure | ||||
|  * | ||||
|  * This function is used to derive PSK for WPA-PSK. For this protocol, | ||||
|  * iterations is set to 4096 and buflen to 32. This function is described in | ||||
|  * IEEE Std 802.11-2004, Clause H.4. The main construction is from PKCS#5 v2.0. | ||||
|  */ | ||||
| typedef int (*esp_pbkdf2_sha1_t)(const char *passphrase, const char *ssid, unsigned int ssid_len, | ||||
|                               int iterations, unsigned char *buf, unsigned int buflen); | ||||
|  | ||||
| /** | ||||
|  * @brief XOR RC4 stream to given data with skip-stream-start | ||||
|  *  | ||||
|  * @key: RC4 key | ||||
|  * @keylen: RC4 key length | ||||
|  * @skip: number of bytes to skip from the beginning of the RC4 stream | ||||
|  * @data: data to be XOR'ed with RC4 stream | ||||
|  * @data_len: buf length | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  * | ||||
|  * Generate RC4 pseudo random stream for the given key, skip beginning of the | ||||
|  * stream, and XOR the end result with the data buffer to perform RC4 | ||||
|  * encryption/decryption. | ||||
|  */ | ||||
| typedef int (*esp_rc4_skip_t)(const unsigned char *key, unsigned int keylen, unsigned int skip, | ||||
|                               unsigned char *data, unsigned int data_len); | ||||
|  | ||||
| /** | ||||
|  * @brief MD5 hash for data vector | ||||
|  *  | ||||
|  * @num_elem: Number of elements in the data vector | ||||
|  * @addr: Pointers to the data areas | ||||
|  * @len: Lengths of the data blocks | ||||
|  * @mac: Buffer for the hash | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  */ | ||||
| typedef int (*esp_md5_vector_t)(unsigned int num_elem, const unsigned char *addr[], const unsigned int *len, | ||||
|                               unsigned char *mac); | ||||
|  | ||||
| /** | ||||
|  * @brief Encrypt one AES block | ||||
|  *  | ||||
|  * @ctx: Context pointer from aes_encrypt_init() | ||||
|  * @plain: Plaintext data to be encrypted (16 bytes) | ||||
|  * @crypt: Buffer for the encrypted data (16 bytes) | ||||
|  */ | ||||
| typedef void (*esp_aes_encrypt_t)(void *ctx, const unsigned char *plain, unsigned char *crypt); | ||||
|  | ||||
| /** | ||||
|  * @brief Initialize AES for encryption | ||||
|  *  | ||||
|  * @key: Encryption key | ||||
|  * @len: Key length in bytes (usually 16, i.e., 128 bits) | ||||
|  * Returns: Pointer to context data or %NULL on failure | ||||
|  */ | ||||
| typedef void * (*esp_aes_encrypt_init_t)(const unsigned char *key,  unsigned int len); | ||||
|  | ||||
| /** | ||||
|  * @brief Deinitialize AES encryption | ||||
|  *  | ||||
|  * @ctx: Context pointer from aes_encrypt_init() | ||||
|  */ | ||||
| typedef void (*esp_aes_encrypt_deinit_t)(void *ctx); | ||||
|  | ||||
| /** | ||||
|  * @brief Decrypt one AES block | ||||
|  *  | ||||
|  * @ctx: Context pointer from aes_encrypt_init() | ||||
|  * @crypt: Encrypted data (16 bytes) | ||||
|  * @plain: Buffer for the decrypted data (16 bytes) | ||||
|  */ | ||||
| typedef void (*esp_aes_decrypt_t)(void *ctx, const unsigned char *crypt, unsigned char *plain); | ||||
|  | ||||
| /** | ||||
|  * @brief Initialize AES for decryption | ||||
|  *  | ||||
|  * @key: Decryption key | ||||
|  * @len: Key length in bytes (usually 16, i.e., 128 bits) | ||||
|  * Returns: Pointer to context data or %NULL on failure | ||||
|  */ | ||||
| typedef void * (*esp_aes_decrypt_init_t)(const unsigned char *key, unsigned int len); | ||||
|  | ||||
| /** | ||||
|  * @brief Deinitialize AES decryption | ||||
|  *  | ||||
|  * @ctx: Context pointer from aes_encrypt_init() | ||||
|  */ | ||||
| typedef void (*esp_aes_decrypt_deinit_t)(void *ctx); | ||||
|  | ||||
| /** | ||||
|  * @brief One-Key CBC MAC (OMAC1) hash with AES-128 for MIC computation | ||||
|  * | ||||
|  * @key: 128-bit key for the hash operation | ||||
|  * @data: Data buffer for which a MIC is computed | ||||
|  * @data_len: Length of data buffer in bytes | ||||
|  * @mic: Buffer for MIC (128 bits, i.e., 16 bytes) | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  */ | ||||
| typedef int (*esp_omac1_aes_128_t)(const uint8_t *key, const uint8_t *data, size_t data_len, | ||||
|                                    uint8_t *mic); | ||||
|  | ||||
| /** | ||||
|  * @brief Decrypt data using CCMP (Counter Mode CBC-MAC Protocol OR | ||||
|  *        Counter Mode Cipher Block Chaining Message Authentication | ||||
|  *        Code Protocol) which is used in IEEE 802.11i RSN standard. | ||||
|  * @tk: 128-bit Temporal Key for obtained during 4-way handshake | ||||
|  * @hdr: Pointer to IEEE802.11 frame headeri needed for AAD | ||||
|  * @data: Pointer to encrypted data buffer | ||||
|  * @data_len: Encrypted data length in bytes | ||||
|  * @decrypted_len: Length of decrypted data | ||||
|  * Returns: Pointer to decrypted data on success, NULL on failure | ||||
|  */ | ||||
| typedef uint8_t * (*esp_ccmp_decrypt_t)(const uint8_t *tk, const uint8_t *ieee80211_hdr, | ||||
|                                         const uint8_t *data, size_t data_len, size_t *decrypted_len); | ||||
|  | ||||
| /** | ||||
|  * @brief Encrypt data using CCMP (Counter Mode CBC-MAC Protocol OR | ||||
|  *        Counter Mode Cipher Block Chaining Message Authentication | ||||
|  *        Code Protocol) which is used in IEEE 802.11i RSN standard. | ||||
|  * @tk: 128-bit Temporal Key for obtained during 4-way handshake | ||||
|  * @frame: Pointer to IEEE802.11 frame including header | ||||
|  * @len: Length of the frame including header | ||||
|  * @hdrlen: Length of the header | ||||
|  * @pn: Packet Number counter | ||||
|  * @keyid: Key ID to be mentioned in CCMP Vector | ||||
|  * @encrypted_len: Length of the encrypted frame including header | ||||
|  */ | ||||
| typedef uint8_t * (*esp_ccmp_encrypt_t)(const uint8_t *tk, uint8_t *frame, size_t len, size_t hdrlen, | ||||
|                                         uint8_t *pn, int keyid, size_t *encrypted_len); | ||||
|  | ||||
| /** | ||||
|   * @brief The crypto callback function structure used when do station security connect. | ||||
|   *        The structure can be set as software crypto or the crypto optimized by ESP32 | ||||
|   *        hardware. | ||||
|   */ | ||||
| typedef struct { | ||||
|     uint32_t size; | ||||
|     uint32_t version; | ||||
|     esp_aes_wrap_t aes_wrap;                         /**< station connect function used when send EAPOL frame */ | ||||
|     esp_aes_unwrap_t aes_unwrap;                     /**< station connect function used when decrypt key data */ | ||||
|     esp_hmac_sha256_vector_t hmac_sha256_vector;     /**< station connect function used when check MIC */ | ||||
|     esp_sha256_prf_t sha256_prf;                     /**< station connect function used when check MIC */ | ||||
|     esp_hmac_md5_t hmac_md5; | ||||
|     esp_hmac_md5_vector_t hamc_md5_vector; | ||||
|     esp_hmac_sha1_t hmac_sha1; | ||||
|     esp_hmac_sha1_vector_t hmac_sha1_vector; | ||||
|     esp_sha1_prf_t sha1_prf; | ||||
|     esp_sha1_vector_t sha1_vector; | ||||
|     esp_pbkdf2_sha1_t pbkdf2_sha1; | ||||
|     esp_rc4_skip_t rc4_skip; | ||||
|     esp_md5_vector_t md5_vector; | ||||
|     esp_aes_encrypt_t aes_encrypt; | ||||
|     esp_aes_encrypt_init_t aes_encrypt_init; | ||||
|     esp_aes_encrypt_deinit_t aes_encrypt_deinit; | ||||
|     esp_aes_decrypt_t aes_decrypt; | ||||
|     esp_aes_decrypt_init_t aes_decrypt_init; | ||||
|     esp_aes_decrypt_deinit_t aes_decrypt_deinit; | ||||
|     esp_omac1_aes_128_t omac1_aes_128; | ||||
|     esp_ccmp_decrypt_t ccmp_decrypt; | ||||
|     esp_ccmp_encrypt_t ccmp_encrypt; | ||||
| }wpa_crypto_funcs_t; | ||||
|  | ||||
| /** | ||||
|   * @brief The crypto callback function structure used in mesh vendor IE encryption. The | ||||
|   *        structure can be set as software crypto or the crypto optimized by ESP32 | ||||
|   *        hardware. | ||||
|   */ | ||||
| typedef struct{ | ||||
|     esp_aes_128_encrypt_t aes_128_encrypt;          /**< function used in mesh vendor IE encryption */ | ||||
|     esp_aes_128_decrypt_t aes_128_decrypt;          /**< function used in mesh vendor IE decryption */ | ||||
| } mesh_crypto_funcs_t; | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| #endif | ||||
							
								
								
									
										118
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_wifi_default.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										118
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_wifi_default.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,118 @@ | ||||
| // Copyright 2019 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
|  | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef _ESP_WIFI_DEFAULT_H | ||||
| #define _ESP_WIFI_DEFAULT_H | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief Attaches wifi station interface to supplied netif | ||||
|  * | ||||
|  * @param esp_netif instance to attach the wifi station to | ||||
|  * | ||||
|  * @return | ||||
|  *  - ESP_OK on success | ||||
|  *  - ESP_FAIL if attach failed | ||||
|  */ | ||||
| esp_err_t esp_netif_attach_wifi_station(esp_netif_t *esp_netif); | ||||
|  | ||||
| /** | ||||
|  * @brief Attaches wifi soft AP interface to supplied netif | ||||
|  * | ||||
|  * @param esp_netif instance to attach the wifi AP to | ||||
|  * | ||||
|  * @return | ||||
|  *  - ESP_OK on success | ||||
|  *  - ESP_FAIL if attach failed | ||||
|  */ | ||||
| esp_err_t esp_netif_attach_wifi_ap(esp_netif_t *esp_netif); | ||||
|  | ||||
| /** | ||||
|  * @brief Sets default wifi event handlers for STA interface | ||||
|  * | ||||
|  * @return | ||||
|  *  - ESP_OK on success, error returned from esp_event_handler_register if failed | ||||
|  */ | ||||
| esp_err_t esp_wifi_set_default_wifi_sta_handlers(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Sets default wifi event handlers for STA interface | ||||
|  * | ||||
|  * @return | ||||
|  *  - ESP_OK on success, error returned from esp_event_handler_register if failed | ||||
|  */ | ||||
| esp_err_t esp_wifi_set_default_wifi_ap_handlers(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Clears default wifi event handlers for supplied network interface | ||||
|  * | ||||
|  * @param esp_netif instance of corresponding if object | ||||
|  * | ||||
|  * @return | ||||
|  *  - ESP_OK on success, error returned from esp_event_handler_register if failed | ||||
|  */ | ||||
| esp_err_t esp_wifi_clear_default_wifi_driver_and_handlers(void *esp_netif); | ||||
|  | ||||
| /** | ||||
|  * @brief Creates default WIFI AP. In case of any init error this API aborts. | ||||
|  * | ||||
|  * @return pointer to esp-netif instance | ||||
|  */ | ||||
| esp_netif_t* esp_netif_create_default_wifi_ap(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Creates default WIFI STA. In case of any init error this API aborts. | ||||
|  * | ||||
|  * @return pointer to esp-netif instance | ||||
|  */ | ||||
| esp_netif_t* esp_netif_create_default_wifi_sta(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Creates esp_netif WiFi object based on the custom configuration. | ||||
|  * | ||||
|  * @attention This API DOES NOT register default handlers! | ||||
|  * | ||||
|  * @param[in] wifi_if type of wifi interface | ||||
|  * @param[in] esp_netif_config inherent esp-netif configuration pointer | ||||
|  * | ||||
|  * @return pointer to esp-netif instance | ||||
|  */ | ||||
| esp_netif_t* esp_netif_create_wifi(wifi_interface_t wifi_if, esp_netif_inherent_config_t *esp_netif_config); | ||||
|  | ||||
| /** | ||||
|  * @brief Creates default STA and AP network interfaces for esp-mesh. | ||||
|  * | ||||
|  * Both netifs are almost identical to the default station and softAP, but with | ||||
|  * DHCP client and server disabled. Please note that the DHCP client is typically | ||||
|  * enabled only if the device is promoted to a root node. | ||||
|  * | ||||
|  * Returns created interfaces which could be ignored setting parameters to NULL | ||||
|  * if an application code does not need to save the interface instances | ||||
|  * for further processing. | ||||
|  * | ||||
|  * @param[out] p_netif_sta pointer where the resultant STA interface is saved (if non NULL) | ||||
|  * @param[out] p_netif_ap pointer where the resultant AP interface is saved (if non NULL) | ||||
|  * | ||||
|  * @return ESP_OK on success | ||||
|  */ | ||||
| esp_err_t esp_netif_create_default_wifi_mesh_netifs(esp_netif_t **p_netif_sta, esp_netif_t **p_netif_ap); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif //_ESP_WIFI_DEFAULT_H | ||||
							
								
								
									
										91
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_wifi_netif.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_wifi_netif.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | ||||
| // Copyright 2019 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
|  | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef _ESP_WIFI_NETIF_H | ||||
| #define _ESP_WIFI_NETIF_H | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief Number of WiFi interfaces used by wifi-netif abstraction | ||||
|  */ | ||||
| #define MAX_WIFI_IFS (2) | ||||
|  | ||||
| /** | ||||
|  * @brief Forward declaration of WiFi interface handle | ||||
|  */ | ||||
| typedef struct wifi_netif_driver* wifi_netif_driver_t; | ||||
|  | ||||
| /** | ||||
|  * @brief Creates wifi driver instance to be used with esp-netif | ||||
|  * | ||||
|  * @param wifi_if wifi interface type (station, softAP) | ||||
|  * | ||||
|  * @return | ||||
|  *  - pointer to wifi interface handle on success | ||||
|  *  - NULL otherwise | ||||
|  */ | ||||
| wifi_netif_driver_t esp_wifi_create_if_driver(wifi_interface_t wifi_if); | ||||
|  | ||||
| /** | ||||
|  * @brief Destroys wifi driver instance | ||||
|  * | ||||
|  * @param h pointer to wifi interface handle | ||||
|  * | ||||
|  */ | ||||
| void esp_wifi_destroy_if_driver(wifi_netif_driver_t h); | ||||
|  | ||||
| /** | ||||
|  * @brief Return mac of specified wifi driver instance | ||||
|  * | ||||
|  * @param[in] ifx pointer to wifi interface handle | ||||
|  * @param[out] mac output mac address | ||||
|  * | ||||
|  * @return ESP_OK on success | ||||
|  * | ||||
|  */ | ||||
| esp_err_t esp_wifi_get_if_mac(wifi_netif_driver_t ifx, uint8_t mac[6]); | ||||
|  | ||||
| /** | ||||
|  * @brief Return true if the supplied interface instance is ready after start. | ||||
|  * Typically used when registering on receive callback, which ought to be | ||||
|  * installed as soon as AP started, but once STA gets connected. | ||||
|  * | ||||
|  * @param[in] ifx pointer to wifi interface handle | ||||
|  * | ||||
|  * @return | ||||
|  *      - true if ready after intertace started (typically Access Point type) | ||||
|  *      - false if ready once intertace connected (typically for Station type) | ||||
|  */ | ||||
| bool esp_wifi_is_if_ready_when_started(wifi_netif_driver_t ifx); | ||||
|  | ||||
| /** | ||||
|  * @brief Register interface receive callback function with argument | ||||
|  * | ||||
|  * @param[in] ifx pointer to wifi interface handle | ||||
|  * @param[in] fn  funtion to be registered (typically esp_netif_receive) | ||||
|  * @param[in] arg argument to be supplied to registered function (typically esp_netif ptr) | ||||
|  * | ||||
|  * @return ESP_OK on success | ||||
|  * | ||||
|  */ | ||||
| esp_err_t esp_wifi_register_if_rxcb(wifi_netif_driver_t ifx, esp_netif_receive_t fn, void * arg); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif //_ESP_WIFI_NETIF_H | ||||
							
								
								
									
										604
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_wifi_types.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										604
									
								
								tools/sdk/esp32/include/esp_wifi/include/esp_wifi_types.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,604 @@ | ||||
| // Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
|  | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
|  | ||||
| #ifndef __ESP_WIFI_TYPES_H__ | ||||
| #define __ESP_WIFI_TYPES_H__ | ||||
|  | ||||
| #include "esp_private/esp_wifi_types_private.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_MODE_NULL = 0,  /**< null mode */ | ||||
|     WIFI_MODE_STA,       /**< WiFi station mode */ | ||||
|     WIFI_MODE_AP,        /**< WiFi soft-AP mode */ | ||||
|     WIFI_MODE_APSTA,     /**< WiFi station + soft-AP mode */ | ||||
|     WIFI_MODE_MAX | ||||
| } wifi_mode_t; | ||||
|  | ||||
| typedef esp_interface_t wifi_interface_t; | ||||
|  | ||||
| #define WIFI_IF_STA ESP_IF_WIFI_STA | ||||
| #define WIFI_IF_AP  ESP_IF_WIFI_AP | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_COUNTRY_POLICY_AUTO,   /**< Country policy is auto, use the country info of AP to which the station is connected */ | ||||
|     WIFI_COUNTRY_POLICY_MANUAL, /**< Country policy is manual, always use the configured country info */ | ||||
| } wifi_country_policy_t; | ||||
|  | ||||
| /** @brief Structure describing WiFi country-based regional restrictions. */ | ||||
| typedef struct { | ||||
|     char                  cc[3];   /**< country code string */ | ||||
|     uint8_t               schan;   /**< start channel */ | ||||
|     uint8_t               nchan;   /**< total channel number */ | ||||
|     int8_t                max_tx_power;   /**< This field is used for getting WiFi maximum transmitting power, call esp_wifi_set_max_tx_power to set the maximum transmitting power. */ | ||||
|     wifi_country_policy_t policy;  /**< country policy */ | ||||
| } wifi_country_t; | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_AUTH_OPEN = 0,         /**< authenticate mode : open */ | ||||
|     WIFI_AUTH_WEP,              /**< authenticate mode : WEP */ | ||||
|     WIFI_AUTH_WPA_PSK,          /**< authenticate mode : WPA_PSK */ | ||||
|     WIFI_AUTH_WPA2_PSK,         /**< authenticate mode : WPA2_PSK */ | ||||
|     WIFI_AUTH_WPA_WPA2_PSK,     /**< authenticate mode : WPA_WPA2_PSK */ | ||||
|     WIFI_AUTH_WPA2_ENTERPRISE,  /**< authenticate mode : WPA2_ENTERPRISE */ | ||||
|     WIFI_AUTH_WPA3_PSK,         /**< authenticate mode : WPA3_PSK */ | ||||
|     WIFI_AUTH_MAX | ||||
| } wifi_auth_mode_t; | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_REASON_UNSPECIFIED              = 1, | ||||
|     WIFI_REASON_AUTH_EXPIRE              = 2, | ||||
|     WIFI_REASON_AUTH_LEAVE               = 3, | ||||
|     WIFI_REASON_ASSOC_EXPIRE             = 4, | ||||
|     WIFI_REASON_ASSOC_TOOMANY            = 5, | ||||
|     WIFI_REASON_NOT_AUTHED               = 6, | ||||
|     WIFI_REASON_NOT_ASSOCED              = 7, | ||||
|     WIFI_REASON_ASSOC_LEAVE              = 8, | ||||
|     WIFI_REASON_ASSOC_NOT_AUTHED         = 9, | ||||
|     WIFI_REASON_DISASSOC_PWRCAP_BAD      = 10, | ||||
|     WIFI_REASON_DISASSOC_SUPCHAN_BAD     = 11, | ||||
|     WIFI_REASON_IE_INVALID               = 13, | ||||
|     WIFI_REASON_MIC_FAILURE              = 14, | ||||
|     WIFI_REASON_4WAY_HANDSHAKE_TIMEOUT   = 15, | ||||
|     WIFI_REASON_GROUP_KEY_UPDATE_TIMEOUT = 16, | ||||
|     WIFI_REASON_IE_IN_4WAY_DIFFERS       = 17, | ||||
|     WIFI_REASON_GROUP_CIPHER_INVALID     = 18, | ||||
|     WIFI_REASON_PAIRWISE_CIPHER_INVALID  = 19, | ||||
|     WIFI_REASON_AKMP_INVALID             = 20, | ||||
|     WIFI_REASON_UNSUPP_RSN_IE_VERSION    = 21, | ||||
|     WIFI_REASON_INVALID_RSN_IE_CAP       = 22, | ||||
|     WIFI_REASON_802_1X_AUTH_FAILED       = 23, | ||||
|     WIFI_REASON_CIPHER_SUITE_REJECTED    = 24, | ||||
|  | ||||
|     WIFI_REASON_INVALID_PMKID            = 53, | ||||
|  | ||||
|     WIFI_REASON_BEACON_TIMEOUT           = 200, | ||||
|     WIFI_REASON_NO_AP_FOUND              = 201, | ||||
|     WIFI_REASON_AUTH_FAIL                = 202, | ||||
|     WIFI_REASON_ASSOC_FAIL               = 203, | ||||
|     WIFI_REASON_HANDSHAKE_TIMEOUT        = 204, | ||||
|     WIFI_REASON_CONNECTION_FAIL          = 205, | ||||
| } wifi_err_reason_t; | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_SECOND_CHAN_NONE = 0,  /**< the channel width is HT20 */ | ||||
|     WIFI_SECOND_CHAN_ABOVE,     /**< the channel width is HT40 and the secondary channel is above the primary channel */ | ||||
|     WIFI_SECOND_CHAN_BELOW,     /**< the channel width is HT40 and the secondary channel is below the primary channel */ | ||||
| } wifi_second_chan_t; | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_SCAN_TYPE_ACTIVE = 0,  /**< active scan */ | ||||
|     WIFI_SCAN_TYPE_PASSIVE,     /**< passive scan */ | ||||
| } wifi_scan_type_t; | ||||
|  | ||||
| /** @brief Range of active scan times per channel */ | ||||
| typedef struct { | ||||
|     uint32_t min;  /**< minimum active scan time per channel, units: millisecond */ | ||||
|     uint32_t max;  /**< maximum active scan time per channel, units: millisecond, values above 1500ms may | ||||
|                                           cause station to disconnect from AP and are not recommended.  */ | ||||
| } wifi_active_scan_time_t; | ||||
|  | ||||
| /** @brief Aggregate of active & passive scan time per channel */ | ||||
| typedef struct { | ||||
|     wifi_active_scan_time_t active;  /**< active scan time per channel, units: millisecond. */ | ||||
|     uint32_t passive;                /**< passive scan time per channel, units: millisecond, values above 1500ms may | ||||
|                                           cause station to disconnect from AP and are not recommended. */ | ||||
| } wifi_scan_time_t; | ||||
|  | ||||
| /** @brief Parameters for an SSID scan. */ | ||||
| typedef struct { | ||||
|     uint8_t *ssid;               /**< SSID of AP */ | ||||
|     uint8_t *bssid;              /**< MAC address of AP */ | ||||
|     uint8_t channel;             /**< channel, scan the specific channel */ | ||||
|     bool show_hidden;            /**< enable to scan AP whose SSID is hidden */ | ||||
|     wifi_scan_type_t scan_type;  /**< scan type, active or passive */ | ||||
|     wifi_scan_time_t scan_time;  /**< scan time per channel */ | ||||
| } wifi_scan_config_t; | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_CIPHER_TYPE_NONE = 0,   /**< the cipher type is none */ | ||||
|     WIFI_CIPHER_TYPE_WEP40,      /**< the cipher type is WEP40 */ | ||||
|     WIFI_CIPHER_TYPE_WEP104,     /**< the cipher type is WEP104 */ | ||||
|     WIFI_CIPHER_TYPE_TKIP,       /**< the cipher type is TKIP */ | ||||
|     WIFI_CIPHER_TYPE_CCMP,       /**< the cipher type is CCMP */ | ||||
|     WIFI_CIPHER_TYPE_TKIP_CCMP,  /**< the cipher type is TKIP and CCMP */ | ||||
|     WIFI_CIPHER_TYPE_AES_CMAC128,/**< the cipher type is AES-CMAC-128 */ | ||||
|     WIFI_CIPHER_TYPE_UNKNOWN,    /**< the cipher type is unknown */ | ||||
| } wifi_cipher_type_t; | ||||
|  | ||||
| /** | ||||
|   * @brief WiFi antenna | ||||
|   * | ||||
|   */ | ||||
| typedef enum { | ||||
|     WIFI_ANT_ANT0,          /**< WiFi antenna 0 */ | ||||
|     WIFI_ANT_ANT1,          /**< WiFi antenna 1 */ | ||||
|     WIFI_ANT_MAX,           /**< Invalid WiFi antenna */ | ||||
| } wifi_ant_t; | ||||
|  | ||||
| /** @brief Description of a WiFi AP */ | ||||
| typedef struct { | ||||
|     uint8_t bssid[6];                     /**< MAC address of AP */ | ||||
|     uint8_t ssid[33];                     /**< SSID of AP */ | ||||
|     uint8_t primary;                      /**< channel of AP */ | ||||
|     wifi_second_chan_t second;            /**< secondary channel of AP */ | ||||
|     int8_t  rssi;                         /**< signal strength of AP */ | ||||
|     wifi_auth_mode_t authmode;            /**< authmode of AP */ | ||||
|     wifi_cipher_type_t pairwise_cipher;   /**< pairwise cipher of AP */ | ||||
|     wifi_cipher_type_t group_cipher;      /**< group cipher of AP */ | ||||
|     wifi_ant_t ant;                       /**< antenna used to receive beacon from AP */ | ||||
|     uint32_t phy_11b:1;                   /**< bit: 0 flag to identify if 11b mode is enabled or not */ | ||||
|     uint32_t phy_11g:1;                   /**< bit: 1 flag to identify if 11g mode is enabled or not */ | ||||
|     uint32_t phy_11n:1;                   /**< bit: 2 flag to identify if 11n mode is enabled or not */ | ||||
|     uint32_t phy_lr:1;                    /**< bit: 3 flag to identify if low rate is enabled or not */ | ||||
|     uint32_t wps:1;                       /**< bit: 4 flag to identify if WPS is supported or not */ | ||||
|     uint32_t reserved:27;                 /**< bit: 5..31 reserved */ | ||||
|     wifi_country_t country;               /**< country information of AP */ | ||||
| } wifi_ap_record_t; | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_FAST_SCAN = 0,                   /**< Do fast scan, scan will end after find SSID match AP */ | ||||
|     WIFI_ALL_CHANNEL_SCAN,                /**< All channel scan, scan will end after scan all the channel */ | ||||
| }wifi_scan_method_t; | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_CONNECT_AP_BY_SIGNAL = 0,        /**< Sort match AP in scan list by RSSI */ | ||||
|     WIFI_CONNECT_AP_BY_SECURITY,          /**< Sort match AP in scan list by security mode */ | ||||
| }wifi_sort_method_t; | ||||
|  | ||||
| /** @brief Structure describing parameters for a WiFi fast scan */ | ||||
| typedef struct { | ||||
|     int8_t              rssi;             /**< The minimum rssi to accept in the fast scan mode */ | ||||
|     wifi_auth_mode_t    authmode;         /**< The weakest authmode to accept in the fast scan mode */ | ||||
| }wifi_scan_threshold_t; | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_PS_NONE,        /**< No power save */ | ||||
|     WIFI_PS_MIN_MODEM,   /**< Minimum modem power saving. In this mode, station wakes up to receive beacon every DTIM period */ | ||||
|     WIFI_PS_MAX_MODEM,   /**< Maximum modem power saving. In this mode, interval to receive beacons is determined by the listen_interval parameter in wifi_sta_config_t */ | ||||
| } wifi_ps_type_t; | ||||
|  | ||||
| #define WIFI_PROTOCOL_11B         1 | ||||
| #define WIFI_PROTOCOL_11G         2 | ||||
| #define WIFI_PROTOCOL_11N         4 | ||||
| #define WIFI_PROTOCOL_LR          8 | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_BW_HT20 = 1, /* Bandwidth is HT20 */ | ||||
|     WIFI_BW_HT40,     /* Bandwidth is HT40 */ | ||||
| } wifi_bandwidth_t; | ||||
|  | ||||
| /** Configuration structure for Protected Management Frame */ | ||||
| typedef struct { | ||||
|     bool capable;            /**< Advertizes support for Protected Management Frame. Device will prefer to connect in PMF mode if other device also advertizes PMF capability. */ | ||||
|     bool required;           /**< Advertizes that Protected Management Frame is required. Device will not associate to non-PMF capable devices. */ | ||||
| } wifi_pmf_config_t; | ||||
|  | ||||
| /** @brief Soft-AP configuration settings for the ESP32 */ | ||||
| typedef struct { | ||||
|     uint8_t ssid[32];           /**< SSID of ESP32 soft-AP. If ssid_len field is 0, this must be a Null terminated string. Otherwise, length is set according to ssid_len. */ | ||||
|     uint8_t password[64];       /**< Password of ESP32 soft-AP. Null terminated string. */ | ||||
|     uint8_t ssid_len;           /**< Optional length of SSID field. */ | ||||
|     uint8_t channel;            /**< Channel of ESP32 soft-AP */ | ||||
|     wifi_auth_mode_t authmode;  /**< Auth mode of ESP32 soft-AP. Do not support AUTH_WEP in soft-AP mode */ | ||||
|     uint8_t ssid_hidden;        /**< Broadcast SSID or not, default 0, broadcast the SSID */ | ||||
|     uint8_t max_connection;     /**< Max number of stations allowed to connect in, default 4, max 10 */ | ||||
|     uint16_t beacon_interval;   /**< Beacon interval, 100 ~ 60000 ms, default 100 ms */ | ||||
| } wifi_ap_config_t; | ||||
|  | ||||
| /** @brief STA configuration settings for the ESP32 */ | ||||
| typedef struct { | ||||
|     uint8_t ssid[32];      /**< SSID of target AP. Null terminated string. */ | ||||
|     uint8_t password[64];  /**< Password of target AP. Null terminated string.*/ | ||||
|     wifi_scan_method_t scan_method;    /**< do all channel scan or fast scan */ | ||||
|     bool bssid_set;        /**< whether set MAC address of target AP or not. Generally, station_config.bssid_set needs to be 0; and it needs to be 1 only when users need to check the MAC address of the AP.*/ | ||||
|     uint8_t bssid[6];     /**< MAC address of target AP*/ | ||||
|     uint8_t channel;       /**< channel of target AP. Set to 1~13 to scan starting from the specified channel before connecting to AP. If the channel of AP is unknown, set it to 0.*/ | ||||
|     uint16_t listen_interval;   /**< Listen interval for ESP32 station to receive beacon when WIFI_PS_MAX_MODEM is set. Units: AP beacon intervals. Defaults to 3 if set to 0. */ | ||||
|     wifi_sort_method_t sort_method;    /**< sort the connect AP in the list by rssi or security mode */ | ||||
|     wifi_scan_threshold_t  threshold;     /**< When sort_method is set, only APs which have an auth mode that is more secure than the selected auth mode and a signal stronger than the minimum RSSI will be used. */ | ||||
|     wifi_pmf_config_t pmf_cfg;    /**< Configuration for Protected Management Frame. Will be advertized in RSN Capabilities in RSN IE. */ | ||||
| } wifi_sta_config_t; | ||||
|  | ||||
| /** @brief Configuration data for ESP32 AP or STA. | ||||
|  * | ||||
|  * The usage of this union (for ap or sta configuration) is determined by the accompanying | ||||
|  * interface argument passed to esp_wifi_set_config() or esp_wifi_get_config() | ||||
|  * | ||||
|  */ | ||||
| typedef union { | ||||
|     wifi_ap_config_t  ap;  /**< configuration of AP */ | ||||
|     wifi_sta_config_t sta; /**< configuration of STA */ | ||||
| } wifi_config_t; | ||||
|  | ||||
| /** @brief Description of STA associated with AP */ | ||||
| typedef struct { | ||||
|     uint8_t mac[6];  /**< mac address */ | ||||
|     int8_t  rssi;    /**< current average rssi of sta connected */ | ||||
|     uint32_t phy_11b:1;      /**< bit: 0 flag to identify if 11b mode is enabled or not */ | ||||
|     uint32_t phy_11g:1;      /**< bit: 1 flag to identify if 11g mode is enabled or not */ | ||||
|     uint32_t phy_11n:1;      /**< bit: 2 flag to identify if 11n mode is enabled or not */ | ||||
|     uint32_t phy_lr:1;       /**< bit: 3 flag to identify if low rate is enabled or not */ | ||||
|     uint32_t reserved:28;    /**< bit: 4..31 reserved */ | ||||
| } wifi_sta_info_t; | ||||
|  | ||||
| #define ESP_WIFI_MAX_CONN_NUM  (10)       /**< max number of stations which can connect to ESP32 soft-AP */ | ||||
|  | ||||
| /** @brief List of stations associated with the ESP32 Soft-AP */ | ||||
| typedef struct { | ||||
|     wifi_sta_info_t sta[ESP_WIFI_MAX_CONN_NUM]; /**< station list */ | ||||
|     int       num; /**< number of stations in the list (other entries are invalid) */ | ||||
| } wifi_sta_list_t; | ||||
|  | ||||
| typedef enum { | ||||
|     WIFI_STORAGE_FLASH,  /**< all configuration will store in both memory and flash */ | ||||
|     WIFI_STORAGE_RAM,    /**< all configuration will only store in the memory */ | ||||
| } wifi_storage_t; | ||||
|  | ||||
| /** | ||||
|   * @brief     Vendor Information Element type | ||||
|   * | ||||
|   * Determines the frame type that the IE will be associated with. | ||||
|   */ | ||||
| typedef enum { | ||||
|     WIFI_VND_IE_TYPE_BEACON, | ||||
|     WIFI_VND_IE_TYPE_PROBE_REQ, | ||||
|     WIFI_VND_IE_TYPE_PROBE_RESP, | ||||
|     WIFI_VND_IE_TYPE_ASSOC_REQ, | ||||
|     WIFI_VND_IE_TYPE_ASSOC_RESP, | ||||
| } wifi_vendor_ie_type_t; | ||||
|  | ||||
| /** | ||||
|   * @brief     Vendor Information Element index | ||||
|   * | ||||
|   * Each IE type can have up to two associated vendor ID elements. | ||||
|   */ | ||||
| typedef enum { | ||||
|     WIFI_VND_IE_ID_0, | ||||
|     WIFI_VND_IE_ID_1, | ||||
| } wifi_vendor_ie_id_t; | ||||
|  | ||||
| #define WIFI_VENDOR_IE_ELEMENT_ID 0xDD | ||||
|  | ||||
| /** | ||||
|  * @brief Vendor Information Element header | ||||
|  * | ||||
|  * The first bytes of the Information Element will match this header. Payload follows. | ||||
|  */ | ||||
| typedef struct { | ||||
|     uint8_t element_id;      /**< Should be set to WIFI_VENDOR_IE_ELEMENT_ID (0xDD) */ | ||||
|     uint8_t length;          /**< Length of all bytes in the element data following this field. Minimum 4. */ | ||||
|     uint8_t vendor_oui[3];   /**< Vendor identifier (OUI). */ | ||||
|     uint8_t vendor_oui_type; /**< Vendor-specific OUI type. */ | ||||
|     uint8_t payload[0];      /**< Payload. Length is equal to value in 'length' field, minus 4. */ | ||||
| } vendor_ie_data_t; | ||||
|  | ||||
| /** @brief Received packet radio metadata header, this is the common header at the beginning of all promiscuous mode RX callback buffers */ | ||||
| typedef struct { | ||||
|     signed rssi:8;                /**< Received Signal Strength Indicator(RSSI) of packet. unit: dBm */ | ||||
|     unsigned rate:5;              /**< PHY rate encoding of the packet. Only valid for non HT(11bg) packet */ | ||||
|     unsigned :1;                  /**< reserved */ | ||||
|     unsigned sig_mode:2;          /**< 0: non HT(11bg) packet; 1: HT(11n) packet; 3: VHT(11ac) packet */ | ||||
|     unsigned :16;                 /**< reserved */ | ||||
|     unsigned mcs:7;               /**< Modulation Coding Scheme. If is HT(11n) packet, shows the modulation, range from 0 to 76(MSC0 ~ MCS76) */ | ||||
|     unsigned cwb:1;               /**< Channel Bandwidth of the packet. 0: 20MHz; 1: 40MHz */ | ||||
|     unsigned :16;                 /**< reserved */ | ||||
|     unsigned smoothing:1;         /**< reserved */ | ||||
|     unsigned not_sounding:1;      /**< reserved */ | ||||
|     unsigned :1;                  /**< reserved */ | ||||
|     unsigned aggregation:1;       /**< Aggregation. 0: MPDU packet; 1: AMPDU packet */ | ||||
|     unsigned stbc:2;              /**< Space Time Block Code(STBC). 0: non STBC packet; 1: STBC packet */ | ||||
|     unsigned fec_coding:1;        /**< Flag is set for 11n packets which are LDPC */ | ||||
|     unsigned sgi:1;               /**< Short Guide Interval(SGI). 0: Long GI; 1: Short GI */ | ||||
| #if CONFIG_IDF_TARGET_ESP32 | ||||
|     signed noise_floor:8;         /**< noise floor of Radio Frequency Module(RF). unit: 0.25dBm*/ | ||||
| #elif CONFIG_IDF_TARGET_ESP32S2 | ||||
|     unsigned :8;                  /**< reserved */ | ||||
| #endif | ||||
|     unsigned ampdu_cnt:8;         /**< ampdu cnt */ | ||||
|     unsigned channel:4;           /**< primary channel on which this packet is received */ | ||||
|     unsigned secondary_channel:4; /**< secondary channel on which this packet is received. 0: none; 1: above; 2: below */ | ||||
|     unsigned :8;                  /**< reserved */ | ||||
|     unsigned timestamp:32;        /**< timestamp. The local time when this packet is received. It is precise only if modem sleep or light sleep is not enabled. unit: microsecond */ | ||||
|     unsigned :32;                 /**< reserved */ | ||||
| #if CONFIG_IDF_TARGET_ESP32S2 | ||||
|     unsigned :32;                 /**< reserved */ | ||||
| #endif | ||||
|     unsigned :31;                 /**< reserved */ | ||||
|     unsigned ant:1;               /**< antenna number from which this packet is received. 0: WiFi antenna 0; 1: WiFi antenna 1 */ | ||||
| #if CONFIG_IDF_TARGET_ESP32S2 | ||||
|     signed noise_floor:8;         /**< noise floor of Radio Frequency Module(RF). unit: 0.25dBm*/ | ||||
|     unsigned :24;                 /**< reserved */ | ||||
| #endif | ||||
|     unsigned sig_len:12;          /**< length of packet including Frame Check Sequence(FCS) */ | ||||
|     unsigned :12;                 /**< reserved */ | ||||
|     unsigned rx_state:8;          /**< state of the packet. 0: no error; others: error numbers which are not public */ | ||||
| } wifi_pkt_rx_ctrl_t; | ||||
|  | ||||
| /** @brief Payload passed to 'buf' parameter of promiscuous mode RX callback. | ||||
|  */ | ||||
| typedef struct { | ||||
|     wifi_pkt_rx_ctrl_t rx_ctrl; /**< metadata header */ | ||||
|     uint8_t payload[0];       /**< Data or management payload. Length of payload is described by rx_ctrl.sig_len. Type of content determined by packet type argument of callback. */ | ||||
| } wifi_promiscuous_pkt_t; | ||||
|  | ||||
| /** | ||||
|   * @brief Promiscuous frame type | ||||
|   * | ||||
|   * Passed to promiscuous mode RX callback to indicate the type of parameter in the buffer. | ||||
|   * | ||||
|   */ | ||||
| typedef enum { | ||||
|     WIFI_PKT_MGMT,  /**< Management frame, indicates 'buf' argument is wifi_promiscuous_pkt_t */ | ||||
|     WIFI_PKT_CTRL,  /**< Control frame, indicates 'buf' argument is wifi_promiscuous_pkt_t */ | ||||
|     WIFI_PKT_DATA,  /**< Data frame, indiciates 'buf' argument is wifi_promiscuous_pkt_t */ | ||||
|     WIFI_PKT_MISC,  /**< Other type, such as MIMO etc. 'buf' argument is wifi_promiscuous_pkt_t but the payload is zero length. */ | ||||
| } wifi_promiscuous_pkt_type_t; | ||||
|  | ||||
|  | ||||
| #define WIFI_PROMIS_FILTER_MASK_ALL         (0xFFFFFFFF)  /**< filter all packets */ | ||||
| #define WIFI_PROMIS_FILTER_MASK_MGMT        (1)           /**< filter the packets with type of WIFI_PKT_MGMT */ | ||||
| #define WIFI_PROMIS_FILTER_MASK_CTRL        (1<<1)        /**< filter the packets with type of WIFI_PKT_CTRL */ | ||||
| #define WIFI_PROMIS_FILTER_MASK_DATA        (1<<2)        /**< filter the packets with type of WIFI_PKT_DATA */ | ||||
| #define WIFI_PROMIS_FILTER_MASK_MISC        (1<<3)        /**< filter the packets with type of WIFI_PKT_MISC */ | ||||
| #define WIFI_PROMIS_FILTER_MASK_DATA_MPDU   (1<<4)        /**< filter the MPDU which is a kind of WIFI_PKT_DATA */ | ||||
| #define WIFI_PROMIS_FILTER_MASK_DATA_AMPDU  (1<<5)        /**< filter the AMPDU which is a kind of WIFI_PKT_DATA */ | ||||
|  | ||||
| #define WIFI_PROMIS_CTRL_FILTER_MASK_ALL         (0xFF800000)  /**< filter all control packets */ | ||||
| #define WIFI_PROMIS_CTRL_FILTER_MASK_WRAPPER     (1<<23)       /**< filter the control packets with subtype of Control Wrapper */ | ||||
| #define WIFI_PROMIS_CTRL_FILTER_MASK_BAR         (1<<24)       /**< filter the control packets with subtype of Block Ack Request */ | ||||
| #define WIFI_PROMIS_CTRL_FILTER_MASK_BA          (1<<25)       /**< filter the control packets with subtype of Block Ack */ | ||||
| #define WIFI_PROMIS_CTRL_FILTER_MASK_PSPOLL      (1<<26)       /**< filter the control packets with subtype of PS-Poll */ | ||||
| #define WIFI_PROMIS_CTRL_FILTER_MASK_RTS         (1<<27)       /**< filter the control packets with subtype of RTS */ | ||||
| #define WIFI_PROMIS_CTRL_FILTER_MASK_CTS         (1<<28)       /**< filter the control packets with subtype of CTS */ | ||||
| #define WIFI_PROMIS_CTRL_FILTER_MASK_ACK         (1<<29)       /**< filter the control packets with subtype of ACK */ | ||||
| #define WIFI_PROMIS_CTRL_FILTER_MASK_CFEND       (1<<30)       /**< filter the control packets with subtype of CF-END */ | ||||
| #define WIFI_PROMIS_CTRL_FILTER_MASK_CFENDACK    (1<<31)       /**< filter the control packets with subtype of CF-END+CF-ACK */ | ||||
|  | ||||
| /** @brief Mask for filtering different packet types in promiscuous mode. */ | ||||
| typedef struct { | ||||
|     uint32_t filter_mask; /**< OR of one or more filter values WIFI_PROMIS_FILTER_* */ | ||||
| } wifi_promiscuous_filter_t; | ||||
|  | ||||
| #define WIFI_EVENT_MASK_ALL                 (0xFFFFFFFF)  /**< mask all WiFi events */ | ||||
| #define WIFI_EVENT_MASK_NONE                (0)           /**< mask none of the WiFi events */ | ||||
| #define WIFI_EVENT_MASK_AP_PROBEREQRECVED   (BIT(0))      /**< mask SYSTEM_EVENT_AP_PROBEREQRECVED event */ | ||||
|  | ||||
| /** | ||||
|   * @brief Channel state information(CSI) configuration type | ||||
|   * | ||||
|   */ | ||||
| typedef struct { | ||||
|     bool lltf_en;           /**< enable to receive legacy long training field(lltf) data. Default enabled */ | ||||
|     bool htltf_en;          /**< enable to receive HT long training field(htltf) data. Default enabled */ | ||||
|     bool stbc_htltf2_en;    /**< enable to receive space time block code HT long training field(stbc-htltf2) data. Default enabled */ | ||||
|     bool ltf_merge_en;      /**< enable to generate htlft data by averaging lltf and ht_ltf data when receiving HT packet. Otherwise, use ht_ltf data directly. Default enabled */ | ||||
|     bool channel_filter_en; /**< enable to turn on channel filter to smooth adjacent sub-carrier. Disable it to keep independence of adjacent sub-carrier. Default enabled */ | ||||
|     bool manu_scale;        /**< manually scale the CSI data by left shifting or automatically scale the CSI data. If set true, please set the shift bits. false: automatically. true: manually. Default false */ | ||||
|     uint8_t shift;          /**< manually left shift bits of the scale of the CSI data. The range of the left shift bits is 0~15 */ | ||||
| } wifi_csi_config_t; | ||||
|  | ||||
| /** | ||||
|   * @brief CSI data type | ||||
|   * | ||||
|   */ | ||||
| typedef struct { | ||||
|     wifi_pkt_rx_ctrl_t rx_ctrl;/**< received packet radio metadata header of the CSI data */ | ||||
|     uint8_t mac[6];            /**< source MAC address of the CSI data */ | ||||
|     bool first_word_invalid;   /**< first four bytes of the CSI data is invalid or not */ | ||||
|     int8_t *buf;               /**< buffer of CSI data */ | ||||
|     uint16_t len;              /**< length of CSI data */ | ||||
| } wifi_csi_info_t; | ||||
|  | ||||
| /** | ||||
|   * @brief WiFi GPIO configuration for antenna selection | ||||
|   * | ||||
|   */ | ||||
| typedef struct { | ||||
|     uint8_t gpio_select: 1,           /**< Whether this GPIO is connected to external antenna switch */ | ||||
|             gpio_num: 7;              /**< The GPIO number that connects to external antenna switch */ | ||||
| } wifi_ant_gpio_t; | ||||
|  | ||||
| /** | ||||
|   * @brief WiFi GPIOs configuration for antenna selection | ||||
|   * | ||||
|   */ | ||||
| typedef struct { | ||||
|     wifi_ant_gpio_t  gpio_cfg[4];  /**< The configurations of GPIOs that connect to external antenna switch */ | ||||
| } wifi_ant_gpio_config_t; | ||||
|  | ||||
| /** | ||||
|   * @brief WiFi antenna mode | ||||
|   * | ||||
|   */ | ||||
| typedef enum { | ||||
|     WIFI_ANT_MODE_ANT0,          /**< Enable WiFi antenna 0 only */ | ||||
|     WIFI_ANT_MODE_ANT1,          /**< Enable WiFi antenna 1 only */ | ||||
|     WIFI_ANT_MODE_AUTO,          /**< Enable WiFi antenna 0 and 1, automatically select an antenna */ | ||||
|     WIFI_ANT_MODE_MAX,           /**< Invalid WiFi enabled antenna */ | ||||
| } wifi_ant_mode_t; | ||||
|  | ||||
| /** | ||||
|   * @brief WiFi antenna configuration | ||||
|   * | ||||
|   */ | ||||
| typedef struct { | ||||
|     wifi_ant_mode_t rx_ant_mode;          /**< WiFi antenna mode for receiving */ | ||||
|     wifi_ant_t      rx_ant_default;       /**< Default antenna mode for receiving, it's ignored if rx_ant_mode is not WIFI_ANT_MODE_AUTO */ | ||||
|     wifi_ant_mode_t tx_ant_mode;          /**< WiFi antenna mode for transmission, it can be set to WIFI_ANT_MODE_AUTO only if rx_ant_mode is set to WIFI_ANT_MODE_AUTO */ | ||||
|     uint8_t         enabled_ant0: 4,      /**< Index (in antenna GPIO configuration) of enabled WIFI_ANT_MODE_ANT0 */ | ||||
|                     enabled_ant1: 4;      /**< Index (in antenna GPIO configuration) of enabled WIFI_ANT_MODE_ANT1 */ | ||||
| } wifi_ant_config_t; | ||||
|  | ||||
| /** | ||||
|   * @brief WiFi PHY rate encodings | ||||
|   * | ||||
|   */ | ||||
| typedef enum { | ||||
|     WIFI_PHY_RATE_1M_L      = 0x00, /**< 1 Mbps with long preamble */ | ||||
|     WIFI_PHY_RATE_2M_L      = 0x01, /**< 2 Mbps with long preamble */ | ||||
|     WIFI_PHY_RATE_5M_L      = 0x02, /**< 5.5 Mbps with long preamble */ | ||||
|     WIFI_PHY_RATE_11M_L     = 0x03, /**< 11 Mbps with long preamble */ | ||||
|     WIFI_PHY_RATE_2M_S      = 0x05, /**< 2 Mbps with short preamble */ | ||||
|     WIFI_PHY_RATE_5M_S      = 0x06, /**< 5.5 Mbps with short preamble */ | ||||
|     WIFI_PHY_RATE_11M_S     = 0x07, /**< 11 Mbps with short preamble */ | ||||
|     WIFI_PHY_RATE_48M       = 0x08, /**< 48 Mbps */ | ||||
|     WIFI_PHY_RATE_24M       = 0x09, /**< 24 Mbps */ | ||||
|     WIFI_PHY_RATE_12M       = 0x0A, /**< 12 Mbps */ | ||||
|     WIFI_PHY_RATE_6M        = 0x0B, /**< 6 Mbps */ | ||||
|     WIFI_PHY_RATE_54M       = 0x0C, /**< 54 Mbps */ | ||||
|     WIFI_PHY_RATE_36M       = 0x0D, /**< 36 Mbps */ | ||||
|     WIFI_PHY_RATE_18M       = 0x0E, /**< 18 Mbps */ | ||||
|     WIFI_PHY_RATE_9M        = 0x0F, /**< 9 Mbps */ | ||||
|     WIFI_PHY_RATE_MCS0_LGI  = 0x10, /**< MCS0 with long GI, 6.5 Mbps for 20MHz, 13.5 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS1_LGI  = 0x11, /**< MCS1 with long GI, 13 Mbps for 20MHz, 27 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS2_LGI  = 0x12, /**< MCS2 with long GI, 19.5 Mbps for 20MHz, 40.5 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS3_LGI  = 0x13, /**< MCS3 with long GI, 26 Mbps for 20MHz, 54 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS4_LGI  = 0x14, /**< MCS4 with long GI, 39 Mbps for 20MHz, 81 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS5_LGI  = 0x15, /**< MCS5 with long GI, 52 Mbps for 20MHz, 108 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS6_LGI  = 0x16, /**< MCS6 with long GI, 58.5 Mbps for 20MHz, 121.5 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS7_LGI  = 0x17, /**< MCS7 with long GI, 65 Mbps for 20MHz, 135 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS0_SGI  = 0x18, /**< MCS0 with short GI, 7.2 Mbps for 20MHz, 15 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS1_SGI  = 0x19, /**< MCS1 with short GI, 14.4 Mbps for 20MHz, 30 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS2_SGI  = 0x1A, /**< MCS2 with short GI, 21.7 Mbps for 20MHz, 45 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS3_SGI  = 0x1B, /**< MCS3 with short GI, 28.9 Mbps for 20MHz, 60 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS4_SGI  = 0x1C, /**< MCS4 with short GI, 43.3 Mbps for 20MHz, 90 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS5_SGI  = 0x1D, /**< MCS5 with short GI, 57.8 Mbps for 20MHz, 120 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS6_SGI  = 0x1E, /**< MCS6 with short GI, 65 Mbps for 20MHz, 135 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_MCS7_SGI  = 0x1F, /**< MCS7 with short GI, 72.2 Mbps for 20MHz, 150 Mbps for 40MHz */ | ||||
|     WIFI_PHY_RATE_LORA_250K = 0x29, /**< 250 Kbps */ | ||||
|     WIFI_PHY_RATE_LORA_500K = 0x2A, /**< 500 Kbps */ | ||||
|     WIFI_PHY_RATE_MAX, | ||||
| } wifi_phy_rate_t; | ||||
|  | ||||
|  | ||||
| /** WiFi event declarations */ | ||||
| typedef enum { | ||||
|     WIFI_EVENT_WIFI_READY = 0,           /**< ESP32 WiFi ready */ | ||||
|     WIFI_EVENT_SCAN_DONE,                /**< ESP32 finish scanning AP */ | ||||
|     WIFI_EVENT_STA_START,                /**< ESP32 station start */ | ||||
|     WIFI_EVENT_STA_STOP,                 /**< ESP32 station stop */ | ||||
|     WIFI_EVENT_STA_CONNECTED,            /**< ESP32 station connected to AP */ | ||||
|     WIFI_EVENT_STA_DISCONNECTED,         /**< ESP32 station disconnected from AP */ | ||||
|     WIFI_EVENT_STA_AUTHMODE_CHANGE,      /**< the auth mode of AP connected by ESP32 station changed */ | ||||
|  | ||||
|     WIFI_EVENT_STA_WPS_ER_SUCCESS,       /**< ESP32 station wps succeeds in enrollee mode */ | ||||
|     WIFI_EVENT_STA_WPS_ER_FAILED,        /**< ESP32 station wps fails in enrollee mode */ | ||||
|     WIFI_EVENT_STA_WPS_ER_TIMEOUT,       /**< ESP32 station wps timeout in enrollee mode */ | ||||
|     WIFI_EVENT_STA_WPS_ER_PIN,           /**< ESP32 station wps pin code in enrollee mode */ | ||||
|     WIFI_EVENT_STA_WPS_ER_PBC_OVERLAP,   /**< ESP32 station wps overlap in enrollee mode */ | ||||
|  | ||||
|     WIFI_EVENT_AP_START,                 /**< ESP32 soft-AP start */ | ||||
|     WIFI_EVENT_AP_STOP,                  /**< ESP32 soft-AP stop */ | ||||
|     WIFI_EVENT_AP_STACONNECTED,          /**< a station connected to ESP32 soft-AP */ | ||||
|     WIFI_EVENT_AP_STADISCONNECTED,       /**< a station disconnected from ESP32 soft-AP */ | ||||
|     WIFI_EVENT_AP_PROBEREQRECVED,        /**< Receive probe request packet in soft-AP interface */ | ||||
|  | ||||
|     WIFI_EVENT_MAX,                      /**< Invalid WiFi event ID */ | ||||
| } wifi_event_t; | ||||
|  | ||||
| /** @cond **/ | ||||
| /** @brief WiFi event base declaration */ | ||||
| ESP_EVENT_DECLARE_BASE(WIFI_EVENT); | ||||
| /** @endcond **/ | ||||
|  | ||||
| /** Argument structure for WIFI_EVENT_SCAN_DONE event */ | ||||
| typedef struct { | ||||
|     uint32_t status;          /**< status of scanning APs: 0 — success, 1 - failure */ | ||||
|     uint8_t  number;          /**< number of scan results */ | ||||
|     uint8_t  scan_id;         /**< scan sequence number, used for block scan */ | ||||
| } wifi_event_sta_scan_done_t; | ||||
|  | ||||
| /** Argument structure for WIFI_EVENT_STA_CONNECTED event */ | ||||
| typedef struct { | ||||
|     uint8_t ssid[32];         /**< SSID of connected AP */ | ||||
|     uint8_t ssid_len;         /**< SSID length of connected AP */ | ||||
|     uint8_t bssid[6];         /**< BSSID of connected AP*/ | ||||
|     uint8_t channel;          /**< channel of connected AP*/ | ||||
|     wifi_auth_mode_t authmode;/**< authentication mode used by AP*/ | ||||
| } wifi_event_sta_connected_t; | ||||
|  | ||||
| /** Argument structure for WIFI_EVENT_STA_DISCONNECTED event */ | ||||
| typedef struct { | ||||
|     uint8_t ssid[32];         /**< SSID of disconnected AP */ | ||||
|     uint8_t ssid_len;         /**< SSID length of disconnected AP */ | ||||
|     uint8_t bssid[6];         /**< BSSID of disconnected AP */ | ||||
|     uint8_t reason;           /**< reason of disconnection */ | ||||
| } wifi_event_sta_disconnected_t; | ||||
|  | ||||
| /** Argument structure for WIFI_EVENT_STA_AUTHMODE_CHANGE event */ | ||||
| typedef struct { | ||||
|     wifi_auth_mode_t old_mode;         /**< the old auth mode of AP */ | ||||
|     wifi_auth_mode_t new_mode;         /**< the new auth mode of AP */ | ||||
| } wifi_event_sta_authmode_change_t; | ||||
|  | ||||
| /** Argument structure for WIFI_EVENT_STA_WPS_ER_PIN event */ | ||||
| typedef struct { | ||||
|     uint8_t pin_code[8];         /**< PIN code of station in enrollee mode */ | ||||
| } wifi_event_sta_wps_er_pin_t; | ||||
|  | ||||
| /** Argument structure for WIFI_EVENT_STA_WPS_ER_FAILED event */ | ||||
| typedef enum { | ||||
|     WPS_FAIL_REASON_NORMAL = 0,     /**< ESP32 WPS normal fail reason */ | ||||
|     WPS_FAIL_REASON_RECV_M2D,       /**< ESP32 WPS receive M2D frame */ | ||||
|     WPS_FAIL_REASON_MAX | ||||
| } wifi_event_sta_wps_fail_reason_t; | ||||
|  | ||||
| /** Argument structure for WIFI_EVENT_AP_STACONNECTED event */ | ||||
| typedef struct { | ||||
|     uint8_t mac[6];           /**< MAC address of the station connected to ESP32 soft-AP */ | ||||
|     uint8_t aid;              /**< the aid that ESP32 soft-AP gives to the station connected to  */ | ||||
| } wifi_event_ap_staconnected_t; | ||||
|  | ||||
| /** Argument structure for WIFI_EVENT_AP_STADISCONNECTED event */ | ||||
| typedef struct { | ||||
|     uint8_t mac[6];           /**< MAC address of the station disconnects to ESP32 soft-AP */ | ||||
|     uint8_t aid;              /**< the aid that ESP32 soft-AP gave to the station disconnects to  */ | ||||
| } wifi_event_ap_stadisconnected_t; | ||||
|  | ||||
| /** Argument structure for WIFI_EVENT_AP_PROBEREQRECVED event */ | ||||
| typedef struct { | ||||
|     int rssi;                 /**< Received probe request signal strength */ | ||||
|     uint8_t mac[6];           /**< MAC address of the station which send probe request */ | ||||
| } wifi_event_ap_probe_req_rx_t; | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* __ESP_WIFI_TYPES_H__ */ | ||||
							
								
								
									
										77
									
								
								tools/sdk/esp32/include/esp_wifi/include/phy.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								tools/sdk/esp32/include/esp_wifi/include/phy.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | ||||
| // Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| // | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #pragma once | ||||
| #include "esp_phy_init.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| #define ESP_CAL_DATA_CHECK_FAIL 1 | ||||
|  | ||||
| /** | ||||
|  * @file phy.h | ||||
|  * @brief Declarations for functions provided by libphy.a | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * @brief Return ROM function pointer table from PHY library. | ||||
|  */ | ||||
| void phy_get_romfunc_addr(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Initialize PHY module and do RF calibration | ||||
|  * @param[in] init_data Initialization parameters to be used by the PHY | ||||
|  * @param[inout] cal_data As input, calibration data previously obtained. As output, will contain new calibration data. | ||||
|  * @param[in] cal_mode  RF calibration mode | ||||
|  * @return ESP_CAL_DATA_CHECK_FAIL if calibration data checksum fails, other values are reserved for future use | ||||
|  */ | ||||
| int register_chipv7_phy(const esp_phy_init_data_t* init_data, esp_phy_calibration_data_t *cal_data, esp_phy_calibration_mode_t cal_mode); | ||||
|  | ||||
| /** | ||||
|  * @brief Get the format version of calibration data used by PHY library. | ||||
|  * @return Format version number, OR'ed with BIT(16) if PHY is in WIFI only mode. | ||||
|  */ | ||||
| uint32_t phy_get_rf_cal_version(void); | ||||
|  | ||||
| /** | ||||
|  * @brief Set RF/BB for only WIFI mode or coexist(WIFI & BT) mode | ||||
|  * @param[in] true is for only WIFI mode, false is for coexist mode. default is 0. | ||||
|  * @return NULL | ||||
|  */ | ||||
| void phy_set_wifi_mode_only(bool wifi_only); | ||||
|  | ||||
| /** | ||||
|  * @brief Set BT the highest priority in coexist mode. | ||||
|  * @return NULL | ||||
|  */ | ||||
| void coex_bt_high_prio(void); | ||||
|  | ||||
| #if CONFIG_IDF_TARGET_ESP32S2 | ||||
| /** | ||||
|  * @brief Open PHY and RF. | ||||
|  */ | ||||
| void phy_wakeup_init(void); | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief Shutdown PHY and RF. | ||||
|  */ | ||||
| void phy_close_rf(void); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
							
								
								
									
										44
									
								
								tools/sdk/esp32/include/esp_wifi/include/smartconfig_ack.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								tools/sdk/esp32/include/esp_wifi/include/smartconfig_ack.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| // Copyright 2010-2017 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| // | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef SMARTCONFIG_ACK_H | ||||
| #define SMARTCONFIG_ACK_H | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|   * @brief  Send smartconfig ACK to cellphone. | ||||
|   * | ||||
|   * @attention The API can only be used when receiving SC_EVENT_GOT_SSID_PSWD event. | ||||
|   * | ||||
|   * @param  type: smartconfig type(ESPTouch or AirKiss); | ||||
|   *         token: token from the cellphone; | ||||
|   *         cellphone_ip: IP address of the cellphone; | ||||
|   * | ||||
|   * @retuen ESP_OK: succeed | ||||
|   *         others: fail | ||||
|   */ | ||||
| esp_err_t sc_send_ack_start(smartconfig_type_t type, uint8_t token, uint8_t *cellphone_ip); | ||||
|  | ||||
| /** | ||||
|   * @brief  Stop sending smartconfig ACK to cellphone. | ||||
|   */ | ||||
| void sc_send_ack_stop(void); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| #endif | ||||
		Reference in New Issue
	
	Block a user