mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-25 11:23:22 +00:00 
			
		
		
		
	Merge branch 'feature/sperate_esp_netif_component_v4.3' into 'release/v4.3'
esp_netif: Add CONFIG_PPP_SUPPORT and CONFIG_LWIP_SLIP_SUPPORT to sperate the code(backport v4.3) See merge request espressif/esp-idf!14158
This commit is contained in:
		| @@ -1,12 +1,30 @@ | |||||||
| idf_component_register(SRCS "esp_netif_handlers.c" | set(srcs | ||||||
|                             "esp_netif_objects.c" |     "esp_netif_handlers.c" | ||||||
|                             "esp_netif_defaults.c" |     "esp_netif_objects.c" | ||||||
|                             "lwip/esp_netif_lwip.c" |     "esp_netif_defaults.c" | ||||||
|                             "lwip/esp_netif_lwip_ppp.c" |     "lwip/esp_netif_lwip.c" | ||||||
|                             "lwip/esp_netif_lwip_slip.c" |     "lwip/esp_netif_lwip_defaults.c" | ||||||
|                             "loopback/esp_netif_loopback.c" |     "lwip/esp_netif_sta_list.c") | ||||||
|                             "lwip/esp_netif_lwip_defaults.c" |  | ||||||
|                             "lwip/esp_netif_sta_list.c" | set(include_dirs "include") | ||||||
|                     INCLUDE_DIRS include | set(priv_include_dirs "lwip" "private_include") | ||||||
|                     PRIV_INCLUDE_DIRS lwip private_include |  | ||||||
|  | if(CONFIG_LWIP_SLIP_SUPPORT) | ||||||
|  | list(APPEND srcs | ||||||
|  |     "lwip/esp_netif_lwip_slip.c") | ||||||
|  | endif() | ||||||
|  |  | ||||||
|  | if(CONFIG_PPP_SUPPORT) | ||||||
|  | list(APPEND srcs | ||||||
|  |     "lwip/esp_netif_lwip_ppp.c") | ||||||
|  | endif() | ||||||
|  |  | ||||||
|  | if(CONFIG_LWIP_NETIF_LOOPBACK) | ||||||
|  | list(APPEND srcs | ||||||
|  |     "loopback/esp_netif_loopback.c") | ||||||
|  | endif() | ||||||
|  |  | ||||||
|  | idf_component_register(SRCS "${srcs}" | ||||||
|  |                     INCLUDE_DIRS "${include_dirs}" | ||||||
|  |                     PRIV_INCLUDE_DIRS "${priv_include_dirs}" | ||||||
|                     REQUIRES lwip esp_eth tcpip_adapter) |                     REQUIRES lwip esp_eth tcpip_adapter) | ||||||
|   | |||||||
| @@ -4,3 +4,15 @@ | |||||||
| COMPONENT_ADD_INCLUDEDIRS := include | COMPONENT_ADD_INCLUDEDIRS := include | ||||||
| COMPONENT_PRIV_INCLUDEDIRS := private_include lwip | COMPONENT_PRIV_INCLUDEDIRS := private_include lwip | ||||||
| COMPONENT_SRCDIRS := . lwip loopback | COMPONENT_SRCDIRS := . lwip loopback | ||||||
|  |  | ||||||
|  | ifndef CONFIG_LWIP_SLIP_SUPPORT | ||||||
|  |     COMPONENT_OBJEXCLUDE := lwip/esp_netif_lwip_slip.o | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | ifndef CONFIG_PPP_SUPPORT | ||||||
|  |     COMPONENT_OBJEXCLUDE += lwip/esp_netif_lwip_ppp.o | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | ifndef CONFIG_LWIP_NETIF_LOOPBACK | ||||||
|  |     COMPONENT_OBJEXCLUDE += loopback/esp_netif_loopback.o | ||||||
|  | endif | ||||||
|   | |||||||
| @@ -76,4 +76,7 @@ void esp_netif_lwip_slip_raw_output(esp_netif_t *netif, void *buffer, size_t len | |||||||
|  */ |  */ | ||||||
| const esp_ip6_addr_t *esp_slip_get_ip6(esp_netif_t *slip_netif); | const esp_ip6_addr_t *esp_slip_get_ip6(esp_netif_t *slip_netif); | ||||||
|  |  | ||||||
|  | #ifdef __cplusplus | ||||||
|  | } | ||||||
| #endif | #endif | ||||||
|  | #endif //_ESP_NETIF_SLIP_H_ | ||||||
|   | |||||||
| @@ -60,8 +60,11 @@ | |||||||
| /** | /** | ||||||
|  * @brief macros to check netif related data to evaluate interface type |  * @brief macros to check netif related data to evaluate interface type | ||||||
|  */ |  */ | ||||||
|  | #if CONFIG_PPP_SUPPORT || CONFIG_LWIP_SLIP_SUPPORT | ||||||
| #define _IS_NETIF_ANY_POINT2POINT_TYPE(netif) (netif->related_data && netif->related_data->is_point2point) | #define _IS_NETIF_ANY_POINT2POINT_TYPE(netif) (netif->related_data && netif->related_data->is_point2point) | ||||||
|  | #else | ||||||
|  | #define _IS_NETIF_ANY_POINT2POINT_TYPE(netif) false | ||||||
|  | #endif | ||||||
| #define _RUN_IN_LWIP_TASK_IF_SUPPORTED(function, netif, param) \ | #define _RUN_IN_LWIP_TASK_IF_SUPPORTED(function, netif, param) \ | ||||||
| {                                                              \ | {                                                              \ | ||||||
|     if (_IS_NETIF_ANY_POINT2POINT_TYPE(netif)) {               \ |     if (_IS_NETIF_ANY_POINT2POINT_TYPE(netif)) {               \ | ||||||
| @@ -169,7 +172,9 @@ static esp_netif_t* esp_netif_is_active(esp_netif_t *arg) | |||||||
| static void esp_netif_set_default_netif(esp_netif_t *esp_netif) | static void esp_netif_set_default_netif(esp_netif_t *esp_netif) | ||||||
| { | { | ||||||
|     if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { |     if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { | ||||||
|  | #if CONFIG_PPP_SUPPORT | ||||||
|         esp_netif_ppp_set_default_netif(esp_netif->netif_handle); |         esp_netif_ppp_set_default_netif(esp_netif->netif_handle); | ||||||
|  | #endif | ||||||
|     } else { |     } else { | ||||||
|         netif_set_default(esp_netif->netif_handle); |         netif_set_default(esp_netif->netif_handle); | ||||||
|     } |     } | ||||||
| @@ -388,6 +393,7 @@ static esp_err_t esp_netif_init_configuration(esp_netif_t *esp_netif, const esp_ | |||||||
|     // Install network stack functions -- connects netif and L3 stack |     // Install network stack functions -- connects netif and L3 stack | ||||||
|     const esp_netif_netstack_config_t *esp_netif_stack_config = cfg->stack; |     const esp_netif_netstack_config_t *esp_netif_stack_config = cfg->stack; | ||||||
|     if (cfg->base->flags & ESP_NETIF_FLAG_IS_PPP) { |     if (cfg->base->flags & ESP_NETIF_FLAG_IS_PPP) { | ||||||
|  | #if CONFIG_PPP_SUPPORT | ||||||
|         esp_netif->related_data = esp_netif_new_ppp(esp_netif, esp_netif_stack_config); |         esp_netif->related_data = esp_netif_new_ppp(esp_netif, esp_netif_stack_config); | ||||||
|         if (esp_netif->related_data == NULL) { |         if (esp_netif->related_data == NULL) { | ||||||
|             return ESP_ERR_ESP_NETIF_INIT_FAILED; |             return ESP_ERR_ESP_NETIF_INIT_FAILED; | ||||||
| @@ -395,8 +401,11 @@ static esp_err_t esp_netif_init_configuration(esp_netif_t *esp_netif, const esp_ | |||||||
|         esp_netif->lwip_input_fn = esp_netif_stack_config->lwip_ppp.input_fn; |         esp_netif->lwip_input_fn = esp_netif_stack_config->lwip_ppp.input_fn; | ||||||
|         // Make the netif handle (used for tcpip input function) the ppp_netif |         // Make the netif handle (used for tcpip input function) the ppp_netif | ||||||
|         esp_netif->netif_handle = esp_netif->related_data; |         esp_netif->netif_handle = esp_netif->related_data; | ||||||
|  | #else | ||||||
|  |         LOG_NETIF_DISABLED_AND_DO("PPP", return ESP_ERR_NOT_SUPPORTED); | ||||||
|  | #endif | ||||||
|     } else if (cfg->base->flags & ESP_NETIF_FLAG_IS_SLIP) { |     } else if (cfg->base->flags & ESP_NETIF_FLAG_IS_SLIP) { | ||||||
|  | #if CONFIG_LWIP_SLIP_SUPPORT | ||||||
|         esp_netif->related_data = esp_netif_new_slip(esp_netif, esp_netif_stack_config); |         esp_netif->related_data = esp_netif_new_slip(esp_netif, esp_netif_stack_config); | ||||||
|         if (esp_netif->related_data == NULL) { |         if (esp_netif->related_data == NULL) { | ||||||
|             return ESP_ERR_ESP_NETIF_INIT_FAILED; |             return ESP_ERR_ESP_NETIF_INIT_FAILED; | ||||||
| @@ -409,7 +418,9 @@ static esp_err_t esp_netif_init_configuration(esp_netif_t *esp_netif, const esp_ | |||||||
|         } |         } | ||||||
|         // Make the netif handle (used for tcpip input function) the esp_netif itself |         // Make the netif handle (used for tcpip input function) the esp_netif itself | ||||||
|         esp_netif->netif_handle = esp_netif; |         esp_netif->netif_handle = esp_netif; | ||||||
|  | #else | ||||||
|  |         LOG_NETIF_DISABLED_AND_DO("SLIP", return ESP_ERR_NOT_SUPPORTED); | ||||||
|  | #endif | ||||||
|     } else { |     } else { | ||||||
|         if (esp_netif_stack_config-> lwip.init_fn) { |         if (esp_netif_stack_config-> lwip.init_fn) { | ||||||
|             esp_netif->lwip_init_fn = esp_netif_stack_config->lwip.init_fn; |             esp_netif->lwip_init_fn = esp_netif_stack_config->lwip.init_fn; | ||||||
| @@ -528,11 +539,15 @@ static esp_err_t esp_netif_lwip_add(esp_netif_t *esp_netif) | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     if (esp_netif->flags & ESP_NETIF_FLAG_IS_PPP) { |     if (esp_netif->flags & ESP_NETIF_FLAG_IS_PPP) { | ||||||
|  | #if CONFIG_PPP_SUPPORT | ||||||
|         err_t err = esp_netif->lwip_init_fn(NULL); |         err_t err = esp_netif->lwip_init_fn(NULL); | ||||||
|         if (err != ERR_OK) { |         if (err != ERR_OK) { | ||||||
|             ESP_LOGE(TAG, "Init netif failed with  %d", err); |             ESP_LOGE(TAG, "Init netif failed with  %d", err); | ||||||
|             return ESP_ERR_ESP_NETIF_INIT_FAILED; |             return ESP_ERR_ESP_NETIF_INIT_FAILED; | ||||||
|         } |         } | ||||||
|  | #else | ||||||
|  |         LOG_NETIF_DISABLED_AND_DO("PPP", return ESP_ERR_NOT_SUPPORTED); | ||||||
|  | #endif | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (NULL == netif_add(esp_netif->lwip_netif, (struct ip4_addr*)&esp_netif->ip_info->ip, |     if (NULL == netif_add(esp_netif->lwip_netif, (struct ip4_addr*)&esp_netif->ip_info->ip, | ||||||
| @@ -547,9 +562,13 @@ static esp_err_t esp_netif_lwip_add(esp_netif_t *esp_netif) | |||||||
| static void esp_netif_destroy_related(esp_netif_t *esp_netif) | static void esp_netif_destroy_related(esp_netif_t *esp_netif) | ||||||
| { | { | ||||||
|     if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { |     if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { | ||||||
|  | #if CONFIG_PPP_SUPPORT | ||||||
|         esp_netif_destroy_ppp(esp_netif->related_data); |         esp_netif_destroy_ppp(esp_netif->related_data); | ||||||
|  | #endif | ||||||
|     } else if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, SLIP_LWIP_NETIF)) { |     } else if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, SLIP_LWIP_NETIF)) { | ||||||
|  | #if CONFIG_LWIP_SLIP_SUPPORT | ||||||
|         esp_netif_destroy_slip(esp_netif->related_data); |         esp_netif_destroy_slip(esp_netif->related_data); | ||||||
|  | #endif | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -695,7 +714,9 @@ static esp_err_t esp_netif_start_api(esp_netif_api_msg_t *msg) | |||||||
|     } |     } | ||||||
|     struct netif *p_netif = esp_netif->lwip_netif; |     struct netif *p_netif = esp_netif->lwip_netif; | ||||||
|     if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, SLIP_LWIP_NETIF)) { |     if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, SLIP_LWIP_NETIF)) { | ||||||
|  | #if CONFIG_LWIP_SLIP_SUPPORT | ||||||
|         esp_netif_start_slip(esp_netif); |         esp_netif_start_slip(esp_netif); | ||||||
|  | #endif | ||||||
|     } |     } | ||||||
|     if (esp_netif->flags&ESP_NETIF_FLAG_AUTOUP) { |     if (esp_netif->flags&ESP_NETIF_FLAG_AUTOUP) { | ||||||
|         ESP_LOGD(TAG, "%s Setting the lwip netif%p UP", __func__, p_netif); |         ESP_LOGD(TAG, "%s Setting the lwip netif%p UP", __func__, p_netif); | ||||||
| @@ -752,12 +773,14 @@ static esp_err_t esp_netif_start_api(esp_netif_api_msg_t *msg) | |||||||
| esp_err_t esp_netif_start(esp_netif_t *esp_netif) | esp_err_t esp_netif_start(esp_netif_t *esp_netif) | ||||||
| { | { | ||||||
|     if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { |     if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { | ||||||
|  | #if CONFIG_PPP_SUPPORT | ||||||
|         // No need to start PPP interface in lwip thread |         // No need to start PPP interface in lwip thread | ||||||
|         esp_err_t ret = esp_netif_start_ppp(esp_netif->related_data); |         esp_err_t ret = esp_netif_start_ppp(esp_netif->related_data); | ||||||
|         if (ret == ESP_OK) { |         if (ret == ESP_OK) { | ||||||
|             esp_netif_update_default_netif(esp_netif, ESP_NETIF_STARTED); |             esp_netif_update_default_netif(esp_netif, ESP_NETIF_STARTED); | ||||||
|         } |         } | ||||||
|         return ret; |         return ret; | ||||||
|  | #endif | ||||||
|     } |     } | ||||||
|     return esp_netif_lwip_ipc_call(esp_netif_start_api, esp_netif, NULL); |     return esp_netif_lwip_ipc_call(esp_netif_start_api, esp_netif, NULL); | ||||||
| } | } | ||||||
| @@ -805,19 +828,23 @@ static esp_err_t esp_netif_stop_api(esp_netif_api_msg_t *msg) | |||||||
| esp_err_t esp_netif_stop(esp_netif_t *esp_netif) | esp_err_t esp_netif_stop(esp_netif_t *esp_netif) | ||||||
| { | { | ||||||
|     if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { |     if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { | ||||||
|  | #if CONFIG_PPP_SUPPORT | ||||||
|         // No need to stop PPP interface in lwip thread |         // No need to stop PPP interface in lwip thread | ||||||
|         esp_err_t ret = esp_netif_stop_ppp(esp_netif->related_data); |         esp_err_t ret = esp_netif_stop_ppp(esp_netif->related_data); | ||||||
|         if (ret == ESP_OK) { |         if (ret == ESP_OK) { | ||||||
|             esp_netif_update_default_netif(esp_netif, ESP_NETIF_STOPPED);; |             esp_netif_update_default_netif(esp_netif, ESP_NETIF_STOPPED);; | ||||||
|         } |         } | ||||||
|         return ret; |         return ret; | ||||||
|  | #endif | ||||||
|     } else if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, SLIP_LWIP_NETIF)) { |     } else if (_IS_NETIF_POINT2POINT_TYPE(esp_netif, SLIP_LWIP_NETIF)) { | ||||||
|         // No need to stop PPP interface in lwip thread | #if CONFIG_LWIP_SLIP_SUPPORT | ||||||
|  |         // No need to stop SLIP interface in lwip thread | ||||||
|         esp_err_t ret = esp_netif_stop_slip(esp_netif); |         esp_err_t ret = esp_netif_stop_slip(esp_netif); | ||||||
|         if (ret == ESP_OK) { |         if (ret == ESP_OK) { | ||||||
|             esp_netif_update_default_netif(esp_netif, ESP_NETIF_STOPPED);; |             esp_netif_update_default_netif(esp_netif, ESP_NETIF_STOPPED);; | ||||||
|         } |         } | ||||||
|         return ret; |         return ret; | ||||||
|  | #endif | ||||||
|     } |     } | ||||||
|     return esp_netif_lwip_ipc_call(esp_netif_stop_api, esp_netif, NULL); |     return esp_netif_lwip_ipc_call(esp_netif_stop_api, esp_netif, NULL); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -70,7 +70,11 @@ typedef struct esp_netif_ip_lost_timer_s { | |||||||
| /** | /** | ||||||
|  * @brief Check the netif if of a specific P2P type |  * @brief Check the netif if of a specific P2P type | ||||||
|  */ |  */ | ||||||
|  | #if CONFIG_PPP_SUPPORT || CONFIG_LWIP_SLIP_SUPPORT | ||||||
| #define _IS_NETIF_POINT2POINT_TYPE(netif, type) (netif->related_data && netif->related_data->is_point2point && netif->related_data->netif_type == type) | #define _IS_NETIF_POINT2POINT_TYPE(netif, type) (netif->related_data && netif->related_data->is_point2point && netif->related_data->netif_type == type) | ||||||
|  | #else | ||||||
|  | #define _IS_NETIF_POINT2POINT_TYPE(netif, type) false | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * @brief Additional netif types when related data are needed |  * @brief Additional netif types when related data are needed | ||||||
|   | |||||||
| @@ -32,8 +32,6 @@ ESP_EVENT_DEFINE_BASE(NETIF_PPP_STATUS); | |||||||
|  |  | ||||||
| static const char *TAG = "esp-netif_lwip-ppp"; | static const char *TAG = "esp-netif_lwip-ppp"; | ||||||
|  |  | ||||||
| #if PPPOS_SUPPORT |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * @brief internal lwip_ppp context struct extends the netif related data |  * @brief internal lwip_ppp context struct extends the netif related data | ||||||
|  *        used to hold PPP netif related parameters |  *        used to hold PPP netif related parameters | ||||||
| @@ -350,43 +348,5 @@ esp_err_t esp_netif_ppp_set_params(esp_netif_t *netif, const esp_netif_ppp_confi | |||||||
|     obj->ppp_error_event_enabled = config->ppp_error_event_enabled; |     obj->ppp_error_event_enabled = config->ppp_error_event_enabled; | ||||||
|     return ESP_OK; |     return ESP_OK; | ||||||
| } | } | ||||||
| #else  /* PPPOS_SUPPORT */ |  | ||||||
|  |  | ||||||
| typedef struct lwip_peer2peer_ctx lwip_peer2peer_ctx_t; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * @brief If PPP not enabled in menuconfig, log the error and return appropriate code indicating failure |  | ||||||
| */ |  | ||||||
| #define LOG_PPP_DISABLED_AND_DO(action) \ |  | ||||||
|     {   \ |  | ||||||
|     ESP_LOGE(TAG, "%s not supported, please enable PPP in lwIP component configuration", __func__); \ |  | ||||||
|     action; \ |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| esp_err_t esp_netif_ppp_set_auth(esp_netif_t *netif, esp_netif_auth_type_t authtype, const char *user, const char *passwd) |  | ||||||
|     LOG_PPP_DISABLED_AND_DO(return ESP_ERR_NOT_SUPPORTED) |  | ||||||
|  |  | ||||||
| void esp_netif_ppp_set_default_netif(lwip_peer2peer_ctx_t* ppp_ctx) |  | ||||||
|     LOG_PPP_DISABLED_AND_DO() |  | ||||||
|  |  | ||||||
| lwip_peer2peer_ctx_t* esp_netif_new_ppp(esp_netif_t *esp_netif, const esp_netif_netstack_config_t *esp_netif_stack_config) |  | ||||||
|     LOG_PPP_DISABLED_AND_DO(return NULL) |  | ||||||
|  |  | ||||||
| esp_err_t esp_netif_start_ppp(lwip_peer2peer_ctx_t *ppp_ctx) |  | ||||||
|     LOG_PPP_DISABLED_AND_DO(return ESP_ERR_NOT_SUPPORTED) |  | ||||||
|  |  | ||||||
| void esp_netif_lwip_ppp_input(void *ppp_ctx, void *buffer, size_t len, void *eb) |  | ||||||
|     LOG_PPP_DISABLED_AND_DO() |  | ||||||
|  |  | ||||||
| esp_err_t esp_netif_stop_ppp(lwip_peer2peer_ctx_t *ppp_ctx) |  | ||||||
|     LOG_PPP_DISABLED_AND_DO(return ESP_ERR_NOT_SUPPORTED) |  | ||||||
|  |  | ||||||
| void esp_netif_destroy_ppp(lwip_peer2peer_ctx_t *ppp_ctx) |  | ||||||
|     LOG_PPP_DISABLED_AND_DO() |  | ||||||
|  |  | ||||||
| esp_err_t esp_netif_ppp_set_params(esp_netif_t *netif, const esp_netif_ppp_config_t *config) |  | ||||||
|     LOG_PPP_DISABLED_AND_DO(return ESP_ERR_NOT_SUPPORTED) |  | ||||||
|  |  | ||||||
| #endif /* PPPOS_SUPPORT */ |  | ||||||
|  |  | ||||||
| #endif /* CONFIG_ESP_NETIF_TCPIP_LWIP */ | #endif /* CONFIG_ESP_NETIF_TCPIP_LWIP */ | ||||||
|   | |||||||
| @@ -31,10 +31,8 @@ | |||||||
|  |  | ||||||
| #include <string.h> | #include <string.h> | ||||||
|  |  | ||||||
|  |  | ||||||
| static const char *TAG = "esp-netif_lwip-slip"; | static const char *TAG = "esp-netif_lwip-slip"; | ||||||
|  |  | ||||||
| #if CONFIG_LWIP_SLIP_SUPPORT |  | ||||||
| /** | /** | ||||||
|  * @brief LWIP SLIP context object extends esp-netif related data |  * @brief LWIP SLIP context object extends esp-netif related data | ||||||
|  */ |  */ | ||||||
| @@ -312,28 +310,5 @@ void sio_send(uint8_t c, sio_fd_t fd) | |||||||
|         ESP_LOGD(TAG, "%s: uart_write_bytes error %i", __func__, ret); |         ESP_LOGD(TAG, "%s: uart_write_bytes error %i", __func__, ret); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| #else /* CONFIG_LWIP_SLIP_SUPPORT */ |  | ||||||
| typedef struct lwip_slip_ctx lwip_slip_ctx_t; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * @brief If SLIP not enabled in menuconfig, log the error and return appropriate code indicating failure |  | ||||||
| */ |  | ||||||
| #define LOG_SLIP_DISABLED_AND_DO(action) \ |  | ||||||
|     {   \ |  | ||||||
|     ESP_LOGE(TAG, "%s not supported, please enable SLIP in lwIP component configuration", __func__); \ |  | ||||||
|     action; \ |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| netif_related_data_t * esp_netif_new_slip(esp_netif_t *esp_netif, const esp_netif_netstack_config_t *esp_netif_stack_config) |  | ||||||
|     LOG_SLIP_DISABLED_AND_DO(return NULL) |  | ||||||
|  |  | ||||||
| void esp_netif_destroy_slip(netif_related_data_t *slip) |  | ||||||
|     LOG_SLIP_DISABLED_AND_DO() |  | ||||||
|  |  | ||||||
| esp_err_t esp_netif_stop_slip(esp_netif_t *esp_netif) |  | ||||||
|     LOG_SLIP_DISABLED_AND_DO(return ESP_ERR_NOT_SUPPORTED) |  | ||||||
|  |  | ||||||
| esp_err_t esp_netif_start_slip(esp_netif_t *esp_netif) |  | ||||||
|     LOG_SLIP_DISABLED_AND_DO(return ESP_ERR_NOT_SUPPORTED) |  | ||||||
| #endif |  | ||||||
| #endif /* CONFIG_ESP_NETIF_TCPIP_LWIP */ | #endif /* CONFIG_ESP_NETIF_TCPIP_LWIP */ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 David Čermák
					David Čermák