Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
ip_addr.h
00001 /** 00002 * @file 00003 * IP address API (common IPv4 and IPv6) 00004 */ 00005 00006 /* 00007 * Copyright (c) 2001-2004 Swedish Institute of Computer Science. 00008 * All rights reserved. 00009 * 00010 * Redistribution and use in source and binary forms, with or without modification, 00011 * are permitted provided that the following conditions are met: 00012 * 00013 * 1. Redistributions of source code must retain the above copyright notice, 00014 * this list of conditions and the following disclaimer. 00015 * 2. Redistributions in binary form must reproduce the above copyright notice, 00016 * this list of conditions and the following disclaimer in the documentation 00017 * and/or other materials provided with the distribution. 00018 * 3. The name of the author may not be used to endorse or promote products 00019 * derived from this software without specific prior written permission. 00020 * 00021 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED 00022 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 00023 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT 00024 * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00025 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT 00026 * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00027 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00028 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 00029 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY 00030 * OF SUCH DAMAGE. 00031 * 00032 * This file is part of the lwIP TCP/IP stack. 00033 * 00034 * Author: Adam Dunkels <adam@sics.se> 00035 * 00036 */ 00037 #ifndef LWIP_HDR_IP_ADDR_H__ 00038 #define LWIP_HDR_IP_ADDR_H__ 00039 00040 #include "lwip/opt.h" 00041 #include "lwip/def.h" 00042 00043 #include "lwip/ip4_addr.h" 00044 #include "lwip/ip6_addr.h" 00045 00046 #ifdef __cplusplus 00047 extern "C" { 00048 #endif 00049 00050 /** These are the values for ip_addr_t.type */ 00051 #define IPADDR_TYPE_V4 0U 00052 #define IPADDR_TYPE_V6 6U 00053 #define IPADDR_TYPE_ANY 46U 00054 00055 #if LWIP_IPV4 && LWIP_IPV6 00056 /** 00057 * @ingroup ipaddr 00058 * A union struct for both IP version's addresses. 00059 * ATTENTION: watch out for its size when adding IPv6 address scope! 00060 */ 00061 typedef struct _ip_addr { 00062 union { 00063 ip6_addr_t ip6; 00064 ip4_addr_t ip4; 00065 } u_addr; 00066 u8_t type; 00067 } ip_addr_t; 00068 00069 extern const ip_addr_t ip_addr_any_type; 00070 00071 /** @ingroup ip4addr */ 00072 #define IPADDR4_INIT(u32val) { { { { u32val, 0ul, 0ul, 0ul } } }, IPADDR_TYPE_V4 } 00073 /** @ingroup ip6addr */ 00074 #define IPADDR6_INIT(a, b, c, d) { { { { a, b, c, d } } }, IPADDR_TYPE_V6 } 00075 00076 /** @ingroup ipaddr */ 00077 #define IP_IS_ANY_TYPE_VAL(ipaddr) (IP_GET_TYPE(&ipaddr) == IPADDR_TYPE_ANY) 00078 /** @ingroup ipaddr */ 00079 #define IPADDR_ANY_TYPE_INIT { { { { 0ul, 0ul, 0ul, 0ul } } }, IPADDR_TYPE_ANY } 00080 00081 /** @ingroup ip4addr */ 00082 #define IP_IS_V4_VAL(ipaddr) (IP_GET_TYPE(&ipaddr) == IPADDR_TYPE_V4) 00083 /** @ingroup ip6addr */ 00084 #define IP_IS_V6_VAL(ipaddr) (IP_GET_TYPE(&ipaddr) == IPADDR_TYPE_V6) 00085 /** @ingroup ip4addr */ 00086 #define IP_IS_V4(ipaddr) (((ipaddr) == NULL) || IP_IS_V4_VAL(*(ipaddr))) 00087 /** @ingroup ip6addr */ 00088 #define IP_IS_V6(ipaddr) (((ipaddr) != NULL) && IP_IS_V6_VAL(*(ipaddr))) 00089 00090 #define IP_SET_TYPE_VAL(ipaddr, iptype) do { (ipaddr).type = (iptype); }while(0) 00091 #define IP_SET_TYPE(ipaddr, iptype) do { if((ipaddr) != NULL) { IP_SET_TYPE_VAL(*(ipaddr), iptype); }}while(0) 00092 #define IP_GET_TYPE(ipaddr) ((ipaddr)->type) 00093 00094 #define IP_ADDR_PCB_VERSION_MATCH_EXACT(pcb, ipaddr) (IP_GET_TYPE(&pcb->local_ip) == IP_GET_TYPE(ipaddr)) 00095 #define IP_ADDR_PCB_VERSION_MATCH(pcb, ipaddr) (IP_IS_ANY_TYPE_VAL(pcb->local_ip) || IP_ADDR_PCB_VERSION_MATCH_EXACT(pcb, ipaddr)) 00096 00097 /** @ingroup ip6addr 00098 * Convert generic ip address to specific protocol version 00099 */ 00100 #define ip_2_ip6(ipaddr) (&((ipaddr)->u_addr.ip6)) 00101 /** @ingroup ip4addr 00102 * Convert generic ip address to specific protocol version 00103 */ 00104 #define ip_2_ip4(ipaddr) (&((ipaddr)->u_addr.ip4)) 00105 00106 /** @ingroup ip4addr */ 00107 #define IP_ADDR4(ipaddr,a,b,c,d) do { IP4_ADDR(ip_2_ip4(ipaddr),a,b,c,d); \ 00108 IP_SET_TYPE_VAL(*(ipaddr), IPADDR_TYPE_V4); } while(0) 00109 /** @ingroup ip6addr */ 00110 #define IP_ADDR6(ipaddr,i0,i1,i2,i3) do { IP6_ADDR(ip_2_ip6(ipaddr),i0,i1,i2,i3); \ 00111 IP_SET_TYPE_VAL(*(ipaddr), IPADDR_TYPE_V6); } while(0) 00112 00113 /** @ingroup ipaddr */ 00114 #define ip_addr_copy(dest, src) do{ IP_SET_TYPE_VAL(dest, IP_GET_TYPE(&src)); if(IP_IS_V6_VAL(src)){ \ 00115 ip6_addr_copy(*ip_2_ip6(&(dest)), *ip_2_ip6(&(src))); }else{ \ 00116 ip4_addr_copy(*ip_2_ip4(&(dest)), *ip_2_ip4(&(src))); }}while(0) 00117 /** @ingroup ip6addr */ 00118 #define ip_addr_copy_from_ip6(dest, src) do{ \ 00119 ip6_addr_copy(*ip_2_ip6(&(dest)), src); IP_SET_TYPE_VAL(dest, IPADDR_TYPE_V6); }while(0) 00120 /** @ingroup ip4addr */ 00121 #define ip_addr_copy_from_ip4(dest, src) do{ \ 00122 ip4_addr_copy(*ip_2_ip4(&(dest)), src); IP_SET_TYPE_VAL(dest, IPADDR_TYPE_V4); }while(0) 00123 /** @ingroup ip4addr */ 00124 #define ip_addr_set_ip4_u32(ipaddr, val) do{if(ipaddr){ip4_addr_set_u32(ip_2_ip4(ipaddr), val); \ 00125 IP_SET_TYPE(ipaddr, IPADDR_TYPE_V4); }}while(0) 00126 /** @ingroup ip4addr */ 00127 #define ip_addr_get_ip4_u32(ipaddr) (((ipaddr) && IP_IS_V4(ipaddr)) ? \ 00128 ip4_addr_get_u32(ip_2_ip4(ipaddr)) : 0) 00129 /** @ingroup ipaddr */ 00130 #define ip_addr_set(dest, src) do{ IP_SET_TYPE(dest, IP_GET_TYPE(src)); if(IP_IS_V6(src)){ \ 00131 ip6_addr_set(ip_2_ip6(dest), ip_2_ip6(src)); }else{ \ 00132 ip4_addr_set(ip_2_ip4(dest), ip_2_ip4(src)); }}while(0) 00133 /** @ingroup ipaddr */ 00134 #define ip_addr_set_ipaddr(dest, src) ip_addr_set(dest, src) 00135 /** @ingroup ipaddr */ 00136 #define ip_addr_set_zero(ipaddr) do{ \ 00137 ip6_addr_set_zero(ip_2_ip6(ipaddr)); IP_SET_TYPE(ipaddr, 0); }while(0) 00138 /** @ingroup ip5addr */ 00139 #define ip_addr_set_zero_ip4(ipaddr) do{ \ 00140 ip6_addr_set_zero(ip_2_ip6(ipaddr)); IP_SET_TYPE(ipaddr, IPADDR_TYPE_V4); }while(0) 00141 /** @ingroup ip6addr */ 00142 #define ip_addr_set_zero_ip6(ipaddr) do{ \ 00143 ip6_addr_set_zero(ip_2_ip6(ipaddr)); IP_SET_TYPE(ipaddr, IPADDR_TYPE_V6); }while(0) 00144 /** @ingroup ipaddr */ 00145 #define ip_addr_set_any(is_ipv6, ipaddr) do{if(is_ipv6){ \ 00146 ip6_addr_set_any(ip_2_ip6(ipaddr)); IP_SET_TYPE(ipaddr, IPADDR_TYPE_V6); }else{ \ 00147 ip4_addr_set_any(ip_2_ip4(ipaddr)); IP_SET_TYPE(ipaddr, IPADDR_TYPE_V4); }}while(0) 00148 /** @ingroup ipaddr */ 00149 #define ip_addr_set_loopback(is_ipv6, ipaddr) do{if(is_ipv6){ \ 00150 ip6_addr_set_loopback(ip_2_ip6(ipaddr)); IP_SET_TYPE(ipaddr, IPADDR_TYPE_V6); }else{ \ 00151 ip4_addr_set_loopback(ip_2_ip4(ipaddr)); IP_SET_TYPE(ipaddr, IPADDR_TYPE_V4); }}while(0) 00152 /** @ingroup ipaddr */ 00153 #define ip_addr_set_hton(dest, src) do{if(IP_IS_V6(src)){ \ 00154 ip6_addr_set_hton(ip_2_ip6(ipaddr), (src)); IP_SET_TYPE(dest, IPADDR_TYPE_V6); }else{ \ 00155 ip4_addr_set_hton(ip_2_ip4(ipaddr), (src)); IP_SET_TYPE(dest, IPADDR_TYPE_V4); }}while(0) 00156 /** @ingroup ipaddr */ 00157 #define ip_addr_get_network(target, host, netmask) do{if(IP_IS_V6(host)){ \ 00158 ip4_addr_set_zero(ip_2_ip4(target)); IP_SET_TYPE(target, IPADDR_TYPE_V6); } else { \ 00159 ip4_addr_get_network(ip_2_ip4(target), ip_2_ip4(host), ip_2_ip4(netmask)); IP_SET_TYPE(target, IPADDR_TYPE_V4); }}while(0) 00160 /** @ingroup ipaddr */ 00161 #define ip_addr_netcmp(addr1, addr2, mask) ((IP_IS_V6(addr1) && IP_IS_V6(addr2)) ? \ 00162 0 : \ 00163 ip4_addr_netcmp(ip_2_ip4(addr1), ip_2_ip4(addr2), mask)) 00164 /** @ingroup ipaddr */ 00165 #define ip_addr_cmp(addr1, addr2) ((IP_GET_TYPE(addr1) != IP_GET_TYPE(addr2)) ? 0 : (IP_IS_V6_VAL(*(addr1)) ? \ 00166 ip6_addr_cmp(ip_2_ip6(addr1), ip_2_ip6(addr2)) : \ 00167 ip4_addr_cmp(ip_2_ip4(addr1), ip_2_ip4(addr2)))) 00168 /** @ingroup ipaddr */ 00169 #define ip_addr_isany(ipaddr) ((IP_IS_V6(ipaddr)) ? \ 00170 ip6_addr_isany(ip_2_ip6(ipaddr)) : \ 00171 ip4_addr_isany(ip_2_ip4(ipaddr))) 00172 /** @ingroup ipaddr */ 00173 #define ip_addr_isany_val(ipaddr) ((IP_IS_V6_VAL(ipaddr)) ? \ 00174 ip6_addr_isany_val(*ip_2_ip6(&(ipaddr))) : \ 00175 ip4_addr_isany_val(*ip_2_ip4(&(ipaddr)))) 00176 /** @ingroup ipaddr */ 00177 #define ip_addr_isbroadcast(ipaddr, netif) ((IP_IS_V6(ipaddr)) ? \ 00178 0 : \ 00179 ip4_addr_isbroadcast(ip_2_ip4(ipaddr), netif)) 00180 /** @ingroup ipaddr */ 00181 #define ip_addr_ismulticast(ipaddr) ((IP_IS_V6(ipaddr)) ? \ 00182 ip6_addr_ismulticast(ip_2_ip6(ipaddr)) : \ 00183 ip4_addr_ismulticast(ip_2_ip4(ipaddr))) 00184 /** @ingroup ipaddr */ 00185 #define ip_addr_isloopback(ipaddr) ((IP_IS_V6(ipaddr)) ? \ 00186 ip6_addr_isloopback(ip_2_ip6(ipaddr)) : \ 00187 ip4_addr_isloopback(ip_2_ip4(ipaddr))) 00188 /** @ingroup ipaddr */ 00189 #define ip_addr_islinklocal(ipaddr) ((IP_IS_V6(ipaddr)) ? \ 00190 ip6_addr_islinklocal(ip_2_ip6(ipaddr)) : \ 00191 ip4_addr_islinklocal(ip_2_ip4(ipaddr))) 00192 #define ip_addr_debug_print(debug, ipaddr) do { if(IP_IS_V6(ipaddr)) { \ 00193 ip6_addr_debug_print(debug, ip_2_ip6(ipaddr)); } else { \ 00194 ip4_addr_debug_print(debug, ip_2_ip4(ipaddr)); }}while(0) 00195 #define ip_addr_debug_print_val(debug, ipaddr) do { if(IP_IS_V6_VAL(ipaddr)) { \ 00196 ip6_addr_debug_print_val(debug, *ip_2_ip6(&(ipaddr))); } else { \ 00197 ip4_addr_debug_print_val(debug, *ip_2_ip4(&(ipaddr))); }}while(0) 00198 /** @ingroup ipaddr */ 00199 #define ipaddr_ntoa(addr) (((addr) == NULL) ? "NULL" : \ 00200 ((IP_IS_V6(addr)) ? ip6addr_ntoa(ip_2_ip6(addr)) : ip4addr_ntoa(ip_2_ip4(addr)))) 00201 /** @ingroup ipaddr */ 00202 #define ipaddr_ntoa_r(addr, buf, buflen) (((addr) == NULL) ? "NULL" : \ 00203 ((IP_IS_V6(addr)) ? ip6addr_ntoa_r(ip_2_ip6(addr), buf, buflen) : ip4addr_ntoa_r(ip_2_ip4(addr), buf, buflen))) 00204 int ipaddr_aton(const char *cp, ip_addr_t *addr); 00205 00206 /** @ingroup ipaddr */ 00207 #define IPADDR_STRLEN_MAX IP6ADDR_STRLEN_MAX 00208 00209 #else /* LWIP_IPV4 && LWIP_IPV6 */ 00210 00211 #define IP_ADDR_PCB_VERSION_MATCH(addr, pcb) 1 00212 #define IP_ADDR_PCB_VERSION_MATCH_EXACT(pcb, ipaddr) 1 00213 00214 #if LWIP_IPV4 00215 00216 typedef ip4_addr_t ip_addr_t; 00217 #define IPADDR4_INIT(u32val) { u32val } 00218 #define IP_IS_V4_VAL(ipaddr) 1 00219 #define IP_IS_V6_VAL(ipaddr) 0 00220 #define IP_IS_V4(ipaddr) 1 00221 #define IP_IS_V6(ipaddr) 0 00222 #define IP_IS_ANY_TYPE_VAL(ipaddr) 0 00223 #define IP_SET_TYPE_VAL(ipaddr, iptype) 00224 #define IP_SET_TYPE(ipaddr, iptype) 00225 #define IP_GET_TYPE(ipaddr) IPADDR_TYPE_V4 00226 #define ip_2_ip4(ipaddr) (ipaddr) 00227 #define IP_ADDR4(ipaddr,a,b,c,d) IP4_ADDR(ipaddr,a,b,c,d) 00228 00229 #define ip_addr_copy(dest, src) ip4_addr_copy(dest, src) 00230 #define ip_addr_copy_from_ip4(dest, src) ip4_addr_copy(dest, src) 00231 #define ip_addr_set_ip4_u32(ipaddr, val) ip4_addr_set_u32(ip_2_ip4(ipaddr), val) 00232 #define ip_addr_get_ip4_u32(ipaddr) ip4_addr_get_u32(ip_2_ip4(ipaddr)) 00233 #define ip_addr_set(dest, src) ip4_addr_set(dest, src) 00234 #define ip_addr_set_ipaddr(dest, src) ip4_addr_set(dest, src) 00235 #define ip_addr_set_zero(ipaddr) ip4_addr_set_zero(ipaddr) 00236 #define ip_addr_set_zero_ip4(ipaddr) ip4_addr_set_zero(ipaddr) 00237 #define ip_addr_set_any(is_ipv6, ipaddr) ip4_addr_set_any(ipaddr) 00238 #define ip_addr_set_loopback(is_ipv6, ipaddr) ip4_addr_set_loopback(ipaddr) 00239 #define ip_addr_set_hton(dest, src) ip4_addr_set_hton(dest, src) 00240 #define ip_addr_get_network(target, host, mask) ip4_addr_get_network(target, host, mask) 00241 #define ip_addr_netcmp(addr1, addr2, mask) ip4_addr_netcmp(addr1, addr2, mask) 00242 #define ip_addr_cmp(addr1, addr2) ip4_addr_cmp(addr1, addr2) 00243 #define ip_addr_isany(ipaddr) ip4_addr_isany(ipaddr) 00244 #define ip_addr_isany_val(ipaddr) ip4_addr_isany_val(ipaddr) 00245 #define ip_addr_isloopback(ipaddr) ip4_addr_isloopback(ipaddr) 00246 #define ip_addr_islinklocal(ipaddr) ip4_addr_islinklocal(ipaddr) 00247 #define ip_addr_isbroadcast(addr, netif) ip4_addr_isbroadcast(addr, netif) 00248 #define ip_addr_ismulticast(ipaddr) ip4_addr_ismulticast(ipaddr) 00249 #define ip_addr_debug_print(debug, ipaddr) ip4_addr_debug_print(debug, ipaddr) 00250 #define ip_addr_debug_print_val(debug, ipaddr) ip4_addr_debug_print_val(debug, ipaddr) 00251 #define ipaddr_ntoa(ipaddr) ip4addr_ntoa(ipaddr) 00252 #define ipaddr_ntoa_r(ipaddr, buf, buflen) ip4addr_ntoa_r(ipaddr, buf, buflen) 00253 #define ipaddr_aton(cp, addr) ip4addr_aton(cp, addr) 00254 00255 #define IPADDR_STRLEN_MAX IP4ADDR_STRLEN_MAX 00256 00257 #else /* LWIP_IPV4 */ 00258 00259 typedef ip6_addr_t ip_addr_t; 00260 #define IPADDR6_INIT(a, b, c, d) { { a, b, c, d } } 00261 #define IP_IS_V4_VAL(ipaddr) 0 00262 #define IP_IS_V6_VAL(ipaddr) 1 00263 #define IP_IS_V4(ipaddr) 0 00264 #define IP_IS_V6(ipaddr) 1 00265 #define IP_IS_ANY_TYPE_VAL(ipaddr) 0 00266 #define IP_SET_TYPE_VAL(ipaddr, iptype) 00267 #define IP_SET_TYPE(ipaddr, iptype) 00268 #define IP_GET_TYPE(ipaddr) IPADDR_TYPE_V6 00269 #define ip_2_ip6(ipaddr) (ipaddr) 00270 #define IP_ADDR6(ipaddr,i0,i1,i2,i3) IP6_ADDR(ipaddr,i0,i1,i2,i3) 00271 00272 #define ip_addr_copy(dest, src) ip6_addr_copy(dest, src) 00273 #define ip_addr_copy_from_ip6(dest, src) ip6_addr_copy(dest, src) 00274 #define ip_addr_set(dest, src) ip6_addr_set(dest, src) 00275 #define ip_addr_set_ipaddr(dest, src) ip6_addr_set(dest, src) 00276 #define ip_addr_set_zero(ipaddr) ip6_addr_set_zero(ipaddr) 00277 #define ip_addr_set_zero_ip6(ipaddr) ip6_addr_set_zero(ipaddr) 00278 #define ip_addr_set_any(is_ipv6, ipaddr) ip6_addr_set_any(ipaddr) 00279 #define ip_addr_set_loopback(is_ipv6, ipaddr) ip6_addr_set_loopback(ipaddr) 00280 #define ip_addr_set_hton(dest, src) ip6_addr_set_hton(dest, src) 00281 #define ip_addr_get_network(target, host, mask) ip6_addr_set_zero(target) 00282 #define ip_addr_netcmp(addr1, addr2, mask) 0 00283 #define ip_addr_cmp(addr1, addr2) ip6_addr_cmp(addr1, addr2) 00284 #define ip_addr_isany(ipaddr) ip6_addr_isany(ipaddr) 00285 #define ip_addr_isany_val(ipaddr) ip6_addr_isany_val(ipaddr) 00286 #define ip_addr_isloopback(ipaddr) ip6_addr_isloopback(ipaddr) 00287 #define ip_addr_islinklocal(ipaddr) ip6_addr_islinklocal(ipaddr) 00288 #define ip_addr_isbroadcast(addr, netif) 0 00289 #define ip_addr_ismulticast(ipaddr) ip6_addr_ismulticast(ipaddr) 00290 #define ip_addr_debug_print(debug, ipaddr) ip6_addr_debug_print(debug, ipaddr) 00291 #define ip_addr_debug_print_val(debug, ipaddr) ip6_addr_debug_print_val(debug, ipaddr) 00292 #define ipaddr_ntoa(ipaddr) ip6addr_ntoa(ipaddr) 00293 #define ipaddr_ntoa_r(ipaddr, buf, buflen) ip6addr_ntoa_r(ipaddr, buf, buflen) 00294 #define ipaddr_aton(cp, addr) ip6addr_aton(cp, addr) 00295 00296 #define IPADDR_STRLEN_MAX IP6ADDR_STRLEN_MAX 00297 00298 #endif /* LWIP_IPV4 */ 00299 #endif /* LWIP_IPV4 && LWIP_IPV6 */ 00300 00301 #if LWIP_IPV4 00302 00303 extern const ip_addr_t ip_addr_any; 00304 extern const ip_addr_t ip_addr_broadcast; 00305 00306 /** 00307 * @ingroup ipaddr 00308 * IP_ADDR_ can be used as a fixed/const ip_addr_t 00309 * for the IPv4 wildcard and the broadcast address 00310 */ 00311 #define IP_ADDR_ANY (&ip_addr_any) 00312 /** @ingroup ipaddr */ 00313 #define IP_ADDR_BROADCAST (&ip_addr_broadcast) 00314 /** 00315 * @ingroup ip4addr 00316 * IP4_ADDR_ can be used as a fixed/const ip4_addr_t 00317 * for the wildcard and the broadcast address 00318 */ 00319 #define IP4_ADDR_ANY (ip_2_ip4(&ip_addr_any)) 00320 /** @ingroup ip4addr */ 00321 #define IP4_ADDR_BROADCAST (ip_2_ip4(&ip_addr_broadcast)) 00322 00323 #endif /* LWIP_IPV4*/ 00324 00325 #if LWIP_IPV6 00326 00327 extern const ip_addr_t ip6_addr_any; 00328 00329 /** 00330 * @ingroup ip6addr 00331 * IP6_ADDR_ANY can be used as a fixed ip_addr_t 00332 * for the IPv6 wildcard address 00333 */ 00334 #define IP6_ADDR_ANY (&ip6_addr_any) 00335 /** 00336 * @ingroup ip6addr 00337 * IP6_ADDR_ANY6 can be used as a fixed ip6_addr_t 00338 * for the IPv6 wildcard address 00339 */ 00340 #define IP6_ADDR_ANY6 (ip_2_ip6(&ip6_addr_any)) 00341 00342 #if !LWIP_IPV4 00343 /** Just a little upgrade-helper for IPv6-only configurations: */ 00344 #define IP_ADDR_ANY IP6_ADDR_ANY 00345 #endif /* !LWIP_IPV4 */ 00346 00347 #endif 00348 00349 #if LWIP_IPV4 && LWIP_IPV6 00350 /** @ingroup ipaddr */ 00351 #define IP_ANY_TYPE (&ip_addr_any_type) 00352 #else 00353 #define IP_ANY_TYPE IP_ADDR_ANY 00354 #endif 00355 00356 #ifdef __cplusplus 00357 } 00358 #endif 00359 00360 #endif /* LWIP_HDR_IP_ADDR_H__ */
Generated on Tue Jul 12 2022 18:19:29 by
1.7.2