Difference between revisions of "Unit ICMP"
(5 intermediate revisions by the same user not shown) | |||
Line 6: | Line 6: | ||
'''Ultibo ICMP (Internet Control Message Protocol) unit''' | '''Ultibo ICMP (Internet Control Message Protocol) unit''' | ||
− | |||
− | |||
=== Constants === | === Constants === | ||
Line 534: | Line 532: | ||
− | '''ICMP | + | '''ICMP specific classes''' |
− | + | {| class="wikitable" style="font-size: 14px; text-align: left; width: 100%; height: 50px;" | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
|- | |- | ||
− | | | + | | [[TICMPProtocolTransport|<code>TICMPProtocolTransport = class(TProtocolTransport)</code>]] |
− | + | ||
− | + | ||
− | | <code> | + | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
|- | |- | ||
|} | |} | ||
− | + | {| class="wikitable" style="font-size: 14px; text-align: left; width: 100%; height: 50px;" | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
|- | |- | ||
− | | | + | | [[TICMPProtocol|<code>TICMPProtocol = class(TNetworkProtocol)</code>]] |
− | + | ||
− | + | ||
− | | <code> | + | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
|- | |- | ||
|} | |} | ||
− | + | {| class="wikitable" style="font-size: 14px; text-align: left; width: 100%; height: 50px;" | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
|- | |- | ||
− | | | + | | [[TICMPSocket|<code>TICMPSocket = class(TProtocolSocket)</code>]] |
− | + | ||
− | + | ||
− | + | ||
− | | <code> | + | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
|- | |- | ||
|} | |} | ||
− | + | {| class="wikitable" style="font-size: 14px; text-align: left; width: 100%; height: 50px;" | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
|- | |- | ||
− | | | + | | [[TICMPBuffer|<code>TICMPBuffer = class(TSocketBuffer)</code>]] |
− | + | ||
− | + | ||
− | | <code> | + | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
|- | |- | ||
|} | |} | ||
− | |||
<br /> | <br /> | ||
− | |||
=== Public variables === | === Public variables === | ||
---- | ---- | ||
Line 880: | Line 572: | ||
{| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
|- | |- | ||
− | ! | + | ! Note |
| None documented | | None documented | ||
|- | |- | ||
Line 895: | Line 587: | ||
{| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
|- | |- | ||
− | ! | + | ! Buffer |
| The complete packet including Transport header | | The complete packet including Transport header | ||
|- | |- | ||
Line 907: | Line 599: | ||
{| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
|- | |- | ||
− | ! | + | ! Buffer |
| The complete packet including Transport header | | The complete packet including Transport header | ||
|- | |- | ||
Line 919: | Line 611: | ||
{| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
|- | |- | ||
− | ! | + | ! Buffer |
| The complete packet including Transport header | | The complete packet including Transport header | ||
|- | |- | ||
Line 931: | Line 623: | ||
{| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
|- | |- | ||
− | ! | + | ! Buffer |
| The complete packet including Transport header | | The complete packet including Transport header | ||
|- | |- | ||
Line 943: | Line 635: | ||
{| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
|- | |- | ||
− | ! | + | ! Buffer |
| The complete packet including Transport header | | The complete packet including Transport header | ||
|- | |- | ||
Line 955: | Line 647: | ||
{| class="wikitable" style="font-size: 14px; background: white;" | {| class="wikitable" style="font-size: 14px; background: white;" | ||
|- | |- | ||
− | ! | + | ! Note |
| None documented | | None documented | ||
|- | |- |
Latest revision as of 05:24, 31 August 2021
Return to Unit Reference
Contents
Description
Ultibo ICMP (Internet Control Message Protocol) unit
Constants
ICMP_PROTOCOL_*
Note: Some ICMP definitions are in the Protocol or IP modules | |
ICMP_PROTOCOL_NAME = 'ICMP';
|
ICMP_*
ICMP_TIMEOUT = 0;
|
Wait forever on a ICMP Read |
ICMP_BUFFER_SIZE = 65536;
|
ICMP Receive Buffer Size |
ICMP_HEADER_SIZE = 8;
|
SizeOf(TICMPHeader); ICMP.Solicit |
ICMP_PACKET_SIZE = 8;
|
SizeOf(TICMPPacket) |
ICMP_ROUTER_TIMEOUT = 60000;
|
Type definitions
ICMP unused header
PICMPUnusedHeader = ^TICMPUnusedHeader;
TICMPUnusedHeader = packed record {Unreachable, TimeExceeded, SourceQuench etc}
Note: Some ICMP definitions are in the Protocol or IP modules | |
ICMPType:Byte;
|
ICMP_UNREACH etc |
Code:Byte;
|
ICMP_UNREACH_NET,ICMP_UNREACH_PORT etc |
Checksum:Word;
|
1s Compliment checksum of Structure |
Unused:LongWord;
|
4 Bytes Unused Must be Zero |
IP:TIPHeader;
|
IP Header from Original IP Packet |
Data:array[0..7] of Byte;
|
8 Bytes of Original IP Packet Data |
ICMP unreach header
PICMPUnreachHeader = ^TICMPUnreachHeader;
TICMPUnreachHeader = TICMPUnusedHeader;
Note: ICMP_UNREACH | |
ICMP expire header
PICMPExpireHeader = ^TICMPExpireHeader;
TICMPExpireHeader = TICMPUnusedHeader;
Note: ICMP_TIMXCEED | |
ICMP quench header
PICMPQuenchHeader = ^TICMPQuenchHeader;
TICMPQuenchHeader = TICMPUnusedHeader;
Note: ICMP_SOURCEQUENCH | |
ICMP pointer header
PICMPPointerHeader = ^TICMPPointerHeader;
TICMPPointerHeader = packed record
Note: Param Problem | |
ICMPType:Byte;
|
ICMP_PARAMPROB etc |
Code:Byte;
|
ICMP_PARAMPROB_OPTABSENT etc |
Checksum:Word;
|
1s Compliment checksum of Structure |
Pointer:Byte;
|
If Code = 0 Pointer to Byte where Error Occured |
Unused:array[0..2] of Byte;
|
3 Bytes Unused Must be Zero |
IP:TIPHeader;
|
IP Header from Original IP Packet |
Data:array[0..7] of Byte;
|
8 Bytes of Original IP Packet Data |
ICMP param header
PICMPParamHeader = ^TICMPParamHeader;
TICMPParamHeader = TICMPPointerHeader;
Note: ICMP_PARAMPROB | |
ICMP IP header
PICMPIpHeader = ^TICMPIpHeader;
TICMPIpHeader = packed record
Note: Redirect | |
ICMPType:Byte;
|
ICMP_REDIRECT etc |
Code:Byte;
|
ICMP_REDIRECT_NET,ICMP_REDIRECT_HOST etc |
Checksum:Word;
|
1s Compliment checksum of Structure |
Gateway:TInAddr;
|
Redirect Gateway Address |
IP:TIPHeader;
|
IP Header from Original IP Packet |
Data:array[0..7] of Byte;
|
8 Bytes of Original IP Packet Data |
ICMP redirect header
PICMPRedirectHeader = ^TICMPRedirectHeader;
TICMPRedirectHeader = TICMPIpHeader
Note: ICMP_REDIRECT | |
ICMP echo header
PICMPEchoHeader = ^TICMPEchoHeader;
TICMPEchoHeader = packed record
Note: Echo Request/Reply | |
ICMPType:Byte;
|
ICMP_ECHO,ICMP_ECHOREPLY |
Code:Byte;
|
Always 0 |
Checksum:Word;
|
1s Compliment checksum of Structure |
Identifier:Word;
|
Increments with each ICMP_ECHO |
Sequence:Word;
|
Sequence within an ICMP_ECHO set |
Data:array[0..((MAX_IP_PACKET - 1) - SizeOf(TIPHeader)) - 8] of Byte;
|
ICMP time stamp header
PICMPTimestampHeader = ^TICMPTimestampHeader;
TICMPTimestampHeader = packed record
Note: Timestamp Request/Reply | |
ICMPType:Byte;
|
ICMP_TSTAMP,ICMP_TSTAMPREPLY |
Code:Byte;
|
Always 0 |
Checksum:Word;
|
1s Compliment checksum of Structure |
Identifier:Word;
|
Increments with each ICMP_TSTAMP |
Sequence:Word;
|
Sequence within an ICMP_TSTAMP set |
Original:LongWord;
|
Original Timestamp |
Receive:LongWord;
|
Receive Timestamp |
Transmit:LongWord;
|
Transmit Timestamp (A sort of Round Trip Time Echo) |
ICMP info header
PICMPInfoHeader = ^TICMPInfoHeader;
TICMPInfoHeader = packed record
Note: Info Request/Reply | |
ICMPType:Byte;
|
ICMP_IREQ,ICMP_IREQREPLY |
Code:Byte;
|
Always 0 |
Checksum:Word;
|
1s Compliment checksum of Structure |
Identifier:Word;
|
Increments with each ICMP_IREQ |
Sequence:Word;
|
Sequence within an ICMP_IREQ set (Used to determine Network Number of Local Subnet) |
ICMP mask header
PICMPMaskHeader = ^TICMPMaskHeader;
TICMPMaskHeader = packed record
Note: Mask Request/Reply | |
ICMPType:Byte;
|
ICMP_MASKREQ,ICMP_MASKREPLY |
Code:Byte;
|
Always 0 |
Checksum:Word;
|
1s Compliment checksum of Structure |
Identifier:Word;
|
Increments with each ICMP_MASKREQ |
Sequence:Word;
|
Sequence within an ICMP_MASKREQ set |
Mask:TInAddr;
|
Subnet Mask of Local Subnet (Used to determine Subnet Mask of Local Subnet) |
ICMP router address
PICMPRouterAddress = ^TICMPRouterAddress;
TICMPRouterAddress = packed record
Address:TInAddr;
|
The address of the Router on this subnet |
Level:LongInt;
|
The level of preference, higher is better |
ICMP advert header
PICMPAdvertHeader = ^TICMPAdvertHeader;
TICMPAdvertHeader = packed record
ICMPType:Byte;
|
ICMP_ROUTERADVERT |
Code:Byte;
|
Always 0 |
Checksum:Word;
|
1s Compliment checksum of Structure |
EntryCount:Byte;
|
Number of Router Address entries |
EntrySize:Byte;
|
Size of each Router Address entry |
Lifetime:Word;
|
Lifetime of entries in seconds |
Routers:array[1..EntryCount] of TICMPRouterAddress;
|
Used to advertise routers |
ICMP solicit header
PICMPSolicitHeader = ^TICMPSolicitHeader;
TICMPSolicitHeader = packed record
ICMPType:Byte;
|
ICMP_ROUTERSOLICIT |
Code:Byte;
|
Always 0 |
Checksum:Word;
|
1s Compliment checksum of Structure |
Reserved:LongWord;
|
Always 0 (Used to solicit routers) |
ICMP header
PICMPHeader = ^TICMPHeader;
TICMPHeader = packed record
case Integer of
|
|
0:(Unused:TICMPUnusedHeader);
|
|
1:(Unreach:TICMPUnreachHeader);
|
|
2:(Expire:TICMPExpireHeader);
|
|
3:(Quench:TICMPQuenchHeader);
|
|
4:(Pointer:TICMPPointerHeader);
|
|
5:(Param:TICMPParamHeader);
|
|
6:(Ip:TICMPIpHeader);
|
|
7:(Redirect:TICMPRedirectHeader);
|
|
8:(Echo:TICMPEchoHeader);
|
|
9:(Timestamp:TICMPTimestampHeader);
|
|
10:(Info:TICMPInfoHeader);
|
|
11:(Mask:TICMPMaskHeader);
|
|
12:(Advert:TICMPAdvertHeader);
|
|
13:(Solicit:TICMPSolicitHeader);
|
ICMP packet
PICMPPacket = ^TICMPPacket;
TICMPPacket = record
Note: 8 Bytes (Used by ICMPBuffer) | |
Size:LongWord;
|
LongWord to keep size even |
Next:PICMPPacket;
|
Followed by RemoteAddress (4 or 16 Bytes) |
Class definitions
ICMP specific classes
TICMPProtocolTransport = class(TProtocolTransport)
|
TICMPProtocol = class(TNetworkProtocol)
|
TICMPSocket = class(TProtocolSocket)
|
TICMPBuffer = class(TSocketBuffer)
|
Public variables
None defined
Function declarations
Initialization functions
procedure ICMPInit;
Note | None documented |
---|
ICMP functions
function CheckICMP(AFamily:Word; ABuffer:Pointer):Boolean;
Buffer | The complete packet including Transport header |
---|
function GetICMPHeaderOffset(AFamily:Word; ABuffer:Pointer):Word;
Buffer | The complete packet including Transport header |
---|
function GetICMPHeaderLength(AFamily:Word; ABuffer:Pointer):Word;
Buffer | The complete packet including Transport header |
---|
function GetICMPDataOffset(AFamily:Word; ABuffer:Pointer):Word;
Buffer | The complete packet including Transport header |
---|
function GetICMPDataLength(AFamily:Word; ABuffer:Pointer):Word;
Buffer | The complete packet including Transport header |
---|
function ChecksumICMP(AFamily:Word; ABuffer:Pointer; AOffset,ALength:Word):Word;
Note | None documented |
---|
Return to Unit Reference