Zephyr API Documentation  2.7.0-rc2
A Scalable Open Source RTOS
net_if.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2016 Intel Corporation.
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
12#ifndef ZEPHYR_INCLUDE_NET_NET_IF_H_
13#define ZEPHYR_INCLUDE_NET_NET_IF_H_
14
22#include <device.h>
23#include <sys/slist.h>
24
25#include <net/net_core.h>
26#include <net/hostname.h>
27#include <net/net_linkaddr.h>
28#include <net/net_ip.h>
29#include <net/net_l2.h>
30#include <net/net_stats.h>
31#include <net/net_timeout.h>
32
33#if defined(CONFIG_NET_DHCPV4) && defined(CONFIG_NET_NATIVE_IPV4)
34#include <net/dhcpv4.h>
35#endif
36#if defined(CONFIG_NET_IPV4_AUTO) && defined(CONFIG_NET_NATIVE_IPV4)
37#include <net/ipv4_autoconf.h>
38#endif
39
40#ifdef __cplusplus
41extern "C" {
42#endif
43
51 struct net_addr address;
52
53#if defined(CONFIG_NET_NATIVE_IPV6)
54 struct net_timeout lifetime;
55#endif
56
57#if defined(CONFIG_NET_IPV6_DAD) && defined(CONFIG_NET_NATIVE_IPV6)
59 sys_snode_t dad_node;
60 uint32_t dad_start;
61#endif
64
67
68#if defined(CONFIG_NET_IPV6_DAD) && defined(CONFIG_NET_NATIVE_IPV6)
70 uint8_t dad_count;
71#endif
72
75
78
81
82 uint8_t _unused : 5;
83};
84
92 struct net_addr address;
93
96
99
100 uint8_t _unused : 6;
101};
102
111
114
116 struct net_if *iface;
117
120
123
126
127 uint8_t _unused : 6;
128};
129
138
140 struct net_addr address;
141
143 struct net_if *iface;
144
147
150
153
156
159
160 uint8_t _unused : 5;
161};
162
166
169
172
180
183
189
192
195
197 /* Total number of flags - must be at the end of the enum */
198 NET_IF_NUM_FLAGS
200};
201
202#if defined(CONFIG_NET_OFFLOAD)
203struct net_offload;
204#endif /* CONFIG_NET_OFFLOAD */
205
207#if defined(CONFIG_NET_NATIVE_IPV6)
208#define NET_IF_MAX_IPV6_ADDR CONFIG_NET_IF_UNICAST_IPV6_ADDR_COUNT
209#define NET_IF_MAX_IPV6_MADDR CONFIG_NET_IF_MCAST_IPV6_ADDR_COUNT
210#define NET_IF_MAX_IPV6_PREFIX CONFIG_NET_IF_IPV6_PREFIX_COUNT
211#else
212#define NET_IF_MAX_IPV6_ADDR 0
213#define NET_IF_MAX_IPV6_MADDR 0
214#define NET_IF_MAX_IPV6_PREFIX 0
215#endif
216/* @endcond */
217
220 struct net_if_addr unicast[NET_IF_MAX_IPV6_ADDR];
221
223 struct net_if_mcast_addr mcast[NET_IF_MAX_IPV6_MADDR];
224
226 struct net_if_ipv6_prefix prefix[NET_IF_MAX_IPV6_PREFIX];
227
230
233
236#if defined(CONFIG_NET_IPV6_ND) && defined(CONFIG_NET_NATIVE_IPV6)
238 sys_snode_t rs_node;
239
240 /* RS start time */
241 uint32_t rs_start;
242
244 uint8_t rs_count;
245#endif
246
249};
250
252#if defined(CONFIG_NET_NATIVE_IPV4)
253#define NET_IF_MAX_IPV4_ADDR CONFIG_NET_IF_UNICAST_IPV4_ADDR_COUNT
254#define NET_IF_MAX_IPV4_MADDR CONFIG_NET_IF_MCAST_IPV4_ADDR_COUNT
255#else
256#define NET_IF_MAX_IPV4_ADDR 0
257#define NET_IF_MAX_IPV4_MADDR 0
258#endif
263 struct net_if_addr unicast[NET_IF_MAX_IPV4_ADDR];
264
266 struct net_if_mcast_addr mcast[NET_IF_MAX_IPV4_MADDR];
267
269 struct in_addr gw;
270
273
276};
277
278#if defined(CONFIG_NET_DHCPV4) && defined(CONFIG_NET_NATIVE_IPV4)
279struct net_if_dhcpv4 {
281 sys_snode_t node;
282
284 int64_t timer_start;
285
287 uint32_t request_time;
288
289 uint32_t xid;
290
292 uint32_t lease_time;
293
295 uint32_t renewal_time;
296
298 uint32_t rebinding_time;
299
301 struct in_addr server_id;
302
304 struct in_addr requested_ip;
305
310 enum net_dhcpv4_state state;
311
313 uint8_t attempts;
314};
315#endif /* CONFIG_NET_DHCPV4 */
316
317#if defined(CONFIG_NET_IPV4_AUTO) && defined(CONFIG_NET_NATIVE_IPV4)
318struct net_if_ipv4_autoconf {
320 sys_snode_t node;
321
323 struct net_if *iface;
324
326 int64_t timer_start;
327
329 uint32_t timer_timeout;
330
332 struct in_addr current_ip;
333
335 struct in_addr requested_ip;
336
340
342 uint8_t probe_cnt;
343
345 uint8_t announce_cnt;
346
348 uint8_t conflict_cnt;
349};
350#endif /* CONFIG_NET_IPV4_AUTO */
351
353/* We always need to have at least one IP config */
354#define NET_IF_MAX_CONFIGS 1
360struct net_if_ip {
361#if defined(CONFIG_NET_NATIVE_IPV6)
362 struct net_if_ipv6 *ipv6;
363#endif /* CONFIG_NET_IPV6 */
364
365#if defined(CONFIG_NET_NATIVE_IPV4)
366 struct net_if_ipv4 *ipv4;
367#endif /* CONFIG_NET_IPV4 */
368};
369
375 struct net_if_ip ip;
376
377#if defined(CONFIG_NET_DHCPV4) && defined(CONFIG_NET_NATIVE_IPV4)
378 struct net_if_dhcpv4 dhcpv4;
379#endif /* CONFIG_NET_DHCPV4 */
380
381#if defined(CONFIG_NET_IPV4_AUTO) && defined(CONFIG_NET_NATIVE_IPV4)
382 struct net_if_ipv4_autoconf ipv4auto;
383#endif /* CONFIG_NET_IPV4_AUTO */
384
385#if defined(CONFIG_NET_L2_VIRTUAL)
390 sys_slist_t virtual_interfaces;
391#endif /* CONFIG_NET_L2_VIRTUAL */
392};
393
405 struct k_fifo fifo;
406
409
412};
413
429 const struct device *dev;
430
432 const struct net_l2 * const l2;
433
435 void *l2_data;
436
437 /* For internal use */
438 ATOMIC_DEFINE(flags, NET_IF_NUM_FLAGS);
439
442
443#if defined(CONFIG_NET_OFFLOAD)
449 struct net_offload *offload;
450#endif /* CONFIG_NET_OFFLOAD */
451
454
455#if defined(CONFIG_NET_SOCKETS_OFFLOAD)
457 bool offloaded;
458#endif /* CONFIG_NET_SOCKETS_OFFLOAD */
459};
460
468struct net_if {
471
472#if defined(CONFIG_NET_STATISTICS_PER_INTERFACE)
474 struct net_stats stats;
475#endif /* CONFIG_NET_STATISTICS_PER_INTERFACE */
476
479
480#if defined(CONFIG_NET_POWER_MANAGEMENT)
485 int tx_pending;
486#endif
487};
488
495static inline void net_if_flag_set(struct net_if *iface,
496 enum net_if_flag value)
497{
498 NET_ASSERT(iface);
499
500 atomic_set_bit(iface->if_dev->flags, value);
501}
502
511static inline bool net_if_flag_test_and_set(struct net_if *iface,
512 enum net_if_flag value)
513{
514 NET_ASSERT(iface);
515
516 return atomic_test_and_set_bit(iface->if_dev->flags, value);
517}
518
525static inline void net_if_flag_clear(struct net_if *iface,
526 enum net_if_flag value)
527{
528 NET_ASSERT(iface);
529
530 atomic_clear_bit(iface->if_dev->flags, value);
531}
532
541static inline bool net_if_flag_is_set(struct net_if *iface,
542 enum net_if_flag value)
543{
544 if (iface == NULL) {
545 return false;
546 }
547
548 return atomic_test_bit(iface->if_dev->flags, value);
549}
550
559enum net_verdict net_if_send_data(struct net_if *iface, struct net_pkt *pkt);
560
568static inline const struct net_l2 * const net_if_l2(struct net_if *iface)
569{
570 if (!iface || !iface->if_dev) {
571 return NULL;
572 }
573
574 return iface->if_dev->l2;
575}
576
585enum net_verdict net_if_recv_data(struct net_if *iface, struct net_pkt *pkt);
586
594static inline void *net_if_l2_data(struct net_if *iface)
595{
596 return iface->if_dev->l2_data;
597}
598
606static inline const struct device *net_if_get_device(struct net_if *iface)
607{
608 return iface->if_dev->dev;
609}
610
617void net_if_queue_tx(struct net_if *iface, struct net_pkt *pkt);
618
626static inline bool net_if_is_ip_offloaded(struct net_if *iface)
627{
628#if defined(CONFIG_NET_OFFLOAD)
629 return (iface->if_dev->offload != NULL);
630#else
631 ARG_UNUSED(iface);
632
633 return false;
634#endif
635}
636
644static inline struct net_offload *net_if_offload(struct net_if *iface)
645{
646#if defined(CONFIG_NET_OFFLOAD)
647 return iface->if_dev->offload;
648#else
649 ARG_UNUSED(iface);
650
651 return NULL;
652#endif
653}
654
662static inline bool net_if_is_socket_offloaded(struct net_if *iface)
663{
664#if defined(CONFIG_NET_SOCKETS_OFFLOAD)
665 return iface->if_dev->offloaded;
666#else
667 ARG_UNUSED(iface);
668
669 return false;
670#endif
671}
672
680static inline struct net_linkaddr *net_if_get_link_addr(struct net_if *iface)
681{
682 return &iface->if_dev->link_addr;
683}
684
692static inline struct net_if_config *net_if_get_config(struct net_if *iface)
693{
694 return &iface->config;
695}
696
702#if defined(CONFIG_NET_IPV6_DAD) && defined(CONFIG_NET_NATIVE_IPV6)
703void net_if_start_dad(struct net_if *iface);
704#else
705static inline void net_if_start_dad(struct net_if *iface)
706{
707 ARG_UNUSED(iface);
708}
709#endif
710
716void net_if_start_rs(struct net_if *iface);
717
718
724#if defined(CONFIG_NET_IPV6_ND) && defined(CONFIG_NET_NATIVE_IPV6)
725void net_if_stop_rs(struct net_if *iface);
726#else
727static inline void net_if_stop_rs(struct net_if *iface)
728{
729 ARG_UNUSED(iface);
730}
731#endif /* CONFIG_NET_IPV6_ND */
732
735static inline int net_if_set_link_addr_unlocked(struct net_if *iface,
736 uint8_t *addr, uint8_t len,
737 enum net_link_type type)
738{
739 if (net_if_flag_is_set(iface, NET_IF_UP)) {
740 return -EPERM;
741 }
742
743 net_if_get_link_addr(iface)->addr = addr;
744 net_if_get_link_addr(iface)->len = len;
745 net_if_get_link_addr(iface)->type = type;
746
747 net_hostname_set_postfix(addr, len);
748
749 return 0;
750}
751
752int net_if_set_link_addr_locked(struct net_if *iface,
753 uint8_t *addr, uint8_t len,
754 enum net_link_type type);
768static inline int net_if_set_link_addr(struct net_if *iface,
769 uint8_t *addr, uint8_t len,
770 enum net_link_type type)
771{
772#if defined(CONFIG_NET_RAW_MODE)
773 return net_if_set_link_addr_unlocked(iface, addr, len, type);
774#else
775 return net_if_set_link_addr_locked(iface, addr, len, type);
776#endif
777}
778
786static inline uint16_t net_if_get_mtu(struct net_if *iface)
787{
788 if (iface == NULL) {
789 return 0U;
790 }
791
792 return iface->if_dev->mtu;
793}
794
801static inline void net_if_set_mtu(struct net_if *iface,
802 uint16_t mtu)
803{
804 if (iface == NULL) {
805 return;
806 }
807
808 iface->if_dev->mtu = mtu;
809}
810
817static inline void net_if_addr_set_lf(struct net_if_addr *ifaddr,
818 bool is_infinite)
819{
820 ifaddr->is_infinite = is_infinite;
821}
822
831
839struct net_if *net_if_lookup_by_dev(const struct device *dev);
840
848static inline struct net_if_config *net_if_config_get(struct net_if *iface)
849{
850 return &iface->config;
851}
852
858void net_if_router_rm(struct net_if_router *router);
859
866
875struct net_if *net_if_get_first_by_type(const struct net_l2 *l2);
876
877#if defined(CONFIG_NET_L2_IEEE802154)
884static inline struct net_if *net_if_get_ieee802154(void)
885{
886 return net_if_get_first_by_type(&NET_L2_GET_NAME(IEEE802154));
887}
888#endif /* CONFIG_NET_L2_IEEE802154 */
889
901 struct net_if_ipv6 **ipv6);
902
911
921 struct net_if **iface);
922
932 struct in6_addr *addr);
933
942__syscall int net_if_ipv6_addr_lookup_by_index(const struct in6_addr *addr);
943
955 struct in6_addr *addr,
957 uint32_t vlifetime);
958
970 struct in6_addr *addr,
972 uint32_t vlifetime);
973
981 uint32_t vlifetime);
982
991bool net_if_ipv6_addr_rm(struct net_if *iface, const struct in6_addr *addr);
992
1002 const struct in6_addr *addr);
1003
1013 const struct in6_addr *addr);
1014
1023bool net_if_ipv6_maddr_rm(struct net_if *iface, const struct in6_addr *addr);
1024
1036 struct net_if **iface);
1037
1049typedef void (*net_if_mcast_callback_t)(struct net_if *iface,
1050 const struct in6_addr *addr,
1051 bool is_joined);
1052
1064
1066 struct net_if *iface;
1067
1070};
1071
1081 struct net_if *iface,
1083
1090
1098void net_if_mcast_monitor(struct net_if *iface, const struct in6_addr *addr,
1099 bool is_joined);
1100
1107
1115static inline bool net_if_ipv6_maddr_is_joined(struct net_if_mcast_addr *addr)
1116{
1117 NET_ASSERT(addr);
1118
1119 return addr->is_joined;
1120}
1121
1128
1138 struct in6_addr *addr);
1139
1150 struct in6_addr *addr,
1151 uint8_t len);
1152
1164 struct in6_addr *prefix,
1165 uint8_t len,
1167
1177bool net_if_ipv6_prefix_rm(struct net_if *iface, struct in6_addr *addr,
1178 uint8_t len);
1179
1187 bool is_infinite)
1188{
1189 prefix->is_infinite = is_infinite;
1190}
1191
1200
1207
1218bool net_if_ipv6_addr_onlink(struct net_if **iface, struct in6_addr *addr);
1219
1226#if defined(CONFIG_NET_NATIVE_IPV6)
1227static inline struct in6_addr *net_if_router_ipv6(struct net_if_router *router)
1228{
1229 return &router->address.in6_addr;
1230}
1231#else
1232static inline struct in6_addr *net_if_router_ipv6(struct net_if_router *router)
1233{
1234 static struct in6_addr addr;
1235
1236 ARG_UNUSED(router);
1237
1238 return &addr;
1239}
1240#endif
1241
1252 struct in6_addr *addr);
1253
1264 struct in6_addr *addr);
1265
1274
1285 struct in6_addr *addr,
1286 uint16_t router_lifetime);
1287
1296
1306
1314
1322 uint32_t reachable_time)
1323{
1324#if defined(CONFIG_NET_NATIVE_IPV6)
1325 if (!iface->config.ip.ipv6) {
1326 return;
1327 }
1328
1329 iface->config.ip.ipv6->base_reachable_time = reachable_time;
1330#endif
1331}
1332
1341{
1342#if defined(CONFIG_NET_NATIVE_IPV6)
1343 if (!iface->config.ip.ipv6) {
1344 return 0;
1345 }
1346
1347 return iface->config.ip.ipv6->reachable_time;
1348#else
1349 return 0;
1350#endif
1351}
1352
1361
1368static inline void net_if_ipv6_set_reachable_time(struct net_if_ipv6 *ipv6)
1369{
1370#if defined(CONFIG_NET_NATIVE_IPV6)
1372#endif
1373}
1374
1381static inline void net_if_ipv6_set_retrans_timer(struct net_if *iface,
1382 uint32_t retrans_timer)
1383{
1384#if defined(CONFIG_NET_NATIVE_IPV6)
1385 if (!iface->config.ip.ipv6) {
1386 return;
1387 }
1388
1389 iface->config.ip.ipv6->retrans_timer = retrans_timer;
1390#endif
1391}
1392
1401{
1402#if defined(CONFIG_NET_NATIVE_IPV6)
1403 if (!iface->config.ip.ipv6) {
1404 return 0;
1405 }
1406
1407 return iface->config.ip.ipv6->retrans_timer;
1408#else
1409 return 0;
1410#endif
1411}
1412
1424#if defined(CONFIG_NET_NATIVE_IPV6)
1425const struct in6_addr *net_if_ipv6_select_src_addr(struct net_if *iface,
1426 const struct in6_addr *dst);
1427#else
1428static inline const struct in6_addr *net_if_ipv6_select_src_addr(
1429 struct net_if *iface, const struct in6_addr *dst)
1430{
1431 ARG_UNUSED(iface);
1432 ARG_UNUSED(dst);
1433
1434 return NULL;
1435}
1436#endif
1437
1447#if defined(CONFIG_NET_NATIVE_IPV6)
1448struct net_if *net_if_ipv6_select_src_iface(const struct in6_addr *dst);
1449#else
1451 const struct in6_addr *dst)
1452{
1453 ARG_UNUSED(dst);
1454
1455 return NULL;
1456}
1457#endif
1458
1468struct in6_addr *net_if_ipv6_get_ll(struct net_if *iface,
1469 enum net_addr_state addr_state);
1470
1481 struct net_if **iface);
1482
1490void net_if_ipv6_dad_failed(struct net_if *iface, const struct in6_addr *addr);
1491
1504 struct net_if **iface);
1505
1517 struct net_if_ipv4 **ipv4);
1518
1527
1536
1543void net_if_ipv4_set_ttl(struct net_if *iface, uint8_t ttl);
1544
1554 struct net_if **iface);
1555
1567 struct in_addr *addr,
1569 uint32_t vlifetime);
1570
1579bool net_if_ipv4_addr_rm(struct net_if *iface, const struct in_addr *addr);
1580
1589__syscall int net_if_ipv4_addr_lookup_by_index(const struct in_addr *addr);
1590
1602 struct in_addr *addr,
1604 uint32_t vlifetime);
1605
1615 const struct in_addr *addr);
1616
1626 const struct in_addr *addr);
1627
1636bool net_if_ipv4_maddr_rm(struct net_if *iface, const struct in_addr *addr);
1637
1649 struct net_if **iface);
1650
1657
1665static inline bool net_if_ipv4_maddr_is_joined(struct net_if_mcast_addr *addr)
1666{
1667 NET_ASSERT(addr);
1668
1669 return addr->is_joined;
1670}
1671
1678
1685#if defined(CONFIG_NET_NATIVE_IPV4)
1686static inline struct in_addr *net_if_router_ipv4(struct net_if_router *router)
1687{
1688 return &router->address.in_addr;
1689}
1690#else
1691static inline struct in_addr *net_if_router_ipv4(struct net_if_router *router)
1692{
1693 static struct in_addr addr;
1694
1695 ARG_UNUSED(router);
1696
1697 return &addr;
1698}
1699#endif
1700
1711 struct in_addr *addr);
1712
1723 struct in_addr *addr);
1735 struct in_addr *addr,
1736 bool is_default,
1737 uint16_t router_lifetime);
1738
1747
1757 const struct in_addr *addr);
1758
1768 const struct in_addr *addr);
1769
1779#if defined(CONFIG_NET_NATIVE_IPV4)
1780struct net_if *net_if_ipv4_select_src_iface(const struct in_addr *dst);
1781#else
1783 const struct in_addr *dst)
1784{
1785 ARG_UNUSED(dst);
1786
1787 return NULL;
1788}
1789#endif
1790
1802#if defined(CONFIG_NET_NATIVE_IPV4)
1803const struct in_addr *net_if_ipv4_select_src_addr(struct net_if *iface,
1804 const struct in_addr *dst);
1805#else
1806static inline const struct in_addr *net_if_ipv4_select_src_addr(
1807 struct net_if *iface, const struct in_addr *dst)
1808{
1809 ARG_UNUSED(iface);
1810 ARG_UNUSED(dst);
1811
1812 return NULL;
1813}
1814#endif
1815
1825struct in_addr *net_if_ipv4_get_ll(struct net_if *iface,
1826 enum net_addr_state addr_state);
1827
1838 enum net_addr_state addr_state);
1839
1847 const struct in_addr *netmask);
1848
1858 const struct in_addr *netmask);
1859
1866void net_if_ipv4_set_gw(struct net_if *iface, const struct in_addr *gw);
1867
1876__syscall bool net_if_ipv4_set_gw_by_index(int index, const struct in_addr *gw);
1877
1888struct net_if *net_if_select_src_iface(const struct sockaddr *dst);
1889
1898typedef void (*net_if_link_callback_t)(struct net_if *iface,
1899 struct net_linkaddr *dst,
1900 int status);
1901
1913
1916};
1917
1926
1933
1941void net_if_call_link_cb(struct net_if *iface, struct net_linkaddr *lladdr,
1942 int status);
1943
1954
1966
1977__syscall struct net_if *net_if_get_by_index(int index);
1978
1986int net_if_get_by_iface(struct net_if *iface);
1987
1995typedef void (*net_if_cb_t)(struct net_if *iface, void *user_data);
1996
2005
2013int net_if_up(struct net_if *iface);
2014
2022static inline bool net_if_is_up(struct net_if *iface)
2023{
2024 NET_ASSERT(iface);
2025
2026 return net_if_flag_is_set(iface, NET_IF_UP);
2027}
2028
2036int net_if_down(struct net_if *iface);
2037
2038#if defined(CONFIG_NET_PKT_TIMESTAMP) && defined(CONFIG_NET_NATIVE)
2046typedef void (*net_if_timestamp_callback_t)(struct net_pkt *pkt);
2047
2056struct net_if_timestamp_cb {
2058 sys_snode_t node;
2059
2063 struct net_pkt *pkt;
2064
2068 struct net_if *iface;
2069
2071 net_if_timestamp_callback_t cb;
2072};
2073
2084void net_if_register_timestamp_cb(struct net_if_timestamp_cb *handle,
2085 struct net_pkt *pkt,
2086 struct net_if *iface,
2087 net_if_timestamp_callback_t cb);
2088
2094void net_if_unregister_timestamp_cb(struct net_if_timestamp_cb *handle);
2095
2101void net_if_call_timestamp_cb(struct net_pkt *pkt);
2102
2103/*
2104 * @brief Add timestamped TX buffer to be handled
2105 *
2106 * @param pkt Timestamped buffer
2107 */
2108void net_if_add_tx_timestamp(struct net_pkt *pkt);
2109#endif /* CONFIG_NET_PKT_TIMESTAMP */
2110
2120int net_if_set_promisc(struct net_if *iface);
2121
2127void net_if_unset_promisc(struct net_if *iface);
2128
2137bool net_if_is_promisc(struct net_if *iface);
2138
2148static inline bool net_if_are_pending_tx_packets(struct net_if *iface)
2149{
2150#if defined(CONFIG_NET_POWER_MANAGEMENT)
2151 return !!iface->tx_pending;
2152#else
2153 ARG_UNUSED(iface);
2154
2155 return false;
2156#endif
2157}
2158
2159#ifdef CONFIG_NET_POWER_MANAGEMENT
2167int net_if_suspend(struct net_if *iface);
2168
2176int net_if_resume(struct net_if *iface);
2177
2185bool net_if_is_suspended(struct net_if *iface);
2186#endif /* CONFIG_NET_POWER_MANAGEMENT */
2187
2189struct net_if_api {
2190 void (*init)(struct net_if *iface);
2191};
2192
2193#if defined(CONFIG_NET_DHCPV4) && defined(CONFIG_NET_NATIVE_IPV4)
2194#define NET_IF_DHCPV4_INIT .dhcpv4.state = NET_DHCPV4_DISABLED,
2195#else
2196#define NET_IF_DHCPV4_INIT
2197#endif
2198
2199#define NET_IF_CONFIG_INIT \
2200 .config = { \
2201 .ip = { \
2202 }, \
2203 NET_IF_DHCPV4_INIT \
2204 }
2205
2206#define NET_IF_GET_NAME(dev_name, sfx) __net_if_##dev_name##_##sfx
2207#define NET_IF_DEV_GET_NAME(dev_name, sfx) __net_if_dev_##dev_name##_##sfx
2208
2209#define NET_IF_GET(dev_name, sfx) \
2210 ((struct net_if *)&NET_IF_GET_NAME(dev_name, sfx))
2211
2212#define NET_IF_INIT(dev_name, sfx, _l2, _mtu, _num_configs) \
2213 static STRUCT_SECTION_ITERABLE(net_if_dev, \
2214 NET_IF_DEV_GET_NAME(dev_name, sfx)) = { \
2215 .dev = &(DEVICE_NAME_GET(dev_name)), \
2216 .l2 = &(NET_L2_GET_NAME(_l2)), \
2217 .l2_data = &(NET_L2_GET_DATA(dev_name, sfx)), \
2218 .mtu = _mtu, \
2219 }; \
2220 static Z_DECL_ALIGN(struct net_if) \
2221 NET_IF_GET_NAME(dev_name, sfx)[_num_configs] \
2222 __used __in_section(_net_if, static, \
2223 dev_name) = { \
2224 [0 ... (_num_configs - 1)] = { \
2225 .if_dev = &(NET_IF_DEV_GET_NAME(dev_name, sfx)), \
2226 NET_IF_CONFIG_INIT \
2227 } \
2228 }
2229
2230#define NET_IF_OFFLOAD_INIT(dev_name, sfx, _mtu) \
2231 static STRUCT_SECTION_ITERABLE(net_if_dev, \
2232 NET_IF_DEV_GET_NAME(dev_name, sfx)) = { \
2233 .dev = &(DEVICE_NAME_GET(dev_name)), \
2234 .mtu = _mtu, \
2235 }; \
2236 static Z_DECL_ALIGN(struct net_if) \
2237 NET_IF_GET_NAME(dev_name, sfx)[NET_IF_MAX_CONFIGS] \
2238 __used __in_section(_net_if, static, \
2239 dev_name) = { \
2240 [0 ... (NET_IF_MAX_CONFIGS - 1)] = { \
2241 .if_dev = &(NET_IF_DEV_GET_NAME(dev_name, sfx)), \
2242 NET_IF_CONFIG_INIT \
2243 } \
2244 }
2245
2248/* Network device initialization macros */
2249
2250#define Z_NET_DEVICE_INIT(node_id, dev_name, drv_name, init_fn, \
2251 pm_control_fn, data, cfg, prio, api, l2, \
2252 l2_ctx_type, mtu) \
2253 Z_DEVICE_DEFINE(node_id, dev_name, drv_name, init_fn, \
2254 pm_control_fn, data, \
2255 cfg, POST_KERNEL, prio, api); \
2256 NET_L2_DATA_INIT(dev_name, 0, l2_ctx_type); \
2257 NET_IF_INIT(dev_name, 0, l2, mtu, NET_IF_MAX_CONFIGS)
2258
2280#define NET_DEVICE_INIT(dev_name, drv_name, init_fn, pm_control_fn, \
2281 data, cfg, prio, api, l2, \
2282 l2_ctx_type, mtu) \
2283 Z_NET_DEVICE_INIT(DT_INVALID_NODE, dev_name, drv_name, init_fn, \
2284 pm_control_fn, data, cfg, prio, api, l2, \
2285 l2_ctx_type, mtu)
2286
2307#define NET_DEVICE_DT_DEFINE(node_id, init_fn, pm_control_fn, data, cfg, \
2308 prio, api, l2, l2_ctx_type, mtu) \
2309 Z_NET_DEVICE_INIT(node_id, Z_DEVICE_DT_DEV_NAME(node_id), \
2310 DT_PROP_OR(node_id, label, ""), init_fn, \
2311 pm_control_fn, data, cfg, prio, api, l2, \
2312 l2_ctx_type, mtu)
2313
2324#define NET_DEVICE_DT_INST_DEFINE(inst, ...) \
2325 NET_DEVICE_DT_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
2326
2327#define Z_NET_DEVICE_INIT_INSTANCE(node_id, dev_name, drv_name, \
2328 instance, init_fn, pm_control_fn, \
2329 data, cfg, prio, api, l2, \
2330 l2_ctx_type, mtu) \
2331 Z_DEVICE_DEFINE(node_id, dev_name, drv_name, init_fn, \
2332 pm_control_fn, data, cfg, POST_KERNEL, \
2333 prio, api); \
2334 NET_L2_DATA_INIT(dev_name, instance, l2_ctx_type); \
2335 NET_IF_INIT(dev_name, instance, l2, mtu, NET_IF_MAX_CONFIGS)
2336
2362#define NET_DEVICE_INIT_INSTANCE(dev_name, drv_name, instance, init_fn, \
2363 pm_control_fn, data, cfg, prio, \
2364 api, l2, l2_ctx_type, mtu) \
2365 Z_NET_DEVICE_INIT_INSTANCE(DT_INVALID_NODE, dev_name, drv_name, \
2366 instance, init_fn, pm_control_fn, \
2367 data, cfg, prio, api, l2, \
2368 l2_ctx_type, mtu)
2369
2394#define NET_DEVICE_DT_DEFINE_INSTANCE(node_id, instance, init_fn, \
2395 pm_control_fn, data, cfg, prio, \
2396 api, l2, l2_ctx_type, mtu) \
2397 Z_NET_DEVICE_INIT_INSTANCE(node_id, node_id, DT_LABEL(node_id), \
2398 instance, init_fn, pm_control_fn, \
2399 data, cfg, prio, api, l2, \
2400 l2_ctx_type, mtu)
2401
2413#define NET_DEVICE_DT_INST_DEFINE_INSTANCE(inst, ...) \
2414 NET_DEVICE_DT_DEFINE_INSTANCE(DT_DRV_INST(inst), __VA_ARGS__)
2415
2416#define Z_NET_DEVICE_OFFLOAD_INIT(node_id, dev_name, drv_name, init_fn, \
2417 pm_control_fn, data, cfg, prio, \
2418 api, mtu) \
2419 Z_DEVICE_DEFINE(node_id, dev_name, drv_name, init_fn, \
2420 pm_control_fn, data, cfg, POST_KERNEL, prio, api);\
2421 NET_IF_OFFLOAD_INIT(dev_name, 0, mtu)
2422
2444#define NET_DEVICE_OFFLOAD_INIT(dev_name, drv_name, init_fn, \
2445 pm_control_fn, data, cfg, prio, api, mtu)\
2446 Z_NET_DEVICE_OFFLOAD_INIT(DT_INVALID_NODE, dev_name, drv_name, \
2447 init_fn, pm_control_fn, data, cfg, prio,\
2448 api, mtu)
2449
2470#define NET_DEVICE_DT_OFFLOAD_DEFINE(node_id, init_fn, pm_control_fn, \
2471 data, cfg, prio, api, mtu) \
2472 Z_NET_DEVICE_OFFLOAD_INIT(node_id, Z_DEVICE_DT_DEV_NAME(node_id), \
2473 DT_PROP_OR(node_id, label, NULL), \
2474 init_fn, pm_control_fn, data, cfg, \
2475 prio, api, mtu)
2476
2488#define NET_DEVICE_DT_INST_OFFLOAD_DEFINE(inst, ...) \
2489 NET_DEVICE_DT_OFFLOAD_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
2490
2491#ifdef __cplusplus
2492}
2493#endif
2494
2495#include <syscalls/net_if.h>
2496
2501#endif /* ZEPHYR_INCLUDE_NET_NET_IF_H_ */
struct z_thread_stack_element k_thread_stack_t
Typedef of struct z_thread_stack_element.
Definition: arch_interface.h:44
ZTEST_BMEM int index[(3)]
Definition: main.c:32
DHCPv4 Client Handler.
void
Definition: eswifi_shell.c:15
static void atomic_set_bit(atomic_t *target, int bit)
Atomically set a bit.
Definition: atomic.h:205
static bool atomic_test_bit(const atomic_t *target, int bit)
Atomically test a bit.
Definition: atomic.h:127
static void atomic_clear_bit(atomic_t *target, int bit)
Atomically clear a bit.
Definition: atomic.h:187
#define ATOMIC_DEFINE(name, num_bits)
Define an array of atomic variables.
Definition: atomic.h:113
static bool atomic_test_and_set_bit(atomic_t *target, int bit)
Atomically set a bit.
Definition: atomic.h:166
net_addr_state
Definition: net_ip.h:431
net_addr_type
Definition: net_ip.h:439
net_verdict
Net Verdict.
Definition: net_core.h:97
static int net_hostname_set_postfix(const uint8_t *hostname_postfix, int postfix_len)
Set the device hostname postfix.
Definition: hostname.h:74
struct net_if * net_if_select_src_iface(const struct sockaddr *dst)
Get a network interface that should be used when sending IPv6 or IPv4 network data to destination.
struct net_if_router * net_if_ipv4_router_lookup(struct net_if *iface, struct in_addr *addr)
Check if IPv4 address is one of the routers configured in the system.
int net_if_get_by_iface(struct net_if *iface)
Get interface index according to pointer.
int net_if_up(struct net_if *iface)
Bring interface up.
struct net_if_addr * net_if_ipv4_addr_lookup(const struct in_addr *addr, struct net_if **iface)
Check if this IPv4 address belongs to one of the interfaces.
int net_if_ipv4_addr_lookup_by_index(const struct in_addr *addr)
Check if this IPv4 address belongs to one of the interface indices.
struct net_if_addr * net_if_ipv6_addr_lookup(const struct in6_addr *addr, struct net_if **iface)
Check if this IPv6 address belongs to one of the interfaces.
int net_if_ipv6_addr_lookup_by_index(const struct in6_addr *addr)
Check if this IPv6 address belongs to one of the interface indices.
struct net_if * net_if_get_by_link_addr(struct net_linkaddr *ll_addr)
Get an interface according to link layer address.
bool net_if_ipv6_router_rm(struct net_if_router *router)
Remove IPv6 router from the system.
bool net_if_ipv4_maddr_rm(struct net_if *iface, const struct in_addr *addr)
Remove an IPv4 multicast address from an interface.
void net_if_ipv6_dad_failed(struct net_if *iface, const struct in6_addr *addr)
Stop IPv6 Duplicate Address Detection (DAD) procedure if we find out that our IPv6 address is already...
int net_if_down(struct net_if *iface)
Bring interface down.
void net_if_unset_promisc(struct net_if *iface)
Set network interface into normal mode.
bool net_if_need_calc_tx_checksum(struct net_if *iface)
Check if network packet checksum calculation can be avoided or not when sending the packet....
struct net_if_router * net_if_ipv4_router_find_default(struct net_if *iface, struct in_addr *addr)
Find default router for this IPv4 address.
bool net_if_ipv6_addr_onlink(struct net_if **iface, struct in6_addr *addr)
Check if this IPv6 address is part of the subnet of our network interface.
static struct in_addr * net_if_router_ipv4(struct net_if_router *router)
Get the IPv4 address of the given router.
Definition: net_if.h:1691
void net_if_ipv6_prefix_unset_timer(struct net_if_ipv6_prefix *prefix)
Unset the prefix lifetime timer.
void net_if_ipv4_maddr_leave(struct net_if_mcast_addr *addr)
Mark a given multicast address to be left.
struct net_if_ipv6_prefix * net_if_ipv6_prefix_add(struct net_if *iface, struct in6_addr *prefix, uint8_t len, uint32_t lifetime)
Add a IPv6 prefix to an network interface.
void net_if_ipv4_set_gw(struct net_if *iface, const struct in_addr *gw)
Set IPv4 gateway for an interface.
int net_if_config_ipv4_get(struct net_if *iface, struct net_if_ipv4 **ipv4)
Allocate network interface IPv4 config.
static const struct net_l2 *const net_if_l2(struct net_if *iface)
Get a pointer to the interface L2.
Definition: net_if.h:568
struct net_if_router * net_if_ipv6_router_find_default(struct net_if *iface, struct in6_addr *addr)
Find default router for this IPv6 address.
bool net_if_ipv6_prefix_rm(struct net_if *iface, struct in6_addr *addr, uint8_t len)
Remove an IPv6 prefix from an interface.
void(* net_if_link_callback_t)(struct net_if *iface, struct net_linkaddr *dst, int status)
Define callback that is called after a network packet has been sent.
Definition: net_if.h:1898
static void * net_if_l2_data(struct net_if *iface)
Get a pointer to the interface L2 private data.
Definition: net_if.h:594
static bool net_if_are_pending_tx_packets(struct net_if *iface)
Check if there are any pending TX network data for a given network interface.
Definition: net_if.h:2148
static bool net_if_flag_test_and_set(struct net_if *iface, enum net_if_flag value)
Test and set a value in network interface flags.
Definition: net_if.h:511
bool net_if_ipv4_addr_rm(struct net_if *iface, const struct in_addr *addr)
Remove a IPv4 address from an interface.
struct net_if_router * net_if_ipv4_router_add(struct net_if *iface, struct in_addr *addr, bool is_default, uint16_t router_lifetime)
Add IPv4 router to the system.
void net_if_mcast_monitor(struct net_if *iface, const struct in6_addr *addr, bool is_joined)
Call registered multicast monitors.
static struct net_linkaddr * net_if_get_link_addr(struct net_if *iface)
Get an network interface's link address.
Definition: net_if.h:680
static const struct in6_addr * net_if_ipv6_select_src_addr(struct net_if *iface, const struct in6_addr *dst)
Get a IPv6 source address that should be used when sending network data to destination.
Definition: net_if.h:1428
static struct net_offload * net_if_offload(struct net_if *iface)
Return the IP offload plugin.
Definition: net_if.h:644
static int net_if_set_link_addr(struct net_if *iface, uint8_t *addr, uint8_t len, enum net_link_type type)
Set a network interface's link address.
Definition: net_if.h:768
static void net_if_flag_set(struct net_if *iface, enum net_if_flag value)
Set a value in network interface flags.
Definition: net_if.h:495
uint8_t net_if_ipv6_get_hop_limit(struct net_if *iface)
Get IPv6 hop limit specified for a given interface. This is the default value but can be overridden b...
struct net_if * net_if_get_default(void)
Get the default network interface.
void net_if_ipv4_set_ttl(struct net_if *iface, uint8_t ttl)
Set IPv4 time-to-live value specified to a given interface.
bool net_if_ipv4_addr_mask_cmp(struct net_if *iface, const struct in_addr *addr)
Check if the given IPv4 address belongs to local subnet.
void net_if_queue_tx(struct net_if *iface, struct net_pkt *pkt)
Queue a packet to the net interface TX queue.
int net_if_config_ipv6_get(struct net_if *iface, struct net_if_ipv6 **ipv6)
Allocate network interface IPv6 config.
struct net_if_ipv6_prefix * net_if_ipv6_prefix_get(struct net_if *iface, struct in6_addr *addr)
Return prefix that corresponds to this IPv6 address.
bool net_if_ipv6_addr_rm(struct net_if *iface, const struct in6_addr *addr)
Remove an IPv6 address from an interface.
void net_if_ipv6_prefix_set_timer(struct net_if_ipv6_prefix *prefix, uint32_t lifetime)
Set the prefix lifetime timer.
void net_if_unregister_link_cb(struct net_if_link_cb *link)
Unregister a link callback.
bool net_if_ipv4_router_rm(struct net_if_router *router)
Remove IPv4 router from the system.
static bool net_if_is_ip_offloaded(struct net_if *iface)
Return the IP offload status.
Definition: net_if.h:626
struct net_if_addr * net_if_ipv4_addr_add(struct net_if *iface, struct in_addr *addr, enum net_addr_type addr_type, uint32_t vlifetime)
Add a IPv4 address to an interface.
struct net_if * net_if_get_by_index(int index)
Get interface according to index.
enum net_verdict net_if_recv_data(struct net_if *iface, struct net_pkt *pkt)
Input a packet through a net iface.
struct net_if * net_if_get_first_by_type(const struct net_l2 *l2)
Get the first network interface according to its type.
static void net_if_set_mtu(struct net_if *iface, uint16_t mtu)
Set an network interface's MTU.
Definition: net_if.h:801
bool net_if_need_calc_rx_checksum(struct net_if *iface)
Check if received network packet checksum calculation can be avoided or not. For example many etherne...
struct net_if_mcast_addr * net_if_ipv6_maddr_add(struct net_if *iface, const struct in6_addr *addr)
Add a IPv6 multicast address to an interface.
uint8_t net_if_ipv4_get_ttl(struct net_if *iface)
Get IPv4 time-to-live value specified for a given interface.
static bool net_if_is_up(struct net_if *iface)
Check if interface is up.
Definition: net_if.h:2022
static void net_if_ipv6_set_reachable_time(struct net_if_ipv6 *ipv6)
Set IPv6 reachable time for a given interface. This requires that base reachable time is set for the ...
Definition: net_if.h:1368
struct in6_addr * net_if_ipv6_get_ll_addr(enum net_addr_state state, struct net_if **iface)
Return link local IPv6 address from the first interface that has a link local address matching give s...
int net_if_config_ipv4_put(struct net_if *iface)
Release network interface IPv4 config.
int net_if_config_ipv6_put(struct net_if *iface)
Release network interface IPv6 config.
bool net_if_ipv4_is_addr_bcast(struct net_if *iface, const struct in_addr *addr)
Check if the given IPv4 address is a broadcast address.
void net_if_mcast_mon_register(struct net_if_mcast_monitor *mon, struct net_if *iface, net_if_mcast_callback_t cb)
Register a multicast monitor.
void net_if_ipv6_maddr_join(struct net_if_mcast_addr *addr)
Mark a given multicast address to be joined.
bool net_if_ipv4_set_netmask_by_index(int index, const struct in_addr *netmask)
Set IPv4 netmask for an interface index.
static void net_if_start_dad(struct net_if *iface)
Start duplicate address detection procedure.
Definition: net_if.h:705
void net_if_foreach(net_if_cb_t cb, void *user_data)
Go through all the network interfaces and call callback for each interface.
bool net_if_ipv6_addr_add_by_index(int index, struct in6_addr *addr, enum net_addr_type addr_type, uint32_t vlifetime)
Add a IPv6 address to an interface by index.
struct net_if_router * net_if_ipv6_router_add(struct net_if *iface, struct in6_addr *addr, uint16_t router_lifetime)
Add IPv6 router to the system.
static uint32_t net_if_ipv6_get_reachable_time(struct net_if *iface)
Get IPv6 reachable timeout specified for a given interface.
Definition: net_if.h:1340
static bool net_if_ipv4_maddr_is_joined(struct net_if_mcast_addr *addr)
Check if given multicast address is joined or not.
Definition: net_if.h:1665
static void net_if_ipv6_prefix_set_lf(struct net_if_ipv6_prefix *prefix, bool is_infinite)
Set the infinite status of the prefix.
Definition: net_if.h:1186
struct net_if_mcast_addr * net_if_ipv4_maddr_add(struct net_if *iface, const struct in_addr *addr)
Add a IPv4 multicast address to an interface.
void net_if_register_link_cb(struct net_if_link_cb *link, net_if_link_callback_t cb)
Register a link callback.
void net_if_call_link_cb(struct net_if *iface, struct net_linkaddr *lladdr, int status)
Call a link callback function.
void net_if_ipv6_router_update_lifetime(struct net_if_router *router, uint16_t lifetime)
Update validity lifetime time of a router.
struct net_if_ipv6_prefix * net_if_ipv6_prefix_lookup(struct net_if *iface, struct in6_addr *addr, uint8_t len)
Check if this IPv6 prefix belongs to this interface.
static void net_if_stop_rs(struct net_if *iface)
Stop neighbor discovery.
Definition: net_if.h:727
uint32_t net_if_ipv6_calc_reachable_time(struct net_if_ipv6 *ipv6)
Calculate next reachable time value for IPv6 reachable time.
static void net_if_ipv6_set_base_reachable_time(struct net_if *iface, uint32_t reachable_time)
Set IPv6 reachable time for a given interface.
Definition: net_if.h:1321
void(* net_if_mcast_callback_t)(struct net_if *iface, const struct in6_addr *addr, bool is_joined)
Define callback that is called whenever IPv6 multicast address group is joined or left.
Definition: net_if.h:1049
struct net_if_addr * net_if_ipv6_addr_lookup_by_iface(struct net_if *iface, struct in6_addr *addr)
Check if this IPv6 address belongs to this specific interfaces.
int net_if_set_promisc(struct net_if *iface)
Set network interface into promiscuous mode.
void net_if_start_rs(struct net_if *iface)
Start neighbor discovery and send router solicitation message.
static bool net_if_ipv6_maddr_is_joined(struct net_if_mcast_addr *addr)
Check if given multicast address is joined or not.
Definition: net_if.h:1115
bool net_if_is_promisc(struct net_if *iface)
Check if promiscuous mode is set or not.
bool net_if_ipv6_addr_rm_by_index(int index, const struct in6_addr *addr)
Remove an IPv6 address from an interface by index.
bool net_if_ipv4_addr_rm_by_index(int index, const struct in_addr *addr)
Remove a IPv4 address from an interface by interface index.
void net_ipv6_set_hop_limit(struct net_if *iface, uint8_t hop_limit)
Set the default IPv6 hop limit of a given interface.
struct in6_addr * net_if_ipv6_get_global_addr(enum net_addr_state state, struct net_if **iface)
Return global IPv6 address from the first interface that has a global IPv6 address matching the given...
static uint16_t net_if_get_mtu(struct net_if *iface)
Get an network interface's MTU.
Definition: net_if.h:786
struct net_if_router * net_if_ipv6_router_lookup(struct net_if *iface, struct in6_addr *addr)
Check if IPv6 address is one of the routers configured in the system.
bool net_if_ipv4_addr_add_by_index(int index, struct in_addr *addr, enum net_addr_type addr_type, uint32_t vlifetime)
Add a IPv4 address to an interface by network interface index.
struct in_addr * net_if_ipv4_get_ll(struct net_if *iface, enum net_addr_state addr_state)
Get a IPv4 link local address in a given state.
void net_if_mcast_mon_unregister(struct net_if_mcast_monitor *mon)
Unregister a multicast monitor.
void net_if_ipv6_maddr_leave(struct net_if_mcast_addr *addr)
Mark a given multicast address to be left.
void net_if_ipv4_set_netmask(struct net_if *iface, const struct in_addr *netmask)
Set IPv4 netmask for an interface.
static const struct in_addr * net_if_ipv4_select_src_addr(struct net_if *iface, const struct in_addr *dst)
Get a IPv4 source address that should be used when sending network data to destination.
Definition: net_if.h:1806
struct in6_addr * net_if_ipv6_get_ll(struct net_if *iface, enum net_addr_state addr_state)
Get a IPv6 link local address in a given state.
static void net_if_ipv6_set_retrans_timer(struct net_if *iface, uint32_t retrans_timer)
Set IPv6 retransmit timer for a given interface.
Definition: net_if.h:1381
struct in_addr * net_if_ipv4_get_global_addr(struct net_if *iface, enum net_addr_state addr_state)
Get a IPv4 global address in a given state.
enum net_verdict net_if_send_data(struct net_if *iface, struct net_pkt *pkt)
Send a packet through a net iface.
struct net_if_mcast_addr * net_if_ipv6_maddr_lookup(const struct in6_addr *addr, struct net_if **iface)
Check if this IPv6 multicast address belongs to a specific interface or one of the interfaces.
struct net_if * net_if_lookup_by_dev(const struct device *dev)
Find an interface from it's related device.
static struct in6_addr * net_if_router_ipv6(struct net_if_router *router)
Get the IPv6 address of the given router.
Definition: net_if.h:1232
struct net_if_mcast_addr * net_if_ipv4_maddr_lookup(const struct in_addr *addr, struct net_if **iface)
Check if this IPv4 multicast address belongs to a specific interface or one of the interfaces.
void net_if_router_rm(struct net_if_router *router)
Remove a router from the system.
static uint32_t net_if_ipv6_get_retrans_timer(struct net_if *iface)
Get IPv6 retransmit timer specified for a given interface.
Definition: net_if.h:1400
bool net_if_ipv4_set_gw_by_index(int index, const struct in_addr *gw)
Set IPv4 gateway for an interface index.
struct net_if_addr * net_if_ipv6_addr_add(struct net_if *iface, struct in6_addr *addr, enum net_addr_type addr_type, uint32_t vlifetime)
Add a IPv6 address to an interface.
static struct net_if * net_if_ipv6_select_src_iface(const struct in6_addr *dst)
Get a network interface that should be used when sending IPv6 network data to destination.
Definition: net_if.h:1450
static bool net_if_flag_is_set(struct net_if *iface, enum net_if_flag value)
Check if a value in network interface flags is set.
Definition: net_if.h:541
static struct net_if_config * net_if_config_get(struct net_if *iface)
Get network interface IP config.
Definition: net_if.h:848
static struct net_if_config * net_if_get_config(struct net_if *iface)
Return network configuration for this network interface.
Definition: net_if.h:692
static void net_if_addr_set_lf(struct net_if_addr *ifaddr, bool is_infinite)
Set the infinite status of the network interface address.
Definition: net_if.h:817
net_if_flag
Definition: net_if.h:163
static const struct device * net_if_get_device(struct net_if *iface)
Get an network interface's device.
Definition: net_if.h:606
void(* net_if_cb_t)(struct net_if *iface, void *user_data)
Callback used while iterating over network interfaces.
Definition: net_if.h:1995
void net_if_ipv6_addr_update_lifetime(struct net_if_addr *ifaddr, uint32_t vlifetime)
Update validity lifetime time of an IPv6 address.
bool net_if_ipv6_maddr_rm(struct net_if *iface, const struct in6_addr *addr)
Remove an IPv6 multicast address from an interface.
static bool net_if_is_socket_offloaded(struct net_if *iface)
Return the socket offload status.
Definition: net_if.h:662
void net_if_ipv4_maddr_join(struct net_if_mcast_addr *addr)
Mark a given multicast address to be joined.
static struct net_if * net_if_ipv4_select_src_iface(const struct in_addr *dst)
Get a network interface that should be used when sending IPv4 network data to destination.
Definition: net_if.h:1782
static void net_if_flag_clear(struct net_if *iface, enum net_if_flag value)
Clear a value in network interface flags.
Definition: net_if.h:525
@ NET_IF_NO_AUTO_START
Definition: net_if.h:179
@ NET_IF_POINTOPOINT
Definition: net_if.h:168
@ NET_IF_FORWARD_MULTICASTS
Definition: net_if.h:188
@ NET_IF_IPV4
Definition: net_if.h:191
@ NET_IF_PROMISC
Definition: net_if.h:171
@ NET_IF_SUSPENDED
Definition: net_if.h:182
@ NET_IF_IPV6
Definition: net_if.h:194
@ NET_IF_UP
Definition: net_if.h:165
net_link_type
Definition: net_linkaddr.h:47
#define EPERM
Definition: errno.h:40
Hostname configuration definitions.
flags
Definition: http_parser.h:131
state
Definition: http_parser_state.h:30
IPv4 Autoconfiguration.
net_ipv4_autoconf_state
Definition: ipv4_autoconf.h:15
Network core definitions.
IPv6 and IPv4 definitions.
Public API for network L2 interface.
Public API for network link address.
Network statistics.
Network timer with wrap around.
Single-linked list implementation.
struct _slist sys_slist_t
Definition: slist.h:40
struct _snode sys_snode_t
Definition: slist.h:33
__UINT32_TYPE__ uint32_t
Definition: stdint.h:60
__UINT8_TYPE__ uint8_t
Definition: stdint.h:58
__UINT16_TYPE__ uint16_t
Definition: stdint.h:59
__INT64_TYPE__ int64_t
Definition: stdint.h:45
Runtime device structure (in ROM) per driver instance.
Definition: device.h:367
Definition: net_ip.h:139
Definition: net_ip.h:148
Definition: kernel.h:2153
Definition: thread.h:201
Network Interface unicast IP addresses.
Definition: net_if.h:49
struct net_addr address
Definition: net_if.h:51
uint8_t is_mesh_local
Definition: net_if.h:80
enum net_addr_state addr_state
Definition: net_if.h:66
uint8_t is_infinite
Definition: net_if.h:74
enum net_addr_type addr_type
Definition: net_if.h:63
uint8_t is_used
Definition: net_if.h:77
IP and other configuration related data for network interface.
Definition: net_if.h:373
struct net_if_ip ip
Definition: net_if.h:375
Network Interface Device structure.
Definition: net_if.h:427
const struct net_l2 *const l2
Definition: net_if.h:432
void * l2_data
Definition: net_if.h:435
uint16_t mtu
Definition: net_if.h:453
const struct device * dev
Definition: net_if.h:429
struct net_linkaddr link_addr
Definition: net_if.h:441
atomic_t flags[ATOMIC_BITMAP_SIZE(NET_IF_NUM_FLAGS)]
Definition: net_if.h:438
Network interface IP address configuration.
Definition: net_if.h:360
Definition: net_if.h:261
struct net_if_addr unicast[NET_IF_MAX_IPV4_ADDR]
Definition: net_if.h:263
struct in_addr netmask
Definition: net_if.h:272
struct in_addr gw
Definition: net_if.h:269
uint8_t ttl
Definition: net_if.h:275
struct net_if_mcast_addr mcast[NET_IF_MAX_IPV4_MADDR]
Definition: net_if.h:266
Network Interface IPv6 prefixes.
Definition: net_if.h:108
struct net_if * iface
Definition: net_if.h:116
uint8_t is_infinite
Definition: net_if.h:122
uint8_t len
Definition: net_if.h:119
struct in6_addr prefix
Definition: net_if.h:113
uint8_t is_used
Definition: net_if.h:125
struct net_timeout lifetime
Definition: net_if.h:110
Definition: net_if.h:218
struct net_if_ipv6_prefix prefix[NET_IF_MAX_IPV6_PREFIX]
Definition: net_if.h:226
uint32_t base_reachable_time
Definition: net_if.h:229
uint8_t hop_limit
Definition: net_if.h:248
struct net_if_mcast_addr mcast[NET_IF_MAX_IPV6_MADDR]
Definition: net_if.h:223
uint32_t retrans_timer
Definition: net_if.h:235
struct net_if_addr unicast[NET_IF_MAX_IPV6_ADDR]
Definition: net_if.h:220
uint32_t reachable_time
Definition: net_if.h:232
Network Interface multicast IP addresses.
Definition: net_if.h:90
struct net_addr address
Definition: net_if.h:92
uint8_t is_joined
Definition: net_if.h:98
uint8_t is_used
Definition: net_if.h:95
Multicast monitor handler struct.
Definition: net_if.h:1061
sys_snode_t node
Definition: net_if.h:1063
net_if_mcast_callback_t cb
Definition: net_if.h:1069
struct net_if * iface
Definition: net_if.h:1066
Information about routers in the system.
Definition: net_if.h:135
struct net_if * iface
Definition: net_if.h:143
uint8_t is_default
Definition: net_if.h:155
uint16_t lifetime
Definition: net_if.h:149
uint8_t is_infinite
Definition: net_if.h:158
uint8_t is_used
Definition: net_if.h:152
struct net_addr address
Definition: net_if.h:140
sys_snode_t node
Definition: net_if.h:137
uint32_t life_start
Definition: net_if.h:146
Network Interface structure.
Definition: net_if.h:468
struct net_if_dev * if_dev
Definition: net_if.h:470
struct net_if_config config
Definition: net_if.h:478
Network L2 structure.
Definition: net_l2.h:54
Hardware link address structure.
Definition: net_linkaddr.h:69
uint8_t * addr
Definition: net_linkaddr.h:71
uint8_t type
Definition: net_linkaddr.h:77
uint8_t len
Definition: net_linkaddr.h:74
Network packet.
Definition: net_pkt.h:62
All network statistics in one struct.
Definition: net_stats.h:292
Definition: net_timeout.h:55
Network traffic class.
Definition: net_if.h:403
k_thread_stack_t * stack
Definition: net_if.h:411
struct k_thread handler
Definition: net_if.h:408
struct k_fifo fifo
Definition: net_if.h:405
Definition: net_ip.h:335
static const intptr_t user_data[5]
Definition: main.c:590