Go to file
2014-12-20 14:11:38 +00:00
compat Use __restrict rather than restrict. 2014-12-20 12:15:07 +00:00
crypt Fix import so that matching system vs local headers are not imported. 2014-07-30 10:58:20 +00:00
dev We changed this file in 2014 2014-03-06 09:44:00 +00:00
dhcpcd-hooks If neither dig nor host are present fall back to getent. 2014-12-04 13:45:24 +00:00
test Fix dependency and test targets 2014-07-31 00:57:47 +00:00
arp.c Zero length UDP packets are not an error condition on the socket. 2014-11-25 20:40:00 +00:00
arp.h Fix build without INET 2014-12-18 11:47:09 +00:00
auth.c TAILQ is now inlcuded via config.h either via sys/queue.h or compat/queue.h. 2014-11-10 16:56:32 +00:00
auth.h TAILQ is now inlcuded via config.h either via sys/queue.h or compat/queue.h. 2014-11-10 16:56:32 +00:00
bpf-filter.h Move the bpf filter len to a define. 2014-04-01 10:17:09 +00:00
common.c Remove the direct include for cdefs.h - it's not needed for supported 2014-11-10 17:30:29 +00:00
common.h be32enc is missing on OpenBSD, so provide a configure test. 2014-06-05 13:53:20 +00:00
config-null.mk Compile embedded in without a config 2014-04-23 19:09:03 +00:00
configure Fix compile on QNX. Thanks to Will Miles. 2014-12-20 14:11:38 +00:00
control.c Free control memory on fork 2014-10-04 08:22:09 +00:00
control.h Fix FD_LISTEN | FD_UNPRIV flags 2014-09-15 22:50:44 +00:00
defs.h Release dhcpcd-6.6.7 2014-12-19 10:45:45 +00:00
dev.c Improve the dev API a little. 2014-10-04 08:26:15 +00:00
dev.h Fix compile on BSD. 2014-10-04 10:19:00 +00:00
dhcp6.c Store acquired time for each IPv6 address so we can correctly offset 2014-12-16 20:20:01 +00:00
dhcp6.h Allow the same IP address to be leased for different interfaces. 2014-10-09 18:59:30 +00:00
dhcp-common.c The decode and print functions should not including the trailing NUL 2014-10-02 13:21:29 +00:00
dhcp-common.h Remove vis based encoding - instead expand the DHCP option encoding to a 2014-10-01 18:32:03 +00:00
dhcp.c A server should not NAK an INFORM. 2014-12-12 21:52:16 +00:00
dhcp.h Fix transition from IPv4LL to a valid DHCP state. 2014-10-24 09:14:16 +00:00
dhcpcd-definitions.conf Remove vis based encoding - instead expand the DHCP option encoding to a 2014-10-01 18:32:03 +00:00
dhcpcd-embedded.c.in Source now compiles on Solaris, just missing the if-sun.c support so 2014-05-21 23:07:52 +00:00
dhcpcd-embedded.h.in We changed these files in 2014 2014-01-14 14:42:00 +00:00
dhcpcd-run-hooks.8.in Wrong month, duh. 2014-10-03 18:29:08 +00:00
dhcpcd-run-hooks.in If STOPPED, set if_down = true when releasing, otherwise false. 2014-11-28 15:18:09 +00:00
dhcpcd.8.in Clarify timeout and reboot timeout, make it more sane. 2014-12-12 21:51:48 +00:00
dhcpcd.c Guard against failure in if_discover. Thanks to Will Miles. 2014-12-20 14:09:26 +00:00
dhcpcd.conf Add a sample controlgroup directive to dhcpcd.conf to make setup easier. 2014-09-05 14:14:28 +00:00
dhcpcd.conf.5.in The noalias directive will now remove any IPv4 addresses existing on 2014-12-13 13:35:18 +00:00
dhcpcd.h If allowinterfaces is not specified, allow all configured interfaces 2014-11-18 12:06:08 +00:00
duid.c Move net.c to if.c. 2014-04-25 10:42:37 +00:00
duid.h Move net.c to if.c. 2014-04-25 10:42:37 +00:00
eloop.c eloop queue 0 is all queues, respect it. 2014-11-10 19:22:43 +00:00
eloop.h Punt this now un-used function eloop_q_timeouts_delete 2014-09-13 14:55:55 +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 Remove hard coded DHCP/DHCPv6 options and then to dhcpcd-definitions.conf 2013-12-02 16:42:09 +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 For BSD systems stop polling for IPv6 router reachability. 2014-12-16 13:25:40 +00:00
if-linux-wext.c Spelling 2014-12-10 22:39:50 +00:00
if-linux.c Loopback interfaces have routes scoped to the host only. 2014-11-18 10:55:44 +00:00
if-options.c If allowinterfaces is not specified, allow all configured interfaces 2014-11-18 12:06:08 +00:00
if-options.h Whitespace 2014-11-24 10:54:46 +00:00
if-sun.c For BSD systems stop polling for IPv6 router reachability. 2014-12-16 13:25:40 +00:00
if.c Fix compile on QNX. Thanks to Will Miles. 2014-12-20 14:11:38 +00:00
if.h For BSD systems stop polling for IPv6 router reachability. 2014-12-16 13:25:40 +00:00
ipv4.c The noalias directive will now remove any IPv4 addresses existing on 2014-12-13 13:35:18 +00:00
ipv4.h Flags fake routes so we can change them when we renew our lease. 2014-11-26 10:41:32 +00:00
ipv4ll.c Add a guard to IPv4LL probed in case of an ARP race. 2014-11-14 07:16:49 +00:00
ipv4ll.h When closing the IPv4LL state, close any timers as well. 2014-11-11 09:17:06 +00:00
ipv6.c Fix compile on QNX. Thanks to Will Miles. 2014-12-20 14:11:38 +00:00
ipv6.h Attempt to define CMSG_SPACE for systems which lack it, like QNX. 2014-12-20 11:56:27 +00:00
ipv6nd.c Store acquired time for each IPv6 address so we can correctly offset 2014-12-16 20:20:01 +00:00
ipv6nd.h For BSD systems stop polling for IPv6 router reachability. 2014-12-16 13:25:40 +00:00
Makefile Remove RCSIDs from dhcpcd, they belong in the upstream project only. 2014-11-07 20:56:47 +00:00
Makefile.inc If CC is not defined, default it to cc 2014-02-28 20:32:34 +00:00
README Document some BSD systems lacking the ability to announce IPv6 address flag changes. 2014-12-16 22:12:16 +00:00
script.c Fix prior patch 2014-11-28 15:20:01 +00:00
script.h Implement a send queue for each control fd. 2014-09-05 12:28:05 +00:00

dhcpcd - DHCP client daemon
Copyright (c) 2006-2014 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

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

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

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.

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, 10-wpa_supplicant,
15-timezone, 20-resolv.conf, 29-lookup-hostname and 30-hostname.
The default dhcpcd.conf disables the lookup-hostname hook by default.
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_oneup && $if_ipwaited
  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/