Seth Woolley's Man Viewer

icmp(7) - IPPROTO_ICMP, icmp, IPPROTO_ICMP, icmp - Linux IPv4 ICMP kernel module - man 7 icmp

([section] manual, -k keyword, -K [section] search, -f whatis)
man plain no title

ICMP(7)                    Linux Programmer's Manual                   ICMP(7)

       icmp, IPPROTO_ICMP - Linux IPv4 ICMP kernel module.

       This  kernel  protocol  module  implements the Internet Control Message
       Protocol defined in(1,8) RFC792. It is used to signal(2,7) error(8,n)  conditions  and
       for  diagnosis.   The  user doesn't interact directly with this module;
       instead it communicates with the other  protocols  in(1,8)  the  kernel  and
       these  pass  the ICMP errors to the application layers. The kernel ICMP
       module also answers ICMP requests.

       A user protocol may receive ICMP packets for all local sockets by open-
       ing  a  raw(3x,7,8,3x cbreak) socket(2,7,n) with the protocol IPPROTO_ICMP.  See raw(3x,7,8,3x cbreak)(7) for more
       information.  The types of ICMP packets passed to  the  socket(2,7,n)  can  be
       filtered  using  the ICMP_FILTER socket(2,7,n) option. ICMP packets are always
       processed by the kernel too, even when passed to a user socket.

       Linux limits the rate  of  ICMP  error(8,n)  packets  to  each  destination.
       ICMP_REDIRECT and ICMP_DEST_UNREACH are also limited by the destination
       route of the incoming packets.

       ICMP supports a sysctl(2,5,8) interface to configure some  global  IP  parame-
       ters.    The  sysctls  can  be  accessed  by  reading  or  writing  the
       /proc(5,n)/sys/net/ipv4/* files or with the  sysctl(2,5,8)(2)  interface.  Most  of
       these  sysctls are rate limitations for specific ICMP types.  Linux 2.2
       uses a token bucket filter(1,3x,3x curs_util) to limit ICMPs.  The value is the timeout(1,3x,3x cbreak) in(1,8)
       jiffies until the token bucket filter(1,3x,3x curs_util) is cleared after a burst. A jiffy
       is a system dependent unit, usually 10ms on x86 and about 1ms on  alpha
       and IA64.

              Maximum rate to send(2,n) ICMP Destination Unreachable packets.  This
              limits the rate at which packets  are  sent  to  any  individual
              route  or  destination.   The  limit  does not affect sending of
              ICMP_FRAG_NEEDED packets needed for path MTU discovery.

              If this value is  non-zero,  Linux  will  ignore  all  ICMP_ECHO

              If this value is non-zero, Linux will ignore all ICMP_ECHO pack-
              ets sent to broadcast addresses.

              Maximum rate for sending ICMP_ECHOREPLY packets in(1,8)  response  to
              ICMP_ECHOREQUEST packets.

              Maximum  rate  for  sending  ICMP_PARAMETERPROB  packets.  These
              packets are sent when  a  packet  arrives  with  an  invalid  IP

              Maximum  rate  for  sending  ICMP_TIME_EXCEEDED  packets.  These
              packets are sent to prevent loops when a packet has crossed  too
              many hops.

       As  many  other implementations don't support IPPROTO_ICMP raw(3x,7,8,3x cbreak) sockets,
       this feature should not be relied on in(1,8) portable programs.

       ICMP_REDIRECT packets are not sent  when  Linux  is  not  acting  as  a
       router.   They  are  also only accepted from the old gateway defined in(1,8)
       the routing table and the redirect routes are expired after some  time.

       The  64-bit  timestamp  returned  by  ICMP_TIMESTAMP is in(1,8) milliseconds
       since January 1, 1970.

       Linux ICMP internally uses a raw(3x,7,8,3x cbreak) socket(2,7,n) to send(2,n) ICMPs. This raw(3x,7,8,3x cbreak)  socket(2,7,n)
       may appear in(1,8) netstat(8) output with a zero inode.

       Support for the ICMP_ADDRESS request was removed in(1,8) 2.2.

       Support for ICMP_SOURCE_QUENCH was removed in(1,8) Linux 2.2.


       RFC792 for a description of the ICMP protocol.

Linux Man Page                    1999-04-27                           ICMP(7)

References for this manual (incoming links)