mirror of
				https://github.com/0xFEEDC0DE64/arduino-esp32.git
				synced 2025-10-25 20:21:41 +02:00 
			
		
		
		
	Initial Commit
This commit is contained in:
		| @@ -0,0 +1,79 @@ | ||||
| // 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_WPA_H__ | ||||
| #define __ESP_WPA_H__ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| #include "esp_err.h" | ||||
| #include "esp_wifi_crypto_types.h" | ||||
| #include "esp_wifi_types.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** \defgroup WiFi_APIs WiFi Related APIs | ||||
|   * @brief WiFi APIs | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup WiFi_APIs | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** \defgroup WPA_APIs  WPS APIs | ||||
|   * @brief ESP32 Supplicant APIs | ||||
|   * | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup WPA_APIs | ||||
|   * @{ | ||||
|   */ | ||||
| /* Crypto callback functions */ | ||||
| const wpa_crypto_funcs_t g_wifi_default_wpa_crypto_funcs; | ||||
| /* Mesh crypto callback functions */ | ||||
| const mesh_crypto_funcs_t g_wifi_default_mesh_crypto_funcs; | ||||
|  | ||||
| /** | ||||
|   * @brief     Supplicant initialization | ||||
|   * | ||||
|   * @return     | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_NO_MEM : out of memory | ||||
|   */ | ||||
| esp_err_t esp_supplicant_init(void); | ||||
|  | ||||
| /** | ||||
|   * @brief     Supplicant deinitialization | ||||
|   * | ||||
|   * @return     | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - others: failed | ||||
|   */ | ||||
| esp_err_t esp_supplicant_deinit(void); | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* __ESP_WPA_H__ */ | ||||
| @@ -0,0 +1,197 @@ | ||||
| // Hardware crypto support 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_WPA2_H | ||||
| #define _ESP_WPA2_H | ||||
|  | ||||
| #include <stdbool.h> | ||||
|  | ||||
| #include "esp_err.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|   * @brief  Enable wpa2 enterprise authentication. | ||||
|   * | ||||
|   * @attention 1. wpa2 enterprise authentication can only be used when ESP32 station is enabled. | ||||
|   * @attention 2. wpa2 enterprise authentication can only support TLS, PEAP-MSCHAPv2 and TTLS-MSCHAPv2 method. | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed. | ||||
|   *    - ESP_ERR_NO_MEM: fail(internal memory malloc fail) | ||||
|   */ | ||||
| esp_err_t esp_wifi_sta_wpa2_ent_enable(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  Disable wpa2 enterprise authentication. | ||||
|   * | ||||
|   * @attention 1. wpa2 enterprise authentication can only be used when ESP32 station is enabled. | ||||
|   * @attention 2. wpa2 enterprise authentication can only support TLS, PEAP-MSCHAPv2 and TTLS-MSCHAPv2 method. | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed. | ||||
|   */ | ||||
| esp_err_t esp_wifi_sta_wpa2_ent_disable(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  Set identity for PEAP/TTLS method. | ||||
|   * | ||||
|   * @attention The API only passes the parameter identity to the global pointer variable in wpa2 enterprise module. | ||||
|   * | ||||
|   * @param  identity: point to address where stores the identity; | ||||
|   * @param  len: length of identity, limited to 1~127 | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   *    - ESP_ERR_INVALID_ARG: fail(len <= 0 or len >= 128) | ||||
|   *    - ESP_ERR_NO_MEM: fail(internal memory malloc fail) | ||||
|   */ | ||||
| esp_err_t esp_wifi_sta_wpa2_ent_set_identity(const unsigned char *identity, int len); | ||||
|  | ||||
| /** | ||||
|   * @brief  Clear identity for PEAP/TTLS method. | ||||
|   */ | ||||
| void esp_wifi_sta_wpa2_ent_clear_identity(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  Set username for PEAP/TTLS method. | ||||
|   * | ||||
|   * @attention The API only passes the parameter username to the global pointer variable in wpa2 enterprise module. | ||||
|   * | ||||
|   * @param  username: point to address where stores the username; | ||||
|   * @param  len: length of username, limited to 1~127 | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   *    - ESP_ERR_INVALID_ARG: fail(len <= 0 or len >= 128) | ||||
|   *    - ESP_ERR_NO_MEM: fail(internal memory malloc fail) | ||||
|   */ | ||||
| esp_err_t esp_wifi_sta_wpa2_ent_set_username(const unsigned char *username, int len); | ||||
|  | ||||
| /** | ||||
|   * @brief  Clear username for PEAP/TTLS method. | ||||
|   */ | ||||
| void esp_wifi_sta_wpa2_ent_clear_username(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  Set password for PEAP/TTLS method.. | ||||
|   * | ||||
|   * @attention The API only passes the parameter password to the global pointer variable in wpa2 enterprise module. | ||||
|   * | ||||
|   * @param  password: point to address where stores the password; | ||||
|   * @param  len: length of password(len > 0) | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   *    - ESP_ERR_INVALID_ARG: fail(len <= 0) | ||||
|   *    - ESP_ERR_NO_MEM: fail(internal memory malloc fail) | ||||
|   */ | ||||
| esp_err_t esp_wifi_sta_wpa2_ent_set_password(const unsigned char *password, int len); | ||||
|  | ||||
| /** | ||||
|   * @brief  Clear password for PEAP/TTLS method.. | ||||
|   */ | ||||
| void esp_wifi_sta_wpa2_ent_clear_password(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  Set new password for MSCHAPv2 method.. | ||||
|   * | ||||
|   * @attention 1. The API only passes the parameter password to the global pointer variable in wpa2 enterprise module. | ||||
|   * @attention 2. The new password is used to substitute the old password when eap-mschapv2 failure request message with error code ERROR_PASSWD_EXPIRED is received. | ||||
|   * | ||||
|   * @param  new_password: point to address where stores the password; | ||||
|   * @param  len: length of password | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   *    - ESP_ERR_INVALID_ARG: fail(len <= 0) | ||||
|   *    - ESP_ERR_NO_MEM: fail(internal memory malloc fail) | ||||
|   */ | ||||
|  | ||||
| esp_err_t esp_wifi_sta_wpa2_ent_set_new_password(const unsigned char *new_password, int len); | ||||
|  | ||||
| /** | ||||
|   * @brief  Clear new password for MSCHAPv2 method.. | ||||
|   */ | ||||
| void esp_wifi_sta_wpa2_ent_clear_new_password(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  Set CA certificate for PEAP/TTLS method. | ||||
|   * | ||||
|   * @attention 1. The API only passes the parameter ca_cert to the global pointer variable in wpa2 enterprise module. | ||||
|   * @attention 2. The ca_cert should be zero terminated. | ||||
|   * | ||||
|   * @param  ca_cert: point to address where stores the CA certificate; | ||||
|   * @param  ca_cert_len: length of ca_cert | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   */ | ||||
| esp_err_t esp_wifi_sta_wpa2_ent_set_ca_cert(const unsigned char *ca_cert, int ca_cert_len); | ||||
|  | ||||
| /** | ||||
|   * @brief  Clear CA certificate for PEAP/TTLS method. | ||||
|   */ | ||||
| void esp_wifi_sta_wpa2_ent_clear_ca_cert(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  Set client certificate and key. | ||||
|   * | ||||
|   * @attention 1. The API only passes the parameter client_cert, private_key and private_key_passwd to the global pointer variable in wpa2 enterprise module. | ||||
|   * @attention 2. The client_cert, private_key and private_key_passwd should be zero terminated. | ||||
|   * | ||||
|   * @param  client_cert: point to address where stores the client certificate; | ||||
|   * @param  client_cert_len: length of client certificate; | ||||
|   * @param  private_key: point to address where stores the private key; | ||||
|   * @param  private_key_len: length of private key, limited to 1~2048; | ||||
|   * @param  private_key_password: point to address where stores the private key password; | ||||
|   * @param  private_key_password_len: length of private key password; | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   */ | ||||
| esp_err_t esp_wifi_sta_wpa2_ent_set_cert_key(const unsigned char *client_cert, int client_cert_len, const unsigned char *private_key, int private_key_len, const unsigned char *private_key_passwd, int private_key_passwd_len); | ||||
|  | ||||
| /** | ||||
|   * @brief  Clear client certificate and key. | ||||
|   */ | ||||
| void esp_wifi_sta_wpa2_ent_clear_cert_key(void); | ||||
|  | ||||
| /** | ||||
|   * @brief  Set wpa2 enterprise certs time check(disable or not). | ||||
|   * | ||||
|   * @param  true: disable wpa2 enterprise certs time check | ||||
|   * @param  false: enable wpa2 enterprise certs time check | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   */ | ||||
| esp_err_t esp_wifi_sta_wpa2_ent_set_disable_time_check(bool disable); | ||||
|  | ||||
| /** | ||||
|   * @brief  Get wpa2 enterprise certs time check(disable or not). | ||||
|   * | ||||
|   * @param  disable: store disable value | ||||
|   * | ||||
|   * @return | ||||
|   *    - ESP_OK: succeed | ||||
|   */ | ||||
| esp_err_t esp_wifi_sta_wpa2_ent_get_disable_time_check(bool *disable); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| #endif | ||||
| @@ -0,0 +1,141 @@ | ||||
| // 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_WPS_H__ | ||||
| #define __ESP_WPS_H__ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| #include "esp_err.h" | ||||
| #include "esp_wifi_crypto_types.h" | ||||
| #include "esp_compiler.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** \defgroup WiFi_APIs WiFi Related APIs | ||||
|   * @brief WiFi APIs | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup WiFi_APIs | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** \defgroup WPS_APIs  WPS APIs | ||||
|   * @brief ESP32 WPS APIs | ||||
|   * | ||||
|   * WPS can only be used when ESP32 station is enabled. | ||||
|   * | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup WPS_APIs | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| #define ESP_ERR_WIFI_REGISTRAR   (ESP_ERR_WIFI_BASE + 51)  /*!< WPS registrar is not supported */ | ||||
| #define ESP_ERR_WIFI_WPS_TYPE    (ESP_ERR_WIFI_BASE + 52)  /*!< WPS type error */ | ||||
| #define ESP_ERR_WIFI_WPS_SM      (ESP_ERR_WIFI_BASE + 53)  /*!< WPS state machine is not initialized */ | ||||
|  | ||||
| typedef enum wps_type { | ||||
|     WPS_TYPE_DISABLE = 0, | ||||
|     WPS_TYPE_PBC, | ||||
|     WPS_TYPE_PIN, | ||||
|     WPS_TYPE_MAX, | ||||
| } wps_type_t; | ||||
|  | ||||
| #define WPS_MAX_MANUFACTURER_LEN 65 | ||||
| #define WPS_MAX_MODEL_NUMBER_LEN 33 | ||||
| #define WPS_MAX_MODEL_NAME_LEN   33 | ||||
| #define WPS_MAX_DEVICE_NAME_LEN  33 | ||||
|  | ||||
| typedef struct { | ||||
|     char manufacturer[WPS_MAX_MANUFACTURER_LEN]; /*!< Manufacturer, null-terminated string. The default manufcturer is used if the string is empty */ | ||||
|     char model_number[WPS_MAX_MODEL_NUMBER_LEN]; /*!< Model number, null-terminated string. The default model number is used if the string is empty */ | ||||
|     char model_name[WPS_MAX_MODEL_NAME_LEN];     /*!< Model name, null-terminated string. The default model name is used if the string is empty */ | ||||
|     char device_name[WPS_MAX_DEVICE_NAME_LEN];   /*!< Device name, null-terminated string. The default device name is used if the string is empty */ | ||||
| } wps_factory_information_t; | ||||
|  | ||||
| typedef struct { | ||||
|     wps_type_t wps_type; | ||||
|     wps_factory_information_t factory_info; | ||||
| } esp_wps_config_t; | ||||
|  | ||||
| #define WPS_CONFIG_INIT_DEFAULT(type) { \ | ||||
|     .wps_type = type, \ | ||||
|     .factory_info = {   \ | ||||
|         ESP_COMPILER_DESIGNATED_INIT_AGGREGATE_TYPE_STR(manufacturer, "ESPRESSIF")  \ | ||||
|         ESP_COMPILER_DESIGNATED_INIT_AGGREGATE_TYPE_STR(model_number, "ESP32")  \ | ||||
|         ESP_COMPILER_DESIGNATED_INIT_AGGREGATE_TYPE_STR(model_name, "ESPRESSIF IOT")  \ | ||||
|         ESP_COMPILER_DESIGNATED_INIT_AGGREGATE_TYPE_STR(device_name, "ESP STATION")  \ | ||||
|     }  \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|   * @brief     Enable Wi-Fi WPS function. | ||||
|   * | ||||
|   * @attention WPS can only be used when ESP32 station is enabled. | ||||
|   * | ||||
|   * @param     wps_type_t wps_type : WPS type, so far only WPS_TYPE_PBC and WPS_TYPE_PIN is supported | ||||
|   * | ||||
|   * @return     | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_WIFI_WPS_TYPE : wps type is invalid | ||||
|   *          - ESP_ERR_WIFI_WPS_MODE : wifi is not in station mode or sniffer mode is on | ||||
|   *          - ESP_FAIL : wps initialization fails | ||||
|   */ | ||||
| esp_err_t esp_wifi_wps_enable(const esp_wps_config_t *config); | ||||
|  | ||||
| /** | ||||
|   * @brief  Disable Wi-Fi WPS function and release resource it taken. | ||||
|   * | ||||
|   * @param  null | ||||
|   * | ||||
|   * @return     | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_WIFI_WPS_MODE : wifi is not in station mode or sniffer mode is on | ||||
|   */ | ||||
| esp_err_t esp_wifi_wps_disable(void); | ||||
|  | ||||
| /** | ||||
|   * @brief     WPS starts to work. | ||||
|   * | ||||
|   * @attention WPS can only be used when ESP32 station is enabled. | ||||
|   * | ||||
|   * @param     timeout_ms : maximum blocking time before API return. | ||||
|   *          - 0 : non-blocking | ||||
|   *          - 1~120000 : blocking time (not supported in IDF v1.0) | ||||
|   * | ||||
|   * @return     | ||||
|   *          - ESP_OK : succeed | ||||
|   *          - ESP_ERR_WIFI_WPS_TYPE : wps type is invalid | ||||
|   *          - ESP_ERR_WIFI_WPS_MODE : wifi is not in station mode or sniffer mode is on | ||||
|   *          - ESP_ERR_WIFI_WPS_SM : wps state machine is not initialized | ||||
|   *          - ESP_FAIL : wps initialization fails | ||||
|   */ | ||||
| esp_err_t esp_wifi_wps_start(int timeout_ms); | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* __ESP_WPS_H__ */ | ||||
| @@ -0,0 +1,205 @@ | ||||
| /* | ||||
|  * wpa_supplicant/hostapd / Debug prints | ||||
|  * Copyright (c) 2002-2007, Jouni Malinen <j@w1.fi> | ||||
|  * | ||||
|  * This program is free software; you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License version 2 as | ||||
|  * published by the Free Software Foundation. | ||||
|  * | ||||
|  * Alternatively, this software may be distributed under the terms of BSD | ||||
|  * license. | ||||
|  * | ||||
|  * See README and COPYING for more details. | ||||
|  */ | ||||
|  | ||||
| #ifndef WPA_DEBUG_H | ||||
| #define WPA_DEBUG_H | ||||
|  | ||||
| #include "wpabuf.h" | ||||
| #include "esp_log.h" | ||||
|  | ||||
| #ifdef ESPRESSIF_USE | ||||
|  | ||||
| #define TAG "wpa" | ||||
|  | ||||
| #define MSG_ERROR ESP_LOG_ERROR | ||||
| #define MSG_WARNING ESP_LOG_WARN | ||||
| #define MSG_INFO ESP_LOG_INFO | ||||
| #define MSG_DEBUG ESP_LOG_DEBUG | ||||
| #define MSG_MSGDUMP ESP_LOG_VERBOSE | ||||
|  | ||||
| #else  | ||||
| enum { MSG_MSGDUMP, MSG_DEBUG, MSG_INFO, MSG_WARNING, MSG_ERROR }; | ||||
| #endif | ||||
|  | ||||
| /** EAP authentication completed successfully */ | ||||
| #define WPA_EVENT_EAP_SUCCESS "CTRL-EVENT-EAP-SUCCESS " | ||||
|  | ||||
| int wpa_debug_open_file(const char *path); | ||||
| void wpa_debug_close_file(void); | ||||
|  | ||||
| /** | ||||
|  * wpa_debug_printf_timestamp - Print timestamp for debug output | ||||
|  * | ||||
|  * This function prints a timestamp in seconds_from_1970.microsoconds | ||||
|  * format if debug output has been configured to include timestamps in debug | ||||
|  * messages. | ||||
|  */ | ||||
| void wpa_debug_print_timestamp(void); | ||||
|  | ||||
| #ifdef DEBUG_PRINT | ||||
| /** | ||||
|  * wpa_printf - conditional printf | ||||
|  * @level: priority level (MSG_*) of the message | ||||
|  * @fmt: printf format string, followed by optional arguments | ||||
|  * | ||||
|  * This function is used to print conditional debugging and error messages. The | ||||
|  * output may be directed to stdout, stderr, and/or syslog based on | ||||
|  * configuration. | ||||
|  * | ||||
|  * Note: New line '\n' is added to the end of the text when printing to stdout. | ||||
|  */ | ||||
| #define wpa_printf(level,fmt, args...) ESP_LOG_LEVEL_LOCAL(level, TAG, fmt, ##args) | ||||
|  | ||||
| void wpa_dump_mem(char* desc, uint8_t *addr, uint16_t len); | ||||
| static inline void wpa_hexdump_ascii(int level, const char *title, const u8 *buf, size_t len) | ||||
| { | ||||
|  | ||||
| } | ||||
|  | ||||
| static inline void wpa_hexdump_ascii_key(int level, const char *title, const u8 *buf, size_t len) | ||||
| { | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * wpa_hexdump - conditional hex dump | ||||
|  * @level: priority level (MSG_*) of the message | ||||
|  * @title: title of for the message | ||||
|  * @buf: data buffer to be dumped | ||||
|  * @len: length of the buf | ||||
|  * | ||||
|  * This function is used to print conditional debugging and error messages. The | ||||
|  * output may be directed to stdout, stderr, and/or syslog based on | ||||
|  * configuration. The contents of buf is printed out has hex dump. | ||||
|  */ | ||||
| void wpa_hexdump(int level, const char *title, const u8 *buf, size_t len); | ||||
|  | ||||
| static inline void wpa_hexdump_buf(int level, const char *title, | ||||
| 				   const struct wpabuf *buf) | ||||
| { | ||||
| 	wpa_hexdump(level, title, wpabuf_head(buf), wpabuf_len(buf)); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * wpa_hexdump_key - conditional hex dump, hide keys | ||||
|  * @level: priority level (MSG_*) of the message | ||||
|  * @title: title of for the message | ||||
|  * @buf: data buffer to be dumped | ||||
|  * @len: length of the buf | ||||
|  * | ||||
|  * This function is used to print conditional debugging and error messages. The | ||||
|  * output may be directed to stdout, stderr, and/or syslog based on | ||||
|  * configuration. The contents of buf is printed out has hex dump. This works | ||||
|  * like wpa_hexdump(), but by default, does not include secret keys (passwords, | ||||
|  * etc.) in debug output. | ||||
|  */ | ||||
| void wpa_hexdump_key(int level, const char *title, const u8 *buf, size_t len); | ||||
|  | ||||
|  | ||||
| static inline void wpa_hexdump_buf_key(int level, const char *title, | ||||
| 				       const struct wpabuf *buf) | ||||
| { | ||||
| 	wpa_hexdump_key(level, title, wpabuf_head(buf), wpabuf_len(buf)); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * wpa_hexdump_ascii - conditional hex dump | ||||
|  * @level: priority level (MSG_*) of the message | ||||
|  * @title: title of for the message | ||||
|  * @buf: data buffer to be dumped | ||||
|  * @len: length of the buf | ||||
|  * | ||||
|  * This function is used to print conditional debugging and error messages. The | ||||
|  * output may be directed to stdout, stderr, and/or syslog based on | ||||
|  * configuration. The contents of buf is printed out has hex dump with both | ||||
|  * the hex numbers and ASCII characters (for printable range) are shown. 16 | ||||
|  * bytes per line will be shown. | ||||
|  */ | ||||
| void wpa_hexdump_ascii(int level, const char *title, const u8 *buf, | ||||
| 		       size_t len); | ||||
|  | ||||
| /** | ||||
|  * wpa_hexdump_ascii_key - conditional hex dump, hide keys | ||||
|  * @level: priority level (MSG_*) of the message | ||||
|  * @title: title of for the message | ||||
|  * @buf: data buffer to be dumped | ||||
|  * @len: length of the buf | ||||
|  * | ||||
|  * This function is used to print conditional debugging and error messages. The | ||||
|  * output may be directed to stdout, stderr, and/or syslog based on | ||||
|  * configuration. The contents of buf is printed out has hex dump with both | ||||
|  * the hex numbers and ASCII characters (for printable range) are shown. 16 | ||||
|  * bytes per line will be shown. This works like wpa_hexdump_ascii(), but by | ||||
|  * default, does not include secret keys (passwords, etc.) in debug output. | ||||
|  */ | ||||
| void wpa_hexdump_ascii_key(int level, const char *title, const u8 *buf, | ||||
| 			   size_t len); | ||||
| #else | ||||
| #define wpa_printf(level,fmt, args...) do {} while(0) | ||||
| #define wpa_hexdump(...) do {} while(0) | ||||
| #define wpa_dump_mem(...) do {} while(0) | ||||
| #define wpa_hexdump_buf(...) do {} while(0) | ||||
| #define wpa_hexdump_key(...) do {} while(0) | ||||
| #define wpa_hexdump_buf_key(...) do {} while(0) | ||||
| #define wpa_hexdump_ascii(...) do {} while(0) | ||||
| #define wpa_hexdump_ascii_key(...) do {} while(0) | ||||
| #endif | ||||
|  | ||||
| #define wpa_auth_logger | ||||
| #define wpa_auth_vlogger | ||||
|  | ||||
| /** | ||||
|  * wpa_msg - Conditional printf for default target and ctrl_iface monitors | ||||
|  * @ctx: Pointer to context data; this is the ctx variable registered | ||||
|  *	with struct wpa_driver_ops::init() | ||||
|  * @level: priority level (MSG_*) of the message | ||||
|  * @fmt: printf format string, followed by optional arguments | ||||
|  * | ||||
|  * This function is used to print conditional debugging and error messages. The | ||||
|  * output may be directed to stdout, stderr, and/or syslog based on | ||||
|  * configuration. This function is like wpa_printf(), but it also sends the | ||||
|  * same message to all attached ctrl_iface monitors. | ||||
|  * | ||||
|  * Note: New line '\n' is added to the end of the text when printing to stdout. | ||||
|  */ | ||||
| void wpa_msg(void *ctx, int level, const char *fmt, ...) PRINTF_FORMAT(3, 4); | ||||
|  | ||||
| /** | ||||
|  * wpa_msg_ctrl - Conditional printf for ctrl_iface monitors | ||||
|  * @ctx: Pointer to context data; this is the ctx variable registered | ||||
|  *	with struct wpa_driver_ops::init() | ||||
|  * @level: priority level (MSG_*) of the message | ||||
|  * @fmt: printf format string, followed by optional arguments | ||||
|  * | ||||
|  * This function is used to print conditional debugging and error messages. | ||||
|  * This function is like wpa_msg(), but it sends the output only to the | ||||
|  * attached ctrl_iface monitors. In other words, it can be used for frequent | ||||
|  * events that do not need to be sent to syslog. | ||||
|  */ | ||||
| void wpa_msg_ctrl(void *ctx, int level, const char *fmt, ...) | ||||
| PRINTF_FORMAT(3, 4); | ||||
|  | ||||
| typedef void (*wpa_msg_cb_func)(void *ctx, int level, const char *txt, | ||||
| 				size_t len); | ||||
|  | ||||
| typedef void (*eloop_timeout_handler)(void *eloop_data, void *user_ctx); | ||||
|  | ||||
| int eloop_cancel_timeout(eloop_timeout_handler handler, | ||||
| 			 void *eloop_data, void *user_data); | ||||
|  | ||||
| int eloop_register_timeout(unsigned int secs, unsigned int usecs, | ||||
| 			   eloop_timeout_handler handler, | ||||
| 			   void *eloop_data, void *user_data); | ||||
|  | ||||
|  | ||||
| #endif /* WPA_DEBUG_H */ | ||||
							
								
								
									
										168
									
								
								tools/sdk/esp32s2/include/wpa_supplicant/include/utils/wpabuf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								tools/sdk/esp32s2/include/wpa_supplicant/include/utils/wpabuf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,168 @@ | ||||
| /* | ||||
|  * Dynamic data buffer | ||||
|  * Copyright (c) 2007-2009, Jouni Malinen <j@w1.fi> | ||||
|  * | ||||
|  * This program is free software; you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License version 2 as | ||||
|  * published by the Free Software Foundation. | ||||
|  * | ||||
|  * Alternatively, this software may be distributed under the terms of BSD | ||||
|  * license. | ||||
|  * | ||||
|  * See README and COPYING for more details. | ||||
|  */ | ||||
|  | ||||
| #ifndef WPABUF_H | ||||
| #define WPABUF_H | ||||
|  | ||||
| /* | ||||
|  * Internal data structure for wpabuf. Please do not touch this directly from | ||||
|  * elsewhere. This is only defined in header file to allow inline functions | ||||
|  * from this file to access data. | ||||
|  */ | ||||
| struct wpabuf { | ||||
| 	size_t size; /* total size of the allocated buffer */ | ||||
| 	size_t used; /* length of data in the buffer */ | ||||
| 	u8 *ext_data; /* pointer to external data; NULL if data follows | ||||
| 		       * struct wpabuf */ | ||||
| 	/* optionally followed by the allocated buffer */ | ||||
| }; | ||||
|  | ||||
|  | ||||
| int wpabuf_resize(struct wpabuf **buf, size_t add_len); | ||||
| struct wpabuf * wpabuf_alloc(size_t len); | ||||
| struct wpabuf * wpabuf_alloc_ext_data(u8 *data, size_t len); | ||||
| struct wpabuf * wpabuf_alloc_copy(const void *data, size_t len); | ||||
| struct wpabuf * wpabuf_dup(const struct wpabuf *src); | ||||
| void wpabuf_free(struct wpabuf *buf); | ||||
| void * wpabuf_put(struct wpabuf *buf, size_t len); | ||||
| struct wpabuf * wpabuf_concat(struct wpabuf *a, struct wpabuf *b); | ||||
| struct wpabuf * wpabuf_zeropad(struct wpabuf *buf, size_t len); | ||||
| void wpabuf_printf(struct wpabuf *buf, const char *fmt, ...) PRINTF_FORMAT(2, 3); | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * wpabuf_size - Get the currently allocated size of a wpabuf buffer | ||||
|  * @buf: wpabuf buffer | ||||
|  * Returns: Currently allocated size of the buffer | ||||
|  */ | ||||
| static inline size_t wpabuf_size(const struct wpabuf *buf) | ||||
| { | ||||
| 	return buf->size; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * wpabuf_len - Get the current length of a wpabuf buffer data | ||||
|  * @buf: wpabuf buffer | ||||
|  * Returns: Currently used length of the buffer | ||||
|  */ | ||||
| static inline size_t wpabuf_len(const struct wpabuf *buf) | ||||
| { | ||||
| 	return buf->used; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * wpabuf_tailroom - Get size of available tail room in the end of the buffer | ||||
|  * @buf: wpabuf buffer | ||||
|  * Returns: Tail room (in bytes) of available space in the end of the buffer | ||||
|  */ | ||||
| static inline size_t wpabuf_tailroom(const struct wpabuf *buf) | ||||
| { | ||||
| 	return buf->size - buf->used; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * wpabuf_head - Get pointer to the head of the buffer data | ||||
|  * @buf: wpabuf buffer | ||||
|  * Returns: Pointer to the head of the buffer data | ||||
|  */ | ||||
| static inline const void * wpabuf_head(const struct wpabuf *buf) | ||||
| { | ||||
| 	if (buf->ext_data) | ||||
| 		return buf->ext_data; | ||||
| 	return buf + 1; | ||||
| } | ||||
|  | ||||
| static inline const u8 * wpabuf_head_u8(const struct wpabuf *buf) | ||||
| { | ||||
| 	return wpabuf_head(buf); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * wpabuf_mhead - Get modifiable pointer to the head of the buffer data | ||||
|  * @buf: wpabuf buffer | ||||
|  * Returns: Pointer to the head of the buffer data | ||||
|  */ | ||||
| static inline void * wpabuf_mhead(struct wpabuf *buf) | ||||
| { | ||||
| 	if (buf->ext_data) | ||||
| 		return buf->ext_data; | ||||
| 	return buf + 1; | ||||
| } | ||||
|  | ||||
| static inline u8 * wpabuf_mhead_u8(struct wpabuf *buf) | ||||
| { | ||||
| 	return wpabuf_mhead(buf); | ||||
| } | ||||
|  | ||||
| static inline void wpabuf_put_u8(struct wpabuf *buf, u8 data) | ||||
| { | ||||
| 	u8 *pos = wpabuf_put(buf, 1); | ||||
| 	*pos = data; | ||||
| } | ||||
|  | ||||
| static inline void wpabuf_put_le16(struct wpabuf *buf, u16 data) | ||||
| { | ||||
| 	u8 *pos = wpabuf_put(buf, 2); | ||||
| 	WPA_PUT_LE16(pos, data); | ||||
| } | ||||
|  | ||||
| static inline void wpabuf_put_le32(struct wpabuf *buf, u32 data) | ||||
| { | ||||
| 	u8 *pos = wpabuf_put(buf, 4); | ||||
| 	WPA_PUT_LE32(pos, data); | ||||
| } | ||||
|  | ||||
| static inline void wpabuf_put_be16(struct wpabuf *buf, u16 data) | ||||
| { | ||||
| 	u8 *pos = wpabuf_put(buf, 2); | ||||
| 	WPA_PUT_BE16(pos, data); | ||||
| } | ||||
|  | ||||
| static inline void wpabuf_put_be24(struct wpabuf *buf, u32 data) | ||||
| { | ||||
| 	u8 *pos = wpabuf_put(buf, 3); | ||||
| 	WPA_PUT_BE24(pos, data); | ||||
| } | ||||
|  | ||||
| static inline void wpabuf_put_be32(struct wpabuf *buf, u32 data) | ||||
| { | ||||
| 	u8 *pos = wpabuf_put(buf, 4); | ||||
| 	WPA_PUT_BE32(pos, data); | ||||
| } | ||||
|  | ||||
| static inline void wpabuf_put_data(struct wpabuf *buf, const void *data, | ||||
| 				   size_t len) | ||||
| { | ||||
| 	if (data) | ||||
| 		os_memcpy(wpabuf_put(buf, len), data, len); | ||||
| } | ||||
|  | ||||
| static inline void wpabuf_put_buf(struct wpabuf *dst, | ||||
| 				  const struct wpabuf *src) | ||||
| { | ||||
| 	wpabuf_put_data(dst, wpabuf_head(src), wpabuf_len(src)); | ||||
| } | ||||
|  | ||||
| static inline void wpabuf_set(struct wpabuf *buf, const void *data, size_t len) | ||||
| { | ||||
| 	buf->ext_data = (u8 *) data; | ||||
| 	buf->size = buf->used = len; | ||||
| } | ||||
|  | ||||
| static inline void wpabuf_put_str(struct wpabuf *dst, const char *str) | ||||
| { | ||||
| 	wpabuf_put_data(dst, str, os_strlen(str)); | ||||
| } | ||||
|  | ||||
| #endif /* WPABUF_H */ | ||||
| @@ -0,0 +1,73 @@ | ||||
| /* | ||||
|  * Copyright (c) 2010 Espressif System | ||||
|  */ | ||||
|  | ||||
| #ifndef BYTESWAP_H | ||||
| #define BYTESWAP_H | ||||
|  | ||||
| #include <machine/endian.h> | ||||
|  | ||||
| /* Swap bytes in 16 bit value.  */ | ||||
| #ifndef __bswap_16 | ||||
| #ifdef __GNUC__ | ||||
| # define __bswap_16(x) \ | ||||
|     (__extension__							      \ | ||||
|      ({ unsigned short int __bsx = (x);					      \ | ||||
|         ((((__bsx) >> 8) & 0xff) | (((__bsx) & 0xff) << 8)); })) | ||||
| #else | ||||
| static INLINE unsigned short int | ||||
| __bswap_16 (unsigned short int __bsx) | ||||
| { | ||||
|   return ((((__bsx) >> 8) & 0xff) | (((__bsx) & 0xff) << 8)); | ||||
| } | ||||
| #endif | ||||
| #endif // __bswap_16 | ||||
|  | ||||
| /* Swap bytes in 32 bit value.  */ | ||||
| #ifndef __bswap_32 | ||||
| #ifdef __GNUC__ | ||||
| # define __bswap_32(x) \ | ||||
|     (__extension__							      \ | ||||
|      ({ unsigned int __bsx = (x);					      \ | ||||
|         ((((__bsx) & 0xff000000) >> 24) | (((__bsx) & 0x00ff0000) >>  8) |    \ | ||||
| 	 (((__bsx) & 0x0000ff00) <<  8) | (((__bsx) & 0x000000ff) << 24)); })) | ||||
| #else | ||||
| static INLINE unsigned int | ||||
| __bswap_32 (unsigned int __bsx) | ||||
| { | ||||
|   return ((((__bsx) & 0xff000000) >> 24) | (((__bsx) & 0x00ff0000) >>  8) | | ||||
| 	  (((__bsx) & 0x0000ff00) <<  8) | (((__bsx) & 0x000000ff) << 24)); | ||||
| } | ||||
| #endif | ||||
| #endif // __bswap_32 | ||||
|  | ||||
| #ifndef __bswap_64 | ||||
| #if defined __GNUC__ && __GNUC__ >= 2 | ||||
| /* Swap bytes in 64 bit value.  */ | ||||
| # define __bswap_constant_64(x) \ | ||||
|      ((((x) & 0xff00000000000000ull) >> 56)				      \ | ||||
|       | (((x) & 0x00ff000000000000ull) >> 40)				      \ | ||||
|       | (((x) & 0x0000ff0000000000ull) >> 24)				      \ | ||||
|       | (((x) & 0x000000ff00000000ull) >> 8)				      \ | ||||
|       | (((x) & 0x00000000ff000000ull) << 8)				      \ | ||||
|       | (((x) & 0x0000000000ff0000ull) << 24)				      \ | ||||
|       | (((x) & 0x000000000000ff00ull) << 40)				      \ | ||||
|       | (((x) & 0x00000000000000ffull) << 56)) | ||||
|  | ||||
| # define __bswap_64(x) \ | ||||
|      (__extension__							      \ | ||||
|       ({ union { __extension__ unsigned long long int __ll;		      \ | ||||
| 		 unsigned int __l[2]; } __w, __r;			      \ | ||||
|          if (__builtin_constant_p (x))					      \ | ||||
| 	   __r.__ll = __bswap_constant_64 (x);				      \ | ||||
| 	 else								      \ | ||||
| 	   {								      \ | ||||
| 	     __w.__ll = (x);						      \ | ||||
| 	     __r.__l[0] = __bswap_32 (__w.__l[1]);			      \ | ||||
| 	     __r.__l[1] = __bswap_32 (__w.__l[0]);			      \ | ||||
| 	   }								      \ | ||||
| 	 __r.__ll; })) | ||||
| #endif | ||||
| #endif // __bswap_64 | ||||
|  | ||||
| #endif /* BYTESWAP_H */ | ||||
							
								
								
									
										226
									
								
								tools/sdk/esp32s2/include/wpa_supplicant/port/include/endian.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										226
									
								
								tools/sdk/esp32s2/include/wpa_supplicant/port/include/endian.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,226 @@ | ||||
| /*- | ||||
|  * Copyright (c) 2002 Thomas Moestl <tmm@FreeBSD.org> | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
|  * are met: | ||||
|  * 1. Redistributions of source code must retain the above copyright | ||||
|  *    notice, this list of conditions and the following disclaimer. | ||||
|  * 2. Redistributions in binary form must reproduce the above copyright | ||||
|  *    notice, this list of conditions and the following disclaimer in the | ||||
|  *    documentation and/or other materials provided with the distribution. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND | ||||
|  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||
|  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | ||||
|  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE | ||||
|  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||||
|  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | ||||
|  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | ||||
|  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | ||||
|  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | ||||
|  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | ||||
|  * SUCH DAMAGE. | ||||
|  * | ||||
|  * $FreeBSD$ | ||||
|  */ | ||||
|  | ||||
| #ifndef _ENDIAN_H_ | ||||
| #define _ENDIAN_H_ | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <sys/types.h> | ||||
| #include "byteswap.h" | ||||
|  | ||||
| #ifndef BIG_ENDIAN | ||||
| #define BIG_ENDIAN 4321 | ||||
| #endif | ||||
| #ifndef LITTLE_ENDIAN | ||||
| #define LITTLE_ENDIAN 1234 | ||||
| #endif | ||||
|  | ||||
| #ifndef BYTE_ORDER | ||||
| #ifdef __IEEE_LITTLE_ENDIAN | ||||
| #define BYTE_ORDER LITTLE_ENDIAN | ||||
| #else | ||||
| #define BYTE_ORDER BIG_ENDIAN | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #define _UINT8_T_DECLARED | ||||
| #ifndef _UINT8_T_DECLARED | ||||
| typedef	__uint8_t	uint8_t; | ||||
| #define	_UINT8_T_DECLARED | ||||
| #endif | ||||
|  | ||||
| #define _UINT16_T_DECLARED | ||||
| #ifndef _UINT16_T_DECLARED | ||||
| typedef	__uint16_t	uint16_t; | ||||
| #define	_UINT16_T_DECLARED | ||||
| #endif | ||||
|   | ||||
| #define _UINT32_T_DECLARED | ||||
| #ifndef _UINT32_T_DECLARED | ||||
| typedef	__uint32_t	uint32_t; | ||||
| #define	_UINT32_T_DECLARED | ||||
| #endif | ||||
|   | ||||
| #define _UINT64_T_DECLARED | ||||
| #ifndef _UINT64_T_DECLARED | ||||
| typedef	__uint64_t	uint64_t; | ||||
| #define	_UINT64_T_DECLARED | ||||
| #endif | ||||
|   | ||||
| /* | ||||
|  * General byte order swapping functions. | ||||
|  */ | ||||
| #define	bswap16(x)	__bswap16(x) | ||||
| #define	bswap32(x)	__bswap32(x) | ||||
| #define	bswap64(x)	__bswap64(x) | ||||
|  | ||||
| /* | ||||
|  * Host to big endian, host to little endian, big endian to host, and little | ||||
|  * endian to host byte order functions as detailed in byteorder(9). | ||||
|  */ | ||||
| #if BYTE_ORDER == _LITTLE_ENDIAN | ||||
| #define	htobe16(x)	bswap16((x)) | ||||
| #define	htobe32(x)	bswap32((x)) | ||||
| #define	htobe64(x)	bswap64((x)) | ||||
| #define	htole16(x)	((uint16_t)(x)) | ||||
| #define	htole32(x)	((uint32_t)(x)) | ||||
| #define	htole64(x)	((uint64_t)(x)) | ||||
|  | ||||
| #define	be16toh(x)	bswap16((x)) | ||||
| #define	be32toh(x)	bswap32((x)) | ||||
| #define	be64toh(x)	bswap64((x)) | ||||
| #define	le16toh(x)	((uint16_t)(x)) | ||||
| #define	le32toh(x)	((uint32_t)(x)) | ||||
| #define	le64toh(x)	((uint64_t)(x)) | ||||
|  | ||||
| #else /* _BYTE_ORDER != _LITTLE_ENDIAN */ | ||||
| #define	htobe16(x)	((uint16_t)(x)) | ||||
| #define	htobe32(x)	((uint32_t)(x)) | ||||
| #define	htobe64(x)	((uint64_t)(x)) | ||||
| #define	htole16(x)	bswap16((x)) | ||||
| #define	htole32(x)	bswap32((x)) | ||||
| #define	htole64(x)	bswap64((x)) | ||||
|  | ||||
| #define	be16toh(x)	((uint16_t)(x)) | ||||
| #define	be32toh(x)	((uint32_t)(x)) | ||||
| #define	be64toh(x)	((uint64_t)(x)) | ||||
| #define	le16toh(x)	bswap16((x)) | ||||
| #define	le32toh(x)	bswap32((x)) | ||||
| #define	le64toh(x)	bswap64((x)) | ||||
| #endif /* _BYTE_ORDER == _LITTLE_ENDIAN */ | ||||
|  | ||||
| /* Alignment-agnostic encode/decode bytestream to/from little/big endian. */ | ||||
| #define INLINE                  __inline__ | ||||
|  | ||||
| static INLINE uint16_t | ||||
| be16dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return ((p[0] << 8) | p[1]); | ||||
| } | ||||
|  | ||||
| static INLINE uint32_t | ||||
| be32dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return (((unsigned)p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3]); | ||||
| } | ||||
|  | ||||
| static INLINE uint64_t | ||||
| be64dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return (((uint64_t)be32dec(p) << 32) | be32dec(p + 4)); | ||||
| } | ||||
|  | ||||
| static INLINE uint16_t | ||||
| le16dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return ((p[1] << 8) | p[0]); | ||||
| } | ||||
|  | ||||
| static INLINE uint32_t | ||||
| le32dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return (((unsigned)p[3] << 24) | (p[2] << 16) | (p[1] << 8) | p[0]); | ||||
| } | ||||
|  | ||||
| static INLINE uint64_t | ||||
| le64dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return (((uint64_t)le32dec(p + 4) << 32) | le32dec(p)); | ||||
| } | ||||
|  | ||||
| static INLINE void | ||||
| be16enc(void *pp, uint16_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	p[0] = (u >> 8) & 0xff; | ||||
| 	p[1] = u & 0xff; | ||||
| } | ||||
|  | ||||
| static INLINE void | ||||
| be32enc(void *pp, uint32_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	p[0] = (u >> 24) & 0xff; | ||||
| 	p[1] = (u >> 16) & 0xff; | ||||
| 	p[2] = (u >> 8) & 0xff; | ||||
| 	p[3] = u & 0xff; | ||||
| } | ||||
|  | ||||
| static INLINE void | ||||
| be64enc(void *pp, uint64_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	be32enc(p, (uint32_t)(u >> 32)); | ||||
| 	be32enc(p + 4, (uint32_t)(u & 0xffffffffU)); | ||||
| } | ||||
|  | ||||
| static INLINE void | ||||
| le16enc(void *pp, uint16_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	p[0] = u & 0xff; | ||||
| 	p[1] = (u >> 8) & 0xff; | ||||
| } | ||||
|  | ||||
| static INLINE void | ||||
| le32enc(void *pp, uint32_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	p[0] = u & 0xff; | ||||
| 	p[1] = (u >> 8) & 0xff; | ||||
| 	p[2] = (u >> 16) & 0xff; | ||||
| 	p[3] = (u >> 24) & 0xff; | ||||
| } | ||||
|  | ||||
| static INLINE void | ||||
| le64enc(void *pp, uint64_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	le32enc(p, (uint32_t)(u & 0xffffffffU)); | ||||
| 	le32enc(p + 4, (uint32_t)(u >> 32)); | ||||
| } | ||||
|  | ||||
| #endif	/* _ENDIAN_H_ */ | ||||
							
								
								
									
										306
									
								
								tools/sdk/esp32s2/include/wpa_supplicant/port/include/os.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										306
									
								
								tools/sdk/esp32s2/include/wpa_supplicant/port/include/os.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,306 @@ | ||||
| /* | ||||
|  * OS specific functions | ||||
|  * Copyright (c) 2005-2009, Jouni Malinen <j@w1.fi> | ||||
|  * | ||||
|  * This program is free software; you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License version 2 as | ||||
|  * published by the Free Software Foundation. | ||||
|  * | ||||
|  * Alternatively, this software may be distributed under the terms of BSD | ||||
|  * license. | ||||
|  * | ||||
|  * See README and COPYING for more details. | ||||
|  */ | ||||
|  | ||||
| #ifndef OS_H | ||||
| #define OS_H | ||||
| #include "esp_types.h" | ||||
| #include <string.h> | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include "esp_err.h" | ||||
| // #include "esp32/rom/ets_sys.h" | ||||
|  | ||||
| typedef time_t os_time_t; | ||||
|  | ||||
| /** | ||||
|  * os_sleep - Sleep (sec, usec) | ||||
|  * @sec: Number of seconds to sleep | ||||
|  * @usec: Number of microseconds to sleep | ||||
|  */ | ||||
| void os_sleep(os_time_t sec, os_time_t usec); | ||||
|  | ||||
| struct os_time { | ||||
| 	os_time_t sec; | ||||
| 	suseconds_t usec; | ||||
| }; | ||||
|  | ||||
| struct os_tm { | ||||
|     int sec; /* 0..59 or 60 for leap seconds */ | ||||
|     int min; /* 0..59 */ | ||||
|     int hour; /* 0..23 */ | ||||
|     int day; /* 1..31 */ | ||||
|     int month; /* 1..12 */ | ||||
|     int year; /* Four digit year */ | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * os_get_time - Get current time (sec, usec) | ||||
|  * @t: Pointer to buffer for the time | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  */ | ||||
| int os_get_time(struct os_time *t); | ||||
|  | ||||
|  | ||||
| /* Helper macros for handling struct os_time */ | ||||
|  | ||||
| #define os_time_before(a, b) \ | ||||
| 	((a)->sec < (b)->sec || \ | ||||
| 	 ((a)->sec == (b)->sec && (a)->usec < (b)->usec)) | ||||
|  | ||||
| #define os_time_sub(a, b, res) do { \ | ||||
| 	(res)->sec = (a)->sec - (b)->sec; \ | ||||
| 	(res)->usec = (a)->usec - (b)->usec; \ | ||||
| 	if ((res)->usec < 0) { \ | ||||
| 		(res)->sec--; \ | ||||
| 		(res)->usec += 1000000; \ | ||||
| 	} \ | ||||
| } while (0) | ||||
|  | ||||
| /** | ||||
|  * os_mktime - Convert broken-down time into seconds since 1970-01-01 | ||||
|  * @year: Four digit year | ||||
|  * @month: Month (1 .. 12) | ||||
|  * @day: Day of month (1 .. 31) | ||||
|  * @hour: Hour (0 .. 23) | ||||
|  * @min: Minute (0 .. 59) | ||||
|  * @sec: Second (0 .. 60) | ||||
|  * @t: Buffer for returning calendar time representation (seconds since | ||||
|  * 1970-01-01 00:00:00) | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  * | ||||
|  * Note: The result is in seconds from Epoch, i.e., in UTC, not in local time | ||||
|  * which is used by POSIX mktime(). | ||||
|  */ | ||||
| int os_mktime(int year, int month, int day, int hour, int min, int sec, | ||||
| 	      os_time_t *t); | ||||
|  | ||||
| int os_gmtime(os_time_t t, struct os_tm *tm); | ||||
|  | ||||
| /** | ||||
|  * os_daemonize - Run in the background (detach from the controlling terminal) | ||||
|  * @pid_file: File name to write the process ID to or %NULL to skip this | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  */ | ||||
| int os_daemonize(const char *pid_file); | ||||
|  | ||||
| /** | ||||
|  * os_daemonize_terminate - Stop running in the background (remove pid file) | ||||
|  * @pid_file: File name to write the process ID to or %NULL to skip this | ||||
|  */ | ||||
| void os_daemonize_terminate(const char *pid_file); | ||||
|  | ||||
| /** | ||||
|  * os_get_random - Get cryptographically strong pseudo random data | ||||
|  * @buf: Buffer for pseudo random data | ||||
|  * @len: Length of the buffer | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  */ | ||||
| int os_get_random(unsigned char *buf, size_t len); | ||||
|  | ||||
| /** | ||||
|  * os_random - Get pseudo random value (not necessarily very strong) | ||||
|  * Returns: Pseudo random value | ||||
|  */ | ||||
| unsigned long os_random(void); | ||||
|  | ||||
| /** | ||||
|  * os_rel2abs_path - Get an absolute path for a file | ||||
|  * @rel_path: Relative path to a file | ||||
|  * Returns: Absolute path for the file or %NULL on failure | ||||
|  * | ||||
|  * This function tries to convert a relative path of a file to an absolute path | ||||
|  * in order for the file to be found even if current working directory has | ||||
|  * changed. The returned value is allocated and caller is responsible for | ||||
|  * freeing it. It is acceptable to just return the same path in an allocated | ||||
|  * buffer, e.g., return strdup(rel_path). This function is only used to find | ||||
|  * configuration files when os_daemonize() may have changed the current working | ||||
|  * directory and relative path would be pointing to a different location. | ||||
|  */ | ||||
| char * os_rel2abs_path(const char *rel_path); | ||||
|  | ||||
| /** | ||||
|  * os_program_init - Program initialization (called at start) | ||||
|  * Returns: 0 on success, -1 on failure | ||||
|  * | ||||
|  * This function is called when a programs starts. If there are any OS specific | ||||
|  * processing that is needed, it can be placed here. It is also acceptable to | ||||
|  * just return 0 if not special processing is needed. | ||||
|  */ | ||||
| int os_program_init(void); | ||||
|  | ||||
| /** | ||||
|  * os_program_deinit - Program deinitialization (called just before exit) | ||||
|  * | ||||
|  * This function is called just before a program exists. If there are any OS | ||||
|  * specific processing, e.g., freeing resourced allocated in os_program_init(), | ||||
|  * it should be done here. It is also acceptable for this function to do | ||||
|  * nothing. | ||||
|  */ | ||||
| void os_program_deinit(void); | ||||
|  | ||||
| /** | ||||
|  * os_setenv - Set environment variable | ||||
|  * @name: Name of the variable | ||||
|  * @value: Value to set to the variable | ||||
|  * @overwrite: Whether existing variable should be overwritten | ||||
|  * Returns: 0 on success, -1 on error | ||||
|  * | ||||
|  * This function is only used for wpa_cli action scripts. OS wrapper does not | ||||
|  * need to implement this if such functionality is not needed. | ||||
|  */ | ||||
| int os_setenv(const char *name, const char *value, int overwrite); | ||||
|  | ||||
| /** | ||||
|  * os_unsetenv - Delete environent variable | ||||
|  * @name: Name of the variable | ||||
|  * Returns: 0 on success, -1 on error | ||||
|  * | ||||
|  * This function is only used for wpa_cli action scripts. OS wrapper does not | ||||
|  * need to implement this if such functionality is not needed. | ||||
|  */ | ||||
| int os_unsetenv(const char *name); | ||||
|  | ||||
| /** | ||||
|  * os_readfile - Read a file to an allocated memory buffer | ||||
|  * @name: Name of the file to read | ||||
|  * @len: For returning the length of the allocated buffer | ||||
|  * Returns: Pointer to the allocated buffer or %NULL on failure | ||||
|  * | ||||
|  * This function allocates memory and reads the given file to this buffer. Both | ||||
|  * binary and text files can be read with this function. The caller is | ||||
|  * responsible for freeing the returned buffer with os_free(). | ||||
|  */ | ||||
| char * os_readfile(const char *name, size_t *len); | ||||
|  | ||||
| /* | ||||
|  * The following functions are wrapper for standard ANSI C or POSIX functions. | ||||
|  * By default, they are just defined to use the standard function name and no | ||||
|  * os_*.c implementation is needed for them. This avoids extra function calls | ||||
|  * by allowing the C pre-processor take care of the function name mapping. | ||||
|  * | ||||
|  * If the target system uses a C library that does not provide these functions, | ||||
|  * build_config.h can be used to define the wrappers to use a different | ||||
|  * function name. This can be done on function-by-function basis since the | ||||
|  * defines here are only used if build_config.h does not define the os_* name. | ||||
|  * If needed, os_*.c file can be used to implement the functions that are not | ||||
|  * included in the C library on the target system. Alternatively, | ||||
|  * OS_NO_C_LIB_DEFINES can be defined to skip all defines here in which case | ||||
|  * these functions need to be implemented in os_*.c file for the target system. | ||||
|  */ | ||||
|  | ||||
| #ifndef os_malloc | ||||
| #define os_malloc(s) malloc((s)) | ||||
| #endif | ||||
| #ifndef os_realloc | ||||
| #define os_realloc(p, s) realloc((p), (s)) | ||||
| #endif | ||||
| #ifndef os_zalloc | ||||
| #define os_zalloc(s) calloc(1, (s)) | ||||
| #endif | ||||
| #ifndef os_free | ||||
| #define os_free(p) free((p)) | ||||
| #endif | ||||
|  | ||||
| #ifndef os_bzero | ||||
| #define os_bzero(s, n) bzero(s, n) | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #ifndef os_strdup | ||||
| #ifdef _MSC_VER | ||||
| #define os_strdup(s) _strdup(s) | ||||
| #else | ||||
| #define os_strdup(s) strdup(s) | ||||
| #endif | ||||
| #endif | ||||
| char * ets_strdup(const char *s); | ||||
|  | ||||
| #ifndef os_memcpy | ||||
| #define os_memcpy(d, s, n) memcpy((d), (s), (n)) | ||||
| #endif | ||||
| #ifndef os_memmove | ||||
| #define os_memmove(d, s, n) memmove((d), (s), (n)) | ||||
| #endif | ||||
| #ifndef os_memset | ||||
| #define os_memset(s, c, n) memset(s, c, n) | ||||
| #endif | ||||
| #ifndef os_memcmp | ||||
| #define os_memcmp(s1, s2, n) memcmp((s1), (s2), (n)) | ||||
| #endif | ||||
| #ifndef os_memcmp_const | ||||
| #define os_memcmp_const(s1, s2, n) memcmp((s1), (s2), (n)) | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #ifndef os_strlen | ||||
| #define os_strlen(s) strlen(s) | ||||
| #endif | ||||
| #ifndef os_strcasecmp | ||||
| #ifdef _MSC_VER | ||||
| #define os_strcasecmp(s1, s2) _stricmp((s1), (s2)) | ||||
| #else | ||||
| #define os_strcasecmp(s1, s2) strcasecmp((s1), (s2)) | ||||
| #endif | ||||
| #endif | ||||
| #ifndef os_strncasecmp | ||||
| #ifdef _MSC_VER | ||||
| #define os_strncasecmp(s1, s2, n) _strnicmp((s1), (s2), (n)) | ||||
| #else | ||||
| #define os_strncasecmp(s1, s2, n) strncasecmp((s1), (s2), (n)) | ||||
| #endif | ||||
| #endif | ||||
| #ifndef os_strchr | ||||
| #define os_strchr(s, c) strchr((s), (c)) | ||||
| #endif | ||||
| #ifndef os_strcmp | ||||
| #define os_strcmp(s1, s2) strcmp((s1), (s2)) | ||||
| #endif | ||||
| #ifndef os_strncmp | ||||
| #define os_strncmp(s1, s2, n) strncmp((s1), (s2), (n)) | ||||
| #endif | ||||
| #ifndef os_strncpy | ||||
| #define os_strncpy(d, s, n) strncpy((d), (s), (n)) | ||||
| #endif | ||||
| #ifndef os_strrchr | ||||
| #define os_strrchr(s, c)  strrchr((s), (c)) | ||||
| #endif | ||||
| #ifndef os_strstr | ||||
| #define os_strstr(h, n) strstr((h), (n)) | ||||
| #endif | ||||
|  | ||||
| #ifndef os_snprintf | ||||
| #ifdef _MSC_VER | ||||
| #define os_snprintf _snprintf | ||||
| #else | ||||
| #define os_snprintf snprintf | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| static inline int os_snprintf_error(size_t size, int res) | ||||
| { | ||||
|         return res < 0 || (unsigned int) res >= size; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * os_strlcpy - Copy a string with size bound and NUL-termination | ||||
|  * @dest: Destination | ||||
|  * @src: Source | ||||
|  * @siz: Size of the target buffer | ||||
|  * Returns: Total length of the target string (length of src) (not including | ||||
|  * NUL-termination) | ||||
|  * | ||||
|  * This function matches in behavior with the strlcpy(3) function in OpenBSD. | ||||
|  */ | ||||
| size_t os_strlcpy(char *dest, const char *src, size_t siz); | ||||
| #endif /* OS_H */ | ||||
| @@ -0,0 +1,32 @@ | ||||
| // 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 _SUPPLICANT_OPT_H | ||||
| #define _SUPPLICANT_OPT_H | ||||
|  | ||||
| #include "sdkconfig.h" | ||||
|  | ||||
| #if CONFIG_WPA_MBEDTLS_CRYPTO | ||||
| #define USE_MBEDTLS_CRYPTO 1 | ||||
| #endif | ||||
|  | ||||
| #if CONFIG_WPA_DEBUG_PRINT | ||||
| #define DEBUG_PRINT | ||||
| #endif | ||||
|  | ||||
| #if CONFIG_WPA_TLS_V12 | ||||
| #define CONFIG_TLSV12 | ||||
| #endif | ||||
|  | ||||
| #endif /* _SUPPLICANT_OPT_H */ | ||||
		Reference in New Issue
	
	Block a user