Annotation of embedaddon/dnsmasq/src/config.h, revision 1.1.1.5
1.1.1.5 ! misho 1: /* dnsmasq is Copyright (c) 2000-2022 Simon Kelley
1.1 misho 2:
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
5: the Free Software Foundation; version 2 dated June, 1991, or
6: (at your option) version 3 dated 29 June, 2007.
7:
8: 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.
12:
13: 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/>.
15: */
16:
17: #define FTABSIZ 150 /* max number of outstanding requests (default) */
18: #define MAX_PROCS 20 /* max no children for TCP requests */
19: #define CHILD_LIFETIME 150 /* secs 'till terminated (RFC1035 suggests > 120s) */
1.1.1.3 misho 20: #define TCP_MAX_QUERIES 100 /* Maximum number of queries per incoming TCP connection */
1.1.1.4 misho 21: #define TCP_BACKLOG 32 /* kernel backlog limit for TCP connections */
1.1.1.5 ! misho 22: #define EDNS_PKTSZ 1232 /* default max EDNS.0 UDP packet from from /dnsflagday.net/2020 */
! 23: #define SAFE_PKTSZ 1232 /* "go anywhere" UDP packet size, see https://dnsflagday.net/2020/ */
1.1.1.4 misho 24: #define KEYBLOCK_LEN 40 /* choose to minimise fragmentation when storing DNSSEC keys */
1.1.1.2 misho 25: #define DNSSEC_WORK 50 /* Max number of queries to validate one question */
1.1.1.5 ! misho 26: #define TIMEOUT 10 /* drop UDP queries after TIMEOUT seconds */
! 27: #define SMALL_PORT_RANGE 30 /* If DNS port range is smaller than this, use different allocation. */
1.1 misho 28: #define FORWARD_TEST 50 /* try all servers every 50 queries */
29: #define FORWARD_TIME 20 /* or 20 seconds */
1.1.1.4 misho 30: #define UDP_TEST_TIME 60 /* How often to reset our idea of max packet size. */
1.1.1.3 misho 31: #define SERVERS_LOGGED 30 /* Only log this many servers when logging state */
1.1.1.4 misho 32: #define LOCALS_LOGGED 8 /* Only log this many local addresses when logging state */
1.1 misho 33: #define LEASE_RETRY 60 /* on error, retry writing leasefile after LEASE_RETRY seconds */
34: #define CACHESIZ 150 /* default cache size */
1.1.1.3 misho 35: #define TTL_FLOOR_LIMIT 3600 /* don't allow --min-cache-ttl to raise TTL above this under any circumstances */
1.1 misho 36: #define MAXLEASES 1000 /* maximum number of DHCP leases */
37: #define PING_WAIT 3 /* wait for ping address-in-use test */
38: #define PING_CACHE_TIME 30 /* Ping test assumed to be valid this long. */
39: #define DECLINE_BACKOFF 600 /* disable DECLINEd static addresses for this long */
40: #define DHCP_PACKET_MAX 16384 /* hard limit on DHCP packet size */
1.1.1.2 misho 41: #define SMALLDNAME 50 /* most domain names are smaller than this */
42: #define CNAME_CHAIN 10 /* chains longer than this atr dropped for loop protection */
1.1.1.4 misho 43: #define DNSSEC_MIN_TTL 60 /* DNSKEY and DS records in cache last at least this long */
1.1 misho 44: #define HOSTSFILE "/etc/hosts"
45: #define ETHERSFILE "/etc/ethers"
1.1.1.4 misho 46: #define DEFLEASE 3600 /* default DHCPv4 lease time, one hour */
47: #define DEFLEASE6 (3600*24) /* default lease time for DHCPv6. One day. */
1.1 misho 48: #define CHUSER "nobody"
49: #define CHGRP "dip"
50: #define TFTP_MAX_CONNECTIONS 50 /* max simultaneous connections */
51: #define LOG_MAX 5 /* log-queue length */
52: #define RANDFILE "/dev/urandom"
53: #define DNSMASQ_SERVICE "uk.org.thekelleys.dnsmasq" /* Default - may be overridden by config */
54: #define DNSMASQ_PATH "/uk/org/thekelleys/dnsmasq"
1.1.1.4 misho 55: #define DNSMASQ_UBUS_NAME "dnsmasq" /* Default - may be overridden by config */
1.1 misho 56: #define AUTH_TTL 600 /* default TTL for auth DNS */
57: #define SOA_REFRESH 1200 /* SOA refresh default */
58: #define SOA_RETRY 180 /* SOA retry default */
59: #define SOA_EXPIRY 1209600 /* SOA expiry default */
1.1.1.3 misho 60: #define LOOP_TEST_DOMAIN "test" /* domain for loop testing, "test" is reserved by RFC 2606 and won't therefore clash */
61: #define LOOP_TEST_TYPE T_TXT
1.1.1.5 ! misho 62: #define DEFAULT_FAST_RETRY 1000 /* ms, default delay before fast retry */
! 63: #define STALE_CACHE_EXPIRY 86400 /* 1 day in secs, default maximum expiry time for stale cache data */
1.1 misho 64:
65: /* compile-time options: uncomment below to enable or do eg.
66: make COPTS=-DHAVE_BROKEN_RTC
67:
68: HAVE_BROKEN_RTC
69: define this on embedded systems which don't have an RTC
70: which keeps time over reboots. Causes dnsmasq to use uptime
71: for timing, and keep lease lengths rather than expiry times
72: in its leases file. This also make dnsmasq "flash disk friendly".
73: Normally, dnsmasq tries very hard to keep the on-disk leases file
74: up-to-date: rewriting it after every renewal. When HAVE_BROKEN_RTC
75: is in effect, the lease file is only written when a new lease is
76: created, or an old one destroyed. (Because those are the only times
77: it changes.) This vastly reduces the number of file writes, and makes
78: it viable to keep the lease file on a flash filesystem.
79: NOTE: when enabling or disabling this, be sure to delete any old
80: leases file, otherwise dnsmasq may get very confused.
81:
82: HAVE_TFTP
83: define this to get dnsmasq's built-in TFTP server.
84:
85: HAVE_DHCP
86: define this to get dnsmasq's DHCPv4 server.
87:
88: HAVE_DHCP6
89: define this to get dnsmasq's DHCPv6 server. (implies HAVE_DHCP).
90:
91: HAVE_SCRIPT
92: define this to get the ability to call scripts on lease-change.
93:
94: HAVE_LUASCRIPT
95: define this to get the ability to call Lua script on lease-change. (implies HAVE_SCRIPT)
96:
97: HAVE_DBUS
98: define this if you want to link against libdbus, and have dnsmasq
99: support some methods to allow (re)configuration of the upstream DNS
100: servers via DBus.
101:
1.1.1.4 misho 102: HAVE_UBUS
103: define this if you want to link against libubus
104:
1.1 misho 105: HAVE_IDN
1.1.1.4 misho 106: define this if you want international domain name 2003 support.
107:
108: HAVE_LIBIDN2
109: define this if you want international domain name 2008 support.
1.1 misho 110:
111: HAVE_CONNTRACK
1.1.1.4 misho 112: define this to include code which propagates conntrack marks from
1.1 misho 113: incoming DNS queries to the corresponding upstream queries. This adds
114: a build-dependency on libnetfilter_conntrack, but the resulting binary will
115: still run happily on a kernel without conntrack support.
116:
117: HAVE_IPSET
118: define this to include the ability to selectively add resolved ip addresses
119: to given ipsets.
120:
1.1.1.5 ! misho 121: HAVE_NFTSET
! 122: define this to include the ability to selectively add resolved ip addresses
! 123: to given nftables sets.
! 124:
1.1 misho 125: HAVE_AUTH
126: define this to include the facility to act as an authoritative DNS
127: server for one or more zones.
128:
1.1.1.4 misho 129: HAVE_CRYPTOHASH
130: include just hash function from crypto library, but no DNSSEC.
131:
1.1.1.3 misho 132: HAVE_DNSSEC
133: include DNSSEC validator.
134:
1.1.1.4 misho 135: HAVE_DUMPFILE
136: include code to dump packets to a libpcap-format file for debugging.
137:
1.1.1.3 misho 138: HAVE_LOOP
139: include functionality to probe for and remove DNS forwarding loops.
140:
141: HAVE_INOTIFY
142: use the Linux inotify facility to efficiently re-read configuration files.
1.1 misho 143:
1.1.1.4 misho 144: NO_ID
145: Don't report *.bind CHAOS info to clients, forward such requests upstream instead.
1.1 misho 146: NO_TFTP
147: NO_DHCP
148: NO_DHCP6
149: NO_SCRIPT
150: NO_LARGEFILE
151: NO_AUTH
1.1.1.4 misho 152: NO_DUMPFILE
1.1.1.5 ! misho 153: NO_LOOP
1.1.1.3 misho 154: NO_INOTIFY
1.1.1.4 misho 155: these are available to explicitly disable compile time options which would
156: otherwise be enabled automatically or which are enabled by default
157: in the distributed source tree. Building dnsmasq
1.1 misho 158: with something like "make COPTS=-DNO_SCRIPT" will do the trick.
1.1.1.3 misho 159: NO_GMP
160: Don't use and link against libgmp, Useful if nettle is built with --enable-mini-gmp.
161:
1.1 misho 162: LEASEFILE
163: CONFFILE
164: RESOLVFILE
165: the default locations of these files are determined below, but may be overridden
166: in a build command line using COPTS.
167:
168: */
169:
1.1.1.2 misho 170: /* Defining this builds a binary which handles time differently and works better on a system without a
171: stable RTC (it uses uptime, not epoch time) and writes the DHCP leases file less often to avoid flash wear.
172: */
173:
174: /* #define HAVE_BROKEN_RTC */
1.1 misho 175:
176: /* The default set of options to build. Built with these options, dnsmasq
177: has no library dependencies other than libc */
178:
179: #define HAVE_DHCP
180: #define HAVE_DHCP6
181: #define HAVE_TFTP
182: #define HAVE_SCRIPT
183: #define HAVE_AUTH
184: #define HAVE_IPSET
1.1.1.3 misho 185: #define HAVE_LOOP
1.1.1.4 misho 186: #define HAVE_DUMPFILE
1.1.1.2 misho 187:
188: /* Build options which require external libraries.
189:
190: Defining HAVE_<opt>_STATIC as _well_ as HAVE_<opt> will link the library statically.
191:
192: You can use "make COPTS=-DHAVE_<opt>" instead of editing these.
193: */
194:
1.1 misho 195: /* #define HAVE_LUASCRIPT */
196: /* #define HAVE_DBUS */
197: /* #define HAVE_IDN */
1.1.1.4 misho 198: /* #define HAVE_LIBIDN2 */
1.1 misho 199: /* #define HAVE_CONNTRACK */
1.1.1.4 misho 200: /* #define HAVE_CRYPTOHASH */
1.1.1.2 misho 201: /* #define HAVE_DNSSEC */
1.1.1.5 ! misho 202: /* #define HAVE_NFTSET */
1.1 misho 203:
204: /* Default locations for important system files. */
205:
206: #ifndef LEASEFILE
207: # if defined(__FreeBSD__) || defined (__OpenBSD__) || defined(__DragonFly__) || defined(__NetBSD__)
208: # define LEASEFILE "/var/db/dnsmasq.leases"
209: # elif defined(__sun__) || defined (__sun)
210: # define LEASEFILE "/var/cache/dnsmasq.leases"
211: # elif defined(__ANDROID__)
212: # define LEASEFILE "/data/misc/dhcp/dnsmasq.leases"
213: # else
214: # define LEASEFILE "/var/lib/misc/dnsmasq.leases"
215: # endif
216: #endif
217:
218: #ifndef CONFFILE
219: # if defined(__FreeBSD__)
220: # define CONFFILE "/usr/local/etc/dnsmasq.conf"
221: # else
222: # define CONFFILE "/etc/dnsmasq.conf"
223: # endif
224: #endif
225:
226: #ifndef RESOLVFILE
227: # if defined(__uClinux__)
228: # define RESOLVFILE "/etc/config/resolv.conf"
229: # else
230: # define RESOLVFILE "/etc/resolv.conf"
231: # endif
232: #endif
233:
234: #ifndef RUNFILE
235: # if defined(__ANDROID__)
236: # define RUNFILE "/data/dnsmasq.pid"
237: # else
238: # define RUNFILE "/var/run/dnsmasq.pid"
239: # endif
240: #endif
241:
242: /* platform dependent options: these are determined automatically below
243:
244: HAVE_LINUX_NETWORK
245: HAVE_BSD_NETWORK
246: HAVE_SOLARIS_NETWORK
247: define exactly one of these to alter interaction with kernel networking.
248:
249: HAVE_GETOPT_LONG
250: defined when GNU-style getopt_long available.
251:
252: HAVE_SOCKADDR_SA_LEN
253: defined if struct sockaddr has sa_len field (*BSD)
254: */
255:
1.1.1.4 misho 256: #if defined(__UCLIBC__)
1.1 misho 257: #define HAVE_LINUX_NETWORK
258: #if defined(__UCLIBC_HAS_GNU_GETOPT__) || \
259: ((__UCLIBC_MAJOR__==0) && (__UCLIBC_MINOR__==9) && (__UCLIBC_SUBLEVEL__<21))
260: # define HAVE_GETOPT_LONG
261: #endif
262: #undef HAVE_SOCKADDR_SA_LEN
263: #if defined(__UCLIBC_HAS_IPV6__)
264: # ifndef IPV6_V6ONLY
265: # define IPV6_V6ONLY 26
266: # endif
267: #endif
268:
269: /* This is for glibc 2.x */
270: #elif defined(__linux__)
271: #define HAVE_LINUX_NETWORK
272: #define HAVE_GETOPT_LONG
273: #undef HAVE_SOCKADDR_SA_LEN
274:
275: #elif defined(__FreeBSD__) || \
276: defined(__OpenBSD__) || \
277: defined(__DragonFly__) || \
278: defined(__FreeBSD_kernel__)
279: #define HAVE_BSD_NETWORK
1.1.1.4 misho 280: /* Later versions of FreeBSD have getopt_long() */
1.1 misho 281: #if defined(optional_argument) && defined(required_argument)
282: # define HAVE_GETOPT_LONG
283: #endif
284: #define HAVE_SOCKADDR_SA_LEN
285:
286: #elif defined(__APPLE__)
287: #define HAVE_BSD_NETWORK
288: #define HAVE_GETOPT_LONG
289: #define HAVE_SOCKADDR_SA_LEN
1.1.1.4 misho 290: #define NO_IPSET
1.1 misho 291: /* Define before sys/socket.h is included so we get socklen_t */
292: #define _BSD_SOCKLEN_T_
1.1.1.2 misho 293: /* Select the RFC_3542 version of the IPv6 socket API.
294: Define before netinet6/in6.h is included. */
1.1.1.4 misho 295: #define __APPLE_USE_RFC_3542
296: /* Required for Mojave. */
297: #ifndef SOL_TCP
298: # define SOL_TCP IPPROTO_TCP
299: #endif
1.1.1.3 misho 300: #define NO_IPSET
1.1.1.2 misho 301:
1.1 misho 302: #elif defined(__NetBSD__)
303: #define HAVE_BSD_NETWORK
304: #define HAVE_GETOPT_LONG
305: #define HAVE_SOCKADDR_SA_LEN
306:
307: #elif defined(__sun) || defined(__sun__)
308: #define HAVE_SOLARIS_NETWORK
309: #define HAVE_GETOPT_LONG
310: #undef HAVE_SOCKADDR_SA_LEN
311: #define ETHER_ADDR_LEN 6
312:
313: #endif
314:
315: /* rules to implement compile-time option dependencies and
316: the NO_XXX flags */
317:
318: #ifdef NO_TFTP
319: #undef HAVE_TFTP
320: #endif
321:
322: #ifdef NO_DHCP
323: #undef HAVE_DHCP
324: #undef HAVE_DHCP6
325: #endif
326:
1.1.1.4 misho 327: #if defined(NO_DHCP6)
1.1 misho 328: #undef HAVE_DHCP6
329: #endif
330:
331: /* DHCP6 needs DHCP too */
332: #ifdef HAVE_DHCP6
333: #define HAVE_DHCP
334: #endif
335:
1.1.1.4 misho 336: #if defined(NO_SCRIPT)
1.1 misho 337: #undef HAVE_SCRIPT
338: #undef HAVE_LUASCRIPT
339: #endif
340:
341: /* Must HAVE_SCRIPT to HAVE_LUASCRIPT */
342: #ifdef HAVE_LUASCRIPT
343: #define HAVE_SCRIPT
344: #endif
345:
346: #ifdef NO_AUTH
347: #undef HAVE_AUTH
348: #endif
349:
1.1.1.3 misho 350: #if defined(NO_IPSET)
1.1 misho 351: #undef HAVE_IPSET
352: #endif
353:
1.1.1.3 misho 354: #ifdef NO_LOOP
355: #undef HAVE_LOOP
356: #endif
357:
1.1.1.4 misho 358: #ifdef NO_DUMPFILE
359: #undef HAVE_DUMPFILE
360: #endif
361:
1.1.1.3 misho 362: #if defined (HAVE_LINUX_NETWORK) && !defined(NO_INOTIFY)
363: #define HAVE_INOTIFY
364: #endif
365:
1.1 misho 366: /* Define a string indicating which options are in use.
1.1.1.4 misho 367: DNSMASQ_COMPILE_OPTS is only defined in dnsmasq.c */
1.1 misho 368:
369: #ifdef DNSMASQ_COMPILE_OPTS
370:
371: static char *compile_opts =
372: "IPv6 "
373: #ifndef HAVE_GETOPT_LONG
374: "no-"
375: #endif
376: "GNU-getopt "
377: #ifdef HAVE_BROKEN_RTC
378: "no-RTC "
379: #endif
380: #ifndef HAVE_DBUS
381: "no-"
382: #endif
383: "DBus "
1.1.1.4 misho 384: #ifndef HAVE_UBUS
385: "no-"
386: #endif
387: "UBus "
1.1 misho 388: #ifndef LOCALEDIR
389: "no-"
390: #endif
391: "i18n "
1.1.1.4 misho 392: #if defined(HAVE_LIBIDN2)
393: "IDN2 "
394: #else
395: #if !defined(HAVE_IDN)
1.1 misho 396: "no-"
1.1.1.4 misho 397: #endif
398: "IDN "
399: #endif
1.1 misho 400: #ifndef HAVE_DHCP
401: "no-"
402: #endif
403: "DHCP "
404: #if defined(HAVE_DHCP)
405: # if !defined (HAVE_DHCP6)
406: "no-"
407: # endif
408: "DHCPv6 "
1.1.1.4 misho 409: #endif
410: #if !defined(HAVE_SCRIPT)
1.1 misho 411: "no-scripts "
1.1.1.4 misho 412: #else
413: # if !defined(HAVE_LUASCRIPT)
414: "no-"
1.1 misho 415: # endif
1.1.1.4 misho 416: "Lua "
1.1 misho 417: #endif
418: #ifndef HAVE_TFTP
419: "no-"
420: #endif
421: "TFTP "
422: #ifndef HAVE_CONNTRACK
423: "no-"
424: #endif
425: "conntrack "
426: #ifndef HAVE_IPSET
427: "no-"
428: #endif
429: "ipset "
1.1.1.5 ! misho 430: #ifndef HAVE_NFTSET
! 431: "no-"
! 432: #endif
! 433: "nftset "
1.1 misho 434: #ifndef HAVE_AUTH
435: "no-"
436: #endif
1.1.1.2 misho 437: "auth "
1.1.1.4 misho 438: #if !defined(HAVE_CRYPTOHASH) && !defined(HAVE_DNSSEC)
439: "no-"
440: #endif
441: "cryptohash "
1.1.1.2 misho 442: #ifndef HAVE_DNSSEC
443: "no-"
444: #endif
1.1.1.3 misho 445: "DNSSEC "
1.1.1.4 misho 446: #ifdef NO_ID
447: "no-ID "
448: #endif
1.1.1.3 misho 449: #ifndef HAVE_LOOP
450: "no-"
451: #endif
452: "loop-detect "
453: #ifndef HAVE_INOTIFY
454: "no-"
455: #endif
1.1.1.4 misho 456: "inotify "
457: #ifndef HAVE_DUMPFILE
458: "no-"
459: #endif
460: "dumpfile";
1.1 misho 461:
1.1.1.5 ! misho 462: #endif /* defined(HAVE_DHCP) */
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>