mirror of
git://sourceware.org/git/glibc.git
synced 2025-03-31 14:01:18 +08:00
nss_dns: Skip over non-PTR records in the netent code [BZ #19868]
This requires additional checks for the RDATA length and the availability of record metadata.
This commit is contained in:
parent
c3bae689d3
commit
a12f9431b3
@ -1,3 +1,10 @@
|
||||
2016-03-25 Florian Weimer <fweimer@redhat.com>
|
||||
|
||||
[BZ #19868]
|
||||
* resolv/nss_dns/dns-network.c (getanswer_r): Implement additional
|
||||
DNS packet syntax checks (which were not needed before). Skip
|
||||
over non-PTR records.
|
||||
|
||||
2016-04-27 Florian Weimer <fweimer@redhat.com>
|
||||
|
||||
* resolv/nss_dns/dns-network.c (offsetof): Remove macro
|
||||
|
@ -343,10 +343,23 @@ getanswer_r (const querybuf *answer, int anslen, struct netent *result,
|
||||
if (n < 0 || res_dnok (bp) == 0)
|
||||
break;
|
||||
cp += n;
|
||||
|
||||
if (end_of_message - cp < 10)
|
||||
{
|
||||
__set_h_errno (NO_RECOVERY);
|
||||
return NSS_STATUS_UNAVAIL;
|
||||
}
|
||||
|
||||
GETSHORT (type, cp);
|
||||
GETSHORT (class, cp);
|
||||
cp += INT32SZ; /* TTL */
|
||||
GETSHORT (n, cp);
|
||||
uint16_t rdatalen;
|
||||
GETSHORT (rdatalen, cp);
|
||||
if (end_of_message - cp < rdatalen)
|
||||
{
|
||||
__set_h_errno (NO_RECOVERY);
|
||||
return NSS_STATUS_UNAVAIL;
|
||||
}
|
||||
|
||||
if (class == C_IN && type == T_PTR)
|
||||
{
|
||||
@ -368,7 +381,7 @@ getanswer_r (const querybuf *answer, int anslen, struct netent *result,
|
||||
cp += n;
|
||||
return NSS_STATUS_UNAVAIL;
|
||||
}
|
||||
cp += n;
|
||||
cp += rdatalen;
|
||||
if (alias_pointer + 2 < &net_data->aliases[MAX_NR_ALIASES])
|
||||
{
|
||||
*alias_pointer++ = bp;
|
||||
@ -379,6 +392,9 @@ getanswer_r (const querybuf *answer, int anslen, struct netent *result,
|
||||
++have_answer;
|
||||
}
|
||||
}
|
||||
else
|
||||
/* Skip over unknown record data. */
|
||||
cp += rdatalen;
|
||||
}
|
||||
|
||||
if (have_answer)
|
||||
|
Loading…
x
Reference in New Issue
Block a user