diff options
author | David 'Digit' Turner <digit@google.com> | 2009-07-27 19:19:29 +0200 |
---|---|---|
committer | David 'Digit' Turner <digit@google.com> | 2009-07-27 19:19:29 +0200 |
commit | 3773d35eb98e22b5edab4d82fb72bdf86ff80494 (patch) | |
tree | 05cdad25492e5dd326c10bc0b1f6ac78b0e8b1bd /libc/netbsd | |
parent | 39f3745cf30efe38482ffead1c32f4e62f6fe32e (diff) | |
download | bionic-3773d35eb98e22b5edab4d82fb72bdf86ff80494.zip bionic-3773d35eb98e22b5edab4d82fb72bdf86ff80494.tar.gz bionic-3773d35eb98e22b5edab4d82fb72bdf86ff80494.tar.bz2 |
Make the DNS resolver accept domain names with an underscore.
More precisely, this accepts domain labels with an underscore in
the middle (i.e. not at the start or the end of the label). This
is needed to perform complex CNAME chain resolution in certain
VPN networks.
Diffstat (limited to 'libc/netbsd')
-rw-r--r-- | libc/netbsd/resolv/res_comp.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/libc/netbsd/resolv/res_comp.c b/libc/netbsd/resolv/res_comp.c index 6991e8b..77b81b4 100644 --- a/libc/netbsd/resolv/res_comp.c +++ b/libc/netbsd/resolv/res_comp.c @@ -147,6 +147,12 @@ dn_skipname(const u_char *ptr, const u_char *eom) { * tell us anything about network-format data. The rest of the BIND system * is not careful about this, but for some reason, we're doing it right here. */ + +/* BIONIC: We also accept underscores in the middle of labels. + * This extension is needed to make resolution on some VPN networks + * work properly. + */ + #define PERIOD 0x2e #define hyphenchar(c) ((c) == 0x2d) #define bslashchar(c) ((c) == 0x5c) @@ -155,9 +161,10 @@ dn_skipname(const u_char *ptr, const u_char *eom) { #define alphachar(c) (((c) >= 0x41 && (c) <= 0x5a) \ || ((c) >= 0x61 && (c) <= 0x7a)) #define digitchar(c) ((c) >= 0x30 && (c) <= 0x39) +#define underscorechar(c) ((c) == 0x5f) #define borderchar(c) (alphachar(c) || digitchar(c)) -#define middlechar(c) (borderchar(c) || hyphenchar(c)) +#define middlechar(c) (borderchar(c) || hyphenchar(c) || underscorechar(c)) #define domainchar(c) ((c) > 0x20 && (c) < 0x7f) int |