Re: [BUG] dhcpcd 9.0.1: dhcpcd refused to start if ipv6 is not available
Roy Marples
Thu Apr 16 15:37:51 2020
Hi Juergen
On 16/04/2020 13:15, Juergen Daubert wrote:
Hallo,
this is on a Linux system without ipv6:
# dhcpcd -d
dhcpcd-9.0.1 starting
executing `/lib/dhcpcd/dhcpcd-run-hooks' CHROOT
spawned privileged actioneer on PID 1362
spawned network proxy on PID 1363
udev: starting
dev: loaded udev
chrooting to `/var/lib/dhcpcd'
ps_inet_startcb: ipv6nd_open: Address family not supported by protocol
ps_start: Address family not supported by protocol
enp8s0: if_disable_autolinklocal: Address family not supported by
protocol
enp8s0: executing `/lib/dhcpcd/dhcpcd-run-hooks' PREINIT
enp8s0: executing `/lib/dhcpcd/dhcpcd-run-hooks' CARRIER
DUID 00:01:00:01:26:26:fe:b6:2c:fd:a1:5a:a7:99
enp8s0: IAID a1:5a:a7:99
enp8s0: adding address fe80::bd1b:1c16:d5d4:cd7e
enp8s0: pltime infinity, vltime infinity
ipv6_addaddr1: Operation not supported
enp8s0: delaying IPv6 router solicitation for 0.6 seconds
enp8s0: delaying IPv4 for 1.3 seconds
ps_dostop: Connection refused
dev: unloaded udev
dhcpcd exited
Notes:
- works if dhcpcd is started with --ipv4only
- works with dhcpcd 8.1.8
Does the attached patch help at all?
Roy
diff --git a/src/privsep-inet.c b/src/privsep-inet.c
index 0cf50b42..9f1eeab7 100644
--- a/src/privsep-inet.c
+++ b/src/privsep-inet.c
@@ -99,37 +99,37 @@ ps_inet_startcb(void *arg)
close(ctx->ps_data_fd);
ctx->ps_data_fd = -1;
+ errno = 0;
+
#ifdef INET
if ((ctx->options & (DHCPCD_IPV4 | DHCPCD_MASTER)) ==
(DHCPCD_IPV4 | DHCPCD_MASTER))
{
ctx->udp_fd = dhcp_openudp(NULL);
- if (ctx->udp_fd == -1) {
+ if (ctx->udp_fd == -1)
logerr("%s: dhcp_open", __func__);
- return -1;
- }
- if (eloop_event_add(ctx->eloop, ctx->udp_fd,
+ else if (eloop_event_add(ctx->eloop, ctx->udp_fd,
ps_inet_recvbootp, ctx) == -1)
{
logerr("%s: eloop_event_add DHCP", __func__);
- return -1;
- }
- ret++;
+ close(ctx->udp_fd);
+ ctx->udp_fd = -1;
+ } else
+ ret++;
}
#endif
#if defined(INET6) && !defined(__sun)
if (ctx->options & DHCPCD_IPV6) {
- if (ipv6nd_open(ctx) == -1) {
+ if (ipv6nd_open(ctx) == -1)
logerr("%s: ipv6nd_open", __func__);
- return -1;
- }
- if (eloop_event_add(ctx->eloop, ctx->nd_fd,
+ else if (eloop_event_add(ctx->eloop, ctx->nd_fd,
ps_inet_recvra, ctx) == -1)
{
logerr("%s: eloop_event_add RA", __func__);
- return -1;
- }
- ret++;
+ close(ctx->nd_fd);
+ ctx->nd_fd = -1;
+ } else
+ ret++;
}
#endif
#ifdef DHCP6
@@ -137,21 +137,20 @@ ps_inet_startcb(void *arg)
(DHCPCD_DHCP6 | DHCPCD_MASTER))
{
ctx->dhcp6_fd = dhcp6_openudp(0, NULL);
- if (ctx->dhcp6_fd == -1) {
+ if (ctx->dhcp6_fd == -1)
logerr("%s: dhcp6_open", __func__);
- return -1;
- }
- if (eloop_event_add(ctx->eloop, ctx->dhcp6_fd,
+ else if (eloop_event_add(ctx->eloop, ctx->dhcp6_fd,
ps_inet_recvdhcp6, ctx) == -1)
{
logerr("%s: eloop_event_add DHCP6", __func__);
- return -1;
- }
- ret++;
+ close(ctx->dhcp6_fd);
+ ctx->dhcp6_fd = -1;
+ } else
+ ret++;
}
#endif
- if (ret == 0) {
+ if (ret == 0 && errno == 0) {
errno = ENXIO;
return -1;
}
Archive administrator: postmaster@marples.name