net: if: Separate IP address configuration from net_if
Move IP address settings from net_if to separate structs. This is needed for VLAN support. Signed-off-by: Jukka Rissanen <jukka.rissanen@linux.intel.com>
This commit is contained in:
parent
bdc5c72498
commit
47dafffb67
|
@ -676,7 +676,7 @@ static int eth_net_tx(struct net_if *iface, struct net_pkt *pkt)
|
|||
|
||||
SYS_LOG_DBG("pkt %p (len %u)", pkt, len);
|
||||
|
||||
ret = eth_enc28j60_tx(iface->dev, pkt, len);
|
||||
ret = eth_enc28j60_tx(net_if_get_device(iface), pkt, len);
|
||||
if (ret == 0) {
|
||||
net_pkt_unref(pkt);
|
||||
}
|
||||
|
|
|
@ -312,7 +312,7 @@ static void eth_mcux_delayed_phy_work(struct k_work *item)
|
|||
|
||||
static int eth_tx(struct net_if *iface, struct net_pkt *pkt)
|
||||
{
|
||||
struct eth_context *context = iface->dev->driver_data;
|
||||
struct eth_context *context = net_if_get_device(iface)->driver_data;
|
||||
const struct net_buf *frag;
|
||||
u8_t *dst;
|
||||
status_t status;
|
||||
|
|
|
@ -69,7 +69,8 @@ static bool received_dest_addr_matched(u8_t *rx_buffer)
|
|||
if (memcmp(&rx_buffer[DEST_ADDR_OFFSET],
|
||||
BROADCAST_ADDRESS,
|
||||
SHORT_ADDRESS_SIZE) != 0 &&
|
||||
(upipe->iface->link_addr.len != SHORT_ADDRESS_SIZE ||
|
||||
(net_if_get_link_addr(upipe->iface)->len !=
|
||||
SHORT_ADDRESS_SIZE ||
|
||||
memcmp(&rx_buffer[DEST_ADDR_OFFSET],
|
||||
dev_short_addr,
|
||||
SHORT_ADDRESS_SIZE) != 0)) {
|
||||
|
@ -79,7 +80,8 @@ static bool received_dest_addr_matched(u8_t *rx_buffer)
|
|||
|
||||
case DEST_ADDR_TYPE_EXTENDED:
|
||||
/* If not broadcast, check if lenght and address matches */
|
||||
if (upipe->iface->link_addr.len != EXTENDED_ADDRESS_SIZE ||
|
||||
if (net_if_get_link_addr(upipe->iface)->len !=
|
||||
EXTENDED_ADDRESS_SIZE ||
|
||||
memcmp(&rx_buffer[DEST_ADDR_OFFSET],
|
||||
dev_ext_addr, EXTENDED_ADDRESS_SIZE) != 0) {
|
||||
return false;
|
||||
|
|
|
@ -162,6 +162,14 @@
|
|||
__net_if_end = .;
|
||||
} GROUP_DATA_LINK_IN(RAMABLE_REGION, ROMABLE_REGION)
|
||||
|
||||
SECTION_DATA_PROLOGUE(net_if_dev, (OPTIONAL), SUBALIGN(4))
|
||||
{
|
||||
__net_if_dev_start = .;
|
||||
*(".net_if_dev.*")
|
||||
KEEP(*(SORT_BY_NAME(".net_if_dev.*")))
|
||||
__net_if_dev_end = .;
|
||||
} GROUP_DATA_LINK_IN(RAMABLE_REGION, ROMABLE_REGION)
|
||||
|
||||
SECTION_DATA_PROLOGUE(net_if_event, (OPTIONAL), SUBALIGN(4))
|
||||
{
|
||||
__net_if_event_start = .;
|
||||
|
|
|
@ -168,21 +168,153 @@ enum {
|
|||
struct net_offload;
|
||||
#endif /* CONFIG_NET_OFFLOAD */
|
||||
|
||||
#if defined(CONFIG_NET_IPV6)
|
||||
#define NET_IF_MAX_IPV6_ADDR CONFIG_NET_IF_UNICAST_IPV6_ADDR_COUNT
|
||||
#define NET_IF_MAX_IPV6_MADDR CONFIG_NET_IF_MCAST_IPV6_ADDR_COUNT
|
||||
#define NET_IF_MAX_IPV6_PREFIX CONFIG_NET_IF_IPV6_PREFIX_COUNT
|
||||
|
||||
struct net_if_ipv6 {
|
||||
/** Unicast IP addresses */
|
||||
struct net_if_addr unicast[NET_IF_MAX_IPV6_ADDR];
|
||||
|
||||
/** Multicast IP addresses */
|
||||
struct net_if_mcast_addr mcast[NET_IF_MAX_IPV6_MADDR];
|
||||
|
||||
/** Prefixes */
|
||||
struct net_if_ipv6_prefix prefix[NET_IF_MAX_IPV6_PREFIX];
|
||||
|
||||
/** Router solicitation timer */
|
||||
struct k_delayed_work rs_timer;
|
||||
|
||||
/** Default reachable time (RFC 4861, page 52) */
|
||||
u32_t base_reachable_time;
|
||||
|
||||
/** Reachable time (RFC 4861, page 20) */
|
||||
u32_t reachable_time;
|
||||
|
||||
/** Retransmit timer (RFC 4861, page 52) */
|
||||
u32_t retrans_timer;
|
||||
|
||||
/** IPv6 hop limit */
|
||||
u8_t hop_limit;
|
||||
|
||||
#if defined(CONFIG_NET_IPV6_DAD)
|
||||
/** IPv6 current duplicate address detection count */
|
||||
u8_t dad_count;
|
||||
#endif /* CONFIG_NET_IPV6_DAD */
|
||||
|
||||
/** RS count */
|
||||
u8_t rs_count;
|
||||
};
|
||||
#endif /* CONFIG_NET_IPV6 */
|
||||
|
||||
#if defined(CONFIG_NET_IPV4)
|
||||
#define NET_IF_MAX_IPV4_ADDR CONFIG_NET_IF_UNICAST_IPV4_ADDR_COUNT
|
||||
#define NET_IF_MAX_IPV4_MADDR CONFIG_NET_IF_MCAST_IPV4_ADDR_COUNT
|
||||
|
||||
struct net_if_ipv4 {
|
||||
/** Unicast IP addresses */
|
||||
struct net_if_addr unicast[NET_IF_MAX_IPV4_ADDR];
|
||||
|
||||
/** Multicast IP addresses */
|
||||
struct net_if_mcast_addr mcast[NET_IF_MAX_IPV4_MADDR];
|
||||
|
||||
/** Gateway */
|
||||
struct in_addr gw;
|
||||
|
||||
/** Netmask */
|
||||
struct in_addr netmask;
|
||||
|
||||
/** IPv4 time-to-live */
|
||||
u8_t ttl;
|
||||
};
|
||||
#endif /* CONFIG_NET_IPV4 */
|
||||
|
||||
#if defined(CONFIG_NET_DHCPV4)
|
||||
struct net_if_dhcpv4 {
|
||||
u32_t xid;
|
||||
|
||||
/** IP address Lease time */
|
||||
u32_t lease_time;
|
||||
|
||||
/** IP address Renewal time */
|
||||
u32_t renewal_time;
|
||||
|
||||
/** IP address Rebinding time */
|
||||
u32_t rebinding_time;
|
||||
|
||||
/** Server ID */
|
||||
struct in_addr server_id;
|
||||
|
||||
/** Requested IP addr */
|
||||
struct in_addr requested_ip;
|
||||
|
||||
/** Timer for DHCPv4 Client requests (DISCOVER, REQUEST or RENEWAL)
|
||||
*/
|
||||
struct k_delayed_work timer;
|
||||
|
||||
/** T1 (Renewal) timer */
|
||||
struct k_delayed_work t1_timer;
|
||||
|
||||
/** T2 (Rebinding) timer */
|
||||
struct k_delayed_work t2_timer;
|
||||
|
||||
/**
|
||||
* DHCPv4 client state in the process of network
|
||||
* address allocation.
|
||||
*/
|
||||
enum net_dhcpv4_state state;
|
||||
|
||||
/** Number of attempts made for REQUEST and RENEWAL messages */
|
||||
u8_t attempts;
|
||||
};
|
||||
#endif /* CONFIG_NET_DHCPV4 */
|
||||
|
||||
/* We always need to have at least one IP config */
|
||||
#define NET_IF_MAX_CONFIGS 1
|
||||
|
||||
/**
|
||||
* @brief Network Interface structure
|
||||
* @brief Network interface IP address configuration.
|
||||
*
|
||||
* TODO: Use pointers here so that we could have IPv6 only interface which
|
||||
* would save memory by not having IPv4 enabled.
|
||||
*/
|
||||
struct net_if_ip {
|
||||
#if defined(CONFIG_NET_IPV6)
|
||||
struct net_if_ipv6 ipv6;
|
||||
#endif /* CONFIG_NET_IPV6 */
|
||||
|
||||
#if defined(CONFIG_NET_IPV4)
|
||||
struct net_if_ipv4 ipv4;
|
||||
#endif /* CONFIG_NET_IPV4 */
|
||||
};
|
||||
|
||||
/**
|
||||
* @brief IP and other configuration related data for network interface.
|
||||
*/
|
||||
struct net_if_config {
|
||||
/** IP address configuration setting */
|
||||
struct net_if_ip ip;
|
||||
|
||||
#if defined(CONFIG_NET_DHCPV4)
|
||||
struct net_if_dhcpv4 dhcpv4;
|
||||
#endif /* CONFIG_NET_DHCPV4 */
|
||||
};
|
||||
|
||||
/**
|
||||
* @brief Network Interface Device structure
|
||||
*
|
||||
* Used to handle a network interface on top of a device driver instance.
|
||||
* There can be many net_if instance against the same device.
|
||||
* There can be many net_if_dev instance against the same device.
|
||||
*
|
||||
* Such interface is mainly to be used by the link layer, but is also tight
|
||||
* to a network context: it then makes the relation with a network context
|
||||
* and the network device.
|
||||
*
|
||||
* Because of the strong relationship between a device driver and such
|
||||
* network interface, each net_if should be instantiated by
|
||||
* network interface, each net_if_dev should be instantiated by
|
||||
*/
|
||||
struct net_if {
|
||||
struct net_if_dev {
|
||||
/** The actually device driver instance the net_if is related to */
|
||||
struct device *dev;
|
||||
|
||||
|
@ -213,107 +345,22 @@ struct net_if {
|
|||
struct net_offload *offload;
|
||||
#endif /* CONFIG_NET_OFFLOAD */
|
||||
|
||||
#if defined(CONFIG_NET_IPV6)
|
||||
#define NET_IF_MAX_IPV6_ADDR CONFIG_NET_IF_UNICAST_IPV6_ADDR_COUNT
|
||||
#define NET_IF_MAX_IPV6_MADDR CONFIG_NET_IF_MCAST_IPV6_ADDR_COUNT
|
||||
#define NET_IF_MAX_IPV6_PREFIX CONFIG_NET_IF_IPV6_PREFIX_COUNT
|
||||
struct {
|
||||
/** Unicast IP addresses */
|
||||
struct net_if_addr unicast[NET_IF_MAX_IPV6_ADDR];
|
||||
};
|
||||
|
||||
/** Multicast IP addresses */
|
||||
struct net_if_mcast_addr mcast[NET_IF_MAX_IPV6_MADDR];
|
||||
/**
|
||||
* @brief Network Interface structure
|
||||
*
|
||||
* Used to handle a network interface on top of a net_if_dev instance.
|
||||
* There can be many net_if instance against the same net_if_dev instance.
|
||||
*
|
||||
*/
|
||||
struct net_if {
|
||||
/** The net_if_dev instance the net_if is related to */
|
||||
struct net_if_dev *if_dev;
|
||||
|
||||
/** Prefixes */
|
||||
struct net_if_ipv6_prefix prefix[NET_IF_MAX_IPV6_PREFIX];
|
||||
|
||||
/** Router solicitation timer */
|
||||
struct k_delayed_work rs_timer;
|
||||
|
||||
/** Default reachable time (RFC 4861, page 52) */
|
||||
u32_t base_reachable_time;
|
||||
|
||||
/** Reachable time (RFC 4861, page 20) */
|
||||
u32_t reachable_time;
|
||||
|
||||
/** Retransmit timer (RFC 4861, page 52) */
|
||||
u32_t retrans_timer;
|
||||
|
||||
/** IPv6 hop limit */
|
||||
u8_t hop_limit;
|
||||
|
||||
#if defined(CONFIG_NET_IPV6_DAD)
|
||||
/** IPv6 current duplicate address detection count */
|
||||
u8_t dad_count;
|
||||
#endif /* CONFIG_NET_IPV6_DAD */
|
||||
|
||||
/** RS count */
|
||||
u8_t rs_count;
|
||||
} ipv6;
|
||||
#endif /* CONFIG_NET_IPV6 */
|
||||
|
||||
#if defined(CONFIG_NET_IPV4)
|
||||
#define NET_IF_MAX_IPV4_ADDR CONFIG_NET_IF_UNICAST_IPV4_ADDR_COUNT
|
||||
#define NET_IF_MAX_IPV4_MADDR CONFIG_NET_IF_MCAST_IPV4_ADDR_COUNT
|
||||
struct {
|
||||
/** Unicast IP addresses */
|
||||
struct net_if_addr unicast[NET_IF_MAX_IPV4_ADDR];
|
||||
|
||||
/** Multicast IP addresses */
|
||||
struct net_if_mcast_addr mcast[NET_IF_MAX_IPV4_MADDR];
|
||||
|
||||
/** Gateway */
|
||||
struct in_addr gw;
|
||||
|
||||
/** Netmask */
|
||||
struct in_addr netmask;
|
||||
|
||||
/** IPv4 time-to-live */
|
||||
u8_t ttl;
|
||||
} ipv4;
|
||||
#endif /* CONFIG_NET_IPV4 */
|
||||
|
||||
#if defined(CONFIG_NET_DHCPV4)
|
||||
struct {
|
||||
u32_t xid;
|
||||
|
||||
/** IP address Lease time */
|
||||
u32_t lease_time;
|
||||
|
||||
/** IP address Renewal time */
|
||||
u32_t renewal_time;
|
||||
|
||||
/** IP address Rebinding time */
|
||||
u32_t rebinding_time;
|
||||
|
||||
/** Server ID */
|
||||
struct in_addr server_id;
|
||||
|
||||
/** Requested IP addr */
|
||||
struct in_addr requested_ip;
|
||||
|
||||
/** Timer for DHCPv4 Client requests (DISCOVER,
|
||||
* REQUEST or RENEWAL)
|
||||
*/
|
||||
struct k_delayed_work timer;
|
||||
|
||||
/** T1 (Renewal) timer */
|
||||
struct k_delayed_work t1_timer;
|
||||
|
||||
/** T2 (Rebinding) timer */
|
||||
struct k_delayed_work t2_timer;
|
||||
|
||||
/**
|
||||
* DHCPv4 client state in the process of network
|
||||
* address allocation.
|
||||
*/
|
||||
enum net_dhcpv4_state state;
|
||||
|
||||
/** Number of attempts made for REQUEST and RENEWAL messages */
|
||||
u8_t attempts;
|
||||
} dhcpv4;
|
||||
#endif
|
||||
} __net_if_align;
|
||||
/** Network interface instance configuration */
|
||||
struct net_if_config config;
|
||||
};
|
||||
|
||||
/**
|
||||
* @brief Send a packet through a net iface
|
||||
|
@ -325,6 +372,18 @@ struct net_if {
|
|||
*/
|
||||
enum net_verdict net_if_send_data(struct net_if *iface, struct net_pkt *pkt);
|
||||
|
||||
/**
|
||||
* @brief Get a pointer to the interface L2
|
||||
*
|
||||
* @param iface a valid pointer to a network interface structure
|
||||
*
|
||||
* @return a pointer to the iface L2
|
||||
*/
|
||||
static inline const struct net_l2 * const net_if_l2(struct net_if *iface)
|
||||
{
|
||||
return iface->if_dev->l2;
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Input a packet through a net iface
|
||||
*
|
||||
|
@ -336,7 +395,7 @@ enum net_verdict net_if_send_data(struct net_if *iface, struct net_pkt *pkt);
|
|||
static inline enum net_verdict net_if_recv_data(struct net_if *iface,
|
||||
struct net_pkt *pkt)
|
||||
{
|
||||
return iface->l2->recv(iface, pkt);
|
||||
return net_if_l2(iface)->recv(iface, pkt);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -351,7 +410,7 @@ static inline enum net_verdict net_if_recv_data(struct net_if *iface,
|
|||
static inline u16_t net_if_get_ll_reserve(struct net_if *iface,
|
||||
const struct in6_addr *dst_ip6)
|
||||
{
|
||||
return iface->l2->reserve(iface, (void *)dst_ip6);
|
||||
return net_if_l2(iface)->reserve(iface, (void *)dst_ip6);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -363,7 +422,7 @@ static inline u16_t net_if_get_ll_reserve(struct net_if *iface,
|
|||
*/
|
||||
static inline void *net_if_l2_data(struct net_if *iface)
|
||||
{
|
||||
return iface->l2_data;
|
||||
return iface->if_dev->l2_data;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -375,7 +434,7 @@ static inline void *net_if_l2_data(struct net_if *iface)
|
|||
*/
|
||||
static inline struct device *net_if_get_device(struct net_if *iface)
|
||||
{
|
||||
return iface->dev;
|
||||
return iface->if_dev->dev;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -386,7 +445,17 @@ static inline struct device *net_if_get_device(struct net_if *iface)
|
|||
*/
|
||||
static inline void net_if_queue_tx(struct net_if *iface, struct net_pkt *pkt)
|
||||
{
|
||||
k_fifo_put(&iface->tx_queue, pkt);
|
||||
k_fifo_put(&iface->if_dev->tx_queue, pkt);
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Get TX queue of an network interface
|
||||
*
|
||||
* @param iface Pointer to a network interface structure
|
||||
*/
|
||||
static inline struct k_fifo *net_if_get_queue_tx(struct net_if *iface)
|
||||
{
|
||||
return &iface->if_dev->tx_queue;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_NET_OFFLOAD)
|
||||
|
@ -399,7 +468,19 @@ static inline void net_if_queue_tx(struct net_if *iface, struct net_pkt *pkt)
|
|||
*/
|
||||
static inline bool net_if_is_ip_offloaded(struct net_if *iface)
|
||||
{
|
||||
return (iface->offload != NULL);
|
||||
return (iface->if_dev->offload != NULL);
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Return the IP offload plugin
|
||||
*
|
||||
* @param iface Network interface
|
||||
*
|
||||
* @return NULL if there is no offload plugin defined, valid pointer otherwise
|
||||
*/
|
||||
static inline struct net_offload *net_if_offload(struct net_if *iface)
|
||||
{
|
||||
return iface->if_dev->offload;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@ -412,7 +493,19 @@ static inline bool net_if_is_ip_offloaded(struct net_if *iface)
|
|||
*/
|
||||
static inline struct net_linkaddr *net_if_get_link_addr(struct net_if *iface)
|
||||
{
|
||||
return &iface->link_addr;
|
||||
return &iface->if_dev->link_addr;
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Return network configuration for this network interface
|
||||
*
|
||||
* @param iface Pointer to a network interface structure
|
||||
*
|
||||
* @return Pointer to configuration
|
||||
*/
|
||||
static inline struct net_if_config *net_if_get_config(struct net_if *iface)
|
||||
{
|
||||
return &iface->config;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -447,13 +540,13 @@ static inline int net_if_set_link_addr(struct net_if *iface,
|
|||
u8_t *addr, u8_t len,
|
||||
enum net_link_type type)
|
||||
{
|
||||
if (atomic_test_bit(iface->flags, NET_IF_UP)) {
|
||||
if (atomic_test_bit(iface->if_dev->flags, NET_IF_UP)) {
|
||||
return -EPERM;
|
||||
}
|
||||
|
||||
iface->link_addr.addr = addr;
|
||||
iface->link_addr.len = len;
|
||||
iface->link_addr.type = type;
|
||||
net_if_get_link_addr(iface)->addr = addr;
|
||||
net_if_get_link_addr(iface)->len = len;
|
||||
net_if_get_link_addr(iface)->type = type;
|
||||
|
||||
net_hostname_set_postfix(addr, len);
|
||||
|
||||
|
@ -469,7 +562,7 @@ static inline int net_if_set_link_addr(struct net_if *iface,
|
|||
*/
|
||||
static inline u16_t net_if_get_mtu(struct net_if *iface)
|
||||
{
|
||||
return iface->mtu;
|
||||
return iface->if_dev->mtu;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -481,7 +574,7 @@ static inline u16_t net_if_get_mtu(struct net_if *iface)
|
|||
static inline void net_if_set_mtu(struct net_if *iface,
|
||||
u16_t mtu)
|
||||
{
|
||||
iface->mtu = mtu;
|
||||
iface->if_dev->mtu = mtu;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -514,6 +607,18 @@ struct net_if *net_if_get_by_link_addr(struct net_linkaddr *ll_addr);
|
|||
*/
|
||||
struct net_if *net_if_lookup_by_dev(struct device *dev);
|
||||
|
||||
/**
|
||||
* @brief Get network interface IP config
|
||||
*
|
||||
* @param iface Interface to use.
|
||||
*
|
||||
* @return NULL if not found or pointer to correct config settings.
|
||||
*/
|
||||
static inline struct net_if_config *net_if_config_get(struct net_if *iface)
|
||||
{
|
||||
return &iface->config;
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Remove a router from the system
|
||||
*
|
||||
|
@ -583,15 +688,16 @@ struct net_if_addr *net_if_ipv6_addr_lookup_by_iface(struct net_if *iface,
|
|||
int i;
|
||||
|
||||
for (i = 0; i < NET_IF_MAX_IPV6_ADDR; i++) {
|
||||
if (!iface->ipv6.unicast[i].is_used ||
|
||||
iface->ipv6.unicast[i].address.family != AF_INET6) {
|
||||
if (!iface->config.ip.ipv6.unicast[i].is_used ||
|
||||
iface->config.ip.ipv6.unicast[i].address.family
|
||||
!= AF_INET6) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if (net_is_ipv6_prefix(addr->s6_addr,
|
||||
iface->ipv6.unicast[i].address.in6_addr.s6_addr,
|
||||
iface->config.ip.ipv6.unicast[i].address.in6_addr.s6_addr,
|
||||
128)) {
|
||||
return &iface->ipv6.unicast[i];
|
||||
return &iface->config.ip.ipv6.unicast[i];
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -913,7 +1019,11 @@ bool net_if_ipv6_router_rm(struct net_if_router *router);
|
|||
*/
|
||||
static inline u8_t net_if_ipv6_get_hop_limit(struct net_if *iface)
|
||||
{
|
||||
return iface->ipv6.hop_limit;
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
return config->ip.ipv6.hop_limit;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -925,7 +1035,11 @@ static inline u8_t net_if_ipv6_get_hop_limit(struct net_if *iface)
|
|||
static inline void net_ipv6_set_hop_limit(struct net_if *iface,
|
||||
u8_t hop_limit)
|
||||
{
|
||||
iface->ipv6.hop_limit = hop_limit;
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
config->ip.ipv6.hop_limit = hop_limit;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -935,9 +1049,13 @@ static inline void net_ipv6_set_hop_limit(struct net_if *iface,
|
|||
* @param reachable_time New reachable time
|
||||
*/
|
||||
static inline void net_if_ipv6_set_base_reachable_time(struct net_if *iface,
|
||||
u32_t reachable_time)
|
||||
u32_t reachable_time)
|
||||
{
|
||||
iface->ipv6.base_reachable_time = reachable_time;
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
config->ip.ipv6.base_reachable_time = reachable_time;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -949,7 +1067,11 @@ static inline void net_if_ipv6_set_base_reachable_time(struct net_if *iface,
|
|||
*/
|
||||
static inline u32_t net_if_ipv6_get_reachable_time(struct net_if *iface)
|
||||
{
|
||||
return iface->ipv6.reachable_time;
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
return config->ip.ipv6.reachable_time;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -969,7 +1091,12 @@ u32_t net_if_ipv6_calc_reachable_time(struct net_if *iface);
|
|||
*/
|
||||
static inline void net_if_ipv6_set_reachable_time(struct net_if *iface)
|
||||
{
|
||||
iface->ipv6.reachable_time = net_if_ipv6_calc_reachable_time(iface);
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
config->ip.ipv6.reachable_time =
|
||||
net_if_ipv6_calc_reachable_time(iface);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -981,7 +1108,11 @@ static inline void net_if_ipv6_set_reachable_time(struct net_if *iface)
|
|||
static inline void net_if_ipv6_set_retrans_timer(struct net_if *iface,
|
||||
u32_t retrans_timer)
|
||||
{
|
||||
iface->ipv6.retrans_timer = retrans_timer;
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
config->ip.ipv6.retrans_timer = retrans_timer;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -993,7 +1124,11 @@ static inline void net_if_ipv6_set_retrans_timer(struct net_if *iface,
|
|||
*/
|
||||
static inline u32_t net_if_ipv6_get_retrans_timer(struct net_if *iface)
|
||||
{
|
||||
return iface->ipv6.retrans_timer;
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
return config->ip.ipv6.retrans_timer;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1068,7 +1203,11 @@ struct in6_addr *net_if_ipv6_get_global_addr(struct net_if **iface);
|
|||
*/
|
||||
static inline u8_t net_if_ipv4_get_ttl(struct net_if *iface)
|
||||
{
|
||||
return iface->ipv4.ttl;
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
return config->ip.ipv4.ttl;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1188,7 +1327,11 @@ bool net_if_ipv4_addr_mask_cmp(struct net_if *iface,
|
|||
static inline void net_if_ipv4_set_netmask(struct net_if *iface,
|
||||
struct in_addr *netmask)
|
||||
{
|
||||
net_ipaddr_copy(&iface->ipv4.netmask, netmask);
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
net_ipaddr_copy(&config->ip.ipv4.netmask, netmask);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1200,7 +1343,11 @@ static inline void net_if_ipv4_set_netmask(struct net_if *iface,
|
|||
static inline void net_if_ipv4_set_gw(struct net_if *iface,
|
||||
struct in_addr *gw)
|
||||
{
|
||||
net_ipaddr_copy(&iface->ipv4.gw, gw);
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
net_ipaddr_copy(&config->ip.ipv4.gw, gw);
|
||||
}
|
||||
|
||||
#endif /* CONFIG_NET_IPV4 */
|
||||
|
@ -1340,7 +1487,7 @@ static inline bool net_if_is_up(struct net_if *iface)
|
|||
{
|
||||
NET_ASSERT(iface);
|
||||
|
||||
return atomic_test_bit(iface->flags, NET_IF_UP);
|
||||
return atomic_test_bit(iface->if_dev->flags, NET_IF_UP);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1363,7 +1510,15 @@ struct net_if_api {
|
|||
#define NET_IF_DHCPV4_INIT
|
||||
#endif
|
||||
|
||||
#define NET_IF_CONFIG_INIT \
|
||||
.config = { \
|
||||
.ip = { \
|
||||
}, \
|
||||
NET_IF_DHCPV4_INIT \
|
||||
}
|
||||
|
||||
#define NET_IF_GET_NAME(dev_name, sfx) (__net_if_##dev_name##_##sfx)
|
||||
#define NET_IF_DEV_GET_NAME(dev_name, sfx) (__net_if_dev_##dev_name##_##sfx)
|
||||
#define NET_IF_EVENT_GET_NAME(dev_name, sfx) \
|
||||
(__net_if_event_##dev_name##_##sfx)
|
||||
|
||||
|
@ -1371,13 +1526,20 @@ struct net_if_api {
|
|||
((struct net_if *)&NET_IF_GET_NAME(dev_name, sfx))
|
||||
|
||||
#define NET_IF_INIT(dev_name, sfx, _l2, _mtu) \
|
||||
static struct net_if (NET_IF_GET_NAME(dev_name, sfx)) __used \
|
||||
__attribute__((__section__(".net_if.data"))) = { \
|
||||
static struct net_if_dev (NET_IF_DEV_GET_NAME(dev_name, sfx)) __used \
|
||||
__attribute__((__section__(".net_if_dev.data"))) = { \
|
||||
.dev = &(__device_##dev_name), \
|
||||
.l2 = &(NET_L2_GET_NAME(_l2)), \
|
||||
.l2_data = &(NET_L2_GET_DATA(dev_name, sfx)), \
|
||||
.mtu = _mtu, \
|
||||
NET_IF_DHCPV4_INIT \
|
||||
}; \
|
||||
static struct net_if \
|
||||
(NET_IF_GET_NAME(dev_name, sfx))[NET_IF_MAX_CONFIGS] __used \
|
||||
__attribute__((__section__(".net_if.data"))) = { \
|
||||
[0 ... (NET_IF_MAX_CONFIGS - 1)] = { \
|
||||
.if_dev = &(NET_IF_DEV_GET_NAME(dev_name, sfx)), \
|
||||
NET_IF_CONFIG_INIT \
|
||||
} \
|
||||
}; \
|
||||
static struct k_poll_event \
|
||||
(NET_IF_EVENT_GET_NAME(dev_name, sfx)) __used \
|
||||
|
|
|
@ -349,6 +349,7 @@ static inline bool net_is_ipv6_addr_mcast(const struct in6_addr *addr)
|
|||
}
|
||||
|
||||
struct net_if;
|
||||
struct net_if_config;
|
||||
|
||||
extern struct net_if_addr *net_if_ipv6_addr_lookup(const struct in6_addr *addr,
|
||||
struct net_if **iface);
|
||||
|
|
|
@ -133,10 +133,10 @@ static inline int net_offload_get(struct net_if *iface,
|
|||
struct net_context **context)
|
||||
{
|
||||
NET_ASSERT(iface);
|
||||
NET_ASSERT(iface->offload);
|
||||
NET_ASSERT(iface->offload->get);
|
||||
NET_ASSERT(net_if_offload(iface));
|
||||
NET_ASSERT(net_if_offload(iface)->get);
|
||||
|
||||
return iface->offload->get(family, type, ip_proto, context);
|
||||
return net_if_offload(iface)->get(family, type, ip_proto, context);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -158,10 +158,10 @@ static inline int net_offload_bind(struct net_if *iface,
|
|||
socklen_t addrlen)
|
||||
{
|
||||
NET_ASSERT(iface);
|
||||
NET_ASSERT(iface->offload);
|
||||
NET_ASSERT(iface->offload->bind);
|
||||
NET_ASSERT(net_if_offload(iface));
|
||||
NET_ASSERT(net_if_offload(iface)->bind);
|
||||
|
||||
return iface->offload->bind(context, addr, addrlen);
|
||||
return net_if_offload(iface)->bind(context, addr, addrlen);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -181,10 +181,10 @@ static inline int net_offload_listen(struct net_if *iface,
|
|||
int backlog)
|
||||
{
|
||||
NET_ASSERT(iface);
|
||||
NET_ASSERT(iface->offload);
|
||||
NET_ASSERT(iface->offload->listen);
|
||||
NET_ASSERT(net_if_offload(iface));
|
||||
NET_ASSERT(net_if_offload(iface)->listen);
|
||||
|
||||
return iface->offload->listen(context, backlog);
|
||||
return net_if_offload(iface)->listen(context, backlog);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -225,10 +225,10 @@ static inline int net_offload_connect(struct net_if *iface,
|
|||
void *user_data)
|
||||
{
|
||||
NET_ASSERT(iface);
|
||||
NET_ASSERT(iface->offload);
|
||||
NET_ASSERT(iface->offload->connect);
|
||||
NET_ASSERT(net_if_offload(iface));
|
||||
NET_ASSERT(net_if_offload(iface)->connect);
|
||||
|
||||
return iface->offload->connect(context, addr, addrlen, cb,
|
||||
return net_if_offload(iface)->connect(context, addr, addrlen, cb,
|
||||
timeout, user_data);
|
||||
}
|
||||
|
||||
|
@ -266,10 +266,10 @@ static inline int net_offload_accept(struct net_if *iface,
|
|||
void *user_data)
|
||||
{
|
||||
NET_ASSERT(iface);
|
||||
NET_ASSERT(iface->offload);
|
||||
NET_ASSERT(iface->offload->accept);
|
||||
NET_ASSERT(net_if_offload(iface));
|
||||
NET_ASSERT(net_if_offload(iface)->accept);
|
||||
|
||||
return iface->offload->accept(context, cb, timeout, user_data);
|
||||
return net_if_offload(iface)->accept(context, cb, timeout, user_data);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -307,10 +307,10 @@ static inline int net_offload_send(struct net_if *iface,
|
|||
void *user_data)
|
||||
{
|
||||
NET_ASSERT(iface);
|
||||
NET_ASSERT(iface->offload);
|
||||
NET_ASSERT(iface->offload->send);
|
||||
NET_ASSERT(net_if_offload(iface));
|
||||
NET_ASSERT(net_if_offload(iface)->send);
|
||||
|
||||
return iface->offload->send(pkt, cb, timeout, token, user_data);
|
||||
return net_if_offload(iface)->send(pkt, cb, timeout, token, user_data);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -352,10 +352,10 @@ static inline int net_offload_sendto(struct net_if *iface,
|
|||
void *user_data)
|
||||
{
|
||||
NET_ASSERT(iface);
|
||||
NET_ASSERT(iface->offload);
|
||||
NET_ASSERT(iface->offload->sendto);
|
||||
NET_ASSERT(net_if_offload(iface));
|
||||
NET_ASSERT(net_if_offload(iface)->sendto);
|
||||
|
||||
return iface->offload->sendto(pkt, dst_addr, addrlen, cb,
|
||||
return net_if_offload(iface)->sendto(pkt, dst_addr, addrlen, cb,
|
||||
timeout, token, user_data);
|
||||
}
|
||||
|
||||
|
@ -399,10 +399,10 @@ static inline int net_offload_recv(struct net_if *iface,
|
|||
void *user_data)
|
||||
{
|
||||
NET_ASSERT(iface);
|
||||
NET_ASSERT(iface->offload);
|
||||
NET_ASSERT(iface->offload->recv);
|
||||
NET_ASSERT(net_if_offload(iface));
|
||||
NET_ASSERT(net_if_offload(iface)->recv);
|
||||
|
||||
return iface->offload->recv(context, cb, timeout, user_data);
|
||||
return net_if_offload(iface)->recv(context, cb, timeout, user_data);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -422,10 +422,10 @@ static inline int net_offload_put(struct net_if *iface,
|
|||
struct net_context *context)
|
||||
{
|
||||
NET_ASSERT(iface);
|
||||
NET_ASSERT(iface->offload);
|
||||
NET_ASSERT(iface->offload->put);
|
||||
NET_ASSERT(net_if_offload(iface));
|
||||
NET_ASSERT(net_if_offload(iface)->put);
|
||||
|
||||
return iface->offload->put(context);
|
||||
return net_if_offload(iface)->put(context);
|
||||
}
|
||||
|
||||
#ifdef __cplusplus
|
||||
|
|
|
@ -181,8 +181,8 @@ static inline void net_pkt_set_iface(struct net_pkt *pkt, struct net_if *iface)
|
|||
* the network address that is stored in pkt. This is done here so
|
||||
* that the address type is properly set and is not forgotten.
|
||||
*/
|
||||
pkt->lladdr_src.type = iface->link_addr.type;
|
||||
pkt->lladdr_dst.type = iface->link_addr.type;
|
||||
pkt->lladdr_src.type = net_if_get_link_addr(iface)->type;
|
||||
pkt->lladdr_dst.type = net_if_get_link_addr(iface)->type;
|
||||
}
|
||||
|
||||
static inline struct net_if *net_pkt_orig_iface(struct net_pkt *pkt)
|
||||
|
|
|
@ -283,7 +283,7 @@ void main(void)
|
|||
|
||||
#if defined(CONFIG_NET_MGMT_EVENT)
|
||||
/* Subscribe to NET_IF_UP if interface is not ready */
|
||||
if (!atomic_test_bit(iface->flags, NET_IF_UP)) {
|
||||
if (!atomic_test_bit(iface->if_dev->flags, NET_IF_UP)) {
|
||||
net_mgmt_init_event_callback(&cb, event_iface_up,
|
||||
NET_EVENT_IF_UP);
|
||||
net_mgmt_add_event_callback(&cb);
|
||||
|
|
|
@ -38,20 +38,22 @@ static void handler(struct net_mgmt_event_callback *cb,
|
|||
for (i = 0; i < NET_IF_MAX_IPV4_ADDR; i++) {
|
||||
char buf[NET_IPV4_ADDR_LEN];
|
||||
|
||||
if (iface->ipv4.unicast[i].addr_type != NET_ADDR_DHCP) {
|
||||
if (iface->config.ip.ipv4.unicast[i].addr_type !=
|
||||
NET_ADDR_DHCP) {
|
||||
continue;
|
||||
}
|
||||
|
||||
NET_INFO("Your address: %s",
|
||||
net_addr_ntop(AF_INET,
|
||||
&iface->ipv4.unicast[i].address.in_addr,
|
||||
buf, sizeof(buf)));
|
||||
NET_INFO("Lease time: %u seconds", iface->dhcpv4.lease_time);
|
||||
&iface->config.ip.ipv4.unicast[i].address.in_addr,
|
||||
buf, sizeof(buf)));
|
||||
NET_INFO("Lease time: %u seconds",
|
||||
iface->config.dhcpv4.lease_time);
|
||||
NET_INFO("Subnet: %s",
|
||||
net_addr_ntop(AF_INET, &iface->ipv4.netmask,
|
||||
net_addr_ntop(AF_INET, &iface->config.ip.ipv4.netmask,
|
||||
buf, sizeof(buf)));
|
||||
NET_INFO("Router: %s",
|
||||
net_addr_ntop(AF_INET, &iface->ipv4.gw,
|
||||
net_addr_ntop(AF_INET, &iface->config.ip.ipv4.gw,
|
||||
buf, sizeof(buf)));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -580,7 +580,8 @@ class SizeCalculator:
|
|||
"_k_sem_area", "_k_mutex_area", "_k_alert_area",
|
||||
"_k_fifo_area", "_k_lifo_area", "_k_stack_area",
|
||||
"_k_msgq_area", "_k_mbox_area", "_k_pipe_area",
|
||||
"net_if", "net_if_event", "net_stack", "net_l2_data",
|
||||
"net_if", "net_if_dev", "net_if_event", "net_stack",
|
||||
"net_l2_data",
|
||||
"_k_queue_area", "_net_buf_pool_area", "app_datas",
|
||||
"kobject_data", "mmu_tables", "app_pad", "priv_stacks",
|
||||
"ccm_data"]
|
||||
|
|
|
@ -324,7 +324,7 @@ static struct net_pkt *prepare_message(struct net_if *iface, u8_t type,
|
|||
msg->htype = HARDWARE_ETHERNET_TYPE;
|
||||
msg->hlen = HARDWARE_ETHERNET_LEN;
|
||||
|
||||
msg->xid = htonl(iface->dhcpv4.xid);
|
||||
msg->xid = htonl(iface->config.dhcpv4.xid);
|
||||
msg->flags = htons(DHCPV4_MSG_BROADCAST);
|
||||
|
||||
if (ciaddr) {
|
||||
|
@ -335,7 +335,8 @@ static struct net_pkt *prepare_message(struct net_if *iface, u8_t type,
|
|||
memcpy(msg->ciaddr, ciaddr, 4);
|
||||
}
|
||||
|
||||
memcpy(msg->chaddr, iface->link_addr.addr, iface->link_addr.len);
|
||||
memcpy(msg->chaddr, net_if_get_link_addr(iface)->addr,
|
||||
net_if_get_link_addr(iface)->len);
|
||||
|
||||
net_buf_add(frag, sizeof(struct dhcp_msg));
|
||||
|
||||
|
@ -363,16 +364,16 @@ static void send_request(struct net_if *iface)
|
|||
bool with_server_id = false;
|
||||
bool with_requested_ip = false;
|
||||
|
||||
iface->dhcpv4.xid++;
|
||||
iface->config.dhcpv4.xid++;
|
||||
|
||||
switch (iface->dhcpv4.state) {
|
||||
switch (iface->config.dhcpv4.state) {
|
||||
case NET_DHCPV4_DISABLED:
|
||||
case NET_DHCPV4_INIT:
|
||||
case NET_DHCPV4_SELECTING:
|
||||
case NET_DHCPV4_BOUND:
|
||||
/* Not possible */
|
||||
NET_ASSERT_INFO(0, "Invalid state %s",
|
||||
net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state));
|
||||
break;
|
||||
case NET_DHCPV4_REQUESTING:
|
||||
with_server_id = true;
|
||||
|
@ -381,10 +382,10 @@ static void send_request(struct net_if *iface)
|
|||
case NET_DHCPV4_RENEWING:
|
||||
/* Since we have an address populate the ciaddr field.
|
||||
*/
|
||||
ciaddr = &iface->dhcpv4.requested_ip;
|
||||
ciaddr = &iface->config.dhcpv4.requested_ip;
|
||||
|
||||
/* UNICAST the DHCPREQUEST */
|
||||
server_addr = &iface->dhcpv4.server_id;
|
||||
server_addr = &iface->config.dhcpv4.server_id;
|
||||
|
||||
/* RFC2131 4.4.5 Client MUST NOT include server
|
||||
* identifier in the DHCPREQUEST.
|
||||
|
@ -393,7 +394,7 @@ static void send_request(struct net_if *iface)
|
|||
case NET_DHCPV4_REBINDING:
|
||||
/* Since we have an address populate the ciaddr field.
|
||||
*/
|
||||
ciaddr = &iface->dhcpv4.requested_ip;
|
||||
ciaddr = &iface->config.dhcpv4.requested_ip;
|
||||
|
||||
server_addr = net_ipv4_broadcast_address();
|
||||
break;
|
||||
|
@ -404,12 +405,13 @@ static void send_request(struct net_if *iface)
|
|||
goto fail;
|
||||
}
|
||||
|
||||
if (with_server_id && !add_server_id(pkt, &iface->dhcpv4.server_id)) {
|
||||
if (with_server_id &&
|
||||
!add_server_id(pkt, &iface->config.dhcpv4.server_id)) {
|
||||
goto fail;
|
||||
}
|
||||
|
||||
if (with_requested_ip
|
||||
&& !add_req_ipaddr(pkt, &iface->dhcpv4.requested_ip)) {
|
||||
&& !add_req_ipaddr(pkt, &iface->config.dhcpv4.requested_ip)) {
|
||||
goto fail;
|
||||
}
|
||||
|
||||
|
@ -425,11 +427,13 @@ static void send_request(struct net_if *iface)
|
|||
goto fail;
|
||||
}
|
||||
|
||||
timeout = DHCPV4_INITIAL_RETRY_TIMEOUT << iface->dhcpv4.attempts;
|
||||
timeout = DHCPV4_INITIAL_RETRY_TIMEOUT <<
|
||||
iface->config.dhcpv4.attempts;
|
||||
|
||||
k_delayed_work_submit(&iface->dhcpv4.timer, timeout * MSEC_PER_SEC);
|
||||
k_delayed_work_submit(&iface->config.dhcpv4.timer,
|
||||
timeout * MSEC_PER_SEC);
|
||||
|
||||
iface->dhcpv4.attempts++;
|
||||
iface->config.dhcpv4.attempts++;
|
||||
|
||||
const char *ciaddr_buf = 0;
|
||||
static char pbuf[NET_IPV4_ADDR_LEN];
|
||||
|
@ -443,7 +447,7 @@ static void send_request(struct net_if *iface)
|
|||
NET_DBG("send request dst=%s xid=0x%"PRIx32" ciaddr=%s"
|
||||
"%s%s timeout=%"PRIu32"s",
|
||||
net_sprint_ipv4_addr(server_addr),
|
||||
iface->dhcpv4.xid,
|
||||
iface->config.dhcpv4.xid,
|
||||
ciaddr_buf,
|
||||
with_server_id ? " +server-id" : "",
|
||||
with_requested_ip ? " +requested-ip" : "",
|
||||
|
@ -465,7 +469,7 @@ static void send_discover(struct net_if *iface)
|
|||
struct net_pkt *pkt;
|
||||
u32_t timeout;
|
||||
|
||||
iface->dhcpv4.xid++;
|
||||
iface->config.dhcpv4.xid++;
|
||||
|
||||
pkt = prepare_message(iface, DHCPV4_MSG_TYPE_DISCOVER, NULL);
|
||||
if (!pkt) {
|
||||
|
@ -485,14 +489,15 @@ static void send_discover(struct net_if *iface)
|
|||
goto fail;
|
||||
}
|
||||
|
||||
timeout = DHCPV4_INITIAL_RETRY_TIMEOUT << iface->dhcpv4.attempts;
|
||||
timeout = DHCPV4_INITIAL_RETRY_TIMEOUT << iface->config.dhcpv4.attempts;
|
||||
|
||||
k_delayed_work_submit(&iface->dhcpv4.timer, timeout * MSEC_PER_SEC);
|
||||
k_delayed_work_submit(&iface->config.dhcpv4.timer,
|
||||
timeout * MSEC_PER_SEC);
|
||||
|
||||
iface->dhcpv4.attempts++;
|
||||
iface->config.dhcpv4.attempts++;
|
||||
|
||||
NET_DBG("send discover xid=0x%"PRIx32" timeout=%"PRIu32"s",
|
||||
iface->dhcpv4.xid, timeout);
|
||||
iface->config.dhcpv4.xid, timeout);
|
||||
|
||||
return;
|
||||
|
||||
|
@ -506,25 +511,25 @@ fail:
|
|||
|
||||
static void enter_selecting(struct net_if *iface)
|
||||
{
|
||||
iface->dhcpv4.attempts = 0;
|
||||
iface->config.dhcpv4.attempts = 0;
|
||||
|
||||
iface->dhcpv4.lease_time = 0;
|
||||
iface->dhcpv4.renewal_time = 0;
|
||||
iface->dhcpv4.rebinding_time = 0;
|
||||
iface->config.dhcpv4.lease_time = 0;
|
||||
iface->config.dhcpv4.renewal_time = 0;
|
||||
iface->config.dhcpv4.rebinding_time = 0;
|
||||
|
||||
iface->dhcpv4.state = NET_DHCPV4_SELECTING;
|
||||
iface->config.dhcpv4.state = NET_DHCPV4_SELECTING;
|
||||
NET_DBG("enter state=%s",
|
||||
net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state));
|
||||
|
||||
send_discover(iface);
|
||||
}
|
||||
|
||||
static void enter_requesting(struct net_if *iface)
|
||||
{
|
||||
iface->dhcpv4.attempts = 0;
|
||||
iface->dhcpv4.state = NET_DHCPV4_REQUESTING;
|
||||
iface->config.dhcpv4.attempts = 0;
|
||||
iface->config.dhcpv4.state = NET_DHCPV4_REQUESTING;
|
||||
NET_DBG("enter state=%s",
|
||||
net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state));
|
||||
|
||||
send_request(iface);
|
||||
}
|
||||
|
@ -532,11 +537,11 @@ static void enter_requesting(struct net_if *iface)
|
|||
static void dhcpv4_t1_timeout(struct k_work *work)
|
||||
{
|
||||
struct net_if *iface = CONTAINER_OF(work, struct net_if,
|
||||
dhcpv4.t1_timer);
|
||||
config.dhcpv4.t1_timer);
|
||||
|
||||
NET_DBG("");
|
||||
|
||||
switch (iface->dhcpv4.state) {
|
||||
switch (iface->config.dhcpv4.state) {
|
||||
case NET_DHCPV4_DISABLED:
|
||||
case NET_DHCPV4_INIT:
|
||||
case NET_DHCPV4_SELECTING:
|
||||
|
@ -545,13 +550,13 @@ static void dhcpv4_t1_timeout(struct k_work *work)
|
|||
case NET_DHCPV4_REBINDING:
|
||||
/* This path cannot happen. */
|
||||
NET_ASSERT_INFO(0, "Invalid state %s",
|
||||
net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state));
|
||||
break;
|
||||
case NET_DHCPV4_BOUND:
|
||||
iface->dhcpv4.state = NET_DHCPV4_RENEWING;
|
||||
iface->config.dhcpv4.state = NET_DHCPV4_RENEWING;
|
||||
NET_DBG("enter state=%s",
|
||||
net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
iface->dhcpv4.attempts = 0;
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state));
|
||||
iface->config.dhcpv4.attempts = 0;
|
||||
send_request(iface);
|
||||
break;
|
||||
}
|
||||
|
@ -560,18 +565,18 @@ static void dhcpv4_t1_timeout(struct k_work *work)
|
|||
static void dhcpv4_t2_timeout(struct k_work *work)
|
||||
{
|
||||
struct net_if *iface = CONTAINER_OF(work, struct net_if,
|
||||
dhcpv4.t2_timer);
|
||||
config.dhcpv4.t2_timer);
|
||||
|
||||
NET_DBG("");
|
||||
|
||||
switch (iface->dhcpv4.state) {
|
||||
switch (iface->config.dhcpv4.state) {
|
||||
case NET_DHCPV4_DISABLED:
|
||||
case NET_DHCPV4_INIT:
|
||||
case NET_DHCPV4_SELECTING:
|
||||
case NET_DHCPV4_REQUESTING:
|
||||
case NET_DHCPV4_REBINDING:
|
||||
NET_ASSERT_INFO(0, "Invalid state %s",
|
||||
net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state));
|
||||
break;
|
||||
case NET_DHCPV4_BOUND:
|
||||
/* If renewal time and rebinding time are
|
||||
|
@ -580,10 +585,10 @@ static void dhcpv4_t2_timeout(struct k_work *work)
|
|||
* through RENEWAL already.
|
||||
*/
|
||||
case NET_DHCPV4_RENEWING:
|
||||
iface->dhcpv4.state = NET_DHCPV4_REBINDING;
|
||||
iface->config.dhcpv4.state = NET_DHCPV4_REBINDING;
|
||||
NET_DBG("enter state=%s",
|
||||
net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
iface->dhcpv4.attempts = 0;
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state));
|
||||
iface->config.dhcpv4.attempts = 0;
|
||||
send_request(iface);
|
||||
break;
|
||||
}
|
||||
|
@ -594,43 +599,43 @@ static void enter_bound(struct net_if *iface)
|
|||
u32_t renewal_time;
|
||||
u32_t rebinding_time;
|
||||
|
||||
k_delayed_work_cancel(&iface->dhcpv4.timer);
|
||||
k_delayed_work_cancel(&iface->config.dhcpv4.timer);
|
||||
|
||||
renewal_time = iface->dhcpv4.renewal_time;
|
||||
renewal_time = iface->config.dhcpv4.renewal_time;
|
||||
if (!renewal_time) {
|
||||
/* The default renewal time rfc2131 4.4.5 */
|
||||
renewal_time = iface->dhcpv4.lease_time / 2;
|
||||
renewal_time = iface->config.dhcpv4.lease_time / 2;
|
||||
}
|
||||
|
||||
rebinding_time = iface->dhcpv4.rebinding_time;
|
||||
rebinding_time = iface->config.dhcpv4.rebinding_time;
|
||||
if (!rebinding_time) {
|
||||
/* The default rebinding time rfc2131 4.4.5 */
|
||||
rebinding_time = iface->dhcpv4.lease_time * 875 / 1000;
|
||||
rebinding_time = iface->config.dhcpv4.lease_time * 875 / 1000;
|
||||
}
|
||||
|
||||
iface->dhcpv4.state = NET_DHCPV4_BOUND;
|
||||
iface->config.dhcpv4.state = NET_DHCPV4_BOUND;
|
||||
NET_DBG("enter state=%s renewal=%"PRIu32"s "
|
||||
"rebinding=%"PRIu32"s",
|
||||
net_dhcpv4_state_name(iface->dhcpv4.state),
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state),
|
||||
renewal_time, rebinding_time);
|
||||
|
||||
/* Start renewal time */
|
||||
k_delayed_work_submit(&iface->dhcpv4.t1_timer,
|
||||
k_delayed_work_submit(&iface->config.dhcpv4.t1_timer,
|
||||
renewal_time * MSEC_PER_SEC);
|
||||
|
||||
/* Start rebinding time */
|
||||
k_delayed_work_submit(&iface->dhcpv4.t2_timer,
|
||||
k_delayed_work_submit(&iface->config.dhcpv4.t2_timer,
|
||||
rebinding_time * MSEC_PER_SEC);
|
||||
}
|
||||
|
||||
static void dhcpv4_timeout(struct k_work *work)
|
||||
{
|
||||
struct net_if *iface = CONTAINER_OF(work, struct net_if,
|
||||
dhcpv4.timer);
|
||||
config.dhcpv4.timer);
|
||||
|
||||
NET_DBG("state=%s", net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
NET_DBG("state=%s", net_dhcpv4_state_name(iface->config.dhcpv4.state));
|
||||
|
||||
switch (iface->dhcpv4.state) {
|
||||
switch (iface->config.dhcpv4.state) {
|
||||
case NET_DHCPV4_DISABLED:
|
||||
break;
|
||||
case NET_DHCPV4_INIT:
|
||||
|
@ -644,7 +649,8 @@ static void dhcpv4_timeout(struct k_work *work)
|
|||
/* Maximum number of renewal attempts failed, so start
|
||||
* from the beginning.
|
||||
*/
|
||||
if (iface->dhcpv4.attempts >= DHCPV4_MAX_NUMBER_OF_ATTEMPTS) {
|
||||
if (iface->config.dhcpv4.attempts >=
|
||||
DHCPV4_MAX_NUMBER_OF_ATTEMPTS) {
|
||||
NET_DBG("too many attempts, restart");
|
||||
enter_selecting(iface);
|
||||
} else {
|
||||
|
@ -656,10 +662,11 @@ static void dhcpv4_timeout(struct k_work *work)
|
|||
break;
|
||||
case NET_DHCPV4_RENEWING:
|
||||
case NET_DHCPV4_REBINDING:
|
||||
if (iface->dhcpv4.attempts >= DHCPV4_MAX_NUMBER_OF_ATTEMPTS) {
|
||||
if (iface->config.dhcpv4.attempts >=
|
||||
DHCPV4_MAX_NUMBER_OF_ATTEMPTS) {
|
||||
NET_DBG("too many attempts, restart");
|
||||
if (!net_if_ipv4_addr_rm(iface,
|
||||
&iface->dhcpv4.requested_ip)) {
|
||||
&iface->config.dhcpv4.requested_ip)) {
|
||||
NET_DBG("Failed to remove addr from iface");
|
||||
}
|
||||
/* Maximum number of renewal attempts failed, so start
|
||||
|
@ -802,10 +809,10 @@ static enum net_verdict parse_options(struct net_if *iface,
|
|||
}
|
||||
|
||||
frag = net_frag_read_be32(frag, pos, &pos,
|
||||
&iface->dhcpv4.lease_time);
|
||||
&iface->config.dhcpv4.lease_time);
|
||||
NET_DBG("options_lease_time: %u",
|
||||
iface->dhcpv4.lease_time);
|
||||
if (!iface->dhcpv4.lease_time) {
|
||||
iface->config.dhcpv4.lease_time);
|
||||
if (!iface->config.dhcpv4.lease_time) {
|
||||
return NET_DROP;
|
||||
}
|
||||
|
||||
|
@ -817,10 +824,10 @@ static enum net_verdict parse_options(struct net_if *iface,
|
|||
}
|
||||
|
||||
frag = net_frag_read_be32(frag, pos, &pos,
|
||||
&iface->dhcpv4.renewal_time);
|
||||
&iface->config.dhcpv4.renewal_time);
|
||||
NET_DBG("options_renewal: %u",
|
||||
iface->dhcpv4.renewal_time);
|
||||
if (!iface->dhcpv4.renewal_time) {
|
||||
iface->config.dhcpv4.renewal_time);
|
||||
if (!iface->config.dhcpv4.renewal_time) {
|
||||
return NET_DROP;
|
||||
}
|
||||
|
||||
|
@ -832,10 +839,10 @@ static enum net_verdict parse_options(struct net_if *iface,
|
|||
}
|
||||
|
||||
frag = net_frag_read_be32(frag, pos, &pos,
|
||||
&iface->dhcpv4.rebinding_time);
|
||||
&iface->config.dhcpv4.rebinding_time);
|
||||
NET_DBG("options_rebinding: %u",
|
||||
iface->dhcpv4.rebinding_time);
|
||||
if (!iface->dhcpv4.rebinding_time) {
|
||||
iface->config.dhcpv4.rebinding_time);
|
||||
if (!iface->config.dhcpv4.rebinding_time) {
|
||||
return NET_DROP;
|
||||
}
|
||||
|
||||
|
@ -847,9 +854,10 @@ static enum net_verdict parse_options(struct net_if *iface,
|
|||
}
|
||||
|
||||
frag = net_frag_read(frag, pos, &pos, length,
|
||||
iface->dhcpv4.server_id.s4_addr);
|
||||
iface->config.dhcpv4.server_id.s4_addr);
|
||||
NET_DBG("options_server_id: %s",
|
||||
net_sprint_ipv4_addr(&iface->dhcpv4.server_id));
|
||||
net_sprint_ipv4_addr(
|
||||
&iface->config.dhcpv4.server_id));
|
||||
break;
|
||||
case DHCPV4_OPTIONS_MSG_TYPE: {
|
||||
u8_t v;
|
||||
|
@ -880,7 +888,7 @@ static enum net_verdict parse_options(struct net_if *iface,
|
|||
|
||||
static inline void handle_offer(struct net_if *iface)
|
||||
{
|
||||
switch (iface->dhcpv4.state) {
|
||||
switch (iface->config.dhcpv4.state) {
|
||||
case NET_DHCPV4_DISABLED:
|
||||
case NET_DHCPV4_INIT:
|
||||
case NET_DHCPV4_REQUESTING:
|
||||
|
@ -889,7 +897,7 @@ static inline void handle_offer(struct net_if *iface)
|
|||
case NET_DHCPV4_BOUND:
|
||||
break;
|
||||
case NET_DHCPV4_SELECTING:
|
||||
k_delayed_work_cancel(&iface->dhcpv4.timer);
|
||||
k_delayed_work_cancel(&iface->config.dhcpv4.timer);
|
||||
enter_requesting(iface);
|
||||
break;
|
||||
}
|
||||
|
@ -897,7 +905,7 @@ static inline void handle_offer(struct net_if *iface)
|
|||
|
||||
static void handle_ack(struct net_if *iface)
|
||||
{
|
||||
switch (iface->dhcpv4.state) {
|
||||
switch (iface->config.dhcpv4.state) {
|
||||
case NET_DHCPV4_DISABLED:
|
||||
case NET_DHCPV4_INIT:
|
||||
case NET_DHCPV4_SELECTING:
|
||||
|
@ -905,11 +913,12 @@ static void handle_ack(struct net_if *iface)
|
|||
break;
|
||||
case NET_DHCPV4_REQUESTING:
|
||||
NET_INFO("Received: %s",
|
||||
net_sprint_ipv4_addr(&iface->dhcpv4.requested_ip));
|
||||
net_sprint_ipv4_addr(
|
||||
&iface->config.dhcpv4.requested_ip));
|
||||
if (!net_if_ipv4_addr_add(iface,
|
||||
&iface->dhcpv4.requested_ip,
|
||||
&iface->config.dhcpv4.requested_ip,
|
||||
NET_ADDR_DHCP,
|
||||
iface->dhcpv4.lease_time)) {
|
||||
iface->config.dhcpv4.lease_time)) {
|
||||
NET_DBG("Failed to add IPv4 addr to iface %p", iface);
|
||||
return;
|
||||
}
|
||||
|
@ -929,7 +938,7 @@ static void handle_ack(struct net_if *iface)
|
|||
|
||||
static void handle_nak(struct net_if *iface)
|
||||
{
|
||||
switch (iface->dhcpv4.state) {
|
||||
switch (iface->config.dhcpv4.state) {
|
||||
case NET_DHCPV4_DISABLED:
|
||||
case NET_DHCPV4_INIT:
|
||||
case NET_DHCPV4_SELECTING:
|
||||
|
@ -940,9 +949,9 @@ static void handle_nak(struct net_if *iface)
|
|||
case NET_DHCPV4_REBINDING:
|
||||
/* Restart the configuration process. */
|
||||
|
||||
k_delayed_work_cancel(&iface->dhcpv4.timer);
|
||||
k_delayed_work_cancel(&iface->dhcpv4.t1_timer);
|
||||
k_delayed_work_cancel(&iface->dhcpv4.t2_timer);
|
||||
k_delayed_work_cancel(&iface->config.dhcpv4.timer);
|
||||
k_delayed_work_cancel(&iface->config.dhcpv4.t1_timer);
|
||||
k_delayed_work_cancel(&iface->config.dhcpv4.t2_timer);
|
||||
|
||||
enter_selecting(iface);
|
||||
break;
|
||||
|
@ -953,7 +962,7 @@ static void handle_dhcpv4_reply(struct net_if *iface,
|
|||
enum dhcpv4_msg_type msg_type)
|
||||
{
|
||||
NET_DBG("state=%s msg=%s",
|
||||
net_dhcpv4_state_name(iface->dhcpv4.state),
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state),
|
||||
net_dhcpv4_msg_type_name(msg_type));
|
||||
|
||||
switch (msg_type) {
|
||||
|
@ -1025,16 +1034,16 @@ static enum net_verdict net_dhcpv4_input(struct net_conn *conn,
|
|||
net_sprint_ll_addr(msg->chaddr, 6));
|
||||
|
||||
if (!(msg->op == DHCPV4_MSG_BOOT_REPLY &&
|
||||
iface->dhcpv4.xid == ntohl(msg->xid) &&
|
||||
!memcmp(msg->chaddr, iface->link_addr.addr,
|
||||
iface->link_addr.len))) {
|
||||
iface->config.dhcpv4.xid == ntohl(msg->xid) &&
|
||||
!memcmp(msg->chaddr, net_if_get_link_addr(iface)->addr,
|
||||
net_if_get_link_addr(iface)->len))) {
|
||||
|
||||
NET_DBG("Unexpected op (%d), xid (%x vs %x) or chaddr",
|
||||
msg->op, iface->dhcpv4.xid, ntohl(msg->xid));
|
||||
msg->op, iface->config.dhcpv4.xid, ntohl(msg->xid));
|
||||
goto drop;
|
||||
}
|
||||
|
||||
memcpy(iface->dhcpv4.requested_ip.s4_addr, msg->yiaddr,
|
||||
memcpy(iface->config.dhcpv4.requested_ip.s4_addr, msg->yiaddr,
|
||||
sizeof(msg->yiaddr));
|
||||
|
||||
/* SNAME, FILE are not used at the moment, skip it */
|
||||
|
@ -1064,21 +1073,25 @@ void net_dhcpv4_start(struct net_if *iface)
|
|||
u32_t timeout;
|
||||
u32_t entropy;
|
||||
|
||||
switch (iface->dhcpv4.state) {
|
||||
switch (iface->config.dhcpv4.state) {
|
||||
case NET_DHCPV4_DISABLED:
|
||||
iface->dhcpv4.state = NET_DHCPV4_INIT;
|
||||
NET_DBG("state=%s", net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
iface->config.dhcpv4.state = NET_DHCPV4_INIT;
|
||||
NET_DBG("state=%s",
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state));
|
||||
|
||||
iface->dhcpv4.attempts = 0;
|
||||
iface->dhcpv4.lease_time = 0;
|
||||
iface->dhcpv4.renewal_time = 0;
|
||||
iface->config.dhcpv4.attempts = 0;
|
||||
iface->config.dhcpv4.lease_time = 0;
|
||||
iface->config.dhcpv4.renewal_time = 0;
|
||||
|
||||
iface->dhcpv4.server_id.s_addr = 0;
|
||||
iface->dhcpv4.requested_ip.s_addr = 0;
|
||||
iface->config.dhcpv4.server_id.s_addr = 0;
|
||||
iface->config.dhcpv4.requested_ip.s_addr = 0;
|
||||
|
||||
k_delayed_work_init(&iface->dhcpv4.timer, dhcpv4_timeout);
|
||||
k_delayed_work_init(&iface->dhcpv4.t1_timer, dhcpv4_t1_timeout);
|
||||
k_delayed_work_init(&iface->dhcpv4.t2_timer, dhcpv4_t2_timeout);
|
||||
k_delayed_work_init(&iface->config.dhcpv4.timer,
|
||||
dhcpv4_timeout);
|
||||
k_delayed_work_init(&iface->config.dhcpv4.t1_timer,
|
||||
dhcpv4_t1_timeout);
|
||||
k_delayed_work_init(&iface->config.dhcpv4.t2_timer,
|
||||
dhcpv4_t2_timeout);
|
||||
|
||||
/* We need entropy for both an XID and a random delay
|
||||
* before sending the initial discover message.
|
||||
|
@ -1090,7 +1103,7 @@ void net_dhcpv4_start(struct net_if *iface)
|
|||
* one used by another client. Choose a random xid st
|
||||
* startup and increment it on each new request.
|
||||
*/
|
||||
iface->dhcpv4.xid = entropy;
|
||||
iface->config.dhcpv4.xid = entropy;
|
||||
|
||||
|
||||
/* RFC2131 4.1.1 requires we wait a random period
|
||||
|
@ -1103,7 +1116,7 @@ void net_dhcpv4_start(struct net_if *iface)
|
|||
|
||||
NET_DBG("wait timeout=%"PRIu32"s", timeout);
|
||||
|
||||
k_delayed_work_submit(&iface->dhcpv4.timer,
|
||||
k_delayed_work_submit(&iface->config.dhcpv4.timer,
|
||||
timeout * MSEC_PER_SEC);
|
||||
break;
|
||||
case NET_DHCPV4_INIT:
|
||||
|
@ -1118,13 +1131,13 @@ void net_dhcpv4_start(struct net_if *iface)
|
|||
|
||||
void net_dhcpv4_stop(struct net_if *iface)
|
||||
{
|
||||
switch (iface->dhcpv4.state) {
|
||||
switch (iface->config.dhcpv4.state) {
|
||||
case NET_DHCPV4_DISABLED:
|
||||
break;
|
||||
|
||||
case NET_DHCPV4_BOUND:
|
||||
if (!net_if_ipv4_addr_rm(iface,
|
||||
&iface->dhcpv4.requested_ip)) {
|
||||
&iface->config.dhcpv4.requested_ip)) {
|
||||
NET_DBG("Failed to remove addr from iface");
|
||||
}
|
||||
/* Fall through */
|
||||
|
@ -1134,12 +1147,13 @@ void net_dhcpv4_stop(struct net_if *iface)
|
|||
case NET_DHCPV4_REQUESTING:
|
||||
case NET_DHCPV4_RENEWING:
|
||||
case NET_DHCPV4_REBINDING:
|
||||
iface->dhcpv4.state = NET_DHCPV4_DISABLED;
|
||||
NET_DBG("state=%s", net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
iface->config.dhcpv4.state = NET_DHCPV4_DISABLED;
|
||||
NET_DBG("state=%s",
|
||||
net_dhcpv4_state_name(iface->config.dhcpv4.state));
|
||||
|
||||
k_delayed_work_cancel(&iface->dhcpv4.timer);
|
||||
k_delayed_work_cancel(&iface->dhcpv4.t1_timer);
|
||||
k_delayed_work_cancel(&iface->dhcpv4.t2_timer);
|
||||
k_delayed_work_cancel(&iface->config.dhcpv4.timer);
|
||||
k_delayed_work_cancel(&iface->config.dhcpv4.t1_timer);
|
||||
k_delayed_work_cancel(&iface->config.dhcpv4.t2_timer);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -189,12 +189,15 @@ int net_icmpv4_send_echo_request(struct net_if *iface,
|
|||
u16_t identifier,
|
||||
u16_t sequence)
|
||||
{
|
||||
struct net_if_config *config;
|
||||
const struct in_addr *src;
|
||||
struct net_pkt *pkt;
|
||||
struct net_buf *frag;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
/* Take the first address of the network interface */
|
||||
src = &iface->ipv4.unicast[0].address.in_addr;
|
||||
src = &config->ip.ipv4.unicast[0].address.in_addr;
|
||||
|
||||
/* We cast to IPv6 address but that should be ok in this case
|
||||
* as IPv4 cannot be used in 802.15.4 where it is the reserve
|
||||
|
|
|
@ -69,6 +69,10 @@ struct net_pkt *net_ipv4_create(struct net_context *context,
|
|||
const struct in_addr *src,
|
||||
const struct in_addr *dst)
|
||||
{
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(net_pkt_iface(pkt));
|
||||
|
||||
NET_ASSERT(((struct sockaddr_in_ptr *)&context->local)->sin_addr);
|
||||
|
||||
if (!src) {
|
||||
|
@ -77,7 +81,7 @@ struct net_pkt *net_ipv4_create(struct net_context *context,
|
|||
|
||||
if (net_is_ipv4_addr_unspecified(src)
|
||||
|| net_is_ipv4_addr_mcast(src)) {
|
||||
src = &net_pkt_iface(pkt)->ipv4.unicast[0].address.in_addr;
|
||||
src = &config->ip.ipv4.unicast[0].address.in_addr;
|
||||
}
|
||||
|
||||
return net_ipv4_create_raw(pkt,
|
||||
|
|
|
@ -1041,7 +1041,8 @@ ignore_frag_error:
|
|||
/* Workaround Linux bug, see:
|
||||
* https://github.com/zephyrproject-rtos/zephyr/issues/3111
|
||||
*/
|
||||
if (atomic_test_bit(net_pkt_iface(pkt)->flags, NET_IF_POINTOPOINT)) {
|
||||
if (atomic_test_bit(net_pkt_iface(pkt)->if_dev->flags,
|
||||
NET_IF_POINTOPOINT)) {
|
||||
/* Update RPL header */
|
||||
if (net_rpl_update_header(pkt, &NET_IPV6_HDR(pkt)->dst) < 0) {
|
||||
net_pkt_unref(pkt);
|
||||
|
@ -1208,15 +1209,15 @@ struct net_nbr *net_ipv6_get_nbr(struct net_if *iface, u8_t idx)
|
|||
|
||||
static inline u8_t get_llao_len(struct net_if *iface)
|
||||
{
|
||||
if (iface->link_addr.len == 6) {
|
||||
if (net_if_get_link_addr(iface)->len == 6) {
|
||||
return 8;
|
||||
} else if (iface->link_addr.len == 8) {
|
||||
} else if (net_if_get_link_addr(iface)->len == 8) {
|
||||
return 16;
|
||||
}
|
||||
|
||||
/* What else could it be? */
|
||||
NET_ASSERT_INFO(0, "Invalid link address length %d",
|
||||
iface->link_addr.len);
|
||||
net_if_get_link_addr(iface)->len);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -1336,7 +1337,7 @@ int net_ipv6_send_na(struct net_if *iface, const struct in6_addr *src,
|
|||
net_ipaddr_copy(&NET_IPV6_HDR(pkt)->dst, dst);
|
||||
net_ipaddr_copy(&na_hdr->tgt, tgt);
|
||||
|
||||
set_llao(&net_pkt_iface(pkt)->link_addr,
|
||||
set_llao(net_if_get_link_addr(net_pkt_iface(pkt)),
|
||||
(u8_t *)net_pkt_icmp_data(pkt) + sizeof(struct net_icmp_hdr) +
|
||||
sizeof(struct net_icmpv6_na_hdr),
|
||||
llao_len, NET_ICMPV6_ND_OPT_TLLAO);
|
||||
|
@ -1749,7 +1750,8 @@ static void nd_reachable_timeout(struct k_work *work)
|
|||
}
|
||||
}
|
||||
|
||||
void net_ipv6_nbr_set_reachable_timer(struct net_if *iface, struct net_nbr *nbr)
|
||||
void net_ipv6_nbr_set_reachable_timer(struct net_if *iface,
|
||||
struct net_nbr *nbr)
|
||||
{
|
||||
u32_t time;
|
||||
|
||||
|
@ -1792,7 +1794,7 @@ static inline bool handle_na_neighbor(struct net_pkt *pkt,
|
|||
}
|
||||
|
||||
if (tllao_offset) {
|
||||
lladdr.len = net_pkt_iface(pkt)->link_addr.len;
|
||||
lladdr.len = net_if_get_link_addr(net_pkt_iface(pkt))->len;
|
||||
|
||||
frag = net_frag_read(pkt->frags, tllao_offset,
|
||||
&pos, lladdr.len, lladdr.addr);
|
||||
|
@ -2133,7 +2135,7 @@ int net_ipv6_send_ns(struct net_if *iface,
|
|||
|
||||
net_buf_add(frag, llao_len);
|
||||
|
||||
set_llao(&net_pkt_iface(pkt)->link_addr,
|
||||
set_llao(net_if_get_link_addr(net_pkt_iface(pkt)),
|
||||
(u8_t *)net_pkt_icmp_data(pkt) +
|
||||
sizeof(struct net_icmp_hdr) +
|
||||
sizeof(struct net_icmpv6_ns_hdr),
|
||||
|
@ -2250,7 +2252,7 @@ int net_ipv6_send_rs(struct net_if *iface)
|
|||
if (!unspec_src) {
|
||||
net_buf_add(frag, llao_len);
|
||||
|
||||
set_llao(&net_pkt_iface(pkt)->link_addr,
|
||||
set_llao(net_if_get_link_addr(net_pkt_iface(pkt)),
|
||||
(u8_t *)net_pkt_icmp_data(pkt) +
|
||||
sizeof(struct net_icmp_hdr) +
|
||||
sizeof(struct net_icmpv6_rs_hdr),
|
||||
|
@ -2565,6 +2567,7 @@ static enum net_verdict handle_ra_input(struct net_pkt *pkt)
|
|||
struct net_nbr *nbr = NULL;
|
||||
struct net_icmpv6_ra_hdr hdr, *ra_hdr;
|
||||
struct net_if_router *router;
|
||||
struct net_if_config *config;
|
||||
struct net_buf *frag;
|
||||
u16_t router_lifetime;
|
||||
u32_t reachable_time;
|
||||
|
@ -2758,8 +2761,10 @@ static enum net_verdict handle_ra_input(struct net_pkt *pkt)
|
|||
nbr_clear_ns_pending(net_ipv6_nbr_data(nbr));
|
||||
}
|
||||
|
||||
config = net_if_config_get(net_pkt_iface(pkt));
|
||||
|
||||
/* Cancel the RS timer on iface */
|
||||
k_delayed_work_cancel(&net_pkt_iface(pkt)->ipv6.rs_timer);
|
||||
k_delayed_work_cancel(&config->ip.ipv6.rs_timer);
|
||||
|
||||
net_pkt_unref(pkt);
|
||||
|
||||
|
@ -2949,21 +2954,25 @@ int net_ipv6_mld_leave(struct net_if *iface, const struct in6_addr *addr)
|
|||
|
||||
static void send_mld_report(struct net_if *iface)
|
||||
{
|
||||
struct net_if_config *config;
|
||||
struct net_pkt *pkt;
|
||||
int i, count = 0;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
pkt = net_pkt_get_reserve_tx(net_if_get_ll_reserve(iface, NULL),
|
||||
K_FOREVER);
|
||||
|
||||
net_pkt_append_u8(pkt, 0); /* This will be the record count */
|
||||
|
||||
for (i = 0; i < NET_IF_MAX_IPV6_MADDR; i++) {
|
||||
if (!iface->ipv6.mcast[i].is_used ||
|
||||
!iface->ipv6.mcast[i].is_joined) {
|
||||
if (!config->ip.ipv6.mcast[i].is_used ||
|
||||
!config->ip.ipv6.mcast[i].is_joined) {
|
||||
continue;
|
||||
}
|
||||
|
||||
pkt = create_mldv2(pkt, &iface->ipv6.mcast[i].address.in6_addr,
|
||||
pkt = create_mldv2(pkt,
|
||||
&config->ip.ipv6.mcast[i].address.in6_addr,
|
||||
NET_IPV6_MLDv2_MODE_IS_EXCLUDE, 0);
|
||||
count++;
|
||||
}
|
||||
|
|
|
@ -78,13 +78,17 @@ static inline struct arp_entry *find_entry(struct net_if *iface,
|
|||
|
||||
static inline struct in_addr *if_get_addr(struct net_if *iface)
|
||||
{
|
||||
struct net_if_config *config;
|
||||
int i;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
for (i = 0; i < NET_IF_MAX_IPV4_ADDR; i++) {
|
||||
if (iface->ipv4.unicast[i].is_used &&
|
||||
iface->ipv4.unicast[i].address.family == AF_INET &&
|
||||
iface->ipv4.unicast[i].addr_state == NET_ADDR_PREFERRED) {
|
||||
return &iface->ipv4.unicast[i].address.in_addr;
|
||||
if (config->ip.ipv4.unicast[i].is_used &&
|
||||
config->ip.ipv4.unicast[i].address.family == AF_INET &&
|
||||
config->ip.ipv4.unicast[i].addr_state ==
|
||||
NET_ADDR_PREFERRED) {
|
||||
return &config->ip.ipv4.unicast[i].address.in_addr;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -226,7 +230,11 @@ struct net_pkt *net_arp_prepare(struct net_pkt *pkt)
|
|||
*/
|
||||
if (!net_if_ipv4_addr_mask_cmp(net_pkt_iface(pkt),
|
||||
&NET_IPV4_HDR(pkt)->dst)) {
|
||||
addr = &net_pkt_iface(pkt)->ipv4.gw;
|
||||
struct net_if_config *config;
|
||||
|
||||
config = net_if_config_get(net_pkt_iface(pkt));
|
||||
|
||||
addr = &config->ip.ipv4.gw;
|
||||
if (net_is_ipv4_addr_unspecified(addr)) {
|
||||
NET_ERR("Gateway not set for iface %p",
|
||||
net_pkt_iface(pkt));
|
||||
|
|
|
@ -262,7 +262,7 @@ static void bt_iface_init(struct net_if *iface)
|
|||
/* Workaround Linux bug, see:
|
||||
* https://github.com/zephyrproject-rtos/zephyr/issues/3111
|
||||
*/
|
||||
atomic_set_bit(iface->flags, NET_IF_POINTOPOINT);
|
||||
atomic_set_bit(iface->if_dev->flags, NET_IF_POINTOPOINT);
|
||||
#endif
|
||||
}
|
||||
|
||||
|
|
|
@ -312,7 +312,7 @@ NET_L2_INIT(IEEE802154_L2,
|
|||
void ieee802154_init(struct net_if *iface)
|
||||
{
|
||||
struct ieee802154_context *ctx = net_if_l2_data(iface);
|
||||
const u8_t *mac = iface->link_addr.addr;
|
||||
const u8_t *mac = net_if_get_link_addr(iface)->addr;
|
||||
s16_t tx_power = CONFIG_NET_L2_IEEE802154_RADIO_DFLT_TX_POWER;
|
||||
u8_t long_addr[8];
|
||||
|
||||
|
|
|
@ -17,65 +17,74 @@
|
|||
static inline
|
||||
enum ieee802154_hw_caps ieee802154_get_hw_capabilities(struct net_if *iface)
|
||||
{
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
return radio->get_capabilities(iface->dev);
|
||||
return radio->get_capabilities(net_if_get_device(iface));
|
||||
}
|
||||
|
||||
static inline int ieee802154_cca(struct net_if *iface)
|
||||
{
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
return radio->cca(iface->dev);
|
||||
return radio->cca(net_if_get_device(iface));
|
||||
}
|
||||
|
||||
static inline int ieee802154_set_channel(struct net_if *iface, u16_t channel)
|
||||
{
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
return radio->set_channel(iface->dev, channel);
|
||||
return radio->set_channel(net_if_get_device(iface), channel);
|
||||
}
|
||||
|
||||
static inline int ieee802154_set_tx_power(struct net_if *iface, s16_t dbm)
|
||||
{
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
return radio->set_txpower(iface->dev, dbm);
|
||||
return radio->set_txpower(net_if_get_device(iface), dbm);
|
||||
}
|
||||
|
||||
static inline int ieee802154_tx(struct net_if *iface,
|
||||
struct net_pkt *pkt, struct net_buf *frag)
|
||||
{
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
return radio->tx(iface->dev, pkt, frag);
|
||||
return radio->tx(net_if_get_device(iface), pkt, frag);
|
||||
}
|
||||
|
||||
static inline int ieee802154_start(struct net_if *iface)
|
||||
{
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
return radio->start(iface->dev);
|
||||
return radio->start(net_if_get_device(iface));
|
||||
}
|
||||
|
||||
static inline int ieee802154_stop(struct net_if *iface)
|
||||
{
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
return radio->stop(iface->dev);
|
||||
return radio->stop(net_if_get_device(iface));
|
||||
}
|
||||
|
||||
static inline void ieee802154_filter_ieee_addr(struct net_if *iface,
|
||||
u8_t *ieee_addr)
|
||||
{
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
if (radio->get_capabilities(iface->dev) & IEEE802154_HW_FILTER) {
|
||||
if (radio->get_capabilities(net_if_get_device(iface)) &
|
||||
IEEE802154_HW_FILTER) {
|
||||
struct ieee802154_filter filter;
|
||||
|
||||
filter.ieee_addr = ieee_addr;
|
||||
|
||||
if (radio->set_filter(iface->dev,
|
||||
if (radio->set_filter(net_if_get_device(iface),
|
||||
IEEE802154_FILTER_TYPE_IEEE_ADDR,
|
||||
&filter) != 0) {
|
||||
NET_WARN("Could not apply IEEE address filter");
|
||||
|
@ -86,14 +95,16 @@ static inline void ieee802154_filter_ieee_addr(struct net_if *iface,
|
|||
static inline void ieee802154_filter_short_addr(struct net_if *iface,
|
||||
u16_t short_addr)
|
||||
{
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
if (radio->get_capabilities(iface->dev) & IEEE802154_HW_FILTER) {
|
||||
if (radio->get_capabilities(net_if_get_device(iface)) &
|
||||
IEEE802154_HW_FILTER) {
|
||||
struct ieee802154_filter filter;
|
||||
|
||||
filter.short_addr = short_addr;
|
||||
|
||||
if (radio->set_filter(iface->dev,
|
||||
if (radio->set_filter(net_if_get_device(iface),
|
||||
IEEE802154_FILTER_TYPE_SHORT_ADDR,
|
||||
&filter) != 0) {
|
||||
NET_WARN("Could not apply short address filter");
|
||||
|
@ -104,14 +115,16 @@ static inline void ieee802154_filter_short_addr(struct net_if *iface,
|
|||
static inline void ieee802154_filter_pan_id(struct net_if *iface,
|
||||
u16_t pan_id)
|
||||
{
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
if (radio->get_capabilities(iface->dev) & IEEE802154_HW_FILTER) {
|
||||
if (radio->get_capabilities(net_if_get_device(iface)) &
|
||||
IEEE802154_HW_FILTER) {
|
||||
struct ieee802154_filter filter;
|
||||
|
||||
filter.pan_id = pan_id;
|
||||
|
||||
if (radio->set_filter(iface->dev,
|
||||
if (radio->set_filter(net_if_get_device(iface),
|
||||
IEEE802154_FILTER_TYPE_PAN_ID,
|
||||
&filter) != 0) {
|
||||
NET_WARN("Could not apply PAN ID filter");
|
||||
|
@ -127,10 +140,13 @@ static inline bool ieee802154_verify_channel(struct net_if *iface,
|
|||
}
|
||||
|
||||
#ifdef CONFIG_NET_L2_IEEE802154_SUB_GHZ
|
||||
const struct ieee802154_radio_api *radio = iface->dev->driver_api;
|
||||
const struct ieee802154_radio_api *radio =
|
||||
net_if_get_device(iface)->driver_api;
|
||||
|
||||
if (radio->get_capabilities(iface->dev) & IEEE802154_HW_SUB_GHZ) {
|
||||
if (channel > radio->get_subg_channel_count(iface->dev)) {
|
||||
if (radio->get_capabilities(net_if_get_device(iface)) &
|
||||
IEEE802154_HW_SUB_GHZ) {
|
||||
if (channel >
|
||||
radio->get_subg_channel_count(net_if_get_device(iface))) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -340,7 +340,7 @@ int net_recv_data(struct net_if *iface, struct net_pkt *pkt)
|
|||
return -ENODATA;
|
||||
}
|
||||
|
||||
if (!atomic_test_bit(iface->flags, NET_IF_UP)) {
|
||||
if (!atomic_test_bit(iface->if_dev->flags, NET_IF_UP)) {
|
||||
return -ENETDOWN;
|
||||
}
|
||||
|
||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -100,7 +100,7 @@ static inline const char *addrstate2str(enum net_addr_state addr_state)
|
|||
static const char *iface2str(struct net_if *iface, const char **extra)
|
||||
{
|
||||
#ifdef CONFIG_NET_L2_IEEE802154
|
||||
if (iface->l2 == &NET_L2_GET_NAME(IEEE802154)) {
|
||||
if (net_if_l2(iface) == &NET_L2_GET_NAME(IEEE802154)) {
|
||||
if (extra) {
|
||||
*extra = "=============";
|
||||
}
|
||||
|
@ -110,7 +110,7 @@ static const char *iface2str(struct net_if *iface, const char **extra)
|
|||
#endif
|
||||
|
||||
#ifdef CONFIG_NET_L2_ETHERNET
|
||||
if (iface->l2 == &NET_L2_GET_NAME(ETHERNET)) {
|
||||
if (net_if_l2(iface) == &NET_L2_GET_NAME(ETHERNET)) {
|
||||
if (extra) {
|
||||
*extra = "========";
|
||||
}
|
||||
|
@ -120,7 +120,7 @@ static const char *iface2str(struct net_if *iface, const char **extra)
|
|||
#endif
|
||||
|
||||
#ifdef CONFIG_NET_L2_DUMMY
|
||||
if (iface->l2 == &NET_L2_GET_NAME(DUMMY)) {
|
||||
if (net_if_l2(iface) == &NET_L2_GET_NAME(DUMMY)) {
|
||||
if (extra) {
|
||||
*extra = "=====";
|
||||
}
|
||||
|
@ -130,7 +130,7 @@ static const char *iface2str(struct net_if *iface, const char **extra)
|
|||
#endif
|
||||
|
||||
#ifdef CONFIG_NET_L2_BT
|
||||
if (iface->l2 == &NET_L2_GET_NAME(BLUETOOTH)) {
|
||||
if (net_if_l2(iface) == &NET_L2_GET_NAME(BLUETOOTH)) {
|
||||
if (extra) {
|
||||
*extra = "=========";
|
||||
}
|
||||
|
@ -140,7 +140,7 @@ static const char *iface2str(struct net_if *iface, const char **extra)
|
|||
#endif
|
||||
|
||||
#ifdef CONFIG_NET_OFFLOAD
|
||||
if (iface->l2 == &NET_L2_GET_NAME(OFFLOAD_IP)) {
|
||||
if (net_if_l2(iface) == &NET_L2_GET_NAME(OFFLOAD_IP)) {
|
||||
if (extra) {
|
||||
*extra = "==========";
|
||||
}
|
||||
|
@ -164,29 +164,34 @@ static void iface_cb(struct net_if *iface, void *user_data)
|
|||
#endif
|
||||
struct net_if_addr *unicast;
|
||||
struct net_if_mcast_addr *mcast;
|
||||
struct net_if_config *config;
|
||||
const char *extra;
|
||||
int i, count;
|
||||
|
||||
ARG_UNUSED(user_data);
|
||||
|
||||
printk("\nInterface %p (%s)\n", iface, iface2str(iface, &extra));
|
||||
printk("=======================%s\n", extra);
|
||||
printk("\nInterface %p (%s) [%d]\n", iface, iface2str(iface, &extra),
|
||||
net_if_get_by_iface(iface));
|
||||
printk("===========================%s\n", extra);
|
||||
|
||||
if (!net_if_is_up(iface)) {
|
||||
printk("Interface is down.\n");
|
||||
return;
|
||||
}
|
||||
|
||||
printk("Link addr : %s\n", net_sprint_ll_addr(iface->link_addr.addr,
|
||||
iface->link_addr.len));
|
||||
printk("MTU : %d\n", iface->mtu);
|
||||
config = &iface->config;
|
||||
|
||||
printk("Link addr : %s\n", net_sprint_ll_addr(
|
||||
net_if_get_link_addr(iface)->addr,
|
||||
net_if_get_link_addr(iface)->len));
|
||||
printk("MTU : %d\n", net_if_get_mtu(iface));
|
||||
|
||||
#if defined(CONFIG_NET_IPV6)
|
||||
count = 0;
|
||||
|
||||
printk("IPv6 unicast addresses (max %d):\n", NET_IF_MAX_IPV6_ADDR);
|
||||
for (i = 0; i < NET_IF_MAX_IPV6_ADDR; i++) {
|
||||
unicast = &iface->ipv6.unicast[i];
|
||||
unicast = &config->ip.ipv6.unicast[i];
|
||||
|
||||
if (!unicast->is_used) {
|
||||
continue;
|
||||
|
@ -208,7 +213,7 @@ static void iface_cb(struct net_if *iface, void *user_data)
|
|||
|
||||
printk("IPv6 multicast addresses (max %d):\n", NET_IF_MAX_IPV6_MADDR);
|
||||
for (i = 0; i < NET_IF_MAX_IPV6_MADDR; i++) {
|
||||
mcast = &iface->ipv6.mcast[i];
|
||||
mcast = &config->ip.ipv6.mcast[i];
|
||||
|
||||
if (!mcast->is_used) {
|
||||
continue;
|
||||
|
@ -228,7 +233,7 @@ static void iface_cb(struct net_if *iface, void *user_data)
|
|||
|
||||
printk("IPv6 prefixes (max %d):\n", NET_IF_MAX_IPV6_PREFIX);
|
||||
for (i = 0; i < NET_IF_MAX_IPV6_PREFIX; i++) {
|
||||
prefix = &iface->ipv6.prefix[i];
|
||||
prefix = &config->ip.ipv6.prefix[i];
|
||||
|
||||
if (!prefix->is_used) {
|
||||
continue;
|
||||
|
@ -254,11 +259,15 @@ static void iface_cb(struct net_if *iface, void *user_data)
|
|||
router->is_infinite ? " infinite" : "");
|
||||
}
|
||||
|
||||
printk("IPv6 hop limit : %d\n", iface->ipv6.hop_limit);
|
||||
printk("IPv6 hop limit : %d\n",
|
||||
config->ip.ipv6.hop_limit);
|
||||
printk("IPv6 base reachable time : %d\n",
|
||||
iface->ipv6.base_reachable_time);
|
||||
printk("IPv6 reachable time : %d\n", iface->ipv6.reachable_time);
|
||||
printk("IPv6 retransmit timer : %d\n", iface->ipv6.retrans_timer);
|
||||
config->ip.ipv6.base_reachable_time);
|
||||
printk("IPv6 reachable time : %d\n",
|
||||
config->ip.ipv6.reachable_time);
|
||||
printk("IPv6 retransmit timer : %d\n",
|
||||
config->ip.ipv6.retrans_timer);
|
||||
|
||||
#endif /* CONFIG_NET_IPV6 */
|
||||
|
||||
#if defined(CONFIG_NET_IPV4)
|
||||
|
@ -267,10 +276,10 @@ static void iface_cb(struct net_if *iface, void *user_data)
|
|||
*/
|
||||
if (
|
||||
#if defined(CONFIG_NET_L2_IEEE802154)
|
||||
(iface->l2 == &NET_L2_GET_NAME(IEEE802154)) ||
|
||||
(net_if_l2(iface) == &NET_L2_GET_NAME(IEEE802154)) ||
|
||||
#endif
|
||||
#if defined(CONFIG_NET_L2_BT)
|
||||
(iface->l2 == &NET_L2_GET_NAME(BLUETOOTH)) ||
|
||||
(net_if_l2(iface) == &NET_L2_GET_NAME(BLUETOOTH)) ||
|
||||
#endif
|
||||
0) {
|
||||
printk("IPv4 not supported for this interface.\n");
|
||||
|
@ -279,9 +288,10 @@ static void iface_cb(struct net_if *iface, void *user_data)
|
|||
|
||||
count = 0;
|
||||
|
||||
printk("IPv4 unicast addresses (max %d):\n", NET_IF_MAX_IPV4_ADDR);
|
||||
printk("IPv4 unicast addresses (max %d):\n",
|
||||
NET_IF_MAX_IPV4_ADDR);
|
||||
for (i = 0; i < NET_IF_MAX_IPV4_ADDR; i++) {
|
||||
unicast = &iface->ipv4.unicast[i];
|
||||
unicast = &config->ip.ipv4.unicast[i];
|
||||
|
||||
if (!unicast->is_used) {
|
||||
continue;
|
||||
|
@ -302,9 +312,10 @@ static void iface_cb(struct net_if *iface, void *user_data)
|
|||
|
||||
count = 0;
|
||||
|
||||
printk("IPv4 multicast addresses (max %d):\n", NET_IF_MAX_IPV4_MADDR);
|
||||
printk("IPv4 multicast addresses (max %d):\n",
|
||||
NET_IF_MAX_IPV4_MADDR);
|
||||
for (i = 0; i < NET_IF_MAX_IPV4_MADDR; i++) {
|
||||
mcast = &iface->ipv4.mcast[i];
|
||||
mcast = &config->ip.ipv4.mcast[i];
|
||||
|
||||
if (!mcast->is_used) {
|
||||
continue;
|
||||
|
@ -321,21 +332,24 @@ static void iface_cb(struct net_if *iface, void *user_data)
|
|||
}
|
||||
|
||||
printk("IPv4 gateway : %s\n",
|
||||
net_sprint_ipv4_addr(&iface->ipv4.gw));
|
||||
net_sprint_ipv4_addr(&config->ip.ipv4.gw));
|
||||
printk("IPv4 netmask : %s\n",
|
||||
net_sprint_ipv4_addr(&iface->ipv4.netmask));
|
||||
net_sprint_ipv4_addr(&config->ip.ipv4.netmask));
|
||||
#endif /* CONFIG_NET_IPV4 */
|
||||
|
||||
#if defined(CONFIG_NET_DHCPV4)
|
||||
printk("DHCPv4 lease time : %u\n", iface->dhcpv4.lease_time);
|
||||
printk("DHCPv4 renew time : %u\n", iface->dhcpv4.renewal_time);
|
||||
printk("DHCPv4 lease time : %u\n",
|
||||
config->dhcpv4.lease_time);
|
||||
printk("DHCPv4 renew time : %u\n",
|
||||
config->dhcpv4.renewal_time);
|
||||
printk("DHCPv4 server : %s\n",
|
||||
net_sprint_ipv4_addr(&iface->dhcpv4.server_id));
|
||||
net_sprint_ipv4_addr(&config->dhcpv4.server_id));
|
||||
printk("DHCPv4 requested : %s\n",
|
||||
net_sprint_ipv4_addr(&iface->dhcpv4.requested_ip));
|
||||
net_sprint_ipv4_addr(&config->dhcpv4.requested_ip));
|
||||
printk("DHCPv4 state : %s\n",
|
||||
net_dhcpv4_state_name(iface->dhcpv4.state));
|
||||
printk("DHCPv4 attempts : %d\n", iface->dhcpv4.attempts);
|
||||
net_dhcpv4_state_name(config->dhcpv4.state));
|
||||
printk("DHCPv4 attempts : %d\n",
|
||||
config->dhcpv4.attempts);
|
||||
#endif /* CONFIG_NET_DHCPV4 */
|
||||
}
|
||||
|
||||
|
@ -2245,7 +2259,7 @@ static void get_my_ipv4_addr(struct net_if *iface,
|
|||
{
|
||||
/* Just take the first IPv4 address of an interface. */
|
||||
memcpy(&net_sin(myaddr)->sin_addr,
|
||||
&iface->ipv4.unicast[0].address.in_addr,
|
||||
&iface->config.ip.ipv4.unicast[0].address.in_addr,
|
||||
sizeof(struct in_addr));
|
||||
|
||||
net_sin(myaddr)->sin_port = 0; /* let the IP stack to select */
|
||||
|
|
|
@ -1208,7 +1208,8 @@ static void check_prefix(struct net_if *iface,
|
|||
}
|
||||
|
||||
if (last_prefix) {
|
||||
set_ip_from_prefix(&iface->link_addr, last_prefix, &addr);
|
||||
set_ip_from_prefix(net_if_get_link_addr(iface),
|
||||
last_prefix, &addr);
|
||||
|
||||
if (net_if_ipv6_addr_rm(iface, &addr)) {
|
||||
NET_DBG("Removed global IP address %s",
|
||||
|
@ -1217,7 +1218,8 @@ static void check_prefix(struct net_if *iface,
|
|||
}
|
||||
|
||||
if (new_prefix) {
|
||||
set_ip_from_prefix(&iface->link_addr, new_prefix, &addr);
|
||||
set_ip_from_prefix(net_if_get_link_addr(iface),
|
||||
new_prefix, &addr);
|
||||
|
||||
if (net_if_ipv6_addr_add(iface, &addr, NET_ADDR_AUTOCONF, 0)) {
|
||||
NET_DBG("Added global IP address %s",
|
||||
|
@ -2177,9 +2179,10 @@ static void send_mcast_dao(struct net_rpl_instance *instance)
|
|||
|
||||
/* Send a DAO for own multicast addresses */
|
||||
for (i = 0; i < NET_IF_MAX_IPV6_MADDR; i++) {
|
||||
addr = &instance->iface->ipv6.mcast[i].address.in6_addr;
|
||||
addr =
|
||||
&instance->iface->config.ip.ipv6.mcast[i].address.in6_addr;
|
||||
|
||||
if (instance->iface->ipv6.mcast[i].is_used &&
|
||||
if (instance->iface->config.ip.ipv6.mcast[i].is_used &&
|
||||
net_is_ipv6_addr_mcast_global(addr)) {
|
||||
|
||||
net_rpl_dao_send(instance->iface,
|
||||
|
|
|
@ -576,11 +576,11 @@ u16_t net_tcp_get_recv_mss(const struct net_tcp *tcp)
|
|||
#if defined(CONFIG_NET_IPV4)
|
||||
struct net_if *iface = net_context_get_iface(tcp->context);
|
||||
|
||||
if (iface && iface->mtu >= NET_IPV4TCPH_LEN) {
|
||||
if (iface && net_if_get_mtu(iface) >= NET_IPV4TCPH_LEN) {
|
||||
/* Detect MSS based on interface MTU minus "TCP,IP
|
||||
* header size"
|
||||
*/
|
||||
return iface->mtu - NET_IPV4TCPH_LEN;
|
||||
return net_if_get_mtu(iface) - NET_IPV4TCPH_LEN;
|
||||
}
|
||||
#else
|
||||
return 0;
|
||||
|
@ -591,11 +591,11 @@ u16_t net_tcp_get_recv_mss(const struct net_tcp *tcp)
|
|||
struct net_if *iface = net_context_get_iface(tcp->context);
|
||||
int mss = 0;
|
||||
|
||||
if (iface && iface->mtu >= NET_IPV6TCPH_LEN) {
|
||||
if (iface && net_if_get_mtu(iface) >= NET_IPV6TCPH_LEN) {
|
||||
/* Detect MSS based on interface MTU minus "TCP,IP
|
||||
* header size"
|
||||
*/
|
||||
mss = iface->mtu - NET_IPV6TCPH_LEN;
|
||||
mss = net_if_get_mtu(iface) - NET_IPV6TCPH_LEN;
|
||||
}
|
||||
|
||||
if (mss < NET_IPV6_MTU) {
|
||||
|
|
|
@ -638,7 +638,8 @@ static void check_local_address(struct net_app_ctx *ctx,
|
|||
/* Just take the first IPv4 address of an interface */
|
||||
iface = net_context_get_iface(net_ctx);
|
||||
if (iface) {
|
||||
laddr = &iface->ipv4.unicast[0].address.in_addr;
|
||||
laddr =
|
||||
&iface->config.ip.ipv4.unicast[0].address.in_addr;
|
||||
net_ipaddr_copy(&net_sin(&ctx->ipv4.local)->sin_addr,
|
||||
laddr);
|
||||
} else {
|
||||
|
|
|
@ -50,7 +50,8 @@ static void ipv4_addr_add_handler(struct net_mgmt_event_callback *cb,
|
|||
}
|
||||
|
||||
for (i = 0; i < NET_IF_MAX_IPV4_ADDR; i++) {
|
||||
struct net_if_addr *if_addr = &iface->ipv4.unicast[i];
|
||||
struct net_if_addr *if_addr =
|
||||
&iface->config.ip.ipv4.unicast[i];
|
||||
|
||||
if (if_addr->addr_type != NET_ADDR_DHCP || !if_addr->is_used) {
|
||||
continue;
|
||||
|
@ -60,12 +61,13 @@ static void ipv4_addr_add_handler(struct net_mgmt_event_callback *cb,
|
|||
NET_INFO("IPv4 address: %s",
|
||||
net_addr_ntop(AF_INET, &if_addr->address.in_addr,
|
||||
hr_addr, NET_IPV4_ADDR_LEN));
|
||||
NET_INFO("Lease time: %u seconds", iface->dhcpv4.lease_time);
|
||||
NET_INFO("Lease time: %u seconds",
|
||||
iface->config.dhcpv4.lease_time);
|
||||
NET_INFO("Subnet: %s",
|
||||
net_addr_ntop(AF_INET, &iface->ipv4.netmask,
|
||||
net_addr_ntop(AF_INET, &iface->config.ip.ipv4.netmask,
|
||||
hr_addr, NET_IPV4_ADDR_LEN));
|
||||
NET_INFO("Router: %s",
|
||||
net_addr_ntop(AF_INET, &iface->ipv4.gw,
|
||||
net_addr_ntop(AF_INET, &iface->config.ip.ipv4.gw,
|
||||
hr_addr, NET_IPV4_ADDR_LEN));
|
||||
#endif
|
||||
break;
|
||||
|
@ -176,14 +178,17 @@ static struct in6_addr laddr;
|
|||
static void ipv6_event_handler(struct net_mgmt_event_callback *cb,
|
||||
u32_t mgmt_event, struct net_if *iface)
|
||||
{
|
||||
struct net_if_config *config;
|
||||
int i;
|
||||
|
||||
config = net_if_config_get(iface);
|
||||
|
||||
if (mgmt_event == NET_EVENT_IPV6_ADDR_ADD) {
|
||||
/* save the last added IP address for this interface */
|
||||
for (i = NET_IF_MAX_IPV6_ADDR - 1; i >= 0; i--) {
|
||||
if (iface->ipv6.unicast[i].is_used) {
|
||||
if (config->ip.ipv6.unicast[i].is_used) {
|
||||
memcpy(&laddr,
|
||||
&iface->ipv6.unicast[i].address.in6_addr,
|
||||
&config->ip.ipv6.unicast[i].address.in6_addr,
|
||||
sizeof(laddr));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -310,7 +310,7 @@ int _net_app_set_local_addr(struct sockaddr *addr, const char *myaddr,
|
|||
|
||||
/* For IPv4 we take the first address in the interface */
|
||||
net_ipaddr_copy(&net_sin(addr)->sin_addr,
|
||||
&iface->ipv4.unicast[0].address.in_addr);
|
||||
&iface->config.ip.ipv4.unicast[0].address.in_addr);
|
||||
#else
|
||||
return -EPFNOSUPPORT;
|
||||
#endif
|
||||
|
|
|
@ -109,7 +109,8 @@ static int sender_iface(struct net_if *iface, struct net_pkt *pkt)
|
|||
}
|
||||
|
||||
if (test_started) {
|
||||
struct net_if_test *data = iface->dev->driver_data;
|
||||
struct net_if_test *data =
|
||||
net_if_get_device(iface)->driver_data;
|
||||
|
||||
DBG("Sending at iface %d %p\n", net_if_get_by_iface(iface),
|
||||
iface);
|
||||
|
@ -169,7 +170,7 @@ static void iface_setup(void)
|
|||
|
||||
iface1 = net_if_get_by_index(0);
|
||||
|
||||
((struct net_if_test *)iface1->dev->driver_data)->idx = 0;
|
||||
((struct net_if_test *)net_if_get_device(iface1)->driver_data)->idx = 0;
|
||||
|
||||
idx = net_if_get_by_iface(iface1);
|
||||
zassert_equal(idx, 0, "Invalid index iface1");
|
||||
|
|
|
@ -151,10 +151,13 @@ static inline struct in_addr *if_get_addr(struct net_if *iface)
|
|||
int i;
|
||||
|
||||
for (i = 0; i < NET_IF_MAX_IPV4_ADDR; i++) {
|
||||
if (iface->ipv4.unicast[i].is_used &&
|
||||
iface->ipv4.unicast[i].address.family == AF_INET &&
|
||||
iface->ipv4.unicast[i].addr_state == NET_ADDR_PREFERRED) {
|
||||
return &iface->ipv4.unicast[i].address.in_addr;
|
||||
if (iface->config.ip.ipv4.unicast[i].is_used &&
|
||||
iface->config.ip.ipv4.unicast[i].address.family ==
|
||||
AF_INET &&
|
||||
iface->config.ip.ipv4.unicast[i].addr_state ==
|
||||
NET_ADDR_PREFERRED) {
|
||||
return
|
||||
&iface->config.ip.ipv4.unicast[i].address.in_addr;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -408,11 +411,11 @@ void run_tests(void)
|
|||
}
|
||||
|
||||
if (memcmp(net_pkt_ll(pkt2) + sizeof(struct net_eth_addr),
|
||||
iface->link_addr.addr,
|
||||
net_if_get_link_addr(iface)->addr,
|
||||
sizeof(struct net_eth_addr))) {
|
||||
printk("ARP ETH source address invalid\n");
|
||||
net_hexdump("ETH src correct",
|
||||
iface->link_addr.addr,
|
||||
net_if_get_link_addr(iface)->addr,
|
||||
sizeof(struct net_eth_addr));
|
||||
net_hexdump("ETH src wrong ",
|
||||
net_pkt_ll(pkt2) + sizeof(struct net_eth_addr),
|
||||
|
@ -503,13 +506,14 @@ void run_tests(void)
|
|||
|
||||
arp_hdr = NET_ARP_HDR(pkt2);
|
||||
|
||||
if (!net_ipv4_addr_cmp(&arp_hdr->dst_ipaddr, &iface->ipv4.gw)) {
|
||||
if (!net_ipv4_addr_cmp(&arp_hdr->dst_ipaddr,
|
||||
&iface->config.ip.ipv4.gw)) {
|
||||
char out[sizeof("xxx.xxx.xxx.xxx")];
|
||||
|
||||
snprintk(out, sizeof(out), "%s",
|
||||
net_sprint_ipv4_addr(&arp_hdr->dst_ipaddr));
|
||||
printk("ARP IP dst invalid %s, should be %s\n", out,
|
||||
net_sprint_ipv4_addr(&iface->ipv4.gw));
|
||||
net_sprint_ipv4_addr(&iface->config.ip.ipv4.gw));
|
||||
zassert_true(0, "exiting");
|
||||
}
|
||||
|
||||
|
|
|
@ -269,13 +269,13 @@ struct user_data {
|
|||
static const char *iface2str(struct net_if *iface)
|
||||
{
|
||||
#ifdef CONFIG_NET_L2_ETHERNET
|
||||
if (iface->l2 == &NET_L2_GET_NAME(ETHERNET)) {
|
||||
if (net_if_l2(iface) == &NET_L2_GET_NAME(ETHERNET)) {
|
||||
return "Ethernet";
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_NET_L2_DUMMY
|
||||
if (iface->l2 == &NET_L2_GET_NAME(DUMMY)) {
|
||||
if (net_if_l2(iface) == &NET_L2_GET_NAME(DUMMY)) {
|
||||
return "Dummy";
|
||||
}
|
||||
#endif
|
||||
|
@ -291,7 +291,7 @@ static void iface_cb(struct net_if *iface, void *user_data)
|
|||
DBG("Interface %p (%s) [%d]\n", iface, iface2str(iface),
|
||||
net_if_get_by_iface(iface));
|
||||
|
||||
if (iface->l2 == &NET_L2_GET_NAME(ETHERNET)) {
|
||||
if (net_if_l2(iface) == &NET_L2_GET_NAME(ETHERNET)) {
|
||||
struct eth_context *eth_ctx =
|
||||
net_if_get_device(iface)->driver_data;
|
||||
|
||||
|
|
|
@ -284,7 +284,7 @@ static bool initialize_test_environment(void)
|
|||
|
||||
NET_INFO("Fake IEEE 802.15.4 network interface ready\n");
|
||||
|
||||
ieee_addr_hexdump(iface->link_addr.addr, 8);
|
||||
ieee_addr_hexdump(net_if_get_link_addr(iface)->addr, 8);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
|
|
@ -107,7 +107,8 @@ static int sender_iface(struct net_if *iface, struct net_pkt *pkt)
|
|||
}
|
||||
|
||||
if (test_started) {
|
||||
struct net_if_test *data = iface->dev->driver_data;
|
||||
struct net_if_test *data =
|
||||
net_if_get_device(iface)->driver_data;
|
||||
|
||||
DBG("Sending at iface %d %p\n", net_if_get_by_iface(iface),
|
||||
iface);
|
||||
|
@ -193,9 +194,9 @@ static void iface_setup(void)
|
|||
iface2 = net_if_get_by_index(1);
|
||||
iface3 = net_if_get_by_index(2);
|
||||
|
||||
((struct net_if_test *)iface1->dev->driver_data)->idx = 0;
|
||||
((struct net_if_test *)iface2->dev->driver_data)->idx = 1;
|
||||
((struct net_if_test *)iface3->dev->driver_data)->idx = 2;
|
||||
((struct net_if_test *)net_if_get_device(iface1)->driver_data)->idx = 0;
|
||||
((struct net_if_test *)net_if_get_device(iface2)->driver_data)->idx = 1;
|
||||
((struct net_if_test *)net_if_get_device(iface3)->driver_data)->idx = 2;
|
||||
|
||||
idx = net_if_get_by_iface(iface1);
|
||||
zassert_equal(idx, 0, "Invalid index iface1");
|
||||
|
|
|
@ -258,11 +258,11 @@ static bool test_init(void)
|
|||
* pass.
|
||||
*/
|
||||
for (i = 0; i < NET_IF_MAX_IPV6_ADDR; i++) {
|
||||
if (iface->ipv6.unicast[i].is_used) {
|
||||
if (iface->config.ip.ipv6.unicast[i].is_used) {
|
||||
continue;
|
||||
}
|
||||
|
||||
ifaddr = &iface->ipv6.unicast[i];
|
||||
ifaddr = &iface->config.ip.ipv6.unicast[i];
|
||||
|
||||
ifaddr->is_used = true;
|
||||
ifaddr->address.family = AF_INET6;
|
||||
|
|
|
@ -329,7 +329,8 @@ static int sender_iface(struct net_if *iface, struct net_pkt *pkt)
|
|||
}
|
||||
|
||||
if (test_started) {
|
||||
struct net_if_test *data = iface->dev->driver_data;
|
||||
struct net_if_test *data =
|
||||
net_if_get_device(iface)->driver_data;
|
||||
|
||||
DBG("Sending at iface %d %p\n", net_if_get_by_iface(iface),
|
||||
iface);
|
||||
|
@ -452,8 +453,8 @@ static void setup(void)
|
|||
iface1 = net_if_get_by_index(0);
|
||||
iface2 = net_if_get_by_index(1);
|
||||
|
||||
((struct net_if_test *)iface1->dev->driver_data)->idx = 0;
|
||||
((struct net_if_test *)iface2->dev->driver_data)->idx = 1;
|
||||
((struct net_if_test *)net_if_get_device(iface1)->driver_data)->idx = 0;
|
||||
((struct net_if_test *)net_if_get_device(iface2)->driver_data)->idx = 1;
|
||||
|
||||
idx = net_if_get_by_iface(iface1);
|
||||
zassert_equal(idx, 0, "Invalid index iface1");
|
||||
|
|
|
@ -127,7 +127,8 @@ static int sender_iface(struct net_if *iface, struct net_pkt *pkt)
|
|||
}
|
||||
|
||||
if (!timeout_query) {
|
||||
struct net_if_test *data = iface->dev->driver_data;
|
||||
struct net_if_test *data =
|
||||
net_if_get_device(iface)->driver_data;
|
||||
struct dns_resolve_context *ctx;
|
||||
int slot;
|
||||
|
||||
|
@ -211,7 +212,7 @@ static void test_init(void)
|
|||
|
||||
iface1 = net_if_get_by_index(0);
|
||||
|
||||
((struct net_if_test *)iface1->dev->driver_data)->idx = 0;
|
||||
((struct net_if_test *)net_if_get_device(iface1)->driver_data)->idx = 0;
|
||||
|
||||
#if defined(CONFIG_NET_IPV6)
|
||||
ifaddr = net_if_ipv6_addr_add(iface1, &my_addr1,
|
||||
|
|
|
@ -129,7 +129,7 @@ static int tester_send(struct net_if *iface, struct net_pkt *pkt)
|
|||
return -ENODATA;
|
||||
}
|
||||
|
||||
set_pkt_ll_addr(iface->dev, pkt);
|
||||
set_pkt_ll_addr(net_if_get_device(iface), pkt);
|
||||
|
||||
/* By default we assume that the test is ok */
|
||||
data_failure = false;
|
||||
|
@ -300,7 +300,7 @@ static void test_dio_dummy_input(void)
|
|||
|
||||
msg_sending = NET_RPL_DODAG_INFO_OBJ;
|
||||
|
||||
set_pkt_ll_addr(net_if_get_default()->dev, pkt);
|
||||
set_pkt_ll_addr(net_if_get_device(net_if_get_default()), pkt);
|
||||
|
||||
ret = net_icmpv6_input(pkt, NET_ICMPV6_RPL, msg_sending);
|
||||
if (!ret) {
|
||||
|
@ -393,7 +393,7 @@ static bool net_test_send_ns(void)
|
|||
*/
|
||||
nbr = net_ipv6_nbr_add(iface,
|
||||
&in6addr_my,
|
||||
&iface->link_addr,
|
||||
net_if_get_link_addr(iface),
|
||||
false,
|
||||
NET_IPV6_NBR_STATE_REACHABLE);
|
||||
if (!nbr) {
|
||||
|
|
|
@ -196,10 +196,13 @@ static inline struct in_addr *if_get_addr(struct net_if *iface)
|
|||
int i;
|
||||
|
||||
for (i = 0; i < NET_IF_MAX_IPV4_ADDR; i++) {
|
||||
if (iface->ipv4.unicast[i].is_used &&
|
||||
iface->ipv4.unicast[i].address.family == AF_INET &&
|
||||
iface->ipv4.unicast[i].addr_state == NET_ADDR_PREFERRED) {
|
||||
return &iface->ipv4.unicast[i].address.in_addr;
|
||||
if (iface->config.ip.ipv4.unicast[i].is_used &&
|
||||
iface->config.ip.ipv4.unicast[i].address.family ==
|
||||
AF_INET &&
|
||||
iface->config.ip.ipv4.unicast[i].addr_state ==
|
||||
NET_ADDR_PREFERRED) {
|
||||
return
|
||||
&iface->config.ip.ipv4.unicast[i].address.in_addr;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -106,10 +106,13 @@ static inline struct in_addr *if_get_addr(struct net_if *iface)
|
|||
int i;
|
||||
|
||||
for (i = 0; i < NET_IF_MAX_IPV4_ADDR; i++) {
|
||||
if (iface->ipv4.unicast[i].is_used &&
|
||||
iface->ipv4.unicast[i].address.family == AF_INET &&
|
||||
iface->ipv4.unicast[i].addr_state == NET_ADDR_PREFERRED) {
|
||||
return &iface->ipv4.unicast[i].address.in_addr;
|
||||
if (iface->config.ip.ipv4.unicast[i].is_used &&
|
||||
iface->config.ip.ipv4.unicast[i].address.family ==
|
||||
AF_INET &&
|
||||
iface->config.ip.ipv4.unicast[i].addr_state ==
|
||||
NET_ADDR_PREFERRED) {
|
||||
return
|
||||
&iface->config.ip.ipv4.unicast[i].address.in_addr;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue