Go to file
2016-09-06 10:43:49 +00:00
compat Fix returning a pid if open fails. 2016-05-04 12:32:29 +00:00
crypt Fix a Coverity error by avoiding a memset with zero length. 2016-05-03 10:25:42 +00:00
dev Install example hooks 2015-12-22 23:46:17 +00:00
dhcpcd-hooks Allow resolvconf to be user tunable. 2016-07-28 10:02:42 +00:00
test Fix another gcc warning. 2015-03-17 15:18:41 +00:00
arp.c Revert [da213b6490] because the fd we're reading from could be a generic 2016-06-28 12:22:51 +00:00
arp.h Rework if_address to just use an ipv4_addr structure, similar to how 2016-05-18 16:23:28 +00:00
auth.c DHCP messages are really BOOTP so lets name the structure accordingly. 2016-05-06 13:26:41 +00:00
auth.h Fix compile on BSD 2015-05-12 20:07:34 +00:00
bpf-filter.h dhcp_bpf_filter -> bootp_bpf_filter (and DHCP -> BOOTP for ports). 2016-05-14 16:35:23 +00:00
common.c Test slen is not -1 before setting error on MSG_TRUNC. 2016-09-02 14:29:54 +00:00
common.h Rework the recvmsg_realloc function to handle flags. 2016-09-02 08:09:47 +00:00
config-null.mk Compile embedded in without a config 2014-04-23 19:09:03 +00:00
configure Rework the recvmsg_realloc function to handle flags. 2016-09-02 08:09:47 +00:00
control.c Rework control_open to be cleaner for static analysis. 2016-05-03 14:31:50 +00:00
control.h Rework control_open to be cleaner for static analysis. 2016-05-03 14:31:50 +00:00
defs.h Release dhcpcd-6.11.3 2016-08-15 10:34:22 +00:00
dev.c Check a calloc failure. 2016-05-06 12:51:01 +00:00
dev.h Update copyrights to 2015. 2015-01-02 20:03:28 +00:00
dhcp6.c Remove the need for statically sized receive buffers for IPv6 ND and DHCPv6 2016-09-02 11:34:09 +00:00
dhcp6.h Simplify handling of IPv6 address from kernel messages, similar to IPv4. 2016-07-26 20:52:31 +00:00
dhcp-common.c uname always returns -1 on error on all supported platforms, so test for that. 2016-07-26 15:52:15 +00:00
dhcp-common.h Move dhcp6's read lease code into dhcp-common. 2016-05-06 13:02:41 +00:00
dhcp.c Fix a dropping leases when the ip address is removed by a 3rd party. 2016-09-01 11:46:51 +00:00
dhcp.h Rework if_address to just use an ipv4_addr structure, similar to how 2016-05-18 16:23:28 +00:00
dhcpcd-definitions.conf iSNS is option 83, not 84. 2016-04-12 14:15:11 +00:00
dhcpcd-embedded.c.in Adjust comment to remove +x bit. 2015-02-08 13:24:14 +00:00
dhcpcd-embedded.h.in Handle ND options in the same way we handle DHCP and DHCPv6 options. 2015-05-14 19:46:21 +00:00
dhcpcd-run-hooks.8.in Fix spelling mistakes, [944ac40b82]. 2016-06-27 15:40:57 +00:00
dhcpcd-run-hooks.in Support buggy FreeBSD rc system out of the box. 2016-03-12 10:52:41 +00:00
dhcpcd.8.in Fix formatting. 2016-08-15 10:53:49 +00:00
dhcpcd.c recvmsg expects an array of iovec structures, not a pointer to the first one. 2016-09-05 22:27:47 +00:00
dhcpcd.conf Move lookup-hostname hook to the example directory. 2015-12-22 22:33:32 +00:00
dhcpcd.conf.5.in Fix spelling mistakes, [944ac40b82]. 2016-06-27 15:40:57 +00:00
dhcpcd.h recvmsg expects an array of iovec structures, not a pointer to the first one. 2016-09-05 22:27:47 +00:00
duid.c Fix spelling mistakes, [944ac40b82]. 2016-06-27 15:40:57 +00:00
duid.h Update copyrights to 2015. 2015-01-02 20:03:28 +00:00
eloop.c Only mask off the signals we are interested in catching. 2016-08-12 16:34:01 +00:00
eloop.h Make eloop a tad easier to use. 2016-03-17 14:35:13 +00:00
genembedc Source now compiles on Solaris, just missing the if-sun.c support so 2014-05-21 23:07:52 +00:00
genembedh Handle ND options in the same way we handle DHCP and DHCPv6 options. 2015-05-14 19:46:21 +00:00
GNUmakefile Fix dependency and test targets 2014-07-31 00:57:47 +00:00
iconfig.mk Load config.{h,mk} when building tests. Fixes [1c11c59282]. 2014-05-30 21:47:14 +00:00
if-bsd.c Remove the POLLADDR check out of if-bsd.c and into ipv6.c for other OS's 2016-09-06 10:43:49 +00:00
if-linux-wext.c Change IF_SSIDSIZE to IF_SSIDLEN to be more clear about it. 2016-02-11 16:06:26 +00:00
if-linux.c More iovec array fixes. 2016-09-05 22:48:08 +00:00
if-options.c Fix processing of hex and octal strings. 2016-08-24 19:32:41 +00:00
if-options.h Add --inactive which makes all interfaces inactive on initial start. 2016-07-27 16:47:34 +00:00
if-sun.c recvmsg expects an array of iovec structures, not a pointer to the first one. 2016-09-05 22:27:47 +00:00
if.c When deactivating an interface, set the carrier to unknown as it's no longer being tracked. 2016-07-28 13:10:20 +00:00
if.h Add some commentary for ALIAS_ADDR remove and unused define. 2016-07-27 15:46:53 +00:00
ipv4.c Dodge more errors when deleting not available anymore. 2016-09-05 20:11:44 +00:00
ipv4.h Juggle #define ordering. 2016-07-27 03:54:22 +00:00
ipv4ll.c Check we have an assigned address when an ARP conflict occurs to avoid a NULL 2016-06-25 11:43:58 +00:00
ipv4ll.h Rework if_address to just use an ipv4_addr structure, similar to how 2016-05-18 16:23:28 +00:00
ipv6.c Remove the POLLADDR check out of if-bsd.c and into ipv6.c for other OS's 2016-09-06 10:43:49 +00:00
ipv6.h Fix more iovec to arrays. 2016-09-05 22:35:29 +00:00
ipv6nd.c Remove the need for statically sized receive buffers for IPv6 ND and DHCPv6 2016-09-02 11:34:09 +00:00
ipv6nd.h Simplify handling of IPv6 address from kernel messages, similar to IPv4. 2016-07-26 20:52:31 +00:00
Makefile Support buggy FreeBSD rc system out of the box. 2016-03-12 10:52:41 +00:00
Makefile.inc If CC is not defined, default it to cc 2014-02-28 20:32:34 +00:00
README Document --with-poll 2016-03-23 22:18:00 +00:00
script.c Rework if_address to just use an ipv4_addr structure, similar to how 2016-05-18 16:23:28 +00:00
script.h Bump copyright here as well. 2015-01-30 10:46:53 +00:00

dhcpcd - DHCP client daemon
Copyright (c) 2006-2016 Roy Marples <roy@marples.name>


Installation
------------
./configure; make; make install
man dhcpcd for command line options
man dhcpcd.conf for configuration options
man dhcpcd-run-hooks to learn how to hook scripts into dhcpcd events


Notes
-----
If you're cross compiling you may need set the platform if OS is different
from the host.
--target=sparc-sun-netbsd5.0

If you're building for an MMU-less system where fork() does not work, you
should ./configure --disable-fork.
This also puts the --no-background flag on and stops the --background flag
from working.

You can change the default dirs with these knobs.
For example, to satisfy FHS compliance you would do this:-
./configure --libexecdir=/lib/dhcpcd dbdir=/var/lib/dhcpcd

We now default to using -std=c99. For 64-bit linux, this always works, but
for 32-bit linux it requires either gnu99 or a patch to asm/types.h.
Most distros patch linux headers so this should work fine.
linux-2.6.24 finally ships with a working 32-bit header.
If your linux headers are older, or your distro hasn't patched them you can
set CSTD=gnu99 to work around this.

Some BSD systems do not allow the manipulation of automatically added subnet
routes. You can find discussion here:
    http://mail-index.netbsd.org/tech-net/2008/12/03/msg000896.html
BSD systems where this has been fixed or is known to work are:
    NetBSD-5.0
    FreeBSD-10.0

Some BSD systems protect against IPv6 NS/NA messages by ensuring that the
source address matches a prefix on the recieved by a RA message.
This is an error as the correct check is for on-link prefixes as the
kernel may not be handling RA itself.
BSD systems where this has been fixed or is known to work are:
    NetBSD-7.0
    OpenBSD-5.0
    patch submitted against FreeBSD-10.0

Some BSD systems do not announce IPv6 address flag changes, such as
IN6_IFF_TENTATIVE, IN6_IFF_DUPLICATED, etc. On these systems,
dhcpcd will poll a freshly added address until either IN6_IFF_TENTATIVE is
cleared or IN6_IFF_DUPLICATED is set and take action accordingly.
BSD systems where this has been fixed or is known to work are:
    NetBSD-7.0

OpenBSD will always add it's own link-local address if no link-local address
exists, because it doesn't check if the address we are adding is a link-local
address or not.

Some BSD systems do not announce cached neighbour route changes based
on reachability to userland. For such systems, IPv6 routers will always
be assumed to be reachable until they either stop being a router or expire.
BSD systems where this has been fixed or is known to work are:
    NetBSD-7.99.3

Linux prior to 3.17 won't allow userland to manage IPv6 temporary addresses.
Either upgrade or don't allow dhcpcd to manage the RA,
so don't set either "ipv6ra_own" or "slaac private" in dhcpcd.conf if you
want to have working IPv6 temporary addresses.
SLAAC private addresses are just as private, just stable.

ArchLinux presently sanitises all kernel headers to the latest version
regardless of the version for your CPU. As such, Arch presently ships a
3.12 kernel with 3.17 headers which claim that it suppors temporary address
management and no automatic prefix route generation, both of which are
obviously false. You will have to patch support either in the kernel or
out of the headers (or dhcpcd itself) to have correct operation.

We try and detect how dhcpcd should interact with system services at runtime.
If we cannot auto-detect how do to this, or it is wrong then
you can change this by passing shell commands to --serviceexists,
--servicecmd and optionally --servicestatus to ./configure or overriding
the service variables in a hook.

Some systems have /dev management systems and some of these like to rename
interfaces. As this system would listen in the same way as dhcpcd to new
interface arrivals, dhcpcd needs to listen to the /dev management sytem
instead of the kernel. However, if the /dev management system breaks, stops
working, or changes to a new one, dhcpcd should still try and continue to work.
To facilitate this, dhcpcd allows a plugin to load to instruct dhcpcd when it
can use an interface. As of the time of writing only udev support is included.
You can disable this with --without-dev, or without-udev.
NOTE: in Gentoo at least, sys-fs/udev as provided by systemd leaks memory
sys-fs/eudev, the fork of udev does not and as such is recommended.

To shrink dhcpcd you can disable IPv4 or IPv6:
	--disable-inet
	--disable-inet6

You can also move the embedded extended configuration from the dhcpcd binary
to an external file (LIBEXECDIR/dhcpcd-definitions.conf)
	--disable-embedded
If dhcpcd cannot load this file at runtime, dhcpcd will work but will not be
able to decode any DHCP/DHCPv6 options that are not defined by the user
in /etc/dhcpcd.conf.

dhcpcd uses eloop.c, which is a portable main event loop with timeouts and
signal handling. Unlike libevent and similar, it can be transplanted directly
within the application - the only caveat outside of POSIX calls is that
you provide queue.h based on a recent BSD (glibc sys/queue.h is not enough).
eloop supports the following polling mechanisms, listed in order of preference:
	kqueue, epoll, pollts, ppoll and pselect.
If signal handling is disabled (ie in RTEMS or other single process
OS's) then eloop can use poll.
You can decide will polling mechanism dhcpcd will select in eloop like so
./configure --with-poll=[kqueue|epoll|pselect|pollts|ppoll]

To prepare dhcpcd for import into a platform source tree (like NetBSD)
you can use the make import target to create /tmp/dhcpcd-$version and
populate it with all the source files and hooks needed.
In this instance, you may wish to disable some configured tests when
the binary has to run on older versions which lack support, such as getline.
./configure --without-getline

Building for distribution (ie making a dhcpcd source tarball) now requires
gmake-4 or any BSD make.


Hooks
-----
Not all the hooks in dhcpcd-hooks are installed by default.
By default we install 01-test, 02-dump, 10-mtu, 20-resolv.conf and 30-hostname.
The other hooks, 10-wpa_supplicant, 15-timezone, 29-lookup-hostname
are installed to $(datadir)/dhcpcd/hooks by default and need to be
copied to $(libexecdir)/dhcpcd-hooks for use.
The configure program attempts to find hooks for systems you have installed.
To add more simply
./configure -with-hook=ntp.conf

Some system services expose the name of the service we are in,
by default dhcpcd will pick RC_SVCNAME from the environment.
You can override this in CPPFLAGS+= -DRC_SVCNAME="YOUR_SVCNAME".
This is important because dhcpcd will scrub the environment aside from $PATH
before running hooks.
This variable could be used to facilitate service re-entry so this chain could
happen in a custom OS hook:
  dhcpcd service marked inactive && dhcpcd service starts
  dependant services are not started because dhcpcd is inactive (not stopped)
  dhcpcd hook tests if $if_up = true and $af_waiting is empty or unset.
  if true, mark the dhcpcd service as started and then start dependencies
  if false and the dhcpcd service was previously started, mark as inactive and
     stop any dependant services.


Compatibility
-------------
dhcpcd-5.0 is only fully command line compatible with dhcpcd-4.0
For compatibility with older versions, use dhcpcd-4.0


ChangeLog
---------
We no longer supply a ChangeLog.
However, you're more than welcome to read the commit log at
http://roy.marples.name/projects/dhcpcd/timeline/