mirror of
				https://github.com/espressif/ESP8266_RTOS_SDK.git
				synced 2025-10-20 22:31:30 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			240 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			240 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // 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.
 | |
| 
 | |
| #include <stdio.h>
 | |
| #include <string.h>
 | |
| #include "sdkconfig.h"
 | |
| #include "esp_libc.h"
 | |
| #include "esp_system.h"
 | |
| #include "esp_wifi.h"
 | |
| #include "esp_log.h"
 | |
| #include "esp_private/wifi.h"
 | |
| #include "phy.h"
 | |
| #include "esp_supplicant/esp_wpa.h"
 | |
| #include "esp_aio.h"
 | |
| 
 | |
| #define TAG "wifi_init"
 | |
| 
 | |
| const size_t _g_esp_wifi_ppt_task_stk_size = CONFIG_WIFI_PPT_TASKSTACK_SIZE;
 | |
| 
 | |
| #if CONFIG_ESP8266_WIFI_CONNECT_OPEN_ROUTER_WHEN_PWD_IS_SET
 | |
| const bool _g_esp_wifi_connect_open_router_when_pwd_is_set = true;
 | |
| #else
 | |
| const bool _g_esp_wifi_connect_open_router_when_pwd_is_set = false;
 | |
| #endif
 | |
| 
 | |
| #define  EP_OFFSET 36
 | |
| int ieee80211_output_pbuf(esp_aio_t *aio);
 | |
| 
 | |
| esp_err_t mac_init(void);
 | |
| 
 | |
| ESP_EVENT_DEFINE_BASE(WIFI_EVENT);
 | |
| 
 | |
| static void esp_wifi_set_debug_log()
 | |
| {
 | |
|     /* set WiFi log level and module */
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_ENABLE
 | |
|     uint32_t wifi_log_level = WIFI_LOG_ERROR;
 | |
|     uint32_t wifi_log_submodule = WIFI_LOG_SUBMODULE_NULL;
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_WARNING
 | |
|     wifi_log_level = WIFI_LOG_WARNING;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_INFO
 | |
|     wifi_log_level = WIFI_LOG_INFO;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_DEBUG
 | |
|     wifi_log_level = WIFI_LOG_DEBUG;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_VERBOSE
 | |
|     wifi_log_level = WIFI_LOG_VERBOSE;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_CORE
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_CORE;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_SCAN
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_SCAN;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_PM
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_PM;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_NVS
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_NVS;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_TRC
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_TRC;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_EBUF
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_EBUF;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_NET80211
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_NET80211;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_TIMER
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_TIMER;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_ESPNOW
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_ESPNOW;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_MAC
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_MAC;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_WPA
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_WPA;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_WPS
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_WPS;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_AMPDU
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_AMPDU;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_AMSDU
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_AMSDU;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_FRAG
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_FRAG;
 | |
| #endif
 | |
| #if CONFIG_ESP8266_WIFI_DEBUG_LOG_SUBMODULE_WPA2
 | |
|     wifi_log_submodule |= WIFI_LOG_SUBMODULE_WPA2;
 | |
| #endif
 | |
|     esp_wifi_internal_set_log_level(wifi_log_level);
 | |
|     esp_wifi_internal_set_log_mod(wifi_log_submodule);
 | |
| #else
 | |
|     esp_wifi_internal_set_log_level(WIFI_LOG_ERROR);
 | |
|     esp_wifi_internal_set_log_mod(WIFI_LOG_SUBMODULE_NULL);
 | |
| #endif /* CONFIG_ESP8266_WIFI_DEBUG_LOG_ENABLE*/
 | |
| }
 | |
| 
 | |
| esp_err_t esp_wifi_deinit(void)
 | |
| {
 | |
|     esp_err_t err = ESP_OK;
 | |
| 
 | |
|     esp_supplicant_deinit();
 | |
|     err = esp_wifi_deinit_internal();
 | |
|     if (err != ESP_OK) {
 | |
|         ESP_LOGE(TAG, "Failed to deinit Wi-Fi driver (0x%x)", err);
 | |
|         return err;
 | |
|     }
 | |
|     return err;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   * @brief  Init WiFi
 | |
|   *         Alloc resource for WiFi driver, such as WiFi control structure, RX/TX buffer,
 | |
|   *         WiFi NVS structure etc, this WiFi also start WiFi task
 | |
|   *
 | |
|   * @attention 1. This API must be called before all other WiFi API can be called
 | |
|   * @attention 2. Always use WIFI_INIT_CONFIG_DEFAULT macro to init the config to default values, this can
 | |
|   *               guarantee all the fields got correct value when more fields are added into wifi_init_config_t
 | |
|   *               in future release. If you want to set your owner initial values, overwrite the default values
 | |
|   *               which are set by WIFI_INIT_CONFIG_DEFAULT, please be notified that the field 'magic' of 
 | |
|   *               wifi_init_config_t should always be WIFI_INIT_CONFIG_MAGIC!
 | |
|   *
 | |
|   * @param  config pointer to WiFi init configuration structure; can point to a temporary variable.
 | |
|   *
 | |
|   * @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(const wifi_init_config_t *config)
 | |
| {
 | |
|     mac_init();
 | |
| 
 | |
|     esp_wifi_set_rx_pbuf_mem_type(WIFI_RX_PBUF_DRAM);
 | |
| 
 | |
|     esp_err_t result = esp_wifi_init_internal(config);
 | |
|     if (result == ESP_OK) {
 | |
|         esp_wifi_set_debug_log();
 | |
|         result = esp_supplicant_init();
 | |
|         if (result != ESP_OK) {
 | |
|             ESP_LOGE(TAG, "Failed to init supplicant (0x%x)", result);
 | |
|             esp_err_t deinit_ret = esp_wifi_deinit();
 | |
|             if (deinit_ret != ESP_OK) {
 | |
|                 ESP_LOGE(TAG, "Failed to deinit Wi-Fi (0x%x)", deinit_ret);
 | |
|             }
 | |
| 
 | |
|             return result;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     result = tcpip_adapter_set_default_wifi_handlers();
 | |
|     if (result != ESP_OK) {
 | |
|         ESP_LOGW(TAG, "Failed to set default Wi-Fi event handlers (0x%x)", result);
 | |
|     }
 | |
| 
 | |
|     return result;
 | |
| }
 | |
| 
 | |
| void esp_deep_sleep_set_rf_option(uint8_t option)
 | |
| {
 | |
|     phy_afterwake_set_rfoption(option);
 | |
| }
 | |
| 
 | |
| size_t __attribute__((weak)) esp_wifi_scan_get_ap_num_max(void)
 | |
| {
 | |
|     return CONFIG_SCAN_AP_MAX;
 | |
| }
 | |
| 
 | |
| bool IRAM_ATTR esp_wifi_try_rate_from_high(void) {
 | |
| #if CONFIG_WIFI_TX_RATE_SEQUENCE_FROM_HIGH
 | |
|     int8_t rssi;
 | |
|     rssi = esp_wifi_get_ap_rssi();
 | |
|     wifi_mode_t mode;
 | |
|     esp_wifi_get_mode( &mode );
 | |
|     if (rssi < -26 && mode == WIFI_MODE_STA) {
 | |
|         return true;
 | |
|     }
 | |
| #endif
 | |
|     return false;
 | |
| }
 | |
| 
 | |
| int wifi_internal_send_cb(esp_aio_t* aio)
 | |
| {
 | |
|     char* pb = (char*)aio->arg;
 | |
| 
 | |
|     if (pb) {
 | |
|         os_free(pb);
 | |
|         pb = NULL;
 | |
|     }
 | |
| 
 | |
|     return ESP_OK;
 | |
| }
 | |
| 
 | |
| int esp_wifi_internal_tx(wifi_interface_t wifi_if, void *buffer, uint16_t len)
 | |
| {
 | |
|     esp_aio_t aio;
 | |
|     esp_err_t ret = ESP_OK;
 | |
|     uint8_t *dram_buffer = (uint8_t *)heap_caps_malloc(len + EP_OFFSET, MALLOC_CAP_8BIT);
 | |
|     if (!dram_buffer) {
 | |
|         return ESP_ERR_NO_MEM;
 | |
|     }
 | |
|     dram_buffer = ((uint8_t *)dram_buffer + EP_OFFSET);
 | |
|     memcpy(dram_buffer, buffer, len);
 | |
| 
 | |
|     aio.arg = (char *)dram_buffer - EP_OFFSET;
 | |
|     aio.cb = wifi_internal_send_cb;
 | |
|     aio.fd = wifi_if;
 | |
|     aio.pbuf = (char *)dram_buffer;
 | |
|     aio.len = len;
 | |
|     aio.ret = 0;
 | |
|     ret = ieee80211_output_pbuf(&aio);
 | |
| 
 | |
|     if(ret != 0) {
 | |
|         os_free(aio.arg);
 | |
|     }
 | |
| 
 | |
|     return ret;
 | |
| }
 | |
| 
 | 
