fbpx
Wikipedia

Internet Control Message Protocol

The Internet Control Message Protocol (ICMP) is a supporting protocol in the Internet protocol suite. It is used by network devices, including routers, to send error messages and operational information indicating success or failure when communicating with another IP address. For example, an error is indicated when a requested service is not available or that a host or router could not be reached.[2] ICMP differs from transport protocols such as TCP and UDP in that it is not typically used to exchange data between systems, nor is it regularly employed by end-user network applications (with the exception of some diagnostic tools like ping and traceroute).

Internet Control Message Protocol
Communication protocol
A general header for ICMPv4
PurposeAuxiliary protocol for IPv4[1]
Developer(s)DARPA
Introduction1981
OSI layerNetwork layer
RFC(s)RFC 792

ICMP for IPv4 is defined in RFC 792. A separate ICMPv6, defined by RFC 4443, is used with IPv6.

Technical details edit

ICMP is part of the Internet protocol suite as defined in RFC 792. ICMP messages are typically used for diagnostic or control purposes or generated in response to errors in IP operations (as specified in RFC 1122). ICMP errors are directed to the source IP address of the originating packet.[2]

For example, every device (such as an intermediate router) forwarding an IP datagram first decrements the time to live (TTL) field in the IP header by one. If the resulting TTL is 0, the packet is discarded and an ICMP time exceeded message is sent to the datagram's source address.

Many commonly used network utilities are based on ICMP messages. The traceroute command can be implemented by transmitting IP datagrams with specially set IP TTL header fields, and looking for ICMP time exceeded in transit and destination unreachable messages generated in response. The related ping utility is implemented using the ICMP echo request and echo reply messages.

ICMP uses the basic support of IP as if it were a higher-level protocol, however, ICMP is actually an integral part of IP. Although ICMP messages are contained within standard IP packets, ICMP messages are usually processed as a special case, distinguished from normal IP processing. In many cases, it is necessary to inspect the contents of the ICMP message and deliver the appropriate error message to the application responsible for transmitting the IP packet that prompted the ICMP message to be sent.

ICMP is a network-layer protocol; this makes it a layer 3 protocol in the seven-layer OSI model. Based on the four-layer TCP/IP model, ICMP is an internet-layer protocol, which makes it a layer 2 protocol in the Internet Standard RFC 1122 TCP/IP four-layer model or a layer 3 protocol in the modern five-layer TCP/IP protocol definitions (by Kozierok, Comer, Tanenbaum, Forouzan, Kurose, Stallings).[citation needed]

There is no TCP or UDP port number associated with ICMP packets as these numbers are associated with the transport layer above.[3]

Datagram structure edit

The ICMP packet is encapsulated in an IPv4 packet.[2] The packet consists of header and data sections.

Header edit

The ICMP header starts after the IPv4 header and is identified by its protocol number, 1.[4] All ICMP packets have an eight-byte header and variable-sized data section. The first four bytes of the header have fixed format, while the last four bytes depend on the type and code of the ICMP packet.[2]

ICMP header format
Offsets Octet 0 1 2 3
Octet Bit 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
0 0 Type Code Checksum
4 32 Rest of header
Type
ICMP type, see § Control messages.
Code
ICMP subtype, see § Control messages.
Checksum
Internet checksum (RFC 1071) for error checking, calculated from the ICMP header and data with value 0 substituted for this field.
Rest of header
Four-byte field, contents vary based on the ICMP type and code.

Data edit

ICMP error messages contain a data section that includes a copy of the entire IPv4 header, plus at least the first eight bytes of data from the IPv4 packet that caused the error message. The length of ICMP error messages should not exceed 576 bytes.[5] This data is used by the host to match the message to the appropriate process. If a higher level protocol uses port numbers, they are assumed to be in the first eight bytes of the original datagram's data.[6]

The variable size of the ICMP packet data section has been exploited. In the "Ping of death", large or fragmented ICMP packets are used for denial-of-service attacks. ICMP data can also be used to create covert channels for communication. These channels are known as ICMP tunnels.

Control messages edit

Control messages are identified by the value in the type field. The code field gives additional context information for the message. Some control messages have been deprecated since the protocol was first introduced.

Notable control messages[7][8]
Type Code Status Description
0 – Echo Reply[6]: 14  0 Echo reply (used to ping)
1 and 2 unassigned Reserved
3 – Destination Unreachable[6]: 4 [9] 0 Destination network unreachable
1 Destination host unreachable
2 Destination protocol unreachable
3 Destination port unreachable
4 Fragmentation required, and DF flag set
5 Source route failed
6 Destination network unknown
7 Destination host unknown
8 Source host isolated
9 Network administratively prohibited
10 Host administratively prohibited
11 Network unreachable for ToS
12 Host unreachable for ToS
13 Communication administratively prohibited
14 Host Precedence Violation
15 Precedence cutoff in effect
4 – Source Quench 0 deprecated Source quench (congestion control)
5 – Redirect Message 0 Redirect Datagram for the Network
1 Redirect Datagram for the Host
2 Redirect Datagram for the ToS & network
3 Redirect Datagram for the ToS & host
6 deprecated Alternate Host Address
7 unassigned Reserved
8 – Echo Request 0 Echo request (used to ping)
9 – Router Advertisement 0 Router Advertisement
10 – Router Solicitation 0 Router discovery/selection/solicitation
11 – Time Exceeded[6]: 6  0 TTL expired in transit
1 Fragment reassembly time exceeded
12 – Parameter Problem: Bad IP header 0 Pointer indicates the error
1 Missing a required option
2 Bad length
13 – Timestamp 0 Timestamp
14 – Timestamp Reply 0 Timestamp reply
15 – Information Request 0 deprecated Information Request
16 – Information Reply 0 deprecated Information Reply
17 – Address Mask Request 0 deprecated Address Mask Request
18 – Address Mask Reply 0 deprecated Address Mask Reply
19 reserved Reserved for security
20 through 29 reserved Reserved for robustness experiment
30 – Traceroute 0 deprecated Information Request
31 deprecated Datagram Conversion Error
32 deprecated Mobile Host Redirect
33 deprecated Where-Are-You (originally meant for IPv6)
34 deprecated Here-I-Am (originally meant for IPv6)
35 deprecated Mobile Registration Request
36 deprecated Mobile Registration Reply
37 deprecated Domain Name Request
38 deprecated Domain Name Reply
39 deprecated SKIP Algorithm Discovery Protocol, Simple Key-Management for Internet Protocol
40 Photuris, Security failures
41 Experimental ICMP for experimental mobility protocols such as Seamoby [RFC4065]
42 – Extended Echo Request[10] 0 Request Extended Echo (XPing - see Extended Ping (Xping))
43 – Extended Echo Reply[10] 0 No Error
1 Malformed Query
2 No Such Interface
3 No Such Table Entry
4 Multiple Interfaces Satisfy Query
44 through 252 unassigned Reserved
253 Experimental RFC3692-style Experiment 1 (RFC 4727)
254 Experimental RFC3692-style Experiment 2 (RFC 4727)
255 reserved Reserved

Source quench edit

Source Quench requests that the sender decrease the rate of messages sent to a router or host. This message may be generated if a router or host does not have sufficient buffer space to process the request, or may occur if the router or host buffer is approaching its limit.

Data is sent at a very high speed from a host or from several hosts at the same time to a particular router on a network. Although a router has buffering capabilities, the buffering is limited to within a specified range. The router cannot queue any more data than the capacity of the limited buffering space. Thus if the queue gets filled up, incoming data is discarded until the queue is no longer full. But as no acknowledgement mechanism is present in the network layer, the client does not know whether the data has reached the destination successfully. Hence some remedial measures should be taken by the network layer to avoid these kind of situations. These measures are referred to as source quench.

In a source quench mechanism, the router sees that the incoming data rate is much faster than the outgoing data rate, and sends an ICMP message to the clients, informing them that they should slow down their data transfer speeds or wait for a certain amount of time before attempting to send more data. When a client receives this message, it automatically slows down the outgoing data rate or waits for a sufficient amount of time, which enables the router to empty the queue. Thus the source quench ICMP message acts as flow control in the network layer.

Since research suggested that "ICMP Source Quench [was] an ineffective (and unfair) antidote for congestion",[11] routers' creation of source quench messages was deprecated in 1995 by RFC 1812. Furthermore, forwarding of and any kind of reaction to (flow control actions) source quench messages was deprecated from 2012 by RFC 6633.

Source quench message[6]: 9 
00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
Type = 4 Code = 0 Checksum
unused
IP header and first 8 bytes of original datagram's data

Where:

Type must be set to 4
Code must be set to 0
IP header and additional data is used by the sender to match the reply with the associated request

Redirect edit

 
An example of how an ICMPv4 redirect message works

Redirect requests data packets be sent on an alternative route. ICMP Redirect is a mechanism for routers to convey routing information to hosts. The message informs a host to update its routing information (to send packets on an alternative route). If a host tries to send data through a router (R1) and R1 sends the data on another router (R2) and a direct path from the host to R2 is available (that is, the host and R2 are on the same subnetwork), then R1 will send a redirect message to inform the host that the best route for the destination is via R2. The host should then change its route information and send packets for that destination directly to R2. The router will still send the original datagram to the intended destination.[12] However, if the datagram contains routing information, this message will not be sent even if a better route is available. RFC 1122 states that redirects should only be sent by gateways and should not be sent by Internet hosts.

Redirect message[6]: 11 
00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
Type = 5 Code Checksum
IP address
IP header and first 8 bytes of original datagram's data

Where:

Type must be set to 5.
Code specifies the reason for the redirection, and may be one of the following:
Code Description
0 Redirect for Network
1 Redirect for Host
2 Redirect for Type of Service and Network
3 Redirect for Type of Service and Host
IP address is the 32-bit address of the gateway to which the redirection should be sent.
IP header and additional data is included to allow the host to match the reply with the request that caused the redirection reply.

Time exceeded edit

Time Exceeded is generated by a gateway to inform the source of a discarded datagram due to the time to live field reaching zero. A time exceeded message may also be sent by a host if it fails to reassemble a fragmented datagram within its time limit.

Time exceeded messages are used by the traceroute utility to identify gateways on the path between two hosts.

Time exceeded message[6]: 5 
00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
Type = 11 Code Checksum
unused
IP header and first 8 bytes of original datagram's data

Where:

Type must be set to 11
Code specifies the reason for the time exceeded message, include the following:
Code Description
0 Time-to-live exceeded in transit.
1 Fragment reassembly time exceeded.
IP header and first 64 bits of the original payload are used by the source host to match the time exceeded message to the discarded datagram. For higher-level protocols such as UDP and TCP the 64-bit payload will include the source and destination ports of the discarded packet.

Timestamp edit

Timestamp is used for time synchronization. The originating timestamp is set to the time (in milliseconds since midnight) the sender last touched the packet. The receive and transmit timestamps are not used.

Timestamp message[6]: 15 
00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
Type = 13 Code = 0 Checksum
Identifier Sequence number
Originate timestamp
Receive timestamp
Transmit timestamp

Where:

Type must be set to 13
Code must be set to 0
Identifier and Sequence Number can be used by the client to match the timestamp reply with the timestamp request.
Originate timestamp is the number of milliseconds since midnight Universal Time (UT). If a UT reference is not available the most-significant bit can be set to indicate a non-standard time value.

Timestamp reply edit

Timestamp Reply replies to a Timestamp message. It consists of the originating timestamp sent by the sender of the Timestamp as well as a receive timestamp indicating when the Timestamp was received and a transmit timestamp indicating when the Timestamp reply was sent.

Timestamp reply message[6]: 15 
00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
Type = 14 Code = 0 Checksum
Identifier Sequence number
Originate timestamp
Receive timestamp
Transmit timestamp

Where:

Type must be set to 14
Code must be set to 0
Identifier and Sequence number can be used by the client to match the reply with the request that caused the reply.
Originate timestamp is the time the sender last touched the message before sending it.
Receive timestamp is the time the echoer first touched it on receipt.
Transmit timestamp is the time the echoer last touched the message on sending it.
All timestamps are in units of milliseconds since midnight UT. If the time is not available in milliseconds or cannot be provided with respect to midnight UT then any time can be inserted in a timestamp provided the high order bit of the timestamp is also set to indicate this non-standard value.

The use of Timestamp and Timestamp Reply messages to synchronize the clocks of Internet nodes has largely been replaced by the UDP-based Network Time Protocol and the Precision Time Protocol.[13]

Address mask request edit

Address mask request is normally sent by a host to a router in order to obtain an appropriate subnet mask.

Recipients should reply to this message with an Address mask reply message.

Address mask request
00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
Type = 17 Code = 0 Checksum
Identifier Sequence number
Address mask

Where:

Type must be set to 17
Code must be set to 0
Address mask can be set to 0

ICMP Address Mask Request may be used as a part of reconnaissance attack to gather information on the target network, therefore ICMP Address Mask Reply is disabled by default on Cisco IOS.[14]

Address mask reply edit

Address mask reply is used to reply to an address mask request message with an appropriate subnet mask.

Address mask reply
00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
Type = 18 Code = 0 Checksum
Identifier Sequence number
Address mask

Where:

Type must be set to 18
Code must be set to 0
Address mask should be set to the subnet mask

Destination unreachable edit

Destination unreachable is generated by the host or its inbound gateway[6] to inform the client that the destination is unreachable for some reason. Reasons for this message may include: the physical connection to the host does not exist (distance is infinite); the indicated protocol or port is not active; the data must be fragmented but the 'don't fragment' flag is on. Unreachable TCP ports notably respond with TCP RST rather than a destination unreachable type 3 as might be expected. Destination unreachable is never reported for IP multicast transmissions.

Destination unreachable message[6]: 3 
00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
Type = 3 Code Checksum
unused Next-hop MTU
IP header and first 8 bytes of original datagram's data

Where:

Type field (bits 0–7) must be set to 3
Code field (bits 8–15) is used to specify the type of error, and can be any of the following:
Code Description
0 Network unreachable error.
1 Host unreachable error.
2 Protocol unreachable error (the designated transport protocol is not supported).
3 Port unreachable error (the designated protocol is unable to inform the host of the incoming message).
4 The datagram is too big. Packet fragmentation is required but the 'don't fragment' (DF) flag is on.
5 Source route failed error.
6 Destination network unknown error.
7 Destination host unknown error.
8 Source host isolated error.
9 The destination network is administratively prohibited.
10 The destination host is administratively prohibited.
11 The network is unreachable for Type Of Service.
12 The host is unreachable for Type Of Service.
13 Communication administratively prohibited (administrative filtering prevents packet from being forwarded).
14 Host precedence violation (indicates the requested precedence is not permitted for the combination of host or network and port).
15 Precedence cutoff in effect (precedence of datagram is below the level set by the network administrators).
Next-hop MTU field (bits 48–63) contains the MTU of the next-hop network if a code 4 error occurs.[15]
IP header and additional data is included to allow the client to match the reply with the request that caused the destination unreachable reply.

See also edit

References edit

  1. ^ F. Baker (June 1995). Baker, F (ed.). Requirements for IP Version 4 Routers. p. 52. RFC 1812.
  2. ^ a b c d Forouzan, Behrouz A. (2007). Data Communications And Networking (Fourth ed.). Boston: McGraw-Hill. pp. 621–630. ISBN 978-0-07-296775-3.
  3. ^ "The OSI Model's Seven Layers Defined and Functions Explained". Microsoft Support. Retrieved 2014-12-28.
  4. ^ "Protocol Numbers". Internet Assigned Numbers Authority. Retrieved 2011-06-23.
  5. ^ Requirements for IP Version 4 Routers. doi:10.17487/RFC1812. RFC 1812.
  6. ^ a b c d e f g h i j k Postel, J. (September 1981). Internet Control Message Protocol. IETF. doi:10.17487/RFC0792. RFC 792.
  7. ^ "IANA ICMP Parameters". Iana.org. 2012-09-21. Retrieved 2013-01-07.
  8. ^ Kurose, J.F; Ross, K.W. (2006). Computer Networking: A Top-Down Approach. World student series. Addison-Wesley. ISBN 9780321418494.
  9. ^ "Internet Control Message Protocol (ICMP) Parameters". www.iana.org. Retrieved 2023-09-13.
  10. ^ a b PROBE: A Utility for Probing Interfaces. doi:10.17487/RFC8335. RFC 8335.
  11. ^ RFC 6633
  12. ^ "When Are ICMP Redirects Sent?". Cisco Systems. 2008-06-28. Retrieved 2013-08-15.
  13. ^ D.L. Mills (September 1985). Network Time Protocol (NTP). doi:10.17487/RFC0958. RFC 958. It is evolved from the Time Protocol and the ICMP Timestamp message and is a suitable replacement for both.
  14. ^ . Cisco Systems. Archived from the original on 2013-01-02. Retrieved 2013-01-07.
  15. ^ Extended ICMP to Support Multi-Part Messages. doi:10.17487/RFC4884. RFC 4884.

Sources edit

RFCs edit

  • RFC 792, Internet Control Message Protocol
  • RFC 950, Internet Standard Subnetting Procedure
  • RFC 1016, Something a Host Could Do with Source Quench: The Source Quench Introduced Delay (SQuID)
  • RFC 1122, Requirements for Internet Hosts – Communication Layers
  • RFC 1716, Towards Requirements for IP Routers
  • RFC 1812, Requirements for IP Version 4 Routers
  • RFC 4884, Extended ICMP to Support Multi-Part Messages

External links edit

  • IANA ICMP parameters
  • IANA protocol numbers
  • at the Wayback Machine (archived 2015-01-10)

internet, control, message, protocol, this, article, about, support, protocol, ipv4, icmpv4, icmpv6, icmpv6, icmp, supporting, protocol, internet, protocol, suite, used, network, devices, including, routers, send, error, messages, operational, information, ind. This article is about the support protocol for IPv4 ICMPv4 For ICMPv6 see ICMPv6 The Internet Control Message Protocol ICMP is a supporting protocol in the Internet protocol suite It is used by network devices including routers to send error messages and operational information indicating success or failure when communicating with another IP address For example an error is indicated when a requested service is not available or that a host or router could not be reached 2 ICMP differs from transport protocols such as TCP and UDP in that it is not typically used to exchange data between systems nor is it regularly employed by end user network applications with the exception of some diagnostic tools like ping and traceroute Internet Control Message ProtocolCommunication protocolA general header for ICMPv4PurposeAuxiliary protocol for IPv4 1 Developer s DARPAIntroduction1981OSI layerNetwork layerRFC s RFC 792ICMP for IPv4 is defined in RFC 792 A separate ICMPv6 defined by RFC 4443 is used with IPv6 Contents 1 Technical details 2 Datagram structure 2 1 Header 2 2 Data 3 Control messages 3 1 Source quench 3 2 Redirect 3 3 Time exceeded 3 4 Timestamp 3 5 Timestamp reply 3 6 Address mask request 3 7 Address mask reply 3 8 Destination unreachable 4 See also 5 References 6 Sources 6 1 RFCs 7 External linksTechnical details editICMP is part of the Internet protocol suite as defined in RFC 792 ICMP messages are typically used for diagnostic or control purposes or generated in response to errors in IP operations as specified in RFC 1122 ICMP errors are directed to the source IP address of the originating packet 2 For example every device such as an intermediate router forwarding an IP datagram first decrements the time to live TTL field in the IP header by one If the resulting TTL is 0 the packet is discarded and an ICMP time exceeded message is sent to the datagram s source address Many commonly used network utilities are based on ICMP messages The traceroute command can be implemented by transmitting IP datagrams with specially set IP TTL header fields and looking for ICMP time exceeded in transit and destination unreachable messages generated in response The related ping utility is implemented using the ICMP echo request and echo reply messages ICMP uses the basic support of IP as if it were a higher level protocol however ICMP is actually an integral part of IP Although ICMP messages are contained within standard IP packets ICMP messages are usually processed as a special case distinguished from normal IP processing In many cases it is necessary to inspect the contents of the ICMP message and deliver the appropriate error message to the application responsible for transmitting the IP packet that prompted the ICMP message to be sent ICMP is a network layer protocol this makes it a layer 3 protocol in the seven layer OSI model Based on the four layer TCP IP model ICMP is an internet layer protocol which makes it a layer 2 protocol in the Internet Standard RFC 1122 TCP IP four layer model or a layer 3 protocol in the modern five layer TCP IP protocol definitions by Kozierok Comer Tanenbaum Forouzan Kurose Stallings citation needed There is no TCP or UDP port number associated with ICMP packets as these numbers are associated with the transport layer above 3 Datagram structure editThe ICMP packet is encapsulated in an IPv4 packet 2 The packet consists of header and data sections Header edit The ICMP header starts after the IPv4 header and is identified by its protocol number 1 4 All ICMP packets have an eight byte header and variable sized data section The first four bytes of the header have fixed format while the last four bytes depend on the type and code of the ICMP packet 2 ICMP header format Offsets Octet 0 1 2 3Octet Bit 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 310 0 Type Code Checksum4 32 Rest of headerType ICMP type see Control messages Code ICMP subtype see Control messages Checksum Internet checksum RFC 1071 for error checking calculated from the ICMP header and data with value 0 substituted for this field Rest of header Four byte field contents vary based on the ICMP type and code Data edit ICMP error messages contain a data section that includes a copy of the entire IPv4 header plus at least the first eight bytes of data from the IPv4 packet that caused the error message The length of ICMP error messages should not exceed 576 bytes 5 This data is used by the host to match the message to the appropriate process If a higher level protocol uses port numbers they are assumed to be in the first eight bytes of the original datagram s data 6 The variable size of the ICMP packet data section has been exploited In the Ping of death large or fragmented ICMP packets are used for denial of service attacks ICMP data can also be used to create covert channels for communication These channels are known as ICMP tunnels Control messages editControl messages are identified by the value in the type field The code field gives additional context information for the message Some control messages have been deprecated since the protocol was first introduced Notable control messages 7 8 Type Code Status Description0 Echo Reply 6 14 0 Echo reply used to ping 1 and 2 unassigned Reserved3 Destination Unreachable 6 4 9 0 Destination network unreachable1 Destination host unreachable2 Destination protocol unreachable3 Destination port unreachable4 Fragmentation required and DF flag set5 Source route failed6 Destination network unknown7 Destination host unknown8 Source host isolated9 Network administratively prohibited10 Host administratively prohibited11 Network unreachable for ToS12 Host unreachable for ToS13 Communication administratively prohibited14 Host Precedence Violation15 Precedence cutoff in effect4 Source Quench 0 deprecated Source quench congestion control 5 Redirect Message 0 Redirect Datagram for the Network1 Redirect Datagram for the Host2 Redirect Datagram for the ToS amp network3 Redirect Datagram for the ToS amp host6 deprecated Alternate Host Address7 unassigned Reserved8 Echo Request 0 Echo request used to ping 9 Router Advertisement 0 Router Advertisement10 Router Solicitation 0 Router discovery selection solicitation11 Time Exceeded 6 6 0 TTL expired in transit1 Fragment reassembly time exceeded12 Parameter Problem Bad IP header 0 Pointer indicates the error1 Missing a required option2 Bad length13 Timestamp 0 Timestamp14 Timestamp Reply 0 Timestamp reply15 Information Request 0 deprecated Information Request16 Information Reply 0 deprecated Information Reply17 Address Mask Request 0 deprecated Address Mask Request18 Address Mask Reply 0 deprecated Address Mask Reply19 reserved Reserved for security20 through 29 reserved Reserved for robustness experiment30 Traceroute 0 deprecated Information Request31 deprecated Datagram Conversion Error32 deprecated Mobile Host Redirect33 deprecated Where Are You originally meant for IPv6 34 deprecated Here I Am originally meant for IPv6 35 deprecated Mobile Registration Request36 deprecated Mobile Registration Reply37 deprecated Domain Name Request38 deprecated Domain Name Reply39 deprecated SKIP Algorithm Discovery Protocol Simple Key Management for Internet Protocol40 Photuris Security failures41 Experimental ICMP for experimental mobility protocols such as Seamoby RFC4065 42 Extended Echo Request 10 0 Request Extended Echo XPing see Extended Ping Xping 43 Extended Echo Reply 10 0 No Error1 Malformed Query2 No Such Interface3 No Such Table Entry4 Multiple Interfaces Satisfy Query44 through 252 unassigned Reserved253 Experimental RFC3692 style Experiment 1 RFC 4727 254 Experimental RFC3692 style Experiment 2 RFC 4727 255 reserved ReservedSource quench edit Source Quench requests that the sender decrease the rate of messages sent to a router or host This message may be generated if a router or host does not have sufficient buffer space to process the request or may occur if the router or host buffer is approaching its limit Data is sent at a very high speed from a host or from several hosts at the same time to a particular router on a network Although a router has buffering capabilities the buffering is limited to within a specified range The router cannot queue any more data than the capacity of the limited buffering space Thus if the queue gets filled up incoming data is discarded until the queue is no longer full But as no acknowledgement mechanism is present in the network layer the client does not know whether the data has reached the destination successfully Hence some remedial measures should be taken by the network layer to avoid these kind of situations These measures are referred to as source quench In a source quench mechanism the router sees that the incoming data rate is much faster than the outgoing data rate and sends an ICMP message to the clients informing them that they should slow down their data transfer speeds or wait for a certain amount of time before attempting to send more data When a client receives this message it automatically slows down the outgoing data rate or waits for a sufficient amount of time which enables the router to empty the queue Thus the source quench ICMP message acts as flow control in the network layer Since research suggested that ICMP Source Quench was an ineffective and unfair antidote for congestion 11 routers creation of source quench messages was deprecated in 1995 by RFC 1812 Furthermore forwarding of and any kind of reaction to flow control actions source quench messages was deprecated from 2012 by RFC 6633 Source quench message 6 9 00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31Type 4 Code 0 ChecksumunusedIP header and first 8 bytes of original datagram s dataWhere Type must be set to 4 Code must be set to 0 IP header and additional data is used by the sender to match the reply with the associated requestRedirect edit nbsp An example of how an ICMPv4 redirect message worksRedirect requests data packets be sent on an alternative route ICMP Redirect is a mechanism for routers to convey routing information to hosts The message informs a host to update its routing information to send packets on an alternative route If a host tries to send data through a router R1 and R1 sends the data on another router R2 and a direct path from the host to R2 is available that is the host and R2 are on the same subnetwork then R1 will send a redirect message to inform the host that the best route for the destination is via R2 The host should then change its route information and send packets for that destination directly to R2 The router will still send the original datagram to the intended destination 12 However if the datagram contains routing information this message will not be sent even if a better route is available RFC 1122 states that redirects should only be sent by gateways and should not be sent by Internet hosts Redirect message 6 11 00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31Type 5 Code ChecksumIP addressIP header and first 8 bytes of original datagram s dataWhere Type must be set to 5 Code specifies the reason for the redirection and may be one of the following Code Description0 Redirect for Network1 Redirect for Host2 Redirect for Type of Service and Network3 Redirect for Type of Service and Host dd IP address is the 32 bit address of the gateway to which the redirection should be sent IP header and additional data is included to allow the host to match the reply with the request that caused the redirection reply Time exceeded edit Time Exceeded is generated by a gateway to inform the source of a discarded datagram due to the time to live field reaching zero A time exceeded message may also be sent by a host if it fails to reassemble a fragmented datagram within its time limit Time exceeded messages are used by the traceroute utility to identify gateways on the path between two hosts Time exceeded message 6 5 00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31Type 11 Code ChecksumunusedIP header and first 8 bytes of original datagram s dataWhere Type must be set to 11 Code specifies the reason for the time exceeded message include the following Code Description0 Time to live exceeded in transit 1 Fragment reassembly time exceeded dd IP header and first 64 bits of the original payload are used by the source host to match the time exceeded message to the discarded datagram For higher level protocols such as UDP and TCP the 64 bit payload will include the source and destination ports of the discarded packet Timestamp edit Timestamp is used for time synchronization The originating timestamp is set to the time in milliseconds since midnight the sender last touched the packet The receive and transmit timestamps are not used Timestamp message 6 15 00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31Type 13 Code 0 ChecksumIdentifier Sequence numberOriginate timestampReceive timestampTransmit timestampWhere Type must be set to 13 Code must be set to 0 Identifier and Sequence Number can be used by the client to match the timestamp reply with the timestamp request Originate timestamp is the number of milliseconds since midnight Universal Time UT If a UT reference is not available the most significant bit can be set to indicate a non standard time value Timestamp reply edit Timestamp Reply replies to a Timestamp message It consists of the originating timestamp sent by the sender of the Timestamp as well as a receive timestamp indicating when the Timestamp was received and a transmit timestamp indicating when the Timestamp reply was sent Timestamp reply message 6 15 00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31Type 14 Code 0 ChecksumIdentifier Sequence numberOriginate timestampReceive timestampTransmit timestampWhere Type must be set to 14 Code must be set to 0 Identifier and Sequence number can be used by the client to match the reply with the request that caused the reply Originate timestamp is the time the sender last touched the message before sending it Receive timestamp is the time the echoer first touched it on receipt Transmit timestamp is the time the echoer last touched the message on sending it All timestamps are in units of milliseconds since midnight UT If the time is not available in milliseconds or cannot be provided with respect to midnight UT then any time can be inserted in a timestamp provided the high order bit of the timestamp is also set to indicate this non standard value The use of Timestamp and Timestamp Reply messages to synchronize the clocks of Internet nodes has largely been replaced by the UDP based Network Time Protocol and the Precision Time Protocol 13 Address mask request edit Address mask request is normally sent by a host to a router in order to obtain an appropriate subnet mask Recipients should reply to this message with an Address mask reply message Address mask request 00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31Type 17 Code 0 ChecksumIdentifier Sequence numberAddress maskWhere Type must be set to 17 Code must be set to 0 Address mask can be set to 0ICMP Address Mask Request may be used as a part of reconnaissance attack to gather information on the target network therefore ICMP Address Mask Reply is disabled by default on Cisco IOS 14 Address mask reply edit Address mask reply is used to reply to an address mask request message with an appropriate subnet mask Address mask reply 00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31Type 18 Code 0 ChecksumIdentifier Sequence numberAddress maskWhere Type must be set to 18 Code must be set to 0 Address mask should be set to the subnet maskDestination unreachable edit Destination unreachable is generated by the host or its inbound gateway 6 to inform the client that the destination is unreachable for some reason Reasons for this message may include the physical connection to the host does not exist distance is infinite the indicated protocol or port is not active the data must be fragmented but the don t fragment flag is on Unreachable TCP ports notably respond with TCP RST rather than a destination unreachable type 3 as might be expected Destination unreachable is never reported for IP multicast transmissions Destination unreachable message 6 3 00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31Type 3 Code Checksumunused Next hop MTUIP header and first 8 bytes of original datagram s dataWhere Type field bits 0 7 must be set to 3 Code field bits 8 15 is used to specify the type of error and can be any of the following Code Description0 Network unreachable error 1 Host unreachable error 2 Protocol unreachable error the designated transport protocol is not supported 3 Port unreachable error the designated protocol is unable to inform the host of the incoming message 4 The datagram is too big Packet fragmentation is required but the don t fragment DF flag is on 5 Source route failed error 6 Destination network unknown error 7 Destination host unknown error 8 Source host isolated error 9 The destination network is administratively prohibited 10 The destination host is administratively prohibited 11 The network is unreachable for Type Of Service 12 The host is unreachable for Type Of Service 13 Communication administratively prohibited administrative filtering prevents packet from being forwarded 14 Host precedence violation indicates the requested precedence is not permitted for the combination of host or network and port 15 Precedence cutoff in effect precedence of datagram is below the level set by the network administrators dd Next hop MTU field bits 48 63 contains the MTU of the next hop network if a code 4 error occurs 15 IP header and additional data is included to allow the client to match the reply with the request that caused the destination unreachable reply See also editICMP hole punching PathPing Path MTU Discovery Smurf attackReferences edit F Baker June 1995 Baker F ed Requirements for IP Version 4 Routers p 52 RFC 1812 a b c d Forouzan Behrouz A 2007 Data Communications And Networking Fourth ed Boston McGraw Hill pp 621 630 ISBN 978 0 07 296775 3 The OSI Model s Seven Layers Defined and Functions Explained Microsoft Support Retrieved 2014 12 28 Protocol Numbers Internet Assigned Numbers Authority Retrieved 2011 06 23 Requirements for IP Version 4 Routers doi 10 17487 RFC1812 RFC 1812 a b c d e f g h i j k Postel J September 1981 Internet Control Message Protocol IETF doi 10 17487 RFC0792 RFC 792 IANA ICMP Parameters Iana org 2012 09 21 Retrieved 2013 01 07 Kurose J F Ross K W 2006 Computer Networking A Top Down Approach World student series Addison Wesley ISBN 9780321418494 Internet Control Message Protocol ICMP Parameters www iana org Retrieved 2023 09 13 a b PROBE A Utility for Probing Interfaces doi 10 17487 RFC8335 RFC 8335 RFC 6633 When Are ICMP Redirects Sent Cisco Systems 2008 06 28 Retrieved 2013 08 15 D L Mills September 1985 Network Time Protocol NTP doi 10 17487 RFC0958 RFC 958 It is evolved from the Time Protocol and the ICMP Timestamp message and is a suitable replacement for both Cisco IOS IP Command Reference Volume 1 of 4 Addressing and Services Release 12 3 IP Addressing and Services Commands ip mask reply through ip web cache Cisco Systems Archived from the original on 2013 01 02 Retrieved 2013 01 07 Extended ICMP to Support Multi Part Messages doi 10 17487 RFC4884 RFC 4884 Sources editRFCs edit RFC 792 Internet Control Message Protocol RFC 950 Internet Standard Subnetting Procedure RFC 1016 Something a Host Could Do with Source Quench The Source Quench Introduced Delay SQuID RFC 1122 Requirements for Internet Hosts Communication Layers RFC 1716 Towards Requirements for IP Routers RFC 1812 Requirements for IP Version 4 Routers RFC 4884 Extended ICMP to Support Multi Part MessagesExternal links edit nbsp Wikiversity has learning resources about Internet Control Message Protocol IANA ICMP parameters IANA protocol numbers Explanation of ICMP Redirect Behavior at the Wayback Machine archived 2015 01 10 Retrieved from https en wikipedia org w index php title Internet Control Message Protocol amp oldid 1218013716 Source quench, wikipedia, wiki, book, books, library,

article

, read, download, free, free download, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, picture, music, song, movie, book, game, games.