/* dnsmasq is Copyright (c) 2000-2009 Simon Kelley This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; version 2 dated June, 1991, or (at your option) version 3 dated 29 June, 2007. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ #define VERSION "2.51" #define FTABSIZ 150 /* max number of outstanding requests (default) */ #define MAX_PROCS 20 /* max no children for TCP requests */ #define CHILD_LIFETIME 150 /* secs 'till terminated (RFC1035 suggests > 120s) */ #define EDNS_PKTSZ 1280 /* default max EDNS.0 UDP packet from RFC2671 */ #define TIMEOUT 10 /* drop UDP queries after TIMEOUT seconds */ #define FORWARD_TEST 50 /* try all servers every 50 queries */ #define FORWARD_TIME 10 /* or 10 seconds */ #define RANDOM_SOCKS 64 /* max simultaneous random ports */ #define LEASE_RETRY 60 /* on error, retry writing leasefile after LEASE_RETRY seconds */ #define CACHESIZ 150 /* default cache size */ #define MAXLEASES 150 /* maximum number of DHCP leases */ #define PING_WAIT 3 /* wait for ping address-in-use test */ #define PING_CACHE_TIME 30 /* Ping test assumed to be valid this long. */ #define DECLINE_BACKOFF 600 /* disable DECLINEd static addresses for this long */ #define DHCP_PACKET_MAX 16384 /* hard limit on DHCP packet size */ #define SMALLDNAME 40 /* most domain names are smaller than this */ #define HOSTSFILE "/etc/hosts" #ifdef __uClinux__ # define RESOLVFILE "/etc/config/resolv.conf" #else # define RESOLVFILE "/etc/resolv.conf" #endif #define RUNFILE "/var/run/dnsmasq.pid" #ifndef LEASEFILE # if defined(__FreeBSD__) || defined (__OpenBSD__) || defined(__DragonFly__) || defined(__NetBSD__) # define LEASEFILE "/var/db/dnsmasq.leases" # elif defined(__sun__) || defined (__sun) # define LEASEFILE "/var/cache/dnsmasq.leases" # elif defined(__ANDROID__) # define LEASEFILE "/data/misc/dhcp/dnsmasq.leases" # else # define LEASEFILE "/var/lib/misc/dnsmasq.leases" # endif #endif #ifndef CONFFILE # if defined(__FreeBSD__) # define CONFFILE "/usr/local/etc/dnsmasq.conf" # else # define CONFFILE "/etc/dnsmasq.conf" # endif #endif #define DEFLEASE 3600 /* default lease time, 1 hour */ #define CHUSER "nobody" #define CHGRP "dip" #define DHCP_SERVER_PORT 67 #define DHCP_CLIENT_PORT 68 #define DHCP_SERVER_ALTPORT 1067 #define DHCP_CLIENT_ALTPORT 1068 #define LOG_MAX 5 /* log-queue length */ #define RANDFILE "/dev/urandom" #define DAD_WAIT 20 /* retry binding IPv6 sockets for this long */ /* A small collection of RR-types which are missing on some platforms */ #ifndef T_SIG # define T_SIG 24 #endif #ifndef T_SRV # define T_SRV 33 #endif #ifndef T_OPT # define T_OPT 41 #endif #ifndef T_TKEY # define T_TKEY 249 #endif #ifndef T_TSIG # define T_TSIG 250 #endif /* Follows system specific switches. If you run on a new system, you may want to edit these. May replace this with Autoconf one day. HAVE_LINUX_NETWORK HAVE_BSD_NETWORK HAVE_SOLARIS_NETWORK define exactly one of these to alter interaction with kernel networking. HAVE_BROKEN_RTC define this on embedded systems which don't have an RTC which keeps time over reboots. Causes dnsmasq to use uptime for timing, and keep lease lengths rather than expiry times in its leases file. This also make dnsmasq "flash disk friendly". Normally, dnsmasq tries very hard to keep the on-disk leases file up-to-date: rewriting it after every renewal. When HAVE_BROKEN_RTC is in effect, the lease file is only written when a new lease is created, or an old one destroyed. (Because those are the only times it changes.) This vastly reduces the number of file writes, and makes it viable to keep the lease file on a flash filesystem. NOTE: when enabling or disabling this, be sure to delete any old leases file, otherwise dnsmasq may get very confused. HAVE_DHCP define this to get dnsmasq's DHCP server. HAVE_SCRIPT define this to get the ability to call scripts on lease-change HAVE_GETOPT_LONG define this if you have GNU libc or GNU getopt. HAVE_ARC4RANDOM define this if you have arc4random() to get better security from DNS spoofs by using really random ids (OpenBSD) HAVE_SOCKADDR_SA_LEN define this if struct sockaddr has sa_len field (*BSD) NOTES: For Linux you should define HAVE_LINUX_NETWORK HAVE_GETOPT_LONG you should NOT define HAVE_ARC4RANDOM HAVE_SOCKADDR_SA_LEN For *BSD systems you should define HAVE_BSD_NETWORK HAVE_SOCKADDR_SA_LEN and you MAY define HAVE_ARC4RANDOM - OpenBSD and FreeBSD and NetBSD version 2.0 or later HAVE_GETOPT_LONG - NetBSD, later FreeBSD (FreeBSD and OpenBSD only if you link GNU getopt) */ /* platform independent options- uncomment to enable */ #define HAVE_DHCP #define HAVE_SCRIPT /* #define HAVE_BROKEN_RTC */ /* Allow DHCP to be disabled with COPTS=-DNO_DHCP */ #ifdef NO_DHCP #undef HAVE_DHCP #endif /* Allow scripts to be disabled with COPTS=-DNO_SCRIPT */ #ifdef NO_SCRIPT #undef HAVE_SCRIPT #endif /* platform dependent options. */ /* Must preceed __linux__ since uClinux defines __linux__ too. */ #if defined(__uClinux__) #define HAVE_LINUX_NETWORK #define HAVE_GETOPT_LONG #undef HAVE_ARC4RANDOM #undef HAVE_SOCKADDR_SA_LEN /* Never use fork() on uClinux. Note that this is subtly different from the --keep-in-foreground option, since it also suppresses forking new processes for TCP connections and disables the call-a-script on leasechange system. It's intended for use on MMU-less kernels. */ #define NO_FORK #elif defined(__UCLIBC__) #define HAVE_LINUX_NETWORK #if defined(__UCLIBC_HAS_GNU_GETOPT__) || \ ((__UCLIBC_MAJOR__==0) && (__UCLIBC_MINOR__==9) && (__UCLIBC_SUBLEVEL__<21)) # define HAVE_GETOPT_LONG #endif #undef HAVE_ARC4RANDOM #undef HAVE_SOCKADDR_SA_LEN #if !defined(__ARCH_HAS_MMU__) && !defined(__UCLIBC_HAS_MMU__) # define NO_FORK #endif #if defined(__UCLIBC_HAS_IPV6__) # ifndef IPV6_V6ONLY # define IPV6_V6ONLY 26 # endif #endif /* This is for glibc 2.x */ #elif defined(__linux__) #define HAVE_LINUX_NETWORK #define HAVE_GETOPT_LONG #undef HAVE_ARC4RANDOM #undef HAVE_SOCKADDR_SA_LEN #elif defined(__FreeBSD__) || \ defined(__OpenBSD__) || \ defined(__DragonFly__) || \ defined (__FreeBSD_kernel__) #define HAVE_BSD_NETWORK /* Later verions of FreeBSD have getopt_long() */ #if defined(optional_argument) && defined(required_argument) # define HAVE_GETOPT_LONG #endif #if !defined (__FreeBSD_kernel__) # define HAVE_ARC4RANDOM #endif #define HAVE_SOCKADDR_SA_LEN #elif defined(__APPLE__) #define HAVE_BSD_NETWORK #undef HAVE_GETOPT_LONG #define HAVE_ARC4RANDOM #define HAVE_SOCKADDR_SA_LEN /* Define before sys/socket.h is included so we get socklen_t */ #define _BSD_SOCKLEN_T_ #elif defined(__NetBSD__) #define HAVE_BSD_NETWORK #define HAVE_GETOPT_LONG #undef HAVE_ARC4RANDOM #define HAVE_SOCKADDR_SA_LEN #elif defined(__sun) || defined(__sun__) #define HAVE_SOLARIS_NETWORK #define HAVE_GETOPT_LONG #undef HAVE_ARC4RANDOM #undef HAVE_SOCKADDR_SA_LEN #define _XPG4_2 #define __EXTENSIONS__ #define ETHER_ADDR_LEN 6 #endif /* Decide if we're going to support IPv6 */ /* IPv6 can be forced off with "make COPTS=-DNO_IPV6" */ /* We assume that systems which don't have IPv6 headers don't have ntop and pton either */ #if defined(INET6_ADDRSTRLEN) && defined(IPV6_V6ONLY) && !defined(NO_IPV6) # define HAVE_IPV6 # define ADDRSTRLEN INET6_ADDRSTRLEN # if defined(SOL_IPV6) # define IPV6_LEVEL SOL_IPV6 # else # define IPV6_LEVEL IPPROTO_IPV6 # endif #elif defined(INET_ADDRSTRLEN) # undef HAVE_IPV6 # define ADDRSTRLEN INET_ADDRSTRLEN #else # undef HAVE_IPV6 # define ADDRSTRLEN 16 /* 4*3 + 3 dots + NULL */ #endif /* Can't do scripts without fork */ #ifdef NOFORK # undef HAVE_SCRIPT #endif