| 
									
										
										
										
											2021-06-04 16:43:32 +08:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2023-08-29 16:01:40 +08:00
										 |  |  |  * SPDX-FileCopyrightText: 2019-2023 Espressif Systems (Shanghai) CO LTD | 
					
						
							| 
									
										
										
										
											2021-06-04 16:43:32 +08:00
										 |  |  |  * | 
					
						
							|  |  |  |  * SPDX-License-Identifier: Apache-2.0 | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							| 
									
										
										
										
											2023-02-02 16:27:29 +01:00
										 |  |  | #include <inttypes.h>
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | #include <lwip/ip_addr.h>
 | 
					
						
							| 
									
										
										
										
											2021-01-25 10:17:03 +01:00
										 |  |  | #include <lwip/sockets.h>
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-19 11:52:51 +08:00
										 |  |  | #include "esp_check.h"
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | #include "esp_netif_lwip_internal.h"
 | 
					
						
							| 
									
										
										
										
											2022-05-11 16:01:48 +02:00
										 |  |  | #include "lwip/esp_netif_net_stack.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "esp_netif.h"
 | 
					
						
							|  |  |  | #include "esp_netif_private.h"
 | 
					
						
							| 
									
										
										
										
											2022-01-12 12:23:47 +05:30
										 |  |  | #include "esp_random.h"
 | 
					
						
							| 
									
										
										
										
											2022-07-22 10:14:37 +02:00
										 |  |  | #include "esp_system.h"
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "lwip/tcpip.h"
 | 
					
						
							|  |  |  | #include "lwip/dhcp.h"
 | 
					
						
							|  |  |  | #include "lwip/ip_addr.h"
 | 
					
						
							|  |  |  | #include "lwip/ip6_addr.h"
 | 
					
						
							| 
									
										
										
										
											2021-05-19 11:52:51 +08:00
										 |  |  | #include "lwip/mld6.h"
 | 
					
						
							| 
									
										
										
										
											2023-01-03 17:10:16 +08:00
										 |  |  | #include "lwip/prot/mld6.h"
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | #include "lwip/nd6.h"
 | 
					
						
							| 
									
										
										
										
											2022-05-11 16:01:48 +02:00
										 |  |  | #include "lwip/snmp.h"
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | #include "lwip/priv/tcpip_priv.h"
 | 
					
						
							|  |  |  | #include "lwip/netif.h"
 | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  | #include "lwip/etharp.h"
 | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  | #if CONFIG_ESP_NETIF_BRIDGE_EN
 | 
					
						
							|  |  |  | #include "netif/bridgeif.h"
 | 
					
						
							|  |  |  | #endif // CONFIG_ESP_NETIF_BRIDGE_EN
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | #if LWIP_DNS /* don't build if not configured for use in lwipopts.h */
 | 
					
						
							|  |  |  | #include "lwip/dns.h"
 | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  | #endif // LWIP_DNS
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-22 19:41:15 +02:00
										 |  |  | #if CONFIG_LWIP_HOOK_TCP_ISN_DEFAULT
 | 
					
						
							|  |  |  | #include "lwip_default_hooks.h"
 | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  | #endif // CONFIG_LWIP_HOOK_TCP_ISN_DEFAULT
 | 
					
						
							| 
									
										
										
										
											2020-10-15 19:10:38 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | #include "esp_netif_lwip_ppp.h"
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if ESP_DHCPS
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | #include "dhcpserver/dhcpserver.h"
 | 
					
						
							|  |  |  | #include "dhcpserver/dhcpserver_options.h"
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-03-23 19:20:06 +01:00
										 |  |  | #include "netif/dhcp_state.h"
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | #include "esp_event.h"
 | 
					
						
							|  |  |  | #include "esp_log.h"
 | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  | #if IP_NAPT
 | 
					
						
							|  |  |  | #include "lwip/lwip_napt.h"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // This is the main module implementing lwip interaction with esp-netif
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ESP_NETIF_HOSTNAME_MAX_SIZE    32
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  | #define DHCP_CB_CHANGE (LWIP_NSC_IPV4_SETTINGS_CHANGED | LWIP_NSC_IPV4_ADDRESS_CHANGED | LWIP_NSC_IPV4_GATEWAY_CHANGED | LWIP_NSC_IPV4_NETMASK_CHANGED)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-23 15:17:18 +02:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2020-03-04 12:41:32 +01:00
										 |  |  |  * @brief lwip thread safe tcpip function utility macros | 
					
						
							| 
									
										
										
										
											2019-10-23 15:17:18 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-03-04 12:41:32 +01:00
										 |  |  | #define _RUN_IN_LWIP_TASK(function, netif, param) { return esp_netif_lwip_ipc_call(function, netif, (void *)(param)); }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @brief macros to check netif related data to evaluate interface type | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-07-22 17:37:47 +02:00
										 |  |  | #if CONFIG_PPP_SUPPORT
 | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  | #define _IS_NETIF_ANY_POINT2POINT_TYPE(netif) (netif->related_data && netif->related_data->is_point2point)
 | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define _IS_NETIF_ANY_POINT2POINT_TYPE(netif) false
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | #define _RUN_IN_LWIP_TASK_IF_SUPPORTED(function, netif, param) \
 | 
					
						
							|  |  |  | {                                                              \ | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |     if (_IS_NETIF_ANY_POINT2POINT_TYPE(netif)) {               \ | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |         return ESP_ERR_NOT_SUPPORTED;                          \ | 
					
						
							|  |  |  |     }                                                          \ | 
					
						
							| 
									
										
										
										
											2019-10-23 15:17:18 +02:00
										 |  |  |     return esp_netif_lwip_ipc_call(function, netif, (void *)(param)); \ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @brief Utility macros to convert esp-ip addresses (both IPv6+IPv4 versions unconditionally) | 
					
						
							|  |  |  |  * and lwip-ip addresses (contain only enabled portion of the address for each IP stack) | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if LWIP_IPV4 && LWIP_IPV6
 | 
					
						
							|  |  |  | #define ESPIP_TO_IP(espip, ip) memcpy((ip), (espip), sizeof(ip_addr_t));
 | 
					
						
							|  |  |  | #define IP_TO_ESPIP(ip, espip) memcpy((espip), (ip), sizeof(ip_addr_t));
 | 
					
						
							|  |  |  | #elif LWIP_IPV4
 | 
					
						
							|  |  |  | #define ESPIP_TO_IP(espip, ip) memcpy((ip), &((espip)->u_addr.ip4), sizeof(ip_addr_t));
 | 
					
						
							|  |  |  | #define IP_TO_ESPIP(ip, espip) do { memcpy(&((espip)->u_addr.ip4), (ip), sizeof(ip4_addr_t)); \
 | 
					
						
							|  |  |  |                                     (espip)->type = ESP_IPADDR_TYPE_V4;                       \ | 
					
						
							|  |  |  |                                } while(0) | 
					
						
							|  |  |  | #elif LWIP_IPV6
 | 
					
						
							|  |  |  | #define ESPIP_TO_IP(espip, ip) memcpy((ip), &((espip)->u_addr.ip6), sizeof(ip_addr_t));
 | 
					
						
							|  |  |  | #define IP_TO_ESPIP(ip, espip) do { memcpy(&((espip)->u_addr.ip6), (ip), sizeof(ip6_addr_t)); \
 | 
					
						
							|  |  |  |                                     (espip)->type = ESP_IPADDR_TYPE_V6;                       \ | 
					
						
							|  |  |  |                               } while(0) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @brief If netif protocol not enabled in menuconfig, log the error and return appropriate code indicating failure | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define LOG_NETIF_DISABLED_AND_DO(proto, action)                                                \
 | 
					
						
							|  |  |  | do {                                                                                            \ | 
					
						
							|  |  |  |     ESP_LOGE(TAG, "%s not supported, please enable it in lwIP component configuration", proto); \ | 
					
						
							|  |  |  |     action;                                                                                     \ | 
					
						
							|  |  |  | } while(0) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-23 15:17:18 +02:00
										 |  |  | //
 | 
					
						
							|  |  |  | //  Internal types
 | 
					
						
							|  |  |  | //
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | typedef enum esp_netif_action { | 
					
						
							|  |  |  |     ESP_NETIF_UNDEF, | 
					
						
							|  |  |  |     ESP_NETIF_STARTED, | 
					
						
							|  |  |  |     ESP_NETIF_STOPPED, | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  |     ESP_NETIF_SET_DEFAULT, | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } esp_netif_action_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-23 15:17:18 +02:00
										 |  |  | //
 | 
					
						
							|  |  |  | //  Internal variables for this module
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | static const char *TAG = "esp_netif_lwip"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  | #if LWIP_ESP_NETIF_DATA
 | 
					
						
							|  |  |  | static u8_t lwip_netif_client_id = 0xff; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-10-23 15:17:18 +02:00
										 |  |  | static esp_netif_t *s_last_default_esp_netif = NULL; | 
					
						
							| 
									
										
										
										
											2022-02-22 14:59:09 +01:00
										 |  |  | static bool s_is_last_default_esp_netif_overridden = false; | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  | static netif_ext_callback_t netif_callback = { .callback_fn = NULL, .next = NULL }; | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  | static void esp_netif_internal_dhcpc_cb(struct netif *netif); | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  | #if LWIP_IPV6
 | 
					
						
							|  |  |  | static void esp_netif_internal_nd6_cb(struct netif *p_netif, uint8_t ip_index); | 
					
						
							| 
									
										
										
										
											2023-01-03 17:10:16 +08:00
										 |  |  | static void netif_set_mldv6_flag(struct netif *netif); | 
					
						
							|  |  |  | static void netif_unset_mldv6_flag(struct netif *netif); | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  | #endif /* LWIP_IPV6 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | static esp_err_t esp_netif_destroy_api(esp_netif_api_msg_t *msg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  | static void netif_callback_fn(struct netif* netif, netif_nsc_reason_t reason, const netif_ext_callback_args_t* args) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  |     if (reason & DHCP_CB_CHANGE) { | 
					
						
							|  |  |  |         esp_netif_internal_dhcpc_cb(netif); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif /* LWIP_IPV4 */
 | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  | #if LWIP_IPV6
 | 
					
						
							|  |  |  |     if ((reason & LWIP_NSC_IPV6_ADDR_STATE_CHANGED) && (args != NULL)) { | 
					
						
							|  |  |  |         s8_t addr_idx = args->ipv6_addr_state_changed.addr_index; | 
					
						
							|  |  |  |         if (netif_ip6_addr_state(netif, addr_idx) & IP6_ADDR_VALID)  { | 
					
						
							|  |  |  |             /* address is valid -> call the callback function */ | 
					
						
							|  |  |  |             esp_netif_internal_nd6_cb(netif, addr_idx); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #endif /* #if LWIP_IPV6 */
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef CONFIG_LWIP_GARP_TMR_INTERVAL
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void netif_send_garp(void *arg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     struct netif *netif = arg; | 
					
						
							| 
									
										
										
										
											2023-03-17 09:18:38 +01:00
										 |  |  |     if (!ip4_addr_cmp(netif_ip4_addr(netif), IP4_ADDR_ANY4)) {  // Send GARP requests only if we have a valid IP
 | 
					
						
							|  |  |  |         etharp_gratuitous(netif); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  |     sys_timeout(CONFIG_LWIP_GARP_TMR_INTERVAL*1000, netif_send_garp, netif); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void netif_set_garp_flag(struct netif *netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     sys_timeout(CONFIG_LWIP_GARP_TMR_INTERVAL*1000, netif_send_garp, netif); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void netif_unset_garp_flag(struct netif *netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     sys_untimeout(netif_send_garp, netif); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif  // CONFIG_LWIP_GARP_TMR_INTERVAL
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-29 16:10:37 +08:00
										 |  |  | #if !LWIP_TCPIP_CORE_LOCKING
 | 
					
						
							|  |  |  | static sys_sem_t api_sync_sem = NULL; | 
					
						
							|  |  |  | static sys_sem_t api_lock_sem = NULL; | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2020-12-29 16:10:37 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @brief Api callback from tcpip thread used to call esp-netif | 
					
						
							|  |  |  |  * function in lwip task context | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static void esp_netif_api_cb(void *api_msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_api_msg_t *msg = (esp_netif_api_msg_t *)api_msg; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!msg || !msg->api_fn) { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "null msg/api_fn"); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     msg->ret = msg->api_fn(msg); | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "call api in lwip: ret=0x%x, give sem", msg->ret); | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | #if !LWIP_TCPIP_CORE_LOCKING
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     sys_sem_signal(&api_sync_sem); | 
					
						
							| 
									
										
										
										
											2020-12-29 16:10:37 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief Initiates a tcpip remote call if called from another task | 
					
						
							|  |  |  |  * or calls the function directly if executed from lwip task | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | static inline esp_err_t esp_netif_lwip_ipc_call_msg(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (!sys_thread_tcpip(LWIP_CORE_LOCK_QUERY_HOLDER)) { | 
					
						
							| 
									
										
										
										
											2023-06-09 02:56:11 +08:00
										 |  |  |         ESP_LOGD(TAG, "check: remote, if=%p fn=%p", msg->esp_netif, msg->api_fn); | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | #if LWIP_TCPIP_CORE_LOCKING
 | 
					
						
							|  |  |  |         tcpip_send_msg_wait_sem((tcpip_callback_fn)esp_netif_api_cb, msg, NULL); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |         sys_arch_sem_wait(&api_lock_sem, 0); | 
					
						
							|  |  |  |         tcpip_send_msg_wait_sem((tcpip_callback_fn)esp_netif_api_cb, msg, &api_sync_sem); | 
					
						
							|  |  |  |         sys_sem_signal(&api_lock_sem); | 
					
						
							|  |  |  | #endif /* LWIP_TCPIP_CORE_LOCKING */
 | 
					
						
							|  |  |  |         return msg->ret; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-06-09 02:56:11 +08:00
										 |  |  |     ESP_LOGD(TAG, "check: local, if=%p fn=%p",  msg->esp_netif, msg->api_fn); | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     return msg->api_fn(msg); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline esp_err_t esp_netif_lwip_ipc_call(esp_netif_api_fn fn, esp_netif_t* netif, void *data) | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     esp_netif_api_msg_t msg = { | 
					
						
							|  |  |  |             .esp_netif = netif, | 
					
						
							|  |  |  |             .data = data, | 
					
						
							|  |  |  |             .api_fn = fn | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     return esp_netif_lwip_ipc_call_msg(&msg); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline esp_err_t esp_netif_lwip_ipc_call_fn(esp_netif_api_fn fn, esp_netif_callback_fn user_fn, void *ctx) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_api_msg_t msg = { | 
					
						
							|  |  |  |             .user_fn = user_fn, | 
					
						
							|  |  |  |             .data = ctx, | 
					
						
							|  |  |  |             .api_fn = fn | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call_msg(&msg); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | static inline esp_err_t esp_netif_lwip_ipc_call_get_netif(esp_netif_api_fn fn, esp_netif_t **netif, void *ctx) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_api_msg_t msg = { | 
					
						
							|  |  |  |             .p_esp_netif = netif, | 
					
						
							|  |  |  |             .data = ctx, | 
					
						
							|  |  |  |             .api_fn = fn | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call_msg(&msg); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | static inline esp_err_t esp_netif_lwip_ipc_no_args(esp_netif_api_fn fn) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_api_msg_t msg = { | 
					
						
							|  |  |  |             .api_fn = fn | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call_msg(&msg); | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @brief Check if supplied esp_netif handle is active, i.e. available within registered interfaces | 
					
						
							|  |  |  |  * as it might have already been destroyed. Returns the supplied handle if active, nullptr otherwise | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param esp_netif handle to check if available in the list of registered interfaces | 
					
						
							|  |  |  |  * @return esp_netif handle if available, or NULL if it wasn't found | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static esp_netif_t* esp_netif_is_active(esp_netif_t *arg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     // looking for the netif in the list of registered interfaces
 | 
					
						
							|  |  |  |     //  as it might have already been destroyed
 | 
					
						
							| 
									
										
										
										
											2019-10-22 09:43:20 +02:00
										 |  |  |     if (esp_netif_is_netif_listed(arg)) { | 
					
						
							|  |  |  |         return arg; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return NULL; | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @brief This function sets default netif no matter which implementation used | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param esp_netif handle to network interface | 
					
						
							| 
									
										
										
										
											2020-02-11 10:27:46 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @note: This function must be called from lwip thread | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  | static void esp_netif_set_default_netif_internal(esp_netif_t *esp_netif) | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-22 17:37:47 +02:00
										 |  |  |     if (ESP_NETIF_IS_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #if CONFIG_PPP_SUPPORT
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |         esp_netif_ppp_set_default_netif(esp_netif->netif_handle); | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2021-07-26 11:27:47 +02:00
										 |  |  |         netif_set_default(esp_netif->lwip_netif); | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2020-02-11 10:27:46 +01:00
										 |  |  |  * @brief tcpip thread version of esp_netif_update_default_netif | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-02-11 10:27:46 +01:00
										 |  |  |  * @note This function and all functions called from this must be called from lwip task context | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-02-11 10:27:46 +01:00
										 |  |  | static esp_err_t esp_netif_update_default_netif_lwip(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							|  |  |  |     esp_netif_action_t action = (esp_netif_action_t)msg->data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s %p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-22 14:59:09 +01:00
										 |  |  |     if (s_is_last_default_esp_netif_overridden && action != ESP_NETIF_SET_DEFAULT) { | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  |         // check if manually configured default interface hasn't been destroyed
 | 
					
						
							|  |  |  |         s_last_default_esp_netif = esp_netif_is_active(s_last_default_esp_netif); | 
					
						
							| 
									
										
										
										
											2022-02-22 14:59:09 +01:00
										 |  |  |         if (s_last_default_esp_netif != NULL) { | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  |             return ESP_OK; // still valid -> don't update default netif
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         // invalid -> reset the manual override and perform auto update
 | 
					
						
							| 
									
										
										
										
											2022-02-22 14:59:09 +01:00
										 |  |  |         s_is_last_default_esp_netif_overridden = false; | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     switch (action) { | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  |         case ESP_NETIF_SET_DEFAULT: | 
					
						
							|  |  |  |             s_last_default_esp_netif = esp_netif; | 
					
						
							| 
									
										
										
										
											2022-02-22 14:59:09 +01:00
										 |  |  |             s_is_last_default_esp_netif_overridden = true; | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  |             esp_netif_set_default_netif_internal(s_last_default_esp_netif); | 
					
						
							|  |  |  |         break; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         case ESP_NETIF_STARTED: | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |         { | 
					
						
							|  |  |  |             // check if previously default interface hasn't been destroyed in the meantime
 | 
					
						
							|  |  |  |             s_last_default_esp_netif = esp_netif_is_active(s_last_default_esp_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             if (s_last_default_esp_netif && esp_netif_is_netif_up(s_last_default_esp_netif) | 
					
						
							|  |  |  |                 && (s_last_default_esp_netif->route_prio > esp_netif->route_prio)) { | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  |                 esp_netif_set_default_netif_internal(s_last_default_esp_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             } else if (esp_netif_is_netif_up(esp_netif)) { | 
					
						
							|  |  |  |                 s_last_default_esp_netif = esp_netif; | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  |                 esp_netif_set_default_netif_internal(s_last_default_esp_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         default: | 
					
						
							|  |  |  |         case ESP_NETIF_STOPPED: | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             s_last_default_esp_netif = NULL; | 
					
						
							| 
									
										
										
										
											2019-10-22 09:43:20 +02:00
										 |  |  |             esp_netif_t *netif = esp_netif_next_unsafe(NULL); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             while (netif) { | 
					
						
							|  |  |  |                 if (esp_netif_is_netif_up(netif)) { | 
					
						
							|  |  |  |                     if (s_last_default_esp_netif && esp_netif_is_netif_up(s_last_default_esp_netif)) { | 
					
						
							|  |  |  |                         if (netif->route_prio > s_last_default_esp_netif->route_prio) { | 
					
						
							|  |  |  |                             s_last_default_esp_netif = netif; | 
					
						
							|  |  |  |                         } // else not needed, as the s_last_default_esp_netif is correct
 | 
					
						
							|  |  |  |                     } else { | 
					
						
							|  |  |  |                         // s_last_default is either not set or down, current netif is up
 | 
					
						
							|  |  |  |                         s_last_default_esp_netif = netif; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2019-10-22 09:43:20 +02:00
										 |  |  |                 netif = esp_netif_next_unsafe(netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |             if (s_last_default_esp_netif && esp_netif_is_netif_up(s_last_default_esp_netif)) { | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  |                 esp_netif_set_default_netif_internal(s_last_default_esp_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         break; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-02-11 10:27:46 +01:00
										 |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief This function sets default routing netif based on priorities of all interfaces which are up | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param esp_netif current interface which just updated state | 
					
						
							|  |  |  |  * @param action updating action (on-off) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static esp_err_t esp_netif_update_default_netif(esp_netif_t *esp_netif, esp_netif_action_t action) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call(esp_netif_update_default_netif_lwip, esp_netif, (void*)action); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-21 17:54:12 +01:00
										 |  |  | esp_err_t esp_netif_set_default_netif(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return esp_netif_update_default_netif(esp_netif, ESP_NETIF_SET_DEFAULT); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-25 12:03:02 +05:30
										 |  |  | esp_netif_t *esp_netif_get_default_netif(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return s_last_default_esp_netif; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  | static inline esp_netif_t* lwip_get_esp_netif(struct netif *netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if LWIP_ESP_NETIF_DATA
 | 
					
						
							|  |  |  |     return (esp_netif_t*)netif_get_client_data(netif, lwip_netif_client_id); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     return (esp_netif_t*)netif->state; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void lwip_set_esp_netif(struct netif *netif, esp_netif_t* esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if LWIP_ESP_NETIF_DATA
 | 
					
						
							|  |  |  |     netif_set_client_data(netif, lwip_netif_client_id, esp_netif); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     netif->state = esp_netif; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  | #if CONFIG_ESP_NETIF_BRIDGE_EN
 | 
					
						
							|  |  |  | esp_err_t esp_netif_bridge_add_port(esp_netif_t *esp_netif_br, esp_netif_t *esp_netif_port) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (ERR_OK != bridgeif_add_port(esp_netif_br->lwip_netif, esp_netif_port->lwip_netif)) { | 
					
						
							|  |  |  |         return ESP_FAIL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_bridge_fdb_add(esp_netif_t *esp_netif_br, uint8_t *addr, uint64_t ports_mask) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-11-08 14:16:21 +00:00
										 |  |  |     bridgeif_portmask_t ports = (bridgeif_portmask_t)ports_mask; | 
					
						
							|  |  |  |     if (ports_mask & ESP_NETIF_BR_FDW_CPU) { | 
					
						
							|  |  |  |         ports |= 1 << BRIDGEIF_MAX_PORTS; | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (ERR_OK != bridgeif_fdb_add(esp_netif_br->lwip_netif, (const struct eth_addr *)addr, ports)) { | 
					
						
							|  |  |  |         return ESP_FAIL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_bridge_fdb_remove(esp_netif_t *esp_netif_br, uint8_t *addr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (ERR_OK != bridgeif_fdb_remove(esp_netif_br->lwip_netif, (const struct eth_addr *)addr)) { | 
					
						
							|  |  |  |         return ESP_FAIL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif // CONFIG_ESP_NETIF_BRIDGE_EN
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | void esp_netif_set_ip4_addr(esp_ip4_addr_t *addr, uint8_t a, uint8_t b, uint8_t c, uint8_t d) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ip4_addr_t *address = (ip4_addr_t*)addr; | 
					
						
							|  |  |  |     IP4_ADDR(address, a, b, c, d); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | char * esp_ip4addr_ntoa(const esp_ip4_addr_t *addr, char *buf, int buflen) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return ip4addr_ntoa_r((ip4_addr_t *)addr, buf, buflen); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-04 13:58:29 +02:00
										 |  |  | uint32_t esp_ip4addr_aton(const char *addr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return ipaddr_addr(addr); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-09-04 13:58:29 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-25 10:17:03 +01:00
										 |  |  | esp_err_t esp_netif_str_to_ip4(const char *src, esp_ip4_addr_t *dst) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (src == NULL || dst == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     int err = inet_pton(AF_INET, src, dst); | 
					
						
							|  |  |  |     return err == 1 ? ESP_OK : ESP_FAIL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_str_to_ip6(const char *src, esp_ip6_addr_t *dst) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (src == NULL || dst == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     int err = inet_pton(AF_INET6, src, dst); | 
					
						
							|  |  |  |     return err == 1 ? ESP_OK : ESP_FAIL; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-09-04 13:58:29 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | esp_netif_iodriver_handle esp_netif_get_io_driver(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return esp_netif->driver_handle; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_netif_t* esp_netif_get_handle_from_netif_impl(void *dev) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |     // ppp_pcb ptr would never get to app code, so this function only works with vanilla lwip impl
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     struct netif *lwip_netif = dev; | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  |     return lwip_get_esp_netif(lwip_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void* esp_netif_get_netif_impl(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2024-01-08 09:47:49 +01:00
										 |  |  |     if (esp_netif) { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |         return esp_netif->lwip_netif; | 
					
						
							| 
									
										
										
										
											2019-10-23 15:17:18 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     return NULL; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | static void tcpip_init_done(void *arg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     sys_sem_t *init_sem = arg; | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if LWIP_ESP_NETIF_DATA
 | 
					
						
							|  |  |  |     if (lwip_netif_client_id == 0xFF) { | 
					
						
							|  |  |  |         lwip_netif_client_id = netif_alloc_client_data_id(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     sys_sem_signal(init_sem); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | esp_err_t esp_netif_init(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     if (!sys_thread_tcpip(LWIP_CORE_IS_TCPIP_INITIALIZED)) { | 
					
						
							| 
									
										
										
										
											2020-10-22 19:41:15 +02:00
										 |  |  | #if CONFIG_LWIP_HOOK_TCP_ISN_DEFAULT
 | 
					
						
							| 
									
										
										
										
											2020-10-15 19:10:38 +05:30
										 |  |  |         uint8_t rand_buf[16]; | 
					
						
							|  |  |  |         /*
 | 
					
						
							|  |  |  |          * This is early startup code where WiFi/BT is yet to be enabled and hence | 
					
						
							|  |  |  |          * relevant entropy source is not available. However, bootloader enables | 
					
						
							|  |  |  |          * SAR ADC based entropy source at its initialization, and our requirement | 
					
						
							|  |  |  |          * of random bytes is pretty small (16), so we can assume that following | 
					
						
							|  |  |  |          * API will provide sufficiently random data. | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         esp_fill_random(rand_buf, sizeof(rand_buf)); | 
					
						
							|  |  |  |         lwip_init_tcp_isn(esp_log_timestamp(), rand_buf); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |         sys_sem_t init_sem; | 
					
						
							|  |  |  |         if (sys_sem_new(&init_sem, 0) != ERR_OK) { | 
					
						
							|  |  |  |             ESP_LOGE(TAG, "esp netif cannot create tcpip_init semaphore"); | 
					
						
							|  |  |  |             return ESP_FAIL; | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | #if LWIP_TCPIP_CORE_LOCKING
 | 
					
						
							|  |  |  |         /* TCPIP thread is not initialized yet,
 | 
					
						
							|  |  |  |          * pretend that the calling thread is holder | 
					
						
							|  |  |  |          * to correctly set up the TCPIP task */ | 
					
						
							|  |  |  |         sys_thread_tcpip(LWIP_CORE_LOCK_MARK_HOLDER); | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |         tcpip_init(tcpip_init_done, &init_sem); | 
					
						
							|  |  |  |         sys_sem_wait(&init_sem); | 
					
						
							|  |  |  |         sys_sem_free(&init_sem); | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "LwIP stack has been initialized"); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-29 16:10:37 +08:00
										 |  |  | #if !LWIP_TCPIP_CORE_LOCKING
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     if (!api_sync_sem) { | 
					
						
							|  |  |  |         if (ERR_OK != sys_sem_new(&api_sync_sem, 0)) { | 
					
						
							|  |  |  |             ESP_LOGE(TAG, "esp netif api sync sem init fail"); | 
					
						
							|  |  |  |             return ESP_FAIL; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-11-10 18:40:01 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     if (!api_lock_sem) { | 
					
						
							|  |  |  |         if (ERR_OK != sys_sem_new(&api_lock_sem, 1)) { | 
					
						
							|  |  |  |             ESP_LOGE(TAG, "esp netif api lock sem init fail"); | 
					
						
							|  |  |  |             return ESP_FAIL; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-12-29 16:10:37 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "esp-netif has been successfully initialized"); | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_deinit(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     if (sys_thread_tcpip(LWIP_CORE_IS_TCPIP_INITIALIZED)) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         /* deinit of LwIP not supported:
 | 
					
						
							|  |  |  |          * do not deinit semaphores and states, | 
					
						
							|  |  |  |          * so init could be called multiple times | 
					
						
							|  |  |  |          * | 
					
						
							|  |  |  |         sys_sem_free(&api_sync_sem); | 
					
						
							|  |  |  |         sys_sem_free(&api_lock_sem); | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         return ESP_ERR_NOT_SUPPORTED; | 
					
						
							| 
									
										
										
										
											2020-11-10 18:40:01 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     return ESP_ERR_INVALID_STATE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | static esp_err_t esp_netif_init_configuration(esp_netif_t *esp_netif, const esp_netif_config_t *cfg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     // Basic esp_netif and lwip is a mandatory configuration and cannot be updated after esp_netif_new()
 | 
					
						
							|  |  |  |     if (cfg == NULL || cfg->base == NULL || cfg->stack == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Configure general esp-netif properties
 | 
					
						
							|  |  |  |     memcpy(esp_netif->mac, cfg->base->mac, NETIF_MAX_HWADDR_LEN); | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     if (cfg->base->ip_info == NULL) { | 
					
						
							|  |  |  |         ip4_addr_set_zero(&esp_netif->ip_info->ip); | 
					
						
							|  |  |  |         ip4_addr_set_zero(&esp_netif->ip_info->gw); | 
					
						
							|  |  |  |         ip4_addr_set_zero(&esp_netif->ip_info->netmask); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         memcpy(esp_netif->ip_info, cfg->base->ip_info, sizeof(esp_netif_ip_info_t)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     memcpy(esp_netif->ip_info_old, esp_netif->ip_info, sizeof(esp_netif_ip_info_t)); | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     // Setup main config parameters
 | 
					
						
							|  |  |  |     esp_netif->lost_ip_event = cfg->base->lost_ip_event; | 
					
						
							|  |  |  |     esp_netif->get_ip_event = cfg->base->get_ip_event; | 
					
						
							|  |  |  |     esp_netif->flags = cfg->base->flags; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (cfg->base->if_key) { | 
					
						
							|  |  |  |         esp_netif->if_key = strdup(cfg->base->if_key); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-09-13 15:44:23 +02:00
										 |  |  |     if (cfg->base->if_desc) { | 
					
						
							|  |  |  |         esp_netif->if_desc = strdup(cfg->base->if_desc); | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (cfg->base->route_prio) { | 
					
						
							|  |  |  |         esp_netif->route_prio = cfg->base->route_prio; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  | #if CONFIG_ESP_NETIF_BRIDGE_EN
 | 
					
						
							|  |  |  |     // Setup bridge configuration if the interface is to be bridge
 | 
					
						
							|  |  |  |     if (cfg->base->flags & ESP_NETIF_FLAG_IS_BRIDGE) { | 
					
						
							|  |  |  |         if (cfg->base->bridge_info != NULL) { | 
					
						
							|  |  |  |             esp_netif->max_fdb_dyn_entries = cfg->base->bridge_info->max_fdb_dyn_entries; | 
					
						
							|  |  |  |             esp_netif->max_fdb_sta_entries = cfg->base->bridge_info->max_fdb_sta_entries; | 
					
						
							|  |  |  |             esp_netif->max_ports = cfg->base->bridge_info->max_ports; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #endif // CONFIG_ESP_NETIF_BRIDGE_EN
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     // Install network stack functions -- connects netif and L3 stack
 | 
					
						
							|  |  |  |     const esp_netif_netstack_config_t *esp_netif_stack_config = cfg->stack; | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |     if (cfg->base->flags & ESP_NETIF_FLAG_IS_PPP) { | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #if CONFIG_PPP_SUPPORT
 | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |         esp_netif->related_data = esp_netif_new_ppp(esp_netif, esp_netif_stack_config); | 
					
						
							|  |  |  |         if (esp_netif->related_data == NULL) { | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |             return ESP_ERR_ESP_NETIF_INIT_FAILED; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         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
 | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |         esp_netif->netif_handle = esp_netif->related_data; | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #else
 | 
					
						
							|  |  |  |         LOG_NETIF_DISABLED_AND_DO("PPP", return ESP_ERR_NOT_SUPPORTED); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |     } else { | 
					
						
							|  |  |  |         if (esp_netif_stack_config-> lwip.init_fn) { | 
					
						
							|  |  |  |             esp_netif->lwip_init_fn = esp_netif_stack_config->lwip.init_fn; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (esp_netif_stack_config->lwip.input_fn) { | 
					
						
							|  |  |  |             esp_netif->lwip_input_fn = esp_netif_stack_config->lwip.input_fn; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         // Make the netif handle (used for tcpip input function) the lwip_netif itself
 | 
					
						
							|  |  |  |         esp_netif->netif_handle = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Install IO functions only if provided -- connects driver and netif
 | 
					
						
							|  |  |  |     // this configuration could be updated after esp_netif_new(), typically in post_attach callback
 | 
					
						
							|  |  |  |     if (cfg->driver) { | 
					
						
							|  |  |  |         const esp_netif_driver_ifconfig_t *esp_netif_driver_config = cfg->driver; | 
					
						
							|  |  |  |         if (esp_netif_driver_config->handle) { | 
					
						
							|  |  |  |             esp_netif->driver_handle = esp_netif_driver_config->handle; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (esp_netif_driver_config->transmit) { | 
					
						
							|  |  |  |             esp_netif->driver_transmit = esp_netif_driver_config->transmit; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-02-13 14:26:48 +08:00
										 |  |  |         if (esp_netif_driver_config->transmit_wrap) { | 
					
						
							|  |  |  |             esp_netif->driver_transmit_wrap = esp_netif_driver_config->transmit_wrap; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |         if (esp_netif_driver_config->driver_free_rx_buffer) { | 
					
						
							|  |  |  |             esp_netif->driver_free_rx_buffer = esp_netif_driver_config->driver_free_rx_buffer; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | static esp_err_t tcpip_exec_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return msg->user_fn(msg->data); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_tcpip_exec(esp_netif_callback_fn fn, void*ctx) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call_fn(tcpip_exec_api, fn, ctx); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | static esp_err_t esp_netif_new_api(esp_netif_api_msg_t *msg) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     const esp_netif_config_t *esp_netif_config = msg->data; | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     // mandatory configuration must be provided when creating esp_netif object
 | 
					
						
							| 
									
										
										
										
											2019-09-15 09:47:43 +02:00
										 |  |  |     if (esp_netif_config == NULL || | 
					
						
							|  |  |  |         esp_netif_config->base->if_key == NULL || | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         NULL != esp_netif_get_handle_from_ifkey_unsafe(esp_netif_config->base->if_key)) { | 
					
						
							| 
									
										
										
										
											2019-09-15 09:47:43 +02:00
										 |  |  |         ESP_LOGE(TAG, "%s: Failed to configure netif with config=%p (config or if_key is NULL or duplicate key)", | 
					
						
							|  |  |  |         __func__,  esp_netif_config); | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         return ESP_FAIL; | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-26 20:59:04 +05:30
										 |  |  | #if ESP_DHCPS
 | 
					
						
							|  |  |  |     // DHCP server and client cannot be configured together
 | 
					
						
							|  |  |  |     if((esp_netif_config->base->flags & ESP_NETIF_DHCP_SERVER) && | 
					
						
							|  |  |  |        (esp_netif_config->base->flags & ESP_NETIF_DHCP_CLIENT)) { | 
					
						
							|  |  |  |         ESP_LOGE(TAG, "%s: Failed to configure netif with config=%p (DHCP server and client cannot be configured together)", | 
					
						
							|  |  |  |         __func__,  esp_netif_config); | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         return ESP_FAIL; | 
					
						
							| 
									
										
										
										
											2023-01-26 20:59:04 +05:30
										 |  |  |     } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     // Create parent esp-netif object
 | 
					
						
							|  |  |  |     esp_netif_t *esp_netif = calloc(1, sizeof(struct esp_netif_obj)); | 
					
						
							|  |  |  |     if (!esp_netif) { | 
					
						
							| 
									
										
										
										
											2023-02-02 16:27:29 +01:00
										 |  |  |         ESP_LOGE(TAG, "Failed to allocate %" PRIu32 " bytes (free heap size %" PRIu32 ")", (uint32_t)sizeof(struct esp_netif_obj), | 
					
						
							| 
									
										
										
										
											2019-09-15 09:47:43 +02:00
										 |  |  |                  esp_get_free_heap_size()); | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         return ESP_FAIL; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Create ip info
 | 
					
						
							|  |  |  |     esp_netif_ip_info_t *ip_info = calloc(1, sizeof(esp_netif_ip_info_t)); | 
					
						
							|  |  |  |     if (!ip_info) { | 
					
						
							| 
									
										
										
										
											2023-02-02 16:27:29 +01:00
										 |  |  |         ESP_LOGE(TAG, "Failed to allocate %" PRIu32 " bytes (free heap size %" PRIu32 ")", (uint32_t)sizeof(esp_netif_ip_info_t), | 
					
						
							| 
									
										
										
										
											2019-09-15 09:47:43 +02:00
										 |  |  |                  esp_get_free_heap_size()); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         free(esp_netif); | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         return ESP_FAIL; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     esp_netif->ip_info = ip_info; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // creating another ip info (to store old ip)
 | 
					
						
							|  |  |  |     ip_info = calloc(1, sizeof(esp_netif_ip_info_t)); | 
					
						
							|  |  |  |     if (!ip_info) { | 
					
						
							| 
									
										
										
										
											2023-02-02 16:27:29 +01:00
										 |  |  |         ESP_LOGE(TAG, "Failed to allocate %" PRIu32 " bytes (free heap size %" PRIu32 ")", (uint32_t)sizeof(esp_netif_ip_info_t), | 
					
						
							| 
									
										
										
										
											2019-09-15 09:47:43 +02:00
										 |  |  |                  esp_get_free_heap_size()); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         free(esp_netif->ip_info); | 
					
						
							|  |  |  |         free(esp_netif); | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         return ESP_FAIL; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     esp_netif->ip_info_old = ip_info; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Create underlying lwip netif
 | 
					
						
							|  |  |  |     struct netif * lwip_netif = calloc(1, sizeof(struct netif)); | 
					
						
							|  |  |  |     if (!lwip_netif) { | 
					
						
							| 
									
										
										
										
											2023-02-02 16:27:29 +01:00
										 |  |  |         ESP_LOGE(TAG, "Failed to allocate %" PRIu32 " bytes (free heap size %" PRIu32 ")", (uint32_t)sizeof(struct netif), | 
					
						
							| 
									
										
										
										
											2019-09-15 09:47:43 +02:00
										 |  |  |                  esp_get_free_heap_size()); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         free(esp_netif->ip_info_old); | 
					
						
							|  |  |  |         free(esp_netif->ip_info); | 
					
						
							|  |  |  |         free(esp_netif); | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         return ESP_FAIL; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     esp_netif->lwip_netif = lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     esp_netif_add_to_list_unsafe(esp_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-19 19:50:49 +01:00
										 |  |  | #if ESP_DHCPS
 | 
					
						
							|  |  |  |     // Create DHCP server structure
 | 
					
						
							|  |  |  |     if (esp_netif_config->base->flags & ESP_NETIF_DHCP_SERVER) { | 
					
						
							|  |  |  |         esp_netif->dhcps = dhcps_new(); | 
					
						
							| 
									
										
										
										
											2022-03-07 10:41:28 +01:00
										 |  |  |         if (esp_netif->dhcps == NULL) { | 
					
						
							|  |  |  |             ESP_LOGE(TAG, "Failed to create dhcp server handle"); | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |             esp_netif_api_msg_t to_destroy = { .esp_netif = esp_netif}; | 
					
						
							|  |  |  |             esp_netif_destroy_api(&to_destroy); | 
					
						
							|  |  |  |             return ESP_FAIL; | 
					
						
							| 
									
										
										
										
											2022-03-07 10:41:28 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-01-19 19:50:49 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     // Configure the created object with provided configuration
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_err_t ret =  esp_netif_init_configuration(esp_netif, esp_netif_config); | 
					
						
							|  |  |  |     if (ret != ESP_OK) { | 
					
						
							|  |  |  |         ESP_LOGE(TAG, "Initial configuration of esp_netif failed with %d", ret); | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         esp_netif_api_msg_t to_destroy = { .esp_netif = esp_netif}; | 
					
						
							|  |  |  |         esp_netif_destroy_api(&to_destroy); | 
					
						
							|  |  |  |         return ESP_FAIL; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  |     lwip_set_esp_netif(lwip_netif, esp_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     if (netif_callback.callback_fn == NULL ) { | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         netif_add_ext_callback(&netif_callback, netif_callback_fn); | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-02-14 13:46:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     *msg->p_esp_netif = esp_netif; | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_netif_t *esp_netif_new(const esp_netif_config_t *config) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_t *netif = NULL; | 
					
						
							|  |  |  |     esp_netif_lwip_ipc_call_get_netif(esp_netif_new_api, &netif, (void *)config); | 
					
						
							|  |  |  |     return netif; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t get_handle_from_ifkey_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     *msg->p_esp_netif = esp_netif_get_handle_from_ifkey_unsafe(msg->data); | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_netif_t *esp_netif_get_handle_from_ifkey(const char *if_key) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_t *netif = NULL; | 
					
						
							|  |  |  |     esp_netif_lwip_ipc_call_get_netif(get_handle_from_ifkey_api, &netif, (void*)if_key); | 
					
						
							|  |  |  |     return netif; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-03 16:28:30 +02:00
										 |  |  | typedef struct find_if_api { | 
					
						
							|  |  |  |     esp_netif_find_predicate_t fn; | 
					
						
							|  |  |  |     void *ctx; | 
					
						
							|  |  |  | } find_if_api_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_find_if_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     find_if_api_t *find_if_api = msg->data; | 
					
						
							|  |  |  |     esp_netif_t *esp_netif = NULL; | 
					
						
							| 
									
										
										
										
											2023-10-03 17:38:18 +02:00
										 |  |  |     while ((esp_netif = esp_netif_next_unsafe(esp_netif)) != NULL) { | 
					
						
							| 
									
										
										
										
											2023-10-03 16:28:30 +02:00
										 |  |  |         if (find_if_api->fn(esp_netif, find_if_api->ctx)) { | 
					
						
							|  |  |  |             *msg->p_esp_netif = esp_netif; | 
					
						
							|  |  |  |             return ESP_OK; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ESP_FAIL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_netif_t *esp_netif_find_if(esp_netif_find_predicate_t fn, void *ctx) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_t *netif = NULL; | 
					
						
							|  |  |  |     find_if_api_t find_if_api = { .fn = fn, .ctx = ctx }; | 
					
						
							|  |  |  |     if (esp_netif_lwip_ipc_call_get_netif(esp_netif_find_if_api, &netif, &find_if_api) == ESP_OK) { | 
					
						
							|  |  |  |         return netif; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-04 13:58:29 +02:00
										 |  |  | static void esp_netif_lwip_remove(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (esp_netif->lwip_netif) { | 
					
						
							|  |  |  |         if (netif_is_up(esp_netif->lwip_netif)) { | 
					
						
							|  |  |  |             netif_set_down(esp_netif->lwip_netif); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         netif_remove(esp_netif->lwip_netif); | 
					
						
							| 
									
										
										
										
											2022-02-14 13:46:21 +01:00
										 |  |  | #if ESP_GRATUITOUS_ARP
 | 
					
						
							| 
									
										
										
										
											2022-06-01 20:38:40 +02:00
										 |  |  |         if (esp_netif->flags & ESP_NETIF_FLAG_GARP) { | 
					
						
							| 
									
										
										
										
											2022-02-14 13:46:21 +01:00
										 |  |  |             netif_unset_garp_flag(esp_netif->lwip_netif); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-01-03 17:10:16 +08:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #if ESP_MLDV6_REPORT && LWIP_IPV6
 | 
					
						
							|  |  |  |         if (esp_netif->flags & ESP_NETIF_FLAG_MLDV6_REPORT) { | 
					
						
							|  |  |  |             netif_unset_mldv6_flag(esp_netif->lwip_netif); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-02-14 13:46:21 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |         if (esp_netif->flags & ESP_NETIF_DHCP_CLIENT) { | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2022-02-14 13:46:21 +01:00
										 |  |  |             dhcp_cleanup(esp_netif->lwip_netif); | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-02-14 13:46:21 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-04 13:58:29 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  | static esp_err_t esp_netif_lwip_add(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (esp_netif->lwip_netif == NULL) { | 
					
						
							|  |  |  |         esp_netif->lwip_netif = calloc(1, sizeof(struct netif)); | 
					
						
							|  |  |  |         if (esp_netif->lwip_netif == NULL) { | 
					
						
							|  |  |  |             return ESP_ERR_NO_MEM; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |     if (esp_netif->flags & ESP_NETIF_FLAG_IS_PPP) { | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #if CONFIG_PPP_SUPPORT
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |         err_t err = esp_netif->lwip_init_fn(NULL); | 
					
						
							|  |  |  |         if (err != ERR_OK) { | 
					
						
							| 
									
										
										
										
											2023-02-02 16:27:29 +01:00
										 |  |  |             ESP_LOGE(TAG, "Init netif failed with  %" PRId8 "", err); | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |             return ESP_ERR_ESP_NETIF_INIT_FAILED; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #else
 | 
					
						
							|  |  |  |         LOG_NETIF_DISABLED_AND_DO("PPP", return ESP_ERR_NOT_SUPPORTED); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  | #if CONFIG_ESP_NETIF_BRIDGE_EN
 | 
					
						
							|  |  |  |     if (esp_netif->flags & ESP_NETIF_FLAG_IS_BRIDGE) { | 
					
						
							|  |  |  |         bridgeif_initdata_t bridge_initdata = { | 
					
						
							|  |  |  |             .max_fdb_dynamic_entries = esp_netif->max_fdb_dyn_entries, | 
					
						
							|  |  |  |             .max_fdb_static_entries = esp_netif->max_fdb_sta_entries, | 
					
						
							|  |  |  |             .max_ports = esp_netif->max_ports | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         memcpy(&bridge_initdata.ethaddr, esp_netif->mac, ETH_HWADDR_LEN); | 
					
						
							|  |  |  |         if (NULL == netif_add(esp_netif->lwip_netif, (struct ip4_addr*)&esp_netif->ip_info->ip, | 
					
						
							|  |  |  |                         (struct ip4_addr*)&esp_netif->ip_info->netmask, (struct ip4_addr*)&esp_netif->ip_info->gw, | 
					
						
							|  |  |  |                         &bridge_initdata, esp_netif->lwip_init_fn, tcpip_input)) { | 
					
						
							|  |  |  |             esp_netif_lwip_remove(esp_netif); | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  | #endif // CONFIG_ESP_NETIF_BRIDGE_EN
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  |         if (NULL == netif_add(esp_netif->lwip_netif, | 
					
						
							|  |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							|  |  |  |                             (struct ip4_addr*)&esp_netif->ip_info->ip, | 
					
						
							|  |  |  |                             (struct ip4_addr*)&esp_netif->ip_info->netmask, | 
					
						
							|  |  |  |                             (struct ip4_addr*)&esp_netif->ip_info->gw, | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  |                             esp_netif, esp_netif->lwip_init_fn, tcpip_input)) { | 
					
						
							|  |  |  |             esp_netif_lwip_remove(esp_netif); | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | #if CONFIG_ESP_NETIF_BRIDGE_EN
 | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  | #endif // CONFIG_ESP_NETIF_BRIDGE_EN
 | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  |     lwip_set_esp_netif(esp_netif->lwip_netif, esp_netif); | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  | static void esp_netif_destroy_related(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-22 17:37:47 +02:00
										 |  |  |     if (ESP_NETIF_IS_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #if CONFIG_PPP_SUPPORT
 | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |         esp_netif_destroy_ppp(esp_netif->related_data); | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | static esp_err_t esp_netif_destroy_api(esp_netif_api_msg_t *msg) | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							|  |  |  |     esp_netif_remove_from_list_unsafe(esp_netif); | 
					
						
							|  |  |  |     if (esp_netif_get_nr_of_ifs() == 0) { | 
					
						
							|  |  |  |         netif_remove_ext_callback(&netif_callback); | 
					
						
							|  |  |  |         netif_callback.callback_fn = NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     free(esp_netif->ip_info); | 
					
						
							|  |  |  |     free(esp_netif->ip_info_old); | 
					
						
							|  |  |  |     free(esp_netif->if_key); | 
					
						
							|  |  |  |     free(esp_netif->if_desc); | 
					
						
							|  |  |  |     esp_netif_lwip_remove(esp_netif); | 
					
						
							|  |  |  |     esp_netif_destroy_related(esp_netif); | 
					
						
							|  |  |  |     free(esp_netif->lwip_netif); | 
					
						
							|  |  |  |     free(esp_netif->hostname); | 
					
						
							|  |  |  |     esp_netif_update_default_netif(esp_netif, ESP_NETIF_STOPPED); | 
					
						
							|  |  |  | #if ESP_DHCPS
 | 
					
						
							|  |  |  |     dhcps_delete(esp_netif->dhcps); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     free(esp_netif); | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | void esp_netif_destroy(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     if (esp_netif == NULL) { | 
					
						
							|  |  |  |         return; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     esp_netif_lwip_ipc_call(esp_netif_destroy_api, esp_netif, NULL); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_attach(esp_netif_t *esp_netif, esp_netif_iodriver_handle driver_handle) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_driver_base_t *base_driver = driver_handle; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     esp_netif->driver_handle = driver_handle; | 
					
						
							|  |  |  |     if (base_driver->post_attach) { | 
					
						
							|  |  |  |         esp_err_t ret = base_driver->post_attach(esp_netif, driver_handle); | 
					
						
							|  |  |  |         if (ret != ESP_OK) { | 
					
						
							|  |  |  |             ESP_LOGE(TAG, "Post-attach callback of driver(%p) failed with %d", driver_handle, ret); | 
					
						
							| 
									
										
										
										
											2019-09-12 09:24:56 +02:00
										 |  |  |             return ESP_ERR_ESP_NETIF_DRIVER_ATTACH_FAILED; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | esp_err_t esp_netif_set_driver_config(esp_netif_t *esp_netif, | 
					
						
							|  |  |  |                                       const esp_netif_driver_ifconfig_t *driver_config) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     if (esp_netif == NULL || driver_config == NULL) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif->driver_handle = driver_config->handle; | 
					
						
							|  |  |  |     esp_netif->driver_transmit = driver_config->transmit; | 
					
						
							| 
									
										
										
										
											2020-02-13 14:26:48 +08:00
										 |  |  |     esp_netif->driver_transmit_wrap = driver_config->transmit_wrap; | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif->driver_free_rx_buffer = driver_config->driver_free_rx_buffer; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | static esp_err_t esp_netif_reset_ip_info(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ip4_addr_set_zero(&(esp_netif->ip_info->ip)); | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |     ip4_addr_set_zero(&(esp_netif->ip_info->gw)); | 
					
						
							|  |  |  |     ip4_addr_set_zero(&(esp_netif->ip_info->netmask)); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | esp_err_t esp_netif_set_mac_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     uint8_t *mac = msg->data; | 
					
						
							|  |  |  |     esp_netif_t* esp_netif = msg->esp_netif; | 
					
						
							|  |  |  |     memcpy(esp_netif->mac, mac, NETIF_MAX_HWADDR_LEN); | 
					
						
							|  |  |  |     memcpy(esp_netif->lwip_netif->hwaddr, mac, NETIF_MAX_HWADDR_LEN); | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | esp_err_t esp_netif_set_mac(esp_netif_t *esp_netif, uint8_t mac[]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (esp_netif == NULL || esp_netif->lwip_netif == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |     if (_IS_NETIF_ANY_POINT2POINT_TYPE(esp_netif)) { | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |         return ESP_ERR_NOT_SUPPORTED; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     return esp_netif_lwip_ipc_call(esp_netif_set_mac_api, esp_netif, mac); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-30 16:49:50 +01:00
										 |  |  | esp_err_t esp_netif_get_mac(esp_netif_t *esp_netif, uint8_t mac[]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (esp_netif == NULL || esp_netif->lwip_netif == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |     if (_IS_NETIF_ANY_POINT2POINT_TYPE(esp_netif)) { | 
					
						
							| 
									
										
										
										
											2020-01-30 16:49:50 +01:00
										 |  |  |         return ESP_ERR_NOT_SUPPORTED; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (esp_netif_is_netif_up(esp_netif)) { | 
					
						
							|  |  |  |         memcpy(mac, esp_netif->lwip_netif->hwaddr, NETIF_MAX_HWADDR_LEN); | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     memcpy(mac, esp_netif->mac, NETIF_MAX_HWADDR_LEN); | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #if ESP_DHCPS
 | 
					
						
							| 
									
										
										
										
											2022-02-02 17:17:39 +01:00
										 |  |  | static void esp_netif_dhcps_cb(void* arg, uint8_t ip[4], uint8_t mac[6]) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-02-02 17:17:39 +01:00
										 |  |  |     esp_netif_t *esp_netif = arg; | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  |     ip_event_ap_staipassigned_t evt = { .esp_netif = esp_netif }; | 
					
						
							| 
									
										
										
										
											2021-09-12 08:47:14 +02:00
										 |  |  |     memcpy((char *)&evt.ip.addr, (char *)ip, sizeof(evt.ip.addr)); | 
					
						
							|  |  |  |     memcpy((char *)&evt.mac, mac, sizeof(evt.mac)); | 
					
						
							| 
									
										
										
										
											2022-02-02 17:17:39 +01:00
										 |  |  |     ESP_LOGI(TAG, "DHCP server assigned IP to a client, IP is: " IPSTR, IP2STR(&evt.ip)); | 
					
						
							| 
									
										
										
										
											2021-09-12 08:47:14 +02:00
										 |  |  |     ESP_LOGD(TAG, "Client's MAC: %x:%x:%x:%x:%x:%x", mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-02 15:49:28 +05:30
										 |  |  |     int ret = esp_event_post(IP_EVENT, IP_EVENT_AP_STAIPASSIGNED, &evt, sizeof(evt), 0); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     if (ESP_OK != ret) { | 
					
						
							|  |  |  |         ESP_LOGE(TAG, "dhcps cb: failed to post IP_EVENT_AP_STAIPASSIGNED (%x)", ret); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | static esp_err_t esp_netif_config_sanity_check(const esp_netif_t * esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (esp_netif == NULL) { | 
					
						
							|  |  |  |         ESP_LOGE(TAG,  "Cannot start esp_netif: esp_netif must not be null"); | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_STATE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  |     if ((!(esp_netif->flags & ESP_NETIF_FLAG_IS_BRIDGE) && (esp_netif->driver_transmit == NULL || | 
					
						
							|  |  |  |         esp_netif->driver_handle == NULL || esp_netif->lwip_input_fn == NULL)) || | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |         esp_netif->lwip_init_fn == NULL) { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |         ESP_LOGE(TAG,  "Cannot start esp_netif: Missing mandatory configuration:\n" | 
					
						
							|  |  |  |                        "esp_netif->driver_transmit: %p, esp_netif->driver_handle:%p, " | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |                        "esp_netif->lwip_input_fn: %p, esp_netif->lwip_init_fn:%p", | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |                        esp_netif->driver_transmit,  esp_netif->driver_handle, | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |                        esp_netif->lwip_input_fn,  esp_netif->lwip_init_fn); | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |          return ESP_ERR_INVALID_STATE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_start_api(esp_netif_api_msg_t *msg) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t * esp_netif = msg->esp_netif; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s %p", __func__, esp_netif); | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     if (ESP_NETIF_IS_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { | 
					
						
							|  |  |  | #if CONFIG_PPP_SUPPORT
 | 
					
						
							|  |  |  |         esp_err_t ret = esp_netif_start_ppp(esp_netif); | 
					
						
							|  |  |  |         if (ret == ESP_OK) { | 
					
						
							|  |  |  |             esp_netif_update_default_netif(esp_netif, ESP_NETIF_STARTED); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return ret; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     ESP_ERROR_CHECK(esp_netif_config_sanity_check(esp_netif)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |     ESP_ERROR_CHECK(esp_netif_lwip_add(esp_netif)); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-30 10:53:51 +02:00
										 |  |  | #if ESP_IPV6_AUTOCONFIG
 | 
					
						
							|  |  |  |     esp_netif->lwip_netif->ip6_autoconfig_enabled = 1; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     if (esp_netif->flags&ESP_NETIF_FLAG_GARP) { | 
					
						
							|  |  |  | #if ESP_GRATUITOUS_ARP
 | 
					
						
							|  |  |  |         netif_set_garp_flag(esp_netif->lwip_netif); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2020-05-18 21:44:57 +02:00
										 |  |  |         ESP_LOGW(TAG,"CONFIG_LWIP_ESP_GRATUITOUS_ARP not enabled, but esp-netif configured with ESP_NETIF_FLAG_GARP"); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							| 
									
										
										
										
											2022-07-22 17:37:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     if (esp_netif->flags&ESP_NETIF_FLAG_AUTOUP) { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "%s Setting the lwip netif%p UP", __func__, p_netif); | 
					
						
							|  |  |  |         netif_set_up(p_netif); | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  |         netif_set_link_up(p_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-10-30 20:29:13 +01:00
										 |  |  |     if (esp_netif->flags & ESP_NETIF_DHCP_SERVER) { | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #if ESP_DHCPS
 | 
					
						
							| 
									
										
										
										
											2021-06-16 19:39:15 +02:00
										 |  |  |         if (esp_netif->dhcps_status == ESP_NETIF_DHCP_INIT) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             if (p_netif != NULL && netif_is_up(p_netif)) { | 
					
						
							|  |  |  |                 esp_netif_ip_info_t *default_ip = esp_netif->ip_info; | 
					
						
							|  |  |  |                 ip4_addr_t lwip_ip; | 
					
						
							| 
									
										
										
										
											2020-04-02 19:46:45 +02:00
										 |  |  |                 ip4_addr_t lwip_netmask; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 memcpy(&lwip_ip, &default_ip->ip, sizeof(struct ip4_addr)); | 
					
						
							| 
									
										
										
										
											2020-04-02 19:46:45 +02:00
										 |  |  |                 memcpy(&lwip_netmask, &default_ip->netmask, sizeof(struct ip4_addr)); | 
					
						
							| 
									
										
										
										
											2022-02-02 17:17:39 +01:00
										 |  |  |                 dhcps_set_new_lease_cb(esp_netif->dhcps, esp_netif_dhcps_cb, esp_netif); | 
					
						
							| 
									
										
										
										
											2022-01-19 19:50:49 +01:00
										 |  |  |                 dhcps_set_option_info(esp_netif->dhcps, SUBNET_MASK, (void*)&lwip_netmask, sizeof(lwip_netmask)); | 
					
						
							| 
									
										
										
										
											2022-06-27 09:12:18 +02:00
										 |  |  |                 if (dhcps_start(esp_netif->dhcps, p_netif, lwip_ip) != ERR_OK) { | 
					
						
							|  |  |  |                     ESP_LOGE(TAG, "DHCP server cannot be started"); | 
					
						
							|  |  |  |                     esp_netif->dhcps_status = ESP_NETIF_DHCP_INIT; | 
					
						
							|  |  |  |                     return ESP_ERR_ESP_NETIF_DHCPS_START_FAILED; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 esp_netif->dhcps_status = ESP_NETIF_DHCP_STARTED; | 
					
						
							| 
									
										
										
										
											2022-11-25 02:09:46 +05:30
										 |  |  |                 ESP_LOGI(TAG, "DHCP server started on interface %s with IP: " IPSTR, esp_netif->if_key, IP2STR(&lwip_ip)); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 esp_netif_update_default_netif(esp_netif, ESP_NETIF_STARTED); | 
					
						
							|  |  |  |                 return ESP_OK; | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |                 ESP_LOGD(TAG, "DHCP server re init"); | 
					
						
							|  |  |  |                 esp_netif->dhcps_status = ESP_NETIF_DHCP_INIT; | 
					
						
							|  |  |  |                 return ESP_OK; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-06-16 19:39:15 +02:00
										 |  |  |         } else if (esp_netif->dhcps_status == ESP_NETIF_DHCP_STARTED) { | 
					
						
							|  |  |  |             ESP_LOGD(TAG, "DHCP server already started"); | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_DHCP_ALREADY_STARTED; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-06-16 19:39:15 +02:00
										 |  |  |         return ESP_OK; | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #else
 | 
					
						
							|  |  |  |         LOG_NETIF_DISABLED_AND_DO("DHCP Server", return ESP_ERR_NOT_SUPPORTED); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2020-04-16 17:38:59 +08:00
										 |  |  |     } else if (esp_netif->flags & ESP_NETIF_DHCP_CLIENT) { | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2020-04-16 17:38:59 +08:00
										 |  |  |         if (esp_netif->dhcpc_status != ESP_NETIF_DHCP_STARTED) { | 
					
						
							|  |  |  |             if (p_netif != NULL) { | 
					
						
							|  |  |  |                 struct dhcp *dhcp_data = NULL; | 
					
						
							|  |  |  |                 dhcp_data = netif_dhcp_data(p_netif); | 
					
						
							|  |  |  |                 if (dhcp_data == NULL) { | 
					
						
							|  |  |  |                     dhcp_data = (struct dhcp *)malloc(sizeof(struct dhcp)); | 
					
						
							|  |  |  |                     if (dhcp_data == NULL) { | 
					
						
							|  |  |  |                         return ESP_ERR_NO_MEM; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     dhcp_set_struct(p_netif, dhcp_data); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #else
 | 
					
						
							|  |  |  |         LOG_NETIF_DISABLED_AND_DO("IPv4's DHCP Client", return ESP_ERR_NOT_SUPPORTED); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     esp_netif_update_default_netif(esp_netif, ESP_NETIF_STARTED); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | esp_err_t esp_netif_start(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     return esp_netif_lwip_ipc_call(esp_netif_start_api, esp_netif, NULL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_stop_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-22 17:37:47 +02:00
										 |  |  |     if (ESP_NETIF_IS_POINT2POINT_TYPE(esp_netif, PPP_LWIP_NETIF)) { | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #if CONFIG_PPP_SUPPORT
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         esp_err_t ret = esp_netif_stop_ppp(esp_netif->related_data); | 
					
						
							| 
									
										
										
										
											2020-05-21 17:55:56 +12:00
										 |  |  |         if (ret == ESP_OK) { | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |             esp_netif_update_default_netif(esp_netif, ESP_NETIF_STOPPED); | 
					
						
							| 
									
										
										
										
											2020-05-21 17:55:56 +12:00
										 |  |  |         } | 
					
						
							|  |  |  |         return ret; | 
					
						
							| 
									
										
										
										
											2021-06-23 10:20:08 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     struct netif *lwip_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  |     if (lwip_netif == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!netif_is_up(lwip_netif)) { | 
					
						
							| 
									
										
										
										
											2019-09-04 13:58:29 +02:00
										 |  |  |         esp_netif_lwip_remove(esp_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-30 20:29:13 +01:00
										 |  |  |     if (esp_netif->flags & ESP_NETIF_DHCP_SERVER) { | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #if ESP_DHCPS
 | 
					
						
							| 
									
										
										
										
											2022-06-27 09:12:18 +02:00
										 |  |  |         if (dhcps_stop(esp_netif->dhcps, lwip_netif) != ERR_OK || | 
					
						
							|  |  |  |             esp_netif->dhcps_status != ESP_NETIF_DHCP_STOPPED) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             esp_netif->dhcps_status = ESP_NETIF_DHCP_INIT; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #else
 | 
					
						
							|  |  |  |         LOG_NETIF_DISABLED_AND_DO("DHCP Server", return ESP_ERR_NOT_SUPPORTED); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-10-30 20:29:13 +01:00
										 |  |  |     } else if (esp_netif->flags & ESP_NETIF_DHCP_CLIENT) { | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         dhcp_release(lwip_netif); | 
					
						
							|  |  |  |         dhcp_stop(lwip_netif); | 
					
						
							|  |  |  |         dhcp_cleanup(lwip_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         esp_netif->dhcpc_status = ESP_NETIF_DHCP_INIT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         esp_netif_reset_ip_info(esp_netif); | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #else
 | 
					
						
							|  |  |  |         LOG_NETIF_DISABLED_AND_DO("IPv4's DHCP Client", return ESP_ERR_NOT_SUPPORTED); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     netif_set_down(lwip_netif); | 
					
						
							| 
									
										
										
										
											2019-09-04 13:58:29 +02:00
										 |  |  |     esp_netif_lwip_remove(esp_netif); | 
					
						
							| 
									
										
										
										
											2021-06-01 18:58:30 +02:00
										 |  |  |     esp_netif_update_default_netif(esp_netif, ESP_NETIF_STOPPED); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | esp_err_t esp_netif_stop(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call(esp_netif_stop_api, esp_netif, NULL); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-13 14:26:48 +08:00
										 |  |  | void esp_netif_netstack_buf_ref(void *pbuf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     pbuf_ref(pbuf); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void esp_netif_netstack_buf_free(void *pbuf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     pbuf_free(pbuf); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | //
 | 
					
						
							|  |  |  | // IO translate functions
 | 
					
						
							|  |  |  | //
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | void esp_netif_free_rx_buffer(void *h, void* buffer) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_t *esp_netif = h; | 
					
						
							|  |  |  |     esp_netif->driver_free_rx_buffer(esp_netif->driver_handle, buffer); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_transmit(esp_netif_t *esp_netif, void* data, size_t len) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-12-01 09:53:25 +01:00
										 |  |  |     return (esp_netif->driver_transmit)(esp_netif->driver_handle, data, len); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-13 14:26:48 +08:00
										 |  |  | esp_err_t esp_netif_transmit_wrap(esp_netif_t *esp_netif, void *data, size_t len, void *pbuf) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return (esp_netif->driver_transmit_wrap)(esp_netif->driver_handle, data, len, pbuf); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | esp_err_t esp_netif_receive(esp_netif_t *esp_netif, void *buffer, size_t len, void *eb) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2023-03-27 12:54:25 +02:00
										 |  |  | #ifdef CONFIG_ESP_NETIF_RECEIVE_REPORT_ERRORS
 | 
					
						
							| 
									
										
										
										
											2023-03-27 10:37:51 +02:00
										 |  |  |     return esp_netif->lwip_input_fn(esp_netif->netif_handle, buffer, len, eb); | 
					
						
							| 
									
										
										
										
											2023-03-27 12:54:25 +02:00
										 |  |  | #else
 | 
					
						
							|  |  |  |     esp_netif->lwip_input_fn(esp_netif->netif_handle, buffer, len, eb); | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2022-02-14 13:46:21 +01:00
										 |  |  | static esp_err_t esp_netif_start_ip_lost_timer(esp_netif_t *esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | //
 | 
					
						
							|  |  |  | // DHCP:
 | 
					
						
							|  |  |  | //
 | 
					
						
							| 
									
										
										
										
											2022-06-02 16:25:20 +02:00
										 |  |  | static void esp_netif_internal_dhcpc_cb(struct netif *netif) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  |     esp_netif_t *esp_netif; | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s lwip-netif:%p", __func__, netif); | 
					
						
							|  |  |  |     if (netif == NULL || (esp_netif = lwip_get_esp_netif(netif)) == NULL) { | 
					
						
							|  |  |  |         // internal pointer hasn't been configured yet (probably in the interface init_fn())
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     esp_netif_ip_info_t *ip_info = esp_netif->ip_info; | 
					
						
							|  |  |  |     esp_netif_ip_info_t *ip_info_old = esp_netif->ip_info_old; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ( !ip4_addr_cmp(ip_2_ip4(&netif->ip_addr), IP4_ADDR_ANY4) ) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-16 16:58:48 +01:00
										 |  |  |         //check whether IP is changed (or if we're an PPP interface)
 | 
					
						
							|  |  |  |         if ( (!ip4_addr_cmp(ip_2_ip4(&netif->ip_addr), (&ip_info->ip)) || | 
					
						
							|  |  |  |               !ip4_addr_cmp(ip_2_ip4(&netif->netmask), (&ip_info->netmask)) || | 
					
						
							|  |  |  |               !ip4_addr_cmp(ip_2_ip4(&netif->gw), (&ip_info->gw))) | 
					
						
							|  |  |  |           // post IP event for PPP interfaces even if IP hasn't changed
 | 
					
						
							|  |  |  |              || (_IS_NETIF_ANY_POINT2POINT_TYPE(esp_netif))) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             ip_event_got_ip_t evt = { | 
					
						
							|  |  |  |                     .esp_netif = esp_netif, | 
					
						
							|  |  |  |                     .ip_changed = false, | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  |             ip_event_t evt_id = esp_netif_get_event_id(esp_netif, ESP_NETIF_IP_EVENT_GOT_IP); | 
					
						
							|  |  |  |             int ret; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             ip4_addr_set(&ip_info->ip, ip_2_ip4(&netif->ip_addr)); | 
					
						
							|  |  |  |             ip4_addr_set(&ip_info->netmask, ip_2_ip4(&netif->netmask)); | 
					
						
							|  |  |  |             ip4_addr_set(&ip_info->gw, ip_2_ip4(&netif->gw)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             //notify event
 | 
					
						
							|  |  |  |             if (memcmp(ip_info, ip_info_old, sizeof(esp_netif_ip_info_t))) { | 
					
						
							|  |  |  |                 evt.ip_changed = true; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             memcpy(&evt.ip_info, ip_info, sizeof(esp_netif_ip_info_t)); | 
					
						
							|  |  |  |             memcpy(ip_info_old, ip_info, sizeof(esp_netif_ip_info_t)); | 
					
						
							|  |  |  |             ESP_LOGD(TAG, "if%p ip changed=%d", esp_netif, evt.ip_changed); | 
					
						
							| 
									
										
										
										
											2021-12-02 15:49:28 +05:30
										 |  |  |             ret = esp_event_post(IP_EVENT, evt_id, &evt, sizeof(evt), 0); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             if (ESP_OK != ret) { | 
					
						
							|  |  |  |                 ESP_LOGE(TAG, "dhcpc cb: failed to post got ip event (%x)", ret); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2022-03-23 19:20:06 +01:00
										 |  |  | #ifdef CONFIG_LWIP_DHCP_RESTORE_LAST_IP
 | 
					
						
							|  |  |  |             dhcp_ip_addr_store(netif); | 
					
						
							|  |  |  | #endif /* CONFIG_LWIP_DHCP_RESTORE_LAST_IP */
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         } else { | 
					
						
							|  |  |  |             ESP_LOGD(TAG, "if%p ip unchanged", esp_netif); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         if (!ip4_addr_cmp(&ip_info->ip, IP4_ADDR_ANY4)) { | 
					
						
							|  |  |  |             esp_netif_start_ip_lost_timer(esp_netif); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void esp_netif_ip_lost_timer(void *arg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |     esp_netif_t *esp_netif = esp_netif_is_active(arg); | 
					
						
							| 
									
										
										
										
											2019-09-04 13:58:29 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif == NULL) { | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |         ESP_LOGD(TAG, "%s esp_netif=%p not active any more", __func__, arg); | 
					
						
							| 
									
										
										
										
											2019-09-04 13:58:29 +02:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     esp_netif->timer_running = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct netif *netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ( (!netif) || (netif && ip4_addr_cmp(ip_2_ip4(&netif->ip_addr), IP4_ADDR_ANY4))) { | 
					
						
							|  |  |  |         ip_event_got_ip_t evt = { | 
					
						
							|  |  |  |                 .esp_netif = esp_netif, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         int ret; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "if%p ip lost tmr: raise ip lost event", esp_netif); | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |         memset(esp_netif->ip_info_old, 0, sizeof(esp_netif_ip_info_t)); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         if (esp_netif->lost_ip_event) { | 
					
						
							| 
									
										
										
										
											2021-12-02 15:49:28 +05:30
										 |  |  |             ret = esp_event_post(IP_EVENT, esp_netif->lost_ip_event, | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                                           &evt, sizeof(evt), 0); | 
					
						
							|  |  |  |             if (ESP_OK != ret) { | 
					
						
							|  |  |  |                 ESP_LOGE(TAG, "ip lost timer: failed to post lost ip event (%x)", ret); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "if%p ip lost tmr: no need raise ip lost event", esp_netif); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_start_ip_lost_timer(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |     esp_netif_ip_info_t *ip_info_old = esp_netif->ip_info; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     struct netif *netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif->timer_running) { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "if%p start ip lost tmr: already started", esp_netif); | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-06 15:27:51 +08:00
										 |  |  |     if ( netif && (CONFIG_ESP_NETIF_IP_LOST_TIMER_INTERVAL > 0)) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         esp_netif->timer_running = true; | 
					
						
							|  |  |  |         sys_timeout(CONFIG_ESP_NETIF_IP_LOST_TIMER_INTERVAL * 1000, esp_netif_ip_lost_timer, (void *)esp_netif); | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "if%p start ip lost tmr: interval=%d", esp_netif, CONFIG_ESP_NETIF_IP_LOST_TIMER_INTERVAL); | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 16:27:29 +01:00
										 |  |  |     ESP_LOGD(TAG, "if%p start ip lost tmr: no need start because netif=%p interval=%d ip=%" PRIx32, | 
					
						
							|  |  |  |              esp_netif, netif, (CONFIG_ESP_NETIF_IP_LOST_TIMER_INTERVAL), ip_info_old->ip.addr); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_dhcpc_stop_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif == NULL) { | 
					
						
							|  |  |  |         ESP_LOGE(TAG, "dhcp client stop called with NULL api"); | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif->dhcpc_status == ESP_NETIF_DHCP_STARTED) { | 
					
						
							|  |  |  |         struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (p_netif != NULL) { | 
					
						
							|  |  |  |             dhcp_stop(p_netif); | 
					
						
							|  |  |  |             esp_netif_reset_ip_info(esp_netif); | 
					
						
							|  |  |  |             esp_netif_start_ip_lost_timer(esp_netif); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             ESP_LOGD(TAG, "dhcp client if not ready"); | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } else if (esp_netif->dhcpc_status == ESP_NETIF_DHCP_STOPPED) { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "dhcp client already stoped"); | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_DHCP_ALREADY_STOPPED; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "dhcp client stop successfully"); | 
					
						
							|  |  |  |     esp_netif->dhcpc_status = ESP_NETIF_DHCP_STOPPED; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-23 19:20:06 +01:00
										 |  |  | #ifdef CONFIG_LWIP_DHCP_RESTORE_LAST_IP
 | 
					
						
							|  |  |  |     dhcp_ip_addr_erase(esp_netif->lwip_netif); | 
					
						
							|  |  |  | #endif /* CONFIG_LWIP_DHCP_RESTORE_LAST_IP */
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | esp_err_t esp_netif_dhcpc_stop(esp_netif_t *esp_netif) _RUN_IN_LWIP_TASK_IF_SUPPORTED(esp_netif_dhcpc_stop_api, esp_netif, NULL) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | static void dns_clear_servers(bool keep_fallback) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     u8_t numdns = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (numdns = 0; numdns < DNS_MAX_SERVERS; numdns ++) { | 
					
						
							|  |  |  |         if (keep_fallback && numdns == DNS_FALLBACK_SERVER_INDEX) { | 
					
						
							|  |  |  |             continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         dns_setserver(numdns, NULL); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | static esp_err_t esp_netif_dhcpc_start_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!esp_netif) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-23 11:29:45 +02:00
										 |  |  |     if (esp_netif->dhcpc_status == ESP_NETIF_DHCP_STARTED) { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "dhcp client already started"); | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_DHCP_ALREADY_STARTED; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     esp_netif_reset_ip_info(esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if LWIP_DNS
 | 
					
						
							|  |  |  |     dns_clear_servers(true); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (p_netif != NULL) { | 
					
						
							|  |  |  |         if (netif_is_up(p_netif)) { | 
					
						
							|  |  |  |             ip_addr_set_zero(&p_netif->ip_addr); | 
					
						
							|  |  |  |             ip_addr_set_zero(&p_netif->netmask); | 
					
						
							|  |  |  |             ip_addr_set_zero(&p_netif->gw); | 
					
						
							|  |  |  |             esp_netif_start_ip_lost_timer(esp_netif); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             ESP_LOGD(TAG, "dhcp client re init"); | 
					
						
							|  |  |  |             esp_netif->dhcpc_status = ESP_NETIF_DHCP_INIT; | 
					
						
							|  |  |  |             return ESP_OK; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "starting dhcp client"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (dhcp_start(p_netif) != ERR_OK) { | 
					
						
							|  |  |  |             ESP_LOGE(TAG, "dhcp client start failed"); | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_DHCPC_START_FAILED; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         esp_netif->dhcpc_status = ESP_NETIF_DHCP_STARTED; | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "dhcp client re init"); | 
					
						
							|  |  |  |         esp_netif->dhcpc_status = ESP_NETIF_DHCP_INIT; | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | esp_err_t esp_netif_dhcpc_start(esp_netif_t *esp_netif) _RUN_IN_LWIP_TASK_IF_SUPPORTED(esp_netif_dhcpc_start_api, esp_netif, NULL) | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif /* CONFIG_LWIP_IPV4 */
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #if ESP_DHCPS
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | esp_err_t esp_netif_dhcps_get_status(esp_netif_t *esp_netif, esp_netif_dhcp_status_t *status) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |     if (!esp_netif || (esp_netif->flags & ESP_NETIF_DHCP_CLIENT) || _IS_NETIF_ANY_POINT2POINT_TYPE(esp_netif)) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     *status = esp_netif->dhcps_status; | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_dhcpc_get_status(esp_netif_t *esp_netif, esp_netif_dhcp_status_t *status) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |     if (!esp_netif || (esp_netif->flags & ESP_NETIF_DHCP_SERVER) || _IS_NETIF_ANY_POINT2POINT_TYPE(esp_netif)) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     *status = esp_netif->dhcpc_status; | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #if ESP_DHCPS
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | static esp_err_t esp_netif_dhcps_start_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     if (!esp_netif) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-23 11:29:45 +02:00
										 |  |  |     if (esp_netif->dhcps_status == ESP_NETIF_DHCP_STARTED) { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "dhcp server already started"); | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_DHCP_ALREADY_STARTED; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  |     if (p_netif != NULL && netif_is_up(p_netif)) { | 
					
						
							|  |  |  |         esp_netif_ip_info_t *default_ip = esp_netif->ip_info; | 
					
						
							|  |  |  |         ip4_addr_t lwip_ip; | 
					
						
							| 
									
										
										
										
											2020-04-02 19:46:45 +02:00
										 |  |  |         ip4_addr_t lwip_netmask; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         memcpy(&lwip_ip, &default_ip->ip, sizeof(struct ip4_addr)); | 
					
						
							| 
									
										
										
										
											2020-04-02 19:46:45 +02:00
										 |  |  |         memcpy(&lwip_netmask, &default_ip->netmask, sizeof(struct ip4_addr)); | 
					
						
							| 
									
										
										
										
											2022-02-02 17:17:39 +01:00
										 |  |  |         dhcps_set_new_lease_cb(esp_netif->dhcps, esp_netif_dhcps_cb, esp_netif); | 
					
						
							| 
									
										
										
										
											2022-01-19 19:50:49 +01:00
										 |  |  |         dhcps_set_option_info(esp_netif->dhcps, SUBNET_MASK, (void*)&lwip_netmask, sizeof(lwip_netmask)); | 
					
						
							| 
									
										
										
										
											2022-06-27 09:12:18 +02:00
										 |  |  |         if (dhcps_start(esp_netif->dhcps, p_netif, lwip_ip) != ERR_OK) { | 
					
						
							|  |  |  |             ESP_LOGE(TAG, "DHCP server cannot be started"); | 
					
						
							|  |  |  |             esp_netif->dhcps_status = ESP_NETIF_DHCP_INIT; | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_DHCPS_START_FAILED; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         esp_netif->dhcps_status = ESP_NETIF_DHCP_STARTED; | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "DHCP server started successfully"); | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "dhcp server re init"); | 
					
						
							|  |  |  |         esp_netif->dhcps_status = ESP_NETIF_DHCP_INIT; | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | esp_err_t esp_netif_dhcps_start(esp_netif_t *esp_netif) _RUN_IN_LWIP_TASK_IF_SUPPORTED(esp_netif_dhcps_start_api, esp_netif, NULL) | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | static esp_err_t esp_netif_dhcps_stop_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!esp_netif) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  |     if (esp_netif->dhcps_status == ESP_NETIF_DHCP_STARTED) { | 
					
						
							| 
									
										
										
										
											2022-06-27 09:12:18 +02:00
										 |  |  |         if (dhcps_stop(esp_netif->dhcps, p_netif) != ERR_OK) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             ESP_LOGD(TAG, "dhcp server if not ready"); | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } else if (esp_netif->dhcps_status == ESP_NETIF_DHCP_STOPPED) { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "dhcp server already stoped"); | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_DHCP_ALREADY_STOPPED; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "dhcp server stop successfully"); | 
					
						
							|  |  |  |     esp_netif->dhcps_status = ESP_NETIF_DHCP_STOPPED; | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | esp_err_t esp_netif_dhcps_stop(esp_netif_t *esp_netif) _RUN_IN_LWIP_TASK_IF_SUPPORTED(esp_netif_dhcps_stop_api, esp_netif, NULL) | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | static esp_err_t esp_netif_set_hostname_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							|  |  |  |     const char *hostname = msg->data; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p hostname %s", __func__, esp_netif, hostname); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!esp_netif) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if LWIP_NETIF_HOSTNAME
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (strlen(hostname) > ESP_NETIF_HOSTNAME_MAX_SIZE) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (p_netif != NULL) { | 
					
						
							| 
									
										
										
										
											2020-11-02 20:40:25 +01:00
										 |  |  |         if (esp_netif->hostname) { | 
					
						
							|  |  |  |             free(esp_netif->hostname); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         esp_netif->hostname = strdup(hostname); | 
					
						
							|  |  |  |         if (esp_netif->hostname == NULL) { | 
					
						
							|  |  |  |             p_netif->hostname = CONFIG_LWIP_LOCAL_HOSTNAME; | 
					
						
							|  |  |  |             return ESP_ERR_NO_MEM; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         p_netif->hostname = esp_netif->hostname; | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | esp_err_t esp_netif_set_hostname(esp_netif_t *esp_netif, const char *hostname) _RUN_IN_LWIP_TASK_IF_SUPPORTED(esp_netif_set_hostname_api, esp_netif, hostname) | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | esp_err_t esp_netif_get_hostname(esp_netif_t *esp_netif, const char **hostname) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |     if (!esp_netif || _IS_NETIF_ANY_POINT2POINT_TYPE(esp_netif)) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if LWIP_NETIF_HOSTNAME
 | 
					
						
							|  |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-10 13:40:54 +01:00
										 |  |  |     if (p_netif != NULL && p_netif->hostname != NULL) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         *hostname = p_netif->hostname; | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2020-02-10 13:40:54 +01:00
										 |  |  |         return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  | static esp_err_t esp_netif_up_api(esp_netif_api_msg_t *msg) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!esp_netif) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_STATE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct netif *lwip_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     /* use last obtained ip, or static ip */ | 
					
						
							|  |  |  |     netif_set_addr(lwip_netif, (ip4_addr_t*)&esp_netif->ip_info->ip, (ip4_addr_t*)&esp_netif->ip_info->netmask, (ip4_addr_t*)&esp_netif->ip_info->gw); | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     netif_set_up(lwip_netif); | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  |     netif_set_link_up(lwip_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     esp_netif_update_default_netif(esp_netif, ESP_NETIF_STARTED); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-04 12:41:32 +01:00
										 |  |  | esp_err_t esp_netif_up(esp_netif_t *esp_netif) _RUN_IN_LWIP_TASK(esp_netif_up_api, esp_netif, NULL) | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | static esp_err_t esp_netif_down_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!esp_netif) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_STATE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct netif *lwip_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-30 20:29:13 +01:00
										 |  |  |     if (esp_netif->flags & ESP_NETIF_DHCP_CLIENT && esp_netif->dhcpc_status == ESP_NETIF_DHCP_STARTED) { | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         dhcp_stop(esp_netif->lwip_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         esp_netif->dhcpc_status = ESP_NETIF_DHCP_INIT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         esp_netif_reset_ip_info(esp_netif); | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-01-18 19:14:51 +08:00
										 |  |  | #if CONFIG_LWIP_IPV6
 | 
					
						
							| 
									
										
										
										
											2023-01-03 17:10:16 +08:00
										 |  |  | #if ESP_MLDV6_REPORT
 | 
					
						
							|  |  |  |         if (esp_netif->flags & ESP_NETIF_FLAG_MLDV6_REPORT) { | 
					
						
							|  |  |  |             netif_unset_mldv6_flag(esp_netif->lwip_netif); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2020-03-18 18:30:53 +08:00
										 |  |  |     for(int8_t i = 0 ;i < LWIP_IPV6_NUM_ADDRESSES ;i++) { | 
					
						
							|  |  |  |         netif_ip6_addr_set(lwip_netif, i, IP6_ADDR_ANY6); | 
					
						
							| 
									
										
										
										
											2020-07-01 15:35:46 +08:00
										 |  |  |         netif_ip6_addr_set_valid_life(lwip_netif, i, 0); | 
					
						
							|  |  |  |         netif_ip6_addr_set_pref_life(lwip_netif, i, 0); | 
					
						
							|  |  |  |         netif_ip6_addr_set_state(lwip_netif, i, IP6_ADDR_INVALID); | 
					
						
							| 
									
										
										
										
											2020-03-18 18:30:53 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-01-18 19:14:51 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     netif_set_addr(lwip_netif, IP4_ADDR_ANY4, IP4_ADDR_ANY4, IP4_ADDR_ANY4); | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     netif_set_down(lwip_netif); | 
					
						
							| 
									
										
										
										
											2022-05-06 16:09:24 +02:00
										 |  |  |     netif_set_link_down(lwip_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-30 20:29:13 +01:00
										 |  |  |     if (esp_netif->flags & ESP_NETIF_DHCP_CLIENT) { | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         esp_netif_start_ip_lost_timer(esp_netif); | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     esp_netif_update_default_netif(esp_netif, ESP_NETIF_STOPPED); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-04 12:41:32 +01:00
										 |  |  | esp_err_t esp_netif_down(esp_netif_t *esp_netif) _RUN_IN_LWIP_TASK(esp_netif_down_api, esp_netif, NULL) | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | bool esp_netif_is_netif_up(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ESP_LOGV(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-21 16:40:31 +02:00
										 |  |  |     if (esp_netif != NULL && esp_netif->lwip_netif != NULL) { | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |         if (_IS_NETIF_ANY_POINT2POINT_TYPE(esp_netif)) { | 
					
						
							| 
									
										
										
										
											2020-04-21 16:40:31 +02:00
										 |  |  |             // ppp implementation uses netif_set_link_up/down to update link state
 | 
					
						
							|  |  |  |             return netif_is_link_up(esp_netif->lwip_netif); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         // esp-netif handlers and drivers take care to set_netif_up/down on link state update
 | 
					
						
							|  |  |  |         return netif_is_up(esp_netif->lwip_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } else { | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | esp_err_t esp_netif_get_old_ip_info(esp_netif_t *esp_netif, esp_netif_ip_info_t *ip_info) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif == NULL || ip_info == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     memcpy(ip_info, esp_netif->ip_info_old, sizeof(esp_netif_ip_info_t)); | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_get_ip_info(esp_netif_t *esp_netif, esp_netif_ip_info_t *ip_info) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif == NULL || ip_info == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_ARG; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (p_netif != NULL && netif_is_up(p_netif)) { | 
					
						
							|  |  |  |         ip4_addr_set(&ip_info->ip, ip_2_ip4(&p_netif->ip_addr)); | 
					
						
							|  |  |  |         ip4_addr_set(&ip_info->netmask, ip_2_ip4(&p_netif->netmask)); | 
					
						
							|  |  |  |         ip4_addr_set(&ip_info->gw, ip_2_ip4(&p_netif->gw)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     memcpy(ip_info, esp_netif->ip_info, sizeof(esp_netif_ip_info_t)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool esp_netif_is_valid_static_ip(esp_netif_ip_info_t *ip_info) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (!(ip4_addr_isany_val(ip_info->ip) || ip4_addr_isany_val(ip_info->netmask))) { | 
					
						
							|  |  |  |         // let's assume valid ip_info is when none of ip and netmask is 'any' address (zeros)
 | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_set_ip_old_info_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							|  |  |  |     const esp_netif_ip_info_t *ip_info = msg->data; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif == NULL || ip_info == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_STATE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     memcpy(msg->esp_netif->ip_info_old, msg->data, sizeof(esp_netif_ip_info_t)); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | esp_err_t esp_netif_set_old_ip_info(esp_netif_t *esp_netif, const esp_netif_ip_info_t *ip_info) _RUN_IN_LWIP_TASK_IF_SUPPORTED(esp_netif_set_ip_old_info_api, esp_netif, ip_info) | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | static esp_err_t esp_netif_set_ip_info_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							|  |  |  |     const esp_netif_ip_info_t *ip_info = msg->data; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif == NULL || ip_info == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_INVALID_STATE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-30 20:29:13 +01:00
										 |  |  |     if (esp_netif->flags & ESP_NETIF_DHCP_SERVER) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         if (esp_netif->dhcps_status != ESP_NETIF_DHCP_STOPPED) { | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_DHCP_NOT_STOPPED; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2019-10-30 20:29:13 +01:00
										 |  |  |     } else if (esp_netif->flags & ESP_NETIF_DHCP_CLIENT) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         if (esp_netif->dhcpc_status != ESP_NETIF_DHCP_STOPPED) { | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_DHCP_NOT_STOPPED; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | #if LWIP_DNS /* don't build if not configured for use in lwipopts.h */
 | 
					
						
							|  |  |  |         dns_clear_servers(true); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ip4_addr_copy(esp_netif->ip_info->ip, ip_info->ip); | 
					
						
							|  |  |  |     ip4_addr_copy(esp_netif->ip_info->gw, ip_info->gw); | 
					
						
							|  |  |  |     ip4_addr_copy(esp_netif->ip_info->netmask, ip_info->netmask); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (p_netif != NULL && netif_is_up(p_netif)) { | 
					
						
							|  |  |  |         netif_set_addr(p_netif, (ip4_addr_t*)&ip_info->ip, (ip4_addr_t*)&ip_info->netmask, (ip4_addr_t*)&ip_info->gw); | 
					
						
							|  |  |  |         if (ESP_NETIF_FLAG_EVENT_IP_MODIFIED & esp_netif->flags) { | 
					
						
							|  |  |  |             if (!(ip4_addr_isany_val(ip_info->ip) || ip4_addr_isany_val(ip_info->netmask) || ip4_addr_isany_val(ip_info->gw))) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 ip_event_t evt_id = esp_netif->get_ip_event; | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  |                 ip_event_got_ip_t evt = { .esp_netif = esp_netif, .ip_changed = false}; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 int ret; | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |                 if (memcmp(ip_info, esp_netif->ip_info_old, sizeof(esp_netif_ip_info_t))) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                     evt.ip_changed = true; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 memcpy(&evt.ip_info, ip_info, sizeof(esp_netif_ip_info_t)); | 
					
						
							| 
									
										
										
										
											2019-09-06 11:28:04 +02:00
										 |  |  |                 memcpy(esp_netif->ip_info_old, ip_info, sizeof(esp_netif_ip_info_t)); | 
					
						
							| 
									
										
										
										
											2021-12-02 15:49:28 +05:30
										 |  |  |                 ret = esp_event_post(IP_EVENT, evt_id, &evt, sizeof(evt), 0); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 if (ESP_OK != ret) { | 
					
						
							|  |  |  |                     ESP_LOGE(TAG, "set ip info: failed to post got ip event (%x)", ret); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 ESP_LOGD(TAG, "if%p netif set static ip: ip changed=%d", esp_netif, evt.ip_changed); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | esp_err_t esp_netif_set_ip_info(esp_netif_t *esp_netif, const esp_netif_ip_info_t *ip_info) _RUN_IN_LWIP_TASK_IF_SUPPORTED(esp_netif_set_ip_info_api, esp_netif, ip_info) | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif /* CONFIG_LWIP_IPV4 */
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-11 16:01:48 +02:00
										 |  |  | struct array_mac_ip_t { | 
					
						
							|  |  |  |     int num; | 
					
						
							|  |  |  |     esp_netif_pair_mac_ip_t *mac_ip_pair; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if CONFIG_LWIP_DHCPS
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_dhcps_get_clients_by_mac_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_t *netif = msg->esp_netif; | 
					
						
							| 
									
										
										
										
											2022-07-14 10:34:06 +02:00
										 |  |  |     struct array_mac_ip_t *mac_ip_list = msg->data; | 
					
						
							|  |  |  |     for (int i = 0; i < mac_ip_list->num; i++) { | 
					
						
							|  |  |  |         dhcp_search_ip_on_mac(netif->dhcps, mac_ip_list->mac_ip_pair[i].mac, (ip4_addr_t*)&mac_ip_list->mac_ip_pair[i].ip); | 
					
						
							| 
									
										
										
										
											2022-05-11 16:01:48 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif // CONFIG_LWIP_DHCPS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_dhcps_get_clients_by_mac(esp_netif_t *esp_netif, int num, esp_netif_pair_mac_ip_t *mac_ip_pair) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if CONFIG_LWIP_DHCPS
 | 
					
						
							|  |  |  |     if (esp_netif == NULL || esp_netif->dhcps == NULL || num < 0 || mac_ip_pair == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     struct array_mac_ip_t array_mac_ip = { num, mac_ip_pair }; | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call(esp_netif_dhcps_get_clients_by_mac_api, esp_netif, (void *)&array_mac_ip); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     return ESP_ERR_NOT_SUPPORTED; | 
					
						
							|  |  |  | #endif // CONFIG_LWIP_DHCPS
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | static esp_err_t esp_netif_set_dns_info_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							|  |  |  |     esp_netif_dns_param_t *dns_param = msg->data; | 
					
						
							|  |  |  |     esp_netif_dns_type_t type = dns_param->dns_type; | 
					
						
							|  |  |  |     esp_netif_dns_info_t *dns = dns_param->dns_info; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 16:27:29 +01:00
										 |  |  |     ESP_LOGD(TAG, "esp_netif_set_dns_info: if=%p type=%d dns=%" PRIx32, esp_netif, type, dns->ip.u_addr.ip4.addr); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  |     ip_addr_t lwip_ip = {}; | 
					
						
							|  |  |  |     ESPIP_TO_IP(&dns->ip, &lwip_ip); | 
					
						
							| 
									
										
										
										
											2019-10-30 20:29:13 +01:00
										 |  |  |     if (esp_netif->flags & ESP_NETIF_DHCP_SERVER) { | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #if ESP_DHCPS
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         // if DHCP server configured to set DNS in dhcps API
 | 
					
						
							|  |  |  |         if (type != ESP_NETIF_DNS_MAIN) { | 
					
						
							|  |  |  |             ESP_LOGD(TAG, "set dns invalid type"); | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  |             dhcps_dns_setserver(esp_netif->dhcps, &lwip_ip); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #else
 | 
					
						
							|  |  |  |         LOG_NETIF_DISABLED_AND_DO("DHCP Server", return ESP_ERR_NOT_SUPPORTED); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  |         dns_setserver(type, &lwip_ip); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | esp_err_t esp_netif_set_dns_info(esp_netif_t *esp_netif, esp_netif_dns_type_t type, esp_netif_dns_info_t *dns) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2023-01-02 16:49:37 +01:00
										 |  |  |     if (esp_netif == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dns == NULL) { | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "set dns null dns"); | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-01-02 16:49:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  |     if (ESP_IP_IS_ANY(dns->ip)) { | 
					
						
							| 
									
										
										
										
											2023-01-02 16:49:37 +01:00
										 |  |  |         ESP_LOGD(TAG, "set dns invalid dns"); | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_dns_param_t dns_param = { | 
					
						
							|  |  |  |         .dns_type = type, | 
					
						
							|  |  |  |         .dns_info = dns | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call(esp_netif_set_dns_info_api, esp_netif, (void *)&dns_param); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | static esp_err_t esp_netif_get_dns_info_api(esp_netif_api_msg_t *msg) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							|  |  |  |     esp_netif_dns_param_t *dns_param = msg->data; | 
					
						
							|  |  |  |     esp_netif_dns_type_t type = dns_param->dns_type; | 
					
						
							|  |  |  |     esp_netif_dns_info_t *dns = dns_param->dns_info; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-02 16:49:37 +01:00
										 |  |  |     ESP_LOGD(TAG, "esp_netif_get_dns_info: esp_netif=%p type=%d", esp_netif, type); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-30 20:29:13 +01:00
										 |  |  |     if (esp_netif->flags & ESP_NETIF_DHCP_SERVER) { | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #if ESP_DHCPS
 | 
					
						
							| 
									
										
										
										
											2022-02-02 15:54:49 +01:00
										 |  |  |         ip4_addr_t dns_ip; | 
					
						
							|  |  |  |         dhcps_dns_getserver(esp_netif->dhcps, &dns_ip); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         memcpy(&dns->ip.u_addr.ip4, &dns_ip, sizeof(ip4_addr_t)); | 
					
						
							| 
									
										
										
										
											2023-01-02 16:49:37 +01:00
										 |  |  |         dns->ip.type = ESP_IPADDR_TYPE_V4; | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #else
 | 
					
						
							|  |  |  |         LOG_NETIF_DISABLED_AND_DO("DHCP Server", return ESP_ERR_NOT_SUPPORTED); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } else { | 
					
						
							|  |  |  |         const ip_addr_t*  dns_ip = NULL; | 
					
						
							|  |  |  |         dns_ip = dns_getserver(type); | 
					
						
							|  |  |  |         if(dns_ip != NULL) { | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  |             IP_TO_ESPIP(dns_ip, &dns->ip); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | esp_err_t esp_netif_get_dns_info(esp_netif_t *esp_netif, esp_netif_dns_type_t type, esp_netif_dns_info_t *dns) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2023-01-02 16:49:37 +01:00
										 |  |  |     if (esp_netif == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dns == NULL) { | 
					
						
							|  |  |  |         ESP_LOGE(TAG, "%s: dns_info cannot be NULL", __func__); | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_dns_param_t dns_param = { | 
					
						
							|  |  |  |         .dns_type = type, | 
					
						
							|  |  |  |         .dns_info = dns | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call(esp_netif_get_dns_info_api, esp_netif, (void *)&dns_param); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-18 19:14:51 +08:00
										 |  |  | #if CONFIG_LWIP_IPV6
 | 
					
						
							| 
									
										
										
										
											2023-01-03 17:10:16 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef CONFIG_LWIP_MLDV6_TMR_INTERVAL
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void netif_send_mldv6(void *arg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     struct netif *netif = arg; | 
					
						
							|  |  |  |     if (!netif_is_up(netif)) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     mld6_report_groups(netif); | 
					
						
							|  |  |  |     sys_timeout(CONFIG_LWIP_MLDV6_TMR_INTERVAL*1000, netif_send_mldv6, netif); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void netif_set_mldv6_flag(struct netif *netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (!netif_is_up(netif)) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     sys_timeout(CONFIG_LWIP_MLDV6_TMR_INTERVAL*1000, netif_send_mldv6, netif); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void netif_unset_mldv6_flag(struct netif *netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     sys_untimeout(netif_send_mldv6, netif); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-06 16:48:36 +01:00
										 |  |  | esp_ip6_addr_type_t esp_netif_ip6_get_addr_type(esp_ip6_addr_t* ip6_addr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ip6_addr_t* lwip_ip6_info = (ip6_addr_t*)ip6_addr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (ip6_addr_isglobal(lwip_ip6_info)) { | 
					
						
							|  |  |  |         return ESP_IP6_ADDR_IS_GLOBAL; | 
					
						
							|  |  |  |     } else if (ip6_addr_islinklocal(lwip_ip6_info)) { | 
					
						
							|  |  |  |         return ESP_IP6_ADDR_IS_LINK_LOCAL; | 
					
						
							|  |  |  |     } else if (ip6_addr_issitelocal(lwip_ip6_info)) { | 
					
						
							|  |  |  |         return ESP_IP6_ADDR_IS_SITE_LOCAL; | 
					
						
							|  |  |  |     } else if (ip6_addr_isuniquelocal(lwip_ip6_info)) { | 
					
						
							|  |  |  |         return ESP_IP6_ADDR_IS_UNIQUE_LOCAL; | 
					
						
							|  |  |  |     } else if (ip6_addr_isipv4mappedipv6(lwip_ip6_info)) { | 
					
						
							|  |  |  |         return ESP_IP6_ADDR_IS_IPV4_MAPPED_IPV6; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ESP_IP6_ADDR_IS_UNKNOWN; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  | static void esp_netif_internal_nd6_cb(struct netif *netif, uint8_t ip_index) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  |     esp_netif_t *esp_netif; | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s lwip-netif:%p", __func__, netif); | 
					
						
							|  |  |  |     if (netif == NULL || (esp_netif = lwip_get_esp_netif(netif)) == NULL) { | 
					
						
							|  |  |  |         // internal pointer hasn't been configured yet (probably in the interface init_fn())
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     esp_netif_ip6_info_t ip6_info; | 
					
						
							|  |  |  |     ip6_addr_t lwip_ip6_info; | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  |     ip_event_got_ip6_t evt = { .esp_netif = esp_netif, .ip_index = ip_index }; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  |     ip6_addr_set(&lwip_ip6_info, ip_2_ip6(&netif->ip6_addr[ip_index])); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | #if LWIP_IPV6_SCOPES
 | 
					
						
							|  |  |  |     memcpy(&ip6_info.ip, &lwip_ip6_info, sizeof(esp_ip6_addr_t)); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     memcpy(&ip6_info.ip, &lwip_ip6_info, sizeof(ip6_addr_t)); | 
					
						
							|  |  |  |     ip6_info.ip.zone = 0;   // zero out zone, as not used in lwip
 | 
					
						
							|  |  |  | #endif /* LWIP_IPV6_SCOPES */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-03 17:10:16 +08:00
										 |  |  |     if (esp_netif->flags&ESP_NETIF_FLAG_MLDV6_REPORT) { | 
					
						
							|  |  |  | #if ESP_MLDV6_REPORT
 | 
					
						
							|  |  |  |         netif_set_mldv6_flag(netif); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |         ESP_LOGW(TAG,"CONFIG_LWIP_ESP_MLDV6_REPORT not enabled, but esp-netif configured with ESP_NETIF_FLAG_MLDV6_REPORT"); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     memcpy(&evt.ip6_info, &ip6_info, sizeof(esp_netif_ip6_info_t)); | 
					
						
							| 
									
										
										
										
											2021-12-02 15:49:28 +05:30
										 |  |  |     int ret = esp_event_post(IP_EVENT, IP_EVENT_GOT_IP6, &evt, sizeof(evt), 0); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     if (ESP_OK != ret) { | 
					
						
							|  |  |  |         ESP_LOGE(TAG, "nd6 cb: failed to post IP_EVENT_GOT_IP6 (%x)", ret); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_create_ip6_linklocal_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-23 16:23:46 +02:00
										 |  |  |     ESP_LOGV(TAG, "%s esp-netif:%p", __func__, esp_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  |     if (p_netif != NULL && netif_is_up(p_netif)) { | 
					
						
							|  |  |  |         netif_create_ip6_linklocal_address(p_netif, 1); | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         return ESP_FAIL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-21 13:23:58 +01:00
										 |  |  | esp_err_t esp_netif_create_ip6_linklocal(esp_netif_t *esp_netif) _RUN_IN_LWIP_TASK_IF_SUPPORTED(esp_netif_create_ip6_linklocal_api, esp_netif, NULL) | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | esp_err_t esp_netif_get_ip6_linklocal(esp_netif_t *esp_netif, esp_ip6_addr_t *if_ip6) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-23 16:23:46 +02:00
										 |  |  |     ESP_LOGV(TAG, "%s esp-netif:%p", __func__, esp_netif); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-12 16:43:34 +02:00
										 |  |  |     if (esp_netif == NULL || if_ip6 == NULL || _IS_NETIF_ANY_POINT2POINT_TYPE(esp_netif)) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (p_netif != NULL && netif_is_up(p_netif) && ip6_addr_ispreferred(netif_ip6_addr_state(p_netif, 0))) { | 
					
						
							|  |  |  |         memcpy(if_ip6, &p_netif->ip6_addr[0], sizeof(ip6_addr_t)); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         return ESP_FAIL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-27 10:34:00 +08:00
										 |  |  | esp_err_t esp_netif_get_ip6_global(esp_netif_t *esp_netif, esp_ip6_addr_t *if_ip6) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-23 16:23:46 +02:00
										 |  |  |     ESP_LOGV(TAG, "%s esp-netif:%p", __func__, esp_netif); | 
					
						
							| 
									
										
										
										
											2019-11-27 10:34:00 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif == NULL || if_ip6 == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     int i; | 
					
						
							|  |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (p_netif != NULL && netif_is_up(p_netif)) { | 
					
						
							|  |  |  |         for (i = 1; i < LWIP_IPV6_NUM_ADDRESSES; i++) { | 
					
						
							| 
									
										
										
										
											2020-07-01 15:35:46 +08:00
										 |  |  |             if (ip6_addr_ispreferred(netif_ip6_addr_state(p_netif, i)) && | 
					
						
							|  |  |  |                 ip6_addr_isglobal(netif_ip6_addr(p_netif, i))) { | 
					
						
							|  |  |  |                     memcpy(if_ip6, &p_netif->ip6_addr[i], sizeof(ip6_addr_t)); | 
					
						
							|  |  |  |                     return ESP_OK; | 
					
						
							| 
									
										
										
										
											2019-11-27 10:34:00 +08:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-04-23 16:23:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-27 10:34:00 +08:00
										 |  |  |     return ESP_FAIL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-23 16:23:46 +02:00
										 |  |  | int esp_netif_get_all_ip6(esp_netif_t *esp_netif, esp_ip6_addr_t if_ip6[]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ESP_LOGV(TAG, "%s esp-netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif == NULL || if_ip6 == NULL) { | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     int addr_count = 0; | 
					
						
							|  |  |  |     struct netif *p_netif = esp_netif->lwip_netif; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (p_netif != NULL && netif_is_up(p_netif)) { | 
					
						
							|  |  |  |         for (int i = 0; i < LWIP_IPV6_NUM_ADDRESSES; i++) { | 
					
						
							|  |  |  |             if (!ip_addr_cmp(&p_netif->ip6_addr[i], IP6_ADDR_ANY)) { | 
					
						
							|  |  |  |                 memcpy(&if_ip6[addr_count++], &p_netif->ip6_addr[i], sizeof(ip6_addr_t)); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return addr_count; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-01-18 19:14:51 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2020-04-23 16:23:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | esp_netif_flags_t esp_netif_get_flags(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return esp_netif->flags; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-12 10:06:50 +02:00
										 |  |  | const char *esp_netif_get_ifkey(esp_netif_t *esp_netif) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     return esp_netif->if_key; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-13 15:44:23 +02:00
										 |  |  | const char *esp_netif_get_desc(esp_netif_t *esp_netif) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-09-13 15:44:23 +02:00
										 |  |  |     return esp_netif->if_desc; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-30 16:49:50 +01:00
										 |  |  | int esp_netif_get_route_prio(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (esp_netif == NULL) { | 
					
						
							|  |  |  |         return -1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return esp_netif->route_prio; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-23 15:17:18 +02:00
										 |  |  | int32_t esp_netif_get_event_id(esp_netif_t *esp_netif, esp_netif_ip_event_type_t event_type) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     switch(event_type) { | 
					
						
							|  |  |  |         case ESP_NETIF_IP_EVENT_GOT_IP: | 
					
						
							|  |  |  |             return esp_netif->get_ip_event; | 
					
						
							|  |  |  |         case ESP_NETIF_IP_EVENT_LOST_IP: | 
					
						
							|  |  |  |             return esp_netif->lost_ip_event; | 
					
						
							| 
									
										
										
										
											2019-10-23 15:17:18 +02:00
										 |  |  |         default: | 
					
						
							|  |  |  |             return -1; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | struct dhcp_params { | 
					
						
							|  |  |  |     esp_netif_dhcp_option_mode_t op; | 
					
						
							|  |  |  |     esp_netif_dhcp_option_id_t id; | 
					
						
							|  |  |  |     void *val; | 
					
						
							|  |  |  |     uint32_t len; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-14 19:57:44 +08:00
										 |  |  | #if ESP_DHCPS
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | esp_err_t esp_netif_dhcps_option_api(esp_netif_api_msg_t *msg) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							|  |  |  |     struct dhcp_params *opt = msg->data; | 
					
						
							|  |  |  |     void *opt_info = dhcps_option_info(esp_netif->dhcps, opt->id, opt->len); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     esp_netif_dhcp_status_t dhcps_status = esp_netif->dhcps_status; | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     if (opt_info == NULL || opt->val == NULL) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     if (opt->op == ESP_NETIF_OP_GET) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         if (dhcps_status == ESP_NETIF_DHCP_STOPPED) { | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_DHCP_ALREADY_STOPPED; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |         switch (opt->id) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             case IP_ADDRESS_LEASE_TIME: { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 *(uint32_t *)opt->val = *(uint32_t *)opt_info; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-04-02 19:46:45 +02:00
										 |  |  |             case ESP_NETIF_SUBNET_MASK: | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             case REQUESTED_IP_ADDRESS: { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 memcpy(opt->val, opt_info, opt->len); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case ROUTER_SOLICITATION_ADDRESS: { | 
					
						
							|  |  |  |                 if ((*(uint8_t *)opt_info) & OFFER_ROUTER) { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                     *(uint8_t *)opt->val = 1; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 } else { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                     *(uint8_t *)opt->val = 0; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 } | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case DOMAIN_NAME_SERVER: { | 
					
						
							|  |  |  |                 if ((*(uint8_t *)opt_info) & OFFER_DNS) { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                     *(uint8_t *)opt->val = 1; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 } else { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                     *(uint8_t *)opt->val = 0; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 } | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             default: | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     } else if (opt->op == ESP_NETIF_OP_SET) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |         if (dhcps_status == ESP_NETIF_DHCP_STARTED) { | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_DHCP_ALREADY_STARTED; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |         switch (opt->id) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             case IP_ADDRESS_LEASE_TIME: { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 if (*(uint32_t *)opt->val != 0) { | 
					
						
							|  |  |  |                     *(uint32_t *)opt_info = *(uint32_t *)opt->val; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 } else { | 
					
						
							|  |  |  |                     *(uint32_t *)opt_info = DHCPS_LEASE_TIME_DEF; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-04-02 19:46:45 +02:00
										 |  |  |             case ESP_NETIF_SUBNET_MASK: { | 
					
						
							| 
									
										
										
										
											2023-11-10 11:19:41 +08:00
										 |  |  |                 esp_netif_ip_info_t *default_ip = esp_netif->ip_info; | 
					
						
							|  |  |  |                 ip4_addr_t *config_netmask = (ip4_addr_t *)opt->val; | 
					
						
							|  |  |  |                 if (!memcmp(&default_ip->netmask, config_netmask, sizeof(struct ip4_addr))) { | 
					
						
							|  |  |  |                     ESP_LOGE(TAG, "Please use esp_netif_set_ip_info interface to configure subnet mask"); | 
					
						
							|  |  |  |                     /*
 | 
					
						
							|  |  |  |                      * This API directly changes the subnet mask of dhcp server | 
					
						
							|  |  |  |                      * but the subnet mask of the network interface has not changed | 
					
						
							|  |  |  |                      * If you need to change the subnet mask of dhcp server | 
					
						
							|  |  |  |                      * you need to change the subnet mask of the network interface first. | 
					
						
							|  |  |  |                      * If the subnet mask of dhcp server is changed | 
					
						
							|  |  |  |                      * and the subnet mask of network interface is inconsistent | 
					
						
							|  |  |  |                      * with the subnet mask of dhcp sever, it may lead to the failure of sending packets. | 
					
						
							|  |  |  |                      * If want to configure the subnet mask of dhcp server | 
					
						
							|  |  |  |                      * please use esp_netif_set_ip_info to change the subnet mask of network interface first. | 
					
						
							|  |  |  |                      */ | 
					
						
							|  |  |  |                     return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 memcpy(opt_info, opt->val, opt->len); | 
					
						
							| 
									
										
										
										
											2020-04-02 19:46:45 +02:00
										 |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |             case REQUESTED_IP_ADDRESS: { | 
					
						
							|  |  |  |                 esp_netif_ip_info_t info; | 
					
						
							| 
									
										
										
										
											2023-08-29 16:01:40 +08:00
										 |  |  |                 uint32_t server_ip = 0; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 uint32_t start_ip = 0; | 
					
						
							|  |  |  |                 uint32_t end_ip = 0; | 
					
						
							| 
									
										
										
										
											2023-08-29 16:01:40 +08:00
										 |  |  |                 uint32_t range_start_ip = 0; | 
					
						
							|  |  |  |                 uint32_t range_end_ip = 0; | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 dhcps_lease_t *poll = opt->val; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 if (poll->enable) { | 
					
						
							|  |  |  |                     memset(&info, 0x00, sizeof(esp_netif_ip_info_t)); | 
					
						
							|  |  |  |                     esp_netif_get_ip_info(esp_netif, &info); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-29 16:01:40 +08:00
										 |  |  |                     server_ip = htonl(info.ip.addr); | 
					
						
							|  |  |  |                     range_start_ip = server_ip & htonl(info.netmask.addr); | 
					
						
							|  |  |  |                     range_end_ip = range_start_ip | ~htonl(info.netmask.addr); | 
					
						
							|  |  |  |                     if (server_ip == range_start_ip || server_ip == range_end_ip) { | 
					
						
							|  |  |  |                         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                     start_ip = htonl(poll->start_ip.addr); | 
					
						
							|  |  |  |                     end_ip = htonl(poll->end_ip.addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     /*config ip information can't contain local ip*/ | 
					
						
							| 
									
										
										
										
											2023-08-29 16:01:40 +08:00
										 |  |  |                     if ((server_ip >= start_ip) && (server_ip <= end_ip)) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     /*config ip information must be in the same segment as the local ip*/ | 
					
						
							| 
									
										
										
										
											2023-08-29 16:01:40 +08:00
										 |  |  |                     if (start_ip <= range_start_ip || start_ip >= range_end_ip) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2023-08-29 16:01:40 +08:00
										 |  |  |                     if (end_ip <= range_start_ip || end_ip >= range_end_ip) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2023-08-29 16:01:40 +08:00
										 |  |  |                     /*The number of configured ip is less than DHCPS_MAX_LEASE*/ | 
					
						
							|  |  |  |                     if ((end_ip - start_ip + 1 > DHCPS_MAX_LEASE) || (start_ip >= end_ip)) { | 
					
						
							|  |  |  |                         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 memcpy(opt_info, opt->val, opt->len); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case ROUTER_SOLICITATION_ADDRESS: { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 if (*(uint8_t *)opt->val) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                     *(uint8_t *)opt_info |= OFFER_ROUTER; | 
					
						
							|  |  |  |                 } else { | 
					
						
							|  |  |  |                     *(uint8_t *)opt_info &= ((~OFFER_ROUTER) & 0xFF); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case DOMAIN_NAME_SERVER: { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 if (*(uint8_t *)opt->val) { | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                     *(uint8_t *)opt_info |= OFFER_DNS; | 
					
						
							|  |  |  |                 } else { | 
					
						
							|  |  |  |                     *(uint8_t *)opt_info &= ((~OFFER_DNS) & 0xFF); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             default: | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |         dhcps_set_option_info(esp_netif->dhcps, opt->id, opt_info, opt->len); | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |     } else { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | esp_err_t esp_netif_dhcps_option(esp_netif_t *esp_netif, esp_netif_dhcp_option_mode_t opt_op, esp_netif_dhcp_option_id_t opt_id, void *opt_val, | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  |                                  uint32_t opt_len) | 
					
						
							| 
									
										
										
										
											2020-11-10 18:40:01 +11:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     if (esp_netif == NULL || esp_netif->dhcps == NULL) { | 
					
						
							| 
									
										
										
										
											2019-11-22 13:01:14 +08:00
										 |  |  |         return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     struct dhcp_params opts = { .op = opt_op, .id = opt_id, .len = opt_len, .val = opt_val }; | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call(esp_netif_dhcps_option_api, esp_netif, &opts); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif // ESP_DHCPS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if CONFIG_LWIP_IPV4
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_dhcpc_option_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							|  |  |  |     struct dhcp_params *opt = msg->data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-22 13:01:14 +08:00
										 |  |  |     struct dhcp *dhcp = netif_dhcp_data(esp_netif->lwip_netif); | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     if (dhcp == NULL || opt->val == NULL) { | 
					
						
							| 
									
										
										
										
											2019-11-22 13:01:14 +08:00
										 |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     if (opt->op == ESP_NETIF_OP_GET) { | 
					
						
							| 
									
										
										
										
											2020-04-16 17:38:59 +08:00
										 |  |  |         if (esp_netif->dhcpc_status == ESP_NETIF_DHCP_STOPPED) { | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_DHCP_ALREADY_STOPPED; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |         switch (opt->id) { | 
					
						
							| 
									
										
										
										
											2019-11-22 13:01:14 +08:00
										 |  |  |             case ESP_NETIF_IP_REQUEST_RETRY_TIME: | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 if (opt->len == sizeof(dhcp->tries)) { | 
					
						
							|  |  |  |                     *(uint8_t *)opt->val = dhcp->tries; | 
					
						
							| 
									
										
										
										
											2020-11-10 18:40:01 +11:00
										 |  |  |                 } | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2021-06-04 16:43:32 +08:00
										 |  |  | #if ESP_DHCP && !ESP_DHCP_DISABLE_VENDOR_CLASS_IDENTIFIER
 | 
					
						
							|  |  |  |             case ESP_NETIF_VENDOR_SPECIFIC_INFO: | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 return dhcp_get_vendor_specific_information(opt->len, opt->val); | 
					
						
							| 
									
										
										
										
											2021-06-04 16:43:32 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-11-22 13:01:14 +08:00
										 |  |  |             default: | 
					
						
							|  |  |  |                 return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     } else if (opt->op == ESP_NETIF_OP_SET) { | 
					
						
							| 
									
										
										
										
											2020-04-16 17:38:59 +08:00
										 |  |  |         if (esp_netif->dhcpc_status == ESP_NETIF_DHCP_STARTED) { | 
					
						
							|  |  |  |             return ESP_ERR_ESP_NETIF_DHCP_ALREADY_STARTED; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |         switch (opt->id) { | 
					
						
							| 
									
										
										
										
											2019-11-22 13:01:14 +08:00
										 |  |  |             case ESP_NETIF_IP_REQUEST_RETRY_TIME: | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 if (opt->len == sizeof(dhcp->tries)) { | 
					
						
							|  |  |  |                     dhcp->tries = *(uint8_t *)opt->val; | 
					
						
							| 
									
										
										
										
											2019-11-22 13:01:14 +08:00
										 |  |  |                 } | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2021-06-04 16:43:32 +08:00
										 |  |  | #if ESP_DHCP && !ESP_DHCP_DISABLE_VENDOR_CLASS_IDENTIFIER
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |                 case ESP_NETIF_VENDOR_CLASS_IDENTIFIER: | 
					
						
							|  |  |  |                 return dhcp_set_vendor_class_identifier(opt->len, opt->val); | 
					
						
							| 
									
										
										
										
											2021-06-04 16:43:32 +08:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-11-22 13:01:14 +08:00
										 |  |  |             default: | 
					
						
							|  |  |  |                 return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							| 
									
										
										
										
											2020-11-10 18:40:01 +11:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-11-22 13:01:14 +08:00
										 |  |  |     } else { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							| 
									
										
										
										
											2020-11-10 18:40:01 +11:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-22 13:01:14 +08:00
										 |  |  |     return ESP_OK; | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | esp_err_t esp_netif_dhcpc_option(esp_netif_t *esp_netif, esp_netif_dhcp_option_mode_t opt_op, esp_netif_dhcp_option_id_t opt_id, void *opt_val, | 
					
						
							|  |  |  |                                  uint32_t opt_len) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (esp_netif == NULL || esp_netif->lwip_netif == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     struct dhcp_params opts = { .op = opt_op, .id = opt_id, .len = opt_len, .val = opt_val }; | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call(esp_netif_dhcpc_option_api, esp_netif, &opts); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-03 17:28:01 +02:00
										 |  |  | #endif /* CONFIG_LWIP_IPV4 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 11:22:09 +02:00
										 |  |  | int esp_netif_get_netif_impl_index(esp_netif_t *esp_netif) | 
					
						
							| 
									
										
										
										
											2019-06-28 16:47:34 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     if (esp_netif == NULL || esp_netif->lwip_netif == NULL) { | 
					
						
							|  |  |  |         return -1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return netif_get_index(esp_netif->lwip_netif); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  | esp_err_t esp_netif_get_netif_impl_name_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     struct netif* netif = msg->esp_netif->lwip_netif; | 
					
						
							|  |  |  |     netif_index_to_name(netif_get_index(netif), msg->data); | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-23 14:13:56 +02:00
										 |  |  | esp_err_t esp_netif_get_netif_impl_name(esp_netif_t *esp_netif, char* name) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (esp_netif == NULL || esp_netif->lwip_netif == NULL) { | 
					
						
							|  |  |  |         return ESP_ERR_ESP_NETIF_INVALID_PARAMS; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-10-27 19:07:07 +02:00
										 |  |  |     return esp_netif_lwip_ipc_call(esp_netif_get_netif_impl_name_api, esp_netif, name); | 
					
						
							| 
									
										
										
										
											2020-04-23 14:13:56 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | #if IP_NAPT
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_napt_control_api(esp_netif_api_msg_t *msg) | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     bool enable = (bool)msg->data; | 
					
						
							|  |  |  |     esp_netif_t *esp_netif = msg->esp_netif; | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, esp_netif); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Check if the interface is up */ | 
					
						
							|  |  |  |     if (!netif_is_up(esp_netif->lwip_netif)) { | 
					
						
							|  |  |  |         return ESP_FAIL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     if (enable) { | 
					
						
							|  |  |  |         /* Disable napt on all other interface */ | 
					
						
							|  |  |  |         esp_netif_t *netif = esp_netif_next_unsafe(NULL); | 
					
						
							|  |  |  |         while (netif) { | 
					
						
							|  |  |  |             if (netif != esp_netif) { | 
					
						
							|  |  |  |                 ip_napt_enable_netif(netif->lwip_netif, 0); // Fails only if netif is down
 | 
					
						
							|  |  |  |                 ESP_LOGW(TAG, "napt disabled on esp_netif:%p", esp_netif); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             netif = esp_netif_next_unsafe(netif); | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         int ret = ip_napt_enable_netif(esp_netif->lwip_netif, 1); | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         if (ret == 0) { | 
					
						
							|  |  |  |             return ESP_FAIL; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         ip_napt_enable_netif(esp_netif->lwip_netif, 0); // Fails only if netif is down
 | 
					
						
							|  |  |  |         ESP_LOGD(TAG, "napt disabled on esp_netif:%p", esp_netif); | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |         return ESP_OK; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | #endif // !IP_NAPT
 | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | esp_err_t esp_netif_napt_enable(esp_netif_t *esp_netif) | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  | { | 
					
						
							|  |  |  | #if !IP_NAPT
 | 
					
						
							|  |  |  |     return ESP_ERR_NOT_SUPPORTED; | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  |     return esp_netif_lwip_ipc_call(esp_netif_napt_control_api, esp_netif, (void*)true /* Enable */); | 
					
						
							|  |  |  | #endif /* IP_NAPT */
 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | typedef struct { | 
					
						
							|  |  |  |     u8_t authtype; | 
					
						
							|  |  |  |     const char *user; | 
					
						
							|  |  |  |     const char *passwd; | 
					
						
							|  |  |  | } set_auth_msg_t; | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | static esp_err_t esp_netif_ppp_set_auth_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     set_auth_msg_t *params = msg->data; | 
					
						
							|  |  |  |     return esp_netif_ppp_set_auth_internal(msg->esp_netif, params->authtype, params->user, params->passwd); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_ppp_set_auth(esp_netif_t *esp_netif, esp_netif_auth_type_t authtype, const char *user, const char *passwd) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     set_auth_msg_t msg = { .authtype = authtype, .user = user, .passwd = passwd }; | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call(esp_netif_ppp_set_auth_api, esp_netif, &msg); | 
					
						
							|  |  |  | #if PPP_AUTH_SUPPORT
 | 
					
						
							|  |  |  |         lwip_peer2peer_ctx_t *ppp_ctx = (lwip_peer2peer_ctx_t *)netif->related_data; | 
					
						
							|  |  |  |     assert(ppp_ctx->base.netif_type == PPP_LWIP_NETIF); | 
					
						
							|  |  |  |     pppapi_set_auth(ppp_ctx->ppp, authtype, user, passwd); | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  |     return ESP_OK; | 
					
						
							| 
									
										
										
										
											2023-09-22 19:10:36 +02:00
										 |  |  | #else
 | 
					
						
							|  |  |  |     ESP_LOGE(TAG, "%s failed: No authorisation enabled in menuconfig", __func__); | 
					
						
							|  |  |  |     return ESP_ERR_ESP_NETIF_IF_NOT_READY; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_napt_disable(esp_netif_t *esp_netif) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if !IP_NAPT
 | 
					
						
							|  |  |  |     return ESP_ERR_NOT_SUPPORTED; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     return esp_netif_lwip_ipc_call(esp_netif_napt_control_api, esp_netif, (void*)false /* Disable */); | 
					
						
							| 
									
										
										
										
											2023-01-19 14:50:00 +05:30
										 |  |  | #endif /* IP_NAPT */
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-14 10:34:06 +02:00
										 |  |  | #if MIB2_STATS
 | 
					
						
							| 
									
										
										
										
											2022-05-11 16:01:48 +02:00
										 |  |  | static esp_err_t esp_netif_set_link_speed_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     uint32_t speed = *((uint32_t*)msg->data); | 
					
						
							|  |  |  |     esp_err_t error = ESP_OK; | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, msg->esp_netif); | 
					
						
							| 
									
										
										
										
											2022-07-14 10:34:06 +02:00
										 |  |  |     NETIF_INIT_SNMP(msg->esp_netif->lwip_netif, snmp_ifType_ethernet_csmacd, speed); | 
					
						
							| 
									
										
										
										
											2022-05-11 16:01:48 +02:00
										 |  |  |     LWIP_UNUSED_ARG(speed);     // Maybe unused if SNMP disabled
 | 
					
						
							|  |  |  |     return error; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_set_link_speed(esp_netif_t *esp_netif, uint32_t speed) | 
					
						
							|  |  |  | _RUN_IN_LWIP_TASK(esp_netif_set_link_speed_api, esp_netif, &speed) | 
					
						
							| 
									
										
										
										
											2022-07-14 10:34:06 +02:00
										 |  |  | #else
 | 
					
						
							|  |  |  | esp_err_t esp_netif_set_link_speed(esp_netif_t *esp_netif, uint32_t speed) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     // link speed is used only to collect interface related statistics (if MIB2_STATS enabled)
 | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif /* MIB2_STATS */
 | 
					
						
							| 
									
										
										
										
											2022-05-11 16:01:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-19 11:52:51 +08:00
										 |  |  | #if CONFIG_LWIP_IPV6
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_join_ip6_multicast_group_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_ip6_addr_t *addr = (esp_ip6_addr_t *)msg->data; | 
					
						
							|  |  |  |     esp_err_t error = ESP_OK; | 
					
						
							|  |  |  |     ip6_addr_t ip6addr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, msg->esp_netif); | 
					
						
							|  |  |  |     memcpy(ip6addr.addr, addr->addr, sizeof(ip6addr.addr)); | 
					
						
							|  |  |  | #if LWIP_IPV6_SCOPES
 | 
					
						
							|  |  |  |     ip6addr.zone = 0; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     if (mld6_joingroup_netif(msg->esp_netif->lwip_netif, &ip6addr) != ERR_OK) { | 
					
						
							|  |  |  |         error = ESP_ERR_ESP_NETIF_MLD6_FAILED; | 
					
						
							|  |  |  |         ESP_LOGE(TAG, "failed to join ip6 multicast group"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return error; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_join_ip6_multicast_group(esp_netif_t *esp_netif, const esp_ip6_addr_t *addr) | 
					
						
							|  |  |  |     _RUN_IN_LWIP_TASK(esp_netif_join_ip6_multicast_group_api, esp_netif, addr) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_leave_ip6_multicast_group_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_ip6_addr_t *addr = (esp_ip6_addr_t *)msg->data; | 
					
						
							|  |  |  |     ip6_addr_t ip6addr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, msg->esp_netif); | 
					
						
							|  |  |  |     memcpy(ip6addr.addr, addr->addr, sizeof(ip6addr.addr)); | 
					
						
							|  |  |  | #if LWIP_IPV6_SCOPES
 | 
					
						
							|  |  |  |     ip6addr.zone = 0; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-05-19 16:58:47 -04:00
										 |  |  |     ESP_RETURN_ON_FALSE(mld6_leavegroup_netif(msg->esp_netif->lwip_netif, &ip6addr) == ERR_OK, | 
					
						
							| 
									
										
										
										
											2021-05-19 11:52:51 +08:00
										 |  |  |                         ESP_ERR_ESP_NETIF_MLD6_FAILED, TAG, "Failed to leave ip6 multicast group"); | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_leave_ip6_multicast_group(esp_netif_t *esp_netif, const esp_ip6_addr_t *addr) | 
					
						
							|  |  |  |     _RUN_IN_LWIP_TASK(esp_netif_leave_ip6_multicast_group_api, esp_netif, addr) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static esp_err_t esp_netif_add_ip6_address_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ip_event_add_ip6_t *addr = (ip_event_add_ip6_t *)msg->data; | 
					
						
							|  |  |  |     ip6_addr_t ip6addr; | 
					
						
							|  |  |  |     esp_err_t error = ESP_OK; | 
					
						
							|  |  |  |     int8_t index = -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, msg->esp_netif); | 
					
						
							|  |  |  |     memcpy(ip6addr.addr, addr->addr.addr, sizeof(ip6addr.addr)); | 
					
						
							|  |  |  | #if LWIP_IPV6_SCOPES
 | 
					
						
							|  |  |  |     ip6addr.zone = 0; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     err_t err = netif_add_ip6_address(msg->esp_netif->lwip_netif, &ip6addr, &index); | 
					
						
							|  |  |  |     ESP_RETURN_ON_FALSE(err == ERR_OK && index >= 0, ESP_ERR_ESP_NETIF_IP6_ADDR_FAILED, TAG, | 
					
						
							|  |  |  |                         "Failed to add ip6 address"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     netif_ip6_addr_set_state(msg->esp_netif->lwip_netif, index, | 
					
						
							|  |  |  |                              addr->preferred ? IP6_ADDR_PREFERRED : IP6_ADDR_DEPRECATED); | 
					
						
							| 
									
										
										
										
											2022-07-15 17:32:52 +02:00
										 |  |  |     ip_event_got_ip6_t evt = {.esp_netif = msg->esp_netif, .ip_index = index}; | 
					
						
							| 
									
										
										
										
											2021-05-19 11:52:51 +08:00
										 |  |  |     evt.ip6_info.ip = addr->addr; | 
					
						
							| 
									
										
										
										
											2021-12-02 15:49:28 +05:30
										 |  |  |     ESP_RETURN_ON_ERROR(esp_event_post(IP_EVENT, IP_EVENT_GOT_IP6, &evt, sizeof(evt), 0), TAG, | 
					
						
							| 
									
										
										
										
											2021-05-19 11:52:51 +08:00
										 |  |  |                         "Failed to post IP_EVENT_GOT_IP6"); | 
					
						
							|  |  |  |     return error; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-09 18:00:47 +08:00
										 |  |  | static esp_err_t esp_netif_add_ip6_address_priv(esp_netif_t *esp_netif, const ip_event_add_ip6_t *addr) | 
					
						
							| 
									
										
										
										
											2021-05-19 11:52:51 +08:00
										 |  |  |     _RUN_IN_LWIP_TASK(esp_netif_add_ip6_address_api, esp_netif, addr) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-09 18:00:47 +08:00
										 |  |  | esp_err_t esp_netif_add_ip6_address(esp_netif_t *esp_netif, const esp_ip6_addr_t addr, bool preferred) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     const ip_event_add_ip6_t addr_evt = {.addr = addr, .preferred = preferred}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return esp_netif_add_ip6_address_priv(esp_netif, &addr_evt); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-19 11:52:51 +08:00
										 |  |  | static esp_err_t esp_netif_remove_ip6_address_api(esp_netif_api_msg_t *msg) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     esp_ip6_addr_t *addr = (esp_ip6_addr_t *)msg->data; | 
					
						
							|  |  |  |     ip6_addr_t ip6addr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ESP_LOGD(TAG, "%s esp_netif:%p", __func__, msg->esp_netif); | 
					
						
							|  |  |  |     memcpy(ip6addr.addr, addr->addr, sizeof(ip6addr.addr)); | 
					
						
							|  |  |  | #if LWIP_IPV6_SCOPES
 | 
					
						
							|  |  |  |     ip6addr.zone = 0; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     int8_t index = netif_get_ip6_addr_match(msg->esp_netif->lwip_netif, &ip6addr); | 
					
						
							|  |  |  |     if (index != -1) { | 
					
						
							|  |  |  |         netif_ip6_addr_set_state(msg->esp_netif->lwip_netif, index, IP6_ADDR_INVALID); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ESP_OK; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | esp_err_t esp_netif_remove_ip6_address(esp_netif_t *esp_netif, const esp_ip6_addr_t *addr) | 
					
						
							|  |  |  |     _RUN_IN_LWIP_TASK(esp_netif_remove_ip6_address_api, esp_netif, addr) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif // CONFIG_LWIP_IPV6
 |