blob: 5224adf8e33c912d49394b77d31809a9725c7ebd [file] [log] [blame]
Simon Kelley61744352013-01-31 14:34:40 +00001/* dnsmasq is Copyright (c) 2000-2013 Simon Kelley
Simon Kelley9e4abcb2004-01-22 19:47:41 +00002
3 This program is free software; you can redistribute it and/or modify
4 it under the terms of the GNU General Public License as published by
Simon Kelley824af852008-02-12 20:43:05 +00005 the Free Software Foundation; version 2 dated June, 1991, or
6 (at your option) version 3 dated 29 June, 2007.
7
Simon Kelley9e4abcb2004-01-22 19:47:41 +00008 This program is distributed in the hope that it will be useful,
9 but WITHOUT ANY WARRANTY; without even the implied warranty of
10 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 GNU General Public License for more details.
Simon Kelley824af852008-02-12 20:43:05 +000012
Simon Kelley73a08a22009-02-05 20:28:08 +000013 You should have received a copy of the GNU General Public License
14 along with this program. If not, see <http://www.gnu.org/licenses/>.
Simon Kelley9e4abcb2004-01-22 19:47:41 +000015*/
16
Simon Kelley208b65c2006-08-05 21:41:37 +010017#define FTABSIZ 150 /* max number of outstanding requests (default) */
Simon Kelleyfeba5c12004-07-27 20:28:58 +010018#define MAX_PROCS 20 /* max no children for TCP requests */
19#define CHILD_LIFETIME 150 /* secs 'till terminated (RFC1035 suggests > 120s) */
Simon Kelley316e2732010-01-22 20:16:09 +000020#define EDNS_PKTSZ 4096 /* default max EDNS.0 UDP packet from RFC5625 */
Simon Kelley7b4ad2e2012-04-04 14:05:35 +010021#define KEYBLOCK_LEN 140 /* choose to mininise fragmentation when storing DNSSEC keys */
Simon Kelley16972692006-10-16 20:04:18 +010022#define TIMEOUT 10 /* drop UDP queries after TIMEOUT seconds */
Simon Kelley1f15b812009-10-13 17:49:32 +010023#define FORWARD_TEST 50 /* try all servers every 50 queries */
Simon Kelley28866e92011-02-14 20:19:14 +000024#define FORWARD_TIME 20 /* or 20 seconds */
Simon Kelley1a6bca82008-07-11 11:11:42 +010025#define RANDOM_SOCKS 64 /* max simultaneous random ports */
Simon Kelleycdeda282006-03-16 20:16:06 +000026#define LEASE_RETRY 60 /* on error, retry writing leasefile after LEASE_RETRY seconds */
Simon Kelley9e4abcb2004-01-22 19:47:41 +000027#define CACHESIZ 150 /* default cache size */
Simon Kelley316e2732010-01-22 20:16:09 +000028#define MAXLEASES 1000 /* maximum number of DHCP leases */
Simon Kelley5e9e0ef2006-04-17 14:24:29 +010029#define PING_WAIT 3 /* wait for ping address-in-use test */
30#define PING_CACHE_TIME 30 /* Ping test assumed to be valid this long. */
Simon Kelley849a8352006-06-09 21:02:31 +010031#define DECLINE_BACKOFF 600 /* disable DECLINEd static addresses for this long */
Simon Kelley5e9e0ef2006-04-17 14:24:29 +010032#define DHCP_PACKET_MAX 16384 /* hard limit on DHCP packet size */
Simon Kelley9e4abcb2004-01-22 19:47:41 +000033#define SMALLDNAME 40 /* most domain names are smaller than this */
Simon Kelley9e4abcb2004-01-22 19:47:41 +000034#define HOSTSFILE "/etc/hosts"
Simon Kelley44a2a312004-03-10 20:04:35 +000035#define ETHERSFILE "/etc/ethers"
Simon Kelleyc72daea2012-01-05 21:33:27 +000036#define DEFLEASE 3600 /* default lease time, 1 hour */
37#define CHUSER "nobody"
38#define CHGRP "dip"
39#define TFTP_MAX_CONNECTIONS 50 /* max simultaneous connections */
40#define LOG_MAX 5 /* log-queue length */
41#define RANDFILE "/dev/urandom"
42#define EDNS0_OPTION_MAC 5 /* dyndns.org temporary assignment */
Simon Kelleyad094272012-08-10 17:10:54 +010043#define DNSMASQ_SERVICE "uk.org.thekelleys.dnsmasq" /* Default - may be overridden by config */
Simon Kelleyc72daea2012-01-05 21:33:27 +000044#define DNSMASQ_PATH "/uk/org/thekelleys/dnsmasq"
Simon Kelley4f7b3042012-11-28 21:27:02 +000045#define AUTH_TTL 600 /* default TTL for auth DNS */
46#define SOA_REFRESH 1200 /* SOA refresh default */
47#define SOA_RETRY 180 /* SOA retry default */
48#define SOA_EXPIRY 1209600 /* SOA expiry default */
Simon Kelley55b548a2012-12-29 17:13:04 +000049#define RA_INTERVAL 600 /* Send unsolicited RA's this often when not provoked. */
Simon Kelley4f7b3042012-11-28 21:27:02 +000050
Simon Kelleyc72daea2012-01-05 21:33:27 +000051/* compile-time options: uncomment below to enable or do eg.
52 make COPTS=-DHAVE_BROKEN_RTC
53
54HAVE_BROKEN_RTC
55 define this on embedded systems which don't have an RTC
56 which keeps time over reboots. Causes dnsmasq to use uptime
57 for timing, and keep lease lengths rather than expiry times
58 in its leases file. This also make dnsmasq "flash disk friendly".
59 Normally, dnsmasq tries very hard to keep the on-disk leases file
60 up-to-date: rewriting it after every renewal. When HAVE_BROKEN_RTC
61 is in effect, the lease file is only written when a new lease is
62 created, or an old one destroyed. (Because those are the only times
63 it changes.) This vastly reduces the number of file writes, and makes
64 it viable to keep the lease file on a flash filesystem.
65 NOTE: when enabling or disabling this, be sure to delete any old
66 leases file, otherwise dnsmasq may get very confused.
67
68HAVE_TFTP
69 define this to get dnsmasq's built-in TFTP server.
70
71HAVE_DHCP
72 define this to get dnsmasq's DHCPv4 server.
73
74HAVE_DHCP6
75 define this to get dnsmasq's DHCPv6 server. (implies HAVE_DHCP).
76
77HAVE_SCRIPT
78 define this to get the ability to call scripts on lease-change.
79
80HAVE_LUASCRIPT
81 define this to get the ability to call Lua script on lease-change. (implies HAVE_SCRIPT)
82
83HAVE_DBUS
84 define this if you want to link against libdbus, and have dnsmasq
85 support some methods to allow (re)configuration of the upstream DNS
86 servers via DBus.
87
88HAVE_IDN
89 define this if you want international domain name support.
90 NOTE: for backwards compatibility, IDN support is automatically
91 included when internationalisation support is built, using the
92 *-i18n makefile targets, even if HAVE_IDN is not explicitly set.
93
94HAVE_CONNTRACK
95 define this to include code which propogates conntrack marks from
96 incoming DNS queries to the corresponding upstream queries. This adds
97 a build-dependency on libnetfilter_conntrack, but the resulting binary will
98 still run happily on a kernel without conntrack support.
99
Jason A. Donenfeld13d86c72013-02-22 18:20:53 +0000100HAVE_IPSET
101 define this to include the ability to selectively add resolved ip addresses
102 to given ipsets.
103
Simon Kelley4820dce2012-12-18 18:30:30 +0000104HAVE_AUTH
105 define this to include the facility to act as an authoritative DNS
106 server for one or more zones.
107
108
Simon Kelleyc72daea2012-01-05 21:33:27 +0000109NO_IPV6
110NO_TFTP
111NO_DHCP
112NO_DHCP6
113NO_SCRIPT
114NO_LARGEFILE
Simon Kelley4820dce2012-12-18 18:30:30 +0000115NO_AUTH
Simon Kelleyc72daea2012-01-05 21:33:27 +0000116 these are avilable to explictly disable compile time options which would
117 otherwise be enabled automatically (HAVE_IPV6, >2Gb file sizes) or
118 which are enabled by default in the distributed source tree. Building dnsmasq
119 with something like "make COPTS=-DNO_SCRIPT" will do the trick.
120
121LEASEFILE
122CONFFILE
123RESOLVFILE
124 the default locations of these files are determined below, but may be overridden
125 in a build command line using COPTS.
126
127*/
128
129
130/* The default set of options to build. Built with these options, dnsmasq
131 has no library dependencies other than libc */
132
133#define HAVE_DHCP
Simon Kelley07933802012-02-14 20:55:25 +0000134#define HAVE_DHCP6
Simon Kelleyc72daea2012-01-05 21:33:27 +0000135#define HAVE_TFTP
136#define HAVE_SCRIPT
Simon Kelley4820dce2012-12-18 18:30:30 +0000137#define HAVE_AUTH
Simon Kelley3ddad242013-03-21 17:56:06 +0000138#define HAVE_IPSET
Simon Kelleyc72daea2012-01-05 21:33:27 +0000139/* #define HAVE_LUASCRIPT */
140/* #define HAVE_BROKEN_RTC */
141/* #define HAVE_DBUS */
142/* #define HAVE_IDN */
143/* #define HAVE_CONNTRACK */
Simon Kelleyc72daea2012-01-05 21:33:27 +0000144
145
146/* Default locations for important system files. */
Simon Kelley73a08a22009-02-05 20:28:08 +0000147
148#ifndef LEASEFILE
149# if defined(__FreeBSD__) || defined (__OpenBSD__) || defined(__DragonFly__) || defined(__NetBSD__)
150# define LEASEFILE "/var/db/dnsmasq.leases"
151# elif defined(__sun__) || defined (__sun)
152# define LEASEFILE "/var/cache/dnsmasq.leases"
Simon Kelley572b41e2011-02-18 18:11:18 +0000153# elif defined(__ANDROID__)
154# define LEASEFILE "/data/misc/dhcp/dnsmasq.leases"
Simon Kelley73a08a22009-02-05 20:28:08 +0000155# else
156# define LEASEFILE "/var/lib/misc/dnsmasq.leases"
157# endif
Simon Kelleyfeba5c12004-07-27 20:28:58 +0100158#endif
Simon Kelley73a08a22009-02-05 20:28:08 +0000159
160#ifndef CONFFILE
161# if defined(__FreeBSD__)
162# define CONFFILE "/usr/local/etc/dnsmasq.conf"
163# else
164# define CONFFILE "/etc/dnsmasq.conf"
165# endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000166#endif
Simon Kelley73a08a22009-02-05 20:28:08 +0000167
Simon Kelleyc72daea2012-01-05 21:33:27 +0000168#ifndef RESOLVFILE
169# if defined(__uClinux__)
170# define RESOLVFILE "/etc/config/resolv.conf"
171# else
172# define RESOLVFILE "/etc/resolv.conf"
173# endif
174#endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000175
Simon Kelley55d290a2012-06-29 20:58:32 +0100176#ifndef RUNFILE
177# if defined(__ANDROID__)
178# define RUNFILE "/data/dnsmasq.pid"
179# else
180# define RUNFILE "/var/run/dnsmasq.pid"
181# endif
182#endif
Simon Kelleyc72daea2012-01-05 21:33:27 +0000183
184/* platform dependent options: these are determined automatically below
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000185
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100186HAVE_LINUX_NETWORK
Simon Kelley824af852008-02-12 20:43:05 +0000187HAVE_BSD_NETWORK
188HAVE_SOLARIS_NETWORK
189 define exactly one of these to alter interaction with kernel networking.
190
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000191HAVE_GETOPT_LONG
Simon Kelleyda632e72012-03-26 11:14:05 +0100192 defined when GNU-style getopt_long available.
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000193
194HAVE_ARC4RANDOM
Simon Kelleyc72daea2012-01-05 21:33:27 +0000195 defined if arc4random() available to get better security from DNS spoofs
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000196 by using really random ids (OpenBSD)
197
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000198HAVE_SOCKADDR_SA_LEN
Simon Kelleyc72daea2012-01-05 21:33:27 +0000199 defined if struct sockaddr has sa_len field (*BSD)
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000200*/
201
202/* Must preceed __linux__ since uClinux defines __linux__ too. */
Simon Kelleye17fb622006-01-14 20:33:46 +0000203#if defined(__uClinux__)
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100204#define HAVE_LINUX_NETWORK
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000205#define HAVE_GETOPT_LONG
206#undef HAVE_ARC4RANDOM
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000207#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley59353a62004-11-21 19:34:28 +0000208/* Never use fork() on uClinux. Note that this is subtly different from the
209 --keep-in-foreground option, since it also suppresses forking new
Simon Kelley5aabfc72007-08-29 11:24:47 +0100210 processes for TCP connections and disables the call-a-script on leasechange
211 system. It's intended for use on MMU-less kernels. */
Simon Kelleye17fb622006-01-14 20:33:46 +0000212#define NO_FORK
213
214#elif defined(__UCLIBC__)
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100215#define HAVE_LINUX_NETWORK
Simon Kelleye17fb622006-01-14 20:33:46 +0000216#if defined(__UCLIBC_HAS_GNU_GETOPT__) || \
217 ((__UCLIBC_MAJOR__==0) && (__UCLIBC_MINOR__==9) && (__UCLIBC_SUBLEVEL__<21))
218# define HAVE_GETOPT_LONG
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100219#endif
Simon Kelleye17fb622006-01-14 20:33:46 +0000220#undef HAVE_ARC4RANDOM
Simon Kelleye17fb622006-01-14 20:33:46 +0000221#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley7cebd202006-05-06 14:13:33 +0100222#if !defined(__ARCH_HAS_MMU__) && !defined(__UCLIBC_HAS_MMU__)
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000223# define NO_FORK
224#endif
Simon Kelley7cebd202006-05-06 14:13:33 +0100225#if defined(__UCLIBC_HAS_IPV6__)
226# ifndef IPV6_V6ONLY
227# define IPV6_V6ONLY 26
228# endif
Simon Kelleye17fb622006-01-14 20:33:46 +0000229#endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000230
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000231/* This is for glibc 2.x */
232#elif defined(__linux__)
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100233#define HAVE_LINUX_NETWORK
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000234#define HAVE_GETOPT_LONG
235#undef HAVE_ARC4RANDOM
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000236#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000237
Simon Kelley9e038942008-05-30 20:06:34 +0100238#elif defined(__FreeBSD__) || \
239 defined(__OpenBSD__) || \
240 defined(__DragonFly__) || \
Simon Kelley8ef5ada2010-06-03 19:42:45 +0100241 defined(__FreeBSD_kernel__)
Simon Kelley824af852008-02-12 20:43:05 +0000242#define HAVE_BSD_NETWORK
Simon Kelley59353a62004-11-21 19:34:28 +0000243/* Later verions of FreeBSD have getopt_long() */
244#if defined(optional_argument) && defined(required_argument)
245# define HAVE_GETOPT_LONG
Simon Kelley59353a62004-11-21 19:34:28 +0000246#endif
Simon Kelley8ef5ada2010-06-03 19:42:45 +0100247#if !defined(__FreeBSD_kernel__)
Simon Kelley1a6bca82008-07-11 11:11:42 +0100248# define HAVE_ARC4RANDOM
249#endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000250#define HAVE_SOCKADDR_SA_LEN
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000251
252#elif defined(__APPLE__)
Simon Kelley824af852008-02-12 20:43:05 +0000253#define HAVE_BSD_NETWORK
Simon Kelley316e2732010-01-22 20:16:09 +0000254#define HAVE_GETOPT_LONG
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000255#define HAVE_ARC4RANDOM
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000256#define HAVE_SOCKADDR_SA_LEN
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000257/* Define before sys/socket.h is included so we get socklen_t */
258#define _BSD_SOCKLEN_T_
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000259
260#elif defined(__NetBSD__)
Simon Kelley824af852008-02-12 20:43:05 +0000261#define HAVE_BSD_NETWORK
Simon Kelleyfd9fa482004-10-21 20:24:00 +0100262#define HAVE_GETOPT_LONG
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000263#undef HAVE_ARC4RANDOM
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000264#define HAVE_SOCKADDR_SA_LEN
Simon Kelley824af852008-02-12 20:43:05 +0000265
266#elif defined(__sun) || defined(__sun__)
267#define HAVE_SOLARIS_NETWORK
Simon Kelley7622fc02009-06-04 20:32:05 +0100268#define HAVE_GETOPT_LONG
Simon Kelley824af852008-02-12 20:43:05 +0000269#undef HAVE_ARC4RANDOM
Simon Kelley824af852008-02-12 20:43:05 +0000270#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley7622fc02009-06-04 20:32:05 +0100271#define ETHER_ADDR_LEN 6
272
Simon Kelley824af852008-02-12 20:43:05 +0000273#endif
274
Simon Kelleye17fb622006-01-14 20:33:46 +0000275/* Decide if we're going to support IPv6 */
276/* We assume that systems which don't have IPv6
277 headers don't have ntop and pton either */
278
Simon Kelleyc72daea2012-01-05 21:33:27 +0000279#if defined(INET6_ADDRSTRLEN) && defined(IPV6_V6ONLY)
Simon Kelleye17fb622006-01-14 20:33:46 +0000280# define HAVE_IPV6
281# define ADDRSTRLEN INET6_ADDRSTRLEN
Simon Kelleyb5a7ff42013-04-25 11:03:47 +0100282#else
283# if !defined(INET_ADDRSTRLEN)
284# define INET_ADDRSTRLEN 16 /* 4*3 + 3 dots + NULL */
285# endif
Simon Kelleye17fb622006-01-14 20:33:46 +0000286# undef HAVE_IPV6
287# define ADDRSTRLEN INET_ADDRSTRLEN
Simon Kelleye17fb622006-01-14 20:33:46 +0000288#endif
289
Simon Kelleyc72daea2012-01-05 21:33:27 +0000290
291/* rules to implement compile-time option dependencies and
292 the NO_XXX flags */
293
294#ifdef NO_IPV6
295#undef HAVE_IPV6
Simon Kelley1f15b812009-10-13 17:49:32 +0100296#endif
297
Simon Kelleyc72daea2012-01-05 21:33:27 +0000298#ifdef NO_TFTP
299#undef HAVE_TFTP
300#endif
301
302#ifdef NO_DHCP
303#undef HAVE_DHCP
304#undef HAVE_DHCP6
305#endif
306
307#if defined(NO_DHCP6) || !defined(HAVE_IPV6)
308#undef HAVE_DHCP6
309#endif
310
311/* DHCP6 needs DHCP too */
312#ifdef HAVE_DHCP6
313#define HAVE_DHCP
314#endif
315
316#if defined(NO_SCRIPT) || !defined(HAVE_DHCP) || defined(NO_FORK)
317#undef HAVE_SCRIPT
318#undef HAVE_LUASCRIPT
319#endif
320
321/* Must HAVE_SCRIPT to HAVE_LUASCRIPT */
322#ifdef HAVE_LUASCRIPT
323#define HAVE_SCRIPT
324#endif
325
Simon Kelley4820dce2012-12-18 18:30:30 +0000326#ifdef NO_AUTH
327#undef HAVE_AUTH
328#endif
Simon Kelleyc72daea2012-01-05 21:33:27 +0000329
Simon Kelley3ddad242013-03-21 17:56:06 +0000330#if defined(NO_IPSET) || !defined(HAVE_LINUX_NETWORK)
Jason A. Donenfeld13d86c72013-02-22 18:20:53 +0000331#undef HAVE_IPSET
332#endif
333
Simon Kelleyc72daea2012-01-05 21:33:27 +0000334/* Define a string indicating which options are in use.
335 DNSMASQP_COMPILE_OPTS is only defined in dnsmasq.c */
336
337#ifdef DNSMASQ_COMPILE_OPTS
338
339static char *compile_opts =
340#ifndef HAVE_IPV6
341"no-"
342#endif
343"IPv6 "
344#ifndef HAVE_GETOPT_LONG
345"no-"
346#endif
347"GNU-getopt "
348#ifdef HAVE_BROKEN_RTC
349"no-RTC "
350#endif
351#ifdef NO_FORK
352"no-MMU "
353#endif
354#ifndef HAVE_DBUS
355"no-"
356#endif
357"DBus "
358#ifndef LOCALEDIR
359"no-"
360#endif
361"i18n "
362#if !defined(LOCALEDIR) && !defined(HAVE_IDN)
363"no-"
364#endif
365"IDN "
366#ifndef HAVE_DHCP
367"no-"
368#endif
369"DHCP "
370#if defined(HAVE_DHCP)
371# if !defined (HAVE_DHCP6)
372 "no-"
373# endif
374 "DHCPv6 "
375# if !defined(HAVE_SCRIPT)
376 "no-scripts "
377# else
378# if !defined(HAVE_LUASCRIPT)
379 "no-"
380# endif
381 "Lua "
382# endif
383#endif
384#ifndef HAVE_TFTP
385"no-"
386#endif
387"TFTP "
388#ifndef HAVE_CONNTRACK
389"no-"
390#endif
Simon Kelley4820dce2012-12-18 18:30:30 +0000391"conntrack "
Jason A. Donenfeld13d86c72013-02-22 18:20:53 +0000392#ifndef HAVE_IPSET
393"no-"
394#endif
395"ipset "
Simon Kelley4820dce2012-12-18 18:30:30 +0000396#ifndef HAVE_AUTH
397"no-"
398#endif
399 "auth";
Simon Kelleyc72daea2012-01-05 21:33:27 +0000400
401#endif
402
403
404