]>
git.ipfire.org Git - thirdparty/dhcpcd.git/log
Roy Marples [Sat, 5 Sep 2020 15:12:30 +0000 (16:12 +0100)]
privsep: Use xsocketpair
Roy Marples [Sat, 5 Sep 2020 15:10:30 +0000 (16:10 +0100)]
if: introduce xsocketpair, similar to xsocket
Old systems don't have SOCK_CLOEXEC, etc, this makes it easy.
While here, right limit the sockets.
Roy Marples [Wed, 2 Sep 2020 08:56:32 +0000 (09:56 +0100)]
DHCP: allow leasetime -1 to represent infinity
Easier to enter than
4294967295 seconds which is the real
representation of infinity.
Roy Marples [Tue, 1 Sep 2020 11:24:42 +0000 (12:24 +0100)]
DHCP: optimize prior for systems without IPv4 address lifetimes
Roy Marples [Tue, 1 Sep 2020 11:15:00 +0000 (12:15 +0100)]
DHCP: Adjust prior to be more generic
Roy Marples [Tue, 1 Sep 2020 10:56:53 +0000 (11:56 +0100)]
DHCP: Don't set address lifetimes when extending leases
Otherwise the kernel WILL remove them.
dhcpcd already manages address removal when needed because
some OS's do not support address lifetimes even for IPv6.
While here apply the same logic to IPv6.
Roy Marples [Mon, 31 Aug 2020 05:51:27 +0000 (06:51 +0100)]
dhcpcd: Rename function for prior now it no longer inits
Roy Marples [Mon, 31 Aug 2020 05:48:59 +0000 (06:48 +0100)]
dhcpcd: Adjust prior to ensure options exist for active interfaces before timeouts
Roy Marples [Sun, 30 Aug 2020 08:41:47 +0000 (09:41 +0100)]
DHCP: reason is BOUND when recovering from an expired extended lease
Roy Marples [Sun, 30 Aug 2020 08:07:35 +0000 (09:07 +0100)]
DHCP: When extending the lease, re-enter the DISCOVER phase.
Roy Marples [Sun, 30 Aug 2020 07:28:44 +0000 (08:28 +0100)]
dhcpcd: init new interfaces from route(4) overflow
This ensures that any newly active ones have an options structure.
Roy Marples [Sun, 30 Aug 2020 07:03:01 +0000 (08:03 +0100)]
DHCP: Request offered IP when using lastlease
Also, set expired state on using last lease rather than last lease extension.
Roy Marples [Thu, 20 Aug 2020 15:28:47 +0000 (16:28 +0100)]
privsep: Only the master process accepts signals
The master process dictates when processes should stop, which
allows for a clean shutdown when the admin issues `pkill dhcpcd`.
Roy Marples [Thu, 20 Aug 2020 15:09:53 +0000 (16:09 +0100)]
DHCP: Mark the state as expired on lase lease extension
Expired states do not claim any client IP to request from.
Roy Marples [Sun, 16 Aug 2020 18:21:48 +0000 (19:21 +0100)]
Use a minimum bufsize of 1 as 0 doesn't work on some OS.
Roy Marples [Sun, 16 Aug 2020 17:52:17 +0000 (18:52 +0100)]
privsep: Set a zero length receive buffer for write only sockets
We cannot use shutdown(2) because they are not connected.
Constantly draining would be a waste of CPU time, so just let
the buffer overflow. To ease the kernel as much as we can, set
a zero length buffer.
The kernel may still allocate a small buffer, but this is kernel
dependant and we're just trying to be helpful.
Roy Marples [Sat, 8 Aug 2020 19:27:34 +0000 (20:27 +0100)]
privsep: Improve some errors
Roy Marples [Sat, 8 Aug 2020 19:06:55 +0000 (20:06 +0100)]
dhcpcd: Fix logging we forked at exit.
Roy Marples [Tue, 4 Aug 2020 13:26:18 +0000 (14:26 +0100)]
Revert "Don't install /var/db/dhcpcd in the Makefile"
This was when the privsep code had the database directory in the
chroot, which it not longer is.
This reverts commit
5f275b7bd1ed4d1f830b7a60ba253a98f7ef6127 .
Roy Marples [Mon, 3 Aug 2020 16:04:51 +0000 (17:04 +0100)]
Revert "privsep: shutdown read end of the write only sockets"
Fails noisly on Linux.
This reverts commit
5fc20ae1aa368e36f9cabcbc047cd7d8e468c5b7 .
Roy Marples [Mon, 3 Aug 2020 15:56:14 +0000 (16:56 +0100)]
dhcpcd: If using -4 or -6, check we have support for it
Better to error early sensibly.
Roy Marples [Mon, 3 Aug 2020 15:55:51 +0000 (16:55 +0100)]
inet6: Linux will convert NULL to all, so don't specify all
Roy Marples [Mon, 3 Aug 2020 15:54:59 +0000 (16:54 +0100)]
Linux: fix reading the ipv6 forwarding proc entry
We need to ensure that the carriage return doesn't give issue.
Roy Marples [Mon, 3 Aug 2020 15:15:39 +0000 (16:15 +0100)]
Linux: IP6 forwaring only applies to "all" interface
Per interface forwarding is apparently only for setting things
like IsRouter in NA messages.
Roy Marples [Sat, 1 Aug 2020 19:56:13 +0000 (20:56 +0100)]
options: Let clientid override a prior duid
So you can do
duid
ssid foo
clientid
Roy Marples [Sat, 25 Jul 2020 13:22:18 +0000 (14:22 +0100)]
options: open an address socket to detect if inet6 is available
This should silence dhcpcd warnings if IPv6 is compiled out.
Do the same for IPv4, although that's highly unlikely as
it's kind of required for some interface ioctls.
Fabrice Fontaine [Mon, 13 Jul 2020 08:43:51 +0000 (10:43 +0200)]
src/dhcpcd.c: fix build without fork
Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
Roy Marples [Sat, 1 Aug 2020 19:32:34 +0000 (20:32 +0100)]
privsep: Don't read control_group in privsep
There is no need as it's a global option and it will have already
been read in by this point.
Also means we don't need to pledge getpw.
Roy Marples [Sat, 18 Jul 2020 11:40:30 +0000 (12:40 +0100)]
privsep: shutdown read end of the write only sockets
Clearly shows our intent and hopefully is an optimisation
within the kernel.
Roy Marples [Wed, 8 Jul 2020 11:36:36 +0000 (12:36 +0100)]
Fix prior
Roy Marples [Wed, 8 Jul 2020 11:03:15 +0000 (12:03 +0100)]
route: Ensure IPv4LL routes always come last in priority
Roy Marples [Sat, 4 Jul 2020 12:21:09 +0000 (13:21 +0100)]
Fix compile without IPv6 on systems that do not define ALIGN
Roy Marples [Fri, 3 Jul 2020 10:41:23 +0000 (11:41 +0100)]
Make DBDIR permissions same as the files it creates
Roy Marples [Fri, 3 Jul 2020 10:33:39 +0000 (11:33 +0100)]
Release dhcpcd-9.1.4
Roy Marples [Fri, 3 Jul 2020 10:30:25 +0000 (11:30 +0100)]
dhcpcd: Fix creating DBDIR
As privsep now uses files in / and not the dhcpcd users directory
we need to ensure the mkdir is back with the rundir.
Roy Marples [Thu, 2 Jul 2020 17:14:01 +0000 (18:14 +0100)]
Fix SMALL build
Roy Marples [Thu, 2 Jul 2020 13:42:57 +0000 (14:42 +0100)]
Release dhcpcd-9.1.3
Roy Marples [Thu, 2 Jul 2020 13:05:19 +0000 (14:05 +0100)]
make: clean before import-src
Roy Marples [Wed, 1 Jul 2020 19:09:42 +0000 (20:09 +0100)]
DHCP6: Restore lease timings
Erroneously changed in
060f5a9e93 , only seems to affect
INFORM getting into a loop.
Roy Marples [Wed, 1 Jul 2020 10:46:01 +0000 (11:46 +0100)]
BSD: Setup sysctls before redirecting stderr
Need to do this as early as.
Roy Marples [Wed, 1 Jul 2020 10:45:06 +0000 (11:45 +0100)]
privsep: Don't limit file writes if logging to a file
stderr could be redirected.
While here, there is no longer a need to redirect stderr or stdout
as they already have been in dhcpcd.
Roy Marples [Tue, 30 Jun 2020 21:06:00 +0000 (22:06 +0100)]
dhcpcd: improve prior to log to another fd
This allows stderr and stdout to be redirected to /dev/null.
Roy Marples [Tue, 30 Jun 2020 20:33:24 +0000 (21:33 +0100)]
dhcpcd: Turn off stderr logging rather than closing stderr
And only turn it off when stderr is a tty.
A better approach might to open an fd just to log to and
redirect stdout/stderr to /dev/null alongside stdin at program
start, but that's more code.
Roy Marples [Mon, 29 Jun 2020 12:14:21 +0000 (13:14 +0100)]
privsep: check return of freopen(3)
So shutup some compilers who complain we don't do anything with it.
Roy Marples [Mon, 29 Jun 2020 10:54:29 +0000 (11:54 +0100)]
options: rework prior to use macros
Can't use DHCPCD_MASTER because a config option sets it - duh.
This allows us to use a different config option which makes little
sense in options but makes sense in the code.
Roy Marples [Sat, 27 Jun 2020 12:58:44 +0000 (13:58 +0100)]
inet6: Don't regen temp addresses we didn't add.
Helps with interopability with OpenBSD's slaacd(8).
Roy Marples [Sat, 27 Jun 2020 12:46:25 +0000 (13:46 +0100)]
options: use DHCPCD_MASTER to guard global options
As ifname generally always set.
Roy Marples [Wed, 24 Jun 2020 19:53:20 +0000 (20:53 +0100)]
Linux: restore fix when no address is returned by getifaddrs(3)
Suck sucky sucky, but it fixes PPP links again.
Roy Marples [Tue, 23 Jun 2020 10:31:25 +0000 (11:31 +0100)]
Linux: redefine NLA_ALIGNTO as 4U
This removes the last of the alignment issues reported by clang
in the linux driver for dhcpcd.
Upstream has no interest in fixing this and local testing
shows it works fine on all platforms I have.
https://www.spinics.net/lists/netdev/msg646934.html
Roy Marples [Mon, 22 Jun 2020 21:09:31 +0000 (22:09 +0100)]
Linux: Warn if netlink(7) seq number doesn't match expectation.
While here, ensure it never goes out of scope.
Roy Marples [Mon, 22 Jun 2020 20:56:16 +0000 (21:56 +0100)]
Linux: keep the generic netlink socket around to get ssid with privsep
While here, improve our reading of netlink(7) and terminate on either
ERROR or DONE. If neither are in the message, read again unless it's
the link receiving socket.
Also, only callback if this is the sequence number expected.
Roy Marples [Mon, 22 Jun 2020 16:31:58 +0000 (17:31 +0100)]
privsep: init more fd -1
Roy Marples [Mon, 22 Jun 2020 12:22:16 +0000 (13:22 +0100)]
Linux: Sweep errors about disabling autogeneration of LL addrs
under the table.
I tire of this report.
Roy Marples [Mon, 22 Jun 2020 12:18:26 +0000 (13:18 +0100)]
Linux: fix a compile warning for older compilers
Roy Marples [Mon, 22 Jun 2020 12:17:25 +0000 (13:17 +0100)]
Linux: support aarch64 for reading cpu info
Roy Marples [Mon, 22 Jun 2020 12:08:25 +0000 (13:08 +0100)]
linux: ignore unsupported interfaces by default, such as sit0
Roy Marples [Mon, 22 Jun 2020 11:52:42 +0000 (12:52 +0100)]
dhcpcd: Report error when caching vendor
Roy Marples [Mon, 22 Jun 2020 11:45:37 +0000 (12:45 +0100)]
script: Make visible some link level parameters to lease dumping
protocol, ssid and profile are now visible
Ismael Luceno [Sun, 21 Jun 2020 14:06:14 +0000 (15:06 +0100)]
Libc implementations are allowed to require the explicit inclusion of
either <sys/types.h> (where it should be defined) or <sys/stat.h>
(prototypes requiring it) to expose mode_t.
Without that it fails to be exposed in musl libc, and potentially other
implementations.
Signed-off-by: Ismael Luceno <ismael@iodev.co.uk>
Roy Marples [Fri, 19 Jun 2020 08:36:55 +0000 (09:36 +0100)]
dhcpcd: Only poll after mac randomisation
That will cause a delay and poll instantly rather than
an initial wait.
Roy Marples [Thu, 18 Jun 2020 20:15:15 +0000 (21:15 +0100)]
dhcpcd: Add an option to poll the interface carrier state
Only to be used if the interface does not report carrier state
changes for whatever reason.
Roy Marples [Wed, 17 Jun 2020 14:17:58 +0000 (15:17 +0100)]
Quick change for pior
Roy Marples [Wed, 17 Jun 2020 14:12:13 +0000 (15:12 +0100)]
configure: add --with-eghook=foo
Allows to force for example ypbind if it's not installed.
Roy Marples [Wed, 17 Jun 2020 10:25:58 +0000 (11:25 +0100)]
dhcpcd: preserve the STARTED option when reloading options
This avoids the truncated read when the launcher process exists
after the main process handles SIGHUP.
Roy Marples [Wed, 17 Jun 2020 08:42:32 +0000 (09:42 +0100)]
inet6: No flags on the prefix means the prefix is via the router
Fixes a minor regression from prior.
Roy Marples [Tue, 16 Jun 2020 19:58:17 +0000 (20:58 +0100)]
privsep: Simplyfy signal handling
All privsep processes only need to act on SIGTERM.
The privileged actioneer also needs to act on SIGCHLD.
Roy Marples [Tue, 16 Jun 2020 16:31:47 +0000 (17:31 +0100)]
eloop: Add rationale for ELOOP_NSIGNALS
Roy Marples [Tue, 16 Jun 2020 16:21:20 +0000 (17:21 +0100)]
Align
Roy Marples [Tue, 16 Jun 2020 16:12:58 +0000 (17:12 +0100)]
eloop: Guard diagnostic in prior with ELOOP_DEBUG
Roy Marples [Tue, 16 Jun 2020 16:07:10 +0000 (17:07 +0100)]
privsep: Use root signal_cb for all signals here.
Roy Marples [Tue, 16 Jun 2020 13:35:49 +0000 (14:35 +0100)]
eloop: Try and survive a signal storm
Shouldn't happen in production, but you never know.
Roy Marples [Tue, 16 Jun 2020 11:58:16 +0000 (11:58 +0000)]
privsep: Don't handle any signals meant for the main process
Just incase someone issues a killall -HUP dhcpcd
Roy Marples [Tue, 16 Jun 2020 10:26:25 +0000 (10:26 +0000)]
BSD: Allow non NetBSD and OpenBSD to set IN6_IFF_AUTOCONF
I don't think FreeBSD or DragonFly ever filtered it out, so
all the BSD family should now have parity here.
Roy Marples [Mon, 15 Jun 2020 23:48:42 +0000 (00:48 +0100)]
inet6: Report RA Proxy flag if set
Roy Marples [Mon, 15 Jun 2020 21:43:39 +0000 (22:43 +0100)]
inet6: Add support for reporting Mobile IPv6 RA's
This is RFC6275. dhcpcd is not a client suitable for this,
but it will at least decode the information properly.
Roy Marples [Mon, 15 Jun 2020 21:04:37 +0000 (22:04 +0100)]
configure: Fix fallout with disabling embedded config
Roy Marples [Mon, 15 Jun 2020 15:28:31 +0000 (16:28 +0100)]
Release dhcpcd-9.1.2
Roy Marples [Mon, 15 Jun 2020 14:51:17 +0000 (15:51 +0100)]
DHCP6: Use sla setting when calculating delegated prefix length
This is fine as we have a limited list of interfaces we're
delegating to so we know all the numbers.
This fixes an issue where an interface index could exceed 8 bits.
While here change sla_set to a boolean.
Roy Marples [Mon, 15 Jun 2020 14:14:53 +0000 (15:14 +0100)]
privsep: don't abort if setrlimit fails
Just log the error.
This allows valgrind to be used still as it uses big fd numbers in
the client.
Roy Marples [Mon, 15 Jun 2020 11:52:55 +0000 (12:52 +0100)]
DHCP6: Add requested addresses after freeing all state addresses
Otherwise we don't request the correct prefix delegation length
for example....
Roy Marples [Mon, 15 Jun 2020 08:49:34 +0000 (09:49 +0100)]
BSD: Mark routes as static only from static config
Rather than if genered by an address.
This allows RA prefix routes without an address to be non static,
so you could derive whether a route came from something autoconf
or not.
Roy Marples [Sun, 14 Jun 2020 14:26:59 +0000 (15:26 +0100)]
BSD: Mark address AUTOCONF if no kernel RA
Roy Marples [Thu, 11 Jun 2020 14:37:33 +0000 (15:37 +0100)]
Warn if the OS lacks support to lock down BPF or equivalent
Roy Marples [Thu, 11 Jun 2020 10:35:20 +0000 (11:35 +0100)]
udev: disable for non Linux systems
On FreeBSD udev, the function udev_device_new_from_subsystem_sysname
exists but is not implemented.
As such it breaks our device initialisation detection.
Disabled by default, but can be enabled with ./configure --with-udev
Roy Marples [Wed, 10 Jun 2020 18:00:45 +0000 (19:00 +0100)]
IPv4LL: free the arp state once announced for RFC 5227 kernels
Otherwise the BPF process will hang around
Roy Marples [Wed, 10 Jun 2020 15:32:04 +0000 (16:32 +0100)]
privsep: Fix a shutdown race
Only test a successful stop IPC command.
By the time we shutdown the socket to be extra nice, the
process we sent stop to could have already exited, therefore
we can discard any error.
Roy Marples [Wed, 10 Jun 2020 13:47:00 +0000 (14:47 +0100)]
privsep: fix size of rdm
Roy Marples [Wed, 10 Jun 2020 13:42:08 +0000 (14:42 +0100)]
Fix some logic
Roy Marples [Wed, 10 Jun 2020 13:38:46 +0000 (14:38 +0100)]
dhcpcd: Ensure dump is terminated
Roy Marples [Wed, 10 Jun 2020 13:31:03 +0000 (14:31 +0100)]
logerr: Remove setvbuf diagnostic - it's not critical
Roy Marples [Wed, 10 Jun 2020 13:16:08 +0000 (14:16 +0100)]
minor cleanup
Roy Marples [Wed, 10 Jun 2020 10:16:14 +0000 (11:16 +0100)]
Try and guard against impossibly large data.
Roy Marples [Wed, 10 Jun 2020 07:30:28 +0000 (08:30 +0100)]
privsep: RLIMIT_FSIZE works fine on pledge and capsicum
If you don't use the dhcpcd logfile option.
Duh.
Roy Marples [Wed, 10 Jun 2020 06:34:18 +0000 (07:34 +0100)]
DHCP6: Apply delegations to interface on carrier up
Even with DHCP6 turned off for the interface.
As long as it was activated by another interface this is fine.
Roy Marples [Wed, 10 Jun 2020 06:16:41 +0000 (07:16 +0100)]
Linux: Fix compile for systems without route preference
Roy Marples [Wed, 10 Jun 2020 06:13:21 +0000 (07:13 +0100)]
Linux: fix compile on old ones
Roy Marples [Wed, 10 Jun 2020 06:04:29 +0000 (07:04 +0100)]
privsep: Disable RLIMIT_FSIZE when using the logfile option
We cannot offload it to the root process either because not all
sandboxes have access to that.....
Really need to fix syslog so that it starts before dhcpcd.
Roy Marples [Wed, 10 Jun 2020 05:35:54 +0000 (06:35 +0100)]
privsep: Fix compile on alpine linux
Roy Marples [Wed, 10 Jun 2020 04:46:19 +0000 (05:46 +0100)]
privsep: Apply resource limits to OpenBSD as well where we can
After all, pledge or capsicum could have bugs.
Roy Marples [Wed, 10 Jun 2020 04:27:25 +0000 (05:27 +0100)]
privsep: Apply what resource limits we can to capsicum