author | Rich Felker <dalias@aerifal.cx> | 2022年09月22日 19:11:48 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2022年10月19日 14:01:12 -0400 |
commit | 8c408937da4cb7f6460972a0f645694304de3c8c (patch) | |
tree | 8d60a3a0a2eb962842f2aa240c2641f775818ff5 /src | |
parent | 759bf785a84bd56ed1b163594f3f66ade808c0e3 (diff) | |
download | musl-8c408937da4cb7f6460972a0f645694304de3c8c.tar.gz |
-rw-r--r-- | src/network/lookup_name.c | 8 |
diff --git a/src/network/lookup_name.c b/src/network/lookup_name.c index 37d481f9..4a6999cb 100644 --- a/src/network/lookup_name.c +++ b/src/network/lookup_name.c @@ -108,6 +108,8 @@ struct dpc_ctx { #define RR_CNAME 5 #define RR_AAAA 28 +#define ABUF_SIZE 768 + static int dns_parse_callback(void *c, int rr, const void *data, int len, const void *packet) { char tmp[256]; @@ -127,7 +129,7 @@ static int dns_parse_callback(void *c, int rr, const void *data, int len, const memcpy(ctx->addrs[ctx->cnt++].addr, data, 16); break; case RR_CNAME: - if (__dn_expand(packet, (const unsigned char *)packet + 512, + if (__dn_expand(packet, (const unsigned char *)packet + ABUF_SIZE, data, tmp, sizeof tmp) > 0 && is_valid_hostname(tmp)) strcpy(ctx->canon, tmp); break; @@ -137,7 +139,7 @@ static int dns_parse_callback(void *c, int rr, const void *data, int len, const static int name_from_dns(struct address buf[static MAXADDRS], char canon[static 256], const char *name, int family, const struct resolvconf *conf) { - unsigned char qbuf[2][280], abuf[2][512]; + unsigned char qbuf[2][280], abuf[2][ABUF_SIZE]; const unsigned char *qp[2] = { qbuf[0], qbuf[1] }; unsigned char *ap[2] = { abuf[0], abuf[1] }; int qlens[2], alens[2]; @@ -171,7 +173,7 @@ static int name_from_dns(struct address buf[static MAXADDRS], char canon[static if ((abuf[i][3] & 15) != 0) return EAI_FAIL; } - for (i=0; i<nq; i++) + for (i=nq-1; i>=0; i--) __dns_parse(abuf[i], alens[i], dns_parse_callback, &ctx); if (ctx.cnt) return ctx.cnt; |