| ![[Previous]](../prev.gif) | ![[Contents]](../contents.gif) | ![[Index]](../keyword_index.gif) | ![[Next]](../next.gif) | 
|  | This version of this document is no longer maintained. For the latest documentation, see http://www.qnx.com/developers/docs. | 
Internet Control Message Protocol
#include <sys/socket.h>
#include <netinet/in.h>
int socket( AF_INET, 
            SOCK_RAW, 
            proto );
ICMP is the error- and control-message protocol used by IP and the Internet protocol family. The protocol may be accessed through a "raw socket" for network monitoring and diagnostic functions.
To get the proto parameter to socket() that's used to create an ICMP socket, call getprotobyname(). You normally use ICMP sockets, which are connectionless, with sendto() and recvfrom(), although you can also use connect() to fix the destination for future packets (in which case you can use the read() or recv(), and write() or send() system calls).
Outgoing packets automatically have an IP header prepended to them that's based on the destination address. Incoming packets are received with the IP header and IP options intact.
A descriptor referencing the socket, or -1 if an error occurs (errno is set).
connect(), getprotobyname(), read(), recv(), recvfrom(), send(), sendto(), socket(), write()
RFC 792
| ![[Previous]](../prev.gif) | ![[Contents]](../contents.gif) | ![[Index]](../keyword_index.gif) | ![[Next]](../next.gif) |