summaryrefslogtreecommitdiff
path: root/sbin/dhclient/dhclient.c
diff options
context:
space:
mode:
authorKenneth R Westerback <krw@cvs.openbsd.org>2013-02-01 01:33:45 +0000
committerKenneth R Westerback <krw@cvs.openbsd.org>2013-02-01 01:33:45 +0000
commit19a793606451fcc605c05ca20bbd8662b0ec2fd9 (patch)
treeaaf459c9cb906b086c01cd38f0767035cb58c8d4 /sbin/dhclient/dhclient.c
parent8fb1ab30611285831c4c363f655a50adb5798f2f (diff)
Write out resolv.conf only if the default route is under the control
of the process binding the lease. Re-check the default route whenever a routing message arrives that might mean the default route has changed, and write out resolv.conf if appropriate. Reduces the chances that the name servers in resolv.conf are unreachable. Problem most eloquently explained, and solution suggested by beck@.
Diffstat (limited to 'sbin/dhclient/dhclient.c')
-rw-r--r--sbin/dhclient/dhclient.c28
1 files changed, 19 insertions, 9 deletions
diff --git a/sbin/dhclient/dhclient.c b/sbin/dhclient/dhclient.c
index e3779d07128..c2d0a5209e4 100644
--- a/sbin/dhclient/dhclient.c
+++ b/sbin/dhclient/dhclient.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: dhclient.c,v 1.217 2013/01/27 02:45:46 krw Exp $ */
+/* $OpenBSD: dhclient.c,v 1.218 2013/02/01 01:33:44 krw Exp $ */
/*
* Copyright 2004 Henning Brauer <henning@openbsd.org>
@@ -93,6 +93,7 @@ struct imsgbuf *unpriv_ibuf;
void sighdlr(int);
int findproto(char *, int);
struct sockaddr *get_ifa(char *, int);
+int resolv_conf_priority(int);
void usage(void);
int res_hnok(const char *dn);
char *option_as_string(unsigned int code, unsigned char *data, int len);
@@ -288,6 +289,15 @@ routehandler(void)
default:
break;
}
+
+ /* Something has happened. Try to write out the resolv.conf. */
+ if (client->active && client->active->resolv_conf &&
+ resolv_conf_priority(ifi->rdomain))
+ write_file("/etc/resolv.conf",
+ O_WRONLY | O_CREAT | O_TRUNC | O_SYNC | O_EXLOCK,
+ S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH, 0, 0,
+ client->new->resolv_conf, strlen(client->new->resolv_conf));
+
return;
die:
@@ -783,14 +793,6 @@ bind_lease(void)
if (nameservers == NULL)
error("no memory for nameservers");
- client->new->resolv_conf = resolv_conf_contents(
- &options[DHO_DOMAIN_NAME], &options[DHO_DOMAIN_NAME_SERVERS]);
- if (client->new->resolv_conf)
- write_file("/etc/resolv.conf",
- O_WRONLY | O_CREAT | O_TRUNC | O_SYNC | O_EXLOCK,
- S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH, 0, 0,
- client->new->resolv_conf, strlen(client->new->resolv_conf));
-
/*
* Add address and default route last, so we know when the binding
* is done by the RTM_NEWADDR message being received.
@@ -804,6 +806,14 @@ bind_lease(void)
add_default_route(ifi->rdomain, client->new->address, gateway);
}
+ client->new->resolv_conf = resolv_conf_contents(
+ &options[DHO_DOMAIN_NAME], &options[DHO_DOMAIN_NAME_SERVERS]);
+ if (client->new->resolv_conf)
+ write_file("/etc/resolv.conf",
+ O_WRONLY | O_CREAT | O_TRUNC | O_SYNC | O_EXLOCK,
+ S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH, 0, 0,
+ client->new->resolv_conf, strlen(client->new->resolv_conf));
+
free(domainname);
free(nameservers);