|
HP OpenVMS systems documentation |
Previous | Contents | Index |
The following functions are available for node name to address translation:
Function | Description |
---|---|
gethostbyname() | Returns IPv4 addresses. |
getaddrinfo() | Protocol-independent function for mapping names to addresses. |
freeaddrinfo() | Returns addrinfo() structures and dynamic storage to the system. |
The following functions are available for address to node name translation:
Function | Description |
---|---|
gethostbyaddr() | Returns a node name for an IPv4 address. |
getnameinfo() | Protocol-independent function for mapping addresses to names. |
freeaddrinfo() | Returns addrinfo() structures and dynamic storage to the system. |
The following address conversion functions convert both IPv4 and IPv6 addresses.
Function | Description |
---|---|
inet_pton() | Converts an address in its standard text presentation form to its numeric binary form, in network byte order. |
inet_ntop() | Converts a numeric address to a text string suitable for presentation. |
Table 7-2 lists the currently defined address-testing macros and the return value for a valid test. To use these macros, include the following file in your application:
#include <in.h> |
Macro | Return |
---|---|
IN6_IS_ADDR_UNSPECIFIED | True, if specified type. |
IN6_IS_ADDR_LOOPBACK | True, if specified type. |
IN6_IS_ADDR_MULTICAST | True, if specified type. |
IN6_IS_ADDR_LINKLOCAL | True, if specified type. |
IN6_IS_ADDR_SITELOCAL | True, if specified type. |
IN6_IS_ADDR_V4MAPPED | True, if specified type. |
IN6_IS_ADDR_V4COMPAT | True, if specified type. |
IN6_IS_ADDR_MC_NODELOCAL | True, if specified scope. |
IN6_IS_ADDR_MC_LINKLOCAL | True, if specified scope. |
IN6_IS_ADDR_MC_SITELOCAL | True, if specified scope. |
IN6_IS_ADDR_MC_ORGLOCAL | True, if specified scope. |
IN6_IS_ADDR_MC_GLOBAL | True, if specified scope. |
IN6_ARE_ADDR_EQUAL | True, if addresses are equal. |
The advanced API provides support for advanced applications that may need knowledge of IPv6 headers. These applications commonly use raw sockets to access IPv6 or ICMPv6 header fields. The advanced interface provides the following:
Raw sockets are used in both IPv4 and IPv6 to bypass the TCP and UDP transport layers.
Table 7-3 describes the principal differences between IPv4 and IPv6 raw sockets.
IPv4 | IPv6 | |
---|---|---|
Use | Access ICMPv4, IGMPv4, and to read and write IPv4 datagrams that contain a protocol field the kernel does not recognize. | Access ICMPv6 and to read and write IPv6 datagrams that contain a Next Header field the kernel does not recognize. |
Byte order | Not specified. | Network byte order for all data sent and received. |
Send and receive complete packets | Yes | No. Uses ancillary data objects to transfer extension headers and hop limit information. |
For output, applications can modify all fields, except for the flow label field, by using ancillary data or socket options, or both.
For input, applications can access all fields, except for the flow label, version number, and Next Header fields, and all extension headers by using ancillary data.
For IPv6 raw sockets other than ICMPv6 raw sockets, the application must set the IPV6_CHECKSUM socket option. For example:
int offset = 2; setsockopt (fd, IPPROTO_IPV6, IPV6_CHECKSUM, &offset, sizeof(offset)); |
This enables the kernel to compute and store a checksum for output and to verify the checksum on input. This relieves the application from having to perform source address selection on all outgoing packets. This socket option is disabled by default. You can explicitly disable this option by setting the offset variable to -1.
Using IPv6 raw sockets, an application can access the following information:
The following sections describe how to access this information.
An ICMPv6 raw socket is a socket that is created by calling the socket function with the PF_INET6 , SOCK_RAW , and IPPROTO_ICMPV6 arguments.
The kernel calculates and inserts the ICMPv6 checksum for all outbound ICMPv6 packets and verifies the checksum for all received packets. If the received checksum is incorrect, the packet is discarded.
Because ICMPv6 is a superset of ICMPv4, an ICMPv6 raw socket can receive many more messages than an ICMPv4 raw socket. By default, when you create an ICMPv6 raw socket, it passes all ICMPv6 message types to an application. An application, however, does not need access to all messages. An application can specify the ICMPv6 message types it wants passed by creating an ICMPv6 filter.
The ICMPv6 filter has a datatype of struct icmp6_filter . Use getsockopt() to retrieve the current filter and setsockopt() to store the filter. For example, to enable filtering of ICMPv6 messages, use the ICMP6_FILTER option, as follows:
struct icmp6_filter myfilter; setsockopt (fd, IPPROTO_ICMPV6, IPV6_FILTER, &(myfilter), (sizeof)(myfilter)); |
The value of myfilter is an ICMPv6 message type between 0 and 255.
Table 7-4 describes the ICMPv6 filter macros.
Macro | Description |
---|---|
ICMP6_FILTER_SETPASSALL | Passes all ICMPv6 messages to an application. |
ICMP6_FILTER_SETBLOCKALL | Blocks all ICMPv6 messages from being passed to an application. |
ICMP6_FILTER_SETPASS | Passes ICMPv6 messages of a given type to an application. |
ICMP6_FILTER_SETBLOCK | Blocks ICMPv6 messages of a given type from being passed to an application. |
ICMP6_FILTER_WILLPASS | Returns true, if specified message type is passed to application. |
ICMP6_FILTER_WILLBLOCK | True, if the specified message type is blocked from being passed to an application. |
To clear an installed filter, call setsockopt() for the ICMP_FILTER option with a zero-length filter.
The kernel does not perform any validity checks on message type, message content, or packet structure. The application is responsible for checking them.
When using IPv6 raw sockets, applications must be able to receive the IPv6 header content. To receive this optional information, use the setsockopt() function with the appropriate socket option.
Table 7-5 describes the socket options for receiving optional information.
Optional Information | Socket Option | cmsg_type |
---|---|---|
Source and destination IPv6 address, and sending and receiving interface | IPV6_RECVPKTINFO | IPV6_PKTINFO |
Hop limit | IPV6_RECVHOPLIMIT | IPV6_HOPLIMIT |
Routing header | IPV6_RECVRTHDR | IPV6_RTHDR |
Hop-by-Hop options | IPV6_RECVHOPOPTS | IPV6_HOPOPTS |
Destination options | IPV6_RECVDSTOPTS | IPV6_DSTOPTS |
The recvmsg() function returns the received data as one or more ancillary data objects in a cmsghdr data structure.
To determine the value of a socket option, use the getsockopt() function with the corresponding option. If the IPV6_RECVPKTINFO option is not set, the function returns an in6_pktinfo data structure with ipi6_addr set to in6addr_any and ipi6_addr set to zero. For other options, the function returns an option_len value of zero if there is no option value.
An application can receive the following IPv6 header information as ancillary data from incoming packets:
The IPv6 address and interface index are contained in a in6_pktinfo data structure that is received as ancillary data with the recvmsg() function. the in6_pktinfo data structure is defined in in.h . The tasks associated with the IPv6 header are:
The advanced sockets API enables you to access the IPv6 routing header. The routing header is an IPv6 extension header that enables an application to perform source routing. RFC 2460 defines the type 0 routing header, which supports up to 127 intermediate nodes, or 128 hops.
Table 7-6 describes the sockets calls that an application uses to build and examine routing headers.
Function | Description |
---|---|
inet6_rth_space() | Returns the number of bytes required for a routing header. |
inet6_rth_init() | Initializes buffer data for a routing header. |
inet6_rth_add() | Adds one address to a routing header. |
inet6_rth_reverse() | Reverses the order of fields in a routing header. |
inet6_rth_segments() | Returns the number of segments, or addresses, in a routing header. |
inet6_rth_getaddr() | Fetches one address from a routing header. |
The tasks associated with the routing header are:
The advanced sockets API enables applications to access the following IPv6 options headers:
See RFC 2460 for additional information about the alignment requirements of the headers and ordering of the extensions headers.
Table 7-7 lists the sockets calls that an application uses to build and examine hop-by-hop and destination headers.
Function | Description |
---|---|
inet6_opt_init() | Initializes buffer data for options. |
inet6_opt_append() | Adds an option to the options header. |
inet6_opt_finish() | Finishes adding options to the options header. |
inet6_opt_set_val() | Adds one component of the option content to the options header. |
inet6_opt_next() | Extracts the next option from the options header. |
inet6_opt_find() | Extracts an option of a specified type from the options header. |
inet6_opt_get_val() | Retrieves one component of the option content from the options header. |
The tasks associate with options headers are:
Previous | Next | Contents | Index |