mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-31 15:11:40 +01:00 
			
		
		
		
	Fix dependency tree so that lwip doesn't depend on any specific network interface component. Network interface drivers shall depend on esp_netif. esp_netif shall depend on lwip (but not on any specific interface driver) -- it optionally depends on vfs and esp_eth (need ethernet header for L2/bridge mode)
		
			
				
	
	
		
			107 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			107 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * SPDX-FileCopyrightText: 2015-2022 Espressif Systems (Shanghai) CO LTD
 | |
|  *
 | |
|  * SPDX-License-Identifier: Apache-2.0
 | |
|  */
 | |
| 
 | |
| #ifndef _ESP_NETIF_NET_STACK_H_
 | |
| #define _ESP_NETIF_NET_STACK_H_
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| //
 | |
| // Network stack API: This ESP-NETIF API are supposed to be called only from internals of TCP/IP stack
 | |
| //
 | |
| 
 | |
| /** @addtogroup ESP_NETIF_CONVERT
 | |
|  * @{
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * @brief Returns esp-netif handle
 | |
|  *
 | |
|  * @param[in] dev opaque ptr to network interface of specific TCP/IP stack
 | |
|  *
 | |
|  * @return    handle to related esp-netif instance
 | |
|  */
 | |
| esp_netif_t* esp_netif_get_handle_from_netif_impl(void *dev);
 | |
| 
 | |
| /**
 | |
|  * @brief Returns network stack specific implementation handle (if supported)
 | |
|  *
 | |
|  * Note that it is not supported to acquire PPP netif impl pointer and
 | |
|  * this function will return NULL for esp_netif instances configured to PPP mode
 | |
|  *
 | |
|  * @param[in]  esp_netif Handle to esp-netif instance
 | |
|  *
 | |
|  * @return    handle to related network stack netif handle
 | |
|  */
 | |
| void* esp_netif_get_netif_impl(esp_netif_t *esp_netif);
 | |
| 
 | |
| /**
 | |
|  * @brief Set link-speed for the specified network interface
 | |
|  * @param[in] esp_netif Handle to esp-netif instance
 | |
|  * @param[in] speed  Link speed in bit/s
 | |
|  * @return ESP_OK on success
 | |
|  */
 | |
| esp_err_t esp_netif_set_link_speed(esp_netif_t *esp_netif, uint32_t speed);
 | |
| 
 | |
| /**
 | |
|  * @}
 | |
|  */
 | |
| 
 | |
| /** @addtogroup ESP_NETIF_DATA_IO_API
 | |
|  * @{
 | |
|  */
 | |
| 
 | |
| /**
 | |
|   * @brief  Outputs packets from the TCP/IP stack to the media to be transmitted
 | |
|   *
 | |
|   * This function gets called from network stack to output packets to IO driver.
 | |
|   *
 | |
|   * @param[in]  esp_netif Handle to esp-netif instance
 | |
|   * @param[in]  data Data to be transmitted
 | |
|   * @param[in]  len Length of the data frame
 | |
|   *
 | |
|   * @return   ESP_OK on success, an error passed from the I/O driver otherwise
 | |
|   */
 | |
| esp_err_t esp_netif_transmit(esp_netif_t *esp_netif, void* data, size_t len);
 | |
| 
 | |
| /**
 | |
|   * @brief  Outputs packets from the TCP/IP stack to the media to be transmitted
 | |
|   *
 | |
|   * This function gets called from network stack to output packets to IO driver.
 | |
|   *
 | |
|   * @param[in]  esp_netif Handle to esp-netif instance
 | |
|   * @param[in]  data Data to be transmitted
 | |
|   * @param[in]  len Length of the data frame
 | |
|   * @param[in]  netstack_buf net stack buffer
 | |
|   *
 | |
|   * @return   ESP_OK on success, an error passed from the I/O driver otherwise
 | |
|   */
 | |
| esp_err_t esp_netif_transmit_wrap(esp_netif_t *esp_netif, void *data, size_t len, void *netstack_buf);
 | |
| 
 | |
| /**
 | |
|   * @brief  Free the rx buffer allocated by the media driver
 | |
|   *
 | |
|   * This function gets called from network stack when the rx buffer to be freed in IO driver context,
 | |
|   * i.e. to deallocate a buffer owned by io driver (when data packets were passed to higher levels
 | |
|   * to avoid copying)
 | |
|   *
 | |
|   * @param[in]  esp_netif Handle to esp-netif instance
 | |
|   * @param[in]  buffer Rx buffer pointer
 | |
|   */
 | |
| void esp_netif_free_rx_buffer(void *esp_netif, void* buffer);
 | |
| 
 | |
| /**
 | |
|  * @}
 | |
|  */
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif //_ESP_NETIF_NET_STACK_H_
 |