Kernel/arm7 - Tiny bugfix in NewKThread
[tpg/acess2.git] / Modules / IPStack / icmp.c
index cdc7126..1603719 100644 (file)
@@ -37,24 +37,23 @@ void ICMP_GetPacket(tInterface *Interface, void *Address, int Length, void *Buff
 {
        tICMPHeader     *hdr = Buffer;
        
-       Log("[ICMP ] Length = %i", Length);
-       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));
+       //Log_Debug("ICMPv4", "Length = %i", Length);
+       Log_Debug("ICMPv4", "hdr->Type, hdr->Code = %i, %i", hdr->Type, hdr->Code);
+       //Log_Debug("ICMPv4", "hdr->Checksum = 0x%x", ntohs(hdr->Checksum));
+       Log_Debug("ICMPv4", "hdr->ID = 0x%x", ntohs(hdr->ID));
+       Log_Debug("ICMPv4", "hdr->Sequence = 0x%x", ntohs(hdr->Sequence));
        
        switch(hdr->Type)
        {
        // -- 0: Echo Reply
        case ICMP_ECHOREPLY:
                if(hdr->Code != 0) {
-                       Warning("[ICMP ] Code == %i for ICMP Echo Reply, should be 0", hdr->Code);
+                       Log_Warning("ICMPv4", "Code == %i for ICMP Echo Reply, should be 0", hdr->Code);
                        return ;
                }
                if(hdr->ID != (Uint16)~hdr->Sequence) {
-                       Warning("[ICMP ] ID and Sequence values do not match");
-                       return ;
+                       Log_Warning("ICMPv4", "ID and Sequence values do not match");
+                       //return ;
                }
                gICMP_PingSlots[hdr->ID].bArrived = 1;
                break;
@@ -64,25 +63,26 @@ void ICMP_GetPacket(tInterface *Interface, void *Address, int Length, void *Buff
                switch(hdr->Code)
                {
                case 3: // Port Unreachable
-                       Log("[ICMP ] Destination Unreachable (Port Unreachable)");
+                       Log_Debug("ICMPv4", "Destination Unreachable (Port Unreachable)");
                        break;
                default:
-                       Log("[ICMP ] Destination Unreachable (Code %i)", hdr->Code);
+                       Log_Debug("ICMPv4", "Destination Unreachable (Code %i)", hdr->Code);
                        break;
                }
+//             IPv4_Unreachable( Interface, hdr->Code, htons(hdr->Length)-sizeof(tICMPHeader), hdr->Data );
                break;
        
        // -- 8: Echo Request
        case ICMP_ECHOREQ:
                if(hdr->Code != 0) {
-                       Warning("[ICMP ] Code == %i for ICMP Echo Request, should be 0", hdr->Code);
+                       Log_Warning("ICMPv4", "Code == %i for ICMP Echo Request, should be 0", hdr->Code);
                        return ;
                }
-               Log("[ICMP ] Replying");
+               //Log_Debug("ICMPv4", "Replying");
                hdr->Type = ICMP_ECHOREPLY;
                hdr->Checksum = 0;
-               hdr->Checksum = htons( IPv4_Checksum(hdr, Length) );
-               Log("[ICMP ] Checksum = 0x%04x", hdr->Checksum);
+               hdr->Checksum = htons( IPv4_Checksum( (Uint16*)hdr, Length/2 ) );
+               //Log_Debug("ICMPv4", "Checksum = 0x%04x", hdr->Checksum);
                IPv4_SendPacket(Interface, *(tIPv4*)Address, 1, ntohs(hdr->Sequence), Length, hdr);
                break;
        default:
@@ -110,23 +110,24 @@ int ICMP_Ping(tInterface *Interface, tIPv4 Addr)
                {
                        if(gICMP_PingSlots[i].Interface == NULL)        break;
                }
-               if(gICMP_PingSlots[i].Interface == NULL)        break;
+               if( i < PING_SLOTS )    break;
                Threads_Yield();
        }
        gICMP_PingSlots[i].Interface = Interface;
        gICMP_PingSlots[i].bArrived = 0;
        hdr->ID = i;
        hdr->Sequence = ~i;
-       hdr->Checksum = htons( IPv4_Checksum(hdr, sizeof(buf)) );
-       IPv4_SendPacket(Interface, Addr, 1, i, sizeof(buf), buf);
+       hdr->Checksum = htons( IPv4_Checksum((Uint16*)hdr, sizeof(buf)/2) );
        
        ts = now();
+       
+       IPv4_SendPacket(Interface, Addr, 1, i, sizeof(buf), buf);
+       
        end = ts + Interface->TimeoutDelay;
        while( !gICMP_PingSlots[i].bArrived && now() < end)     Threads_Yield();
        
-       ts = now() - ts;
-       if(ts > Interface->TimeoutDelay)
+       if(now() > end)
                return -1;
        
-       return (int)ts;
+       return (int)( now() - ts );
 }

UCC git Repository :: git.ucc.asn.au