xref: /nrf52832-nimble/rt-thread/components/net/lwip-2.1.0/src/include/lwip/inet.h (revision 104654410c56c573564690304ae786df310c91fc)
1*10465441SEvalZero /**
2*10465441SEvalZero  * @file
3*10465441SEvalZero  * This file (together with sockets.h) aims to provide structs and functions from
4*10465441SEvalZero  * - arpa/inet.h
5*10465441SEvalZero  * - netinet/in.h
6*10465441SEvalZero  *
7*10465441SEvalZero  */
8*10465441SEvalZero 
9*10465441SEvalZero /*
10*10465441SEvalZero  * Copyright (c) 2001-2004 Swedish Institute of Computer Science.
11*10465441SEvalZero  * All rights reserved.
12*10465441SEvalZero  *
13*10465441SEvalZero  * Redistribution and use in source and binary forms, with or without modification,
14*10465441SEvalZero  * are permitted provided that the following conditions are met:
15*10465441SEvalZero  *
16*10465441SEvalZero  * 1. Redistributions of source code must retain the above copyright notice,
17*10465441SEvalZero  *    this list of conditions and the following disclaimer.
18*10465441SEvalZero  * 2. Redistributions in binary form must reproduce the above copyright notice,
19*10465441SEvalZero  *    this list of conditions and the following disclaimer in the documentation
20*10465441SEvalZero  *    and/or other materials provided with the distribution.
21*10465441SEvalZero  * 3. The name of the author may not be used to endorse or promote products
22*10465441SEvalZero  *    derived from this software without specific prior written permission.
23*10465441SEvalZero  *
24*10465441SEvalZero  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
25*10465441SEvalZero  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
26*10465441SEvalZero  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
27*10465441SEvalZero  * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
28*10465441SEvalZero  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
29*10465441SEvalZero  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
30*10465441SEvalZero  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
31*10465441SEvalZero  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
32*10465441SEvalZero  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
33*10465441SEvalZero  * OF SUCH DAMAGE.
34*10465441SEvalZero  *
35*10465441SEvalZero  * This file is part of the lwIP TCP/IP stack.
36*10465441SEvalZero  *
37*10465441SEvalZero  * Author: Adam Dunkels <[email protected]>
38*10465441SEvalZero  *
39*10465441SEvalZero  */
40*10465441SEvalZero #ifndef LWIP_HDR_INET_H
41*10465441SEvalZero #define LWIP_HDR_INET_H
42*10465441SEvalZero 
43*10465441SEvalZero #include "lwip/opt.h"
44*10465441SEvalZero #include "lwip/def.h"
45*10465441SEvalZero #include "lwip/ip_addr.h"
46*10465441SEvalZero #include "lwip/ip6_addr.h"
47*10465441SEvalZero 
48*10465441SEvalZero #ifdef __cplusplus
49*10465441SEvalZero extern "C" {
50*10465441SEvalZero #endif
51*10465441SEvalZero 
52*10465441SEvalZero /* If your port already typedef's in_addr_t, define IN_ADDR_T_DEFINED
53*10465441SEvalZero    to prevent this code from redefining it. */
54*10465441SEvalZero #if !defined(in_addr_t) && !defined(IN_ADDR_T_DEFINED)
55*10465441SEvalZero typedef u32_t in_addr_t;
56*10465441SEvalZero #endif
57*10465441SEvalZero 
58*10465441SEvalZero struct in_addr {
59*10465441SEvalZero   in_addr_t s_addr;
60*10465441SEvalZero };
61*10465441SEvalZero 
62*10465441SEvalZero struct in6_addr {
63*10465441SEvalZero   union {
64*10465441SEvalZero     u32_t u32_addr[4];
65*10465441SEvalZero     u8_t  u8_addr[16];
66*10465441SEvalZero   } un;
67*10465441SEvalZero #define s6_addr  un.u8_addr
68*10465441SEvalZero };
69*10465441SEvalZero 
70*10465441SEvalZero /** 255.255.255.255 */
71*10465441SEvalZero #define INADDR_NONE         IPADDR_NONE
72*10465441SEvalZero /** 127.0.0.1 */
73*10465441SEvalZero #define INADDR_LOOPBACK     IPADDR_LOOPBACK
74*10465441SEvalZero /** 0.0.0.0 */
75*10465441SEvalZero #define INADDR_ANY          IPADDR_ANY
76*10465441SEvalZero /** 255.255.255.255 */
77*10465441SEvalZero #define INADDR_BROADCAST    IPADDR_BROADCAST
78*10465441SEvalZero 
79*10465441SEvalZero /** This macro can be used to initialize a variable of type struct in6_addr
80*10465441SEvalZero     to the IPv6 wildcard address. */
81*10465441SEvalZero #define IN6ADDR_ANY_INIT {{{0,0,0,0}}}
82*10465441SEvalZero /** This macro can be used to initialize a variable of type struct in6_addr
83*10465441SEvalZero     to the IPv6 loopback address. */
84*10465441SEvalZero #define IN6ADDR_LOOPBACK_INIT {{{0,0,0,PP_HTONL(1)}}}
85*10465441SEvalZero /** This variable is initialized by the system to contain the wildcard IPv6 address. */
86*10465441SEvalZero extern const struct in6_addr in6addr_any;
87*10465441SEvalZero 
88*10465441SEvalZero /* Definitions of the bits in an (IPv4) Internet address integer.
89*10465441SEvalZero 
90*10465441SEvalZero    On subnets, host and network parts are found according to
91*10465441SEvalZero    the subnet mask, not these masks.  */
92*10465441SEvalZero #define IN_CLASSA(a)        IP_CLASSA(a)
93*10465441SEvalZero #define IN_CLASSA_NET       IP_CLASSA_NET
94*10465441SEvalZero #define IN_CLASSA_NSHIFT    IP_CLASSA_NSHIFT
95*10465441SEvalZero #define IN_CLASSA_HOST      IP_CLASSA_HOST
96*10465441SEvalZero #define IN_CLASSA_MAX       IP_CLASSA_MAX
97*10465441SEvalZero 
98*10465441SEvalZero #define IN_CLASSB(b)        IP_CLASSB(b)
99*10465441SEvalZero #define IN_CLASSB_NET       IP_CLASSB_NET
100*10465441SEvalZero #define IN_CLASSB_NSHIFT    IP_CLASSB_NSHIFT
101*10465441SEvalZero #define IN_CLASSB_HOST      IP_CLASSB_HOST
102*10465441SEvalZero #define IN_CLASSB_MAX       IP_CLASSB_MAX
103*10465441SEvalZero 
104*10465441SEvalZero #define IN_CLASSC(c)        IP_CLASSC(c)
105*10465441SEvalZero #define IN_CLASSC_NET       IP_CLASSC_NET
106*10465441SEvalZero #define IN_CLASSC_NSHIFT    IP_CLASSC_NSHIFT
107*10465441SEvalZero #define IN_CLASSC_HOST      IP_CLASSC_HOST
108*10465441SEvalZero #define IN_CLASSC_MAX       IP_CLASSC_MAX
109*10465441SEvalZero 
110*10465441SEvalZero #define IN_CLASSD(d)        IP_CLASSD(d)
111*10465441SEvalZero #define IN_CLASSD_NET       IP_CLASSD_NET     /* These ones aren't really */
112*10465441SEvalZero #define IN_CLASSD_NSHIFT    IP_CLASSD_NSHIFT  /*   net and host fields, but */
113*10465441SEvalZero #define IN_CLASSD_HOST      IP_CLASSD_HOST    /*   routing needn't know. */
114*10465441SEvalZero #define IN_CLASSD_MAX       IP_CLASSD_MAX
115*10465441SEvalZero 
116*10465441SEvalZero #define IN_MULTICAST(a)     IP_MULTICAST(a)
117*10465441SEvalZero 
118*10465441SEvalZero #define IN_EXPERIMENTAL(a)  IP_EXPERIMENTAL(a)
119*10465441SEvalZero #define IN_BADCLASS(a)      IP_BADCLASS(a)
120*10465441SEvalZero 
121*10465441SEvalZero #define IN_LOOPBACKNET      IP_LOOPBACKNET
122*10465441SEvalZero 
123*10465441SEvalZero 
124*10465441SEvalZero #ifndef INET_ADDRSTRLEN
125*10465441SEvalZero #define INET_ADDRSTRLEN     IP4ADDR_STRLEN_MAX
126*10465441SEvalZero #endif
127*10465441SEvalZero #if LWIP_IPV6
128*10465441SEvalZero #ifndef INET6_ADDRSTRLEN
129*10465441SEvalZero #define INET6_ADDRSTRLEN    IP6ADDR_STRLEN_MAX
130*10465441SEvalZero #endif
131*10465441SEvalZero #endif
132*10465441SEvalZero 
133*10465441SEvalZero #if LWIP_IPV4
134*10465441SEvalZero 
135*10465441SEvalZero #define inet_addr_from_ip4addr(target_inaddr, source_ipaddr) ((target_inaddr)->s_addr = ip4_addr_get_u32(source_ipaddr))
136*10465441SEvalZero #define inet_addr_to_ip4addr(target_ipaddr, source_inaddr)   (ip4_addr_set_u32(target_ipaddr, (source_inaddr)->s_addr))
137*10465441SEvalZero 
138*10465441SEvalZero /* directly map this to the lwip internal functions */
139*10465441SEvalZero #define inet_addr(cp)                   ipaddr_addr(cp)
140*10465441SEvalZero #define inet_aton(cp, addr)             ip4addr_aton(cp, (ip4_addr_t*)addr)
141*10465441SEvalZero #define inet_ntoa(addr)                 ip4addr_ntoa((const ip4_addr_t*)&(addr))
142*10465441SEvalZero #define inet_ntoa_r(addr, buf, buflen)  ip4addr_ntoa_r((const ip4_addr_t*)&(addr), buf, buflen)
143*10465441SEvalZero 
144*10465441SEvalZero #endif /* LWIP_IPV4 */
145*10465441SEvalZero 
146*10465441SEvalZero #if LWIP_IPV6
147*10465441SEvalZero #define inet6_addr_from_ip6addr(target_in6addr, source_ip6addr) {(target_in6addr)->un.u32_addr[0] = (source_ip6addr)->addr[0]; \
148*10465441SEvalZero                                                                  (target_in6addr)->un.u32_addr[1] = (source_ip6addr)->addr[1]; \
149*10465441SEvalZero                                                                  (target_in6addr)->un.u32_addr[2] = (source_ip6addr)->addr[2]; \
150*10465441SEvalZero                                                                  (target_in6addr)->un.u32_addr[3] = (source_ip6addr)->addr[3];}
151*10465441SEvalZero #define inet6_addr_to_ip6addr(target_ip6addr, source_in6addr)   {(target_ip6addr)->addr[0] = (source_in6addr)->un.u32_addr[0]; \
152*10465441SEvalZero                                                                  (target_ip6addr)->addr[1] = (source_in6addr)->un.u32_addr[1]; \
153*10465441SEvalZero                                                                  (target_ip6addr)->addr[2] = (source_in6addr)->un.u32_addr[2]; \
154*10465441SEvalZero                                                                  (target_ip6addr)->addr[3] = (source_in6addr)->un.u32_addr[3]; \
155*10465441SEvalZero                                                                  ip6_addr_clear_zone(target_ip6addr);}
156*10465441SEvalZero 
157*10465441SEvalZero /* directly map this to the lwip internal functions */
158*10465441SEvalZero #define inet6_aton(cp, addr)            ip6addr_aton(cp, (ip6_addr_t*)addr)
159*10465441SEvalZero #define inet6_ntoa(addr)                ip6addr_ntoa((const ip6_addr_t*)&(addr))
160*10465441SEvalZero #define inet6_ntoa_r(addr, buf, buflen) ip6addr_ntoa_r((const ip6_addr_t*)&(addr), buf, buflen)
161*10465441SEvalZero 
162*10465441SEvalZero #endif /* LWIP_IPV6 */
163*10465441SEvalZero 
164*10465441SEvalZero 
165*10465441SEvalZero #ifdef __cplusplus
166*10465441SEvalZero }
167*10465441SEvalZero #endif
168*10465441SEvalZero 
169*10465441SEvalZero #endif /* LWIP_HDR_INET_H */
170