summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2014-02-12 15:11:31 -0500
committerNick Mathewson <nickm@torproject.org>2014-02-12 15:11:31 -0500
commit24add404ac08df59d0b5d68c6762b869bee63bac (patch)
treef0eac7362de7fa012eb89187efc30f09f6990dee
parent2c0088b8aa360c8dfa4c38c45d50542fa9aae8fb (diff)
downloadtor-24add404ac08df59d0b5d68c6762b869bee63bac.tar.gz
tor-24add404ac08df59d0b5d68c6762b869bee63bac.zip
eventdns.c: survive broken resolv.conf files
If you had a resolv.conf file with a nameserver line containing no nameserver IP, we would crash. That's not terrible, but it's not desirable. Fixes bug 8788; bugfix on 0.1.1.23. Libevent already has this fix.
-rw-r--r--changes/bug87883
-rw-r--r--src/ext/eventdns.c3
2 files changed, 5 insertions, 1 deletions
diff --git a/changes/bug8788 b/changes/bug8788
new file mode 100644
index 0000000000..26fb5bc4f3
--- /dev/null
+++ b/changes/bug8788
@@ -0,0 +1,3 @@
+ o Minor bugfixes:
+ - Avoid crashing on a malformed resolv.conf file when running a
+ server using Libevent 1. Fixes bug 8788; bugfix on 0.1.1.23.
diff --git a/src/ext/eventdns.c b/src/ext/eventdns.c
index 8b934c4430..5ac9c1230c 100644
--- a/src/ext/eventdns.c
+++ b/src/ext/eventdns.c
@@ -3014,7 +3014,8 @@ resolv_conf_parse_line(char *const start, int flags) {
if (!strcmp(first_token, "nameserver") && (flags & DNS_OPTION_NAMESERVERS)) {
const char *const nameserver = NEXT_TOKEN;
- evdns_nameserver_ip_add(nameserver);
+ if (nameserver)
+ evdns_nameserver_ip_add(nameserver);
} else if (!strcmp(first_token, "domain") && (flags & DNS_OPTION_SEARCH)) {
const char *const domain = NEXT_TOKEN;
if (domain) {