mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-11-04 00:51:42 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			119 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
// 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
 |