chiark / gitweb /
src/types.c: IPv4 networks match IPv6-mapped IPv4 addresses in sortlist.
authorMark Wooding <mdw@distorted.org.uk>
Sat, 3 May 2014 21:22:27 +0000 (22:22 +0100)
committerMark Wooding <mdw@distorted.org.uk>
Sat, 10 May 2014 13:31:44 +0000 (14:31 +0100)
Signed-off-by: Mark Wooding <mdw@distorted.org.uk>
src/types.c

index a2ddee31069f4c890160c9a4ecefe5a9ffec4172..0cbbdef7088916559bb52d6a5ddf296769101b57 100644 (file)
@@ -254,11 +254,28 @@ static adns_status pa_inaddr(const parseinfo *pai, int cbyte,
 
 static int search_sortlist(adns_state ads, int af, const void *ad) {
   const struct sortlist *slp;
+  const struct in6_addr *a6;
+  union gen_addr a;
   int i;
-  
+  int v6mappedp = 0;
+
+  if (af == AF_INET6) {
+    a6 = ad;
+    if (IN6_IS_ADDR_V4MAPPED(a6)) {
+      a.v4.s_addr = htonl(((unsigned long)a6->s6_addr[12] << 24) |
+                         ((unsigned long)a6->s6_addr[13] << 16) |
+                         ((unsigned long)a6->s6_addr[14] <<  8) |
+                         ((unsigned long)a6->s6_addr[15] <<  0));
+      v6mappedp = 1;
+    }
+  }
+
   for (i=0, slp=ads->sortlist;
-       i<ads->nsortlist && (af != slp->ai->af ||
-                           !slp->ai->matchp(ad, &slp->base, &slp->mask));
+       i<ads->nsortlist &&
+       !(af == slp->ai->af &&
+        slp->ai->matchp(ad, &slp->base, &slp->mask)) &&
+       !(v6mappedp && slp->ai->af == AF_INET &&
+        slp->ai->matchp(&a, &slp->base, &slp->mask));
        i++, slp++);
   return i;
 }