X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Modules%2FIPStack%2Ficmp.c;h=3f82f878121621feb2bceb0ee95338cbbbca0e1c;hb=78bdffb8a6fceefb0846958fe0152523c7f5b525;hp=bd9c05f4ee381ca550770ae3046e00b49f230f94;hpb=6c5a509b5e14e097ca537c539bc9babe3b8f0c4c;p=tpg%2Facess2.git diff --git a/Modules/IPStack/icmp.c b/Modules/IPStack/icmp.c index bd9c05f4..3f82f878 100644 --- a/Modules/IPStack/icmp.c +++ b/Modules/IPStack/icmp.c @@ -3,13 +3,21 @@ * - ICMP Handling */ #include "ipstack.h" +#include "ipv4.h" #include "icmp.h" +// === CONSTANTS === +#define PING_SLOTS 64 + // === PROTOTYPES === void ICMP_Initialise(); -void ICMP_GetPacket(tInterface *Interface, int Length, void *Buffer); +void ICMP_GetPacket(tInterface *Interface, void *Address, int Length, void *Buffer); // === GLOBALS === +struct { + tInterface *Interface; + int bArrived; +} gICMP_PingSlots[PING_SLOTS]; // === CODE === /** @@ -18,7 +26,7 @@ void ICMP_GetPacket(tInterface *Interface, int Length, void *Buffer); */ void ICMP_Initialise() { - + IPv4_RegisterCallback(IP4PROT_ICMP, ICMP_GetPacket); } /** @@ -29,4 +37,56 @@ void ICMP_GetPacket(tInterface *Interface, void *Address, int Length, void *Buff { tICMPHeader *hdr = Buffer; + Log("[ICMP ] hdr->Type = %i", hdr->Type); + Log("[ICMP ] hdr->Code = %i", hdr->Code); + Log("[ICMP ] hdr->Checksum = 0x%x", ntohs(hdr->Checksum)); + Log("[ICMP ] hdr->ID = 0x%x", ntohs(hdr->ID)); + Log("[ICMP ] hdr->Sequence = 0x%x", ntohs(hdr->Sequence)); + + switch(hdr->Type) + { + case ICMP_ECHOREPLY: + if(hdr->Code != 0) { + Warning("[ICMP ] Code == %i for ICMP Echo Reply, should be 0", hdr->Code); + return ; + } + if(hdr->ID != ~hdr->Sequence) { + Warning("[ICMP ] ID and Sequence values do not match"); + return ; + } + gICMP_PingSlots[hdr->ID].bArrived = 1; + break; + } + +} + +/** + * \brief Sends ICMP Echo and waits for the reply + * \note Times out after \a Interface->TimeoutDelay has elapsed + */ +int ICMP_Ping(tInterface *Interface, tIPv4 Addr) +{ + //Sint64 ts; + char buf[32] = "\x8\0\0\0\0\0\0\0Acess2 I" + "P/TCP Stack 1.0\0"; + tICMPHeader *hdr = (void*)buf; + int i; + + for(;;) + { + for(i=0;iID = i; + hdr->Sequence = ~i; + hdr->Checksum = htons( IPv4_Checksum(hdr, sizeof(buf)) ); + IPv4_SendPacket(Interface, Addr, 1, i, 32, buf); + + return -1; }