| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556 | /** @file * @brief IPv6 and IPv4 definitions * * Generic IPv6 and IPv4 address definitions. *//* * Copyright (c) 2016 Intel Corporation * * SPDX-License-Identifier: Apache-2.0 */#ifndef ZEPHYR_INCLUDE_NET_NET_IP_H_#define ZEPHYR_INCLUDE_NET_NET_IP_H_/** * @brief IPv4/IPv6 primitives and helpers * @defgroup ip_4_6 IPv4/IPv6 primitives and helpers * @ingroup networking * @{ */#include <string.h>#include <zephyr/types.h>#include <stdbool.h>#include <sys/util.h>#include <sys/byteorder.h>#include <toolchain.h>#include <net/net_linkaddr.h>#ifdef __cplusplusextern "C" {#endif/** @cond INTERNAL_HIDDEN *//* Specifying VLAN tag here in order to avoid circular dependencies */#define NET_VLAN_TAG_UNSPEC 0x0fff/** @endcond *//* Protocol families. */#define PF_UNSPEC       0          /**< Unspecified protocol family.  */#define PF_INET         1          /**< IP protocol family version 4. */#define PF_INET6        2          /**< IP protocol family version 6. */#define PF_PACKET       3          /**< Packet family.                */#define PF_CAN          4          /**< Controller Area Network.      */#define PF_NET_MGMT     5          /**< Network management info.      */#define PF_LOCAL        6          /**< Inter-process communication   */#define PF_UNIX         PF_LOCAL   /**< Inter-process communication   *//* Address families. */#define AF_UNSPEC      PF_UNSPEC   /**< Unspecified address family.   */#define AF_INET        PF_INET     /**< IP protocol family version 4. */#define AF_INET6       PF_INET6    /**< IP protocol family version 6. */#define AF_PACKET      PF_PACKET   /**< Packet family.                */#define AF_CAN         PF_CAN      /**< Controller Area Network.      */#define AF_NET_MGMT    PF_NET_MGMT /**< Network management info.      */#define AF_LOCAL       PF_LOCAL    /**< Inter-process communication   */#define AF_UNIX        PF_UNIX     /**< Inter-process communication   *//** Protocol numbers from IANA/BSD */enum net_ip_protocol {	IPPROTO_IP = 0,            /**< IP protocol (pseudo-val for setsockopt() */	IPPROTO_ICMP = 1,          /**< ICMP protocol   */	IPPROTO_IGMP = 2,          /**< IGMP protocol   */	IPPROTO_IPIP = 4,          /**< IPIP tunnels    */	IPPROTO_TCP = 6,           /**< TCP protocol    */	IPPROTO_UDP = 17,          /**< UDP protocol    */	IPPROTO_IPV6 = 41,         /**< IPv6 protocol   */	IPPROTO_ICMPV6 = 58,       /**< ICMPv6 protocol */	IPPROTO_RAW = 255,         /**< RAW IP packets  */};/** Protocol numbers for TLS protocols */enum net_ip_protocol_secure {	IPPROTO_TLS_1_0 = 256,     /**< TLS 1.0 protocol */	IPPROTO_TLS_1_1 = 257,     /**< TLS 1.1 protocol */	IPPROTO_TLS_1_2 = 258,     /**< TLS 1.2 protocol */	IPPROTO_DTLS_1_0 = 272,    /**< DTLS 1.0 protocol */	IPPROTO_DTLS_1_2 = 273,    /**< DTLS 1.2 protocol */};/** Socket type */enum net_sock_type {	SOCK_STREAM = 1,           /**< Stream socket type   */	SOCK_DGRAM,                /**< Datagram socket type */	SOCK_RAW                   /**< RAW socket type      */};/** @brief Convert 16-bit value from network to host byte order. * * @param x The network byte order value to convert. * * @return Host byte order value. */#define ntohs(x) sys_be16_to_cpu(x)/** @brief Convert 32-bit value from network to host byte order. * * @param x The network byte order value to convert. * * @return Host byte order value. */#define ntohl(x) sys_be32_to_cpu(x)/** @brief Convert 64-bit value from network to host byte order. * * @param x The network byte order value to convert. * * @return Host byte order value. */#define ntohll(x) sys_be64_to_cpu(x)/** @brief Convert 16-bit value from host to network byte order. * * @param x The host byte order value to convert. * * @return Network byte order value. */#define htons(x) sys_cpu_to_be16(x)/** @brief Convert 32-bit value from host to network byte order. * * @param x The host byte order value to convert. * * @return Network byte order value. */#define htonl(x) sys_cpu_to_be32(x)/** @brief Convert 64-bit value from host to network byte order. * * @param x The host byte order value to convert. * * @return Network byte order value. */#define htonll(x) sys_cpu_to_be64(x)/** IPv6 address struct */struct in6_addr {	union {		uint8_t s6_addr[16];		uint16_t s6_addr16[8]; /* In big endian */		uint32_t s6_addr32[4]; /* In big endian */	};};/** IPv4 address struct */struct in_addr {	union {		uint8_t s4_addr[4];		uint16_t s4_addr16[2]; /* In big endian */		uint32_t s4_addr32[1]; /* In big endian */		uint32_t s_addr; /* In big endian, for POSIX compatibility. */	};};/** Socket address family type */typedef unsigned short int sa_family_t;/** Length of a socket address */typedef size_t socklen_t;/* * Note that the sin_port and sin6_port are in network byte order * in various sockaddr* structs. *//** Socket address struct for IPv6. */struct sockaddr_in6 {	sa_family_t		sin6_family;   /* AF_INET6               */	uint16_t		sin6_port;     /* Port number            */	struct in6_addr		sin6_addr;     /* IPv6 address           */	uint8_t			sin6_scope_id; /* interfaces for a scope */};struct sockaddr_in6_ptr {	sa_family_t		sin6_family;   /* AF_INET6               */	uint16_t		sin6_port;     /* Port number            */	struct in6_addr		*sin6_addr;    /* IPv6 address           */	uint8_t			sin6_scope_id; /* interfaces for a scope */};/** Socket address struct for IPv4. */struct sockaddr_in {	sa_family_t		sin_family;    /* AF_INET      */	uint16_t		sin_port;      /* Port number  */	struct in_addr		sin_addr;      /* IPv4 address */};struct sockaddr_in_ptr {	sa_family_t		sin_family;    /* AF_INET      */	uint16_t		sin_port;      /* Port number  */	struct in_addr		*sin_addr;     /* IPv4 address */};/** Socket address struct for packet socket. */struct sockaddr_ll {	sa_family_t sll_family;   /* Always AF_PACKET        */	uint16_t    sll_protocol; /* Physical-layer protocol */	int         sll_ifindex;  /* Interface number        */	uint16_t    sll_hatype;   /* ARP hardware type       */	uint8_t     sll_pkttype;  /* Packet type             */	uint8_t     sll_halen;    /* Length of address       */	uint8_t     sll_addr[8];  /* Physical-layer address  */};struct sockaddr_ll_ptr {	sa_family_t sll_family;   /* Always AF_PACKET        */	uint16_t    sll_protocol; /* Physical-layer protocol */	int         sll_ifindex;  /* Interface number        */	uint16_t    sll_hatype;   /* ARP hardware type       */	uint8_t     sll_pkttype;  /* Packet type             */	uint8_t     sll_halen;    /* Length of address       */	uint8_t     *sll_addr;    /* Physical-layer address  */};struct sockaddr_can_ptr {	sa_family_t can_family;	int         can_ifindex;};#if !defined(HAVE_IOVEC)struct iovec {	void  *iov_base;	size_t iov_len;};#endifstruct msghdr {	void         *msg_name;       /* optional socket address */	socklen_t     msg_namelen;    /* size of socket address */	struct iovec *msg_iov;        /* scatter/gather array */	size_t        msg_iovlen;     /* number of elements in msg_iov */	void         *msg_control;    /* ancillary data */	size_t        msg_controllen; /* ancillary data buffer len */	int           msg_flags;      /* flags on received message */};struct cmsghdr {	socklen_t cmsg_len;    /* Number of bytes, including header */	int       cmsg_level;  /* Originating protocol */	int       cmsg_type;   /* Protocol-specific type */	/* Flexible array member to force alignment of cmsghdr */	z_max_align_t cmsg_data[];};/* Alignment for headers and data. These are arch specific but define * them here atm if not found alredy. */#if !defined(ALIGN_H)#define ALIGN_H(x) ROUND_UP(x, __alignof__(struct cmsghdr))#endif#if !defined(ALIGN_D)#define ALIGN_D(x) ROUND_UP(x, __alignof__(z_max_align_t))#endif#if !defined(CMSG_FIRSTHDR)#define CMSG_FIRSTHDR(msghdr)					\	((msghdr)->msg_controllen >= sizeof(struct cmsghdr) ?	\	 (struct cmsghdr *)((msghdr)->msg_control) : NULL)#endif#if !defined(CMSG_NXTHDR)#define CMSG_NXTHDR(msghdr, cmsg)					 \	(((cmsg) == NULL) ? CMSG_FIRSTHDR(msghdr) :			 \	 (((uint8_t *)(cmsg) + ALIGN_H((cmsg)->cmsg_len) +		 \	   ALIGN_D(sizeof(struct cmsghdr)) >				 \	   (uint8_t *)((msghdr)->msg_control) + (msghdr)->msg_controllen) ? \	  NULL :							 \	  (struct cmsghdr *)((uint8_t *)(cmsg) +			 \			     ALIGN_H((cmsg)->cmsg_len))))#endif#if !defined(CMSG_DATA)#define CMSG_DATA(cmsg) ((uint8_t *)(cmsg) + ALIGN_D(sizeof(struct cmsghdr)))#endif#if !defined(CMSG_SPACE)#define CMSG_SPACE(length) (ALIGN_D(sizeof(struct cmsghdr)) + ALIGN_H(length))#endif#if !defined(CMSG_LEN)#define CMSG_LEN(length) (ALIGN_D(sizeof(struct cmsghdr)) + length)#endif/** @cond INTERNAL_HIDDEN *//* Packet types.  */#define PACKET_HOST         0     /* To us            */#define PACKET_BROADCAST    1     /* To all           */#define PACKET_MULTICAST    2     /* To group         */#define PACKET_OTHERHOST    3     /* To someone else  */#define PACKET_OUTGOING     4     /* Originated by us */#define PACKET_LOOPBACK     5#define PACKET_FASTROUTE    6/* Note: These macros are defined in a specific order. * The largest sockaddr size is the last one. */#if defined(CONFIG_NET_IPV4)#undef NET_SOCKADDR_MAX_SIZE#undef NET_SOCKADDR_PTR_MAX_SIZE#define NET_SOCKADDR_MAX_SIZE (sizeof(struct sockaddr_in))#define NET_SOCKADDR_PTR_MAX_SIZE (sizeof(struct sockaddr_in_ptr))#endif#if defined(CONFIG_NET_SOCKETS_PACKET)#undef NET_SOCKADDR_MAX_SIZE#undef NET_SOCKADDR_PTR_MAX_SIZE#define NET_SOCKADDR_MAX_SIZE (sizeof(struct sockaddr_ll))#define NET_SOCKADDR_PTR_MAX_SIZE (sizeof(struct sockaddr_ll_ptr))#endif#if defined(CONFIG_NET_IPV6)#undef NET_SOCKADDR_MAX_SIZE#define NET_SOCKADDR_MAX_SIZE (sizeof(struct sockaddr_in6))#if !defined(CONFIG_NET_SOCKETS_PACKET)#undef NET_SOCKADDR_PTR_MAX_SIZE#define NET_SOCKADDR_PTR_MAX_SIZE (sizeof(struct sockaddr_in6_ptr))#endif#endif#if !defined(CONFIG_NET_IPV4)#if !defined(CONFIG_NET_IPV6)#if !defined(CONFIG_NET_SOCKETS_PACKET)#define NET_SOCKADDR_MAX_SIZE (sizeof(struct sockaddr_in6))#define NET_SOCKADDR_PTR_MAX_SIZE (sizeof(struct sockaddr_in6_ptr))#endif#endif#endif/** @endcond *//** Generic sockaddr struct. Must be cast to proper type. */struct sockaddr {	sa_family_t sa_family;	char data[NET_SOCKADDR_MAX_SIZE - sizeof(sa_family_t)];};/** @cond INTERNAL_HIDDEN */struct sockaddr_ptr {	sa_family_t family;	char data[NET_SOCKADDR_PTR_MAX_SIZE - sizeof(sa_family_t)];};/* Same as sockaddr in our case */struct sockaddr_storage {	sa_family_t ss_family;	char data[NET_SOCKADDR_MAX_SIZE - sizeof(sa_family_t)];};/* Socket address struct for UNIX domain sockets */struct sockaddr_un {	sa_family_t sun_family;    /* AF_UNIX */	char        sun_path[NET_SOCKADDR_MAX_SIZE - sizeof(sa_family_t)];};struct net_addr {	sa_family_t family;	union {		struct in6_addr in6_addr;		struct in_addr in_addr;	};};#define IN6ADDR_ANY_INIT { { { 0, 0, 0, 0, 0, 0, 0, 0, 0, \				0, 0, 0, 0, 0, 0, 0 } } }#define IN6ADDR_LOOPBACK_INIT { { { 0, 0, 0, 0, 0, 0, 0, \				0, 0, 0, 0, 0, 0, 0, 0, 1 } } }extern const struct in6_addr in6addr_any;extern const struct in6_addr in6addr_loopback;/** @endcond *//** Max length of the IPv4 address as a string. Defined by POSIX. */#define INET_ADDRSTRLEN 16/** Max length of the IPv6 address as a string. Takes into account possible * mapped IPv4 addresses. */#define INET6_ADDRSTRLEN 46/** @cond INTERNAL_HIDDEN *//* These are for internal usage of the stack */#define NET_IPV6_ADDR_LEN sizeof("xxxx:xxxx:xxxx:xxxx:xxxx:xxxx:xxxx:xxxx")#define NET_IPV4_ADDR_LEN sizeof("xxx.xxx.xxx.xxx")#define INADDR_ANY 0#define INADDR_ANY_INIT { { { INADDR_ANY } } }/** @endcond */enum net_ip_mtu {	/** IPv6 MTU length. We must be able to receive this size IPv6 packet	 * without fragmentation.	 */	NET_IPV6_MTU = 1280,	/** IPv4 MTU length. We must be able to receive this size IPv4 packet	 * without fragmentation.	 */	NET_IPV4_MTU = 576,};/** Network packet priority settings described in IEEE 802.1Q Annex I.1 */enum net_priority {	NET_PRIORITY_BK = 1, /**< Background (lowest)                */	NET_PRIORITY_BE = 0, /**< Best effort (default)              */	NET_PRIORITY_EE = 2, /**< Excellent effort                   */	NET_PRIORITY_CA = 3, /**< Critical applications (highest)    */	NET_PRIORITY_VI = 4, /**< Video, < 100 ms latency and jitter */	NET_PRIORITY_VO = 5, /**< Voice, < 10 ms latency and jitter  */	NET_PRIORITY_IC = 6, /**< Internetwork control               */	NET_PRIORITY_NC = 7  /**< Network control                    */} __packed;#define NET_MAX_PRIORITIES 8 /* How many priority values there are *//** IPv6/IPv4 network connection tuple */struct net_tuple {	struct net_addr *remote_addr;  /**< IPv6/IPv4 remote address */	struct net_addr *local_addr;   /**< IPv6/IPv4 local address  */	uint16_t remote_port;          /**< UDP/TCP remote port      */	uint16_t local_port;           /**< UDP/TCP local port       */	enum net_ip_protocol ip_proto; /**< IP protocol              */};/** What is the current state of the network address */enum net_addr_state {	NET_ADDR_ANY_STATE = -1, /**< Default (invalid) address type */	NET_ADDR_TENTATIVE = 0,  /**< Tentative address              */	NET_ADDR_PREFERRED,      /**< Preferred address              */	NET_ADDR_DEPRECATED,     /**< Deprecated address             */} __packed;/** How the network address is assigned to network interface */enum net_addr_type {	/** Default value. This is not a valid value. */	NET_ADDR_ANY = 0,	/** Auto configured address */	NET_ADDR_AUTOCONF,	/** Address is from DHCP */	NET_ADDR_DHCP,	/** Manually set address */	NET_ADDR_MANUAL,	/** Manually set address which is overridable by DHCP */	NET_ADDR_OVERRIDABLE,} __packed;/** @cond INTERNAL_HIDDEN */struct net_ipv6_hdr {	uint8_t vtc;	uint8_t tcflow;	uint16_t flow;	uint16_t len;	uint8_t nexthdr;	uint8_t hop_limit;	struct in6_addr src;	struct in6_addr dst;} __packed;struct net_ipv6_frag_hdr {	uint8_t nexthdr;	uint8_t reserved;	uint16_t offset;	uint32_t id;} __packed;struct net_ipv4_hdr {	uint8_t vhl;	uint8_t tos;	uint16_t len;	uint8_t id[2];	uint8_t offset[2];	uint8_t ttl;	uint8_t proto;	uint16_t chksum;	struct in_addr src;	struct in_addr dst;} __packed;struct net_icmp_hdr {	uint8_t type;	uint8_t code;	uint16_t chksum;} __packed;struct net_udp_hdr {	uint16_t src_port;	uint16_t dst_port;	uint16_t len;	uint16_t chksum;} __packed;struct net_tcp_hdr {	uint16_t src_port;	uint16_t dst_port;	uint8_t seq[4];	uint8_t ack[4];	uint8_t offset;	uint8_t flags;	uint8_t wnd[2];	uint16_t chksum;	uint8_t urg[2];	uint8_t optdata[0];} __packed;static inline const char *net_addr_type2str(enum net_addr_type type){	switch (type) {	case NET_ADDR_AUTOCONF:		return "AUTO";	case NET_ADDR_DHCP:		return "DHCP";	case NET_ADDR_MANUAL:		return "MANUAL";	case NET_ADDR_OVERRIDABLE:		return "OVERRIDE";	case NET_ADDR_ANY:	default:		break;	}	return "<unknown>";}/* IPv6 extension headers types */#define NET_IPV6_NEXTHDR_HBHO        0#define NET_IPV6_NEXTHDR_DESTO       60#define NET_IPV6_NEXTHDR_ROUTING     43#define NET_IPV6_NEXTHDR_FRAG        44#define NET_IPV6_NEXTHDR_NONE        59/** * This 2 unions are here temporarily, as long as net_context.h will * be still public and not part of the core only. */union net_ip_header {	struct net_ipv4_hdr *ipv4;	struct net_ipv6_hdr *ipv6;};union net_proto_header {	struct net_udp_hdr *udp;	struct net_tcp_hdr *tcp;};#define NET_UDPH_LEN	8			/* Size of UDP header */#define NET_TCPH_LEN	20			/* Size of TCP header */#define NET_ICMPH_LEN	4			/* Size of ICMP header */#define NET_IPV6H_LEN	   40			/* Size of IPv6 header */#define NET_ICMPV6H_LEN	   NET_ICMPH_LEN	/* Size of ICMPv6 header */#define NET_IPV6UDPH_LEN   (NET_UDPH_LEN + NET_IPV6H_LEN) /* IPv6 + UDP */#define NET_IPV6TCPH_LEN   (NET_TCPH_LEN + NET_IPV6H_LEN) /* IPv6 + TCP */#define NET_IPV6ICMPH_LEN  (NET_IPV6H_LEN + NET_ICMPH_LEN) /* ICMPv6 + IPv6 */#define NET_IPV6_FRAGH_LEN 8#define NET_IPV4H_LEN	   20			/* Size of IPv4 header */#define NET_ICMPV4H_LEN	   NET_ICMPH_LEN	/* Size of ICMPv4 header */#define NET_IPV4UDPH_LEN   (NET_UDPH_LEN + NET_IPV4H_LEN) /* IPv4 + UDP */#define NET_IPV4TCPH_LEN   (NET_TCPH_LEN + NET_IPV4H_LEN) /* IPv4 + TCP */#define NET_IPV4ICMPH_LEN  (NET_IPV4H_LEN + NET_ICMPH_LEN) /* ICMPv4 + IPv4 */#define NET_IPV6H_LENGTH_OFFSET		0x04	/* Offset of the Length field in the IPv6 header */#define NET_IPV6_FRAGH_OFFSET_MASK	0xfff8	/* Mask for the 13-bit Fragment Offset field *//** @endcond *//** * @brief Check if the IPv6 address is a loopback address (::1). * * @param addr IPv6 address * * @return True if address is a loopback address, False otherwise. */static inline bool net_ipv6_is_addr_loopback(struct in6_addr *addr){	return UNALIGNED_GET(&addr->s6_addr32[0]) == 0 &&		UNALIGNED_GET(&addr->s6_addr32[1]) == 0 &&		UNALIGNED_GET(&addr->s6_addr32[2]) == 0 &&		ntohl(UNALIGNED_GET(&addr->s6_addr32[3])) == 1;}/** * @brief Check if the IPv6 address is a multicast address. * * @param addr IPv6 address * * @return True if address is multicast address, False otherwise. */static inline bool net_ipv6_is_addr_mcast(const struct in6_addr *addr){	return addr->s6_addr[0] == 0xFF;}struct net_if;struct net_if_config;extern struct net_if_addr *net_if_ipv6_addr_lookup(const struct in6_addr *addr,						   struct net_if **iface);/** * @brief Check if IPv6 address is found in one of the network interfaces. * * @param addr IPv6 address * * @return True if address was found, False otherwise. */static inline bool net_ipv6_is_my_addr(struct in6_addr *addr){	return net_if_ipv6_addr_lookup(addr, NULL) != NULL;}extern struct net_if_mcast_addr *net_if_ipv6_maddr_lookup(	const struct in6_addr *addr, struct net_if **iface);/** * @brief Check if IPv6 multicast address is found in one of the * network interfaces. * * @param maddr Multicast IPv6 address * * @return True if address was found, False otherwise. */static inline bool net_ipv6_is_my_maddr(struct in6_addr *maddr){	return net_if_ipv6_maddr_lookup(maddr, NULL) != NULL;}/** * @brief Check if two IPv6 addresses are same when compared after prefix mask. * * @param addr1 First IPv6 address. * @param addr2 Second IPv6 address. * @param length Prefix length (max length is 128). * * @return True if IPv6 prefixes are the same, False otherwise. */static inline bool net_ipv6_is_prefix(const uint8_t *addr1,				      const uint8_t *addr2,				      uint8_t length){	uint8_t bits = 128 - length;	uint8_t bytes = length / 8U;	uint8_t remain = bits % 8;	uint8_t mask;	if (length > 128) {		return false;	}	if (memcmp(addr1, addr2, bytes)) {		return false;	}	if (!remain) {		/* No remaining bits, the prefixes are the same as first		 * bytes are the same.		 */		return true;	}	/* Create a mask that has remaining most significant bits set */	mask = ((0xff << (8 - remain)) ^ 0xff) << remain;	return (addr1[bytes] & mask) == (addr2[bytes] & mask);}/** * @brief Check if the IPv4 address is a loopback address (127.0.0.0/8). * * @param addr IPv4 address * * @return True if address is a loopback address, False otherwise. */static inline bool net_ipv4_is_addr_loopback(struct in_addr *addr){	return addr->s4_addr[0] == 127U;}/** *  @brief Check if the IPv4 address is unspecified (all bits zero) * *  @param addr IPv4 address. * *  @return True if the address is unspecified, false otherwise. */static inline bool net_ipv4_is_addr_unspecified(const struct in_addr *addr){	return UNALIGNED_GET(&addr->s_addr) == 0;}/** * @brief Check if the IPv4 address is a multicast address. * * @param addr IPv4 address * * @return True if address is multicast address, False otherwise. */static inline bool net_ipv4_is_addr_mcast(const struct in_addr *addr){	return (ntohl(UNALIGNED_GET(&addr->s_addr)) & 0xF0000000) == 0xE0000000;}/** * @brief Check if the given IPv4 address is a link local address. * * @param addr A valid pointer on an IPv4 address * * @return True if it is, false otherwise. */static inline bool net_ipv4_is_ll_addr(const struct in_addr *addr){	return (ntohl(UNALIGNED_GET(&addr->s_addr)) & 0xA9FE0000) == 0xA9FE0000;}/** *  @def net_ipaddr_copy *  @brief Copy an IPv4 or IPv6 address * *  @param dest Destination IP address. *  @param src Source IP address. * *  @return Destination address. */#define net_ipaddr_copy(dest, src) \	UNALIGNED_PUT(UNALIGNED_GET(src), dest)/** *  @brief Compare two IPv4 addresses * *  @param addr1 Pointer to IPv4 address. *  @param addr2 Pointer to IPv4 address. * *  @return True if the addresses are the same, false otherwise. */static inline bool net_ipv4_addr_cmp(const struct in_addr *addr1,				     const struct in_addr *addr2){	return UNALIGNED_GET(&addr1->s_addr) == UNALIGNED_GET(&addr2->s_addr);}/** *  @brief Compare two IPv6 addresses * *  @param addr1 Pointer to IPv6 address. *  @param addr2 Pointer to IPv6 address. * *  @return True if the addresses are the same, false otherwise. */static inline bool net_ipv6_addr_cmp(const struct in6_addr *addr1,				     const struct in6_addr *addr2){	return !memcmp(addr1, addr2, sizeof(struct in6_addr));}/** * @brief Check if the given IPv6 address is a link local address. * * @param addr A valid pointer on an IPv6 address * * @return True if it is, false otherwise. */static inline bool net_ipv6_is_ll_addr(const struct in6_addr *addr){	return UNALIGNED_GET(&addr->s6_addr16[0]) == htons(0xFE80);}/** * @brief Check if the given IPv6 address is a unique local address. * * @param addr A valid pointer on an IPv6 address * * @return True if it is, false otherwise. */static inline bool net_ipv6_is_ula_addr(const struct in6_addr *addr){	return addr->s6_addr[0] == 0xFD;}/** * @brief Return pointer to any (all bits zeros) IPv6 address. * * @return Any IPv6 address. */const struct in6_addr *net_ipv6_unspecified_address(void);/** * @brief Return pointer to any (all bits zeros) IPv4 address. * * @return Any IPv4 address. */const struct in_addr *net_ipv4_unspecified_address(void);/** * @brief Return pointer to broadcast (all bits ones) IPv4 address. * * @return Broadcast IPv4 address. */const struct in_addr *net_ipv4_broadcast_address(void);struct net_if;extern bool net_if_ipv4_addr_mask_cmp(struct net_if *iface,				      const struct in_addr *addr);/** * @brief Check if the given address belongs to same subnet that * has been configured for the interface. * * @param iface A valid pointer on an interface * @param addr IPv4 address * * @return True if address is in same subnet, false otherwise. */static inline bool net_ipv4_addr_mask_cmp(struct net_if *iface,					  const struct in_addr *addr){	return net_if_ipv4_addr_mask_cmp(iface, addr);}extern bool net_if_ipv4_is_addr_bcast(struct net_if *iface,				      const struct in_addr *addr);/** * @brief Check if the given IPv4 address is a broadcast address. * * @param iface Interface to use. Must be a valid pointer to an interface. * @param addr IPv4 address * * @return True if address is a broadcast address, false otherwise. */#if defined(CONFIG_NET_NATIVE_IPV4)static inline bool net_ipv4_is_addr_bcast(struct net_if *iface,					  const struct in_addr *addr){	if (net_ipv4_addr_cmp(addr, net_ipv4_broadcast_address())) {		return true;	}	return net_if_ipv4_is_addr_bcast(iface, addr);}#elsestatic inline bool net_ipv4_is_addr_bcast(struct net_if *iface,					  const struct in_addr *addr){	ARG_UNUSED(iface);	ARG_UNUSED(addr);	return false;}#endifextern struct net_if_addr *net_if_ipv4_addr_lookup(const struct in_addr *addr,						   struct net_if **iface);/** * @brief Check if the IPv4 address is assigned to any network interface * in the system. * * @param addr A valid pointer on an IPv4 address * * @return True if IPv4 address is found in one of the network interfaces, * False otherwise. */static inline bool net_ipv4_is_my_addr(const struct in_addr *addr){	bool ret;	ret = net_if_ipv4_addr_lookup(addr, NULL) != NULL;	if (!ret) {		ret = net_ipv4_is_addr_bcast(NULL, addr);	}	return ret;}/** *  @brief Check if the IPv6 address is unspecified (all bits zero) * *  @param addr IPv6 address. * *  @return True if the address is unspecified, false otherwise. */static inline bool net_ipv6_is_addr_unspecified(const struct in6_addr *addr){	return UNALIGNED_GET(&addr->s6_addr32[0]) == 0 &&		UNALIGNED_GET(&addr->s6_addr32[1]) == 0 &&		UNALIGNED_GET(&addr->s6_addr32[2]) == 0 &&		UNALIGNED_GET(&addr->s6_addr32[3]) == 0;}/** *  @brief Check if the IPv6 address is solicited node multicast address *  FF02:0:0:0:0:1:FFXX:XXXX defined in RFC 3513 * *  @param addr IPv6 address. * *  @return True if the address is solicited node address, false otherwise. */static inline bool net_ipv6_is_addr_solicited_node(const struct in6_addr *addr){	return UNALIGNED_GET(&addr->s6_addr32[0]) == htonl(0xff020000) &&		UNALIGNED_GET(&addr->s6_addr32[1]) == 0x00000000 &&		UNALIGNED_GET(&addr->s6_addr32[2]) == htonl(0x00000001) &&		((UNALIGNED_GET(&addr->s6_addr32[3]) & htonl(0xff000000)) ==		 htonl(0xff000000));}/** * @brief Check if the IPv6 address is a given scope multicast * address (FFyx::). * * @param addr IPv6 address * @param scope Scope to check * * @return True if the address is in given scope multicast address, * false otherwise. */static inline bool net_ipv6_is_addr_mcast_scope(const struct in6_addr *addr,						int scope){	return (addr->s6_addr[0] == 0xff) && (addr->s6_addr[1] == scope);}/** * @brief Check if the IPv6 addresses have the same multicast scope (FFyx::). * * @param addr_1 IPv6 address 1 * @param addr_2 IPv6 address 2 * * @return True if both addresses have same multicast scope, * false otherwise. */static inline bool net_ipv6_is_same_mcast_scope(const struct in6_addr *addr_1,						const struct in6_addr *addr_2){	return (addr_1->s6_addr[0] == 0xff) && (addr_2->s6_addr[0] == 0xff) &&			(addr_1->s6_addr[1] == addr_2->s6_addr[1]);}/** * @brief Check if the IPv6 address is a global multicast address (FFxE::/16). * * @param addr IPv6 address. * * @return True if the address is global multicast address, false otherwise. */static inline bool net_ipv6_is_addr_mcast_global(const struct in6_addr *addr){	return net_ipv6_is_addr_mcast_scope(addr, 0x0e);}/** * @brief Check if the IPv6 address is a interface scope multicast * address (FFx1::). * * @param addr IPv6 address. * * @return True if the address is a interface scope multicast address, * false otherwise. */static inline bool net_ipv6_is_addr_mcast_iface(const struct in6_addr *addr){	return net_ipv6_is_addr_mcast_scope(addr, 0x01);}/** * @brief Check if the IPv6 address is a link local scope multicast * address (FFx2::). * * @param addr IPv6 address. * * @return True if the address is a link local scope multicast address, * false otherwise. */static inline bool net_ipv6_is_addr_mcast_link(const struct in6_addr *addr){	return net_ipv6_is_addr_mcast_scope(addr, 0x02);}/** * @brief Check if the IPv6 address is a mesh-local scope multicast * address (FFx3::). * * @param addr IPv6 address. * * @return True if the address is a mesh-local scope multicast address, * false otherwise. */static inline bool net_ipv6_is_addr_mcast_mesh(const struct in6_addr *addr){	return net_ipv6_is_addr_mcast_scope(addr, 0x03);}/** * @brief Check if the IPv6 address is a site scope multicast * address (FFx5::). * * @param addr IPv6 address. * * @return True if the address is a site scope multicast address, * false otherwise. */static inline bool net_ipv6_is_addr_mcast_site(const struct in6_addr *addr){	return net_ipv6_is_addr_mcast_scope(addr, 0x05);}/** * @brief Check if the IPv6 address is an organization scope multicast * address (FFx8::). * * @param addr IPv6 address. * * @return True if the address is an organization scope multicast address, * false otherwise. */static inline bool net_ipv6_is_addr_mcast_org(const struct in6_addr *addr){	return net_ipv6_is_addr_mcast_scope(addr, 0x08);}/** * @brief Check if the IPv6 address belongs to certain multicast group * * @param addr IPv6 address. * @param group Group id IPv6 address, the values must be in network * byte order * * @return True if the IPv6 multicast address belongs to given multicast * group, false otherwise. */static inline bool net_ipv6_is_addr_mcast_group(const struct in6_addr *addr,						const struct in6_addr *group){	return UNALIGNED_GET(&addr->s6_addr16[1]) == group->s6_addr16[1] &&		UNALIGNED_GET(&addr->s6_addr16[2]) == group->s6_addr16[2] &&		UNALIGNED_GET(&addr->s6_addr16[3]) == group->s6_addr16[3] &&		UNALIGNED_GET(&addr->s6_addr32[1]) == group->s6_addr32[1] &&		UNALIGNED_GET(&addr->s6_addr32[2]) == group->s6_addr32[1] &&		UNALIGNED_GET(&addr->s6_addr32[3]) == group->s6_addr32[3];}/** * @brief Check if the IPv6 address belongs to the all nodes multicast group * * @param addr IPv6 address * * @return True if the IPv6 multicast address belongs to the all nodes multicast * group, false otherwise */static inline boolnet_ipv6_is_addr_mcast_all_nodes_group(const struct in6_addr *addr){	static const struct in6_addr all_nodes_mcast_group = {		{ { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,		    0x00, 0x00, 0x00, 0x00, 0x00, 0x01 } }	};	return net_ipv6_is_addr_mcast_group(addr, &all_nodes_mcast_group);}/** * @brief Check if the IPv6 address is a interface scope all nodes multicast * address (FF01::1). * * @param addr IPv6 address. * * @return True if the address is a interface scope all nodes multicast address, * false otherwise. */static inline boolnet_ipv6_is_addr_mcast_iface_all_nodes(const struct in6_addr *addr){	return net_ipv6_is_addr_mcast_iface(addr) &&	       net_ipv6_is_addr_mcast_all_nodes_group(addr);}/** * @brief Check if the IPv6 address is a link local scope all nodes multicast * address (FF02::1). * * @param addr IPv6 address. * * @return True if the address is a link local scope all nodes multicast * address, false otherwise. */static inline boolnet_ipv6_is_addr_mcast_link_all_nodes(const struct in6_addr *addr){	return net_ipv6_is_addr_mcast_link(addr) &&	       net_ipv6_is_addr_mcast_all_nodes_group(addr);}/** *  @brief Create solicited node IPv6 multicast address *  FF02:0:0:0:0:1:FFXX:XXXX defined in RFC 3513 * *  @param src IPv6 address. *  @param dst IPv6 address. */static inlinevoid net_ipv6_addr_create_solicited_node(const struct in6_addr *src,					 struct in6_addr *dst){	dst->s6_addr[0]   = 0xFF;	dst->s6_addr[1]   = 0x02;	UNALIGNED_PUT(0, &dst->s6_addr16[1]);	UNALIGNED_PUT(0, &dst->s6_addr16[2]);	UNALIGNED_PUT(0, &dst->s6_addr16[3]);	UNALIGNED_PUT(0, &dst->s6_addr16[4]);	dst->s6_addr[10]  = 0U;	dst->s6_addr[11]  = 0x01;	dst->s6_addr[12]  = 0xFF;	dst->s6_addr[13]  = src->s6_addr[13];	UNALIGNED_PUT(UNALIGNED_GET(&src->s6_addr16[7]), &dst->s6_addr16[7]);}/** @brief Construct an IPv6 address from eight 16-bit words. * *  @param addr IPv6 address *  @param addr0 16-bit word which is part of the address *  @param addr1 16-bit word which is part of the address *  @param addr2 16-bit word which is part of the address *  @param addr3 16-bit word which is part of the address *  @param addr4 16-bit word which is part of the address *  @param addr5 16-bit word which is part of the address *  @param addr6 16-bit word which is part of the address *  @param addr7 16-bit word which is part of the address */static inline 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){	UNALIGNED_PUT(htons(addr0), &addr->s6_addr16[0]);	UNALIGNED_PUT(htons(addr1), &addr->s6_addr16[1]);	UNALIGNED_PUT(htons(addr2), &addr->s6_addr16[2]);	UNALIGNED_PUT(htons(addr3), &addr->s6_addr16[3]);	UNALIGNED_PUT(htons(addr4), &addr->s6_addr16[4]);	UNALIGNED_PUT(htons(addr5), &addr->s6_addr16[5]);	UNALIGNED_PUT(htons(addr6), &addr->s6_addr16[6]);	UNALIGNED_PUT(htons(addr7), &addr->s6_addr16[7]);}/** *  @brief Create link local allnodes multicast IPv6 address * *  @param addr IPv6 address */static inline void net_ipv6_addr_create_ll_allnodes_mcast(struct in6_addr *addr){	net_ipv6_addr_create(addr, 0xff02, 0, 0, 0, 0, 0, 0, 0x0001);}/** *  @brief Create link local allrouters multicast IPv6 address * *  @param addr IPv6 address */static inline void net_ipv6_addr_create_ll_allrouters_mcast(struct in6_addr *addr){	net_ipv6_addr_create(addr, 0xff02, 0, 0, 0, 0, 0, 0, 0x0002);}/** *  @brief Create IPv6 address interface identifier * *  @param addr IPv6 address *  @param lladdr Link local address */static inline void net_ipv6_addr_create_iid(struct in6_addr *addr,					    struct net_linkaddr *lladdr){	UNALIGNED_PUT(htonl(0xfe800000), &addr->s6_addr32[0]);	UNALIGNED_PUT(0, &addr->s6_addr32[1]);	switch (lladdr->len) {	case 2:		/* The generated IPv6 shall not toggle the		 * Universal/Local bit. RFC 6282 ch 3.2.2		 */		if (lladdr->type == NET_LINK_IEEE802154 ||		    lladdr->type == NET_LINK_CANBUS) {			UNALIGNED_PUT(0, &addr->s6_addr32[2]);			addr->s6_addr[11] = 0xff;			addr->s6_addr[12] = 0xfe;			addr->s6_addr[13] = 0U;			addr->s6_addr[14] = lladdr->addr[0];			addr->s6_addr[15] = lladdr->addr[1];		}		break;	case 6:		/* We do not toggle the Universal/Local bit		 * in Bluetooth. See RFC 7668 ch 3.2.2		 */		memcpy(&addr->s6_addr[8], lladdr->addr, 3);		addr->s6_addr[11] = 0xff;		addr->s6_addr[12] = 0xfe;		memcpy(&addr->s6_addr[13], lladdr->addr + 3, 3);#if defined(CONFIG_NET_L2_BT_ZEP1656)		/* Workaround against older Linux kernel BT IPSP code.		 * This will be removed eventually.		 */		if (lladdr->type == NET_LINK_BLUETOOTH) {			addr->s6_addr[8] ^= 0x02;		}#endif		if (lladdr->type == NET_LINK_ETHERNET) {			addr->s6_addr[8] ^= 0x02;		}		break;	case 8:		memcpy(&addr->s6_addr[8], lladdr->addr, lladdr->len);		addr->s6_addr[8] ^= 0x02;		break;	}}/** *  @brief Check if given address is based on link layer address * *  @return True if it is, False otherwise */static inline bool net_ipv6_addr_based_on_ll(const struct in6_addr *addr,					     const struct net_linkaddr *lladdr){	if (!addr || !lladdr) {		return false;	}	switch (lladdr->len) {	case 2:		if (!memcmp(&addr->s6_addr[14], lladdr->addr, lladdr->len) &&		    addr->s6_addr[8]  == 0U &&		    addr->s6_addr[9]  == 0U &&		    addr->s6_addr[10] == 0U &&		    addr->s6_addr[11] == 0xff &&		    addr->s6_addr[12] == 0xfe) {			return true;		}		break;	case 6:		if (lladdr->type == NET_LINK_ETHERNET) {			if (!memcmp(&addr->s6_addr[9], &lladdr->addr[1], 2) &&			    !memcmp(&addr->s6_addr[13], &lladdr->addr[3], 3) &&			    addr->s6_addr[11] == 0xff &&			    addr->s6_addr[12] == 0xfe &&			    (addr->s6_addr[8] ^ 0x02) == lladdr->addr[0]) {				return true;			}		} else if (lladdr->type == NET_LINK_BLUETOOTH) {			if (!memcmp(&addr->s6_addr[9], &lladdr->addr[1], 2) &&			    !memcmp(&addr->s6_addr[13], &lladdr->addr[3], 3) &&			    addr->s6_addr[11] == 0xff &&			    addr->s6_addr[12] == 0xfe#if defined(CONFIG_NET_L2_BT_ZEP1656)			    /* Workaround against older Linux kernel BT IPSP			     * code. This will be removed eventually.			     */			    && (addr->s6_addr[8] ^ 0x02) == lladdr->addr[0]#endif			    ) {				return true;			}		}		break;	case 8:		if (!memcmp(&addr->s6_addr[9], &lladdr->addr[1],			    lladdr->len - 1) &&		    (addr->s6_addr[8] ^ 0x02) == lladdr->addr[0]) {			return true;		}		break;	}	return false;}/** * @brief Get sockaddr_in6 from sockaddr. This is a helper so that * the code calling this function can be made shorter. * * @param addr Socket address * * @return Pointer to IPv6 socket address */static inline struct sockaddr_in6 *net_sin6(const struct sockaddr *addr){	return (struct sockaddr_in6 *)addr;}/** * @brief Get sockaddr_in from sockaddr. This is a helper so that * the code calling this function can be made shorter. * * @param addr Socket address * * @return Pointer to IPv4 socket address */static inline struct sockaddr_in *net_sin(const struct sockaddr *addr){	return (struct sockaddr_in *)addr;}/** * @brief Get sockaddr_in6_ptr from sockaddr_ptr. This is a helper so that * the code calling this function can be made shorter. * * @param addr Socket address * * @return Pointer to IPv6 socket address */static inlinestruct sockaddr_in6_ptr *net_sin6_ptr(const struct sockaddr_ptr *addr){	return (struct sockaddr_in6_ptr *)addr;}/** * @brief Get sockaddr_in_ptr from sockaddr_ptr. This is a helper so that * the code calling this function can be made shorter. * * @param addr Socket address * * @return Pointer to IPv4 socket address */static inlinestruct sockaddr_in_ptr *net_sin_ptr(const struct sockaddr_ptr *addr){	return (struct sockaddr_in_ptr *)addr;}/** * @brief Get sockaddr_ll_ptr from sockaddr_ptr. This is a helper so that * the code calling this function can be made shorter. * * @param addr Socket address * * @return Pointer to linklayer socket address */static inlinestruct sockaddr_ll_ptr *net_sll_ptr(const struct sockaddr_ptr *addr){	return (struct sockaddr_ll_ptr *)addr;}/** * @brief Get sockaddr_can_ptr from sockaddr_ptr. This is a helper so that * the code needing this functionality can be made shorter. * * @param addr Socket address * * @return Pointer to CAN socket address */static inlinestruct sockaddr_can_ptr *net_can_ptr(const struct sockaddr_ptr *addr){	return (struct sockaddr_can_ptr *)addr;}/** * @brief Convert a string to IP address. * * @param family IP address family (AF_INET or AF_INET6) * @param src IP address in a null terminated string * @param dst Pointer to struct in_addr if family is AF_INET or * pointer to struct in6_addr if family is AF_INET6 * * @note This function doesn't do precise error checking, * do not use for untrusted strings. * * @return 0 if ok, < 0 if error */__syscall int net_addr_pton(sa_family_t family, const char *src, void *dst);/** * @brief Convert IP address to string form. * * @param family IP address family (AF_INET or AF_INET6) * @param src Pointer to struct in_addr if family is AF_INET or *        pointer to struct in6_addr if family is AF_INET6 * @param dst Buffer for IP address as a null terminated string * @param size Number of bytes available in the buffer * * @return dst pointer if ok, NULL if error */__syscall char *net_addr_ntop(sa_family_t family, const void *src,			      char *dst, size_t size);/** * @brief Parse a string that contains either IPv4 or IPv6 address * and optional port, and store the information in user supplied * sockaddr struct. * * @details Syntax of the IP address string: *   192.0.2.1:80 *   192.0.2.42 *   [2001:db8::1]:8080 *   [2001:db8::2] *   2001:db::42 * Note that the str_len parameter is used to restrict the amount of * characters that are checked. If the string does not contain port * number, then the port number in sockaddr is not modified. * * @param str String that contains the IP address. * @param str_len Length of the string to be parsed. * @param addr Pointer to user supplied struct sockaddr. * * @return True if parsing could be done, false otherwise. */bool net_ipaddr_parse(const char *str, size_t str_len,		      struct sockaddr *addr);/** * @brief Compare TCP sequence numbers. * * @details This function compares TCP sequence numbers, *          accounting for wraparound effects. * * @param seq1 First sequence number * @param seq2 Seconds sequence number * * @return < 0 if seq1 < seq2, 0 if seq1 == seq2, > 0 if seq > seq2 */static inline int32_t net_tcp_seq_cmp(uint32_t seq1, uint32_t seq2){	return (int32_t)(seq1 - seq2);}/** * @brief Check that one TCP sequence number is greater. * * @details This is convenience function on top of net_tcp_seq_cmp(). * * @param seq1 First sequence number * @param seq2 Seconds sequence number * * @return True if seq > seq2 */static inline bool net_tcp_seq_greater(uint32_t seq1, uint32_t seq2){	return net_tcp_seq_cmp(seq1, seq2) > 0;}/** * @brief Convert a string of hex values to array of bytes. * * @details The syntax of the string is "ab:02:98:fa:42:01" * * @param buf Pointer to memory where the bytes are written. * @param buf_len Length of the memory area. * @param src String of bytes. * * @return 0 if ok, <0 if error */int net_bytes_from_str(uint8_t *buf, int buf_len, const char *src);/** * @brief Convert Tx network packet priority to traffic class so we can place * the packet into correct Tx queue. * * @param prio Network priority * * @return Tx traffic class that handles that priority network traffic. */int net_tx_priority2tc(enum net_priority prio);/** * @brief Convert Rx network packet priority to traffic class so we can place * the packet into correct Rx queue. * * @param prio Network priority * * @return Rx traffic class that handles that priority network traffic. */int net_rx_priority2tc(enum net_priority prio);/** * @brief Convert network packet VLAN priority to network packet priority so we * can place the packet into correct queue. * * @param priority VLAN priority * * @return Network priority */static inline enum net_priority net_vlan2priority(uint8_t priority){	/* Map according to IEEE 802.1Q */	static const uint8_t vlan2priority[] = {		NET_PRIORITY_BE,		NET_PRIORITY_BK,		NET_PRIORITY_EE,		NET_PRIORITY_CA,		NET_PRIORITY_VI,		NET_PRIORITY_VO,		NET_PRIORITY_IC,		NET_PRIORITY_NC	};	if (priority >= ARRAY_SIZE(vlan2priority)) {		/* Use Best Effort as the default priority */		return NET_PRIORITY_BE;	}	return (enum net_priority)vlan2priority[priority];}/** * @brief Convert network packet priority to network packet VLAN priority. * * @param priority Packet priority * * @return VLAN priority (PCP) */static inline uint8_t net_priority2vlan(enum net_priority priority){	/* The conversion works both ways */	return (uint8_t)net_vlan2priority(priority);}/** * @brief Return network address family value as a string. This is only usable * for debugging. * * @param family Network address family code * * @return Network address family as a string, or NULL if family is unknown. */const char *net_family2str(sa_family_t family);#ifdef __cplusplus}#endif#include <syscalls/net_ip.h>/** * @} */#endif /* ZEPHYR_INCLUDE_NET_NET_IP_H_ */
 |