Zephyr Project API  3.1.0
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 <zephyr/device.h>
23#include <zephyr/sys/slist.h>
24
25#include <zephyr/net/net_core.h>
26#include <zephyr/net/hostname.h>
28#include <zephyr/net/net_ip.h>
29#include <zephyr/net/net_l2.h>
32
33#if defined(CONFIG_NET_DHCPV4) && defined(CONFIG_NET_NATIVE_IPV4)
34#include <zephyr/net/dhcpv4.h>
35#endif
36#if defined(CONFIG_NET_IPV4_AUTO) && defined(CONFIG_NET_NATIVE_IPV4)
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
420typedef int (*net_socket_create_t)(int, int, int);
421
437 const struct device *dev;
438
440 const struct net_l2 * const l2;
441
443 void *l2_data;
444
445 /* For internal use */
446 ATOMIC_DEFINE(flags, NET_IF_NUM_FLAGS);
447
450
451#if defined(CONFIG_NET_OFFLOAD)
457 struct net_offload *offload;
458#endif /* CONFIG_NET_OFFLOAD */
459
462
463#if defined(CONFIG_NET_SOCKETS_OFFLOAD)
467 net_socket_create_t socket_offload;
468#endif /* CONFIG_NET_SOCKETS_OFFLOAD */
469};
470
478struct net_if {
481
482#if defined(CONFIG_NET_STATISTICS_PER_INTERFACE)
484 struct net_stats stats;
485#endif /* CONFIG_NET_STATISTICS_PER_INTERFACE */
486
489
490#if defined(CONFIG_NET_POWER_MANAGEMENT)
495 int tx_pending;
496#endif
497};
498
505static inline void net_if_flag_set(struct net_if *iface,
506 enum net_if_flag value)
507{
508 NET_ASSERT(iface);
509
510 atomic_set_bit(iface->if_dev->flags, value);
511}
512
521static inline bool net_if_flag_test_and_set(struct net_if *iface,
522 enum net_if_flag value)
523{
524 NET_ASSERT(iface);
525
526 return atomic_test_and_set_bit(iface->if_dev->flags, value);
527}
528
535static inline void net_if_flag_clear(struct net_if *iface,
536 enum net_if_flag value)
537{
538 NET_ASSERT(iface);
539
540 atomic_clear_bit(iface->if_dev->flags, value);
541}
542
551static inline bool net_if_flag_is_set(struct net_if *iface,
552 enum net_if_flag value)
553{
554 if (iface == NULL) {
555 return false;
556 }
557
558 return atomic_test_bit(iface->if_dev->flags, value);
559}
560
569enum net_verdict net_if_send_data(struct net_if *iface, struct net_pkt *pkt);
570
578static inline const struct net_l2 * const net_if_l2(struct net_if *iface)
579{
580 if (!iface || !iface->if_dev) {
581 return NULL;
582 }
583
584 return iface->if_dev->l2;
585}
586
595enum net_verdict net_if_recv_data(struct net_if *iface, struct net_pkt *pkt);
596
604static inline void *net_if_l2_data(struct net_if *iface)
605{
606 return iface->if_dev->l2_data;
607}
608
616static inline const struct device *net_if_get_device(struct net_if *iface)
617{
618 return iface->if_dev->dev;
619}
620
627void net_if_queue_tx(struct net_if *iface, struct net_pkt *pkt);
628
636static inline bool net_if_is_ip_offloaded(struct net_if *iface)
637{
638#if defined(CONFIG_NET_OFFLOAD)
639 return (iface->if_dev->offload != NULL);
640#else
641 ARG_UNUSED(iface);
642
643 return false;
644#endif
645}
646
654static inline struct net_offload *net_if_offload(struct net_if *iface)
655{
656#if defined(CONFIG_NET_OFFLOAD)
657 return iface->if_dev->offload;
658#else
659 ARG_UNUSED(iface);
660
661 return NULL;
662#endif
663}
664
672static inline bool net_if_is_socket_offloaded(struct net_if *iface)
673{
674#if defined(CONFIG_NET_SOCKETS_OFFLOAD)
675 return (iface->if_dev->socket_offload != NULL);
676#else
677 ARG_UNUSED(iface);
678
679 return false;
680#endif
681}
682
689static inline void net_if_socket_offload_set(
690 struct net_if *iface, net_socket_create_t socket_offload)
691{
692#if defined(CONFIG_NET_SOCKETS_OFFLOAD)
693 iface->if_dev->socket_offload = socket_offload;
694#else
695 ARG_UNUSED(iface);
696 ARG_UNUSED(socket_offload);
697#endif
698}
699
708{
709#if defined(CONFIG_NET_SOCKETS_OFFLOAD)
710 return iface->if_dev->socket_offload;
711#else
712 ARG_UNUSED(iface);
713
714 return NULL;
715#endif
716}
717
725static inline struct net_linkaddr *net_if_get_link_addr(struct net_if *iface)
726{
727 return &iface->if_dev->link_addr;
728}
729
737static inline struct net_if_config *net_if_get_config(struct net_if *iface)
738{
739 return &iface->config;
740}
741
747#if defined(CONFIG_NET_IPV6_DAD) && defined(CONFIG_NET_NATIVE_IPV6)
748void net_if_start_dad(struct net_if *iface);
749#else
750static inline void net_if_start_dad(struct net_if *iface)
751{
752 ARG_UNUSED(iface);
753}
754#endif
755
761void net_if_start_rs(struct net_if *iface);
762
763
769#if defined(CONFIG_NET_IPV6_ND) && defined(CONFIG_NET_NATIVE_IPV6)
770void net_if_stop_rs(struct net_if *iface);
771#else
772static inline void net_if_stop_rs(struct net_if *iface)
773{
774 ARG_UNUSED(iface);
775}
776#endif /* CONFIG_NET_IPV6_ND */
777
780static inline int net_if_set_link_addr_unlocked(struct net_if *iface,
781 uint8_t *addr, uint8_t len,
782 enum net_link_type type)
783{
784 if (net_if_flag_is_set(iface, NET_IF_UP)) {
785 return -EPERM;
786 }
787
788 net_if_get_link_addr(iface)->addr = addr;
789 net_if_get_link_addr(iface)->len = len;
790 net_if_get_link_addr(iface)->type = type;
791
792 net_hostname_set_postfix(addr, len);
793
794 return 0;
795}
796
797int net_if_set_link_addr_locked(struct net_if *iface,
798 uint8_t *addr, uint8_t len,
799 enum net_link_type type);
813static inline int net_if_set_link_addr(struct net_if *iface,
814 uint8_t *addr, uint8_t len,
815 enum net_link_type type)
816{
817#if defined(CONFIG_NET_RAW_MODE)
818 return net_if_set_link_addr_unlocked(iface, addr, len, type);
819#else
820 return net_if_set_link_addr_locked(iface, addr, len, type);
821#endif
822}
823
831static inline uint16_t net_if_get_mtu(struct net_if *iface)
832{
833 if (iface == NULL) {
834 return 0U;
835 }
836
837 return iface->if_dev->mtu;
838}
839
846static inline void net_if_set_mtu(struct net_if *iface,
847 uint16_t mtu)
848{
849 if (iface == NULL) {
850 return;
851 }
852
853 iface->if_dev->mtu = mtu;
854}
855
862static inline void net_if_addr_set_lf(struct net_if_addr *ifaddr,
863 bool is_infinite)
864{
865 ifaddr->is_infinite = is_infinite;
866}
867
876
884struct net_if *net_if_lookup_by_dev(const struct device *dev);
885
893static inline struct net_if_config *net_if_config_get(struct net_if *iface)
894{
895 return &iface->config;
896}
897
903void net_if_router_rm(struct net_if_router *router);
904
910void net_if_set_default(struct net_if *iface);
911
918
927struct net_if *net_if_get_first_by_type(const struct net_l2 *l2);
928
936
937#if defined(CONFIG_NET_L2_IEEE802154)
944static inline struct net_if *net_if_get_ieee802154(void)
945{
946 return net_if_get_first_by_type(&NET_L2_GET_NAME(IEEE802154));
947}
948#endif /* CONFIG_NET_L2_IEEE802154 */
949
961 struct net_if_ipv6 **ipv6);
962
971
981 struct net_if **iface);
982
992 struct in6_addr *addr);
993
1002__syscall int net_if_ipv6_addr_lookup_by_index(const struct in6_addr *addr);
1003
1015 struct in6_addr *addr,
1017 uint32_t vlifetime);
1018
1030 struct in6_addr *addr,
1032 uint32_t vlifetime);
1033
1041 uint32_t vlifetime);
1042
1051bool net_if_ipv6_addr_rm(struct net_if *iface, const struct in6_addr *addr);
1052
1062 const struct in6_addr *addr);
1063
1073 const struct in6_addr *addr);
1074
1083bool net_if_ipv6_maddr_rm(struct net_if *iface, const struct in6_addr *addr);
1084
1096 struct net_if **iface);
1097
1109typedef void (*net_if_mcast_callback_t)(struct net_if *iface,
1110 const struct net_addr *addr,
1111 bool is_joined);
1112
1124
1126 struct net_if *iface;
1127
1130};
1131
1141 struct net_if *iface,
1143
1150
1158void net_if_mcast_monitor(struct net_if *iface, const struct net_addr *addr,
1159 bool is_joined);
1160
1167
1175static inline bool net_if_ipv6_maddr_is_joined(struct net_if_mcast_addr *addr)
1176{
1177 NET_ASSERT(addr);
1178
1179 return addr->is_joined;
1180}
1181
1188
1198 struct in6_addr *addr);
1199
1210 struct in6_addr *addr,
1211 uint8_t len);
1212
1224 struct in6_addr *prefix,
1225 uint8_t len,
1227
1237bool net_if_ipv6_prefix_rm(struct net_if *iface, struct in6_addr *addr,
1238 uint8_t len);
1239
1247 bool is_infinite)
1248{
1249 prefix->is_infinite = is_infinite;
1250}
1251
1260
1267
1278bool net_if_ipv6_addr_onlink(struct net_if **iface, struct in6_addr *addr);
1279
1286#if defined(CONFIG_NET_NATIVE_IPV6)
1287static inline struct in6_addr *net_if_router_ipv6(struct net_if_router *router)
1288{
1289 return &router->address.in6_addr;
1290}
1291#else
1292static inline struct in6_addr *net_if_router_ipv6(struct net_if_router *router)
1293{
1294 static struct in6_addr addr;
1295
1296 ARG_UNUSED(router);
1297
1298 return &addr;
1299}
1300#endif
1301
1312 struct in6_addr *addr);
1313
1324 struct in6_addr *addr);
1325
1334
1345 struct in6_addr *addr,
1346 uint16_t router_lifetime);
1347
1356
1366
1374
1382 uint32_t reachable_time)
1383{
1384#if defined(CONFIG_NET_NATIVE_IPV6)
1385 if (!iface->config.ip.ipv6) {
1386 return;
1387 }
1388
1389 iface->config.ip.ipv6->base_reachable_time = reachable_time;
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->reachable_time;
1408#else
1409 return 0;
1410#endif
1411}
1412
1421
1428static inline void net_if_ipv6_set_reachable_time(struct net_if_ipv6 *ipv6)
1429{
1430#if defined(CONFIG_NET_NATIVE_IPV6)
1432#endif
1433}
1434
1441static inline void net_if_ipv6_set_retrans_timer(struct net_if *iface,
1442 uint32_t retrans_timer)
1443{
1444#if defined(CONFIG_NET_NATIVE_IPV6)
1445 if (!iface->config.ip.ipv6) {
1446 return;
1447 }
1448
1449 iface->config.ip.ipv6->retrans_timer = retrans_timer;
1450#endif
1451}
1452
1461{
1462#if defined(CONFIG_NET_NATIVE_IPV6)
1463 if (!iface->config.ip.ipv6) {
1464 return 0;
1465 }
1466
1467 return iface->config.ip.ipv6->retrans_timer;
1468#else
1469 return 0;
1470#endif
1471}
1472
1484#if defined(CONFIG_NET_NATIVE_IPV6)
1485const struct in6_addr *net_if_ipv6_select_src_addr(struct net_if *iface,
1486 const struct in6_addr *dst);
1487#else
1488static inline const struct in6_addr *net_if_ipv6_select_src_addr(
1489 struct net_if *iface, const struct in6_addr *dst)
1490{
1491 ARG_UNUSED(iface);
1492 ARG_UNUSED(dst);
1493
1494 return NULL;
1495}
1496#endif
1497
1507#if defined(CONFIG_NET_NATIVE_IPV6)
1508struct net_if *net_if_ipv6_select_src_iface(const struct in6_addr *dst);
1509#else
1511 const struct in6_addr *dst)
1512{
1513 ARG_UNUSED(dst);
1514
1515 return NULL;
1516}
1517#endif
1518
1528struct in6_addr *net_if_ipv6_get_ll(struct net_if *iface,
1529 enum net_addr_state addr_state);
1530
1541 struct net_if **iface);
1542
1550void net_if_ipv6_dad_failed(struct net_if *iface, const struct in6_addr *addr);
1551
1564 struct net_if **iface);
1565
1577 struct net_if_ipv4 **ipv4);
1578
1587
1596
1603void net_if_ipv4_set_ttl(struct net_if *iface, uint8_t ttl);
1604
1614 struct net_if **iface);
1615
1627 struct in_addr *addr,
1629 uint32_t vlifetime);
1630
1639bool net_if_ipv4_addr_rm(struct net_if *iface, const struct in_addr *addr);
1640
1649__syscall int net_if_ipv4_addr_lookup_by_index(const struct in_addr *addr);
1650
1662 struct in_addr *addr,
1664 uint32_t vlifetime);
1665
1675 const struct in_addr *addr);
1676
1686 const struct in_addr *addr);
1687
1696bool net_if_ipv4_maddr_rm(struct net_if *iface, const struct in_addr *addr);
1697
1709 struct net_if **iface);
1710
1717
1725static inline bool net_if_ipv4_maddr_is_joined(struct net_if_mcast_addr *addr)
1726{
1727 NET_ASSERT(addr);
1728
1729 return addr->is_joined;
1730}
1731
1738
1745#if defined(CONFIG_NET_NATIVE_IPV4)
1746static inline struct in_addr *net_if_router_ipv4(struct net_if_router *router)
1747{
1748 return &router->address.in_addr;
1749}
1750#else
1751static inline struct in_addr *net_if_router_ipv4(struct net_if_router *router)
1752{
1753 static struct in_addr addr;
1754
1755 ARG_UNUSED(router);
1756
1757 return &addr;
1758}
1759#endif
1760
1771 struct in_addr *addr);
1772
1783 struct in_addr *addr);
1795 struct in_addr *addr,
1796 bool is_default,
1797 uint16_t router_lifetime);
1798
1807
1817 const struct in_addr *addr);
1818
1828 const struct in_addr *addr);
1829
1839#if defined(CONFIG_NET_NATIVE_IPV4)
1840struct net_if *net_if_ipv4_select_src_iface(const struct in_addr *dst);
1841#else
1843 const struct in_addr *dst)
1844{
1845 ARG_UNUSED(dst);
1846
1847 return NULL;
1848}
1849#endif
1850
1862#if defined(CONFIG_NET_NATIVE_IPV4)
1863const struct in_addr *net_if_ipv4_select_src_addr(struct net_if *iface,
1864 const struct in_addr *dst);
1865#else
1866static inline const struct in_addr *net_if_ipv4_select_src_addr(
1867 struct net_if *iface, const struct in_addr *dst)
1868{
1869 ARG_UNUSED(iface);
1870 ARG_UNUSED(dst);
1871
1872 return NULL;
1873}
1874#endif
1875
1885struct in_addr *net_if_ipv4_get_ll(struct net_if *iface,
1886 enum net_addr_state addr_state);
1887
1898 enum net_addr_state addr_state);
1899
1907 const struct in_addr *netmask);
1908
1918 const struct in_addr *netmask);
1919
1926void net_if_ipv4_set_gw(struct net_if *iface, const struct in_addr *gw);
1927
1936__syscall bool net_if_ipv4_set_gw_by_index(int index, const struct in_addr *gw);
1937
1948struct net_if *net_if_select_src_iface(const struct sockaddr *dst);
1949
1958typedef void (*net_if_link_callback_t)(struct net_if *iface,
1959 struct net_linkaddr *dst,
1960 int status);
1961
1973
1976};
1977
1986
1993
2001void net_if_call_link_cb(struct net_if *iface, struct net_linkaddr *lladdr,
2002 int status);
2003
2014
2026
2037__syscall struct net_if *net_if_get_by_index(int index);
2038
2046int net_if_get_by_iface(struct net_if *iface);
2047
2055typedef void (*net_if_cb_t)(struct net_if *iface, void *user_data);
2056
2065
2073int net_if_up(struct net_if *iface);
2074
2082static inline bool net_if_is_up(struct net_if *iface)
2083{
2084 NET_ASSERT(iface);
2085
2086 return net_if_flag_is_set(iface, NET_IF_UP);
2087}
2088
2096int net_if_down(struct net_if *iface);
2097
2098#if defined(CONFIG_NET_PKT_TIMESTAMP) && defined(CONFIG_NET_NATIVE)
2106typedef void (*net_if_timestamp_callback_t)(struct net_pkt *pkt);
2107
2116struct net_if_timestamp_cb {
2118 sys_snode_t node;
2119
2123 struct net_pkt *pkt;
2124
2128 struct net_if *iface;
2129
2131 net_if_timestamp_callback_t cb;
2132};
2133
2144void net_if_register_timestamp_cb(struct net_if_timestamp_cb *handle,
2145 struct net_pkt *pkt,
2146 struct net_if *iface,
2147 net_if_timestamp_callback_t cb);
2148
2154void net_if_unregister_timestamp_cb(struct net_if_timestamp_cb *handle);
2155
2161void net_if_call_timestamp_cb(struct net_pkt *pkt);
2162
2163/*
2164 * @brief Add timestamped TX buffer to be handled
2165 *
2166 * @param pkt Timestamped buffer
2167 */
2168void net_if_add_tx_timestamp(struct net_pkt *pkt);
2169#endif /* CONFIG_NET_PKT_TIMESTAMP */
2170
2180int net_if_set_promisc(struct net_if *iface);
2181
2187void net_if_unset_promisc(struct net_if *iface);
2188
2197bool net_if_is_promisc(struct net_if *iface);
2198
2208static inline bool net_if_are_pending_tx_packets(struct net_if *iface)
2209{
2210#if defined(CONFIG_NET_POWER_MANAGEMENT)
2211 return !!iface->tx_pending;
2212#else
2213 ARG_UNUSED(iface);
2214
2215 return false;
2216#endif
2217}
2218
2219#ifdef CONFIG_NET_POWER_MANAGEMENT
2227int net_if_suspend(struct net_if *iface);
2228
2236int net_if_resume(struct net_if *iface);
2237
2245bool net_if_is_suspended(struct net_if *iface);
2246#endif /* CONFIG_NET_POWER_MANAGEMENT */
2247
2249struct net_if_api {
2250 void (*init)(struct net_if *iface);
2251};
2252
2253#if defined(CONFIG_NET_DHCPV4) && defined(CONFIG_NET_NATIVE_IPV4)
2254#define NET_IF_DHCPV4_INIT .dhcpv4.state = NET_DHCPV4_DISABLED,
2255#else
2256#define NET_IF_DHCPV4_INIT
2257#endif
2258
2259#define NET_IF_CONFIG_INIT \
2260 .config = { \
2261 .ip = { \
2262 }, \
2263 NET_IF_DHCPV4_INIT \
2264 }
2265
2266#define NET_IF_GET_NAME(dev_name, sfx) __net_if_##dev_name##_##sfx
2267#define NET_IF_DEV_GET_NAME(dev_name, sfx) __net_if_dev_##dev_name##_##sfx
2268
2269#define NET_IF_GET(dev_name, sfx) \
2270 ((struct net_if *)&NET_IF_GET_NAME(dev_name, sfx))
2271
2272#define NET_IF_INIT(dev_name, sfx, _l2, _mtu, _num_configs) \
2273 static STRUCT_SECTION_ITERABLE(net_if_dev, \
2274 NET_IF_DEV_GET_NAME(dev_name, sfx)) = { \
2275 .dev = &(DEVICE_NAME_GET(dev_name)), \
2276 .l2 = &(NET_L2_GET_NAME(_l2)), \
2277 .l2_data = &(NET_L2_GET_DATA(dev_name, sfx)), \
2278 .mtu = _mtu, \
2279 }; \
2280 static Z_DECL_ALIGN(struct net_if) \
2281 NET_IF_GET_NAME(dev_name, sfx)[_num_configs] \
2282 __used __in_section(_net_if, static, \
2283 dev_name) = { \
2284 [0 ... (_num_configs - 1)] = { \
2285 .if_dev = &(NET_IF_DEV_GET_NAME(dev_name, sfx)), \
2286 NET_IF_CONFIG_INIT \
2287 } \
2288 }
2289
2290#define NET_IF_OFFLOAD_INIT(dev_name, sfx, _mtu) \
2291 static STRUCT_SECTION_ITERABLE(net_if_dev, \
2292 NET_IF_DEV_GET_NAME(dev_name, sfx)) = { \
2293 .dev = &(DEVICE_NAME_GET(dev_name)), \
2294 .mtu = _mtu, \
2295 }; \
2296 static Z_DECL_ALIGN(struct net_if) \
2297 NET_IF_GET_NAME(dev_name, sfx)[NET_IF_MAX_CONFIGS] \
2298 __used __in_section(_net_if, static, \
2299 dev_name) = { \
2300 [0 ... (NET_IF_MAX_CONFIGS - 1)] = { \
2301 .if_dev = &(NET_IF_DEV_GET_NAME(dev_name, sfx)), \
2302 NET_IF_CONFIG_INIT \
2303 } \
2304 }
2305
2308/* Network device initialization macros */
2309
2310#define Z_NET_DEVICE_INIT(node_id, dev_name, drv_name, init_fn, \
2311 pm_action_cb, data, cfg, prio, api, l2, \
2312 l2_ctx_type, mtu) \
2313 Z_DEVICE_STATE_DEFINE(node_id, dev_name) \
2314 Z_DEVICE_DEFINE(node_id, dev_name, drv_name, init_fn, \
2315 pm_action_cb, data, \
2316 cfg, POST_KERNEL, prio, api, \
2317 &Z_DEVICE_STATE_NAME(dev_name)); \
2318 NET_L2_DATA_INIT(dev_name, 0, l2_ctx_type); \
2319 NET_IF_INIT(dev_name, 0, l2, mtu, NET_IF_MAX_CONFIGS)
2320
2342#define NET_DEVICE_INIT(dev_name, drv_name, init_fn, pm_action_cb, \
2343 data, cfg, prio, api, l2, \
2344 l2_ctx_type, mtu) \
2345 Z_NET_DEVICE_INIT(DT_INVALID_NODE, dev_name, drv_name, init_fn, \
2346 pm_action_cb, data, cfg, prio, api, l2, \
2347 l2_ctx_type, mtu)
2348
2369#define NET_DEVICE_DT_DEFINE(node_id, init_fn, pm_action_cb, data, cfg, \
2370 prio, api, l2, l2_ctx_type, mtu) \
2371 Z_NET_DEVICE_INIT(node_id, Z_DEVICE_DT_DEV_NAME(node_id), \
2372 DT_PROP_OR(node_id, label, ""), init_fn, \
2373 pm_action_cb, data, cfg, prio, api, l2, \
2374 l2_ctx_type, mtu)
2375
2386#define NET_DEVICE_DT_INST_DEFINE(inst, ...) \
2387 NET_DEVICE_DT_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
2388
2389#define Z_NET_DEVICE_INIT_INSTANCE(node_id, dev_name, drv_name, \
2390 instance, init_fn, pm_action_cb, \
2391 data, cfg, prio, api, l2, \
2392 l2_ctx_type, mtu) \
2393 Z_DEVICE_STATE_DEFINE(node_id, dev_name) \
2394 Z_DEVICE_DEFINE(node_id, dev_name, drv_name, init_fn, \
2395 pm_action_cb, data, cfg, POST_KERNEL, \
2396 prio, api, &Z_DEVICE_STATE_NAME(dev_name)); \
2397 NET_L2_DATA_INIT(dev_name, instance, l2_ctx_type); \
2398 NET_IF_INIT(dev_name, instance, l2, mtu, NET_IF_MAX_CONFIGS)
2399
2425#define NET_DEVICE_INIT_INSTANCE(dev_name, drv_name, instance, init_fn, \
2426 pm_action_cb, data, cfg, prio, \
2427 api, l2, l2_ctx_type, mtu) \
2428 Z_NET_DEVICE_INIT_INSTANCE(DT_INVALID_NODE, dev_name, drv_name, \
2429 instance, init_fn, pm_action_cb, \
2430 data, cfg, prio, api, l2, \
2431 l2_ctx_type, mtu)
2432
2457#define NET_DEVICE_DT_DEFINE_INSTANCE(node_id, instance, init_fn, \
2458 pm_action_cb, data, cfg, prio, \
2459 api, l2, l2_ctx_type, mtu) \
2460 Z_NET_DEVICE_INIT_INSTANCE(node_id, \
2461 Z_DEVICE_DT_DEV_NAME(node_id), \
2462 DT_LABEL(node_id), instance, \
2463 pm_action_cb, data, cfg, prio, api, \
2464 l2, l2_ctx_type, mtu)
2465
2477#define NET_DEVICE_DT_INST_DEFINE_INSTANCE(inst, ...) \
2478 NET_DEVICE_DT_DEFINE_INSTANCE(DT_DRV_INST(inst), __VA_ARGS__)
2479
2480#define Z_NET_DEVICE_OFFLOAD_INIT(node_id, dev_name, drv_name, init_fn, \
2481 pm_action_cb, data, cfg, prio, \
2482 api, mtu) \
2483 Z_DEVICE_STATE_DEFINE(node_id, dev_name) \
2484 Z_DEVICE_DEFINE(node_id, dev_name, drv_name, init_fn, \
2485 pm_action_cb, data, cfg, POST_KERNEL, prio, api, \
2486 &Z_DEVICE_STATE_NAME(dev_name)); \
2487 NET_IF_OFFLOAD_INIT(dev_name, 0, mtu)
2488
2510#define NET_DEVICE_OFFLOAD_INIT(dev_name, drv_name, init_fn, \
2511 pm_action_cb, data, cfg, prio, api, mtu)\
2512 Z_NET_DEVICE_OFFLOAD_INIT(DT_INVALID_NODE, dev_name, drv_name, \
2513 init_fn, pm_action_cb, data, cfg, prio,\
2514 api, mtu)
2515
2536#define NET_DEVICE_DT_OFFLOAD_DEFINE(node_id, init_fn, pm_action_cb, \
2537 data, cfg, prio, api, mtu) \
2538 Z_NET_DEVICE_OFFLOAD_INIT(node_id, Z_DEVICE_DT_DEV_NAME(node_id), \
2539 DT_PROP_OR(node_id, label, NULL), \
2540 init_fn, pm_action_cb, data, cfg, \
2541 prio, api, mtu)
2542
2554#define NET_DEVICE_DT_INST_OFFLOAD_DEFINE(inst, ...) \
2555 NET_DEVICE_DT_OFFLOAD_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
2556
2557#ifdef __cplusplus
2558}
2559#endif
2560
2561#include <syscalls/net_if.h>
2562
2567#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.
static void atomic_set_bit(atomic_t *target, int bit)
Atomically set a bit.
Definition: atomic.h:217
static bool atomic_test_bit(const atomic_t *target, int bit)
Atomically test a bit.
Definition: atomic.h:131
static void atomic_clear_bit(atomic_t *target, int bit)
Atomically clear a bit.
Definition: atomic.h:198
#define ATOMIC_DEFINE(name, num_bits)
Define an array of atomic variables.
Definition: atomic.h:114
static bool atomic_test_and_set_bit(atomic_t *target, int bit)
Atomically set a bit.
Definition: atomic.h:176
net_addr_state
Definition: net_ip.h:439
net_addr_type
Definition: net_ip.h:447
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 * net_if_get_first_up(void)
Get the first network interface which is 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.
void net_if_set_default(struct net_if *iface)
Set the default network interface.
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.
int(* net_socket_create_t)(int, int, int)
A function prototype to create an offloaded socket. The prototype is compatible with socket() functio...
Definition: net_if.h:420
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:1751
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:578
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_mcast_monitor(struct net_if *iface, const struct net_addr *addr, bool is_joined)
Call registered multicast monitors.
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:1958
static void * net_if_l2_data(struct net_if *iface)
Get a pointer to the interface L2 private data.
Definition: net_if.h:604
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:2208
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:521
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.
static struct net_linkaddr * net_if_get_link_addr(struct net_if *iface)
Get an network interface's link address.
Definition: net_if.h:725
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:1488
static struct net_offload * net_if_offload(struct net_if *iface)
Return the IP offload plugin.
Definition: net_if.h:654
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:813
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:505
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:636
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.
void(* net_if_mcast_callback_t)(struct net_if *iface, const struct net_addr *addr, bool is_joined)
Define callback that is called whenever IPv6 multicast address group is joined or left.
Definition: net_if.h:1109
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:846
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:2082
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:1428
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:750
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 void net_if_socket_offload_set(struct net_if *iface, net_socket_create_t socket_offload)
Set the function to create an offloaded socket.
Definition: net_if.h:689
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:1400
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:1725
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:1246
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:772
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:1381
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:1175
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:831
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:1866
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:1441
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:1292
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:1460
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:1510
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:551
static struct net_if_config * net_if_config_get(struct net_if *iface)
Get network interface IP config.
Definition: net_if.h:893
static struct net_if_config * net_if_get_config(struct net_if *iface)
Return network configuration for this network interface.
Definition: net_if.h:737
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:862
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:616
void(* net_if_cb_t)(struct net_if *iface, void *user_data)
Callback used while iterating over network interfaces.
Definition: net_if.h:2055
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:672
void net_if_ipv4_maddr_join(struct net_if_mcast_addr *addr)
Mark a given multicast address to be joined.
static net_socket_create_t net_if_socket_offload(struct net_if *iface)
Return the function to create an offloaded socket.
Definition: net_if.h:707
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:1842
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:535
@ 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:29
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:90
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
__UINT16_TYPE__ uint16_t
Definition: stdint.h:89
__INT64_TYPE__ int64_t
Definition: stdint.h:75
Runtime device structure (in ROM) per driver instance.
Definition: device.h:456
Definition: net_ip.h:139
Definition: net_ip.h:151
Definition: kernel.h:2186
Definition: thread.h:231
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:435
const struct net_l2 *const l2
Definition: net_if.h:440
void * l2_data
Definition: net_if.h:443
uint16_t mtu
Definition: net_if.h:461
const struct device * dev
Definition: net_if.h:437
struct net_linkaddr link_addr
Definition: net_if.h:449
atomic_t flags[ATOMIC_BITMAP_SIZE(NET_IF_NUM_FLAGS)]
Definition: net_if.h:446
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:1121
sys_snode_t node
Definition: net_if.h:1123
net_if_mcast_callback_t cb
Definition: net_if.h:1129
struct net_if * iface
Definition: net_if.h:1126
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:478
struct net_if_dev * if_dev
Definition: net_if.h:480
struct net_if_config config
Definition: net_if.h:488
Network L2 structure.
Definition: net_l2.h:54
Hardware link address structure.
Definition: net_linkaddr.h:67
uint8_t * addr
Definition: net_linkaddr.h:69
uint8_t type
Definition: net_linkaddr.h:75
uint8_t len
Definition: net_linkaddr.h:72
Network packet.
Definition: net_pkt.h:59
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:341
static const intptr_t user_data[5]
Definition: main.c:590