Zephyr Project API 3.7.2
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
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>
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_DHCPV6) && defined(CONFIG_NET_NATIVE_IPV6)
37#include <zephyr/net/dhcpv6.h>
38#endif
39#if defined(CONFIG_NET_IPV4_AUTO) && defined(CONFIG_NET_NATIVE_IPV4)
41#endif
42
43#ifdef __cplusplus
44extern "C" {
45#endif
46
54 struct net_addr address;
55
60
61#if defined(CONFIG_NET_NATIVE_IPV6)
62 struct net_timeout lifetime;
63#endif
64
67
70
71#if defined(CONFIG_NET_NATIVE_IPV6)
72#if defined(CONFIG_NET_IPV6_PE)
76 uint32_t addr_create_time;
77
80 uint32_t addr_preferred_lifetime;
81
86 int32_t addr_timeout;
87#endif
88#endif /* CONFIG_NET_NATIVE_IPV6 */
89
90 union {
91#if defined(CONFIG_NET_IPV6_DAD)
92 struct {
94 sys_snode_t dad_node;
95
97 sys_snode_t dad_need_node;
98
100 uint32_t dad_start;
101
103 uint8_t dad_count;
104 };
105#endif /* CONFIG_NET_IPV6_DAD */
106#if defined(CONFIG_NET_IPV4_ACD)
107 struct {
109 sys_snode_t acd_node;
110
112 sys_snode_t acd_need_node;
113
115 k_timepoint_t acd_timeout;
116
118 uint8_t acd_count;
119
121 uint8_t acd_state;
122 };
123#endif /* CONFIG_NET_IPV4_ACD */
124 };
125
126#if defined(CONFIG_NET_IPV6_DAD) || defined(CONFIG_NET_IPV4_ACD)
128 uint8_t ifindex;
129#endif
130
133
136
139
144
147
148 uint8_t _unused : 3;
149};
150
158 struct net_addr address;
159
160#if defined(CONFIG_NET_IPV4_IGMPV3)
162 struct net_addr sources[CONFIG_NET_IF_MCAST_IPV4_SOURCE_COUNT];
163
165 uint16_t sources_len;
166
168 uint8_t record_type;
169#endif
170
173
176
177 uint8_t _unused : 6;
178};
179
188
191
193 struct net_if *iface;
194
197
200
203
204 uint8_t _unused : 6;
205};
206
215
217 struct net_addr address;
218
220 struct net_if *iface;
221
224
227
230
233
236
237 uint8_t _unused : 5;
238};
239
297
308
309#if defined(CONFIG_NET_OFFLOAD)
310struct net_offload;
311#endif /* CONFIG_NET_OFFLOAD */
312
314#if defined(CONFIG_NET_NATIVE_IPV6)
315#define NET_IF_MAX_IPV6_ADDR CONFIG_NET_IF_UNICAST_IPV6_ADDR_COUNT
316#define NET_IF_MAX_IPV6_MADDR CONFIG_NET_IF_MCAST_IPV6_ADDR_COUNT
317#define NET_IF_MAX_IPV6_PREFIX CONFIG_NET_IF_IPV6_PREFIX_COUNT
318#else
319#define NET_IF_MAX_IPV6_ADDR 0
320#define NET_IF_MAX_IPV6_MADDR 0
321#define NET_IF_MAX_IPV6_PREFIX 0
322#endif
323/* @endcond */
324
328 struct net_if_addr unicast[NET_IF_MAX_IPV6_ADDR];
329
331 struct net_if_mcast_addr mcast[NET_IF_MAX_IPV6_MADDR];
332
334 struct net_if_ipv6_prefix prefix[NET_IF_MAX_IPV6_PREFIX];
335
338
341
344
345#if defined(CONFIG_NET_IPV6_PE)
350 uint32_t desync_factor;
351#endif /* CONFIG_NET_IPV6_PE */
352
353#if defined(CONFIG_NET_IPV6_ND) && defined(CONFIG_NET_NATIVE_IPV6)
355 sys_snode_t rs_node;
356
357 /* RS start time */
358 uint32_t rs_start;
359
361 uint8_t rs_count;
362#endif
363
366
369};
370
371#if defined(CONFIG_NET_DHCPV6) && defined(CONFIG_NET_NATIVE_IPV6)
373struct net_if_dhcpv6 {
375 sys_snode_t node;
376
378 struct net_dhcpv6_duid_storage clientid;
379
381 struct net_dhcpv6_duid_storage serverid;
382
384 enum net_dhcpv6_state state;
385
387 struct net_dhcpv6_params params;
388
391
393 uint64_t exchange_start;
394
396 uint64_t t1;
397
399 uint64_t t2;
400
404 uint64_t expire;
405
407 uint32_t addr_iaid;
408
410 uint32_t prefix_iaid;
411
413 uint32_t retransmit_timeout;
414
416 int16_t server_preference;
417
419 uint8_t retransmissions;
420
422 uint8_t tid[DHCPV6_TID_SIZE];
423
425 uint8_t prefix_len;
426
428 struct in6_addr prefix;
429
431 struct in6_addr addr;
432};
433#endif /* defined(CONFIG_NET_DHCPV6) && defined(CONFIG_NET_NATIVE_IPV6) */
434
436#if defined(CONFIG_NET_NATIVE_IPV4)
437#define NET_IF_MAX_IPV4_ADDR CONFIG_NET_IF_UNICAST_IPV4_ADDR_COUNT
438#define NET_IF_MAX_IPV4_MADDR CONFIG_NET_IF_MCAST_IPV4_ADDR_COUNT
439#else
440#define NET_IF_MAX_IPV4_ADDR 0
441#define NET_IF_MAX_IPV4_MADDR 0
442#endif
456
460 struct net_if_addr_ipv4 unicast[NET_IF_MAX_IPV4_ADDR];
461
463 struct net_if_mcast_addr mcast[NET_IF_MAX_IPV4_MADDR];
464
466 struct in_addr gw;
467
470
473
474#if defined(CONFIG_NET_IPV4_ACD)
476 uint8_t conflict_cnt;
477#endif
478};
479
480#if defined(CONFIG_NET_DHCPV4) && defined(CONFIG_NET_NATIVE_IPV4)
481struct net_if_dhcpv4 {
483 sys_snode_t node;
484
486 int64_t timer_start;
487
489 uint32_t request_time;
490
491 uint32_t xid;
492
494 uint32_t lease_time;
495
497 uint32_t renewal_time;
498
500 uint32_t rebinding_time;
501
503 struct in_addr server_id;
504
506 struct in_addr requested_ip;
507
509 struct in_addr netmask;
510
515 enum net_dhcpv4_state state;
516
518 uint8_t attempts;
519
521 struct in_addr request_server_addr;
522
524 struct in_addr response_src_addr;
525
526#ifdef CONFIG_NET_DHCPV4_OPTION_NTP_SERVER
528 struct in_addr ntp_addr;
529#endif
530};
531#endif /* CONFIG_NET_DHCPV4 */
532
533#if defined(CONFIG_NET_IPV4_AUTO) && defined(CONFIG_NET_NATIVE_IPV4)
534struct net_if_ipv4_autoconf {
536 struct net_if *iface;
537
539 struct in_addr requested_ip;
540
544};
545#endif /* CONFIG_NET_IPV4_AUTO */
546
548/* We always need to have at least one IP config */
549#define NET_IF_MAX_CONFIGS 1
555struct net_if_ip {
556#if defined(CONFIG_NET_NATIVE_IPV6)
557 struct net_if_ipv6 *ipv6;
558#endif /* CONFIG_NET_IPV6 */
559
560#if defined(CONFIG_NET_NATIVE_IPV4)
561 struct net_if_ipv4 *ipv4;
562#endif /* CONFIG_NET_IPV4 */
563};
564
569#if defined(CONFIG_NET_IP)
571 struct net_if_ip ip;
572#endif
573
574#if defined(CONFIG_NET_DHCPV4) && defined(CONFIG_NET_NATIVE_IPV4)
575 struct net_if_dhcpv4 dhcpv4;
576#endif /* CONFIG_NET_DHCPV4 */
577
578#if defined(CONFIG_NET_DHCPV6) && defined(CONFIG_NET_NATIVE_IPV6)
579 struct net_if_dhcpv6 dhcpv6;
580#endif /* CONFIG_NET_DHCPV6 */
581
582#if defined(CONFIG_NET_IPV4_AUTO) && defined(CONFIG_NET_NATIVE_IPV4)
583 struct net_if_ipv4_autoconf ipv4auto;
584#endif /* CONFIG_NET_IPV4_AUTO */
585
586#if defined(CONFIG_NET_L2_VIRTUAL)
591 sys_slist_t virtual_interfaces;
592#endif /* CONFIG_NET_L2_VIRTUAL */
593
594#if defined(CONFIG_NET_INTERFACE_NAME)
599 char name[CONFIG_NET_INTERFACE_NAME_LEN + 1];
600#endif
601};
602
622
629typedef int (*net_socket_create_t)(int, int, int);
630
647 const struct device *dev;
648
650 const struct net_l2 * const l2;
651
653 void *l2_data;
654
656 ATOMIC_DEFINE(flags, NET_IF_NUM_FLAGS);
657
660
661#if defined(CONFIG_NET_OFFLOAD)
667 struct net_offload *offload;
668#endif /* CONFIG_NET_OFFLOAD */
669
672
673#if defined(CONFIG_NET_SOCKETS_OFFLOAD)
677 net_socket_create_t socket_offload;
678#endif /* CONFIG_NET_SOCKETS_OFFLOAD */
679
682};
683
691struct net_if {
694
695#if defined(CONFIG_NET_STATISTICS_PER_INTERFACE)
697 struct net_stats stats;
698#endif /* CONFIG_NET_STATISTICS_PER_INTERFACE */
699
702
703#if defined(CONFIG_NET_POWER_MANAGEMENT)
708 int tx_pending;
709#endif
710
712 struct k_mutex lock;
713
716
722
727
729 uint8_t _unused : 6;
730};
731
734static inline void net_if_lock(struct net_if *iface)
735{
736 NET_ASSERT(iface);
737
738 (void)k_mutex_lock(&iface->lock, K_FOREVER);
739}
740
741static inline void net_if_unlock(struct net_if *iface)
742{
743 NET_ASSERT(iface);
744
745 k_mutex_unlock(&iface->lock);
746}
747
748static inline bool net_if_flag_is_set(struct net_if *iface,
749 enum net_if_flag value);
750
751static inline void net_if_tx_lock(struct net_if *iface)
752{
753 NET_ASSERT(iface);
754
756 return;
757 }
758
759 (void)k_mutex_lock(&iface->tx_lock, K_FOREVER);
760}
761
762static inline void net_if_tx_unlock(struct net_if *iface)
763{
764 NET_ASSERT(iface);
765
767 return;
768 }
769
770 k_mutex_unlock(&iface->tx_lock);
771}
772
781static inline void net_if_flag_set(struct net_if *iface,
782 enum net_if_flag value)
783{
784 NET_ASSERT(iface);
785 NET_ASSERT(iface->if_dev);
786
787 atomic_set_bit(iface->if_dev->flags, value);
788}
789
798static inline bool net_if_flag_test_and_set(struct net_if *iface,
799 enum net_if_flag value)
800{
801 NET_ASSERT(iface);
802 NET_ASSERT(iface->if_dev);
803
804 return atomic_test_and_set_bit(iface->if_dev->flags, value);
805}
806
813static inline void net_if_flag_clear(struct net_if *iface,
814 enum net_if_flag value)
815{
816 NET_ASSERT(iface);
817 NET_ASSERT(iface->if_dev);
818
819 atomic_clear_bit(iface->if_dev->flags, value);
820}
821
830static inline bool net_if_flag_test_and_clear(struct net_if *iface,
831 enum net_if_flag value)
832{
833 NET_ASSERT(iface);
834 NET_ASSERT(iface->if_dev);
835
836 return atomic_test_and_clear_bit(iface->if_dev->flags, value);
837}
838
847static inline bool net_if_flag_is_set(struct net_if *iface,
848 enum net_if_flag value)
849{
850 NET_ASSERT(iface);
851 NET_ASSERT(iface->if_dev);
852
853 if (iface == NULL) {
854 return false;
855 }
856
857 return atomic_test_bit(iface->if_dev->flags, value);
858}
859
869 struct net_if *iface, enum net_if_oper_state oper_state)
870{
871 NET_ASSERT(iface);
872 NET_ASSERT(iface->if_dev);
873
874 if (oper_state >= NET_IF_OPER_UNKNOWN && oper_state <= NET_IF_OPER_UP) {
875 iface->if_dev->oper_state = oper_state;
876 }
877
878 return iface->if_dev->oper_state;
879}
880
888static inline enum net_if_oper_state net_if_oper_state(struct net_if *iface)
889{
890 NET_ASSERT(iface);
891 NET_ASSERT(iface->if_dev);
892
893 return iface->if_dev->oper_state;
894}
895
904enum net_verdict net_if_send_data(struct net_if *iface, struct net_pkt *pkt);
905
913static inline const struct net_l2 *net_if_l2(struct net_if *iface)
914{
915 if (!iface || !iface->if_dev) {
916 return NULL;
917 }
918
919 return iface->if_dev->l2;
920}
921
930enum net_verdict net_if_recv_data(struct net_if *iface, struct net_pkt *pkt);
931
939static inline void *net_if_l2_data(struct net_if *iface)
940{
941 NET_ASSERT(iface);
942 NET_ASSERT(iface->if_dev);
943
944 return iface->if_dev->l2_data;
945}
946
954static inline const struct device *net_if_get_device(struct net_if *iface)
955{
956 NET_ASSERT(iface);
957 NET_ASSERT(iface->if_dev);
958
959 return iface->if_dev->dev;
960}
961
968void net_if_queue_tx(struct net_if *iface, struct net_pkt *pkt);
969
977static inline bool net_if_is_ip_offloaded(struct net_if *iface)
978{
979#if defined(CONFIG_NET_OFFLOAD)
980 return (iface != NULL && iface->if_dev != NULL &&
981 iface->if_dev->offload != NULL);
982#else
983 ARG_UNUSED(iface);
984
985 return false;
986#endif
987}
988
996bool net_if_is_offloaded(struct net_if *iface);
997
1005static inline struct net_offload *net_if_offload(struct net_if *iface)
1006{
1007#if defined(CONFIG_NET_OFFLOAD)
1008 NET_ASSERT(iface);
1009 NET_ASSERT(iface->if_dev);
1010
1011 return iface->if_dev->offload;
1012#else
1013 ARG_UNUSED(iface);
1014
1015 return NULL;
1016#endif
1017}
1018
1026static inline bool net_if_is_socket_offloaded(struct net_if *iface)
1027{
1028#if defined(CONFIG_NET_SOCKETS_OFFLOAD)
1029 NET_ASSERT(iface);
1030 NET_ASSERT(iface->if_dev);
1031
1032 return (iface->if_dev->socket_offload != NULL);
1033#else
1034 ARG_UNUSED(iface);
1035
1036 return false;
1037#endif
1038}
1039
1046static inline void net_if_socket_offload_set(
1047 struct net_if *iface, net_socket_create_t socket_offload)
1048{
1049#if defined(CONFIG_NET_SOCKETS_OFFLOAD)
1050 NET_ASSERT(iface);
1051 NET_ASSERT(iface->if_dev);
1052
1053 iface->if_dev->socket_offload = socket_offload;
1054#else
1055 ARG_UNUSED(iface);
1056 ARG_UNUSED(socket_offload);
1057#endif
1058}
1059
1068{
1069#if defined(CONFIG_NET_SOCKETS_OFFLOAD)
1070 NET_ASSERT(iface);
1071 NET_ASSERT(iface->if_dev);
1072
1073 return iface->if_dev->socket_offload;
1074#else
1075 ARG_UNUSED(iface);
1076
1077 return NULL;
1078#endif
1079}
1080
1088static inline struct net_linkaddr *net_if_get_link_addr(struct net_if *iface)
1089{
1090 NET_ASSERT(iface);
1091 NET_ASSERT(iface->if_dev);
1092
1093 return &iface->if_dev->link_addr;
1094}
1095
1103static inline struct net_if_config *net_if_get_config(struct net_if *iface)
1104{
1105 NET_ASSERT(iface);
1106
1107 return &iface->config;
1108}
1109
1115#if defined(CONFIG_NET_IPV6_DAD) && defined(CONFIG_NET_NATIVE_IPV6)
1116void net_if_start_dad(struct net_if *iface);
1117#else
1118static inline void net_if_start_dad(struct net_if *iface)
1119{
1120 ARG_UNUSED(iface);
1121}
1122#endif
1123
1129void net_if_start_rs(struct net_if *iface);
1130
1131
1137#if defined(CONFIG_NET_IPV6_ND) && defined(CONFIG_NET_NATIVE_IPV6)
1138void net_if_stop_rs(struct net_if *iface);
1139#else
1140static inline void net_if_stop_rs(struct net_if *iface)
1141{
1142 ARG_UNUSED(iface);
1143}
1144#endif /* CONFIG_NET_IPV6_ND */
1145
1158#if defined(CONFIG_NET_IPV6_ND) && defined(CONFIG_NET_NATIVE_IPV6)
1159void net_if_nbr_reachability_hint(struct net_if *iface, const struct in6_addr *ipv6_addr);
1160#else
1161static inline void net_if_nbr_reachability_hint(struct net_if *iface,
1162 const struct in6_addr *ipv6_addr)
1163{
1164 ARG_UNUSED(iface);
1165 ARG_UNUSED(ipv6_addr);
1166}
1167#endif
1168
1171static inline int net_if_set_link_addr_unlocked(struct net_if *iface,
1172 uint8_t *addr, uint8_t len,
1173 enum net_link_type type)
1174{
1175 if (net_if_flag_is_set(iface, NET_IF_RUNNING)) {
1176 return -EPERM;
1177 }
1178
1179 net_if_get_link_addr(iface)->addr = addr;
1180 net_if_get_link_addr(iface)->len = len;
1181 net_if_get_link_addr(iface)->type = type;
1182
1183 net_hostname_set_postfix(addr, len);
1184
1185 return 0;
1186}
1187
1188int net_if_set_link_addr_locked(struct net_if *iface,
1189 uint8_t *addr, uint8_t len,
1190 enum net_link_type type);
1191
1192#if CONFIG_NET_IF_LOG_LEVEL >= LOG_LEVEL_DBG
1193extern int net_if_addr_unref_debug(struct net_if *iface,
1194 sa_family_t family,
1195 const void *addr,
1196 struct net_if_addr **ifaddr,
1197 const char *caller, int line);
1198#define net_if_addr_unref(iface, family, addr, ifaddr) \
1199 net_if_addr_unref_debug(iface, family, addr, ifaddr, __func__, __LINE__)
1200
1201extern struct net_if_addr *net_if_addr_ref_debug(struct net_if *iface,
1202 sa_family_t family,
1203 const void *addr,
1204 const char *caller,
1205 int line);
1206#define net_if_addr_ref(iface, family, addr) \
1207 net_if_addr_ref_debug(iface, family, addr, __func__, __LINE__)
1208#else
1209extern int net_if_addr_unref(struct net_if *iface,
1210 sa_family_t family,
1211 const void *addr,
1212 struct net_if_addr **ifaddr);
1213extern struct net_if_addr *net_if_addr_ref(struct net_if *iface,
1214 sa_family_t family,
1215 const void *addr);
1216#endif /* CONFIG_NET_IF_LOG_LEVEL */
1217
1231static inline int net_if_set_link_addr(struct net_if *iface,
1232 uint8_t *addr, uint8_t len,
1233 enum net_link_type type)
1234{
1235#if defined(CONFIG_NET_RAW_MODE)
1236 return net_if_set_link_addr_unlocked(iface, addr, len, type);
1237#else
1238 return net_if_set_link_addr_locked(iface, addr, len, type);
1239#endif
1240}
1241
1249static inline uint16_t net_if_get_mtu(struct net_if *iface)
1250{
1251 if (iface == NULL) {
1252 return 0U;
1253 }
1254
1255 NET_ASSERT(iface->if_dev);
1256
1257 return iface->if_dev->mtu;
1258}
1259
1266static inline void net_if_set_mtu(struct net_if *iface,
1267 uint16_t mtu)
1268{
1269 if (iface == NULL) {
1270 return;
1271 }
1272
1273 NET_ASSERT(iface->if_dev);
1274
1275 iface->if_dev->mtu = mtu;
1276}
1277
1284static inline void net_if_addr_set_lf(struct net_if_addr *ifaddr,
1285 bool is_infinite)
1286{
1287 NET_ASSERT(ifaddr);
1288
1289 ifaddr->is_infinite = is_infinite;
1290}
1291
1300
1308struct net_if *net_if_lookup_by_dev(const struct device *dev);
1309
1317static inline struct net_if_config *net_if_config_get(struct net_if *iface)
1318{
1319 NET_ASSERT(iface);
1320
1321 return &iface->config;
1322}
1323
1329void net_if_router_rm(struct net_if_router *router);
1330
1336void net_if_set_default(struct net_if *iface);
1337
1344
1353struct net_if *net_if_get_first_by_type(const struct net_l2 *l2);
1354
1362
1363#if defined(CONFIG_NET_L2_IEEE802154)
1370static inline struct net_if *net_if_get_ieee802154(void)
1371{
1372 return net_if_get_first_by_type(&NET_L2_GET_NAME(IEEE802154));
1373}
1374#endif /* CONFIG_NET_L2_IEEE802154 */
1375
1387 struct net_if_ipv6 **ipv6);
1388
1397
1407 struct net_if **iface);
1408
1418 struct in6_addr *addr);
1419
1428__syscall int net_if_ipv6_addr_lookup_by_index(const struct in6_addr *addr);
1429
1441 struct in6_addr *addr,
1443 uint32_t vlifetime);
1444
1456 struct in6_addr *addr,
1458 uint32_t vlifetime);
1459
1467 uint32_t vlifetime);
1468
1477bool net_if_ipv6_addr_rm(struct net_if *iface, const struct in6_addr *addr);
1478
1488 const struct in6_addr *addr);
1489
1498typedef void (*net_if_ip_addr_cb_t)(struct net_if *iface,
1499 struct net_if_addr *addr,
1500 void *user_data);
1501
1511 void *user_data);
1512
1522 const struct in6_addr *addr);
1523
1532bool net_if_ipv6_maddr_rm(struct net_if *iface, const struct in6_addr *addr);
1533
1542typedef void (*net_if_ip_maddr_cb_t)(struct net_if *iface,
1543 struct net_if_mcast_addr *maddr,
1544 void *user_data);
1545
1555 void *user_data);
1556
1568 struct net_if **iface);
1569
1580typedef void (*net_if_mcast_callback_t)(struct net_if *iface,
1581 const struct net_addr *addr,
1582 bool is_joined);
1583
1602
1612 struct net_if *iface,
1614
1621
1629void net_if_mcast_monitor(struct net_if *iface, const struct net_addr *addr,
1630 bool is_joined);
1631
1639 struct net_if_mcast_addr *addr);
1640
1648static inline bool net_if_ipv6_maddr_is_joined(struct net_if_mcast_addr *addr)
1649{
1650 NET_ASSERT(addr);
1651
1652 return addr->is_joined;
1653}
1654
1662 struct net_if_mcast_addr *addr);
1663
1673 const struct in6_addr *addr);
1674
1685 struct in6_addr *addr,
1686 uint8_t len);
1687
1699 struct in6_addr *prefix,
1700 uint8_t len,
1702
1712bool net_if_ipv6_prefix_rm(struct net_if *iface, struct in6_addr *addr,
1713 uint8_t len);
1714
1722 bool is_infinite)
1723{
1724 prefix->is_infinite = is_infinite;
1725}
1726
1735
1742
1753bool net_if_ipv6_addr_onlink(struct net_if **iface, struct in6_addr *addr);
1754
1761#if defined(CONFIG_NET_NATIVE_IPV6)
1762static inline struct in6_addr *net_if_router_ipv6(struct net_if_router *router)
1763{
1764 NET_ASSERT(router);
1765
1766 return &router->address.in6_addr;
1767}
1768#else
1769static inline struct in6_addr *net_if_router_ipv6(struct net_if_router *router)
1770{
1771 static struct in6_addr addr;
1772
1773 ARG_UNUSED(router);
1774
1775 return &addr;
1776}
1777#endif
1778
1789 struct in6_addr *addr);
1790
1801 struct in6_addr *addr);
1802
1811
1822 struct in6_addr *addr,
1823 uint16_t router_lifetime);
1824
1833
1843
1851
1854/* The old hop limit setter function is deprecated because the naming
1855 * of it was incorrect. The API name was missing "_if_" so this function
1856 * should not be used.
1857 */
1858__deprecated
1859static inline void net_ipv6_set_hop_limit(struct net_if *iface,
1860 uint8_t hop_limit)
1861{
1862 net_if_ipv6_set_hop_limit(iface, hop_limit);
1863}
1864
1876
1884
1892 uint32_t reachable_time)
1893{
1894#if defined(CONFIG_NET_NATIVE_IPV6)
1895 NET_ASSERT(iface);
1896
1897 if (!iface->config.ip.ipv6) {
1898 return;
1899 }
1900
1901 iface->config.ip.ipv6->base_reachable_time = reachable_time;
1902#else
1903 ARG_UNUSED(iface);
1904 ARG_UNUSED(reachable_time);
1905
1906#endif
1907}
1908
1917{
1918#if defined(CONFIG_NET_NATIVE_IPV6)
1919 NET_ASSERT(iface);
1920
1921 if (!iface->config.ip.ipv6) {
1922 return 0;
1923 }
1924
1925 return iface->config.ip.ipv6->reachable_time;
1926#else
1927 ARG_UNUSED(iface);
1928 return 0;
1929#endif
1930}
1931
1940
1947static inline void net_if_ipv6_set_reachable_time(struct net_if_ipv6 *ipv6)
1948{
1949#if defined(CONFIG_NET_NATIVE_IPV6)
1950 if (ipv6 == NULL) {
1951 return;
1952 }
1953
1955#else
1956 ARG_UNUSED(ipv6);
1957#endif
1958}
1959
1966static inline void net_if_ipv6_set_retrans_timer(struct net_if *iface,
1967 uint32_t retrans_timer)
1968{
1969#if defined(CONFIG_NET_NATIVE_IPV6)
1970 NET_ASSERT(iface);
1971
1972 if (!iface->config.ip.ipv6) {
1973 return;
1974 }
1975
1976 iface->config.ip.ipv6->retrans_timer = retrans_timer;
1977#else
1978 ARG_UNUSED(iface);
1979 ARG_UNUSED(retrans_timer);
1980#endif
1981}
1982
1991{
1992#if defined(CONFIG_NET_NATIVE_IPV6)
1993 NET_ASSERT(iface);
1994
1995 if (!iface->config.ip.ipv6) {
1996 return 0;
1997 }
1998
1999 return iface->config.ip.ipv6->retrans_timer;
2000#else
2001 ARG_UNUSED(iface);
2002 return 0;
2003#endif
2004}
2005
2017#if defined(CONFIG_NET_NATIVE_IPV6)
2018const struct in6_addr *net_if_ipv6_select_src_addr(struct net_if *iface,
2019 const struct in6_addr *dst);
2020#else
2021static inline const struct in6_addr *net_if_ipv6_select_src_addr(
2022 struct net_if *iface, const struct in6_addr *dst)
2023{
2024 ARG_UNUSED(iface);
2025 ARG_UNUSED(dst);
2026
2027 return NULL;
2028}
2029#endif
2030
2044#if defined(CONFIG_NET_NATIVE_IPV6)
2045const struct in6_addr *net_if_ipv6_select_src_addr_hint(struct net_if *iface,
2046 const struct in6_addr *dst,
2047 int flags);
2048#else
2049static inline const struct in6_addr *net_if_ipv6_select_src_addr_hint(
2050 struct net_if *iface, const struct in6_addr *dst, int flags)
2051{
2052 ARG_UNUSED(iface);
2053 ARG_UNUSED(dst);
2054 ARG_UNUSED(flags);
2055
2056 return NULL;
2057}
2058#endif
2059
2069#if defined(CONFIG_NET_NATIVE_IPV6)
2070struct net_if *net_if_ipv6_select_src_iface(const struct in6_addr *dst);
2071#else
2073 const struct in6_addr *dst)
2074{
2075 ARG_UNUSED(dst);
2076
2077 return NULL;
2078}
2079#endif
2080
2090struct in6_addr *net_if_ipv6_get_ll(struct net_if *iface,
2091 enum net_addr_state addr_state);
2092
2103 struct net_if **iface);
2104
2112void net_if_ipv6_dad_failed(struct net_if *iface, const struct in6_addr *addr);
2113
2126 struct net_if **iface);
2127
2139 struct net_if_ipv4 **ipv4);
2140
2149
2158
2165void net_if_ipv4_set_ttl(struct net_if *iface, uint8_t ttl);
2166
2175
2183
2193 struct net_if **iface);
2194
2206 struct in_addr *addr,
2208 uint32_t vlifetime);
2209
2218bool net_if_ipv4_addr_rm(struct net_if *iface, const struct in_addr *addr);
2219
2228__syscall int net_if_ipv4_addr_lookup_by_index(const struct in_addr *addr);
2229
2241 struct in_addr *addr,
2243 uint32_t vlifetime);
2244
2254 const struct in_addr *addr);
2255
2265 void *user_data);
2266
2276 const struct in_addr *addr);
2277
2286bool net_if_ipv4_maddr_rm(struct net_if *iface, const struct in_addr *addr);
2287
2297 void *user_data);
2298
2310 struct net_if **iface);
2311
2319 struct net_if_mcast_addr *addr);
2320
2328static inline bool net_if_ipv4_maddr_is_joined(struct net_if_mcast_addr *addr)
2329{
2330 NET_ASSERT(addr);
2331
2332 return addr->is_joined;
2333}
2334
2342 struct net_if_mcast_addr *addr);
2343
2350#if defined(CONFIG_NET_NATIVE_IPV4)
2351static inline struct in_addr *net_if_router_ipv4(struct net_if_router *router)
2352{
2353 NET_ASSERT(router);
2354
2355 return &router->address.in_addr;
2356}
2357#else
2358static inline struct in_addr *net_if_router_ipv4(struct net_if_router *router)
2359{
2360 static struct in_addr addr;
2361
2362 ARG_UNUSED(router);
2363
2364 return &addr;
2365}
2366#endif
2367
2378 struct in_addr *addr);
2379
2390 struct in_addr *addr);
2402 struct in_addr *addr,
2403 bool is_default,
2404 uint16_t router_lifetime);
2405
2414
2424 const struct in_addr *addr);
2425
2435 const struct in_addr *addr);
2436
2446#if defined(CONFIG_NET_NATIVE_IPV4)
2447struct net_if *net_if_ipv4_select_src_iface(const struct in_addr *dst);
2448#else
2450 const struct in_addr *dst)
2451{
2452 ARG_UNUSED(dst);
2453
2454 return NULL;
2455}
2456#endif
2457
2469#if defined(CONFIG_NET_NATIVE_IPV4)
2470const struct in_addr *net_if_ipv4_select_src_addr(struct net_if *iface,
2471 const struct in_addr *dst);
2472#else
2473static inline const struct in_addr *net_if_ipv4_select_src_addr(
2474 struct net_if *iface, const struct in_addr *dst)
2475{
2476 ARG_UNUSED(iface);
2477 ARG_UNUSED(dst);
2478
2479 return NULL;
2480}
2481#endif
2482
2492struct in_addr *net_if_ipv4_get_ll(struct net_if *iface,
2493 enum net_addr_state addr_state);
2494
2505 enum net_addr_state addr_state);
2506
2517 const struct in_addr *addr);
2518
2528__deprecated struct in_addr net_if_ipv4_get_netmask(struct net_if *iface);
2529
2538__deprecated void net_if_ipv4_set_netmask(struct net_if *iface,
2539 const struct in_addr *netmask);
2540
2551__deprecated __syscall bool net_if_ipv4_set_netmask_by_index(int index,
2552 const struct in_addr *netmask);
2553
2564 const struct in_addr *addr,
2565 const struct in_addr *netmask);
2566
2577 const struct in_addr *addr,
2578 const struct in_addr *netmask);
2579
2586void net_if_ipv4_set_gw(struct net_if *iface, const struct in_addr *gw);
2587
2596__syscall bool net_if_ipv4_set_gw_by_index(int index, const struct in_addr *gw);
2597
2608struct net_if *net_if_select_src_iface(const struct sockaddr *dst);
2609
2618typedef void (*net_if_link_callback_t)(struct net_if *iface,
2619 struct net_linkaddr *dst,
2620 int status);
2621
2637
2646
2653
2661void net_if_call_link_cb(struct net_if *iface, struct net_linkaddr *lladdr,
2662 int status);
2663
2666/* used to ensure encoding of checksum support in net_if.h and
2667 * ethernet.h is the same
2668 */
2669#define NET_IF_CHECKSUM_NONE_BIT 0
2670#define NET_IF_CHECKSUM_IPV4_HEADER_BIT BIT(0)
2671#define NET_IF_CHECKSUM_IPV4_ICMP_BIT BIT(1)
2672/* Space for future protocols and restrictions for IPV4 */
2673#define NET_IF_CHECKSUM_IPV6_HEADER_BIT BIT(10)
2674#define NET_IF_CHECKSUM_IPV6_ICMP_BIT BIT(11)
2675/* Space for future protocols and restrictions for IPV6 */
2676#define NET_IF_CHECKSUM_TCP_BIT BIT(21)
2677#define NET_IF_CHECKSUM_UDP_BIT BIT(22)
2678
2686 NET_IF_CHECKSUM_IPV4_HEADER = NET_IF_CHECKSUM_IPV4_HEADER_BIT,
2688 NET_IF_CHECKSUM_IPV4_TCP = NET_IF_CHECKSUM_IPV4_HEADER_BIT |
2689 NET_IF_CHECKSUM_TCP_BIT,
2691 NET_IF_CHECKSUM_IPV4_UDP = NET_IF_CHECKSUM_IPV4_HEADER_BIT |
2692 NET_IF_CHECKSUM_UDP_BIT,
2694 NET_IF_CHECKSUM_IPV4_ICMP = NET_IF_CHECKSUM_IPV4_ICMP_BIT,
2696 NET_IF_CHECKSUM_IPV6_HEADER = NET_IF_CHECKSUM_IPV6_HEADER_BIT,
2698 NET_IF_CHECKSUM_IPV6_TCP = NET_IF_CHECKSUM_IPV6_HEADER_BIT |
2699 NET_IF_CHECKSUM_TCP_BIT,
2701 NET_IF_CHECKSUM_IPV6_UDP = NET_IF_CHECKSUM_IPV6_HEADER_BIT |
2702 NET_IF_CHECKSUM_UDP_BIT,
2704 NET_IF_CHECKSUM_IPV6_ICMP = NET_IF_CHECKSUM_IPV6_ICMP_BIT
2706
2718 enum net_if_checksum_type chksum_type);
2719
2732 enum net_if_checksum_type chksum_type);
2733
2744__syscall struct net_if *net_if_get_by_index(int index);
2745
2753int net_if_get_by_iface(struct net_if *iface);
2754
2762typedef void (*net_if_cb_t)(struct net_if *iface, void *user_data);
2763
2772
2780int net_if_up(struct net_if *iface);
2781
2789static inline bool net_if_is_up(struct net_if *iface)
2790{
2791 NET_ASSERT(iface);
2792
2793 return net_if_flag_is_set(iface, NET_IF_UP) &&
2795}
2796
2804int net_if_down(struct net_if *iface);
2805
2813static inline bool net_if_is_admin_up(struct net_if *iface)
2814{
2815 NET_ASSERT(iface);
2816
2817 return net_if_flag_is_set(iface, NET_IF_UP);
2818}
2819
2828void net_if_carrier_on(struct net_if *iface);
2829
2838void net_if_carrier_off(struct net_if *iface);
2839
2847static inline bool net_if_is_carrier_ok(struct net_if *iface)
2848{
2849 NET_ASSERT(iface);
2850
2851 return net_if_flag_is_set(iface, NET_IF_LOWER_UP);
2852}
2853
2864void net_if_dormant_on(struct net_if *iface);
2865
2874void net_if_dormant_off(struct net_if *iface);
2875
2883static inline bool net_if_is_dormant(struct net_if *iface)
2884{
2885 NET_ASSERT(iface);
2886
2887 return net_if_flag_is_set(iface, NET_IF_DORMANT);
2888}
2889
2890#if defined(CONFIG_NET_PKT_TIMESTAMP) && defined(CONFIG_NET_NATIVE)
2898typedef void (*net_if_timestamp_callback_t)(struct net_pkt *pkt);
2899
2908struct net_if_timestamp_cb {
2910 sys_snode_t node;
2911
2915 struct net_pkt *pkt;
2916
2920 struct net_if *iface;
2921
2923 net_if_timestamp_callback_t cb;
2924};
2925
2936void net_if_register_timestamp_cb(struct net_if_timestamp_cb *handle,
2937 struct net_pkt *pkt,
2938 struct net_if *iface,
2939 net_if_timestamp_callback_t cb);
2940
2946void net_if_unregister_timestamp_cb(struct net_if_timestamp_cb *handle);
2947
2953void net_if_call_timestamp_cb(struct net_pkt *pkt);
2954
2955/*
2956 * @brief Add timestamped TX buffer to be handled
2957 *
2958 * @param pkt Timestamped buffer
2959 */
2960void net_if_add_tx_timestamp(struct net_pkt *pkt);
2961#endif /* CONFIG_NET_PKT_TIMESTAMP */
2962
2972#if defined(CONFIG_NET_PROMISCUOUS_MODE)
2973int net_if_set_promisc(struct net_if *iface);
2974#else
2975static inline int net_if_set_promisc(struct net_if *iface)
2976{
2977 ARG_UNUSED(iface);
2978
2979 return -ENOTSUP;
2980}
2981#endif
2982
2988#if defined(CONFIG_NET_PROMISCUOUS_MODE)
2989void net_if_unset_promisc(struct net_if *iface);
2990#else
2991static inline void net_if_unset_promisc(struct net_if *iface)
2992{
2993 ARG_UNUSED(iface);
2994}
2995#endif
2996
3005#if defined(CONFIG_NET_PROMISCUOUS_MODE)
3006bool net_if_is_promisc(struct net_if *iface);
3007#else
3008static inline bool net_if_is_promisc(struct net_if *iface)
3009{
3010 ARG_UNUSED(iface);
3011
3012 return false;
3013}
3014#endif
3015
3025static inline bool net_if_are_pending_tx_packets(struct net_if *iface)
3026{
3027#if defined(CONFIG_NET_POWER_MANAGEMENT)
3028 return !!iface->tx_pending;
3029#else
3030 ARG_UNUSED(iface);
3031
3032 return false;
3033#endif
3034}
3035
3036#ifdef CONFIG_NET_POWER_MANAGEMENT
3044int net_if_suspend(struct net_if *iface);
3045
3053int net_if_resume(struct net_if *iface);
3054
3062bool net_if_is_suspended(struct net_if *iface);
3063#endif /* CONFIG_NET_POWER_MANAGEMENT */
3064
3072bool net_if_is_wifi(struct net_if *iface);
3073
3080
3087
3094
3109int net_if_get_name(struct net_if *iface, char *buf, int len);
3110
3125int net_if_set_name(struct net_if *iface, const char *buf);
3126
3134int net_if_get_by_name(const char *name);
3135
3137struct net_if_api {
3138 void (*init)(struct net_if *iface);
3139};
3140
3141#define NET_IF_DHCPV4_INIT \
3142 IF_ENABLED(UTIL_AND(IS_ENABLED(CONFIG_NET_DHCPV4), \
3143 IS_ENABLED(CONFIG_NET_NATIVE_IPV4)), \
3144 (.dhcpv4.state = NET_DHCPV4_DISABLED,))
3145
3146#define NET_IF_DHCPV6_INIT \
3147 IF_ENABLED(UTIL_AND(IS_ENABLED(CONFIG_NET_DHCPV6), \
3148 IS_ENABLED(CONFIG_NET_NATIVE_IPV6)), \
3149 (.dhcpv6.state = NET_DHCPV6_DISABLED,))
3150
3151#define NET_IF_CONFIG_INIT \
3152 .config = { \
3153 IF_ENABLED(CONFIG_NET_IP, (.ip = {},)) \
3154 NET_IF_DHCPV4_INIT \
3155 NET_IF_DHCPV6_INIT \
3156 }
3157
3158#define NET_IF_GET_NAME(dev_id, sfx) __net_if_##dev_id##_##sfx
3159#define NET_IF_DEV_GET_NAME(dev_id, sfx) __net_if_dev_##dev_id##_##sfx
3160
3161#define NET_IF_GET(dev_id, sfx) \
3162 ((struct net_if *)&NET_IF_GET_NAME(dev_id, sfx))
3163
3164#define NET_IF_INIT(dev_id, sfx, _l2, _mtu, _num_configs) \
3165 static STRUCT_SECTION_ITERABLE(net_if_dev, \
3166 NET_IF_DEV_GET_NAME(dev_id, sfx)) = { \
3167 .dev = &(DEVICE_NAME_GET(dev_id)), \
3168 .l2 = &(NET_L2_GET_NAME(_l2)), \
3169 .l2_data = &(NET_L2_GET_DATA(dev_id, sfx)), \
3170 .mtu = _mtu, \
3171 .flags = {BIT(NET_IF_LOWER_UP)}, \
3172 }; \
3173 static Z_DECL_ALIGN(struct net_if) \
3174 NET_IF_GET_NAME(dev_id, sfx)[_num_configs] \
3175 __used __in_section(_net_if, static, \
3176 dev_id) = { \
3177 [0 ... (_num_configs - 1)] = { \
3178 .if_dev = &(NET_IF_DEV_GET_NAME(dev_id, sfx)), \
3179 NET_IF_CONFIG_INIT \
3180 } \
3181 }
3182
3183#define NET_IF_OFFLOAD_INIT(dev_id, sfx, _mtu) \
3184 static STRUCT_SECTION_ITERABLE(net_if_dev, \
3185 NET_IF_DEV_GET_NAME(dev_id, sfx)) = { \
3186 .dev = &(DEVICE_NAME_GET(dev_id)), \
3187 .mtu = _mtu, \
3188 .l2 = &(NET_L2_GET_NAME(OFFLOADED_NETDEV)), \
3189 .flags = {BIT(NET_IF_LOWER_UP)}, \
3190 }; \
3191 static Z_DECL_ALIGN(struct net_if) \
3192 NET_IF_GET_NAME(dev_id, sfx)[NET_IF_MAX_CONFIGS] \
3193 __used __in_section(_net_if, static, \
3194 dev_id) = { \
3195 [0 ... (NET_IF_MAX_CONFIGS - 1)] = { \
3196 .if_dev = &(NET_IF_DEV_GET_NAME(dev_id, sfx)), \
3197 NET_IF_CONFIG_INIT \
3198 } \
3199 }
3200
3203/* Network device initialization macros */
3204
3205#define Z_NET_DEVICE_INIT_INSTANCE(node_id, dev_id, name, instance, \
3206 init_fn, pm, data, config, prio, \
3207 api, l2, l2_ctx_type, mtu) \
3208 Z_DEVICE_STATE_DEFINE(dev_id); \
3209 Z_DEVICE_DEFINE(node_id, dev_id, name, init_fn, pm, data, \
3210 config, POST_KERNEL, prio, api, \
3211 &Z_DEVICE_STATE_NAME(dev_id)); \
3212 NET_L2_DATA_INIT(dev_id, instance, l2_ctx_type); \
3213 NET_IF_INIT(dev_id, instance, l2, mtu, NET_IF_MAX_CONFIGS)
3214
3215#define Z_NET_DEVICE_INIT(node_id, dev_id, name, init_fn, pm, data, \
3216 config, prio, api, l2, l2_ctx_type, mtu) \
3217 Z_NET_DEVICE_INIT_INSTANCE(node_id, dev_id, name, 0, init_fn, \
3218 pm, data, config, prio, api, l2, \
3219 l2_ctx_type, mtu)
3220
3240#define NET_DEVICE_INIT(dev_id, name, init_fn, pm, data, config, prio, \
3241 api, l2, l2_ctx_type, mtu) \
3242 Z_NET_DEVICE_INIT(DT_INVALID_NODE, dev_id, name, init_fn, pm, \
3243 data, config, prio, api, l2, l2_ctx_type, mtu)
3244
3263#define NET_DEVICE_DT_DEFINE(node_id, init_fn, pm, data, \
3264 config, prio, api, l2, l2_ctx_type, mtu) \
3265 Z_NET_DEVICE_INIT(node_id, Z_DEVICE_DT_DEV_ID(node_id), \
3266 DEVICE_DT_NAME(node_id), init_fn, pm, data, \
3267 config, prio, api, l2, l2_ctx_type, mtu)
3268
3277#define NET_DEVICE_DT_INST_DEFINE(inst, ...) \
3278 NET_DEVICE_DT_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
3279
3303#define NET_DEVICE_INIT_INSTANCE(dev_id, name, instance, init_fn, pm, \
3304 data, config, prio, api, l2, \
3305 l2_ctx_type, mtu) \
3306 Z_NET_DEVICE_INIT_INSTANCE(DT_INVALID_NODE, dev_id, name, \
3307 instance, init_fn, pm, data, config, \
3308 prio, api, l2, l2_ctx_type, mtu)
3309
3332#define NET_DEVICE_DT_DEFINE_INSTANCE(node_id, instance, init_fn, pm, \
3333 data, config, prio, api, l2, \
3334 l2_ctx_type, mtu) \
3335 Z_NET_DEVICE_INIT_INSTANCE(node_id, \
3336 Z_DEVICE_DT_DEV_ID(node_id), \
3337 DEVICE_DT_NAME(node_id), instance, \
3338 init_fn, pm, data, config, prio, \
3339 api, l2, l2_ctx_type, mtu)
3340
3350#define NET_DEVICE_DT_INST_DEFINE_INSTANCE(inst, ...) \
3351 NET_DEVICE_DT_DEFINE_INSTANCE(DT_DRV_INST(inst), __VA_ARGS__)
3352
3353#define Z_NET_DEVICE_OFFLOAD_INIT(node_id, dev_id, name, init_fn, pm, \
3354 data, config, prio, api, mtu) \
3355 Z_DEVICE_STATE_DEFINE(dev_id); \
3356 Z_DEVICE_DEFINE(node_id, dev_id, name, init_fn, pm, data, \
3357 config, POST_KERNEL, prio, api, \
3358 &Z_DEVICE_STATE_NAME(dev_id)); \
3359 NET_IF_OFFLOAD_INIT(dev_id, 0, mtu)
3360
3380#define NET_DEVICE_OFFLOAD_INIT(dev_id, name, init_fn, pm, data, \
3381 config, prio, api, mtu) \
3382 Z_NET_DEVICE_OFFLOAD_INIT(DT_INVALID_NODE, dev_id, name, \
3383 init_fn, pm, data, config, prio, api, \
3384 mtu)
3385
3404#define NET_DEVICE_DT_OFFLOAD_DEFINE(node_id, init_fn, pm, data, \
3405 config, prio, api, mtu) \
3406 Z_NET_DEVICE_OFFLOAD_INIT(node_id, Z_DEVICE_DT_DEV_ID(node_id), \
3407 DEVICE_DT_NAME(node_id), init_fn, pm, \
3408 data, config, prio, api, mtu)
3409
3419#define NET_DEVICE_DT_INST_OFFLOAD_DEFINE(inst, ...) \
3420 NET_DEVICE_DT_OFFLOAD_DEFINE(DT_DRV_INST(inst), __VA_ARGS__)
3421
3427#define NET_IFACE_COUNT(_dst) \
3428 do { \
3429 extern struct net_if _net_if_list_start[]; \
3430 extern struct net_if _net_if_list_end[]; \
3431 *(_dst) = ((uintptr_t)_net_if_list_end - \
3432 (uintptr_t)_net_if_list_start) / \
3433 sizeof(struct net_if); \
3434 } while (0)
3435
3436#ifdef __cplusplus
3437}
3438#endif
3439
3440#include <zephyr/syscalls/net_if.h>
3441
3446#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:46
long atomic_t
Definition atomic_types.h:15
ZTEST_BMEM int index[(3)]
Definition main.c:32
ZTEST_BMEM int timeout
Definition main.c:31
DHCPv4 Client Handler.
DHCPv6 client.
static k_tid_t tid[ARRAY_SIZE(timeout_order_data_mult_fifo)]
Definition main.c:86
static void atomic_set_bit(atomic_t *target, int bit)
Atomically set a bit.
Definition atomic.h:209
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:191
#define ATOMIC_DEFINE(name, num_bits)
Define an array of atomic variables.
Definition atomic.h:111
static bool atomic_test_and_clear_bit(atomic_t *target, int bit)
Atomically test and clear a bit.
Definition atomic.h:147
static bool atomic_test_and_set_bit(atomic_t *target, int bit)
Atomically set a bit.
Definition atomic.h:170
#define K_FOREVER
Generate infinite timeout delay.
Definition kernel.h:1363
unsigned short int sa_family_t
Socket address family type.
Definition net_ip.h:164
net_addr_state
What is the current state of the network address.
Definition net_ip.h:500
net_addr_type
How the network address is assigned to network interface.
Definition net_ip.h:508
int k_mutex_unlock(struct k_mutex *mutex)
Unlock a mutex.
int k_mutex_lock(struct k_mutex *mutex, k_timeout_t timeout)
Lock a mutex.
net_verdict
Net Verdict.
Definition net_core.h:100
static int net_hostname_set_postfix(const uint8_t *hostname_postfix, int postfix_len)
Set the device hostname postfix.
Definition hostname.h:108
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.
int net_if_set_name(struct net_if *iface, const char *buf)
Set network interface name.
static bool net_if_is_carrier_ok(struct net_if *iface)
Check if carrier is present on network device.
Definition net_if.h:2847
static bool net_if_is_admin_up(struct net_if *iface)
Check if interface was brought up by the administrator.
Definition net_if.h:2813
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.
Definition net_if.h:629
struct net_if * net_if_get_wifi_sta(void)
Get Wi-Fi network station interface.
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.
void net_if_ipv4_maddr_leave(struct net_if *iface, struct net_if_mcast_addr *addr)
Mark a given multicast address to be left.
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.
int net_if_get_by_name(const char *name)
Get interface index according to its name.
struct net_if * net_if_get_by_link_addr(struct net_linkaddr *ll_addr)
Get an interface according to link layer address.
void net_if_dormant_off(struct net_if *iface)
Mark interface as not dormant.
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...
static enum net_if_oper_state net_if_oper_state_set(struct net_if *iface, enum net_if_oper_state oper_state)
Set an operational state on an interface.
Definition net_if.h:868
int net_if_down(struct net_if *iface)
Bring interface down.
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:2358
void net_if_ipv6_prefix_unset_timer(struct net_if_ipv6_prefix *prefix)
Unset the prefix lifetime timer.
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.
void net_if_carrier_on(struct net_if *iface)
Underlying network device has detected the carrier (cable connected).
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_ipv6_set_mcast_hop_limit(struct net_if *iface, uint8_t hop_limit)
Set the default IPv6 multicast hop limit of a given interface.
void net_if_ipv6_set_hop_limit(struct net_if *iface, uint8_t hop_limit)
Set the default IPv6 hop limit of a given 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:2618
static void * net_if_l2_data(struct net_if *iface)
Get a pointer to the interface L2 private data.
Definition net_if.h:939
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:3025
struct in_addr net_if_ipv4_get_netmask(struct net_if *iface)
Get IPv4 netmask of an interface.
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:798
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:1088
void net_if_ipv6_maddr_join(struct net_if *iface, struct net_if_mcast_addr *addr)
Mark a given multicast address to be joined.
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:2021
static void net_if_nbr_reachability_hint(struct net_if *iface, const struct in6_addr *ipv6_addr)
Provide a reachability hint for IPv6 Neighbor Discovery.
Definition net_if.h:1161
static struct net_offload * net_if_offload(struct net_if *iface)
Return the IP offload plugin.
Definition net_if.h:1005
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:1231
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:781
uint8_t net_if_ipv6_get_hop_limit(struct net_if *iface)
Get IPv6 hop limit specified for a given interface.
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.
void net_if_ipv6_addr_foreach(struct net_if *iface, net_if_ip_addr_cb_t cb, void *user_data)
Go through all IPv6 addresses on a network interface and call callback for each used address.
static const struct in6_addr * net_if_ipv6_select_src_addr_hint(struct net_if *iface, const struct in6_addr *dst, int flags)
Get a IPv6 source address that should be used when sending network data to destination.
Definition net_if.h:2049
int net_if_get_name(struct net_if *iface, char *buf, int len)
Get network interface name.
void(* net_if_ip_maddr_cb_t)(struct net_if *iface, struct net_if_mcast_addr *maddr, void *user_data)
Callback used while iterating over network interface multicast IP addresses.
Definition net_if.h:1542
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_carrier_off(struct net_if *iface)
Underlying network device has lost the carrier (cable disconnected).
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:977
static bool net_if_is_dormant(struct net_if *iface)
Check if the interface is dormant.
Definition net_if.h:2883
struct net_if * net_if_get_first_wifi(void)
Get first Wi-Fi network interface.
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.
uint8_t net_if_ipv4_get_mcast_ttl(struct net_if *iface)
Get IPv4 multicast time-to-live value specified for a given 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 a callback that is called whenever a IPv6 or IPv4 multicast address group is joined or left.
Definition net_if.h:1580
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:1266
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.
bool net_if_ipv4_set_netmask_by_addr(struct net_if *iface, const struct in_addr *addr, const struct in_addr *netmask)
Set IPv4 netmask for an interface index for a given address.
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 and running.
Definition net_if.h:2789
bool net_if_need_calc_rx_checksum(struct net_if *iface, enum net_if_checksum_type chksum_type)
Check if received network packet checksum calculation can be avoided or not.
static void net_if_ipv6_set_reachable_time(struct net_if_ipv6 *ipv6)
Set IPv6 reachable time for a given interface.
Definition net_if.h:1947
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.
bool net_if_ipv4_set_netmask_by_addr_by_index(int index, const struct in_addr *addr, const struct in_addr *netmask)
Set IPv4 netmask for an interface index for a given address.
void net_if_dormant_on(struct net_if *iface)
Mark interface as dormant.
int net_if_config_ipv6_put(struct net_if *iface)
Release network interface IPv6 config.
net_if_checksum_type
Type of checksum for which support in the interface will be queried.
Definition net_if.h:2684
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_ipv4_set_mcast_ttl(struct net_if *iface, uint8_t ttl)
Set IPv4 multicast time-to-live value specified to a given interface.
bool net_if_ipv4_set_netmask_by_index(int index, const struct in_addr *netmask)
Set IPv4 netmask for an interface index.
uint8_t net_if_ipv6_get_mcast_hop_limit(struct net_if *iface)
Get IPv6 multicast hop limit specified for a given interface.
bool net_if_need_calc_tx_checksum(struct net_if *iface, enum net_if_checksum_type chksum_type)
Check if network packet checksum calculation can be avoided or not when sending the packet.
static void net_if_start_dad(struct net_if *iface)
Start duplicate address detection procedure.
Definition net_if.h:1118
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_unset_promisc(struct net_if *iface)
Set network interface into normal mode.
Definition net_if.h:2991
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:1046
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:1916
static bool net_if_is_promisc(struct net_if *iface)
Check if promiscuous mode is set or not.
Definition net_if.h:3008
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:2328
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:1721
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.
bool net_if_is_wifi(struct net_if *iface)
Check if the network interface supports Wi-Fi.
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.
void net_if_ipv4_addr_foreach(struct net_if *iface, net_if_ip_addr_cb_t cb, void *user_data)
Go through all IPv4 addresses on a network interface and call callback for each used address.
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:1140
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:1891
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.
void net_if_ipv6_maddr_foreach(struct net_if *iface, net_if_ip_maddr_cb_t cb, void *user_data)
Go through all IPv6 multicast addresses on a network interface and call callback for each used addres...
static bool net_if_flag_test_and_clear(struct net_if *iface, enum net_if_flag value)
Test and clear a value in network interface flags.
Definition net_if.h:830
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:1648
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.
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:1249
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.
void net_if_ipv6_maddr_leave(struct net_if *iface, struct net_if_mcast_addr *addr)
Mark a given multicast address to be left.
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_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:2473
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:1966
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:1769
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:1990
void(* net_if_ip_addr_cb_t)(struct net_if *iface, struct net_if_addr *addr, void *user_data)
Callback used while iterating over network interface IP addresses.
Definition net_if.h:1498
bool net_if_ipv4_set_gw_by_index(int index, const struct in_addr *gw)
Set IPv4 gateway for an interface index.
struct in_addr net_if_ipv4_get_netmask_by_addr(struct net_if *iface, const struct in_addr *addr)
Get IPv4 netmask related to an address of an interface.
net_if_oper_state
Network interface operational status (RFC 2863).
Definition net_if.h:299
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:2072
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:847
static struct net_if_config * net_if_config_get(struct net_if *iface)
Get network interface IP config.
Definition net_if.h:1317
static struct net_if_config * net_if_get_config(struct net_if *iface)
Return network configuration for this network interface.
Definition net_if.h:1103
void net_if_ipv4_maddr_join(struct net_if *iface, struct net_if_mcast_addr *addr)
Mark a given multicast address to be joined.
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:1284
net_if_flag
Network interface flags.
Definition net_if.h:241
void net_if_ipv4_maddr_foreach(struct net_if *iface, net_if_ip_maddr_cb_t cb, void *user_data)
Go through all IPv4 multicast addresses on a network interface and call callback for each used addres...
struct net_if_ipv6_prefix * net_if_ipv6_prefix_get(struct net_if *iface, const struct in6_addr *addr)
Return prefix that corresponds to this IPv6 address.
static const struct device * net_if_get_device(struct net_if *iface)
Get an network interface's device.
Definition net_if.h:954
void(* net_if_cb_t)(struct net_if *iface, void *user_data)
Callback used while iterating over network interfaces.
Definition net_if.h:2762
bool net_if_is_offloaded(struct net_if *iface)
Return offload status of a given network interface.
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:1026
struct net_if * net_if_get_wifi_sap(void)
Get first Wi-Fi network Soft-AP interface.
static int net_if_set_promisc(struct net_if *iface)
Set network interface into promiscuous mode.
Definition net_if.h:2975
static const struct net_l2 * net_if_l2(struct net_if *iface)
Get a pointer to the interface L2.
Definition net_if.h:913
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:1067
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:2449
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:813
@ NET_IF_CHECKSUM_IPV4_ICMP
Interface supports checksum calculation for ICMP4 payload in IPv4.
Definition net_if.h:2694
@ NET_IF_CHECKSUM_IPV6_TCP
Interface supports checksum calculation for TCP payload in IPv6.
Definition net_if.h:2698
@ NET_IF_CHECKSUM_IPV6_UDP
Interface supports checksum calculation for UDP payload in IPv6.
Definition net_if.h:2701
@ NET_IF_CHECKSUM_IPV4_HEADER
Interface supports IP version 4 header checksum calculation.
Definition net_if.h:2686
@ NET_IF_CHECKSUM_IPV4_TCP
Interface supports checksum calculation for TCP payload in IPv4.
Definition net_if.h:2688
@ NET_IF_CHECKSUM_IPV6_HEADER
Interface supports IP version 6 header checksum calculation.
Definition net_if.h:2696
@ NET_IF_CHECKSUM_IPV6_ICMP
Interface supports checksum calculation for ICMP6 payload in IPv6.
Definition net_if.h:2704
@ NET_IF_CHECKSUM_IPV4_UDP
Interface supports checksum calculation for UDP payload in IPv4.
Definition net_if.h:2691
@ NET_IF_OPER_TESTING
Training mode.
Definition net_if.h:304
@ NET_IF_OPER_DORMANT
Waiting external action.
Definition net_if.h:305
@ NET_IF_OPER_UP
Interface is up.
Definition net_if.h:306
@ NET_IF_OPER_NOTPRESENT
Hardware missing.
Definition net_if.h:301
@ NET_IF_OPER_UNKNOWN
Initial (unknown) value.
Definition net_if.h:300
@ NET_IF_OPER_DOWN
Interface is down.
Definition net_if.h:302
@ NET_IF_OPER_LOWERLAYERDOWN
Lower layer interface is down.
Definition net_if.h:303
@ NET_IF_NO_AUTO_START
Do not start the interface immediately after initialization.
Definition net_if.h:257
@ NET_IF_IPV6_NO_MLD
IPv6 Multicast Listener Discovery disabled.
Definition net_if.h:287
@ NET_IF_POINTOPOINT
Interface is pointopoint.
Definition net_if.h:246
@ NET_IF_IPV6_NO_ND
IPv6 Neighbor Discovery disabled.
Definition net_if.h:284
@ NET_IF_FORWARD_MULTICASTS
Flag defines if received multicasts of other interface are forwarded on this interface.
Definition net_if.h:266
@ NET_IF_IPV4
Interface supports IPv4.
Definition net_if.h:269
@ NET_IF_PROMISC
Interface is in promiscuous mode.
Definition net_if.h:249
@ NET_IF_DORMANT
Driver signals dormant.
Definition net_if.h:281
@ NET_IF_SUSPENDED
Power management specific: interface is being suspended.
Definition net_if.h:260
@ NET_IF_IPV6
Interface supports IPv6.
Definition net_if.h:272
@ NET_IF_UP
Interface is admin up.
Definition net_if.h:243
@ NET_IF_LOWER_UP
Driver signals L1 is up.
Definition net_if.h:278
@ NET_IF_RUNNING
Interface up and running (ready to receive and transmit).
Definition net_if.h:275
@ NET_IF_NO_TX_LOCK
Mutex locking on TX data path disabled on the interface.
Definition net_if.h:290
net_link_type
Type of the link address.
Definition net_linkaddr.h:47
struct _slist sys_slist_t
Single-linked list structure.
Definition slist.h:49
struct _snode sys_snode_t
Single-linked list node structure.
Definition slist.h:39
#define ENOTSUP
Unsupported value.
Definition errno.h:114
#define EPERM
Not owner.
Definition errno.h:39
Hostname configuration definitions.
IPv4 Autoconfiguration.
net_ipv4_autoconf_state
Current state of IPv4 Autoconfiguration.
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.
flags
Definition parser.h:96
state
Definition parser_state.h:29
struct k_thread t2
Definition main.c:28
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__INT32_TYPE__ int32_t
Definition stdint.h:74
__UINT64_TYPE__ uint64_t
Definition stdint.h:91
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
__INT64_TYPE__ int64_t
Definition stdint.h:75
__INT16_TYPE__ int16_t
Definition stdint.h:73
Runtime device structure (in ROM) per driver instance.
Definition device.h:403
IPv6 address struct.
Definition net_ip.h:139
IPv4 address struct.
Definition net_ip.h:151
Definition kernel.h:2391
Mutex Structure.
Definition kernel.h:2917
Thread Structure.
Definition thread.h:259
Kernel timepoint type.
Definition sys_clock.h:219
DHCPv6 client configuration parameters.
Definition dhcpv6.h:61
Network Interface unicast IPv4 address and netmask.
Definition net_if.h:450
struct net_if_addr ipv4
IPv4 address.
Definition net_if.h:452
struct in_addr netmask
Netmask.
Definition net_if.h:454
Network Interface unicast IP addresses.
Definition net_if.h:52
struct net_addr address
IP address.
Definition net_if.h:54
uint8_t is_mesh_local
Is this IP address usage limited to the subnet (mesh) or not.
Definition net_if.h:138
uint8_t is_temporary
Is this IP address temporary and generated for example by IPv6 privacy extension (RFC 8981)
Definition net_if.h:143
enum net_addr_state addr_state
What is the current state of the address.
Definition net_if.h:69
uint8_t is_infinite
Is the IP address valid forever.
Definition net_if.h:132
atomic_t atomic_ref
Reference counter.
Definition net_if.h:59
uint8_t is_added
Was this address added or not.
Definition net_if.h:146
enum net_addr_type addr_type
How the IP address was set.
Definition net_if.h:66
uint8_t is_used
Is this IP address used or not.
Definition net_if.h:135
IP and other configuration related data for network interface.
Definition net_if.h:568
Network Interface Device structure.
Definition net_if.h:645
enum net_if_oper_state oper_state
RFC 2863 operational status.
Definition net_if.h:681
const struct net_l2 *const l2
Interface's L2 layer.
Definition net_if.h:650
void * l2_data
Interface's private L2 data pointer.
Definition net_if.h:653
uint16_t mtu
The hardware MTU.
Definition net_if.h:671
const struct device * dev
The actually device driver instance the net_if is related to.
Definition net_if.h:647
struct net_linkaddr link_addr
The hardware link address.
Definition net_if.h:659
atomic_t flags[ATOMIC_BITMAP_SIZE(NET_IF_NUM_FLAGS)]
For internal use.
Definition net_if.h:656
Network interface IP address configuration.
Definition net_if.h:555
IPv4 configuration.
Definition net_if.h:458
uint8_t mcast_ttl
IPv4 time-to-live for multicast packets.
Definition net_if.h:472
struct net_if_addr_ipv4 unicast[NET_IF_MAX_IPV4_ADDR]
Unicast IP addresses.
Definition net_if.h:460
struct in_addr gw
Gateway.
Definition net_if.h:466
uint8_t ttl
IPv4 time-to-live.
Definition net_if.h:469
struct net_if_mcast_addr mcast[NET_IF_MAX_IPV4_MADDR]
Multicast IP addresses.
Definition net_if.h:463
Network Interface IPv6 prefixes.
Definition net_if.h:185
struct net_if * iface
Backpointer to network interface where this prefix is used.
Definition net_if.h:193
uint8_t is_infinite
Is the IP prefix valid forever.
Definition net_if.h:199
uint8_t len
Prefix length.
Definition net_if.h:196
struct in6_addr prefix
IPv6 prefix.
Definition net_if.h:190
uint8_t is_used
Is this prefix used or not.
Definition net_if.h:202
struct net_timeout lifetime
Prefix lifetime.
Definition net_if.h:187
IPv6 configuration.
Definition net_if.h:326
struct net_if_ipv6_prefix prefix[NET_IF_MAX_IPV6_PREFIX]
Prefixes.
Definition net_if.h:334
uint32_t base_reachable_time
Default reachable time (RFC 4861, page 52)
Definition net_if.h:337
uint8_t hop_limit
IPv6 hop limit.
Definition net_if.h:365
struct net_if_mcast_addr mcast[NET_IF_MAX_IPV6_MADDR]
Multicast IP addresses.
Definition net_if.h:331
uint32_t retrans_timer
Retransmit timer (RFC 4861, page 52)
Definition net_if.h:343
struct net_if_addr unicast[NET_IF_MAX_IPV6_ADDR]
Unicast IP addresses.
Definition net_if.h:328
uint8_t mcast_hop_limit
IPv6 multicast hop limit.
Definition net_if.h:368
uint32_t reachable_time
Reachable time (RFC 4861, page 20)
Definition net_if.h:340
Network Interface multicast IP addresses.
Definition net_if.h:156
struct net_addr address
IP address.
Definition net_if.h:158
uint8_t is_joined
Did we join to this group.
Definition net_if.h:175
uint8_t is_used
Is this multicast IP address used or not.
Definition net_if.h:172
Multicast monitor handler struct.
Definition net_if.h:1592
sys_snode_t node
Node information for the slist.
Definition net_if.h:1594
net_if_mcast_callback_t cb
Multicast callback.
Definition net_if.h:1600
struct net_if * iface
Network interface.
Definition net_if.h:1597
Information about routers in the system.
Definition net_if.h:212
struct net_if * iface
Network interface the router is connected to.
Definition net_if.h:220
uint8_t is_default
Is default router.
Definition net_if.h:232
uint16_t lifetime
Router lifetime.
Definition net_if.h:226
uint8_t is_infinite
Is the router valid forever.
Definition net_if.h:235
uint8_t is_used
Is this router used or not.
Definition net_if.h:229
struct net_addr address
IP address.
Definition net_if.h:217
sys_snode_t node
Slist lifetime timer node.
Definition net_if.h:214
uint32_t life_start
Router life timer start.
Definition net_if.h:223
Network Interface structure.
Definition net_if.h:691
struct net_if_dev * if_dev
The net_if_dev instance the net_if is related to.
Definition net_if.h:693
struct net_if_config config
Network interface instance configuration.
Definition net_if.h:701
uint8_t pe_enabled
Network interface specific flags.
Definition net_if.h:721
struct k_mutex lock
Mutex protecting this network interface instance.
Definition net_if.h:712
uint8_t pe_prefer_public
If PE is enabled, then this tells whether public addresses are preferred over temporary ones for this...
Definition net_if.h:726
struct k_mutex tx_lock
Mutex used when sending data.
Definition net_if.h:715
Network L2 structure.
Definition net_l2.h:55
Hardware link address structure.
Definition net_linkaddr.h:67
uint8_t * addr
The array of byte representing the address.
Definition net_linkaddr.h:69
uint8_t type
What kind of address is this for.
Definition net_linkaddr.h:75
uint8_t len
Length of that address array.
Definition net_linkaddr.h:72
Network packet.
Definition net_pkt.h:67
All network statistics in one struct.
Definition net_stats.h:323
Generic struct for handling network timeouts.
Definition net_timeout.h:55
Network traffic class.
Definition net_if.h:612
k_thread_stack_t * stack
Stack for this handler.
Definition net_if.h:620
struct k_thread handler
Traffic class handler thread.
Definition net_if.h:617
struct k_fifo fifo
Fifo for handling this Tx or Rx packet.
Definition net_if.h:614
Generic sockaddr struct.
Definition net_ip.h:385
static const intptr_t user_data[5]
Definition main.c:588