diff options
author | Ulrich Drepper <drepper@redhat.com> | 2009-07-16 23:37:50 -0700 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2009-07-16 23:37:50 -0700 |
commit | 1c0ab5bd34159d2ae53390571113844ebadc161b (patch) | |
tree | aa81b93cc43a1d56be12f2f9da9f508118a33943 /resolv | |
parent | 137028b4d7e50f71906c1656c27079eac5a1d085 (diff) | |
download | glibc-1c0ab5bd34159d2ae53390571113844ebadc161b.tar.gz glibc-1c0ab5bd34159d2ae53390571113844ebadc161b.tar.xz glibc-1c0ab5bd34159d2ae53390571113844ebadc161b.zip |
Handle overly large answer buffers in resolver.
In EDNS0 records the maximum result size is transmitted in a 16 bit value. Large buffer sizes were handled incorrectly by using only the low 16 bits. Fix this by limiting the size to 0xffff.
Diffstat (limited to 'resolv')
-rw-r--r-- | resolv/res_mkquery.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/resolv/res_mkquery.c b/resolv/res_mkquery.c index ae0cdb417e..2dda4c0f45 100644 --- a/resolv/res_mkquery.c +++ b/resolv/res_mkquery.c @@ -244,7 +244,7 @@ __res_nopt(res_state statp, *cp++ = 0; /* "." */ NS_PUT16(T_OPT, cp); /* TYPE */ - NS_PUT16(anslen & 0xffff, cp); /* CLASS = UDP payload size */ + NS_PUT16(MIN(anslen, 0xffff), cp); /* CLASS = UDP payload size */ *cp++ = NOERROR; /* extended RCODE */ *cp++ = 0; /* EDNS version */ /* XXX Once we support DNSSEC we change the flag value here. */ |