blob: 31fb1cc4f8d2f8803fb613852c1b3a24c630b191 [file] [log] [blame]
Simon Kelley59546082012-01-06 20:02:04 +00001/* dnsmasq is Copyright (c) 2000-2012 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 */
49
Simon Kelleyc72daea2012-01-05 21:33:27 +000050/* compile-time options: uncomment below to enable or do eg.
51 make COPTS=-DHAVE_BROKEN_RTC
52
53HAVE_BROKEN_RTC
54 define this on embedded systems which don't have an RTC
55 which keeps time over reboots. Causes dnsmasq to use uptime
56 for timing, and keep lease lengths rather than expiry times
57 in its leases file. This also make dnsmasq "flash disk friendly".
58 Normally, dnsmasq tries very hard to keep the on-disk leases file
59 up-to-date: rewriting it after every renewal. When HAVE_BROKEN_RTC
60 is in effect, the lease file is only written when a new lease is
61 created, or an old one destroyed. (Because those are the only times
62 it changes.) This vastly reduces the number of file writes, and makes
63 it viable to keep the lease file on a flash filesystem.
64 NOTE: when enabling or disabling this, be sure to delete any old
65 leases file, otherwise dnsmasq may get very confused.
66
67HAVE_TFTP
68 define this to get dnsmasq's built-in TFTP server.
69
70HAVE_DHCP
71 define this to get dnsmasq's DHCPv4 server.
72
73HAVE_DHCP6
74 define this to get dnsmasq's DHCPv6 server. (implies HAVE_DHCP).
75
76HAVE_SCRIPT
77 define this to get the ability to call scripts on lease-change.
78
79HAVE_LUASCRIPT
80 define this to get the ability to call Lua script on lease-change. (implies HAVE_SCRIPT)
81
82HAVE_DBUS
83 define this if you want to link against libdbus, and have dnsmasq
84 support some methods to allow (re)configuration of the upstream DNS
85 servers via DBus.
86
87HAVE_IDN
88 define this if you want international domain name support.
89 NOTE: for backwards compatibility, IDN support is automatically
90 included when internationalisation support is built, using the
91 *-i18n makefile targets, even if HAVE_IDN is not explicitly set.
92
93HAVE_CONNTRACK
94 define this to include code which propogates conntrack marks from
95 incoming DNS queries to the corresponding upstream queries. This adds
96 a build-dependency on libnetfilter_conntrack, but the resulting binary will
97 still run happily on a kernel without conntrack support.
98
99NO_IPV6
100NO_TFTP
101NO_DHCP
102NO_DHCP6
103NO_SCRIPT
104NO_LARGEFILE
105 these are avilable to explictly disable compile time options which would
106 otherwise be enabled automatically (HAVE_IPV6, >2Gb file sizes) or
107 which are enabled by default in the distributed source tree. Building dnsmasq
108 with something like "make COPTS=-DNO_SCRIPT" will do the trick.
109
110LEASEFILE
111CONFFILE
112RESOLVFILE
113 the default locations of these files are determined below, but may be overridden
114 in a build command line using COPTS.
115
116*/
117
118
119/* The default set of options to build. Built with these options, dnsmasq
120 has no library dependencies other than libc */
121
122#define HAVE_DHCP
Simon Kelley07933802012-02-14 20:55:25 +0000123#define HAVE_DHCP6
Simon Kelleyc72daea2012-01-05 21:33:27 +0000124#define HAVE_TFTP
125#define HAVE_SCRIPT
126/* #define HAVE_LUASCRIPT */
127/* #define HAVE_BROKEN_RTC */
128/* #define HAVE_DBUS */
129/* #define HAVE_IDN */
130/* #define HAVE_CONNTRACK */
131
132
133
134/* Default locations for important system files. */
Simon Kelley73a08a22009-02-05 20:28:08 +0000135
136#ifndef LEASEFILE
137# if defined(__FreeBSD__) || defined (__OpenBSD__) || defined(__DragonFly__) || defined(__NetBSD__)
138# define LEASEFILE "/var/db/dnsmasq.leases"
139# elif defined(__sun__) || defined (__sun)
140# define LEASEFILE "/var/cache/dnsmasq.leases"
Simon Kelley572b41e2011-02-18 18:11:18 +0000141# elif defined(__ANDROID__)
142# define LEASEFILE "/data/misc/dhcp/dnsmasq.leases"
Simon Kelley73a08a22009-02-05 20:28:08 +0000143# else
144# define LEASEFILE "/var/lib/misc/dnsmasq.leases"
145# endif
Simon Kelleyfeba5c12004-07-27 20:28:58 +0100146#endif
Simon Kelley73a08a22009-02-05 20:28:08 +0000147
148#ifndef CONFFILE
149# if defined(__FreeBSD__)
150# define CONFFILE "/usr/local/etc/dnsmasq.conf"
151# else
152# define CONFFILE "/etc/dnsmasq.conf"
153# endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000154#endif
Simon Kelley73a08a22009-02-05 20:28:08 +0000155
Simon Kelleyc72daea2012-01-05 21:33:27 +0000156#ifndef RESOLVFILE
157# if defined(__uClinux__)
158# define RESOLVFILE "/etc/config/resolv.conf"
159# else
160# define RESOLVFILE "/etc/resolv.conf"
161# endif
162#endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000163
Simon Kelley55d290a2012-06-29 20:58:32 +0100164#ifndef RUNFILE
165# if defined(__ANDROID__)
166# define RUNFILE "/data/dnsmasq.pid"
167# else
168# define RUNFILE "/var/run/dnsmasq.pid"
169# endif
170#endif
Simon Kelleyc72daea2012-01-05 21:33:27 +0000171
172/* platform dependent options: these are determined automatically below
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000173
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100174HAVE_LINUX_NETWORK
Simon Kelley824af852008-02-12 20:43:05 +0000175HAVE_BSD_NETWORK
176HAVE_SOLARIS_NETWORK
177 define exactly one of these to alter interaction with kernel networking.
178
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000179HAVE_GETOPT_LONG
Simon Kelleyda632e72012-03-26 11:14:05 +0100180 defined when GNU-style getopt_long available.
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000181
182HAVE_ARC4RANDOM
Simon Kelleyc72daea2012-01-05 21:33:27 +0000183 defined if arc4random() available to get better security from DNS spoofs
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000184 by using really random ids (OpenBSD)
185
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000186HAVE_SOCKADDR_SA_LEN
Simon Kelleyc72daea2012-01-05 21:33:27 +0000187 defined if struct sockaddr has sa_len field (*BSD)
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000188*/
189
190/* Must preceed __linux__ since uClinux defines __linux__ too. */
Simon Kelleye17fb622006-01-14 20:33:46 +0000191#if defined(__uClinux__)
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100192#define HAVE_LINUX_NETWORK
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000193#define HAVE_GETOPT_LONG
194#undef HAVE_ARC4RANDOM
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000195#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley59353a62004-11-21 19:34:28 +0000196/* Never use fork() on uClinux. Note that this is subtly different from the
197 --keep-in-foreground option, since it also suppresses forking new
Simon Kelley5aabfc72007-08-29 11:24:47 +0100198 processes for TCP connections and disables the call-a-script on leasechange
199 system. It's intended for use on MMU-less kernels. */
Simon Kelleye17fb622006-01-14 20:33:46 +0000200#define NO_FORK
201
202#elif defined(__UCLIBC__)
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100203#define HAVE_LINUX_NETWORK
Simon Kelleye17fb622006-01-14 20:33:46 +0000204#if defined(__UCLIBC_HAS_GNU_GETOPT__) || \
205 ((__UCLIBC_MAJOR__==0) && (__UCLIBC_MINOR__==9) && (__UCLIBC_SUBLEVEL__<21))
206# define HAVE_GETOPT_LONG
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100207#endif
Simon Kelleye17fb622006-01-14 20:33:46 +0000208#undef HAVE_ARC4RANDOM
Simon Kelleye17fb622006-01-14 20:33:46 +0000209#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley7cebd202006-05-06 14:13:33 +0100210#if !defined(__ARCH_HAS_MMU__) && !defined(__UCLIBC_HAS_MMU__)
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000211# define NO_FORK
212#endif
Simon Kelley7cebd202006-05-06 14:13:33 +0100213#if defined(__UCLIBC_HAS_IPV6__)
214# ifndef IPV6_V6ONLY
215# define IPV6_V6ONLY 26
216# endif
Simon Kelleye17fb622006-01-14 20:33:46 +0000217#endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000218
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000219/* This is for glibc 2.x */
220#elif defined(__linux__)
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100221#define HAVE_LINUX_NETWORK
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000222#define HAVE_GETOPT_LONG
223#undef HAVE_ARC4RANDOM
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000224#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000225
Simon Kelley9e038942008-05-30 20:06:34 +0100226#elif defined(__FreeBSD__) || \
227 defined(__OpenBSD__) || \
228 defined(__DragonFly__) || \
Simon Kelley8ef5ada2010-06-03 19:42:45 +0100229 defined(__FreeBSD_kernel__)
Simon Kelley824af852008-02-12 20:43:05 +0000230#define HAVE_BSD_NETWORK
Simon Kelley59353a62004-11-21 19:34:28 +0000231/* Later verions of FreeBSD have getopt_long() */
232#if defined(optional_argument) && defined(required_argument)
233# define HAVE_GETOPT_LONG
Simon Kelley59353a62004-11-21 19:34:28 +0000234#endif
Simon Kelley8ef5ada2010-06-03 19:42:45 +0100235#if !defined(__FreeBSD_kernel__)
Simon Kelley1a6bca82008-07-11 11:11:42 +0100236# define HAVE_ARC4RANDOM
237#endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000238#define HAVE_SOCKADDR_SA_LEN
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000239
240#elif defined(__APPLE__)
Simon Kelley824af852008-02-12 20:43:05 +0000241#define HAVE_BSD_NETWORK
Simon Kelley316e2732010-01-22 20:16:09 +0000242#define HAVE_GETOPT_LONG
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000243#define HAVE_ARC4RANDOM
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000244#define HAVE_SOCKADDR_SA_LEN
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000245/* Define before sys/socket.h is included so we get socklen_t */
246#define _BSD_SOCKLEN_T_
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000247
248#elif defined(__NetBSD__)
Simon Kelley824af852008-02-12 20:43:05 +0000249#define HAVE_BSD_NETWORK
Simon Kelleyfd9fa482004-10-21 20:24:00 +0100250#define HAVE_GETOPT_LONG
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000251#undef HAVE_ARC4RANDOM
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000252#define HAVE_SOCKADDR_SA_LEN
Simon Kelley824af852008-02-12 20:43:05 +0000253
254#elif defined(__sun) || defined(__sun__)
255#define HAVE_SOLARIS_NETWORK
Simon Kelley7622fc02009-06-04 20:32:05 +0100256#define HAVE_GETOPT_LONG
Simon Kelley824af852008-02-12 20:43:05 +0000257#undef HAVE_ARC4RANDOM
Simon Kelley824af852008-02-12 20:43:05 +0000258#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley7622fc02009-06-04 20:32:05 +0100259#define ETHER_ADDR_LEN 6
260
Simon Kelley824af852008-02-12 20:43:05 +0000261#endif
262
Simon Kelleye17fb622006-01-14 20:33:46 +0000263/* Decide if we're going to support IPv6 */
264/* We assume that systems which don't have IPv6
265 headers don't have ntop and pton either */
266
Simon Kelleyc72daea2012-01-05 21:33:27 +0000267#if defined(INET6_ADDRSTRLEN) && defined(IPV6_V6ONLY)
Simon Kelleye17fb622006-01-14 20:33:46 +0000268# define HAVE_IPV6
269# define ADDRSTRLEN INET6_ADDRSTRLEN
Simon Kelleye17fb622006-01-14 20:33:46 +0000270#elif defined(INET_ADDRSTRLEN)
271# undef HAVE_IPV6
272# define ADDRSTRLEN INET_ADDRSTRLEN
273#else
274# undef HAVE_IPV6
275# define ADDRSTRLEN 16 /* 4*3 + 3 dots + NULL */
276#endif
277
Simon Kelleyc72daea2012-01-05 21:33:27 +0000278
279/* rules to implement compile-time option dependencies and
280 the NO_XXX flags */
281
282#ifdef NO_IPV6
283#undef HAVE_IPV6
Simon Kelley1f15b812009-10-13 17:49:32 +0100284#endif
285
Simon Kelleyc72daea2012-01-05 21:33:27 +0000286#ifdef NO_TFTP
287#undef HAVE_TFTP
288#endif
289
290#ifdef NO_DHCP
291#undef HAVE_DHCP
292#undef HAVE_DHCP6
293#endif
294
295#if defined(NO_DHCP6) || !defined(HAVE_IPV6)
296#undef HAVE_DHCP6
297#endif
298
299/* DHCP6 needs DHCP too */
300#ifdef HAVE_DHCP6
301#define HAVE_DHCP
302#endif
303
304#if defined(NO_SCRIPT) || !defined(HAVE_DHCP) || defined(NO_FORK)
305#undef HAVE_SCRIPT
306#undef HAVE_LUASCRIPT
307#endif
308
309/* Must HAVE_SCRIPT to HAVE_LUASCRIPT */
310#ifdef HAVE_LUASCRIPT
311#define HAVE_SCRIPT
312#endif
313
314
315/* Define a string indicating which options are in use.
316 DNSMASQP_COMPILE_OPTS is only defined in dnsmasq.c */
317
318#ifdef DNSMASQ_COMPILE_OPTS
319
320static char *compile_opts =
321#ifndef HAVE_IPV6
322"no-"
323#endif
324"IPv6 "
325#ifndef HAVE_GETOPT_LONG
326"no-"
327#endif
328"GNU-getopt "
329#ifdef HAVE_BROKEN_RTC
330"no-RTC "
331#endif
332#ifdef NO_FORK
333"no-MMU "
334#endif
335#ifndef HAVE_DBUS
336"no-"
337#endif
338"DBus "
339#ifndef LOCALEDIR
340"no-"
341#endif
342"i18n "
343#if !defined(LOCALEDIR) && !defined(HAVE_IDN)
344"no-"
345#endif
346"IDN "
347#ifndef HAVE_DHCP
348"no-"
349#endif
350"DHCP "
351#if defined(HAVE_DHCP)
352# if !defined (HAVE_DHCP6)
353 "no-"
354# endif
355 "DHCPv6 "
356# if !defined(HAVE_SCRIPT)
357 "no-scripts "
358# else
359# if !defined(HAVE_LUASCRIPT)
360 "no-"
361# endif
362 "Lua "
363# endif
364#endif
365#ifndef HAVE_TFTP
366"no-"
367#endif
368"TFTP "
369#ifndef HAVE_CONNTRACK
370"no-"
371#endif
372"conntrack";
373
374#endif
375
376
377