2021-06-01 18:58:30 +02:00
|
|
|
/*
|
2023-10-03 16:28:30 +02:00
|
|
|
* SPDX-FileCopyrightText: 2015-2023 Espressif Systems (Shanghai) CO LTD
|
2021-06-01 18:58:30 +02:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
2019-06-28 16:47:34 +02:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "esp_netif.h"
|
2019-11-21 13:23:58 +01:00
|
|
|
#include "esp_netif_ppp.h"
|
2019-06-28 16:47:34 +02:00
|
|
|
#include "lwip/netif.h"
|
2022-01-19 19:50:49 +01:00
|
|
|
#include "dhcpserver/dhcpserver.h"
|
2019-06-28 16:47:34 +02:00
|
|
|
|
2022-06-02 16:25:20 +02:00
|
|
|
#if defined(CONFIG_ESP_NETIF_TCPIP_LWIP)
|
2020-09-11 15:37:28 -07:00
|
|
|
|
2019-06-28 16:47:34 +02:00
|
|
|
struct esp_netif_api_msg_s;
|
|
|
|
|
|
|
|
typedef int (*esp_netif_api_fn)(struct esp_netif_api_msg_s *msg);
|
|
|
|
|
|
|
|
typedef struct esp_netif_api_msg_s {
|
|
|
|
int type; /**< The first field MUST be int */
|
|
|
|
int ret;
|
|
|
|
esp_netif_api_fn api_fn;
|
2022-10-27 19:07:07 +02:00
|
|
|
union {
|
2023-10-03 16:28:30 +02:00
|
|
|
esp_netif_t *esp_netif; /* esp_netif as input param */
|
|
|
|
esp_netif_t **p_esp_netif; /* esp_netif as output */
|
|
|
|
esp_netif_callback_fn user_fn; /* user callback */
|
|
|
|
}; /* Commonly used parameters what calling api_fn */
|
2019-06-28 16:47:34 +02:00
|
|
|
void *data;
|
|
|
|
} esp_netif_api_msg_t;
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct esp_netif_dns_param_s {
|
|
|
|
esp_netif_dns_type_t dns_type;
|
|
|
|
esp_netif_dns_info_t *dns_info;
|
|
|
|
} esp_netif_dns_param_t;
|
|
|
|
|
|
|
|
typedef struct esp_netif_ip_lost_timer_s {
|
|
|
|
bool timer_running;
|
|
|
|
} esp_netif_ip_lost_timer_t;
|
|
|
|
|
2020-06-12 16:43:34 +02:00
|
|
|
/**
|
|
|
|
* @brief Check the netif if of a specific P2P type
|
|
|
|
*/
|
2022-07-22 17:37:47 +02:00
|
|
|
#if CONFIG_PPP_SUPPORT
|
|
|
|
#define ESP_NETIF_IS_POINT2POINT_TYPE(netif, type) (netif->related_data && netif->related_data->is_point2point && netif->related_data->netif_type == type)
|
2021-06-23 10:20:08 +08:00
|
|
|
#else
|
2022-07-22 17:37:47 +02:00
|
|
|
#define ESP_NETIF_IS_POINT2POINT_TYPE(netif, type) false
|
2021-06-23 10:20:08 +08:00
|
|
|
#endif
|
2020-06-12 16:43:34 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Additional netif types when related data are needed
|
|
|
|
*/
|
|
|
|
enum netif_types {
|
|
|
|
COMMON_LWIP_NETIF,
|
|
|
|
PPP_LWIP_NETIF,
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Related data to esp-netif (additional data for some special types of netif
|
2022-07-22 17:37:47 +02:00
|
|
|
* (typically for point-point network types, such as PPP)
|
2020-06-12 16:43:34 +02:00
|
|
|
*/
|
|
|
|
typedef struct netif_related_data {
|
|
|
|
bool is_point2point;
|
|
|
|
enum netif_types netif_type;
|
|
|
|
} netif_related_data_t;
|
2019-11-21 13:23:58 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Main esp-netif container with interface related information
|
|
|
|
*/
|
|
|
|
struct esp_netif_obj {
|
|
|
|
// default interface addresses
|
|
|
|
uint8_t mac[NETIF_MAX_HWADDR_LEN];
|
|
|
|
esp_netif_ip_info_t* ip_info;
|
|
|
|
esp_netif_ip_info_t* ip_info_old;
|
|
|
|
|
|
|
|
// lwip netif related
|
|
|
|
struct netif *lwip_netif;
|
|
|
|
err_t (*lwip_init_fn)(struct netif*);
|
2023-03-27 12:54:25 +02:00
|
|
|
esp_netif_recv_ret_t (*lwip_input_fn)(void *input_netif_handle, void *buffer, size_t len, void *eb);
|
2019-11-21 13:23:58 +01:00
|
|
|
void * netif_handle; // netif impl context (either vanilla lwip-netif or ppp_pcb)
|
2020-06-12 16:43:34 +02:00
|
|
|
netif_related_data_t *related_data; // holds additional data for specific netifs
|
2022-01-19 19:50:49 +01:00
|
|
|
#if ESP_DHCPS
|
|
|
|
dhcps_t *dhcps;
|
|
|
|
#endif
|
2019-11-21 13:23:58 +01:00
|
|
|
// io driver related
|
|
|
|
void* driver_handle;
|
|
|
|
esp_err_t (*driver_transmit)(void *h, void *buffer, size_t len);
|
2020-02-13 14:26:48 +08:00
|
|
|
esp_err_t (*driver_transmit_wrap)(void *h, void *buffer, size_t len, void *pbuf);
|
2019-11-21 13:23:58 +01:00
|
|
|
void (*driver_free_rx_buffer)(void *h, void* buffer);
|
|
|
|
|
|
|
|
// dhcp related
|
|
|
|
esp_netif_dhcp_status_t dhcpc_status;
|
|
|
|
esp_netif_dhcp_status_t dhcps_status;
|
|
|
|
bool timer_running;
|
|
|
|
|
|
|
|
// event translation
|
|
|
|
ip_event_t get_ip_event;
|
|
|
|
ip_event_t lost_ip_event;
|
|
|
|
|
|
|
|
// misc flags, types, keys, priority
|
|
|
|
esp_netif_flags_t flags;
|
|
|
|
char * hostname;
|
|
|
|
char * if_key;
|
|
|
|
char * if_desc;
|
|
|
|
int route_prio;
|
2022-05-06 16:09:24 +02:00
|
|
|
|
|
|
|
#if CONFIG_ESP_NETIF_BRIDGE_EN
|
|
|
|
// bridge configuration
|
|
|
|
uint16_t max_fdb_dyn_entries;
|
|
|
|
uint16_t max_fdb_sta_entries;
|
|
|
|
uint8_t max_ports;
|
|
|
|
#endif // CONFIG_ESP_NETIF_BRIDGE_EN
|
2019-11-21 13:23:58 +01:00
|
|
|
};
|
2020-09-11 15:37:28 -07:00
|
|
|
|
|
|
|
#endif /* CONFIG_ESP_NETIF_TCPIP_LWIP */
|