1 diff -Nau dnsmasq-2.35/src/dnsmasq.h dnsmasq/src/dnsmasq.h 2 --- dnsmasq-2.35/src/dnsmasq.h 2006-10-18 16:24:50.000000000 -0400 3 +++ dnsmasq/src/dnsmasq.h 2006-11-16 22:06:31.000000000 -0500 4 @@ -112,6 +112,7 @@ 5 #define OPT_NO_PING 2097152 6 #define OPT_LEASE_RO 4194304 7 #define OPT_RELOAD 8388608 8 +#define OPT_TRY_ALL_NS 16777216 9 10 struct all_addr { 11 union { 12 diff -Nau dnsmasq-2.35/src/forward.c dnsmasq/src/forward.c 13 --- dnsmasq-2.35/src/forward.c 2006-10-18 16:24:50.000000000 -0400 14 +++ dnsmasq/src/forward.c 2006-11-16 22:08:19.000000000 -0500 15 @@ -445,6 +445,10 @@ 16 { 17 struct server *server = forward->sentto; 18 19 + // If strict-order and try-all-ns are set, treat NXDOMAIN as a failed request 20 + if( (daemon->options & OPT_ORDER) && (daemon->options && OPT_TRY_ALL_NS) 21 + && header->rcode == NXDOMAIN ) header->rcode = SERVFAIL; 22 + 23 if ((header->rcode == SERVFAIL || header->rcode == REFUSED) && forward->forwardall == 0) 24 /* for broken servers, attempt to send to another one. */ 25 { 26 diff -Nau dnsmasq-2.35/src/option.c dnsmasq/src/option.c 27 --- dnsmasq-2.35/src/option.c 2006-10-18 16:24:50.000000000 -0400 28 +++ dnsmasq/src/option.c 2006-11-16 22:10:36.000000000 -0500 29 @@ -28,7 +28,7 @@ 30 31 /* options which don't have a one-char version */ 32 #define LOPT_RELOAD 256 33 - 34 +#define LOPT_TRY_ALL_NS 257 35 36 #ifdef HAVE_GETOPT_LONG 37 static const struct option opts[] = 38 @@ -102,6 +102,7 @@ 39 {"leasefile-ro", 0, 0, '9'}, 40 {"dns-forward-max", 1, 0, '0'}, 41 {"clear-on-reload", 0, 0, LOPT_RELOAD }, 42 + {"try-all-ns", 0, 0, LOPT_TRY_ALL_NS }, 43 { NULL, 0, 0, 0 } 44 }; 45 46 @@ -134,6 +135,7 @@ 47 { '5', OPT_NO_PING }, 48 { '9', OPT_LEASE_RO }, 49 { LOPT_RELOAD, OPT_RELOAD }, 50 + { LOPT_TRY_ALL_NS,OPT_TRY_ALL_NS }, 51 { 'v', 0}, 52 { 'w', 0}, 53 { 0, 0 } 54 @@ -208,6 +210,7 @@ 55 { "-9, --leasefile-ro", gettext_noop("Read leases at startup, but never write the lease file."), NULL }, 56 { "-0, --dns-forward-max=<queries>", gettext_noop("Maximum number of concurrent DNS queries. (defaults to %s)"), "!" }, 57 { " --clear-on-reload", gettext_noop("Clear DNS cache when reloading %s."), RESOLVFILE }, 58 + { " --try-all-ns", gettext_noop("Try all name servers in tandem on NXDOMAIN replies (use with strict-order)."), NULL }, 59 { NULL, NULL, NULL } 60 }; 61 62