#include "lwip/opt.h"#include "lwip/def.h"Classes | |
| struct | ip_addr |
| struct | ip_addr_packed |
| struct | ip_addr2 |
Defines | |
| #define | IP_ADDR_ANY ((ip_addr_t *)&ip_addr_any) |
| IP_ADDR_ can be used as a fixed IP address for the wildcard and the broadcast address. | |
| #define | IP_ADDR_BROADCAST ((ip_addr_t *)&ip_addr_broadcast) |
| #define | IPADDR_NONE ((u32_t)0xffffffffUL) |
| 255.255.255.255 | |
| #define | IPADDR_LOOPBACK ((u32_t)0x7f000001UL) |
| 127.0.0.1 | |
| #define | IPADDR_ANY ((u32_t)0x00000000UL) |
| 0.0.0.0 | |
| #define | IPADDR_BROADCAST ((u32_t)0xffffffffUL) |
| 255.255.255.255 | |
| #define | IP_CLASSA(a) ((((u32_t)(a)) & 0x80000000UL) == 0) |
| #define | IP_CLASSA_NET 0xff000000 |
| #define | IP_CLASSA_NSHIFT 24 |
| #define | IP_CLASSA_HOST (0xffffffff & ~IP_CLASSA_NET) |
| #define | IP_CLASSA_MAX 128 |
| #define | IP_CLASSB(a) ((((u32_t)(a)) & 0xc0000000UL) == 0x80000000UL) |
| #define | IP_CLASSB_NET 0xffff0000 |
| #define | IP_CLASSB_NSHIFT 16 |
| #define | IP_CLASSB_HOST (0xffffffff & ~IP_CLASSB_NET) |
| #define | IP_CLASSB_MAX 65536 |
| #define | IP_CLASSC(a) ((((u32_t)(a)) & 0xe0000000UL) == 0xc0000000UL) |
| #define | IP_CLASSC_NET 0xffffff00 |
| #define | IP_CLASSC_NSHIFT 8 |
| #define | IP_CLASSC_HOST (0xffffffff & ~IP_CLASSC_NET) |
| #define | IP_CLASSD(a) (((u32_t)(a) & 0xf0000000UL) == 0xe0000000UL) |
| #define | IP_CLASSD_NET 0xf0000000 |
| #define | IP_CLASSD_NSHIFT 28 |
| #define | IP_CLASSD_HOST 0x0fffffff |
| #define | IP_MULTICAST(a) IP_CLASSD(a) |
| #define | IP_EXPERIMENTAL(a) (((u32_t)(a) & 0xf0000000UL) == 0xf0000000UL) |
| #define | IP_BADCLASS(a) (((u32_t)(a) & 0xf0000000UL) == 0xf0000000UL) |
| #define | IP_LOOPBACKNET 127 |
| #define | IP4_ADDR(ipaddr, a, b, c, d) |
| Set an IP address given by the four byte-parts. | |
| #define | IPADDR2_COPY(dest, src) SMEMCPY(dest, src, sizeof(ip_addr_t)) |
| MEMCPY-like copying of IP addresses where addresses are known to be 16-bit-aligned if the port is correctly configured (so a port could define this to copying 2 u16_t's) - no NULL-pointer-checking needed. | |
| #define | ip_addr_copy(dest, src) ((dest).addr = (src).addr) |
| Copy IP address - faster than ip_addr_set: no NULL check. | |
| #define | ip_addr_set(dest, src) |
| Safely copy one IP address to another (src may be NULL). | |
| #define | ip_addr_set_zero(ipaddr) ((ipaddr)->addr = 0) |
| Set complete address to zero. | |
| #define | ip_addr_set_any(ipaddr) ((ipaddr)->addr = IPADDR_ANY) |
| Set address to IPADDR_ANY (no need for htonl()). | |
| #define | ip_addr_set_loopback(ipaddr) ((ipaddr)->addr = PP_HTONL(IPADDR_LOOPBACK)) |
| Set address to loopback address. | |
| #define | ip_addr_set_hton(dest, src) |
| Safely copy one IP address to another and change byte order from host- to network-order. | |
| #define | ip4_addr_set_u32(dest_ipaddr, src_u32) ((dest_ipaddr)->addr = (src_u32)) |
| IPv4 only: set the IP address given as an u32_t. | |
| #define | ip4_addr_get_u32(src_ipaddr) ((src_ipaddr)->addr) |
| IPv4 only: get the IP address as an u32_t. | |
| #define | ip_addr_get_network(target, host, netmask) ((target)->addr = ((host)->addr) & ((netmask)->addr)) |
| Get the network address by combining host address with netmask. | |
| #define | ip_addr_netcmp(addr1, addr2, mask) |
| Determine if two address are on the same network. | |
| #define | ip_addr_cmp(addr1, addr2) ((addr1)->addr == (addr2)->addr) |
| #define | ip_addr_isany(addr1) ((addr1) == NULL || (addr1)->addr == IPADDR_ANY) |
| #define | ip_addr_isbroadcast(ipaddr, netif) ip4_addr_isbroadcast((ipaddr)->addr, (netif)) |
| #define | ip_addr_netmask_valid(netmask) ip4_addr_netmask_valid((netmask)->addr) |
| #define | ip_addr_ismulticast(addr1) (((addr1)->addr & PP_HTONL(0xf0000000UL)) == PP_HTONL(0xe0000000UL)) |
| #define | ip_addr_islinklocal(addr1) (((addr1)->addr & PP_HTONL(0xffff0000UL)) == PP_HTONL(0xa9fe0000UL)) |
| #define | ip_addr_debug_print(debug, ipaddr) |
| #define | ip4_addr1(ipaddr) (((u8_t*)(ipaddr))[0]) |
| #define | ip4_addr2(ipaddr) (((u8_t*)(ipaddr))[1]) |
| #define | ip4_addr3(ipaddr) (((u8_t*)(ipaddr))[2]) |
| #define | ip4_addr4(ipaddr) (((u8_t*)(ipaddr))[3]) |
| #define | ip4_addr1_16(ipaddr) ((u16_t)ip4_addr1(ipaddr)) |
| #define | ip4_addr2_16(ipaddr) ((u16_t)ip4_addr2(ipaddr)) |
| #define | ip4_addr3_16(ipaddr) ((u16_t)ip4_addr3(ipaddr)) |
| #define | ip4_addr4_16(ipaddr) ((u16_t)ip4_addr4(ipaddr)) |
| #define | ip_ntoa(ipaddr) ipaddr_ntoa(ipaddr) |
| For backwards compatibility. | |
Typedefs | |
| typedef typedefPACK_STRUCT_END struct ip_addr | ip_addr_t |
| ip_addr_t uses a struct for convenience only, so that the same defines can operate both on ip_addr_t as well as on ip_addr_p_t. | |
| typedef struct ip_addr_packed | ip_addr_p_t |
Functions | |
| u8_t | ip4_addr_isbroadcast (u32_t addr, const struct netif *netif) |
| Determine if an address is a broadcast address on a network interface. | |
| u8_t | ip4_addr_netmask_valid (u32_t netmask) |
| Checks if a netmask is valid (starting with ones, then only zeros). | |
| u32_t | ipaddr_addr (const char *cp) |
| Ascii internet address interpretation routine. | |
| int | ipaddr_aton (const char *cp, ip_addr_t *addr) |
| Check whether "cp" is a valid ascii representation of an Internet address and convert to a binary address. | |
| char * | ipaddr_ntoa (const ip_addr_t *addr) |
| returns ptr to static buffer; not reentrant! | |
| char * | ipaddr_ntoa_r (const ip_addr_t *addr, char *buf, int buflen) |
| Same as ipaddr_ntoa, but reentrant since a user-supplied buffer is used. | |
Variables | |
| PACK_STRUCT_BEGIN struct ip_addr_packed | PACK_STRUCT_STRUCT |
| const ip_addr_t | ip_addr_any |
| const ip_addr_t | ip_addr_broadcast |
| #define IP4_ADDR | ( | ipaddr, | ||
| a, | ||||
| b, | ||||
| c, | ||||
| d | ||||
| ) |
| #define ip4_addr1 | ( | ipaddr | ) | (((u8_t*)(ipaddr))[0]) |
| #define ip4_addr1_16 | ( | ipaddr | ) | ((u16_t)ip4_addr1(ipaddr)) |
| #define ip4_addr2 | ( | ipaddr | ) | (((u8_t*)(ipaddr))[1]) |
| #define ip4_addr2_16 | ( | ipaddr | ) | ((u16_t)ip4_addr2(ipaddr)) |
| #define ip4_addr3 | ( | ipaddr | ) | (((u8_t*)(ipaddr))[2]) |
| #define ip4_addr3_16 | ( | ipaddr | ) | ((u16_t)ip4_addr3(ipaddr)) |
| #define ip4_addr4 | ( | ipaddr | ) | (((u8_t*)(ipaddr))[3]) |
| #define ip4_addr4_16 | ( | ipaddr | ) | ((u16_t)ip4_addr4(ipaddr)) |
| #define ip4_addr_get_u32 | ( | src_ipaddr | ) | ((src_ipaddr)->addr) |
IPv4 only: get the IP address as an u32_t.
| #define ip4_addr_set_u32 | ( | dest_ipaddr, | ||
| src_u32 | ||||
| ) | ((dest_ipaddr)->addr = (src_u32)) |
IPv4 only: set the IP address given as an u32_t.
| #define IP_ADDR_ANY ((ip_addr_t *)&ip_addr_any) |
IP_ADDR_ can be used as a fixed IP address for the wildcard and the broadcast address.
| #define IP_ADDR_BROADCAST ((ip_addr_t *)&ip_addr_broadcast) |
| #define ip_addr_cmp | ( | addr1, | ||
| addr2 | ||||
| ) | ((addr1)->addr == (addr2)->addr) |
Copy IP address - faster than ip_addr_set: no NULL check.
| #define ip_addr_debug_print | ( | debug, | ||
| ipaddr | ||||
| ) |
LWIP_DEBUGF(debug, ("%"U16_F".%"U16_F".%"U16_F".%"U16_F, \ ipaddr != NULL ? ip4_addr1_16(ipaddr) : 0, \ ipaddr != NULL ? ip4_addr2_16(ipaddr) : 0, \ ipaddr != NULL ? ip4_addr3_16(ipaddr) : 0, \ ipaddr != NULL ? ip4_addr4_16(ipaddr) : 0))
| #define ip_addr_get_network | ( | target, | ||
| host, | ||||
| netmask | ||||
| ) | ((target)->addr = ((host)->addr) & ((netmask)->addr)) |
Get the network address by combining host address with netmask.
| #define ip_addr_isany | ( | addr1 | ) | ((addr1) == NULL || (addr1)->addr == IPADDR_ANY) |
| #define ip_addr_islinklocal | ( | addr1 | ) | (((addr1)->addr & PP_HTONL(0xffff0000UL)) == PP_HTONL(0xa9fe0000UL)) |
| #define ip_addr_ismulticast | ( | addr1 | ) | (((addr1)->addr & PP_HTONL(0xf0000000UL)) == PP_HTONL(0xe0000000UL)) |
| #define ip_addr_netcmp | ( | addr1, | ||
| addr2, | ||||
| mask | ||||
| ) |
| #define ip_addr_netmask_valid | ( | netmask | ) | ip4_addr_netmask_valid((netmask)->addr) |
| #define ip_addr_set | ( | dest, | ||
| src | ||||
| ) |
| #define ip_addr_set_any | ( | ipaddr | ) | ((ipaddr)->addr = IPADDR_ANY) |
Set address to IPADDR_ANY (no need for htonl()).
| #define ip_addr_set_hton | ( | dest, | ||
| src | ||||
| ) |
| #define ip_addr_set_loopback | ( | ipaddr | ) | ((ipaddr)->addr = PP_HTONL(IPADDR_LOOPBACK)) |
Set address to loopback address.
| #define ip_addr_set_zero | ( | ipaddr | ) | ((ipaddr)->addr = 0) |
Set complete address to zero.
| #define IP_BADCLASS | ( | a | ) | (((u32_t)(a) & 0xf0000000UL) == 0xf0000000UL) |
| #define IP_CLASSA | ( | a | ) | ((((u32_t)(a)) & 0x80000000UL) == 0) |
| #define IP_CLASSA_HOST (0xffffffff & ~IP_CLASSA_NET) |
| #define IP_CLASSA_MAX 128 |
| #define IP_CLASSA_NET 0xff000000 |
| #define IP_CLASSA_NSHIFT 24 |
| #define IP_CLASSB | ( | a | ) | ((((u32_t)(a)) & 0xc0000000UL) == 0x80000000UL) |
| #define IP_CLASSB_HOST (0xffffffff & ~IP_CLASSB_NET) |
| #define IP_CLASSB_MAX 65536 |
| #define IP_CLASSB_NET 0xffff0000 |
| #define IP_CLASSB_NSHIFT 16 |
| #define IP_CLASSC | ( | a | ) | ((((u32_t)(a)) & 0xe0000000UL) == 0xc0000000UL) |
| #define IP_CLASSC_HOST (0xffffffff & ~IP_CLASSC_NET) |
| #define IP_CLASSC_NET 0xffffff00 |
| #define IP_CLASSC_NSHIFT 8 |
| #define IP_CLASSD | ( | a | ) | (((u32_t)(a) & 0xf0000000UL) == 0xe0000000UL) |
| #define IP_CLASSD_HOST 0x0fffffff |
| #define IP_CLASSD_NET 0xf0000000 |
| #define IP_CLASSD_NSHIFT 28 |
| #define IP_EXPERIMENTAL | ( | a | ) | (((u32_t)(a) & 0xf0000000UL) == 0xf0000000UL) |
| #define IP_LOOPBACKNET 127 |
| #define IP_MULTICAST | ( | a | ) | IP_CLASSD(a) |
| #define ip_ntoa | ( | ipaddr | ) | ipaddr_ntoa(ipaddr) |
For backwards compatibility.
MEMCPY-like copying of IP addresses where addresses are known to be 16-bit-aligned if the port is correctly configured (so a port could define this to copying 2 u16_t's) - no NULL-pointer-checking needed.
| #define IPADDR_ANY ((u32_t)0x00000000UL) |
0.0.0.0
| #define IPADDR_BROADCAST ((u32_t)0xffffffffUL) |
255.255.255.255
| #define IPADDR_LOOPBACK ((u32_t)0x7f000001UL) |
127.0.0.1
| #define IPADDR_NONE ((u32_t)0xffffffffUL) |
255.255.255.255
| typedef struct ip_addr_packed ip_addr_p_t |
ip_addr_t uses a struct for convenience only, so that the same defines can operate both on ip_addr_t as well as on ip_addr_p_t.
Determine if an address is a broadcast address on a network interface.
| addr | address to be checked | |
| netif | the network interface against which the address is checked |
Checks if a netmask is valid (starting with ones, then only zeros).
| netmask | the IPv4 netmask to check (in network byte order!) |
| u32_t ipaddr_addr | ( | const char * | cp | ) |
Ascii internet address interpretation routine.
The value returned is in network order.
| cp | IP address in ascii represenation (e.g. "127.0.0.1") |
| int ipaddr_aton | ( | const char * | cp, | |
| ip_addr_t * | addr | |||
| ) |
Check whether "cp" is a valid ascii representation of an Internet address and convert to a binary address.
Returns 1 if the address is valid, 0 if not. This replaces inet_addr, the return value from which cannot distinguish between failure and a local broadcast address.
| cp | IP address in ascii represenation (e.g. "127.0.0.1") | |
| addr | pointer to which to save the ip address in network order |
| char* ipaddr_ntoa | ( | const ip_addr_t * | addr | ) |
returns ptr to static buffer; not reentrant!
returns ptr to static buffer; not reentrant!
returns ptr to static buffer; not reentrant!
| addr | ip address in network order to convert |
| char* ipaddr_ntoa_r | ( | const ip_addr_t * | addr, | |
| char * | buf, | |||
| int | buflen | |||
| ) |
Same as ipaddr_ntoa, but reentrant since a user-supplied buffer is used.
| addr | ip address in network order to convert | |
| buf | target buffer where the string is stored | |
| buflen | length of buf |
| const ip_addr_t ip_addr_any |
| const ip_addr_t ip_addr_broadcast |
| PACK_STRUCT_BEGIN struct ip_addr2 PACK_STRUCT_STRUCT |
1.7.1