diff options
| author | Tom Gundersen <teg@jklm.no> | 2016-01-11 21:31:53 +0100 | 
|---|---|---|
| committer | Tom Gundersen <teg@jklm.no> | 2016-01-11 21:31:53 +0100 | 
| commit | a41a7181c9af8f9ac93a85a2cf133294dd202c8e (patch) | |
| tree | 89f17418bab87d1466023b124dcd96485cc4df59 /src/resolve/resolved-dns-packet.c | |
| parent | 81c5eb5b3dcaf889c678cd46b97e378e3be4743e (diff) | |
| parent | eee026a7ba16336b6493828a2a13ddc9908667ff (diff) | |
Merge pull request #2289 from poettering/dnssec13
Thirteenth DNSSEC patch set
Diffstat (limited to 'src/resolve/resolved-dns-packet.c')
| -rw-r--r-- | src/resolve/resolved-dns-packet.c | 19 | 
1 files changed, 8 insertions, 11 deletions
| diff --git a/src/resolve/resolved-dns-packet.c b/src/resolve/resolved-dns-packet.c index 4750bf1f5d..a8a8632491 100644 --- a/src/resolve/resolved-dns-packet.c +++ b/src/resolve/resolved-dns-packet.c @@ -466,12 +466,8 @@ int dns_packet_append_label(DnsPacket *p, const char *d, size_t l, bool canonica                  /* Generate in canonical form, as defined by DNSSEC                   * RFC 4034, Section 6.2, i.e. all lower-case. */ -                for (i = 0; i < l; i++) { -                        if (d[i] >= 'A' && d[i] <= 'Z') -                                w[i] = (uint8_t) (d[i] - 'A' + 'a'); -                        else -                                w[i] = (uint8_t) d[i]; -                } +                for (i = 0; i < l; i++) +                        w[i] = (uint8_t) ascii_tolower(d[i]);          } else                  /* Otherwise, just copy the string unaltered. This is                   * essential for DNS-SD, where the casing of labels @@ -2089,11 +2085,12 @@ int dns_packet_extract(DnsPacket *p) {                                          goto finish;                                  } -                                /* The OPT RR is only valid in the Additional section */ -                                if (i < DNS_PACKET_ANCOUNT(p) + DNS_PACKET_NSCOUNT(p)) { -                                        r = -EBADMSG; -                                        goto finish; -                                } +                                /* Note that we accept the OPT RR in +                                 * any section, not just in the +                                 * additional section, as some routers +                                 * (Belkin!)  blindly copy the OPT RR +                                 * from the query to the reply packet, +                                 * and don't get the section right. */                                  /* Two OPT RRs? */                                  if (p->opt) { | 
