Different way of detecting neighbor solicitation requests.
authorGuus Sliepen <guus@tinc-vpn.org>
Fri, 15 Mar 2002 15:40:40 +0000 (15:40 +0000)
committerGuus Sliepen <guus@tinc-vpn.org>
Fri, 15 Mar 2002 15:40:40 +0000 (15:40 +0000)
src/route.c

index 4e41cdff7ca6fcb68fc61adffe8b7ac624179596..00b5298b3dacedd3c8a91d425318042418f1d7ff 100644 (file)
@@ -17,7 +17,7 @@
     along with this program; if not, write to the Free Software
     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
-    $Id: route.c,v 1.1.2.34 2002/03/15 15:08:21 guus Exp $
+    $Id: route.c,v 1.1.2.35 2002/03/15 15:40:40 guus Exp $
 */
 
 #include "config.h"
 
 #include "system.h"
 
+#ifndef s6_addr16
+#define s6_addr16 __u6_addr.__u6_addr16
+#endif
+
 int routing_mode = RMODE_ROUTER;
 int priorityinheritance = 0;
 int macexpire = 600;
@@ -305,7 +309,7 @@ cp
   checksum = inet_checksum((unsigned short int *)&pseudo, sizeof(pseudo)/2, ~0);
   checksum = inet_checksum((unsigned short int *)ns, sizeof(*ns)/2 + 4, checksum);
 
-  ns->nd_ns_hdr.icmp6_cksum = checksum;
+  ns->nd_ns_hdr.icmp6_cksum = htons(checksum);
 
   write_packet(packet);
 cp
@@ -395,12 +399,12 @@ cp
               n = route_ipv4(packet);
               break;
             case 0x86DD:
-              n = route_ipv6(packet);
-             if(!n && packet->data[0] == 0x33 && packet->data[1] == 0x33 && packet->data[2] == 0xff)
+              if(packet->data[20] == IPPROTO_ICMPV6 && packet->data[54] = ND_NEIGHBOR_SOLICIT)
                {
                  route_neighborsol(packet);
                  return;
                }
+              n = route_ipv6(packet);
               break;
             case 0x0806:
               route_arp(packet);