Zephyr API Documentation  3.0.0
A Scalable Open Source RTOS
3.0.0
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
net_ip.h
Go to the documentation of this file.
1
7/*
8 * Copyright (c) 2016 Intel Corporation
9 *
10 * SPDX-License-Identifier: Apache-2.0
11 */
12
13#ifndef ZEPHYR_INCLUDE_NET_NET_IP_H_
14#define ZEPHYR_INCLUDE_NET_NET_IP_H_
15
23#include <string.h>
24#include <zephyr/types.h>
25#include <stdbool.h>
26#include <sys/util.h>
27#include <sys/byteorder.h>
28#include <toolchain.h>
29
30#include <net/net_linkaddr.h>
31
32#ifdef __cplusplus
33extern "C" {
34#endif
35
37/* Specifying VLAN tag here in order to avoid circular dependencies */
38#define NET_VLAN_TAG_UNSPEC 0x0fff
41/* Protocol families. */
42#define PF_UNSPEC 0
43#define PF_INET 1
44#define PF_INET6 2
45#define PF_PACKET 3
46#define PF_CAN 4
47#define PF_NET_MGMT 5
48#define PF_LOCAL 6
49#define PF_UNIX PF_LOCAL
51/* Address families. */
52#define AF_UNSPEC PF_UNSPEC
53#define AF_INET PF_INET
54#define AF_INET6 PF_INET6
55#define AF_PACKET PF_PACKET
56#define AF_CAN PF_CAN
57#define AF_NET_MGMT PF_NET_MGMT
58#define AF_LOCAL PF_LOCAL
59#define AF_UNIX PF_UNIX
72};
73
81};
82
88};
89
96#define ntohs(x) sys_be16_to_cpu(x)
97
104#define ntohl(x) sys_be32_to_cpu(x)
105
112#define ntohll(x) sys_be64_to_cpu(x)
113
120#define htons(x) sys_cpu_to_be16(x)
121
128#define htonl(x) sys_cpu_to_be32(x)
129
136#define htonll(x) sys_cpu_to_be64(x)
137
139struct in6_addr {
140 union {
142 uint16_t s6_addr16[8]; /* In big endian */
143 uint32_t s6_addr32[4]; /* In big endian */
144 };
145};
146
147/* Binary size of the IPv6 address */
148#define NET_IPV6_ADDR_SIZE 16
149
151struct in_addr {
152 union {
154 uint16_t s4_addr16[2]; /* In big endian */
155 uint32_t s4_addr32[1]; /* In big endian */
156 uint32_t s_addr; /* In big endian, for POSIX compatibility. */
157 };
158};
159
160/* Binary size of the IPv4 address */
161#define NET_IPV4_ADDR_SIZE 4
162
164typedef unsigned short int sa_family_t;
165
167typedef size_t socklen_t;
168
169/*
170 * Note that the sin_port and sin6_port are in network byte order
171 * in various sockaddr* structs.
172 */
173
176 sa_family_t sin6_family; /* AF_INET6 */
177 uint16_t sin6_port; /* Port number */
178 struct in6_addr sin6_addr; /* IPv6 address */
179 uint8_t sin6_scope_id; /* interfaces for a scope */
180};
181
183 sa_family_t sin6_family; /* AF_INET6 */
184 uint16_t sin6_port; /* Port number */
185 struct in6_addr *sin6_addr; /* IPv6 address */
186 uint8_t sin6_scope_id; /* interfaces for a scope */
187};
188
191 sa_family_t sin_family; /* AF_INET */
192 uint16_t sin_port; /* Port number */
193 struct in_addr sin_addr; /* IPv4 address */
194};
195
197 sa_family_t sin_family; /* AF_INET */
198 uint16_t sin_port; /* Port number */
199 struct in_addr *sin_addr; /* IPv4 address */
200};
201
204 sa_family_t sll_family; /* Always AF_PACKET */
205 uint16_t sll_protocol; /* Physical-layer protocol */
206 int sll_ifindex; /* Interface number */
207 uint16_t sll_hatype; /* ARP hardware type */
208 uint8_t sll_pkttype; /* Packet type */
209 uint8_t sll_halen; /* Length of address */
210 uint8_t sll_addr[8]; /* Physical-layer address */
211};
212
214 sa_family_t sll_family; /* Always AF_PACKET */
215 uint16_t sll_protocol; /* Physical-layer protocol */
216 int sll_ifindex; /* Interface number */
217 uint16_t sll_hatype; /* ARP hardware type */
218 uint8_t sll_pkttype; /* Packet type */
219 uint8_t sll_halen; /* Length of address */
220 uint8_t *sll_addr; /* Physical-layer address */
221};
222
226};
227
228#if !defined(HAVE_IOVEC)
229struct iovec {
230 void *iov_base;
231 size_t iov_len;
232};
233#endif
234
235struct msghdr {
236 void *msg_name; /* optional socket address */
237 socklen_t msg_namelen; /* size of socket address */
238 struct iovec *msg_iov; /* scatter/gather array */
239 size_t msg_iovlen; /* number of elements in msg_iov */
240 void *msg_control; /* ancillary data */
241 size_t msg_controllen; /* ancillary data buffer len */
242 int msg_flags; /* flags on received message */
243};
244
245struct cmsghdr {
246 socklen_t cmsg_len; /* Number of bytes, including header */
247 int cmsg_level; /* Originating protocol */
248 int cmsg_type; /* Protocol-specific type */
249 /* Flexible array member to force alignment of cmsghdr */
250 z_max_align_t cmsg_data[];
251};
252
253/* Alignment for headers and data. These are arch specific but define
254 * them here atm if not found alredy.
255 */
256#if !defined(ALIGN_H)
257#define ALIGN_H(x) ROUND_UP(x, __alignof__(struct cmsghdr))
258#endif
259#if !defined(ALIGN_D)
260#define ALIGN_D(x) ROUND_UP(x, __alignof__(z_max_align_t))
261#endif
262
263#if !defined(CMSG_FIRSTHDR)
264#define CMSG_FIRSTHDR(msghdr) \
265 ((msghdr)->msg_controllen >= sizeof(struct cmsghdr) ? \
266 (struct cmsghdr *)((msghdr)->msg_control) : NULL)
267#endif
268
269#if !defined(CMSG_NXTHDR)
270#define CMSG_NXTHDR(msghdr, cmsg) \
271 (((cmsg) == NULL) ? CMSG_FIRSTHDR(msghdr) : \
272 (((uint8_t *)(cmsg) + ALIGN_H((cmsg)->cmsg_len) + \
273 ALIGN_D(sizeof(struct cmsghdr)) > \
274 (uint8_t *)((msghdr)->msg_control) + (msghdr)->msg_controllen) ? \
275 NULL : \
276 (struct cmsghdr *)((uint8_t *)(cmsg) + \
277 ALIGN_H((cmsg)->cmsg_len))))
278#endif
279
280#if !defined(CMSG_DATA)
281#define CMSG_DATA(cmsg) ((uint8_t *)(cmsg) + ALIGN_D(sizeof(struct cmsghdr)))
282#endif
283
284#if !defined(CMSG_SPACE)
285#define CMSG_SPACE(length) (ALIGN_D(sizeof(struct cmsghdr)) + ALIGN_H(length))
286#endif
287
288#if !defined(CMSG_LEN)
289#define CMSG_LEN(length) (ALIGN_D(sizeof(struct cmsghdr)) + length)
290#endif
291
294/* Packet types. */
295#define PACKET_HOST 0 /* To us */
296#define PACKET_BROADCAST 1 /* To all */
297#define PACKET_MULTICAST 2 /* To group */
298#define PACKET_OTHERHOST 3 /* To someone else */
299#define PACKET_OUTGOING 4 /* Originated by us */
300#define PACKET_LOOPBACK 5
301#define PACKET_FASTROUTE 6
302
303/* Note: These macros are defined in a specific order.
304 * The largest sockaddr size is the last one.
305 */
306#if defined(CONFIG_NET_IPV4)
307#undef NET_SOCKADDR_MAX_SIZE
308#undef NET_SOCKADDR_PTR_MAX_SIZE
309#define NET_SOCKADDR_MAX_SIZE (sizeof(struct sockaddr_in))
310#define NET_SOCKADDR_PTR_MAX_SIZE (sizeof(struct sockaddr_in_ptr))
311#endif
312
313#if defined(CONFIG_NET_SOCKETS_PACKET)
314#undef NET_SOCKADDR_MAX_SIZE
315#undef NET_SOCKADDR_PTR_MAX_SIZE
316#define NET_SOCKADDR_MAX_SIZE (sizeof(struct sockaddr_ll))
317#define NET_SOCKADDR_PTR_MAX_SIZE (sizeof(struct sockaddr_ll_ptr))
318#endif
319
320#if defined(CONFIG_NET_IPV6)
321#undef NET_SOCKADDR_MAX_SIZE
322#define NET_SOCKADDR_MAX_SIZE (sizeof(struct sockaddr_in6))
323#if !defined(CONFIG_NET_SOCKETS_PACKET)
324#undef NET_SOCKADDR_PTR_MAX_SIZE
325#define NET_SOCKADDR_PTR_MAX_SIZE (sizeof(struct sockaddr_in6_ptr))
326#endif
327#endif
328
329#if !defined(CONFIG_NET_IPV4)
330#if !defined(CONFIG_NET_IPV6)
331#if !defined(CONFIG_NET_SOCKETS_PACKET)
332#define NET_SOCKADDR_MAX_SIZE (sizeof(struct sockaddr_in6))
333#define NET_SOCKADDR_PTR_MAX_SIZE (sizeof(struct sockaddr_in6_ptr))
334#endif
335#endif
336#endif
337
341struct sockaddr {
343 char data[NET_SOCKADDR_MAX_SIZE - sizeof(sa_family_t)];
344};
345
348struct sockaddr_ptr {
349 sa_family_t family;
350 char data[NET_SOCKADDR_PTR_MAX_SIZE - sizeof(sa_family_t)];
351};
352
353/* Same as sockaddr in our case */
354struct sockaddr_storage {
355 sa_family_t ss_family;
356 char data[NET_SOCKADDR_MAX_SIZE - sizeof(sa_family_t)];
357};
358
359/* Socket address struct for UNIX domain sockets */
360struct sockaddr_un {
361 sa_family_t sun_family; /* AF_UNIX */
362 char sun_path[NET_SOCKADDR_MAX_SIZE - sizeof(sa_family_t)];
363};
364
365struct net_addr {
366 sa_family_t family;
367 union {
368 struct in6_addr in6_addr;
369 struct in_addr in_addr;
370 };
371};
372
373#define IN6ADDR_ANY_INIT { { { 0, 0, 0, 0, 0, 0, 0, 0, 0, \
374 0, 0, 0, 0, 0, 0, 0 } } }
375#define IN6ADDR_LOOPBACK_INIT { { { 0, 0, 0, 0, 0, 0, 0, \
376 0, 0, 0, 0, 0, 0, 0, 0, 1 } } }
377
378extern const struct in6_addr in6addr_any;
379extern const struct in6_addr in6addr_loopback;
380
384#define INET_ADDRSTRLEN 16
388#define INET6_ADDRSTRLEN 46
389
392/* These are for internal usage of the stack */
393#define NET_IPV6_ADDR_LEN sizeof("xxxx:xxxx:xxxx:xxxx:xxxx:xxxx:xxxx:xxxx")
394#define NET_IPV4_ADDR_LEN sizeof("xxx.xxx.xxx.xxx")
395
396#define INADDR_ANY 0
397#define INADDR_ANY_INIT { { { INADDR_ANY } } }
398
399#define INADDR_LOOPBACK_INIT { { { 127, 0, 0, 1 } } }
400
408
413};
414
424 NET_PRIORITY_NC = 7
425} __packed;
426
427#define NET_MAX_PRIORITIES 8 /* How many priority values there are */
428
430struct net_tuple {
431 struct net_addr *remote_addr;
432 struct net_addr *local_addr;
436};
437
444} __packed;
445
458} __packed;
459
462struct net_ipv6_hdr {
463 uint8_t vtc;
464 uint8_t tcflow;
465 uint16_t flow;
466 uint16_t len;
467 uint8_t nexthdr;
468 uint8_t hop_limit;
471} __packed;
472
473struct net_ipv6_frag_hdr {
474 uint8_t nexthdr;
475 uint8_t reserved;
476 uint16_t offset;
477 uint32_t id;
478} __packed;
479
480struct net_ipv4_hdr {
481 uint8_t vhl;
482 uint8_t tos;
483 uint16_t len;
484 uint8_t id[2];
485 uint8_t offset[2];
486 uint8_t ttl;
487 uint8_t proto;
488 uint16_t chksum;
491} __packed;
492
493struct net_icmp_hdr {
494 uint8_t type;
495 uint8_t code;
496 uint16_t chksum;
497} __packed;
498
499struct net_udp_hdr {
500 uint16_t src_port;
501 uint16_t dst_port;
502 uint16_t len;
503 uint16_t chksum;
504} __packed;
505
506struct net_tcp_hdr {
507 uint16_t src_port;
508 uint16_t dst_port;
509 uint8_t seq[4];
510 uint8_t ack[4];
511 uint8_t offset;
513 uint8_t wnd[2];
514 uint16_t chksum;
515 uint8_t urg[2];
516 uint8_t optdata[0];
517} __packed;
518
519static inline const char *net_addr_type2str(enum net_addr_type type)
520{
521 switch (type) {
523 return "AUTO";
524 case NET_ADDR_DHCP:
525 return "DHCP";
526 case NET_ADDR_MANUAL:
527 return "MANUAL";
529 return "OVERRIDE";
530 case NET_ADDR_ANY:
531 default:
532 break;
533 }
534
535 return "<unknown>";
536}
537
538/* IPv6 extension headers types */
539#define NET_IPV6_NEXTHDR_HBHO 0
540#define NET_IPV6_NEXTHDR_DESTO 60
541#define NET_IPV6_NEXTHDR_ROUTING 43
542#define NET_IPV6_NEXTHDR_FRAG 44
543#define NET_IPV6_NEXTHDR_NONE 59
544
549union net_ip_header {
550 struct net_ipv4_hdr *ipv4;
551 struct net_ipv6_hdr *ipv6;
552};
553
554union net_proto_header {
555 struct net_udp_hdr *udp;
556 struct net_tcp_hdr *tcp;
557};
558
559#define NET_UDPH_LEN 8 /* Size of UDP header */
560#define NET_TCPH_LEN 20 /* Size of TCP header */
561#define NET_ICMPH_LEN 4 /* Size of ICMP header */
562
563#define NET_IPV6H_LEN 40 /* Size of IPv6 header */
564#define NET_ICMPV6H_LEN NET_ICMPH_LEN /* Size of ICMPv6 header */
565#define NET_IPV6UDPH_LEN (NET_UDPH_LEN + NET_IPV6H_LEN) /* IPv6 + UDP */
566#define NET_IPV6TCPH_LEN (NET_TCPH_LEN + NET_IPV6H_LEN) /* IPv6 + TCP */
567#define NET_IPV6ICMPH_LEN (NET_IPV6H_LEN + NET_ICMPH_LEN) /* ICMPv6 + IPv6 */
568#define NET_IPV6_FRAGH_LEN 8
569
570#define NET_IPV4H_LEN 20 /* Size of IPv4 header */
571#define NET_ICMPV4H_LEN NET_ICMPH_LEN /* Size of ICMPv4 header */
572#define NET_IPV4UDPH_LEN (NET_UDPH_LEN + NET_IPV4H_LEN) /* IPv4 + UDP */
573#define NET_IPV4TCPH_LEN (NET_TCPH_LEN + NET_IPV4H_LEN) /* IPv4 + TCP */
574#define NET_IPV4ICMPH_LEN (NET_IPV4H_LEN + NET_ICMPH_LEN) /* ICMPv4 + IPv4 */
575
576#define NET_IPV6H_LENGTH_OFFSET 0x04 /* Offset of the Length field in the IPv6 header */
577
578#define NET_IPV6_FRAGH_OFFSET_MASK 0xfff8 /* Mask for the 13-bit Fragment Offset field */
579
589static inline bool net_ipv6_is_addr_loopback(struct in6_addr *addr)
590{
591 return UNALIGNED_GET(&addr->s6_addr32[0]) == 0 &&
592 UNALIGNED_GET(&addr->s6_addr32[1]) == 0 &&
593 UNALIGNED_GET(&addr->s6_addr32[2]) == 0 &&
594 ntohl(UNALIGNED_GET(&addr->s6_addr32[3])) == 1;
595}
596
604static inline bool net_ipv6_is_addr_mcast(const struct in6_addr *addr)
605{
606 return addr->s6_addr[0] == 0xFF;
607}
608
609struct net_if;
610struct net_if_config;
611
612extern struct net_if_addr *net_if_ipv6_addr_lookup(const struct in6_addr *addr,
613 struct net_if **iface);
614
622static inline bool net_ipv6_is_my_addr(struct in6_addr *addr)
623{
624 return net_if_ipv6_addr_lookup(addr, NULL) != NULL;
625}
626
628 const struct in6_addr *addr, struct net_if **iface);
629
638static inline bool net_ipv6_is_my_maddr(struct in6_addr *maddr)
639{
640 return net_if_ipv6_maddr_lookup(maddr, NULL) != NULL;
641}
642
652static inline bool net_ipv6_is_prefix(const uint8_t *addr1,
653 const uint8_t *addr2,
654 uint8_t length)
655{
656 uint8_t bits = 128 - length;
657 uint8_t bytes = length / 8U;
658 uint8_t remain = bits % 8;
659 uint8_t mask;
660
661 if (length > 128) {
662 return false;
663 }
664
665 if (memcmp(addr1, addr2, bytes)) {
666 return false;
667 }
668
669 if (!remain) {
670 /* No remaining bits, the prefixes are the same as first
671 * bytes are the same.
672 */
673 return true;
674 }
675
676 /* Create a mask that has remaining most significant bits set */
677 mask = ((0xff << (8 - remain)) ^ 0xff) << remain;
678
679 return (addr1[bytes] & mask) == (addr2[bytes] & mask);
680}
681
689static inline bool net_ipv4_is_addr_loopback(struct in_addr *addr)
690{
691 return addr->s4_addr[0] == 127U;
692}
693
701static inline bool net_ipv4_is_addr_unspecified(const struct in_addr *addr)
702{
703 return UNALIGNED_GET(&addr->s_addr) == 0;
704}
705
713static inline bool net_ipv4_is_addr_mcast(const struct in_addr *addr)
714{
715 return (ntohl(UNALIGNED_GET(&addr->s_addr)) & 0xF0000000) == 0xE0000000;
716}
717
725static inline bool net_ipv4_is_ll_addr(const struct in_addr *addr)
726{
727 return (ntohl(UNALIGNED_GET(&addr->s_addr)) & 0xA9FE0000) == 0xA9FE0000;
728}
729
739#define net_ipaddr_copy(dest, src) \
740 UNALIGNED_PUT(UNALIGNED_GET(src), dest)
741
748static inline void net_ipv4_addr_copy_raw(uint8_t *dest,
749 const uint8_t *src)
750{
751 net_ipaddr_copy((struct in_addr *)dest, (const struct in_addr *)src);
752}
753
760static inline void net_ipv6_addr_copy_raw(uint8_t *dest,
761 const uint8_t *src)
762{
763 memcpy(dest, src, sizeof(struct in6_addr));
764}
765
774static inline bool net_ipv4_addr_cmp(const struct in_addr *addr1,
775 const struct in_addr *addr2)
776{
777 return UNALIGNED_GET(&addr1->s_addr) == UNALIGNED_GET(&addr2->s_addr);
778}
779
788static inline bool net_ipv4_addr_cmp_raw(const uint8_t *addr1,
789 const uint8_t *addr2)
790{
791 return net_ipv4_addr_cmp((const struct in_addr *)addr1,
792 (const struct in_addr *)addr2);
793}
794
803static inline bool net_ipv6_addr_cmp(const struct in6_addr *addr1,
804 const struct in6_addr *addr2)
805{
806 return !memcmp(addr1, addr2, sizeof(struct in6_addr));
807}
808
817static inline bool net_ipv6_addr_cmp_raw(const uint8_t *addr1,
818 const uint8_t *addr2)
819{
820 return net_ipv6_addr_cmp((const struct in6_addr *)addr1,
821 (const struct in6_addr *)addr2);
822}
823
831static inline bool net_ipv6_is_ll_addr(const struct in6_addr *addr)
832{
833 return UNALIGNED_GET(&addr->s6_addr16[0]) == htons(0xFE80);
834}
835
843static inline bool net_ipv6_is_ula_addr(const struct in6_addr *addr)
844{
845 return addr->s6_addr[0] == 0xFD;
846}
847
854
861
868
869struct net_if;
870extern bool net_if_ipv4_addr_mask_cmp(struct net_if *iface,
871 const struct in_addr *addr);
872
882static inline bool net_ipv4_addr_mask_cmp(struct net_if *iface,
883 const struct in_addr *addr)
884{
885 return net_if_ipv4_addr_mask_cmp(iface, addr);
886}
887
888extern bool net_if_ipv4_is_addr_bcast(struct net_if *iface,
889 const struct in_addr *addr);
890
899#if defined(CONFIG_NET_NATIVE_IPV4)
900static inline bool net_ipv4_is_addr_bcast(struct net_if *iface,
901 const struct in_addr *addr)
902{
904 return true;
905 }
906
907 return net_if_ipv4_is_addr_bcast(iface, addr);
908}
909#else
910static inline bool net_ipv4_is_addr_bcast(struct net_if *iface,
911 const struct in_addr *addr)
912{
913 ARG_UNUSED(iface);
914 ARG_UNUSED(addr);
915
916 return false;
917}
918#endif
919
920extern struct net_if_addr *net_if_ipv4_addr_lookup(const struct in_addr *addr,
921 struct net_if **iface);
922
932static inline bool net_ipv4_is_my_addr(const struct in_addr *addr)
933{
934 bool ret;
935
936 ret = net_if_ipv4_addr_lookup(addr, NULL) != NULL;
937 if (!ret) {
938 ret = net_ipv4_is_addr_bcast(NULL, addr);
939 }
940
941 return ret;
942}
943
951static inline bool net_ipv6_is_addr_unspecified(const struct in6_addr *addr)
952{
953 return UNALIGNED_GET(&addr->s6_addr32[0]) == 0 &&
954 UNALIGNED_GET(&addr->s6_addr32[1]) == 0 &&
955 UNALIGNED_GET(&addr->s6_addr32[2]) == 0 &&
956 UNALIGNED_GET(&addr->s6_addr32[3]) == 0;
957}
958
967static inline bool net_ipv6_is_addr_solicited_node(const struct in6_addr *addr)
968{
969 return UNALIGNED_GET(&addr->s6_addr32[0]) == htonl(0xff020000) &&
970 UNALIGNED_GET(&addr->s6_addr32[1]) == 0x00000000 &&
971 UNALIGNED_GET(&addr->s6_addr32[2]) == htonl(0x00000001) &&
972 ((UNALIGNED_GET(&addr->s6_addr32[3]) & htonl(0xff000000)) ==
973 htonl(0xff000000));
974}
975
986static inline bool net_ipv6_is_addr_mcast_scope(const struct in6_addr *addr,
987 int scope)
988{
989 return (addr->s6_addr[0] == 0xff) && (addr->s6_addr[1] == scope);
990}
991
1001static inline bool net_ipv6_is_same_mcast_scope(const struct in6_addr *addr_1,
1002 const struct in6_addr *addr_2)
1003{
1004 return (addr_1->s6_addr[0] == 0xff) && (addr_2->s6_addr[0] == 0xff) &&
1005 (addr_1->s6_addr[1] == addr_2->s6_addr[1]);
1006}
1007
1015static inline bool net_ipv6_is_addr_mcast_global(const struct in6_addr *addr)
1016{
1017 return net_ipv6_is_addr_mcast_scope(addr, 0x0e);
1018}
1019
1029static inline bool net_ipv6_is_addr_mcast_iface(const struct in6_addr *addr)
1030{
1031 return net_ipv6_is_addr_mcast_scope(addr, 0x01);
1032}
1033
1043static inline bool net_ipv6_is_addr_mcast_link(const struct in6_addr *addr)
1044{
1045 return net_ipv6_is_addr_mcast_scope(addr, 0x02);
1046}
1047
1057static inline bool net_ipv6_is_addr_mcast_mesh(const struct in6_addr *addr)
1058{
1059 return net_ipv6_is_addr_mcast_scope(addr, 0x03);
1060}
1061
1071static inline bool net_ipv6_is_addr_mcast_site(const struct in6_addr *addr)
1072{
1073 return net_ipv6_is_addr_mcast_scope(addr, 0x05);
1074}
1075
1085static inline bool net_ipv6_is_addr_mcast_org(const struct in6_addr *addr)
1086{
1087 return net_ipv6_is_addr_mcast_scope(addr, 0x08);
1088}
1089
1100static inline bool net_ipv6_is_addr_mcast_group(const struct in6_addr *addr,
1101 const struct in6_addr *group)
1102{
1103 return UNALIGNED_GET(&addr->s6_addr16[1]) == group->s6_addr16[1] &&
1104 UNALIGNED_GET(&addr->s6_addr16[2]) == group->s6_addr16[2] &&
1105 UNALIGNED_GET(&addr->s6_addr16[3]) == group->s6_addr16[3] &&
1106 UNALIGNED_GET(&addr->s6_addr32[1]) == group->s6_addr32[1] &&
1107 UNALIGNED_GET(&addr->s6_addr32[2]) == group->s6_addr32[1] &&
1108 UNALIGNED_GET(&addr->s6_addr32[3]) == group->s6_addr32[3];
1109}
1110
1119static inline bool
1121{
1122 static const struct in6_addr all_nodes_mcast_group = {
1123 { { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
1124 0x00, 0x00, 0x00, 0x00, 0x00, 0x01 } }
1125 };
1126
1127 return net_ipv6_is_addr_mcast_group(addr, &all_nodes_mcast_group);
1128}
1129
1139static inline bool
1141{
1142 return net_ipv6_is_addr_mcast_iface(addr) &&
1144}
1145
1155static inline bool
1157{
1158 return net_ipv6_is_addr_mcast_link(addr) &&
1160}
1161
1169static inline
1171 struct in6_addr *dst)
1172{
1173 dst->s6_addr[0] = 0xFF;
1174 dst->s6_addr[1] = 0x02;
1175 UNALIGNED_PUT(0, &dst->s6_addr16[1]);
1176 UNALIGNED_PUT(0, &dst->s6_addr16[2]);
1177 UNALIGNED_PUT(0, &dst->s6_addr16[3]);
1178 UNALIGNED_PUT(0, &dst->s6_addr16[4]);
1179 dst->s6_addr[10] = 0U;
1180 dst->s6_addr[11] = 0x01;
1181 dst->s6_addr[12] = 0xFF;
1182 dst->s6_addr[13] = src->s6_addr[13];
1183 UNALIGNED_PUT(UNALIGNED_GET(&src->s6_addr16[7]), &dst->s6_addr16[7]);
1184}
1185
1198static inline void net_ipv6_addr_create(struct in6_addr *addr,
1199 uint16_t addr0, uint16_t addr1,
1200 uint16_t addr2, uint16_t addr3,
1201 uint16_t addr4, uint16_t addr5,
1202 uint16_t addr6, uint16_t addr7)
1203{
1204 UNALIGNED_PUT(htons(addr0), &addr->s6_addr16[0]);
1205 UNALIGNED_PUT(htons(addr1), &addr->s6_addr16[1]);
1206 UNALIGNED_PUT(htons(addr2), &addr->s6_addr16[2]);
1207 UNALIGNED_PUT(htons(addr3), &addr->s6_addr16[3]);
1208 UNALIGNED_PUT(htons(addr4), &addr->s6_addr16[4]);
1209 UNALIGNED_PUT(htons(addr5), &addr->s6_addr16[5]);
1210 UNALIGNED_PUT(htons(addr6), &addr->s6_addr16[6]);
1211 UNALIGNED_PUT(htons(addr7), &addr->s6_addr16[7]);
1212}
1213
1219static inline void net_ipv6_addr_create_ll_allnodes_mcast(struct in6_addr *addr)
1220{
1221 net_ipv6_addr_create(addr, 0xff02, 0, 0, 0, 0, 0, 0, 0x0001);
1222}
1223
1230{
1231 net_ipv6_addr_create(addr, 0xff02, 0, 0, 0, 0, 0, 0, 0x0002);
1232}
1233
1240static inline void net_ipv6_addr_create_iid(struct in6_addr *addr,
1241 struct net_linkaddr *lladdr)
1242{
1243 UNALIGNED_PUT(htonl(0xfe800000), &addr->s6_addr32[0]);
1244 UNALIGNED_PUT(0, &addr->s6_addr32[1]);
1245
1246 switch (lladdr->len) {
1247 case 2:
1248 /* The generated IPv6 shall not toggle the
1249 * Universal/Local bit. RFC 6282 ch 3.2.2
1250 */
1251 if (lladdr->type == NET_LINK_IEEE802154 ||
1252 lladdr->type == NET_LINK_CANBUS) {
1253 UNALIGNED_PUT(0, &addr->s6_addr32[2]);
1254 addr->s6_addr[11] = 0xff;
1255 addr->s6_addr[12] = 0xfe;
1256 addr->s6_addr[13] = 0U;
1257 addr->s6_addr[14] = lladdr->addr[0];
1258 addr->s6_addr[15] = lladdr->addr[1];
1259 }
1260
1261 break;
1262 case 6:
1263 /* We do not toggle the Universal/Local bit
1264 * in Bluetooth. See RFC 7668 ch 3.2.2
1265 */
1266 memcpy(&addr->s6_addr[8], lladdr->addr, 3);
1267 addr->s6_addr[11] = 0xff;
1268 addr->s6_addr[12] = 0xfe;
1269 memcpy(&addr->s6_addr[13], lladdr->addr + 3, 3);
1270
1271#if defined(CONFIG_NET_L2_BT_ZEP1656)
1272 /* Workaround against older Linux kernel BT IPSP code.
1273 * This will be removed eventually.
1274 */
1275 if (lladdr->type == NET_LINK_BLUETOOTH) {
1276 addr->s6_addr[8] ^= 0x02;
1277 }
1278#endif
1279
1280 if (lladdr->type == NET_LINK_ETHERNET) {
1281 addr->s6_addr[8] ^= 0x02;
1282 }
1283
1284 break;
1285 case 8:
1286 memcpy(&addr->s6_addr[8], lladdr->addr, lladdr->len);
1287 addr->s6_addr[8] ^= 0x02;
1288 break;
1289 }
1290}
1291
1297static inline bool net_ipv6_addr_based_on_ll(const struct in6_addr *addr,
1298 const struct net_linkaddr *lladdr)
1299{
1300 if (!addr || !lladdr) {
1301 return false;
1302 }
1303
1304 switch (lladdr->len) {
1305 case 2:
1306 if (!memcmp(&addr->s6_addr[14], lladdr->addr, lladdr->len) &&
1307 addr->s6_addr[8] == 0U &&
1308 addr->s6_addr[9] == 0U &&
1309 addr->s6_addr[10] == 0U &&
1310 addr->s6_addr[11] == 0xff &&
1311 addr->s6_addr[12] == 0xfe) {
1312 return true;
1313 }
1314
1315 break;
1316 case 6:
1317 if (lladdr->type == NET_LINK_ETHERNET) {
1318 if (!memcmp(&addr->s6_addr[9], &lladdr->addr[1], 2) &&
1319 !memcmp(&addr->s6_addr[13], &lladdr->addr[3], 3) &&
1320 addr->s6_addr[11] == 0xff &&
1321 addr->s6_addr[12] == 0xfe &&
1322 (addr->s6_addr[8] ^ 0x02) == lladdr->addr[0]) {
1323 return true;
1324 }
1325 } else if (lladdr->type == NET_LINK_BLUETOOTH) {
1326 if (!memcmp(&addr->s6_addr[9], &lladdr->addr[1], 2) &&
1327 !memcmp(&addr->s6_addr[13], &lladdr->addr[3], 3) &&
1328 addr->s6_addr[11] == 0xff &&
1329 addr->s6_addr[12] == 0xfe
1330#if defined(CONFIG_NET_L2_BT_ZEP1656)
1331 /* Workaround against older Linux kernel BT IPSP
1332 * code. This will be removed eventually.
1333 */
1334 && (addr->s6_addr[8] ^ 0x02) == lladdr->addr[0]
1335#endif
1336 ) {
1337 return true;
1338 }
1339 }
1340
1341 break;
1342 case 8:
1343 if (!memcmp(&addr->s6_addr[9], &lladdr->addr[1],
1344 lladdr->len - 1) &&
1345 (addr->s6_addr[8] ^ 0x02) == lladdr->addr[0]) {
1346 return true;
1347 }
1348
1349 break;
1350 }
1351
1352 return false;
1353}
1354
1363static inline struct sockaddr_in6 *net_sin6(const struct sockaddr *addr)
1364{
1365 return (struct sockaddr_in6 *)addr;
1366}
1367
1376static inline struct sockaddr_in *net_sin(const struct sockaddr *addr)
1377{
1378 return (struct sockaddr_in *)addr;
1379}
1380
1389static inline
1390struct sockaddr_in6_ptr *net_sin6_ptr(const struct sockaddr_ptr *addr)
1391{
1392 return (struct sockaddr_in6_ptr *)addr;
1393}
1394
1403static inline
1404struct sockaddr_in_ptr *net_sin_ptr(const struct sockaddr_ptr *addr)
1405{
1406 return (struct sockaddr_in_ptr *)addr;
1407}
1408
1417static inline
1418struct sockaddr_ll_ptr *net_sll_ptr(const struct sockaddr_ptr *addr)
1419{
1420 return (struct sockaddr_ll_ptr *)addr;
1421}
1422
1431static inline
1432struct sockaddr_can_ptr *net_can_ptr(const struct sockaddr_ptr *addr)
1433{
1434 return (struct sockaddr_can_ptr *)addr;
1435}
1436
1450__syscall int net_addr_pton(sa_family_t family, const char *src, void *dst);
1451
1463__syscall char *net_addr_ntop(sa_family_t family, const void *src,
1464 char *dst, size_t size);
1465
1487bool net_ipaddr_parse(const char *str, size_t str_len,
1488 struct sockaddr *addr);
1489
1501static inline int32_t net_tcp_seq_cmp(uint32_t seq1, uint32_t seq2)
1502{
1503 return (int32_t)(seq1 - seq2);
1504}
1505
1516static inline bool net_tcp_seq_greater(uint32_t seq1, uint32_t seq2)
1517{
1518 return net_tcp_seq_cmp(seq1, seq2) > 0;
1519}
1520
1532int net_bytes_from_str(uint8_t *buf, int buf_len, const char *src);
1533
1543
1553
1562static inline enum net_priority net_vlan2priority(uint8_t priority)
1563{
1564 /* Map according to IEEE 802.1Q */
1565 static const uint8_t vlan2priority[] = {
1574 };
1575
1576 if (priority >= ARRAY_SIZE(vlan2priority)) {
1577 /* Use Best Effort as the default priority */
1578 return NET_PRIORITY_BE;
1579 }
1580
1581 return (enum net_priority)vlan2priority[priority];
1582}
1583
1591static inline uint8_t net_priority2vlan(enum net_priority priority)
1592{
1593 /* The conversion works both ways */
1594 return (uint8_t)net_vlan2priority(priority);
1595}
1596
1605const char *net_family2str(sa_family_t family);
1606
1607#ifdef __cplusplus
1608}
1609#endif
1610
1611#include <syscalls/net_ip.h>
1612
1618#endif /* ZEPHYR_INCLUDE_NET_NET_IP_H_ */
Byte order helpers.
static bool net_ipv6_is_my_addr(struct in6_addr *addr)
Check if IPv6 address is found in one of the network interfaces.
Definition: net_ip.h:622
struct net_if_addr * net_if_ipv4_addr_lookup(const struct in_addr *addr, struct net_if **iface)
static void net_ipv6_addr_create(struct in6_addr *addr, uint16_t addr0, uint16_t addr1, uint16_t addr2, uint16_t addr3, uint16_t addr4, uint16_t addr5, uint16_t addr6, uint16_t addr7)
Construct an IPv6 address from eight 16-bit words.
Definition: net_ip.h:1198
static bool net_ipv4_addr_cmp(const struct in_addr *addr1, const struct in_addr *addr2)
Compare two IPv4 addresses.
Definition: net_ip.h:774
#define NET_IPV4_ADDR_SIZE
Definition: net_ip.h:161
struct net_if_addr * net_if_ipv6_addr_lookup(const struct in6_addr *addr, struct net_if **iface)
static bool net_ipv6_is_addr_mcast_org(const struct in6_addr *addr)
Check if the IPv6 address is an organization scope multicast address (FFx8::).
Definition: net_ip.h:1085
static enum net_priority net_vlan2priority(uint8_t priority)
Convert network packet VLAN priority to network packet priority so we can place the packet into corre...
Definition: net_ip.h:1562
static int32_t net_tcp_seq_cmp(uint32_t seq1, uint32_t seq2)
Compare TCP sequence numbers.
Definition: net_ip.h:1501
static bool net_ipv6_is_addr_mcast(const struct in6_addr *addr)
Check if the IPv6 address is a multicast address.
Definition: net_ip.h:604
#define NET_IPV6_ADDR_SIZE
Definition: net_ip.h:148
int net_addr_pton(sa_family_t family, const char *src, void *dst)
Convert a string to IP address.
unsigned short int sa_family_t
Definition: net_ip.h:164
static void net_ipv6_addr_create_ll_allrouters_mcast(struct in6_addr *addr)
Create link local allrouters multicast IPv6 address.
Definition: net_ip.h:1229
char * net_addr_ntop(sa_family_t family, const void *src, char *dst, size_t size)
Convert IP address to string form.
net_addr_state
Definition: net_ip.h:439
static bool net_ipv4_addr_cmp_raw(const uint8_t *addr1, const uint8_t *addr2)
Compare two raw IPv4 address buffers.
Definition: net_ip.h:788
static bool net_ipv6_addr_cmp(const struct in6_addr *addr1, const struct in6_addr *addr2)
Compare two IPv6 addresses.
Definition: net_ip.h:803
static bool net_ipv6_is_addr_mcast_iface_all_nodes(const struct in6_addr *addr)
Check if the IPv6 address is a interface scope all nodes multicast address (FF01::1).
Definition: net_ip.h:1140
static bool net_ipv4_is_my_addr(const struct in_addr *addr)
Check if the IPv4 address is assigned to any network interface in the system.
Definition: net_ip.h:932
static bool net_ipv6_is_same_mcast_scope(const struct in6_addr *addr_1, const struct in6_addr *addr_2)
Check if the IPv6 addresses have the same multicast scope (FFyx::).
Definition: net_ip.h:1001
static void net_ipv6_addr_copy_raw(uint8_t *dest, const uint8_t *src)
Copy an IPv6 address raw buffer.
Definition: net_ip.h:760
static bool net_ipv6_is_addr_mcast_mesh(const struct in6_addr *addr)
Check if the IPv6 address is a mesh-local scope multicast address (FFx3::).
Definition: net_ip.h:1057
static struct sockaddr_in_ptr * net_sin_ptr(const struct sockaddr_ptr *addr)
Get sockaddr_in_ptr from sockaddr_ptr. This is a helper so that the code calling this function can be...
Definition: net_ip.h:1404
const struct in_addr * net_ipv4_broadcast_address(void)
Return pointer to broadcast (all bits ones) IPv4 address.
#define htons(x)
Convert 16-bit value from host to network byte order.
Definition: net_ip.h:120
bool net_if_ipv4_addr_mask_cmp(struct net_if *iface, const struct in_addr *addr)
static bool net_ipv6_is_addr_mcast_global(const struct in6_addr *addr)
Check if the IPv6 address is a global multicast address (FFxE::/16).
Definition: net_ip.h:1015
static void net_ipv6_addr_create_ll_allnodes_mcast(struct in6_addr *addr)
Create link local allnodes multicast IPv6 address.
Definition: net_ip.h:1219
static bool net_ipv6_is_addr_solicited_node(const struct in6_addr *addr)
Check if the IPv6 address is solicited node multicast address FF02:0:0:0:0:1:FFXX:XXXX defined in RFC...
Definition: net_ip.h:967
static void net_ipv6_addr_create_solicited_node(const struct in6_addr *src, struct in6_addr *dst)
Create solicited node IPv6 multicast address FF02:0:0:0:0:1:FFXX:XXXX defined in RFC 3513.
Definition: net_ip.h:1170
static bool net_ipv6_is_addr_mcast_group(const struct in6_addr *addr, const struct in6_addr *group)
Check if the IPv6 address belongs to certain multicast group.
Definition: net_ip.h:1100
static bool net_ipv6_is_addr_mcast_site(const struct in6_addr *addr)
Check if the IPv6 address is a site scope multicast address (FFx5::).
Definition: net_ip.h:1071
static void net_ipv6_addr_create_iid(struct in6_addr *addr, struct net_linkaddr *lladdr)
Create IPv6 address interface identifier.
Definition: net_ip.h:1240
static bool net_ipv6_is_addr_mcast_link(const struct in6_addr *addr)
Check if the IPv6 address is a link local scope multicast address (FFx2::).
Definition: net_ip.h:1043
static bool net_ipv4_addr_mask_cmp(struct net_if *iface, const struct in_addr *addr)
Check if the given address belongs to same subnet that has been configured for the interface.
Definition: net_ip.h:882
net_ip_protocol_secure
Definition: net_ip.h:75
#define net_ipaddr_copy(dest, src)
Copy an IPv4 or IPv6 address.
Definition: net_ip.h:739
net_ip_mtu
Definition: net_ip.h:403
int net_rx_priority2tc(enum net_priority prio)
Convert Rx network packet priority to traffic class so we can place the packet into correct Rx queue.
static bool net_ipv4_is_addr_loopback(struct in_addr *addr)
Check if the IPv4 address is a loopback address (127.0.0.0/8).
Definition: net_ip.h:689
int net_bytes_from_str(uint8_t *buf, int buf_len, const char *src)
Convert a string of hex values to array of bytes.
static uint8_t net_priority2vlan(enum net_priority priority)
Convert network packet priority to network packet VLAN priority.
Definition: net_ip.h:1591
bool net_if_ipv4_is_addr_bcast(struct net_if *iface, const struct in_addr *addr)
static bool net_ipv6_is_prefix(const uint8_t *addr1, const uint8_t *addr2, uint8_t length)
Check if two IPv6 addresses are same when compared after prefix mask.
Definition: net_ip.h:652
bool net_ipaddr_parse(const char *str, size_t str_len, struct sockaddr *addr)
Parse a string that contains either IPv4 or IPv6 address and optional port, and store the information...
static bool net_ipv6_is_addr_loopback(struct in6_addr *addr)
Check if the IPv6 address is a loopback address (::1).
Definition: net_ip.h:589
static bool net_tcp_seq_greater(uint32_t seq1, uint32_t seq2)
Check that one TCP sequence number is greater.
Definition: net_ip.h:1516
net_sock_type
Definition: net_ip.h:84
const struct in6_addr * net_ipv6_unspecified_address(void)
Return pointer to any (all bits zeros) IPv6 address.
static bool net_ipv6_is_addr_mcast_link_all_nodes(const struct in6_addr *addr)
Check if the IPv6 address is a link local scope all nodes multicast address (FF02::1).
Definition: net_ip.h:1156
const char * net_family2str(sa_family_t family)
Return network address family value as a string. This is only usable for debugging.
static bool net_ipv4_is_ll_addr(const struct in_addr *addr)
Check if the given IPv4 address is a link local address.
Definition: net_ip.h:725
static struct sockaddr_can_ptr * net_can_ptr(const struct sockaddr_ptr *addr)
Get sockaddr_can_ptr from sockaddr_ptr. This is a helper so that the code needing this functionality ...
Definition: net_ip.h:1432
#define ntohl(x)
Convert 32-bit value from network to host byte order.
Definition: net_ip.h:104
static bool net_ipv4_is_addr_bcast(struct net_if *iface, const struct in_addr *addr)
Check if the given IPv4 address is a broadcast address.
Definition: net_ip.h:910
static bool net_ipv6_is_ll_addr(const struct in6_addr *addr)
Check if the given IPv6 address is a link local address.
Definition: net_ip.h:831
static struct sockaddr_in * net_sin(const struct sockaddr *addr)
Get sockaddr_in from sockaddr. This is a helper so that the code calling this function can be made sh...
Definition: net_ip.h:1376
const struct in_addr * net_ipv4_unspecified_address(void)
Return pointer to any (all bits zeros) IPv4 address.
static bool net_ipv6_is_addr_mcast_all_nodes_group(const struct in6_addr *addr)
Check if the IPv6 address belongs to the all nodes multicast group.
Definition: net_ip.h:1120
size_t socklen_t
Definition: net_ip.h:167
static struct sockaddr_ll_ptr * net_sll_ptr(const struct sockaddr_ptr *addr)
Get sockaddr_ll_ptr from sockaddr_ptr. This is a helper so that the code calling this function can be...
Definition: net_ip.h:1418
static struct sockaddr_in6 * net_sin6(const struct sockaddr *addr)
Get sockaddr_in6 from sockaddr. This is a helper so that the code calling this function can be made s...
Definition: net_ip.h:1363
struct net_if_mcast_addr * net_if_ipv6_maddr_lookup(const struct in6_addr *addr, struct net_if **iface)
static bool net_ipv4_is_addr_unspecified(const struct in_addr *addr)
Check if the IPv4 address is unspecified (all bits zero)
Definition: net_ip.h:701
static bool net_ipv6_is_addr_mcast_scope(const struct in6_addr *addr, int scope)
Check if the IPv6 address is a given scope multicast address (FFyx::).
Definition: net_ip.h:986
static bool net_ipv6_is_ula_addr(const struct in6_addr *addr)
Check if the given IPv6 address is a unique local address.
Definition: net_ip.h:843
static bool net_ipv6_is_addr_mcast_iface(const struct in6_addr *addr)
Check if the IPv6 address is a interface scope multicast address (FFx1::).
Definition: net_ip.h:1029
#define htonl(x)
Convert 32-bit value from host to network byte order.
Definition: net_ip.h:128
int net_tx_priority2tc(enum net_priority prio)
Convert Tx network packet priority to traffic class so we can place the packet into correct Tx queue.
static struct sockaddr_in6_ptr * net_sin6_ptr(const struct sockaddr_ptr *addr)
Get sockaddr_in6_ptr from sockaddr_ptr. This is a helper so that the code calling this function can b...
Definition: net_ip.h:1390
net_priority
Definition: net_ip.h:416
static bool net_ipv4_is_addr_mcast(const struct in_addr *addr)
Check if the IPv4 address is a multicast address.
Definition: net_ip.h:713
net_ip_protocol
Definition: net_ip.h:62
static bool net_ipv6_addr_based_on_ll(const struct in6_addr *addr, const struct net_linkaddr *lladdr)
Check if given address is based on link layer address.
Definition: net_ip.h:1297
static void net_ipv4_addr_copy_raw(uint8_t *dest, const uint8_t *src)
Copy an IPv4 address raw buffer.
Definition: net_ip.h:748
static bool net_ipv6_is_my_maddr(struct in6_addr *maddr)
Check if IPv6 multicast address is found in one of the network interfaces.
Definition: net_ip.h:638
static bool net_ipv6_addr_cmp_raw(const uint8_t *addr1, const uint8_t *addr2)
Compare two raw IPv6 address buffers.
Definition: net_ip.h:817
static bool net_ipv6_is_addr_unspecified(const struct in6_addr *addr)
Check if the IPv6 address is unspecified (all bits zero)
Definition: net_ip.h:951
net_addr_type
Definition: net_ip.h:447
@ NET_ADDR_ANY_STATE
Definition: net_ip.h:440
@ NET_ADDR_TENTATIVE
Definition: net_ip.h:441
@ NET_ADDR_DEPRECATED
Definition: net_ip.h:443
@ NET_ADDR_PREFERRED
Definition: net_ip.h:442
@ IPPROTO_TLS_1_1
Definition: net_ip.h:77
@ IPPROTO_TLS_1_0
Definition: net_ip.h:76
@ IPPROTO_DTLS_1_0
Definition: net_ip.h:79
@ IPPROTO_TLS_1_2
Definition: net_ip.h:78
@ IPPROTO_DTLS_1_2
Definition: net_ip.h:80
@ NET_IPV4_MTU
Definition: net_ip.h:412
@ NET_IPV6_MTU
Definition: net_ip.h:407
@ SOCK_DGRAM
Definition: net_ip.h:86
@ SOCK_RAW
Definition: net_ip.h:87
@ SOCK_STREAM
Definition: net_ip.h:85
@ NET_PRIORITY_NC
Definition: net_ip.h:424
@ NET_PRIORITY_IC
Definition: net_ip.h:423
@ NET_PRIORITY_CA
Definition: net_ip.h:420
@ NET_PRIORITY_VO
Definition: net_ip.h:422
@ NET_PRIORITY_VI
Definition: net_ip.h:421
@ NET_PRIORITY_BE
Definition: net_ip.h:418
@ NET_PRIORITY_EE
Definition: net_ip.h:419
@ NET_PRIORITY_BK
Definition: net_ip.h:417
@ IPPROTO_IP
Definition: net_ip.h:63
@ IPPROTO_RAW
Definition: net_ip.h:71
@ IPPROTO_IPIP
Definition: net_ip.h:66
@ IPPROTO_TCP
Definition: net_ip.h:67
@ IPPROTO_IGMP
Definition: net_ip.h:65
@ IPPROTO_ICMP
Definition: net_ip.h:64
@ IPPROTO_IPV6
Definition: net_ip.h:69
@ IPPROTO_UDP
Definition: net_ip.h:68
@ IPPROTO_ICMPV6
Definition: net_ip.h:70
@ NET_ADDR_ANY
Definition: net_ip.h:449
@ NET_ADDR_OVERRIDABLE
Definition: net_ip.h:457
@ NET_ADDR_DHCP
Definition: net_ip.h:453
@ NET_ADDR_MANUAL
Definition: net_ip.h:455
@ NET_ADDR_AUTOCONF
Definition: net_ip.h:451
@ NET_LINK_CANBUS
Definition: net_linkaddr.h:61
@ NET_LINK_IEEE802154
Definition: net_linkaddr.h:51
@ NET_LINK_ETHERNET
Definition: net_linkaddr.h:55
@ NET_LINK_BLUETOOTH
Definition: net_linkaddr.h:53
#define ARRAY_SIZE(array)
Number of elements in the given array.
Definition: util.h:108
flags
Definition: http_parser.h:131
static ZTEST_BMEM volatile int ret
Definition: k_float_disable.c:28
Public API for network link address.
__UINT32_TYPE__ uint32_t
Definition: stdint.h:60
__INT32_TYPE__ int32_t
Definition: stdint.h:44
__UINT8_TYPE__ uint8_t
Definition: stdint.h:58
__UINT16_TYPE__ uint16_t
Definition: stdint.h:59
int memcmp(const void *m1, const void *m2, size_t n)
void * memcpy(void *ZRESTRICT d, const void *ZRESTRICT s, size_t n)
Definition: net_ip.h:245
int cmsg_type
Definition: net_ip.h:248
socklen_t cmsg_len
Definition: net_ip.h:246
z_max_align_t cmsg_data[]
Definition: net_ip.h:250
int cmsg_level
Definition: net_ip.h:247
Definition: net_ip.h:139
uint8_t s6_addr[16]
Definition: net_ip.h:141
uint32_t s6_addr32[4]
Definition: net_ip.h:143
uint16_t s6_addr16[8]
Definition: net_ip.h:142
Definition: net_ip.h:151
uint8_t s4_addr[4]
Definition: net_ip.h:153
uint32_t s_addr
Definition: net_ip.h:156
uint16_t s4_addr16[2]
Definition: net_ip.h:154
uint32_t s4_addr32[1]
Definition: net_ip.h:155
Definition: net_ip.h:229
void * iov_base
Definition: net_ip.h:230
size_t iov_len
Definition: net_ip.h:231
Definition: net_ip.h:235
struct iovec * msg_iov
Definition: net_ip.h:238
socklen_t msg_namelen
Definition: net_ip.h:237
void * msg_name
Definition: net_ip.h:236
int msg_flags
Definition: net_ip.h:242
size_t msg_controllen
Definition: net_ip.h:241
size_t msg_iovlen
Definition: net_ip.h:239
void * msg_control
Definition: net_ip.h:240
Network Interface unicast IP addresses.
Definition: net_if.h:49
IP and other configuration related data for network interface.
Definition: net_if.h:373
Network Interface multicast IP addresses.
Definition: net_if.h:90
Network Interface structure.
Definition: net_if.h:468
Hardware link address structure.
Definition: net_linkaddr.h:69
uint8_t * addr
Definition: net_linkaddr.h:71
uint8_t type
Definition: net_linkaddr.h:77
uint8_t len
Definition: net_linkaddr.h:74
Definition: net_ip.h:430
struct net_addr * remote_addr
Definition: net_ip.h:431
uint16_t local_port
Definition: net_ip.h:434
enum net_ip_protocol ip_proto
Definition: net_ip.h:435
uint16_t remote_port
Definition: net_ip.h:433
struct net_addr * local_addr
Definition: net_ip.h:432
Definition: net_ip.h:223
sa_family_t can_family
Definition: net_ip.h:224
int can_ifindex
Definition: net_ip.h:225
Definition: net_ip.h:182
sa_family_t sin6_family
Definition: net_ip.h:183
uint16_t sin6_port
Definition: net_ip.h:184
uint8_t sin6_scope_id
Definition: net_ip.h:186
struct in6_addr * sin6_addr
Definition: net_ip.h:185
Definition: net_ip.h:175
uint8_t sin6_scope_id
Definition: net_ip.h:179
struct in6_addr sin6_addr
Definition: net_ip.h:178
uint16_t sin6_port
Definition: net_ip.h:177
sa_family_t sin6_family
Definition: net_ip.h:176
Definition: net_ip.h:196
struct in_addr * sin_addr
Definition: net_ip.h:199
uint16_t sin_port
Definition: net_ip.h:198
sa_family_t sin_family
Definition: net_ip.h:197
Definition: net_ip.h:190
uint16_t sin_port
Definition: net_ip.h:192
struct in_addr sin_addr
Definition: net_ip.h:193
sa_family_t sin_family
Definition: net_ip.h:191
Definition: net_ip.h:213
uint8_t * sll_addr
Definition: net_ip.h:220
uint16_t sll_hatype
Definition: net_ip.h:217
int sll_ifindex
Definition: net_ip.h:216
uint8_t sll_pkttype
Definition: net_ip.h:218
sa_family_t sll_family
Definition: net_ip.h:214
uint8_t sll_halen
Definition: net_ip.h:219
uint16_t sll_protocol
Definition: net_ip.h:215
Definition: net_ip.h:203
uint8_t sll_pkttype
Definition: net_ip.h:208
uint16_t sll_hatype
Definition: net_ip.h:207
sa_family_t sll_family
Definition: net_ip.h:204
uint16_t sll_protocol
Definition: net_ip.h:205
int sll_ifindex
Definition: net_ip.h:206
uint8_t sll_halen
Definition: net_ip.h:209
uint8_t sll_addr[8]
Definition: net_ip.h:210
Definition: net_ip.h:341
char data[NET_SOCKADDR_MAX_SIZE - sizeof(sa_family_t)]
Definition: net_ip.h:343
sa_family_t sa_family
Definition: net_ip.h:342
static fdata_t data[2]
Definition: test_fifo_contexts.c:15
Macros to abstract toolchain specific capabilities.
Misc utilities.