blob: 80b154cedb5952e0f5c069e5ee5edf4f0bb5679d [file] [log] [blame]
Simon Kelleyc47e3ba2014-01-08 17:07:54 +00001/* dnsmasq is Copyright (c) 2000-2014 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"
Simon Kelleyad094272012-08-10 17:10:54 +010042#define DNSMASQ_SERVICE "uk.org.thekelleys.dnsmasq" /* Default - may be overridden by config */
Simon Kelleyc72daea2012-01-05 21:33:27 +000043#define DNSMASQ_PATH "/uk/org/thekelleys/dnsmasq"
Simon Kelley4f7b3042012-11-28 21:27:02 +000044#define AUTH_TTL 600 /* default TTL for auth DNS */
45#define SOA_REFRESH 1200 /* SOA refresh default */
46#define SOA_RETRY 180 /* SOA retry default */
47#define SOA_EXPIRY 1209600 /* SOA expiry default */
48
Simon Kelleyc72daea2012-01-05 21:33:27 +000049/* compile-time options: uncomment below to enable or do eg.
50 make COPTS=-DHAVE_BROKEN_RTC
51
52HAVE_BROKEN_RTC
53 define this on embedded systems which don't have an RTC
54 which keeps time over reboots. Causes dnsmasq to use uptime
55 for timing, and keep lease lengths rather than expiry times
56 in its leases file. This also make dnsmasq "flash disk friendly".
57 Normally, dnsmasq tries very hard to keep the on-disk leases file
58 up-to-date: rewriting it after every renewal. When HAVE_BROKEN_RTC
59 is in effect, the lease file is only written when a new lease is
60 created, or an old one destroyed. (Because those are the only times
61 it changes.) This vastly reduces the number of file writes, and makes
62 it viable to keep the lease file on a flash filesystem.
63 NOTE: when enabling or disabling this, be sure to delete any old
64 leases file, otherwise dnsmasq may get very confused.
65
66HAVE_TFTP
67 define this to get dnsmasq's built-in TFTP server.
68
69HAVE_DHCP
70 define this to get dnsmasq's DHCPv4 server.
71
72HAVE_DHCP6
73 define this to get dnsmasq's DHCPv6 server. (implies HAVE_DHCP).
74
75HAVE_SCRIPT
76 define this to get the ability to call scripts on lease-change.
77
78HAVE_LUASCRIPT
79 define this to get the ability to call Lua script on lease-change. (implies HAVE_SCRIPT)
80
81HAVE_DBUS
82 define this if you want to link against libdbus, and have dnsmasq
83 support some methods to allow (re)configuration of the upstream DNS
84 servers via DBus.
85
86HAVE_IDN
87 define this if you want international domain name support.
88 NOTE: for backwards compatibility, IDN support is automatically
89 included when internationalisation support is built, using the
90 *-i18n makefile targets, even if HAVE_IDN is not explicitly set.
91
92HAVE_CONNTRACK
93 define this to include code which propogates conntrack marks from
94 incoming DNS queries to the corresponding upstream queries. This adds
95 a build-dependency on libnetfilter_conntrack, but the resulting binary will
96 still run happily on a kernel without conntrack support.
97
Jason A. Donenfeld13d86c72013-02-22 18:20:53 +000098HAVE_IPSET
99 define this to include the ability to selectively add resolved ip addresses
100 to given ipsets.
101
Simon Kelley4820dce2012-12-18 18:30:30 +0000102HAVE_AUTH
103 define this to include the facility to act as an authoritative DNS
104 server for one or more zones.
105
106
Simon Kelleyc72daea2012-01-05 21:33:27 +0000107NO_IPV6
108NO_TFTP
109NO_DHCP
110NO_DHCP6
111NO_SCRIPT
112NO_LARGEFILE
Simon Kelley4820dce2012-12-18 18:30:30 +0000113NO_AUTH
Simon Kelleyc72daea2012-01-05 21:33:27 +0000114 these are avilable to explictly disable compile time options which would
115 otherwise be enabled automatically (HAVE_IPV6, >2Gb file sizes) or
116 which are enabled by default in the distributed source tree. Building dnsmasq
117 with something like "make COPTS=-DNO_SCRIPT" will do the trick.
118
119LEASEFILE
120CONFFILE
121RESOLVFILE
122 the default locations of these files are determined below, but may be overridden
123 in a build command line using COPTS.
124
125*/
126
127
128/* The default set of options to build. Built with these options, dnsmasq
129 has no library dependencies other than libc */
130
131#define HAVE_DHCP
Simon Kelley07933802012-02-14 20:55:25 +0000132#define HAVE_DHCP6
Simon Kelleyc72daea2012-01-05 21:33:27 +0000133#define HAVE_TFTP
134#define HAVE_SCRIPT
Simon Kelley4820dce2012-12-18 18:30:30 +0000135#define HAVE_AUTH
Simon Kelley3ddad242013-03-21 17:56:06 +0000136#define HAVE_IPSET
Simon Kelleyc72daea2012-01-05 21:33:27 +0000137/* #define HAVE_LUASCRIPT */
138/* #define HAVE_BROKEN_RTC */
139/* #define HAVE_DBUS */
140/* #define HAVE_IDN */
141/* #define HAVE_CONNTRACK */
Simon Kelley65d1e3b2014-01-08 11:00:01 +0000142/* #define HAVE_DNSSEC */
143
Simon Kelleyc72daea2012-01-05 21:33:27 +0000144
145/* Default locations for important system files. */
Simon Kelley73a08a22009-02-05 20:28:08 +0000146
147#ifndef LEASEFILE
148# if defined(__FreeBSD__) || defined (__OpenBSD__) || defined(__DragonFly__) || defined(__NetBSD__)
149# define LEASEFILE "/var/db/dnsmasq.leases"
150# elif defined(__sun__) || defined (__sun)
151# define LEASEFILE "/var/cache/dnsmasq.leases"
Simon Kelley572b41e2011-02-18 18:11:18 +0000152# elif defined(__ANDROID__)
153# define LEASEFILE "/data/misc/dhcp/dnsmasq.leases"
Simon Kelley73a08a22009-02-05 20:28:08 +0000154# else
155# define LEASEFILE "/var/lib/misc/dnsmasq.leases"
156# endif
Simon Kelleyfeba5c12004-07-27 20:28:58 +0100157#endif
Simon Kelley73a08a22009-02-05 20:28:08 +0000158
159#ifndef CONFFILE
160# if defined(__FreeBSD__)
161# define CONFFILE "/usr/local/etc/dnsmasq.conf"
162# else
163# define CONFFILE "/etc/dnsmasq.conf"
164# endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000165#endif
Simon Kelley73a08a22009-02-05 20:28:08 +0000166
Simon Kelleyc72daea2012-01-05 21:33:27 +0000167#ifndef RESOLVFILE
168# if defined(__uClinux__)
169# define RESOLVFILE "/etc/config/resolv.conf"
170# else
171# define RESOLVFILE "/etc/resolv.conf"
172# endif
173#endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000174
Simon Kelley55d290a2012-06-29 20:58:32 +0100175#ifndef RUNFILE
176# if defined(__ANDROID__)
177# define RUNFILE "/data/dnsmasq.pid"
178# else
179# define RUNFILE "/var/run/dnsmasq.pid"
180# endif
181#endif
Simon Kelleyc72daea2012-01-05 21:33:27 +0000182
183/* platform dependent options: these are determined automatically below
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000184
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100185HAVE_LINUX_NETWORK
Simon Kelley824af852008-02-12 20:43:05 +0000186HAVE_BSD_NETWORK
187HAVE_SOLARIS_NETWORK
188 define exactly one of these to alter interaction with kernel networking.
189
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000190HAVE_GETOPT_LONG
Simon Kelleyda632e72012-03-26 11:14:05 +0100191 defined when GNU-style getopt_long available.
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000192
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000193HAVE_SOCKADDR_SA_LEN
Simon Kelleyc72daea2012-01-05 21:33:27 +0000194 defined if struct sockaddr has sa_len field (*BSD)
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000195*/
196
197/* Must preceed __linux__ since uClinux defines __linux__ too. */
Simon Kelleye17fb622006-01-14 20:33:46 +0000198#if defined(__uClinux__)
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100199#define HAVE_LINUX_NETWORK
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000200#define HAVE_GETOPT_LONG
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000201#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley59353a62004-11-21 19:34:28 +0000202/* Never use fork() on uClinux. Note that this is subtly different from the
203 --keep-in-foreground option, since it also suppresses forking new
Simon Kelley5aabfc72007-08-29 11:24:47 +0100204 processes for TCP connections and disables the call-a-script on leasechange
205 system. It's intended for use on MMU-less kernels. */
Simon Kelleye17fb622006-01-14 20:33:46 +0000206#define NO_FORK
207
208#elif defined(__UCLIBC__)
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100209#define HAVE_LINUX_NETWORK
Simon Kelleye17fb622006-01-14 20:33:46 +0000210#if defined(__UCLIBC_HAS_GNU_GETOPT__) || \
211 ((__UCLIBC_MAJOR__==0) && (__UCLIBC_MINOR__==9) && (__UCLIBC_SUBLEVEL__<21))
212# define HAVE_GETOPT_LONG
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100213#endif
Simon Kelleye17fb622006-01-14 20:33:46 +0000214#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley7cebd202006-05-06 14:13:33 +0100215#if !defined(__ARCH_HAS_MMU__) && !defined(__UCLIBC_HAS_MMU__)
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000216# define NO_FORK
217#endif
Simon Kelley7cebd202006-05-06 14:13:33 +0100218#if defined(__UCLIBC_HAS_IPV6__)
219# ifndef IPV6_V6ONLY
220# define IPV6_V6ONLY 26
221# endif
Simon Kelleye17fb622006-01-14 20:33:46 +0000222#endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000223
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000224/* This is for glibc 2.x */
225#elif defined(__linux__)
Simon Kelley5e9e0ef2006-04-17 14:24:29 +0100226#define HAVE_LINUX_NETWORK
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000227#define HAVE_GETOPT_LONG
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000228#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000229
Simon Kelley9e038942008-05-30 20:06:34 +0100230#elif defined(__FreeBSD__) || \
231 defined(__OpenBSD__) || \
232 defined(__DragonFly__) || \
Simon Kelley8ef5ada2010-06-03 19:42:45 +0100233 defined(__FreeBSD_kernel__)
Simon Kelley824af852008-02-12 20:43:05 +0000234#define HAVE_BSD_NETWORK
Simon Kelley59353a62004-11-21 19:34:28 +0000235/* Later verions of FreeBSD have getopt_long() */
236#if defined(optional_argument) && defined(required_argument)
237# define HAVE_GETOPT_LONG
Simon Kelley59353a62004-11-21 19:34:28 +0000238#endif
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000239#define HAVE_SOCKADDR_SA_LEN
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000240
241#elif defined(__APPLE__)
Simon Kelley824af852008-02-12 20:43:05 +0000242#define HAVE_BSD_NETWORK
Simon Kelley316e2732010-01-22 20:16:09 +0000243#define HAVE_GETOPT_LONG
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 Kelley6dbdc972013-10-28 14:22:57 +0000247/* Select the RFC_3542 version of the IPv6 socket API.
248 Define before netinet6/in6.h is included. */
249#define __APPLE_USE_RFC_3542
250
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000251#elif defined(__NetBSD__)
Simon Kelley824af852008-02-12 20:43:05 +0000252#define HAVE_BSD_NETWORK
Simon Kelleyfd9fa482004-10-21 20:24:00 +0100253#define HAVE_GETOPT_LONG
Simon Kelley9e4abcb2004-01-22 19:47:41 +0000254#define HAVE_SOCKADDR_SA_LEN
Simon Kelley824af852008-02-12 20:43:05 +0000255
256#elif defined(__sun) || defined(__sun__)
257#define HAVE_SOLARIS_NETWORK
Simon Kelley7622fc02009-06-04 20:32:05 +0100258#define HAVE_GETOPT_LONG
Simon Kelley824af852008-02-12 20:43:05 +0000259#undef HAVE_SOCKADDR_SA_LEN
Simon Kelley7622fc02009-06-04 20:32:05 +0100260#define ETHER_ADDR_LEN 6
261
Simon Kelley824af852008-02-12 20:43:05 +0000262#endif
263
Simon Kelleye17fb622006-01-14 20:33:46 +0000264/* Decide if we're going to support IPv6 */
265/* We assume that systems which don't have IPv6
266 headers don't have ntop and pton either */
267
Simon Kelleyc72daea2012-01-05 21:33:27 +0000268#if defined(INET6_ADDRSTRLEN) && defined(IPV6_V6ONLY)
Simon Kelleye17fb622006-01-14 20:33:46 +0000269# define HAVE_IPV6
270# define ADDRSTRLEN INET6_ADDRSTRLEN
Simon Kelleyb5a7ff42013-04-25 11:03:47 +0100271#else
272# if !defined(INET_ADDRSTRLEN)
273# define INET_ADDRSTRLEN 16 /* 4*3 + 3 dots + NULL */
274# endif
Simon Kelleye17fb622006-01-14 20:33:46 +0000275# undef HAVE_IPV6
276# define ADDRSTRLEN INET_ADDRSTRLEN
Simon Kelleye17fb622006-01-14 20:33:46 +0000277#endif
278
Simon Kelleyc72daea2012-01-05 21:33:27 +0000279
280/* rules to implement compile-time option dependencies and
281 the NO_XXX flags */
282
283#ifdef NO_IPV6
284#undef HAVE_IPV6
Simon Kelley1f15b812009-10-13 17:49:32 +0100285#endif
286
Simon Kelleyc72daea2012-01-05 21:33:27 +0000287#ifdef NO_TFTP
288#undef HAVE_TFTP
289#endif
290
291#ifdef NO_DHCP
292#undef HAVE_DHCP
293#undef HAVE_DHCP6
294#endif
295
296#if defined(NO_DHCP6) || !defined(HAVE_IPV6)
297#undef HAVE_DHCP6
298#endif
299
300/* DHCP6 needs DHCP too */
301#ifdef HAVE_DHCP6
302#define HAVE_DHCP
303#endif
304
305#if defined(NO_SCRIPT) || !defined(HAVE_DHCP) || defined(NO_FORK)
306#undef HAVE_SCRIPT
307#undef HAVE_LUASCRIPT
308#endif
309
310/* Must HAVE_SCRIPT to HAVE_LUASCRIPT */
311#ifdef HAVE_LUASCRIPT
312#define HAVE_SCRIPT
313#endif
314
Simon Kelley4820dce2012-12-18 18:30:30 +0000315#ifdef NO_AUTH
316#undef HAVE_AUTH
317#endif
Simon Kelleyc72daea2012-01-05 21:33:27 +0000318
Simon Kelley3ddad242013-03-21 17:56:06 +0000319#if defined(NO_IPSET) || !defined(HAVE_LINUX_NETWORK)
Jason A. Donenfeld13d86c72013-02-22 18:20:53 +0000320#undef HAVE_IPSET
321#endif
322
Simon Kelleyc72daea2012-01-05 21:33:27 +0000323/* Define a string indicating which options are in use.
324 DNSMASQP_COMPILE_OPTS is only defined in dnsmasq.c */
325
326#ifdef DNSMASQ_COMPILE_OPTS
327
328static char *compile_opts =
329#ifndef HAVE_IPV6
330"no-"
331#endif
332"IPv6 "
333#ifndef HAVE_GETOPT_LONG
334"no-"
335#endif
336"GNU-getopt "
337#ifdef HAVE_BROKEN_RTC
338"no-RTC "
339#endif
340#ifdef NO_FORK
341"no-MMU "
342#endif
343#ifndef HAVE_DBUS
344"no-"
345#endif
346"DBus "
347#ifndef LOCALEDIR
348"no-"
349#endif
350"i18n "
351#if !defined(LOCALEDIR) && !defined(HAVE_IDN)
352"no-"
353#endif
354"IDN "
355#ifndef HAVE_DHCP
356"no-"
357#endif
358"DHCP "
359#if defined(HAVE_DHCP)
360# if !defined (HAVE_DHCP6)
361 "no-"
362# endif
363 "DHCPv6 "
364# if !defined(HAVE_SCRIPT)
365 "no-scripts "
366# else
367# if !defined(HAVE_LUASCRIPT)
368 "no-"
369# endif
370 "Lua "
371# endif
372#endif
373#ifndef HAVE_TFTP
374"no-"
375#endif
376"TFTP "
377#ifndef HAVE_CONNTRACK
378"no-"
379#endif
Simon Kelley4820dce2012-12-18 18:30:30 +0000380"conntrack "
Jason A. Donenfeld13d86c72013-02-22 18:20:53 +0000381#ifndef HAVE_IPSET
382"no-"
383#endif
384"ipset "
Simon Kelley4820dce2012-12-18 18:30:30 +0000385#ifndef HAVE_AUTH
386"no-"
387#endif
Simon Kelley0fc2f312014-01-08 10:26:58 +0000388"auth "
389#ifndef HAVE_DNSSEC
390"no-"
391#endif
392"DNSSEC";
393
Simon Kelleyc72daea2012-01-05 21:33:27 +0000394
395#endif
396
397
398