X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fnetwork%2Fdns_parse.c;h=e6ee19d9a6f88d0608cc43eb438c70d35813a78b;hb=269d193820342dc109f39909d78fb30f4c978f76;hp=aa0d39f39fbc85afea25a483297704d1c2267d78;hpb=3330198060c7b3165a2fba530ffde5fc6706ecf2;p=musl diff --git a/src/network/dns_parse.c b/src/network/dns_parse.c index aa0d39f3..e6ee19d9 100644 --- a/src/network/dns_parse.c +++ b/src/network/dns_parse.c @@ -1,4 +1,5 @@ #include +#include "lookup.h" int __dns_parse(const unsigned char *r, int rlen, int (*callback)(void *, int, const void *, int, const void *), void *ctx) { @@ -6,6 +7,7 @@ int __dns_parse(const unsigned char *r, int rlen, int (*callback)(void *, int, c const unsigned char *p; int len; + if (rlen<12) return -1; if ((r[3]&15)) return 0; p = r+12; qdcount = r[4]*256 + r[5]; @@ -13,13 +15,13 @@ int __dns_parse(const unsigned char *r, int rlen, int (*callback)(void *, int, c if (qdcount+ancount > 64) return -1; while (qdcount--) { while (p-r < rlen && *p-1U < 127) p++; - if (*p>193 || (*p==193 && p[1]>254) || p>r+506) + if (*p>193 || (*p==193 && p[1]>254) || p>r+rlen-6) return -1; p += 5 + !!*p; } while (ancount--) { while (p-r < rlen && *p-1U < 127) p++; - if (*p>193 || (*p==193 && p[1]>254) || p>r+506) + if (*p>193 || (*p==193 && p[1]>254) || p>r+rlen-6) return -1; p += 1 + !!*p; len = p[8]*256 + p[9];