blob: df1258aafa44bea56247c3c4917ed0c99c6149bc [file] [log] [blame]
Russ Dill61fb4892002-10-14 21:41:28 +00001# Sample udhcpd configuration file (/etc/udhcpd.conf)
Denys Vlasenko2b0e9572009-06-17 13:22:26 +02002# Values shown are defaults
Russ Dill61fb4892002-10-14 21:41:28 +00003
4# The start and end of the IP lease block
Denys Vlasenko2b0e9572009-06-17 13:22:26 +02005start 192.168.0.20
6end 192.168.0.254
Russ Dill61fb4892002-10-14 21:41:28 +00007
8# The interface that udhcpd will use
Denys Vlasenko2b0e9572009-06-17 13:22:26 +02009interface eth0
Russ Dill61fb4892002-10-14 21:41:28 +000010
Denys Vlasenko777706c2010-03-19 23:42:23 +010011# The maximum number of leases (includes addresses reserved
12# by OFFER's, DECLINE's, and ARP conflicts). Will be corrected
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020013# if it's bigger than IP lease block, but it ok to make it
14# smaller than lease block.
15#max_leases 254
Russ Dill61fb4892002-10-14 21:41:28 +000016
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020017# The amount of time that an IP will be reserved (leased to nobody)
Denys Vlasenko87fa2162010-03-20 18:06:23 +010018# if a DHCP decline message is received (seconds)
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020019#decline_time 3600
Russ Dill61fb4892002-10-14 21:41:28 +000020
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020021# The amount of time that an IP will be reserved
Denys Vlasenko87fa2162010-03-20 18:06:23 +010022# if an ARP conflict occurs (seconds)
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020023#conflict_time 3600
Russ Dill61fb4892002-10-14 21:41:28 +000024
Denys Vlasenko87fa2162010-03-20 18:06:23 +010025# How long an offered address is reserved (seconds)
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020026#offer_time 60
Russ Dill61fb4892002-10-14 21:41:28 +000027
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020028# If client asks for lease below this value, it will be rounded up
Denys Vlasenko87fa2162010-03-20 18:06:23 +010029# to this value (seconds)
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020030#min_lease 60
Russ Dill61fb4892002-10-14 21:41:28 +000031
Denys Vlasenko14b162f2011-05-04 21:17:23 +020032# The location of the pid file
33#pidfile /var/run/udhcpd.pid
34
Russ Dill61fb4892002-10-14 21:41:28 +000035# The location of the leases file
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020036#lease_file /var/lib/misc/udhcpd.leases
Russ Dill61fb4892002-10-14 21:41:28 +000037
Denys Vlasenko14b162f2011-05-04 21:17:23 +020038# The time period at which udhcpd will write out leases file.
39# If this is 0, udhcpd will never automatically write leases file.
40# Specified in seconds.
41#auto_time 7200
Russ Dill61fb4892002-10-14 21:41:28 +000042
Denys Vlasenko87fa2162010-03-20 18:06:23 +010043# Every time udhcpd writes a leases file, the below script will be called
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020044#notify_file # default: no script
45#notify_file dumpleases # useful for debugging
Russ Dill61fb4892002-10-14 21:41:28 +000046
Denys Vlasenkoa8408842019-05-16 11:18:49 +020047# The following are BOOTP specific options
Denys Vlasenko2e7aa922010-03-21 02:22:07 +010048# next server to use in bootstrap
49#siaddr 192.168.0.22 # default: 0.0.0.0 (none)
50# tftp server name
51#sname zorak # default: none
52# tftp file to download (e.g. kernel image)
53#boot_file /var/nfs_root # default: none
Russ Dill61fb4892002-10-14 21:41:28 +000054
Denys Vlasenkoa8408842019-05-16 11:18:49 +020055# NOTE: "boot_file FILE" and "opt bootfile FILE" are conceptually the same,
56# but "boot_file" goes into BOOTP-defined fixed-size field in the packet,
57# whereas "opt bootfile" goes into DHCP option 0x43.
58# Same for "sname HOST" and "opt tftp HOST".
59
Denys Vlasenko87fa2162010-03-20 18:06:23 +010060# Static leases map
61#static_lease 00:60:08:11:CE:4E 192.168.0.54
Denys Vlasenkoa8408842019-05-16 11:18:49 +020062#static_lease 00:60:08:11:CE:3E 192.168.0.44 optional_hostname
Denys Vlasenko87fa2162010-03-20 18:06:23 +010063
Denys Vlasenko777706c2010-03-19 23:42:23 +010064# The remainder of options are DHCP options and can be specified with the
Russ Dill61fb4892002-10-14 21:41:28 +000065# keyword 'opt' or 'option'. If an option can take multiple items, such
66# as the dns option, they can be listed on the same line, or multiple
Denys Vlasenko2e7aa922010-03-21 02:22:07 +010067# lines.
Denys Vlasenko2b0e9572009-06-17 13:22:26 +020068# Examples:
Russ Dill61fb4892002-10-14 21:41:28 +000069opt dns 192.168.10.2 192.168.10.10
70option subnet 255.255.255.0
71opt router 192.168.10.2
72opt wins 192.168.10.10
Denys Vlasenko777706c2010-03-19 23:42:23 +010073option dns 129.219.13.81 # appended to above DNS servers for a total of 3
Russ Dill61fb4892002-10-14 21:41:28 +000074option domain local
Denys Vlasenko2e7aa922010-03-21 02:22:07 +010075option lease 864000 # default: 10 days
Michael McTernan7b57ff42011-12-16 17:05:52 +010076option msstaticroutes 10.0.0.0/8 10.127.0.1 # single static route
77option staticroutes 10.0.0.0/8 10.127.0.1, 10.11.12.0/24 10.11.12.1
Denys Vlasenko266f6f12018-04-13 13:18:34 +020078# Arbitrary option in hex or string form:
Denys Vlasenko29034692010-04-04 15:38:22 +020079option 0x08 01020304 # option 8: "cookie server IP addr: 1.2.3.4"
Denys Vlasenko266f6f12018-04-13 13:18:34 +020080option 14 "dumpfile"
Russ Dill61fb4892002-10-14 21:41:28 +000081
Denys Vlasenkoedb74f42019-01-15 13:19:01 +010082# Currently supported options [hex option value] (for more info, see options.c):
83#opt lease NUM # [0x33]
84#opt subnet IP # [0x01]
85#opt broadcast IP # [0x1c]
86#opt router IP_LIST # [0x03]
87#opt ipttl NUM # [0x17]
88#opt mtu NUM # [0x1a]
89#opt hostname STRING # [0x0c] client's hostname
90#opt domain STRING # [0x0f] client's domain suffix
91#opt search STRING_LIST # [0x77] search domains
92#opt nisdomain STRING # [0x28]
93#opt timezone NUM # [0x02] (localtime - UTC_time) in seconds. signed
94#opt tftp STRING # [0x42] tftp server name
95#opt bootfile STRING # [0x43] tftp file to download (e.g. kernel image)
96#opt bootsize NUM # [0x0d] size of that file
97#opt rootpath STRING # [0x11] (NFS) path to mount as root fs
98#opt wpad STRING # [0xfc] Web Proxy Auto Discovery Protocol
99#opt serverid IP # [0x36] default: server's IP
100#opt message STRING # [0x38] error message (udhcpd sends it on success too)
101#opt vlanid NUM # [0x84] 802.1P VLAN ID
102#opt vlanpriority NUM # [0x85] 802.1Q VLAN priority
103# RFC 5071: PXELINUX Options
104#opt 0xd0 F100747E # [0xd0] magic
105#opt pxeconffile STRING # [0xd1]
106#opt pxepathprefix STRING # [0xd2]
107#opt reboottime NUM # [0xd3] bootstrap timeout
Denys Vlasenko0f62c4d2010-03-20 07:12:21 +0100108# Options specifying server(s)
Denys Vlasenkoedb74f42019-01-15 13:19:01 +0100109#opt dns IP_LIST # [0x06]
110#opt wins IP_LIST # [0x2c]
111#opt nissrv IP_LIST # [0x29]
112#opt ntpsrv IP_LIST # [0x2a]
113#opt lprsrv IP_LIST # [0x09]
114#opt swapsrv IP # [0x10]
Nigel Hathawayfb6b1732011-04-26 02:50:00 +0200115# Options specifying routes
Denys Vlasenkoedb74f42019-01-15 13:19:01 +0100116#opt routes IP_PAIR_LIST # [0x21]
117#opt staticroutes STATIC_ROUTES # [0x79] RFC 3442 classless static route option
118#opt msstaticroutes STATIC_ROUTES # [0xf9] same, using MS option number
Denys Vlasenkoe5ce91b2010-03-21 00:43:11 +0100119# Obsolete options, no longer supported
Denys Vlasenkoedb74f42019-01-15 13:19:01 +0100120#opt logsrv IP_LIST # [0x07] 704/UDP log server (not syslog!)
121#opt namesrv IP_LIST # [0x05] IEN 116 name server, obsolete (August 1979!!!)
122#opt cookiesrv IP_LIST # [0x08] RFC 865 "quote of the day" server, rarely (never?) used
123#opt timesrv IP_LIST # [0x04] RFC 868 time server, rarely (never?) used
Nigel Hathawayfb6b1732011-04-26 02:50:00 +0200124# TODO: in development
Denys Vlasenkoedb74f42019-01-15 13:19:01 +0100125#opt userclass STRING # [0x4d] RFC 3004. set of LASCII strings. "I am a printer" etc
126#opt sipsrv STRING LIST # [0x78] RFC 3361. flag byte, then: 0: domain names, 1: IP addrs
127#opt ip6rd .... # [0xd4] IPv6 rapid deployment