From cb64c95740c1c0fe7396d05d8bb05b53fe0ac50a Mon Sep 17 00:00:00 2001 From: Kevin Darbyshire-Bryant Date: Mon, 22 Apr 2013 09:49:13 +0700 Subject: [PATCH] Experimental Remove radvd & libdaemon, use dnsmasq for IPv6 RA instead --- release/src/router/Makefile | 21 +- release/src/router/radvd/CHANGES | 521 -- release/src/router/radvd/COPYRIGHT | 37 - release/src/router/radvd/INTRO.html | 142 - release/src/router/radvd/Makefile.am | 133 - release/src/router/radvd/Makefile.in | 925 ---- release/src/router/radvd/README | 61 - release/src/router/radvd/TODO | 85 - release/src/router/radvd/VERSION | 6 - release/src/router/radvd/aclocal.m4 | 1011 ---- release/src/router/radvd/config.guess | 1533 ----- release/src/router/radvd/config.h.in | 111 - release/src/router/radvd/config.sub | 1693 ------ release/src/router/radvd/configure | 6456 ---------------------- release/src/router/radvd/configure.in | 205 - release/src/router/radvd/copyright.blurb | 14 - release/src/router/radvd/defaults.h | 254 - release/src/router/radvd/depcomp | 630 --- release/src/router/radvd/device-bsd44.c | 231 - release/src/router/radvd/device-common.c | 104 - release/src/router/radvd/device-linux.c | 323 -- release/src/router/radvd/gram.y | 986 ---- release/src/router/radvd/includes.h | 102 - release/src/router/radvd/install-sh | 520 -- release/src/router/radvd/interface.c | 257 - release/src/router/radvd/log.c | 180 - release/src/router/radvd/log.h | 31 - release/src/router/radvd/missing | 376 -- release/src/router/radvd/netlink.c | 96 - release/src/router/radvd/netlink.h | 21 - release/src/router/radvd/pathnames.h | 48 - release/src/router/radvd/privsep-bsd44.c | 34 - release/src/router/radvd/privsep-linux.c | 229 - release/src/router/radvd/process.c | 491 -- release/src/router/radvd/radvd.8.man | 188 - release/src/router/radvd/radvd.c | 862 --- release/src/router/radvd/radvd.conf.5.man | 704 --- release/src/router/radvd/radvd.conf.example | 124 - release/src/router/radvd/radvd.h | 280 - release/src/router/radvd/radvdump.8.man | 87 - release/src/router/radvd/radvdump.c | 524 -- release/src/router/radvd/recv.c | 119 - release/src/router/radvd/redhat/radvd-tmpfs.conf | 1 - release/src/router/radvd/redhat/radvd.conf.empty | 18 - release/src/router/radvd/redhat/radvd.init | 93 - release/src/router/radvd/redhat/radvd.spec | 247 - release/src/router/radvd/redhat/radvd.sysconfig | 7 - release/src/router/radvd/scanner.l | 158 - release/src/router/radvd/send.c | 518 -- release/src/router/radvd/socket.c | 107 - release/src/router/radvd/timer.c | 59 - release/src/router/radvd/util.c | 125 - release/src/router/radvd/ylwrap | 222 - release/src/router/rc/services.c | 156 +- release/src/router/www/advanced-dhcpdns.asp | 5 +- release/src/router/www/basic-ipv6.asp | 11 +- 56 files changed, 24 insertions(+), 22458 deletions(-) delete mode 100644 release/src/router/radvd/CHANGES delete mode 100644 release/src/router/radvd/COPYRIGHT delete mode 100644 release/src/router/radvd/INTRO.html delete mode 100644 release/src/router/radvd/Makefile.am delete mode 100644 release/src/router/radvd/Makefile.in delete mode 100644 release/src/router/radvd/README delete mode 100644 release/src/router/radvd/TODO delete mode 100644 release/src/router/radvd/VERSION delete mode 100644 release/src/router/radvd/aclocal.m4 delete mode 100755 release/src/router/radvd/config.guess delete mode 100644 release/src/router/radvd/config.h.in delete mode 100755 release/src/router/radvd/config.sub delete mode 100755 release/src/router/radvd/configure delete mode 100644 release/src/router/radvd/configure.in delete mode 100644 release/src/router/radvd/copyright.blurb delete mode 100644 release/src/router/radvd/defaults.h delete mode 100755 release/src/router/radvd/depcomp delete mode 100644 release/src/router/radvd/device-bsd44.c delete mode 100644 release/src/router/radvd/device-common.c delete mode 100644 release/src/router/radvd/device-linux.c delete mode 100644 release/src/router/radvd/gram.y delete mode 100644 release/src/router/radvd/includes.h delete mode 100755 release/src/router/radvd/install-sh delete mode 100644 release/src/router/radvd/interface.c delete mode 100644 release/src/router/radvd/log.c delete mode 100644 release/src/router/radvd/log.h delete mode 100755 release/src/router/radvd/missing delete mode 100644 release/src/router/radvd/netlink.c delete mode 100644 release/src/router/radvd/netlink.h delete mode 100644 release/src/router/radvd/pathnames.h delete mode 100644 release/src/router/radvd/privsep-bsd44.c delete mode 100644 release/src/router/radvd/privsep-linux.c delete mode 100644 release/src/router/radvd/process.c delete mode 100644 release/src/router/radvd/radvd.8.man delete mode 100644 release/src/router/radvd/radvd.c delete mode 100644 release/src/router/radvd/radvd.conf.5.man delete mode 100644 release/src/router/radvd/radvd.conf.example delete mode 100644 release/src/router/radvd/radvd.h delete mode 100644 release/src/router/radvd/radvdump.8.man delete mode 100644 release/src/router/radvd/radvdump.c delete mode 100644 release/src/router/radvd/recv.c delete mode 100644 release/src/router/radvd/redhat/radvd-tmpfs.conf delete mode 100644 release/src/router/radvd/redhat/radvd.conf.empty delete mode 100644 release/src/router/radvd/redhat/radvd.init delete mode 100644 release/src/router/radvd/redhat/radvd.spec delete mode 100644 release/src/router/radvd/redhat/radvd.sysconfig delete mode 100644 release/src/router/radvd/scanner.l delete mode 100644 release/src/router/radvd/send.c delete mode 100644 release/src/router/radvd/socket.c delete mode 100644 release/src/router/radvd/timer.c delete mode 100644 release/src/router/radvd/util.c delete mode 100755 release/src/router/radvd/ylwrap diff --git a/release/src/router/Makefile b/release/src/router/Makefile index 50ae9c1632..7f281387fc 100644 --- a/release/src/router/Makefile +++ b/release/src/router/Makefile @@ -101,7 +101,8 @@ obj-$(NEED_SAMBA2) += samba obj-$(NEED_SAMBA3) += samba3 obj-$(TCONFIG_NTFS) += ntfs-3g obj-$(TCONFIG_EBTABLES) += ebtables -obj-$(TCONFIG_IPV6) += radvd +#obj-$(TCONFIG_IPV6) += libdaemon +#obj-$(TCONFIG_IPV6) += radvd obj-$(TCONFIG_IPV6) += dhcpv6 obj-$(TCONFIG_MEDIA_SERVER) += zlib @@ -886,24 +887,6 @@ usbmodeswitch-install: usbmodeswitch usbmodeswitchdb-install @mkdir -p $(TARGETDIR)/rom/etc @sed 's/#.*//g;s/[ \t]\+/ /g;s/^[ \t]*//;s/[ \t]*$$//;/^$$/d' < $(TOP)/usbmodeswitch/usb_modeswitch.conf > $(TARGETDIR)/rom/etc/usb_modeswitch.conf - -radvd/stamp-h1: - cd radvd && CFLAGS="-Os $(EXTRACFLAGS) -ffunction-sections -fdata-sections" \ - LDFLAGS="-ffunction-sections -fdata-sections -Wl,--gc-sections" \ - $(CONFIGURE) --prefix="" - @$(MAKE) -C radvd clean - @touch radvd/stamp-h1 - -radvd: radvd/stamp-h1 - -radvd-clean: - -@$(MAKE) -C radvd distclean - @rm -f radvd/stamp-h1 - -radvd-install: radvd - install -D radvd/radvd $(INSTALLDIR)/radvd/usr/sbin/radvd - $(STRIP) $(INSTALLDIR)/radvd/usr/sbin/radvd - dhcpv6/stamp-h1: @cd dhcpv6 && \ CFLAGS="-Os -Wall $(EXTRACFLAGS) -D_GNU_SOURCE -ffunction-sections -fdata-sections" \ diff --git a/release/src/router/radvd/CHANGES b/release/src/router/radvd/CHANGES deleted file mode 100644 index e48b9663ce..0000000000 --- a/release/src/router/radvd/CHANGES +++ /dev/null @@ -1,521 +0,0 @@ -19/08/2011 uClibc has no ifaddrs.h patch by Lonnie - slight changes to debugging output when receiving ra's and rs's - -14/05/2011 Version 1.8 release - -10/05/2011 removed AdvRDNSSPreference and AdvRDNSSOpen from the manpages - -06/05/2011 - IgnoreIfMissing now defaults to on - - Fixed inf loop in Base6Interface (from Ludwig Nussel) - - Modified string regex in scanner.l reducing the compiled - size of scanner.o by a factor or 10. - -04/05/2011 - radvd is useful for advertising ULA's without having a - router too (from Ludwig Nussel) - - Bumping version number to 1.8alpha in VERSION for testing - -28/04/2011 Adding DecrementLifetimes patch (from Mark Smith) - -25/03/2011 Renaming RemoveRoute to FlushRoute (from Mark Smith) - -22/03/2011 Adding RemoveRoute options (from Mark Smith) - -20/03/2011 Added DeprecatePrefix option (from Mark Smith) - -28/02/2011 fixed Debian Bug#615625: radvd: Error in DNSSL parsing - -26/02/2011 Added Base6Interface option - -30/01/2011 Added detailed output to radvd --help for the long options. - Two sigterms or sigints calls abort. - build system cleanup work. - -22/01/2011 Fixed crash and memory leak in device-bsd44.c when an - interface defined in the config file doesn't exist. - Patch submitted by Manual Kasper. - -12/01/2011 Release 1.7. - -07/01/2011 make dist (for building tar.gz source packages) fixed. - - 07/01: AdvSourceLLAddress fixed on FreeBSD when link - layer token length is zero. - -14/12/2010 Deprecate old, pre-RFC5006 parameters. - Support RFC6106 by adding DNS Search List support. - From Pierre Ossman. - -14/12/2010 Integrate cleanup patches from Reuben Hawkins: - - 14/05: patch configure.in to allow OSX 10.6 builds - - 05/06: Unnecessary >255 test when using uint8_t - - 06/06: fix fscanf parsing on Linux - - 10/12: Fix whitespaces; #includes; CLEANFILES - From Ben Greear: - - 05/11: Print errors on all exit() codepaths. - From Iain J. Watson: - - 09/12: Add '-c' flag to test configuration. - From Pierre Ossman (idea): - - 13/12: Remove automake-generated files. - -04/05/2010 Fix a segmentation fault on reload_config() timer list - corruption that only occurs with multiple interfaces. - -10/03/2010 Fix radvd skipping multiple interfaces when - UnicastOnly is on or AdvSendAdvert is off. - This got broken in radvd 1.3. Patch from Cedric BAIL. - -05/03/2010 Release 1.6. - -05/03/2010 Update Redhat spec and init files from Fedora. - -28/01/2010 Decrease MSG_SIZE from 4096 to about 1500B. Send buffer - uses a smaller size in order to avoid sending out - fragmented packets, yet being able to receive full-size - frames. - -28/01/2010 Keep track of buffer size and exit if the number of - prefixes/routes/etc. would grow too much. Prevent a memory - corruption due to wrong memset. Patches from Jan - Görig, Red Hat bug #554125. - -22/01/2010 On BSD use getifaddrs() also in setup_deviceinfo(), - fixes a multiple interfaces problem on NetBSD 5 due to - change in data structures. Patch from Michael Stapelberg. - -07/11/2009 Allow radvd.conf prefix, clients, route, and RDNSS options - to be in any order. Patch from Michael Stapelberg. - -10/09/2009 Release 1.5. - -07/09/2009 Fix infinite loop/segmentation fault problems when cable - plugged out/plugged back in, caused by reload_config() - and subsequent timer list corruption. Slightly modified - patch from Teemu Torma. For more information, see - http://lists.litech.org/pipermail/radvd-devel-l/2009-August/000416.html - -07/09/2009 Fix IgnoreIfMissing when cable is unplugged at startup. - Radvd would keep skipping the interface. Patch from - Reuben Hawkins. - -25/08/2009 Fix parallel make, from Robert Buchholz / Gentoo. - -03/08/2009 Release 1.4. Only restores original behaviour changed in - 1.3: RAs were accidentally often unicast to solicitors - instead of being multicast. - -07/07/2009 Release 1.3. - -24/06/2009 Work around unaligned traps on Alpha, patch from: - http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=456205 - -19/06/2009 Fixes and enhancements from Michael Stapelberg. Add a new - 'clients' interface definition to allow configuring which - address to send advertisements and accept from. Use - getifaddrs() on BSD because ioctl didn't work on NetBSD 5. - Use int instead of bool to make NetBSD 5 happy. - -21/01/2009 Add a workaround for Linux in scenarios where libc is - providing IPV6_RECV(PKTINFO|HOPLIMIT) has renumbered IPV6_PKTINFO, - but kernel doesn't support it yet (<2.6.14). Found out by - Freetz (special thanks to Paul Oranje) and OpenWrt projects. - See the source code and CVS changelog for more. - -28/10/2008 Release 1.2. - -14/10/2008 Accept virtually any interface name (up to 15 chars) instead of - forcing a specific naming convention. Patch from - Michiel Brandenburg. - - If stale radvd.pid file exists, try to overwrite it unless - the specified PID exists, from Fedora (Martin Nagy). - - Define _GNU_SOURCE on Linux, otherwise glibc >= 2.8 - compilation fails. - - Remove -Wconversion from default CFLAGS as it is very noisy. - Fix some warnings, from Jim Paris. - -31/03/2008 Update references to RFCs. Give pointer to the "two hour rule". - Decrease the default valid and preferred lifetimes from 30/1 - days to 1day/4hours, respectively. See more info at: - - http://lists.litech.org/pipermail/radvd-devel-l/2007-October/000282.html - -04/02/2008 Release 1.1. - -24/01/2008 Implement privilege separation (Linux only) so that - config_interface() works both with a user and root, - even after HUP signal. Work by Jim Paris. - -24/01/2008 The old Linux retrans_timer proc value is given in - USER_HZ, not in seconds. Fix that, by Jim Paris. - -21/01/2008 Fix stderr+syslog logging crash (on non-i386). Analysis and - patch by Jim Paris (Debian bug #409600). - -01/12/2007 Require that interface is also 'RUNNING' instead of just - 'UP', except if IgnoreIfMissing is enabled. The reason is - that at least some recent Linux kernels do not generate - link-local addresses before interface is running and as - a result, the startup may fail if network cable is unplugged - in any case. - - Note: this could break deployments with some very old - kernels, see more info at: - - http://lists.litech.org/pipermail/radvd-devel-l/2007-October/000280.html - -25/10/2007 Implement automatically selecting and advertising an - interface address, see radvd.conf(5) for more. Add - a warning about not being able to set interface - variables with non-root user. Relax interface naming - a bit. - -25/06/2007 Send prefix, route and RDNSS options (matters if there - are many RDNSS options) in the same order they appear - in the configuration; add support for AdvDefaultLifetime - in radvdump (patches from C. Scott Ananian) - -11/01/2006 Release 1.0. - -10/09/2006 Perform a static/dynamic code audit; plug some minor - bugs (see CVS changelogs for more information) and - perform minor clean-up. - -08/07/2006 Implement MAX_INITIAL_RTR_ADVERT_INTERVAL handling, - patch from Yoshifuji Hideaki / USAGI. - -05/23/2006 Unblock SIGALRM signals at startup. Some scripts/programs - seem to run radvd from ALRM-blocked context which breaks - the timers. - -05/23/2006 Redefined IgnoreIfMissing: by default, radvd will now - try to reinitialize failed interfaces automatically. - IgnoreIfMissing is still needed if radvd is started when the - interface isn't up, and it also quenches some messages - relating to missing interfaces. - -03/29/2006 Implement RDNSS draft, using non-allocated - IANA ND type value 25, by Lauréline Provost, - Mickaël Guérin, Adrien Clerc, Gaetan Eleouet, - Bahattin Demirplak, Lionel Guilmin (at the - ENSEEIHT, Toulouse) - -03/06/2006 Fix the default STDERR+syslog logging methods, so - we don't try to unnecessarily log to STDERR after - forking. - -01/18/2006 radvd-0.9.1 did not initialize AdvDefaultLifetime (etc.) - appropriately, unbreak the "clean-up". - -01/13/2006 Release 0.9.1. - -12/30/2005 Great cleanup of signed/unsigned values, add - -Wall and a number of other warnings to CFLAGS - by default. Do not allow signed values for - HomeAgentPreference anymore. - -12/30/2005 Fix a couple of IPv6 Ready Logo Phase-2 IPv6 Core - Protocols Self Test issues, patches from Yoshifuji - Hideaki / USAGI. - -11/13/2005 Create a short FAQ in README file. - -10/28/2005 Get interface MTU automatically, so that you can - use jumboframes and advertise MTU >1500. - -10/19/2005 Release 0.9. - -10/18/2005 Transfer sole maintainership of radvd to Pekka Savola. - -10/18/2005 Make the radvd.conf syntax dump default - in radvdump and remove the previous default to - reduce code duplication. - -09/28/2005 Add NEMO Basic support (RFC3961) and fix default - HomeAgentLifetime, from Ville Nuorvala. - -08/18/2005 Implement more robust timer handler, especially - because some Linux kernels don't seem to behave - all that well; see http://lkml.org/lkml/2005/4/29/163. - Based on extensive testing & reports by - Tomasz Grobelny. NB: the bug report was caused by - a bad timer patch in PLD's kernel package, and this - should not occur often with standard kernels. - -07/24/2005 Implement a new logging method "stderr_syslog" which is - now also the default. Everything is logged on syslog, - while the most important messages (i.e., start-up failures) - are also logged on stderr. - -07/08/2005 Release 0.8. - -07/05/2005 Change the more-specific route ND option code - from de-facto '9' to the official '24'. Change - back in defaults.h if you need old behaviour. - -07/05/2005 Fix wrongly calculated prefix with Base6to4Interface - on ppc and maybe other big endian arches, from - Debian #301543 by Sam Hathaway. - -07/05/2005 Fix Linux-2.6.12-bk4+ error with HUP signal, - from YOSHIFUJI Hideaki / USAGI. - -03/29/2005 Merge a part of MIPv6/non-MIPv6 code, make printing - error messages nicer. - -03/22/2005 Be a bit more informative about config file parsing - errors. - -02/21/2005 Release 0.7.3. - -02/19/2005 Fix crash when reloading config with AdvSendAdvert off. - -02/15/2005 Merge a few fixes and improvements from USAGI: - - support microsecond scheduling and fix RA intervals - - send zero router lifetime when forwarding is disabled - - use a more flexible inter-RA delay - -01/07/2005 Accomodate interface indexes > 9999, from Hagen Fritsch. - -12/15/2004 Advertise zero Router Lifetime when shutting down; - implements a SHOULD in RFC2461 section 6.2.5. - -10/16/2004 Update Mobile IPv6 to match RFC 3775, from Greg Daley. - -08/20/2004 Minor documentation cleanups. - -03/09/2004 Implement "IgnoreIfMissing" interface flag, which can be - used on interfaces which aren't enabled when radvd starts - but will later become available (e.g., Bluetooth) -- - and then you wish to send HUP to radvd to activate the - configs. - -02/21/2004 Further cleanups, to fix autoconf/autoheader problems - with newer toolchain; mostly by Marko Myllynen. - -02/20/2004 Clean up a bit: remove old junk from configure.in, - rename "log()" to "flog()" to satisfy newer GCCs, - allow underscores in the interface names (the last two - fixes already committed earlier). - -01/19/2004 Make radvd check for forwarding status using procfs on - Linux; needed with 2.6 kernels. Loosely based on - a patch by USAGI. - -11/21/2003 Add support for Router Preferences and More Specific - Routes from Markku Savela . - NOTE! The specification is not final yet, there will be - changes! (Man page, documentation and radvdump support - by Pekka Savola.) - -09/11/2003 When starting up, check if the MAC address is all zero - (could happen e.g. with bridge interfaces with no attached - physical interfaces), and warn if so. For more information, - http://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=103469 - -06/10/2003 When chrooting, check the possible return code - from chdir("/"). - -03/08/2003 Add patch from MAEDA Naoaki - to discard RS's from the unspecied source address with - link-layer address option, as required by RFC2461. - -10/28/2002 Release 0.7.2: - - add support for VLANs (from USAGI) - - make it compile better on newer NetBSD's (NetBSD) - - fix a syntax error in radvd.conf(5) sample documentation - - use IPV6_RECV{HOPLIMIT,PKTINFO} not - IPV6_{HOPLIMIT,PKTINFO} if supported - - (in Red Hat spec file) don't create radvd gid explicitly - - a lot of coding style cleanups - -01/16/2002 Release 0.7.1. - -01/12/2002 Update config.{guess,sub} from ftp.gnu.org; update INTRO. - Marko Myllynen and Debian bug #115992. - -01/02/2002 Ensure NULL-termination with strncpy. - -12/31/2001 Radvdump fixes: eliminate a warning of Prefix Information - sections with '-d -f'; add a note that - {Min,Max}RtrAdvInterval cannot be obtained with '-f'; - implement '-e' to be used with '-f' which omits all - advertised default settings. Mostly by Marko Myllynen. - -12/28/2001 Small cleanups. AdvSendAdvert is implicitly off by - default. Check configuration file permissions; must - not be writable by others, and if non-root, - not by self/own group. By Marko Myllynen. - -12/21/2001 Check via sysctl that IPv6 forwarding is enabled; - exit unless debugging is enabled. Triggered by - Marko Myllynen. - -11/22/2001 MinRtrAdvInterval for MIPv6 is 0.05 seconds, not 0.5. - (Note: untested). - -11/20/2001 Rework BSD device memory management a bit, minor cleanups. - Version bumped to 0.7.0. - -11/14/2001 Maintainership of radvd transferred from Lars Fenneberg - to Pekka Savola and Nathan Lutchansky. Lars' CVS - repository adopted, and changes merged from the -pX - branch. - -08/29/2001 Minor change for NetBSD 1.5.1 compatibility. - (Nathan Lutchansky) - -07/20/2001 Support for non-multicast links, like ISATAP. - (Nathan Lutchansky) - -07/03/2001 Minimum MTU has been changed to 1280 in the latest RFC's. - (Pekka Savola) - -06/30/2001 Check for possible buffer overflows; replace strcpy with - strncpy. No fatals found. Remove redunant radvd -t check. - (Pekka Savola) - -06/24/2001 Fix 1-byte overflow in /proc/net/igmp6 handling, - clean out possible memory garbage when sending RA's - (patch from ). - -06/19/2001 When dropping root, also set up supplementary groups - properly. On Linux, when sending RA's, check that the - interface has joined all-routers multicast group. Add a few - RFC2461 MUST sanity checks when receiving datagrams. Clean - out non-EUI64 addressing scheme and other minor bits. - (Pekka Savola) - -04/28/2001 Misc cleanup and bugfixes, automake support. - -03/28/2001 Grammar cleanup. Integrated 6to4 support through - "Base6to4Interface" option in prefix configuration. Signal - handling fixed by blocking on select() rather than recvmsg() - so SIGTERM/HUP take effect immediately now. (Nathan Lutchansky) - -03/27/2001 Security fixes: close stdin/out and chdir("/") via - daemon() to prevent possible exploits, and a flag to allow - radvd to set[ug]id to an unprivileged user (from Pekka Savola). - -02/01/2001 scope_id is not supported in glibc2.1. So it is now - compiled conditionally. - -01/31/2001 Add CC variable to Makefile. Fix bug with IPV6_ADD_MEMBERSHIP - handling. Set scope_id when sending packets. - -12/02/2000 man pages update, rewritten pid file handling, rewritten - signal handling (SIGHUP and SIGTERM), gcc warnings cleanup, - new radvdump option -f: print received RAs in config file - format (by Marko) - -11/19/2000 integrated the last two change entries into the main source - (patches by Marko Myllynen), fixed bug in log.c, fixed file - description leak in readin_config, rewrote code in timer.c, - updated man pages again (from Marko Myllynen, too), PID - file support (patch from Marko Myllynen, based on a patch - from Tommi.Komulainen@iki.fi) - -15/08/2000 RFC 2461 updates, Mobile IPv6 extensions added - -14/07/2000 added RA interval option and modified some default values - for timers - -06/15/99 changed to run with glibc 2.1 on RedHat 6.0. - -03/03/98 radvd now joins ipv6-allrouters on Linux. Fix contributed - by A.N.Kuznetsov . - -10/23/97 radvd will now accept any prefix length in its config - file but will warn about unusual ones - -10/19/97 removed backwards compatibility code in recv.c. - IPV6_HOPLIMIT support is now assumed to exist. - -10/19/97 fixed alignment problems in recv.c and send.c. - -10/16/97 the Makefile install target now uses mkinstalldirs. - -10/16/97 changed all u_int*_t to uint*_t for better POSIX - compliance and portability. Needs 2.1.57-CVS or glibc. - BSD seems to need patches. - -10/16/97 more intelligent configure; tries to figure out - where the IPv6 libraries and inclues are (if not in - the standard places). Searches in /usr/inet6 and /usr/ipv6. - -10/15/97 integrated small patches for glibc and BSD from Craig and - Philip - -09/14/97 EUI-64 "support" - -09/01/97 centralized all includes into includes.h for easier - maintainance - -08/25/97 changed all occurences of IPV6_TXINFO/IPV6_RXINFO - to IPV6_PKTINFO - -08/25/97 removed some compatibility stuff for older Linux kernels - -03/17/97 changed linux/if_arp.h to net/if_arp.h in device-linux.c - and configure.in (for glibc compatibility) - -03/17/97 integrated patch from Philip Blundell - into configure.in to check for inet_* in libc first and - then for libinet6 (for glibc compatibility). - -03/16/97 corrected small error in radvd.conf(5) man page and other - small changes - -03/16/97 removed linklocal.c source file from the distribution - because it wasn't used anymore - -03/16/97 added html version of the INTRO, removed ascii version. - -02/12/97 missing directories are now created on make install - -01/19/97 now also the rest of a line followed by a '#' is treated - as a comment in the config file - -01/16/97 added IPPROTO_IPV6/IPV6_HOPLIMIT support, so now incoming - RS' and RAs are checked if there hoplimit is 255 (on Linux - this only works with kernel version 2.1.21 and above) - -01/15/97 lots of portability cleanups; radvd is now using autoconf - for automatic configuration; removed support for the - in. prefix - -01/05/97 integrated BSD 4.4 patches from Craig - -12/21/96 release of version 0.3 - -12/15/96 the AdvSendAdvert flag works now - -12/14/96 added radvdump, dumps all received RAs in a human - readable form - -12/13/96 rewrote radvd to use new advanced API headers - -12/08/96 added radvd.conf(5) man page - -12/03/96 changed RAW_CHECKSUM to IPV6_CHECKSUM for kernels - 2.1.14 and above - -11/24/96 added checking of received RAs according to RFC 1970 - -11/20/96 rewrote the default handling, now it should conform - to RFC 1970 - -11/17/96 release of version 0.2 - -11/17/96 added -h (--help) and -f (--facility) option - -11/17/96 added setsockopt(..., SOL_IPV6, IPV6_MULTICAST_HOPS), so - that radvd works for kernel versions >2.1.7 (without this - you get "NDISC: fake router advertisment received" on your - hosts) - -11/17/96 added a man page for radvd(8) - -11/17/96 some minor filename changes - -11/13/96 first release of this version of in.radvd (0.1) diff --git a/release/src/router/radvd/COPYRIGHT b/release/src/router/radvd/COPYRIGHT deleted file mode 100644 index 1f464b0668..0000000000 --- a/release/src/router/radvd/COPYRIGHT +++ /dev/null @@ -1,37 +0,0 @@ - The author(s) grant permission for redistribution and use in source and -binary forms, with or without modification, of the software and documentation -provided that the following conditions are met: - -0. If you receive a version of the software that is specifically labelled - as not being for redistribution (check the version message and/or README), - you are not permitted to redistribute that version of the software in any - way or form. -1. All terms of all other applicable copyrights and licenses must be - followed. -2. Redistributions of source code must retain the authors' copyright - notice(s), this list of conditions, and the following disclaimer. -3. Redistributions in binary form must reproduce the authors' copyright - notice(s), this list of conditions, and the following disclaimer in the - documentation and/or other materials provided with the distribution. -4. All advertising materials mentioning features or use of this software - must display the following acknowledgement with the name(s) of the - authors as specified in the copyright notice(s) substituted where - indicated: - - This product includes software developed by the authors which are - mentioned at the start of the source files and other contributors. - -5. Neither the name(s) of the author(s) nor the names of its contributors - may be used to endorse or promote products derived from this software - without specific prior written permission. - -THIS SOFTWARE IS PROVIDED BY ITS AUTHORS AND CONTRIBUTORS ``AS IS'' AND ANY -EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED -WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE -DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR ANY -DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES -(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON -ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS -SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/release/src/router/radvd/INTRO.html b/release/src/router/radvd/INTRO.html deleted file mode 100644 index f98752c8f9..0000000000 --- a/release/src/router/radvd/INTRO.html +++ /dev/null @@ -1,142 +0,0 @@ - - - - - -RADVD Introduction - - - -

RADVD Introduction

- -

-by Lars Fenneberg et al. Updated -2002-01-12. -

- -

-IPv6 has a lot more -support for autoconfiguration than -IPv4. But for this -autoconfiguration to work on the hosts of a network, the routers -of the local network have to run a program which answers the -autoconfiguration requests of the hosts. -

- -

-On Linux this program is called -radvd, which stands for -Router ADVertisement Daemon. This daemon listens to Router Solicitations -(RS) and answers with Router Advertisement (RA). Furthermore unsolicited -RAs are also send from time to time. -RFC 4861 defines most -functions of radvd. -

- -

-Router Advertisements contain information, which is used by hosts to -configure their interfaces. This information includes address prefixes, -the MTU of the link and information about default routers. -

- -

-Of course the routers can't autoconfigure themselves, so the information -on the routers has to be provided by the administrator of the system. -This is done by manually configuring the interfaces and routes and by -configuring the router advertisement daemon. -

- -

-A small and simple configuration file for radvd might look like this: -

- -

-

-
-interface eth0
-{
-        AdvSendAdvert on;
-        prefix 2001:db8:0:1::/64
-        {
-                AdvOnLink on;
-                AdvAutonomous on;
-        };
-};
-
-
- -

-It says that radvd should advertise (AdvSendAdvert on) the prefix -2001:db8:0:1:: which has a lenght of 64 on the interface eth0. -Also the prefix is marked as autonomous (AdvAutonomous on) and as on-link -(AdvOnLink on). The both currently default to enabled but are included -here for introductory purposes; it isn't necessary to define them. -All the other options are left on their default values. -

- -

-Autonomous means that the prefix can be used for automatic address -configuration and on-link means that the hosts can assume that all the hosts -which use this prefix are reachable via the interface on which the host -received this RA. -

- -

-The prefix must be 64 bits long (apart from very few exceptions), as dictated by -RFC 2464 and other -standards for different link-layer technologies. For more -details, see RFC 4862 -(IPv6 Stateless Address Autoconfiguration) and -RFC 2464 -(Transmission of IPv6 Packets over Ethernet Networks). For more information -on configuring radvd please look at the manual pages which are included in -the radvd distribution. -

- -

-So, when an interface on a hosts is UPed and a RA is received, the host -can configure an address on the interface by using the prefix and -appending the EUI-64 identifier derived from the hardware address -(also called link-layer token). The EUI-64 identifier is simply appended -after the prefix. For example: -

- -

-

-
-   Announced prefix:    2001:db8:0:1::
-
-   MAC address:         00:07:E9:7B:02:59
-
-   EUI-64 identifier:   0207:e9ff:fe7b:259
-
-   Configured address:  2001:db8:0:1:207:e9ff:fe7b:259
-
-
- -

-The host can also choose a default router by examining the RA. -the rest works automatically. -

- -

-So now we've configured radvd, but we still need to configure the interfaces -and set the routes (on the router). There's a lot of good material on -setting up IPv6, and the reader is encouraged to have a look -at it; for example: -

- -

-

- -
- -

-Copyright © 1997 Lars Fenneberg -

- - - diff --git a/release/src/router/radvd/Makefile.am b/release/src/router/radvd/Makefile.am deleted file mode 100644 index cc84f9f67f..0000000000 --- a/release/src/router/radvd/Makefile.am +++ /dev/null @@ -1,133 +0,0 @@ -# -# $Id: Makefile.am,v 1.22 2011/05/09 11:04:12 psavola Exp $ -# -# Authors: -# Lars Fenneberg -# -# This software is Copyright 1996,1997 by the above mentioned author(s), -# All Rights Reserved. -# -# The license which is distributed with this software in the file COPYRIGHT -# applies to this software. If your distribution is missing this file, you -# may request it from . -# - -AUTOMAKE_OPTIONS = 1.2 foreign - -DEFS = \ - -DINET6=1 \ - -DLOG_FACILITY=$(LOG_FACILITY) \ - -DPATH_RADVD_CONF=\"$(PATH_RADVD_CONF)\" \ - -DPATH_RADVD_LOG=\"$(PATH_RADVD_LOG)\" \ - -DPATH_RADVD_PID=\"$(PATH_RADVD_PID)\" \ - -DVERSION=\"$(VERSION)\" - -INCLUDES = \ - -I$(srcdir) \ - -I. - -COMMON_SRC = \ - defaults.h \ - includes.h \ - log.c \ - log.h \ - pathnames.h \ - radvd.h \ - recv.c \ - socket.c \ - util.c - -sbin_PROGRAMS = \ - radvd \ - radvdump - -radvd_SOURCES = \ - $(COMMON_SRC) \ - device-common.c \ - gram.h \ - gram.y \ - interface.c \ - process.c \ - radvd.c \ - scanner.l \ - send.c \ - timer.c - -EXTRA_radvd_SOURCES = \ - device-bsd44.c \ - device-linux.c \ - netlink.c \ - netlink.h \ - privsep-bsd44.c \ - privsep-linux.c - -radvd_LDADD = \ - @CONDITIONAL_SOURCES@ - -radvd_DEPENDENCIES = \ - @CONDITIONAL_SOURCES@ - -AM_YFLAGS = -d - -AM_CFLAGS = \ - -Wall \ - -Wcast-align \ - -Wcast-qual \ - -Wpointer-arith \ - -Wmissing-declarations \ - -Wmissing-prototypes \ - -Wno-strict-aliasing \ - -Wstrict-prototypes - -radvdump_SOURCES = \ - $(COMMON_SRC) \ - radvdump.c - -man_MANS = \ - radvd.8 \ - radvd.conf.5 \ - radvdump.8 - -EXTRA_DIST = \ - CHANGES \ - COPYRIGHT \ - INTRO.html \ - VERSION \ - copyright.blurb \ - radvd.8.man \ - radvd.conf.5.man \ - radvd.conf.example \ - radvdump.8.man \ - redhat/radvd.conf.empty \ - redhat/radvd.init \ - redhat/radvd.spec \ - redhat/radvd.sysconfig \ - redhat/radvd-tmpfs.conf - -CLEANFILES = \ - gram.c \ - gram.h \ - radvd.8 \ - radvd.conf.5 \ - radvdump.8 \ - scanner.c - -SUFFIXES = .man - -.man: - $(AM_V_GEN)$(SED) \ - -e 's,@''VERSION''@,$(VERSION),g' \ - -e 's,@''sbindir''@,$(sbindir),g' \ - -e 's,@''PATH_RADVD_CONF''@,$(PATH_RADVD_CONF),g' \ - -e 's,@''PATH_RADVD_PID''@,$(PATH_RADVD_PID),g' \ - -e 's,@''PATH_RADVD_LOG''@,$(PATH_RADVD_LOG),g' \ - -e 's,@''LOG_FACILITY''@,$(LOG_FACILITY),g' \ - $< > $@ - -dist-hook: - rm -f $(distdir)/gram.c - rm -f $(distdir)/gram.h - rm -f $(distdir)/scanner.c - -scanner.o: gram.h - diff --git a/release/src/router/radvd/Makefile.in b/release/src/router/radvd/Makefile.in deleted file mode 100644 index 1cebfc3a3b..0000000000 --- a/release/src/router/radvd/Makefile.in +++ /dev/null @@ -1,925 +0,0 @@ -# Makefile.in generated by automake 1.11.1 from Makefile.am. -# @configure_input@ - -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation, -# Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -@SET_MAKE@ - -# -# $Id: Makefile.am,v 1.22 2011/05/09 11:04:12 psavola Exp $ -# -# Authors: -# Lars Fenneberg -# -# This software is Copyright 1996,1997 by the above mentioned author(s), -# All Rights Reserved. -# -# The license which is distributed with this software in the file COPYRIGHT -# applies to this software. If your distribution is missing this file, you -# may request it from . -# - -VPATH = @srcdir@ -pkgdatadir = $(datadir)/@PACKAGE@ -pkgincludedir = $(includedir)/@PACKAGE@ -pkglibdir = $(libdir)/@PACKAGE@ -pkglibexecdir = $(libexecdir)/@PACKAGE@ -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -build_triplet = @build@ -host_triplet = @host@ -target_triplet = @target@ -sbin_PROGRAMS = radvd$(EXEEXT) radvdump$(EXEEXT) -subdir = . -DIST_COMMON = README $(am__configure_deps) $(srcdir)/Makefile.am \ - $(srcdir)/Makefile.in $(srcdir)/config.h.in \ - $(top_srcdir)/configure TODO config.guess config.sub depcomp \ - gram.c gram.h install-sh missing scanner.c ylwrap -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/configure.in -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ - $(ACLOCAL_M4) -am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ - configure.lineno config.status.lineno -mkinstalldirs = $(install_sh) -d -CONFIG_HEADER = config.h -CONFIG_CLEAN_FILES = -CONFIG_CLEAN_VPATH_FILES = -am__installdirs = "$(DESTDIR)$(sbindir)" "$(DESTDIR)$(man5dir)" \ - "$(DESTDIR)$(man8dir)" -PROGRAMS = $(sbin_PROGRAMS) -am__objects_1 = log.$(OBJEXT) recv.$(OBJEXT) socket.$(OBJEXT) \ - util.$(OBJEXT) -am_radvd_OBJECTS = $(am__objects_1) device-common.$(OBJEXT) \ - gram.$(OBJEXT) interface.$(OBJEXT) process.$(OBJEXT) \ - radvd.$(OBJEXT) scanner.$(OBJEXT) send.$(OBJEXT) \ - timer.$(OBJEXT) -radvd_OBJECTS = $(am_radvd_OBJECTS) -am_radvdump_OBJECTS = $(am__objects_1) radvdump.$(OBJEXT) -radvdump_OBJECTS = $(am_radvdump_OBJECTS) -radvdump_LDADD = $(LDADD) -DEFAULT_INCLUDES = -I.@am__isrc@ -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -am__mv = mv -f -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ - $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -AM_V_CC = $(am__v_CC_$(V)) -am__v_CC_ = $(am__v_CC_$(AM_DEFAULT_VERBOSITY)) -am__v_CC_0 = @echo " CC " $@; -AM_V_at = $(am__v_at_$(V)) -am__v_at_ = $(am__v_at_$(AM_DEFAULT_VERBOSITY)) -am__v_at_0 = @ -CCLD = $(CC) -LINK = $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@ -AM_V_CCLD = $(am__v_CCLD_$(V)) -am__v_CCLD_ = $(am__v_CCLD_$(AM_DEFAULT_VERBOSITY)) -am__v_CCLD_0 = @echo " CCLD " $@; -LEXCOMPILE = $(LEX) $(LFLAGS) $(AM_LFLAGS) -AM_V_LEX = $(am__v_LEX_$(V)) -am__v_LEX_ = $(am__v_LEX_$(AM_DEFAULT_VERBOSITY)) -am__v_LEX_0 = @echo " LEX " $@; -YLWRAP = $(top_srcdir)/ylwrap -YACCCOMPILE = $(YACC) $(YFLAGS) $(AM_YFLAGS) -AM_V_YACC = $(am__v_YACC_$(V)) -am__v_YACC_ = $(am__v_YACC_$(AM_DEFAULT_VERBOSITY)) -am__v_YACC_0 = @echo " YACC " $@; -AM_V_GEN = $(am__v_GEN_$(V)) -am__v_GEN_ = $(am__v_GEN_$(AM_DEFAULT_VERBOSITY)) -am__v_GEN_0 = @echo " GEN " $@; -SOURCES = $(radvd_SOURCES) $(EXTRA_radvd_SOURCES) $(radvdump_SOURCES) -DIST_SOURCES = $(radvd_SOURCES) $(EXTRA_radvd_SOURCES) \ - $(radvdump_SOURCES) -am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; -am__vpath_adj = case $$p in \ - $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ - *) f=$$p;; \ - esac; -am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; -am__install_max = 40 -am__nobase_strip_setup = \ - srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` -am__nobase_strip = \ - for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" -am__nobase_list = $(am__nobase_strip_setup); \ - for p in $$list; do echo "$$p $$p"; done | \ - sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ - $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ - if (++n[$$2] == $(am__install_max)) \ - { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ - END { for (dir in files) print dir, files[dir] }' -am__base_list = \ - sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ - sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' -man5dir = $(mandir)/man5 -man8dir = $(mandir)/man8 -NROFF = nroff -MANS = $(man_MANS) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -distdir = $(PACKAGE)-$(VERSION) -top_distdir = $(distdir) -am__remove_distdir = \ - { test ! -d "$(distdir)" \ - || { find "$(distdir)" -type d ! -perm -200 -exec chmod u+w {} ';' \ - && rm -fr "$(distdir)"; }; } -DIST_ARCHIVES = $(distdir).tar.gz -GZIP_ENV = --best -distuninstallcheck_listfiles = find . -type f -print -distcleancheck_listfiles = find . -type f -print -ACLOCAL = @ACLOCAL@ -AMTAR = @AMTAR@ -AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ -AUTOCONF = @AUTOCONF@ -AUTOHEADER = @AUTOHEADER@ -AUTOMAKE = @AUTOMAKE@ -AWK = @AWK@ -CC = @CC@ -CCDEPMODE = @CCDEPMODE@ -CFLAGS = @CFLAGS@ -CONDITIONAL_SOURCES = @CONDITIONAL_SOURCES@ -CPP = @CPP@ -CPPFLAGS = @CPPFLAGS@ -CYGPATH_W = @CYGPATH_W@ -DEFS = \ - -DINET6=1 \ - -DLOG_FACILITY=$(LOG_FACILITY) \ - -DPATH_RADVD_CONF=\"$(PATH_RADVD_CONF)\" \ - -DPATH_RADVD_LOG=\"$(PATH_RADVD_LOG)\" \ - -DPATH_RADVD_PID=\"$(PATH_RADVD_PID)\" \ - -DVERSION=\"$(VERSION)\" - -DEPDIR = @DEPDIR@ -ECHO_C = @ECHO_C@ -ECHO_N = @ECHO_N@ -ECHO_T = @ECHO_T@ -EGREP = @EGREP@ -EXEEXT = @EXEEXT@ -GREP = @GREP@ -GZIP = @GZIP@ -INSTALL = @INSTALL@ -INSTALL_DATA = @INSTALL_DATA@ -INSTALL_PROGRAM = @INSTALL_PROGRAM@ -INSTALL_SCRIPT = @INSTALL_SCRIPT@ -INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -LDFLAGS = @LDFLAGS@ -LEX = @LEX@ -LEXLIB = @LEXLIB@ -LEX_OUTPUT_ROOT = @LEX_OUTPUT_ROOT@ -LIBOBJS = @LIBOBJS@ -LIBS = @LIBS@ -LN = @LN@ -LOG_FACILITY = @LOG_FACILITY@ -LTLIBOBJS = @LTLIBOBJS@ -MAKEINFO = @MAKEINFO@ -MKDIR_P = @MKDIR_P@ -OBJEXT = @OBJEXT@ -PACKAGE = @PACKAGE@ -PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -PACKAGE_NAME = @PACKAGE_NAME@ -PACKAGE_STRING = @PACKAGE_STRING@ -PACKAGE_TARNAME = @PACKAGE_TARNAME@ -PACKAGE_URL = @PACKAGE_URL@ -PACKAGE_VERSION = @PACKAGE_VERSION@ -PATH_RADVD_CONF = @PATH_RADVD_CONF@ -PATH_RADVD_LOG = @PATH_RADVD_LOG@ -PATH_RADVD_PID = @PATH_RADVD_PID@ -PATH_SEPARATOR = @PATH_SEPARATOR@ -RM = @RM@ -SED = @SED@ -SET_MAKE = @SET_MAKE@ -SHELL = @SHELL@ -STRIP = @STRIP@ -TAR = @TAR@ -VERSION = @VERSION@ -YACC = @YACC@ -YFLAGS = @YFLAGS@ -abs_builddir = @abs_builddir@ -abs_srcdir = @abs_srcdir@ -abs_top_builddir = @abs_top_builddir@ -abs_top_srcdir = @abs_top_srcdir@ -ac_ct_CC = @ac_ct_CC@ -am__include = @am__include@ -am__leading_dot = @am__leading_dot@ -am__quote = @am__quote@ -am__tar = @am__tar@ -am__untar = @am__untar@ -bindir = @bindir@ -build = @build@ -build_alias = @build_alias@ -build_cpu = @build_cpu@ -build_os = @build_os@ -build_vendor = @build_vendor@ -builddir = @builddir@ -datadir = @datadir@ -datarootdir = @datarootdir@ -docdir = @docdir@ -dvidir = @dvidir@ -exec_prefix = @exec_prefix@ -host = @host@ -host_alias = @host_alias@ -host_cpu = @host_cpu@ -host_os = @host_os@ -host_vendor = @host_vendor@ -htmldir = @htmldir@ -includedir = @includedir@ -infodir = @infodir@ -install_sh = @install_sh@ -libdir = @libdir@ -libexecdir = @libexecdir@ -localedir = @localedir@ -localstatedir = @localstatedir@ -mandir = @mandir@ -mkdir_p = @mkdir_p@ -oldincludedir = @oldincludedir@ -pdfdir = @pdfdir@ -prefix = @prefix@ -program_transform_name = @program_transform_name@ -psdir = @psdir@ -sbindir = @sbindir@ -sharedstatedir = @sharedstatedir@ -srcdir = @srcdir@ -sysconfdir = @sysconfdir@ -target = @target@ -target_alias = @target_alias@ -target_cpu = @target_cpu@ -target_os = @target_os@ -target_vendor = @target_vendor@ -top_build_prefix = @top_build_prefix@ -top_builddir = @top_builddir@ -top_srcdir = @top_srcdir@ -AUTOMAKE_OPTIONS = 1.2 foreign -INCLUDES = \ - -I$(srcdir) \ - -I. - -COMMON_SRC = \ - defaults.h \ - includes.h \ - log.c \ - log.h \ - pathnames.h \ - radvd.h \ - recv.c \ - socket.c \ - util.c - -radvd_SOURCES = \ - $(COMMON_SRC) \ - device-common.c \ - gram.h \ - gram.y \ - interface.c \ - process.c \ - radvd.c \ - scanner.l \ - send.c \ - timer.c - -EXTRA_radvd_SOURCES = \ - device-bsd44.c \ - device-linux.c \ - netlink.c \ - netlink.h \ - privsep-bsd44.c \ - privsep-linux.c - -radvd_LDADD = \ - @CONDITIONAL_SOURCES@ - -radvd_DEPENDENCIES = \ - @CONDITIONAL_SOURCES@ - -AM_YFLAGS = -d -AM_CFLAGS = \ - -Wall \ - -Wcast-align \ - -Wcast-qual \ - -Wpointer-arith \ - -Wmissing-declarations \ - -Wmissing-prototypes \ - -Wno-strict-aliasing \ - -Wstrict-prototypes - -radvdump_SOURCES = \ - $(COMMON_SRC) \ - radvdump.c - -man_MANS = \ - radvd.8 \ - radvd.conf.5 \ - radvdump.8 - -EXTRA_DIST = \ - CHANGES \ - COPYRIGHT \ - INTRO.html \ - VERSION \ - copyright.blurb \ - radvd.8.man \ - radvd.conf.5.man \ - radvd.conf.example \ - radvdump.8.man \ - redhat/radvd.conf.empty \ - redhat/radvd.init \ - redhat/radvd.spec \ - redhat/radvd.sysconfig \ - redhat/radvd-tmpfs.conf - -CLEANFILES = \ - gram.c \ - gram.h \ - radvd.8 \ - radvd.conf.5 \ - radvdump.8 \ - scanner.c - -SUFFIXES = .man -all: config.h - $(MAKE) $(AM_MAKEFLAGS) all-am - -.SUFFIXES: -.SUFFIXES: .man .c .l .o .obj .y -am--refresh: - @: -.PRECIOUS: Makefile - -$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) - $(SHELL) ./config.status --recheck - -$(top_srcdir)/configure: $(am__configure_deps) - $(am__cd) $(srcdir) && $(AUTOCONF) -$(ACLOCAL_M4): $(am__aclocal_m4_deps) - $(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) -$(am__aclocal_m4_deps): - -config.h: stamp-h1 - @if test ! -f $@; then \ - rm -f stamp-h1; \ - $(MAKE) $(AM_MAKEFLAGS) stamp-h1; \ - else :; fi - -stamp-h1: $(srcdir)/config.h.in $(top_builddir)/config.status - @rm -f stamp-h1 - cd $(top_builddir) && $(SHELL) ./config.status config.h - -distclean-hdr: - -rm -f config.h stamp-h1 -install-sbinPROGRAMS: $(sbin_PROGRAMS) - @$(NORMAL_INSTALL) - test -z "$(sbindir)" || $(MKDIR_P) "$(DESTDIR)$(sbindir)" - @list='$(sbin_PROGRAMS)'; test -n "$(sbindir)" || list=; \ - for p in $$list; do echo "$$p $$p"; done | \ - sed 's/$(EXEEXT)$$//' | \ - while read p p1; do if test -f $$p; \ - then echo "$$p"; echo "$$p"; else :; fi; \ - done | \ - sed -e 'p;s,.*/,,;n;h' -e 's|.*|.|' \ - -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \ - sed 'N;N;N;s,\n, ,g' | \ - $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ - { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ - if ($$2 == $$4) files[d] = files[d] " " $$1; \ - else { print "f", $$3 "/" $$4, $$1; } } \ - END { for (d in files) print "f", d, files[d] }' | \ - while read type dir files; do \ - if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ - test -z "$$files" || { \ - echo " $(INSTALL_PROGRAM_ENV) $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(sbindir)$$dir'"; \ - $(INSTALL_PROGRAM_ENV) $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(sbindir)$$dir" || exit $$?; \ - } \ - ; done - -uninstall-sbinPROGRAMS: - @$(NORMAL_UNINSTALL) - @list='$(sbin_PROGRAMS)'; test -n "$(sbindir)" || list=; \ - files=`for p in $$list; do echo "$$p"; done | \ - sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ - -e 's/$$/$(EXEEXT)/' `; \ - test -n "$$list" || exit 0; \ - echo " ( cd '$(DESTDIR)$(sbindir)' && rm -f" $$files ")"; \ - cd "$(DESTDIR)$(sbindir)" && rm -f $$files - -clean-sbinPROGRAMS: - -test -z "$(sbin_PROGRAMS)" || rm -f $(sbin_PROGRAMS) -gram.h: gram.c - @if test ! -f $@; then \ - rm -f gram.c; \ - $(MAKE) $(AM_MAKEFLAGS) gram.c; \ - else :; fi -radvd$(EXEEXT): $(radvd_OBJECTS) $(radvd_DEPENDENCIES) - @rm -f radvd$(EXEEXT) - $(AM_V_CCLD)$(LINK) $(radvd_OBJECTS) $(radvd_LDADD) $(LIBS) -radvdump$(EXEEXT): $(radvdump_OBJECTS) $(radvdump_DEPENDENCIES) - @rm -f radvdump$(EXEEXT) - $(AM_V_CCLD)$(LINK) $(radvdump_OBJECTS) $(radvdump_LDADD) $(LIBS) - -mostlyclean-compile: - -rm -f *.$(OBJEXT) - -distclean-compile: - -rm -f *.tab.c - -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/device-bsd44.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/device-common.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/device-linux.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gram.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/interface.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/log.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/netlink.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/privsep-bsd44.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/privsep-linux.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/process.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/radvd.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/radvdump.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/recv.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/scanner.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/send.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/socket.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/timer.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/util.Po@am__quote@ - -.c.o: -@am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< -@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po -@am__fastdepCC_FALSE@ $(AM_V_CC) @AM_BACKSLASH@ -@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCC_FALSE@ $(COMPILE) -c $< - -.c.obj: -@am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` -@am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po -@am__fastdepCC_FALSE@ $(AM_V_CC) @AM_BACKSLASH@ -@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCC_FALSE@ $(COMPILE) -c `$(CYGPATH_W) '$<'` - -.l.c: - $(AM_V_LEX)$(am__skiplex) $(SHELL) $(YLWRAP) $< $(LEX_OUTPUT_ROOT).c $@ -- $(LEXCOMPILE) - -.y.c: - $(AM_V_YACC)$(am__skipyacc) $(SHELL) $(YLWRAP) $< y.tab.c $@ y.tab.h $*.h y.output $*.output -- $(YACCCOMPILE) -install-man5: $(man_MANS) - @$(NORMAL_INSTALL) - test -z "$(man5dir)" || $(MKDIR_P) "$(DESTDIR)$(man5dir)" - @list=''; test -n "$(man5dir)" || exit 0; \ - { for i in $$list; do echo "$$i"; done; \ - l2='$(man_MANS)'; for i in $$l2; do echo "$$i"; done | \ - sed -n '/\.5[a-z]*$$/p'; \ - } | while read p; do \ - if test -f $$p; then d=; else d="$(srcdir)/"; fi; \ - echo "$$d$$p"; echo "$$p"; \ - done | \ - sed -e 'n;s,.*/,,;p;h;s,.*\.,,;s,^[^5][0-9a-z]*$$,5,;x' \ - -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,' | \ - sed 'N;N;s,\n, ,g' | { \ - list=; while read file base inst; do \ - if test "$$base" = "$$inst"; then list="$$list $$file"; else \ - echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man5dir)/$$inst'"; \ - $(INSTALL_DATA) "$$file" "$(DESTDIR)$(man5dir)/$$inst" || exit $$?; \ - fi; \ - done; \ - for i in $$list; do echo "$$i"; done | $(am__base_list) | \ - while read files; do \ - test -z "$$files" || { \ - echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(man5dir)'"; \ - $(INSTALL_DATA) $$files "$(DESTDIR)$(man5dir)" || exit $$?; }; \ - done; } - -uninstall-man5: - @$(NORMAL_UNINSTALL) - @list=''; test -n "$(man5dir)" || exit 0; \ - files=`{ for i in $$list; do echo "$$i"; done; \ - l2='$(man_MANS)'; for i in $$l2; do echo "$$i"; done | \ - sed -n '/\.5[a-z]*$$/p'; \ - } | sed -e 's,.*/,,;h;s,.*\.,,;s,^[^5][0-9a-z]*$$,5,;x' \ - -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,'`; \ - test -z "$$files" || { \ - echo " ( cd '$(DESTDIR)$(man5dir)' && rm -f" $$files ")"; \ - cd "$(DESTDIR)$(man5dir)" && rm -f $$files; } -install-man8: $(man_MANS) - @$(NORMAL_INSTALL) - test -z "$(man8dir)" || $(MKDIR_P) "$(DESTDIR)$(man8dir)" - @list=''; test -n "$(man8dir)" || exit 0; \ - { for i in $$list; do echo "$$i"; done; \ - l2='$(man_MANS)'; for i in $$l2; do echo "$$i"; done | \ - sed -n '/\.8[a-z]*$$/p'; \ - } | while read p; do \ - if test -f $$p; then d=; else d="$(srcdir)/"; fi; \ - echo "$$d$$p"; echo "$$p"; \ - done | \ - sed -e 'n;s,.*/,,;p;h;s,.*\.,,;s,^[^8][0-9a-z]*$$,8,;x' \ - -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,' | \ - sed 'N;N;s,\n, ,g' | { \ - list=; while read file base inst; do \ - if test "$$base" = "$$inst"; then list="$$list $$file"; else \ - echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man8dir)/$$inst'"; \ - $(INSTALL_DATA) "$$file" "$(DESTDIR)$(man8dir)/$$inst" || exit $$?; \ - fi; \ - done; \ - for i in $$list; do echo "$$i"; done | $(am__base_list) | \ - while read files; do \ - test -z "$$files" || { \ - echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(man8dir)'"; \ - $(INSTALL_DATA) $$files "$(DESTDIR)$(man8dir)" || exit $$?; }; \ - done; } - -uninstall-man8: - @$(NORMAL_UNINSTALL) - @list=''; test -n "$(man8dir)" || exit 0; \ - files=`{ for i in $$list; do echo "$$i"; done; \ - l2='$(man_MANS)'; for i in $$l2; do echo "$$i"; done | \ - sed -n '/\.8[a-z]*$$/p'; \ - } | sed -e 's,.*/,,;h;s,.*\.,,;s,^[^8][0-9a-z]*$$,8,;x' \ - -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,'`; \ - test -z "$$files" || { \ - echo " ( cd '$(DESTDIR)$(man8dir)' && rm -f" $$files ")"; \ - cd "$(DESTDIR)$(man8dir)" && rm -f $$files; } - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ - END { if (nonempty) { for (i in files) print i; }; }'`; \ - mkid -fID $$unique -tags: TAGS - -TAGS: $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - set x; \ - here=`pwd`; \ - list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ - END { if (nonempty) { for (i in files) print i; }; }'`; \ - shift; \ - if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ - test -n "$$unique" || unique=$$empty_fix; \ - if test $$# -gt 0; then \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - "$$@" $$unique; \ - else \ - $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ - $$unique; \ - fi; \ - fi -ctags: CTAGS -CTAGS: $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \ - $(TAGS_FILES) $(LISP) - list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ - if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ - done | \ - $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ - END { if (nonempty) { for (i in files) print i; }; }'`; \ - test -z "$(CTAGS_ARGS)$$unique" \ - || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ - $$unique - -GTAGS: - here=`$(am__cd) $(top_builddir) && pwd` \ - && $(am__cd) $(top_srcdir) \ - && gtags -i $(GTAGS_ARGS) "$$here" - -distclean-tags: - -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) - @list='$(MANS)'; if test -n "$$list"; then \ - list=`for p in $$list; do \ - if test -f $$p; then d=; else d="$(srcdir)/"; fi; \ - if test -f "$$d$$p"; then echo "$$d$$p"; else :; fi; done`; \ - if test -n "$$list" && \ - grep 'ab help2man is required to generate this page' $$list >/dev/null; then \ - echo "error: found man pages containing the \`missing help2man' replacement text:" >&2; \ - grep -l 'ab help2man is required to generate this page' $$list | sed 's/^/ /' >&2; \ - echo " to fix them, install help2man, remove and regenerate the man pages;" >&2; \ - echo " typically \`make maintainer-clean' will remove them" >&2; \ - exit 1; \ - else :; fi; \ - else :; fi - $(am__remove_distdir) - test -d "$(distdir)" || mkdir "$(distdir)" - @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ - topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ - list='$(DISTFILES)'; \ - dist_files=`for file in $$list; do echo $$file; done | \ - sed -e "s|^$$srcdirstrip/||;t" \ - -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ - case $$dist_files in \ - */*) $(MKDIR_P) `echo "$$dist_files" | \ - sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ - sort -u` ;; \ - esac; \ - for file in $$dist_files; do \ - if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ - if test -d $$d/$$file; then \ - dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ - if test -d "$(distdir)/$$file"; then \ - find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ - fi; \ - if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ - cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ - find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ - fi; \ - cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ - else \ - test -f "$(distdir)/$$file" \ - || cp -p $$d/$$file "$(distdir)/$$file" \ - || exit 1; \ - fi; \ - done - $(MAKE) $(AM_MAKEFLAGS) \ - top_distdir="$(top_distdir)" distdir="$(distdir)" \ - dist-hook - -test -n "$(am__skip_mode_fix)" \ - || find "$(distdir)" -type d ! -perm -755 \ - -exec chmod u+rwx,go+rx {} \; -o \ - ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \ - ! -type d ! -perm -400 -exec chmod a+r {} \; -o \ - ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \ - || chmod -R a+r "$(distdir)" -dist-gzip: distdir - tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz - $(am__remove_distdir) - -dist-bzip2: distdir - tardir=$(distdir) && $(am__tar) | bzip2 -9 -c >$(distdir).tar.bz2 - $(am__remove_distdir) - -dist-lzma: distdir - tardir=$(distdir) && $(am__tar) | lzma -9 -c >$(distdir).tar.lzma - $(am__remove_distdir) - -dist-xz: distdir - tardir=$(distdir) && $(am__tar) | xz -c >$(distdir).tar.xz - $(am__remove_distdir) - -dist-tarZ: distdir - tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z - $(am__remove_distdir) - -dist-shar: distdir - shar $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).shar.gz - $(am__remove_distdir) - -dist-zip: distdir - -rm -f $(distdir).zip - zip -rq $(distdir).zip $(distdir) - $(am__remove_distdir) - -dist dist-all: distdir - tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz - $(am__remove_distdir) - -# This target untars the dist file and tries a VPATH configuration. Then -# it guarantees that the distribution is self-contained by making another -# tarfile. -distcheck: dist - case '$(DIST_ARCHIVES)' in \ - *.tar.gz*) \ - GZIP=$(GZIP_ENV) gzip -dc $(distdir).tar.gz | $(am__untar) ;;\ - *.tar.bz2*) \ - bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ - *.tar.lzma*) \ - lzma -dc $(distdir).tar.lzma | $(am__untar) ;;\ - *.tar.xz*) \ - xz -dc $(distdir).tar.xz | $(am__untar) ;;\ - *.tar.Z*) \ - uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ - *.shar.gz*) \ - GZIP=$(GZIP_ENV) gzip -dc $(distdir).shar.gz | unshar ;;\ - *.zip*) \ - unzip $(distdir).zip ;;\ - esac - chmod -R a-w $(distdir); chmod a+w $(distdir) - mkdir $(distdir)/_build - mkdir $(distdir)/_inst - chmod a-w $(distdir) - test -d $(distdir)/_build || exit 0; \ - dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \ - && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \ - && am__cwd=`pwd` \ - && $(am__cd) $(distdir)/_build \ - && ../configure --srcdir=.. --prefix="$$dc_install_base" \ - $(DISTCHECK_CONFIGURE_FLAGS) \ - && $(MAKE) $(AM_MAKEFLAGS) \ - && $(MAKE) $(AM_MAKEFLAGS) dvi \ - && $(MAKE) $(AM_MAKEFLAGS) check \ - && $(MAKE) $(AM_MAKEFLAGS) install \ - && $(MAKE) $(AM_MAKEFLAGS) installcheck \ - && $(MAKE) $(AM_MAKEFLAGS) uninstall \ - && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \ - distuninstallcheck \ - && chmod -R a-w "$$dc_install_base" \ - && ({ \ - (cd ../.. && umask 077 && mkdir "$$dc_destdir") \ - && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \ - && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \ - && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \ - distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \ - } || { rm -rf "$$dc_destdir"; exit 1; }) \ - && rm -rf "$$dc_destdir" \ - && $(MAKE) $(AM_MAKEFLAGS) dist \ - && rm -rf $(DIST_ARCHIVES) \ - && $(MAKE) $(AM_MAKEFLAGS) distcleancheck \ - && cd "$$am__cwd" \ - || exit 1 - $(am__remove_distdir) - @(echo "$(distdir) archives ready for distribution: "; \ - list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \ - sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x' -distuninstallcheck: - @$(am__cd) '$(distuninstallcheck_dir)' \ - && test `$(distuninstallcheck_listfiles) | wc -l` -le 1 \ - || { echo "ERROR: files left after uninstall:" ; \ - if test -n "$(DESTDIR)"; then \ - echo " (check DESTDIR support)"; \ - fi ; \ - $(distuninstallcheck_listfiles) ; \ - exit 1; } >&2 -distcleancheck: distclean - @if test '$(srcdir)' = . ; then \ - echo "ERROR: distcleancheck can only run from a VPATH build" ; \ - exit 1 ; \ - fi - @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \ - || { echo "ERROR: files left in build directory after distclean:" ; \ - $(distcleancheck_listfiles) ; \ - exit 1; } >&2 -check-am: all-am -check: check-am -all-am: Makefile $(PROGRAMS) $(MANS) config.h -installdirs: - for dir in "$(DESTDIR)$(sbindir)" "$(DESTDIR)$(man5dir)" "$(DESTDIR)$(man8dir)"; do \ - test -z "$$dir" || $(MKDIR_P) "$$dir"; \ - done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am - @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: - $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ - install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ - `test -z '$(STRIP)' || \ - echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -test -z "$(CLEANFILES)" || rm -f $(CLEANFILES) - -distclean-generic: - -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) - -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) - -maintainer-clean-generic: - @echo "This command is intended for maintainers to use" - @echo "it deletes files that may require special tools to rebuild." - -rm -f gram.c - -rm -f gram.h - -rm -f scanner.c -clean: clean-am - -clean-am: clean-generic clean-sbinPROGRAMS mostlyclean-am - -distclean: distclean-am - -rm -f $(am__CONFIG_DISTCLEAN_FILES) - -rm -rf ./$(DEPDIR) - -rm -f Makefile -distclean-am: clean-am distclean-compile distclean-generic \ - distclean-hdr distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -html-am: - -info: info-am - -info-am: - -install-data-am: install-man - -install-dvi: install-dvi-am - -install-dvi-am: - -install-exec-am: install-sbinPROGRAMS - -install-html: install-html-am - -install-html-am: - -install-info: install-info-am - -install-info-am: - -install-man: install-man5 install-man8 - -install-pdf: install-pdf-am - -install-pdf-am: - -install-ps: install-ps-am - -install-ps-am: - -installcheck-am: - -maintainer-clean: maintainer-clean-am - -rm -f $(am__CONFIG_DISTCLEAN_FILES) - -rm -rf $(top_srcdir)/autom4te.cache - -rm -rf ./$(DEPDIR) - -rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-man uninstall-sbinPROGRAMS - -uninstall-man: uninstall-man5 uninstall-man8 - -.MAKE: all install-am install-strip - -.PHONY: CTAGS GTAGS all all-am am--refresh check check-am clean \ - clean-generic clean-sbinPROGRAMS ctags dist dist-all \ - dist-bzip2 dist-gzip dist-hook dist-lzma dist-shar dist-tarZ \ - dist-xz dist-zip distcheck distclean distclean-compile \ - distclean-generic distclean-hdr distclean-tags distcleancheck \ - distdir distuninstallcheck dvi dvi-am html html-am info \ - info-am install install-am install-data install-data-am \ - install-dvi install-dvi-am install-exec install-exec-am \ - install-html install-html-am install-info install-info-am \ - install-man install-man5 install-man8 install-pdf \ - install-pdf-am install-ps install-ps-am install-sbinPROGRAMS \ - install-strip installcheck installcheck-am installdirs \ - maintainer-clean maintainer-clean-generic mostlyclean \ - mostlyclean-compile mostlyclean-generic pdf pdf-am ps ps-am \ - tags uninstall uninstall-am uninstall-man uninstall-man5 \ - uninstall-man8 uninstall-sbinPROGRAMS - - -.man: - $(AM_V_GEN)$(SED) \ - -e 's,@''VERSION''@,$(VERSION),g' \ - -e 's,@''sbindir''@,$(sbindir),g' \ - -e 's,@''PATH_RADVD_CONF''@,$(PATH_RADVD_CONF),g' \ - -e 's,@''PATH_RADVD_PID''@,$(PATH_RADVD_PID),g' \ - -e 's,@''PATH_RADVD_LOG''@,$(PATH_RADVD_LOG),g' \ - -e 's,@''LOG_FACILITY''@,$(LOG_FACILITY),g' \ - $< > $@ - -dist-hook: - rm -f $(distdir)/gram.c - rm -f $(distdir)/gram.h - rm -f $(distdir)/scanner.c - -scanner.o: gram.h - -# Tell versions [3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT: diff --git a/release/src/router/radvd/README b/release/src/router/radvd/README deleted file mode 100644 index 0867576cfd..0000000000 --- a/release/src/router/radvd/README +++ /dev/null @@ -1,61 +0,0 @@ -$Id: README,v 1.9 2005/12/31 16:10:05 psavola Exp $ - -Installation: -============= - -Run configure, e.g. - -./configure --prefix=/usr/local --sysconfdir=/etc --mandir=/usr/share/man - -See configure --help for additional command line arguments. - -Run 'make' and 'make install'. On BSD, you may need to use 'gmake'. - -Configuration: -============== - -See INTRO.html, radvd.conf(8) and radvd.conf.example. - -Frequently Asked Questions: -=========================== - -Setting up radvd is very simple, so the most frequently asked -questions have been about what radvd _doesn't_ do... - - 1. How do I set up the router running radvd to automatically - configure an address from the prefix advertised in Route - Advertisements from upstream? - - -- You don't. By the specification, routers ignore RAs. - You'll probably need to use manual configuration. But you - can't use the same prefix on two links in any case unless you - use something like proxy-ND (draft-ietf-ipv6-ndproxy-04.txt). - You may need to re-think your topology; prefix delegation - (e.g., manually or with RFC3633) may help. - - 2. How do I set up the router running radvd to automatically - configure the interfaces to use an EUI64-based address? - - -- You don't. The design philosophy of radvd is that it's - not the _router's_ configuration tool, but a route advertising - daemon. You'll need to set up all the addresses, routes, etc. - yourself. These tasks are something that system initscripts - could possibly do instead. - - 3. I have a dynamic /48 prefix. How do I set up radvd to: - a) set up interface addresses and routes on downstream - interfaces, and - b) advertise /64 prefixes from the /48 on downstream interfaces? - - -- For a), this isn't supported. For b), radvd includes special - support for 6to4 upstream interface but assumes that the interface - addresses/routes are set up manually. This should probably - be done in the initscripts or manually. (Though if someone were - to send a patch for b), it might be incorporated.) - - 4. How do I set up radvd to do either unicast or multicast routing? - - -- You don't. Radvd is not a routing or forwarding daemon. - You need to set any appropriate routing/forwarding first, - and then radvd to only advertise the prefixes to hosts as - appropriate. diff --git a/release/src/router/radvd/TODO b/release/src/router/radvd/TODO deleted file mode 100644 index 22a3c3ea6c..0000000000 --- a/release/src/router/radvd/TODO +++ /dev/null @@ -1,85 +0,0 @@ -$Id: TODO,v 1.36 2010/12/14 12:40:18 psavola Exp $ - - NOTE WELL - ========= - - *NONE* of the items are being actively worked on. - So, if you're interested in one of these features, - it means you'll have to submit a patch... :-) - - -read list of interfaces with SIOCGIFCONF (AF_INET6 support in the kernel would -be nice) or from /proc - -Quoting Peter Bieringer (peter@bieringer.de): -> Das war's schon. Ach ja, wenn Du mal eine neue Version machst, kannst Du -> noch einen Schalter einbauen, damit radvd trotz debug-level >0 auf Wunsch -> als daemon in den Hintergrund starten kann? -[ Peter wants that a debugging level greater than 0 doesn't stop radvd -from forking.] - -support for few protocol constants defined in RFC 4861 Sec 10 is missing. - -consider whether UnicastOnly flag should be detected by radvdump. - -read the man pages one more time and make sure their are understandable -and English is correct - -The following parts of RFC4861 are not implemented: - - section 6.2.5: when AdvSendAdvertisements changes to FALSE, we don't send - a final RA with zero Router Lifetime (we just send it when shutting down). - (SHOULD) - - section 6.2.8: if the link-local address of the router changes, it should - multicast a few RAs from the old address with zero router lifetime, and a - few from the new address. (SHOULD). - -Consider whether to support RFC 4286 (Multicast Router Discovery). - -Consider whether to support multiple IPv4 addresses with Base6to4Interface -(currently the code just picks one). - -Consider whether to support multiple prefixes and routes with a single -configuration line (instead of having to specify each prefix/route -separately) somewhat similar to how RDNSS configuration already supports. - -Consider whether to support a generalization of Base6to4Interface for -arbitrary IPv6 prefixes, to be used for automatic generation of downstream -prefixes. Also consider whether this would need to support multiple IPv6 -prefixes on the upstream interfaces. See question 3 in README for more on -this. - -Use getifaddrs() instead of ioctl SIOCGIFADDR and other friends. The -problem with this is that e.g. RHL73's glibc didn't support getifaddrs(), -and before glibc 2.3.3 getifaddrs() didn't use netlink so it didn't work -well with IPv6. These old compat concerns are likely moot now.. - -Consider whether radvd should work around missing/broken interfaces by -default, especially if a previously working interface gets disabled. - -Implement Secure Neighbor Discovery (RFC 3971). - -Interface reconfiguration is only supported on Linux. Consider whether to -support that (and privilege separation as a result) on BSD as well. - -The restrictions of the (privilege separation) master process could -be restricted as currently it basically only needs to write to /proc, -do some logging and nothing else. - -radvd does not support splitting up RAs to multiple packets (RFC4861 6.2.3 -last paragraph). In practise this limits advertising to ~45 prefixes on a -link, but there is no reason to be able to so. In order to avoid -fragmenting packets yet support receiving full-size frames, our hack is to -have a bigger receive than send buffer. We could try using setsockopt -IPV6_DONTFRAG, but at least Linux glibc doesn't appear to support it yet. - -Triggered by: https://bugzilla.redhat.com/show_bug.cgi?id=554125 -Known problems (probably can't do anything about these): - - If interface MAC address changes, radvd will keep sending the old MAC - in its LL option (until HUP signal). The kernel will keep sending - Ethernet frames with the old MAC until interface is flapped. - More: http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=508466 - -http://lists.litech.org/pipermail/radvd-devel-l/2009-August/000420.html -localtime() used in vlog() is not reentrant, and is not safe in signal -handling context. There may be other such functions as well. It's not clear -what could be done about that. diff --git a/release/src/router/radvd/VERSION b/release/src/router/radvd/VERSION deleted file mode 100644 index ca36bf7a4e..0000000000 --- a/release/src/router/radvd/VERSION +++ /dev/null @@ -1,6 +0,0 @@ -# -# $Id: VERSION,v 1.32.2.1 2011/08/22 12:32:42 reubenhwk Exp $ -# -# this file is automatically processed by configure -# -1.8.1 diff --git a/release/src/router/radvd/aclocal.m4 b/release/src/router/radvd/aclocal.m4 deleted file mode 100644 index 0fdbb6e185..0000000000 --- a/release/src/router/radvd/aclocal.m4 +++ /dev/null @@ -1,1011 +0,0 @@ -# generated automatically by aclocal 1.11.1 -*- Autoconf -*- - -# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, -# 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc. -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - -m4_ifndef([AC_AUTOCONF_VERSION], - [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl -m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.65],, -[m4_warning([this file was generated for autoconf 2.65. -You have another version of autoconf. It may work, but is not guaranteed to. -If you have problems, you may need to regenerate the build system entirely. -To do so, use the procedure documented by the package, typically `autoreconf'.])]) - -# Copyright (C) 2002, 2003, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# AM_AUTOMAKE_VERSION(VERSION) -# ---------------------------- -# Automake X.Y traces this macro to ensure aclocal.m4 has been -# generated from the m4 files accompanying Automake X.Y. -# (This private macro should not be called outside this file.) -AC_DEFUN([AM_AUTOMAKE_VERSION], -[am__api_version='1.11' -dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to -dnl require some minimum version. Point them to the right macro. -m4_if([$1], [1.11.1], [], - [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl -]) - -# _AM_AUTOCONF_VERSION(VERSION) -# ----------------------------- -# aclocal traces this macro to find the Autoconf version. -# This is a private macro too. Using m4_define simplifies -# the logic in aclocal, which can simply ignore this definition. -m4_define([_AM_AUTOCONF_VERSION], []) - -# AM_SET_CURRENT_AUTOMAKE_VERSION -# ------------------------------- -# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. -# This function is AC_REQUIREd by AM_INIT_AUTOMAKE. -AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], -[AM_AUTOMAKE_VERSION([1.11.1])dnl -m4_ifndef([AC_AUTOCONF_VERSION], - [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl -_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))]) - -# AM_AUX_DIR_EXPAND -*- Autoconf -*- - -# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets -# $ac_aux_dir to `$srcdir/foo'. In other projects, it is set to -# `$srcdir', `$srcdir/..', or `$srcdir/../..'. -# -# Of course, Automake must honor this variable whenever it calls a -# tool from the auxiliary directory. The problem is that $srcdir (and -# therefore $ac_aux_dir as well) can be either absolute or relative, -# depending on how configure is run. This is pretty annoying, since -# it makes $ac_aux_dir quite unusable in subdirectories: in the top -# source directory, any form will work fine, but in subdirectories a -# relative path needs to be adjusted first. -# -# $ac_aux_dir/missing -# fails when called from a subdirectory if $ac_aux_dir is relative -# $top_srcdir/$ac_aux_dir/missing -# fails if $ac_aux_dir is absolute, -# fails when called from a subdirectory in a VPATH build with -# a relative $ac_aux_dir -# -# The reason of the latter failure is that $top_srcdir and $ac_aux_dir -# are both prefixed by $srcdir. In an in-source build this is usually -# harmless because $srcdir is `.', but things will broke when you -# start a VPATH build or use an absolute $srcdir. -# -# So we could use something similar to $top_srcdir/$ac_aux_dir/missing, -# iff we strip the leading $srcdir from $ac_aux_dir. That would be: -# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` -# and then we would define $MISSING as -# MISSING="\${SHELL} $am_aux_dir/missing" -# This will work as long as MISSING is not called from configure, because -# unfortunately $(top_srcdir) has no meaning in configure. -# However there are other variables, like CC, which are often used in -# configure, and could therefore not use this "fixed" $ac_aux_dir. -# -# Another solution, used here, is to always expand $ac_aux_dir to an -# absolute PATH. The drawback is that using absolute paths prevent a -# configured tree to be moved without reconfiguration. - -AC_DEFUN([AM_AUX_DIR_EXPAND], -[dnl Rely on autoconf to set up CDPATH properly. -AC_PREREQ([2.50])dnl -# expand $ac_aux_dir to an absolute path -am_aux_dir=`cd $ac_aux_dir && pwd` -]) - -# AM_CONDITIONAL -*- Autoconf -*- - -# Copyright (C) 1997, 2000, 2001, 2003, 2004, 2005, 2006, 2008 -# Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 9 - -# AM_CONDITIONAL(NAME, SHELL-CONDITION) -# ------------------------------------- -# Define a conditional. -AC_DEFUN([AM_CONDITIONAL], -[AC_PREREQ(2.52)dnl - ifelse([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], - [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl -AC_SUBST([$1_TRUE])dnl -AC_SUBST([$1_FALSE])dnl -_AM_SUBST_NOTMAKE([$1_TRUE])dnl -_AM_SUBST_NOTMAKE([$1_FALSE])dnl -m4_define([_AM_COND_VALUE_$1], [$2])dnl -if $2; then - $1_TRUE= - $1_FALSE='#' -else - $1_TRUE='#' - $1_FALSE= -fi -AC_CONFIG_COMMANDS_PRE( -[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then - AC_MSG_ERROR([[conditional "$1" was never defined. -Usually this means the macro was only invoked conditionally.]]) -fi])]) - -# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2009 -# Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 10 - -# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be -# written in clear, in which case automake, when reading aclocal.m4, -# will think it sees a *use*, and therefore will trigger all it's -# C support machinery. Also note that it means that autoscan, seeing -# CC etc. in the Makefile, will ask for an AC_PROG_CC use... - - -# _AM_DEPENDENCIES(NAME) -# ---------------------- -# See how the compiler implements dependency checking. -# NAME is "CC", "CXX", "GCJ", or "OBJC". -# We try a few techniques and use that to set a single cache variable. -# -# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was -# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular -# dependency, and given that the user is not expected to run this macro, -# just rely on AC_PROG_CC. -AC_DEFUN([_AM_DEPENDENCIES], -[AC_REQUIRE([AM_SET_DEPDIR])dnl -AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl -AC_REQUIRE([AM_MAKE_INCLUDE])dnl -AC_REQUIRE([AM_DEP_TRACK])dnl - -ifelse([$1], CC, [depcc="$CC" am_compiler_list=], - [$1], CXX, [depcc="$CXX" am_compiler_list=], - [$1], OBJC, [depcc="$OBJC" am_compiler_list='gcc3 gcc'], - [$1], UPC, [depcc="$UPC" am_compiler_list=], - [$1], GCJ, [depcc="$GCJ" am_compiler_list='gcc3 gcc'], - [depcc="$$1" am_compiler_list=]) - -AC_CACHE_CHECK([dependency style of $depcc], - [am_cv_$1_dependencies_compiler_type], -[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then - # We make a subdir and do the tests there. Otherwise we can end up - # making bogus files that we don't know about and never remove. For - # instance it was reported that on HP-UX the gcc test will end up - # making a dummy file named `D' -- because `-MD' means `put the output - # in D'. - mkdir conftest.dir - # Copy depcomp to subdir because otherwise we won't find it if we're - # using a relative directory. - cp "$am_depcomp" conftest.dir - cd conftest.dir - # We will build objects and dependencies in a subdirectory because - # it helps to detect inapplicable dependency modes. For instance - # both Tru64's cc and ICC support -MD to output dependencies as a - # side effect of compilation, but ICC will put the dependencies in - # the current directory while Tru64 will put them in the object - # directory. - mkdir sub - - am_cv_$1_dependencies_compiler_type=none - if test "$am_compiler_list" = ""; then - am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` - fi - am__universal=false - m4_case([$1], [CC], - [case " $depcc " in #( - *\ -arch\ *\ -arch\ *) am__universal=true ;; - esac], - [CXX], - [case " $depcc " in #( - *\ -arch\ *\ -arch\ *) am__universal=true ;; - esac]) - - for depmode in $am_compiler_list; do - # Setup a source with many dependencies, because some compilers - # like to wrap large dependency lists on column 80 (with \), and - # we should not choose a depcomp mode which is confused by this. - # - # We need to recreate these files for each test, as the compiler may - # overwrite some of them when testing with obscure command lines. - # This happens at least with the AIX C compiler. - : > sub/conftest.c - for i in 1 2 3 4 5 6; do - echo '#include "conftst'$i'.h"' >> sub/conftest.c - # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with - # Solaris 8's {/usr,}/bin/sh. - touch sub/conftst$i.h - done - echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf - - # We check with `-c' and `-o' for the sake of the "dashmstdout" - # mode. It turns out that the SunPro C++ compiler does not properly - # handle `-M -o', and we need to detect this. Also, some Intel - # versions had trouble with output in subdirs - am__obj=sub/conftest.${OBJEXT-o} - am__minus_obj="-o $am__obj" - case $depmode in - gcc) - # This depmode causes a compiler race in universal mode. - test "$am__universal" = false || continue - ;; - nosideeffect) - # after this tag, mechanisms are not by side-effect, so they'll - # only be used when explicitly requested - if test "x$enable_dependency_tracking" = xyes; then - continue - else - break - fi - ;; - msvisualcpp | msvcmsys) - # This compiler won't grok `-c -o', but also, the minuso test has - # not run yet. These depmodes are late enough in the game, and - # so weak that their functioning should not be impacted. - am__obj=conftest.${OBJEXT-o} - am__minus_obj= - ;; - none) break ;; - esac - if depmode=$depmode \ - source=sub/conftest.c object=$am__obj \ - depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ - $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ - >/dev/null 2>conftest.err && - grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && - grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && - grep $am__obj sub/conftest.Po > /dev/null 2>&1 && - ${MAKE-make} -s -f confmf > /dev/null 2>&1; then - # icc doesn't choke on unknown options, it will just issue warnings - # or remarks (even with -Werror). So we grep stderr for any message - # that says an option was ignored or not supported. - # When given -MP, icc 7.0 and 7.1 complain thusly: - # icc: Command line warning: ignoring option '-M'; no argument required - # The diagnosis changed in icc 8.0: - # icc: Command line remark: option '-MP' not supported - if (grep 'ignoring option' conftest.err || - grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else - am_cv_$1_dependencies_compiler_type=$depmode - break - fi - fi - done - - cd .. - rm -rf conftest.dir -else - am_cv_$1_dependencies_compiler_type=none -fi -]) -AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) -AM_CONDITIONAL([am__fastdep$1], [ - test "x$enable_dependency_tracking" != xno \ - && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) -]) - - -# AM_SET_DEPDIR -# ------------- -# Choose a directory name for dependency files. -# This macro is AC_REQUIREd in _AM_DEPENDENCIES -AC_DEFUN([AM_SET_DEPDIR], -[AC_REQUIRE([AM_SET_LEADING_DOT])dnl -AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl -]) - - -# AM_DEP_TRACK -# ------------ -AC_DEFUN([AM_DEP_TRACK], -[AC_ARG_ENABLE(dependency-tracking, -[ --disable-dependency-tracking speeds up one-time build - --enable-dependency-tracking do not reject slow dependency extractors]) -if test "x$enable_dependency_tracking" != xno; then - am_depcomp="$ac_aux_dir/depcomp" - AMDEPBACKSLASH='\' -fi -AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) -AC_SUBST([AMDEPBACKSLASH])dnl -_AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl -]) - -# Generate code to set up dependency tracking. -*- Autoconf -*- - -# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2008 -# Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -#serial 5 - -# _AM_OUTPUT_DEPENDENCY_COMMANDS -# ------------------------------ -AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], -[{ - # Autoconf 2.62 quotes --file arguments for eval, but not when files - # are listed without --file. Let's play safe and only enable the eval - # if we detect the quoting. - case $CONFIG_FILES in - *\'*) eval set x "$CONFIG_FILES" ;; - *) set x $CONFIG_FILES ;; - esac - shift - for mf - do - # Strip MF so we end up with the name of the file. - mf=`echo "$mf" | sed -e 's/:.*$//'` - # Check whether this is an Automake generated Makefile or not. - # We used to match only the files named `Makefile.in', but - # some people rename them; so instead we look at the file content. - # Grep'ing the first line is not enough: some people post-process - # each Makefile.in and add a new line on top of each file to say so. - # Grep'ing the whole file is not good either: AIX grep has a line - # limit of 2048, but all sed's we know have understand at least 4000. - if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then - dirpart=`AS_DIRNAME("$mf")` - else - continue - fi - # Extract the definition of DEPDIR, am__include, and am__quote - # from the Makefile without running `make'. - DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` - test -z "$DEPDIR" && continue - am__include=`sed -n 's/^am__include = //p' < "$mf"` - test -z "am__include" && continue - am__quote=`sed -n 's/^am__quote = //p' < "$mf"` - # When using ansi2knr, U may be empty or an underscore; expand it - U=`sed -n 's/^U = //p' < "$mf"` - # Find all dependency output files, they are included files with - # $(DEPDIR) in their names. We invoke sed twice because it is the - # simplest approach to changing $(DEPDIR) to its actual value in the - # expansion. - for file in `sed -n " - s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ - sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do - # Make sure the directory exists. - test -f "$dirpart/$file" && continue - fdir=`AS_DIRNAME(["$file"])` - AS_MKDIR_P([$dirpart/$fdir]) - # echo "creating $dirpart/$file" - echo '# dummy' > "$dirpart/$file" - done - done -} -])# _AM_OUTPUT_DEPENDENCY_COMMANDS - - -# AM_OUTPUT_DEPENDENCY_COMMANDS -# ----------------------------- -# This macro should only be invoked once -- use via AC_REQUIRE. -# -# This code is only required when automatic dependency tracking -# is enabled. FIXME. This creates each `.P' file that we will -# need in order to bootstrap the dependency handling code. -AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], -[AC_CONFIG_COMMANDS([depfiles], - [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], - [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"]) -]) - -# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005 -# Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 8 - -# AM_CONFIG_HEADER is obsolete. It has been replaced by AC_CONFIG_HEADERS. -AU_DEFUN([AM_CONFIG_HEADER], [AC_CONFIG_HEADERS($@)]) - -# Do all the work for Automake. -*- Autoconf -*- - -# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, -# 2005, 2006, 2008, 2009 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 16 - -# This macro actually does too much. Some checks are only needed if -# your package does certain things. But this isn't really a big deal. - -# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) -# AM_INIT_AUTOMAKE([OPTIONS]) -# ----------------------------------------------- -# The call with PACKAGE and VERSION arguments is the old style -# call (pre autoconf-2.50), which is being phased out. PACKAGE -# and VERSION should now be passed to AC_INIT and removed from -# the call to AM_INIT_AUTOMAKE. -# We support both call styles for the transition. After -# the next Automake release, Autoconf can make the AC_INIT -# arguments mandatory, and then we can depend on a new Autoconf -# release and drop the old call support. -AC_DEFUN([AM_INIT_AUTOMAKE], -[AC_PREREQ([2.62])dnl -dnl Autoconf wants to disallow AM_ names. We explicitly allow -dnl the ones we care about. -m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl -AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl -AC_REQUIRE([AC_PROG_INSTALL])dnl -if test "`cd $srcdir && pwd`" != "`pwd`"; then - # Use -I$(srcdir) only when $(srcdir) != ., so that make's output - # is not polluted with repeated "-I." - AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl - # test to see if srcdir already configured - if test -f $srcdir/config.status; then - AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) - fi -fi - -# test whether we have cygpath -if test -z "$CYGPATH_W"; then - if (cygpath --version) >/dev/null 2>/dev/null; then - CYGPATH_W='cygpath -w' - else - CYGPATH_W=echo - fi -fi -AC_SUBST([CYGPATH_W]) - -# Define the identity of the package. -dnl Distinguish between old-style and new-style calls. -m4_ifval([$2], -[m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl - AC_SUBST([PACKAGE], [$1])dnl - AC_SUBST([VERSION], [$2])], -[_AM_SET_OPTIONS([$1])dnl -dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. -m4_if(m4_ifdef([AC_PACKAGE_NAME], 1)m4_ifdef([AC_PACKAGE_VERSION], 1), 11,, - [m4_fatal([AC_INIT should be called with package and version arguments])])dnl - AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl - AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl - -_AM_IF_OPTION([no-define],, -[AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package]) - AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])])dnl - -# Some tools Automake needs. -AC_REQUIRE([AM_SANITY_CHECK])dnl -AC_REQUIRE([AC_ARG_PROGRAM])dnl -AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version}) -AM_MISSING_PROG(AUTOCONF, autoconf) -AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version}) -AM_MISSING_PROG(AUTOHEADER, autoheader) -AM_MISSING_PROG(MAKEINFO, makeinfo) -AC_REQUIRE([AM_PROG_INSTALL_SH])dnl -AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl -AC_REQUIRE([AM_PROG_MKDIR_P])dnl -# We need awk for the "check" target. The system "awk" is bad on -# some platforms. -AC_REQUIRE([AC_PROG_AWK])dnl -AC_REQUIRE([AC_PROG_MAKE_SET])dnl -AC_REQUIRE([AM_SET_LEADING_DOT])dnl -_AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], - [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], - [_AM_PROG_TAR([v7])])]) -_AM_IF_OPTION([no-dependencies],, -[AC_PROVIDE_IFELSE([AC_PROG_CC], - [_AM_DEPENDENCIES(CC)], - [define([AC_PROG_CC], - defn([AC_PROG_CC])[_AM_DEPENDENCIES(CC)])])dnl -AC_PROVIDE_IFELSE([AC_PROG_CXX], - [_AM_DEPENDENCIES(CXX)], - [define([AC_PROG_CXX], - defn([AC_PROG_CXX])[_AM_DEPENDENCIES(CXX)])])dnl -AC_PROVIDE_IFELSE([AC_PROG_OBJC], - [_AM_DEPENDENCIES(OBJC)], - [define([AC_PROG_OBJC], - defn([AC_PROG_OBJC])[_AM_DEPENDENCIES(OBJC)])])dnl -]) -_AM_IF_OPTION([silent-rules], [AC_REQUIRE([AM_SILENT_RULES])])dnl -dnl The `parallel-tests' driver may need to know about EXEEXT, so add the -dnl `am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This macro -dnl is hooked onto _AC_COMPILER_EXEEXT early, see below. -AC_CONFIG_COMMANDS_PRE(dnl -[m4_provide_if([_AM_COMPILER_EXEEXT], - [AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl -]) - -dnl Hook into `_AC_COMPILER_EXEEXT' early to learn its expansion. Do not -dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further -dnl mangled by Autoconf and run in a shell conditional statement. -m4_define([_AC_COMPILER_EXEEXT], -m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])]) - - -# When config.status generates a header, we must update the stamp-h file. -# This file resides in the same directory as the config header -# that is generated. The stamp files are numbered to have different names. - -# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the -# loop where config.status creates the headers, so we can generate -# our stamp files there. -AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], -[# Compute $1's index in $config_headers. -_am_arg=$1 -_am_stamp_count=1 -for _am_header in $config_headers :; do - case $_am_header in - $_am_arg | $_am_arg:* ) - break ;; - * ) - _am_stamp_count=`expr $_am_stamp_count + 1` ;; - esac -done -echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) - -# Copyright (C) 2001, 2003, 2005, 2008 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# AM_PROG_INSTALL_SH -# ------------------ -# Define $install_sh. -AC_DEFUN([AM_PROG_INSTALL_SH], -[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl -if test x"${install_sh}" != xset; then - case $am_aux_dir in - *\ * | *\ *) - install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; - *) - install_sh="\${SHELL} $am_aux_dir/install-sh" - esac -fi -AC_SUBST(install_sh)]) - -# Copyright (C) 2003, 2005 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 2 - -# Check whether the underlying file-system supports filenames -# with a leading dot. For instance MS-DOS doesn't. -AC_DEFUN([AM_SET_LEADING_DOT], -[rm -rf .tst 2>/dev/null -mkdir .tst 2>/dev/null -if test -d .tst; then - am__leading_dot=. -else - am__leading_dot=_ -fi -rmdir .tst 2>/dev/null -AC_SUBST([am__leading_dot])]) - -# Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2005 -# Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 5 - -# AM_PROG_LEX -# ----------- -# Autoconf leaves LEX=: if lex or flex can't be found. Change that to a -# "missing" invocation, for better error output. -AC_DEFUN([AM_PROG_LEX], -[AC_PREREQ(2.50)dnl -AC_REQUIRE([AM_MISSING_HAS_RUN])dnl -AC_REQUIRE([AC_PROG_LEX])dnl -if test "$LEX" = :; then - LEX=${am_missing_run}flex -fi]) - -# Check to see how 'make' treats includes. -*- Autoconf -*- - -# Copyright (C) 2001, 2002, 2003, 2005, 2009 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 4 - -# AM_MAKE_INCLUDE() -# ----------------- -# Check to see how make treats includes. -AC_DEFUN([AM_MAKE_INCLUDE], -[am_make=${MAKE-make} -cat > confinc << 'END' -am__doit: - @echo this is the am__doit target -.PHONY: am__doit -END -# If we don't find an include directive, just comment out the code. -AC_MSG_CHECKING([for style of include used by $am_make]) -am__include="#" -am__quote= -_am_result=none -# First try GNU make style include. -echo "include confinc" > confmf -# Ignore all kinds of additional output from `make'. -case `$am_make -s -f confmf 2> /dev/null` in #( -*the\ am__doit\ target*) - am__include=include - am__quote= - _am_result=GNU - ;; -esac -# Now try BSD make style include. -if test "$am__include" = "#"; then - echo '.include "confinc"' > confmf - case `$am_make -s -f confmf 2> /dev/null` in #( - *the\ am__doit\ target*) - am__include=.include - am__quote="\"" - _am_result=BSD - ;; - esac -fi -AC_SUBST([am__include]) -AC_SUBST([am__quote]) -AC_MSG_RESULT([$_am_result]) -rm -f confinc confmf -]) - -# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- - -# Copyright (C) 1997, 1999, 2000, 2001, 2003, 2004, 2005, 2008 -# Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 6 - -# AM_MISSING_PROG(NAME, PROGRAM) -# ------------------------------ -AC_DEFUN([AM_MISSING_PROG], -[AC_REQUIRE([AM_MISSING_HAS_RUN]) -$1=${$1-"${am_missing_run}$2"} -AC_SUBST($1)]) - - -# AM_MISSING_HAS_RUN -# ------------------ -# Define MISSING if not defined so far and test if it supports --run. -# If it does, set am_missing_run to use it, otherwise, to nothing. -AC_DEFUN([AM_MISSING_HAS_RUN], -[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl -AC_REQUIRE_AUX_FILE([missing])dnl -if test x"${MISSING+set}" != xset; then - case $am_aux_dir in - *\ * | *\ *) - MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; - *) - MISSING="\${SHELL} $am_aux_dir/missing" ;; - esac -fi -# Use eval to expand $SHELL -if eval "$MISSING --run true"; then - am_missing_run="$MISSING --run " -else - am_missing_run= - AC_MSG_WARN([`missing' script is too old or missing]) -fi -]) - -# Copyright (C) 2003, 2004, 2005, 2006 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# AM_PROG_MKDIR_P -# --------------- -# Check for `mkdir -p'. -AC_DEFUN([AM_PROG_MKDIR_P], -[AC_PREREQ([2.60])dnl -AC_REQUIRE([AC_PROG_MKDIR_P])dnl -dnl Automake 1.8 to 1.9.6 used to define mkdir_p. We now use MKDIR_P, -dnl while keeping a definition of mkdir_p for backward compatibility. -dnl @MKDIR_P@ is magic: AC_OUTPUT adjusts its value for each Makefile. -dnl However we cannot define mkdir_p as $(MKDIR_P) for the sake of -dnl Makefile.ins that do not define MKDIR_P, so we do our own -dnl adjustment using top_builddir (which is defined more often than -dnl MKDIR_P). -AC_SUBST([mkdir_p], ["$MKDIR_P"])dnl -case $mkdir_p in - [[\\/$]]* | ?:[[\\/]]*) ;; - */*) mkdir_p="\$(top_builddir)/$mkdir_p" ;; -esac -]) - -# Helper functions for option handling. -*- Autoconf -*- - -# Copyright (C) 2001, 2002, 2003, 2005, 2008 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 4 - -# _AM_MANGLE_OPTION(NAME) -# ----------------------- -AC_DEFUN([_AM_MANGLE_OPTION], -[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) - -# _AM_SET_OPTION(NAME) -# ------------------------------ -# Set option NAME. Presently that only means defining a flag for this option. -AC_DEFUN([_AM_SET_OPTION], -[m4_define(_AM_MANGLE_OPTION([$1]), 1)]) - -# _AM_SET_OPTIONS(OPTIONS) -# ---------------------------------- -# OPTIONS is a space-separated list of Automake options. -AC_DEFUN([_AM_SET_OPTIONS], -[m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) - -# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) -# ------------------------------------------- -# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. -AC_DEFUN([_AM_IF_OPTION], -[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) - -# Check to make sure that the build environment is sane. -*- Autoconf -*- - -# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005, 2008 -# Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 5 - -# AM_SANITY_CHECK -# --------------- -AC_DEFUN([AM_SANITY_CHECK], -[AC_MSG_CHECKING([whether build environment is sane]) -# Just in case -sleep 1 -echo timestamp > conftest.file -# Reject unsafe characters in $srcdir or the absolute working directory -# name. Accept space and tab only in the latter. -am_lf=' -' -case `pwd` in - *[[\\\"\#\$\&\'\`$am_lf]]*) - AC_MSG_ERROR([unsafe absolute working directory name]);; -esac -case $srcdir in - *[[\\\"\#\$\&\'\`$am_lf\ \ ]]*) - AC_MSG_ERROR([unsafe srcdir value: `$srcdir']);; -esac - -# Do `set' in a subshell so we don't clobber the current shell's -# arguments. Must try -L first in case configure is actually a -# symlink; some systems play weird games with the mod time of symlinks -# (eg FreeBSD returns the mod time of the symlink's containing -# directory). -if ( - set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` - if test "$[*]" = "X"; then - # -L didn't work. - set X `ls -t "$srcdir/configure" conftest.file` - fi - rm -f conftest.file - if test "$[*]" != "X $srcdir/configure conftest.file" \ - && test "$[*]" != "X conftest.file $srcdir/configure"; then - - # If neither matched, then we have a broken ls. This can happen - # if, for instance, CONFIG_SHELL is bash and it inherits a - # broken ls alias from the environment. This has actually - # happened. Such a system could not be considered "sane". - AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken -alias in your environment]) - fi - - test "$[2]" = conftest.file - ) -then - # Ok. - : -else - AC_MSG_ERROR([newly created file is older than distributed files! -Check your system clock]) -fi -AC_MSG_RESULT(yes)]) - -# Copyright (C) 2009 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 1 - -# AM_SILENT_RULES([DEFAULT]) -# -------------------------- -# Enable less verbose build rules; with the default set to DEFAULT -# (`yes' being less verbose, `no' or empty being verbose). -AC_DEFUN([AM_SILENT_RULES], -[AC_ARG_ENABLE([silent-rules], -[ --enable-silent-rules less verbose build output (undo: `make V=1') - --disable-silent-rules verbose build output (undo: `make V=0')]) -case $enable_silent_rules in -yes) AM_DEFAULT_VERBOSITY=0;; -no) AM_DEFAULT_VERBOSITY=1;; -*) AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);; -esac -AC_SUBST([AM_DEFAULT_VERBOSITY])dnl -AM_BACKSLASH='\' -AC_SUBST([AM_BACKSLASH])dnl -_AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl -]) - -# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# AM_PROG_INSTALL_STRIP -# --------------------- -# One issue with vendor `install' (even GNU) is that you can't -# specify the program used to strip binaries. This is especially -# annoying in cross-compiling environments, where the build's strip -# is unlikely to handle the host's binaries. -# Fortunately install-sh will honor a STRIPPROG variable, so we -# always use install-sh in `make install-strip', and initialize -# STRIPPROG with the value of the STRIP variable (set by the user). -AC_DEFUN([AM_PROG_INSTALL_STRIP], -[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl -# Installed binaries are usually stripped using `strip' when the user -# run `make install-strip'. However `strip' might not be the right -# tool to use in cross-compilation environments, therefore Automake -# will honor the `STRIP' environment variable to overrule this program. -dnl Don't test for $cross_compiling = yes, because it might be `maybe'. -if test "$cross_compiling" != no; then - AC_CHECK_TOOL([STRIP], [strip], :) -fi -INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" -AC_SUBST([INSTALL_STRIP_PROGRAM])]) - -# Copyright (C) 2006, 2008 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 2 - -# _AM_SUBST_NOTMAKE(VARIABLE) -# --------------------------- -# Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. -# This macro is traced by Automake. -AC_DEFUN([_AM_SUBST_NOTMAKE]) - -# AM_SUBST_NOTMAKE(VARIABLE) -# --------------------------- -# Public sister of _AM_SUBST_NOTMAKE. -AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)]) - -# Check how to create a tarball. -*- Autoconf -*- - -# Copyright (C) 2004, 2005 Free Software Foundation, Inc. -# -# This file is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# serial 2 - -# _AM_PROG_TAR(FORMAT) -# -------------------- -# Check how to create a tarball in format FORMAT. -# FORMAT should be one of `v7', `ustar', or `pax'. -# -# Substitute a variable $(am__tar) that is a command -# writing to stdout a FORMAT-tarball containing the directory -# $tardir. -# tardir=directory && $(am__tar) > result.tar -# -# Substitute a variable $(am__untar) that extract such -# a tarball read from stdin. -# $(am__untar) < result.tar -AC_DEFUN([_AM_PROG_TAR], -[# Always define AMTAR for backward compatibility. -AM_MISSING_PROG([AMTAR], [tar]) -m4_if([$1], [v7], - [am__tar='${AMTAR} chof - "$$tardir"'; am__untar='${AMTAR} xf -'], - [m4_case([$1], [ustar],, [pax],, - [m4_fatal([Unknown tar format])]) -AC_MSG_CHECKING([how to create a $1 tar archive]) -# Loop over all known methods to create a tar archive until one works. -_am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' -_am_tools=${am_cv_prog_tar_$1-$_am_tools} -# Do not fold the above two line into one, because Tru64 sh and -# Solaris sh will not grok spaces in the rhs of `-'. -for _am_tool in $_am_tools -do - case $_am_tool in - gnutar) - for _am_tar in tar gnutar gtar; - do - AM_RUN_LOG([$_am_tar --version]) && break - done - am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' - am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' - am__untar="$_am_tar -xf -" - ;; - plaintar) - # Must skip GNU tar: if it does not support --format= it doesn't create - # ustar tarball either. - (tar --version) >/dev/null 2>&1 && continue - am__tar='tar chf - "$$tardir"' - am__tar_='tar chf - "$tardir"' - am__untar='tar xf -' - ;; - pax) - am__tar='pax -L -x $1 -w "$$tardir"' - am__tar_='pax -L -x $1 -w "$tardir"' - am__untar='pax -r' - ;; - cpio) - am__tar='find "$$tardir" -print | cpio -o -H $1 -L' - am__tar_='find "$tardir" -print | cpio -o -H $1 -L' - am__untar='cpio -i -H $1 -d' - ;; - none) - am__tar=false - am__tar_=false - am__untar=false - ;; - esac - - # If the value was cached, stop now. We just wanted to have am__tar - # and am__untar set. - test -n "${am_cv_prog_tar_$1}" && break - - # tar/untar a dummy directory, and stop if the command works - rm -rf conftest.dir - mkdir conftest.dir - echo GrepMe > conftest.dir/file - AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) - rm -rf conftest.dir - if test -s conftest.tar; then - AM_RUN_LOG([$am__untar /dev/null 2>&1 && break - fi -done -rm -rf conftest.dir - -AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) -AC_MSG_RESULT([$am_cv_prog_tar_$1])]) -AC_SUBST([am__tar]) -AC_SUBST([am__untar]) -]) # _AM_PROG_TAR - diff --git a/release/src/router/radvd/config.guess b/release/src/router/radvd/config.guess deleted file mode 100755 index e3a2116a7d..0000000000 --- a/release/src/router/radvd/config.guess +++ /dev/null @@ -1,1533 +0,0 @@ -#! /bin/sh -# Attempt to guess a canonical system name. -# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, -# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 -# Free Software Foundation, Inc. - -timestamp='2009-06-10' - -# This file 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; either version 2 of the License, or -# (at your option) any later version. -# -# 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, write to the Free Software -# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA -# 02110-1301, USA. -# -# As a special exception to the GNU General Public License, if you -# distribute this file as part of a program that contains a -# configuration script generated by Autoconf, you may include it under -# the same distribution terms that you use for the rest of that program. - - -# Originally written by Per Bothner . -# Please send patches to . Submit a context -# diff and a properly formatted ChangeLog entry. -# -# This script attempts to guess a canonical system name similar to -# config.sub. If it succeeds, it prints the system name on stdout, and -# exits with 0. Otherwise, it exits with 1. -# -# The plan is that this can be called by configure scripts if you -# don't specify an explicit build system type. - -me=`echo "$0" | sed -e 's,.*/,,'` - -usage="\ -Usage: $0 [OPTION] - -Output the configuration name of the system \`$me' is run on. - -Operation modes: - -h, --help print this help, then exit - -t, --time-stamp print date of last modification, then exit - -v, --version print version number, then exit - -Report bugs and patches to ." - -version="\ -GNU config.guess ($timestamp) - -Originally written by Per Bothner. -Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, -2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. - -This is free software; see the source for copying conditions. There is NO -warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." - -help=" -Try \`$me --help' for more information." - -# Parse command line -while test $# -gt 0 ; do - case $1 in - --time-stamp | --time* | -t ) - echo "$timestamp" ; exit ;; - --version | -v ) - echo "$version" ; exit ;; - --help | --h* | -h ) - echo "$usage"; exit ;; - -- ) # Stop option processing - shift; break ;; - - ) # Use stdin as input. - break ;; - -* ) - echo "$me: invalid option $1$help" >&2 - exit 1 ;; - * ) - break ;; - esac -done - -if test $# != 0; then - echo "$me: too many arguments$help" >&2 - exit 1 -fi - -trap 'exit 1' 1 2 15 - -# CC_FOR_BUILD -- compiler used by this script. Note that the use of a -# compiler to aid in system detection is discouraged as it requires -# temporary files to be created and, as you can see below, it is a -# headache to deal with in a portable fashion. - -# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still -# use `HOST_CC' if defined, but it is deprecated. - -# Portable tmp directory creation inspired by the Autoconf team. - -set_cc_for_build=' -trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ; -trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ; -: ${TMPDIR=/tmp} ; - { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || - { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } || - { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } || - { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ; -dummy=$tmp/dummy ; -tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; -case $CC_FOR_BUILD,$HOST_CC,$CC in - ,,) echo "int x;" > $dummy.c ; - for c in cc gcc c89 c99 ; do - if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then - CC_FOR_BUILD="$c"; break ; - fi ; - done ; - if test x"$CC_FOR_BUILD" = x ; then - CC_FOR_BUILD=no_compiler_found ; - fi - ;; - ,,*) CC_FOR_BUILD=$CC ;; - ,*,*) CC_FOR_BUILD=$HOST_CC ;; -esac ; set_cc_for_build= ;' - -# This is needed to find uname on a Pyramid OSx when run in the BSD universe. -# (ghazi@noc.rutgers.edu 1994-08-24) -if (test -f /.attbin/uname) >/dev/null 2>&1 ; then - PATH=$PATH:/.attbin ; export PATH -fi - -UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown -UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown -UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown -UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown - -# Note: order is significant - the case branches are not exclusive. - -case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in - *:NetBSD:*:*) - # NetBSD (nbsd) targets should (where applicable) match one or - # more of the tupples: *-*-netbsdelf*, *-*-netbsdaout*, - # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently - # switched to ELF, *-*-netbsd* would select the old - # object file format. This provides both forward - # compatibility and a consistent mechanism for selecting the - # object file format. - # - # Note: NetBSD doesn't particularly care about the vendor - # portion of the name. We always set it to "unknown". - sysctl="sysctl -n hw.machine_arch" - UNAME_MACHINE_ARCH=`(/sbin/$sysctl 2>/dev/null || \ - /usr/sbin/$sysctl 2>/dev/null || echo unknown)` - case "${UNAME_MACHINE_ARCH}" in - armeb) machine=armeb-unknown ;; - arm*) machine=arm-unknown ;; - sh3el) machine=shl-unknown ;; - sh3eb) machine=sh-unknown ;; - sh5el) machine=sh5le-unknown ;; - *) machine=${UNAME_MACHINE_ARCH}-unknown ;; - esac - # The Operating System including object format, if it has switched - # to ELF recently, or will in the future. - case "${UNAME_MACHINE_ARCH}" in - arm*|i386|m68k|ns32k|sh3*|sparc|vax) - eval $set_cc_for_build - if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ - | grep -q __ELF__ - then - # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). - # Return netbsd for either. FIX? - os=netbsd - else - os=netbsdelf - fi - ;; - *) - os=netbsd - ;; - esac - # The OS release - # Debian GNU/NetBSD machines have a different userland, and - # thus, need a distinct triplet. However, they do not need - # kernel version information, so it can be replaced with a - # suitable tag, in the style of linux-gnu. - case "${UNAME_VERSION}" in - Debian*) - release='-gnu' - ;; - *) - release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'` - ;; - esac - # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: - # contains redundant information, the shorter form: - # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. - echo "${machine}-${os}${release}" - exit ;; - *:OpenBSD:*:*) - UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` - echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE} - exit ;; - *:ekkoBSD:*:*) - echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE} - exit ;; - *:SolidBSD:*:*) - echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE} - exit ;; - macppc:MirBSD:*:*) - echo powerpc-unknown-mirbsd${UNAME_RELEASE} - exit ;; - *:MirBSD:*:*) - echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE} - exit ;; - alpha:OSF1:*:*) - case $UNAME_RELEASE in - *4.0) - UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` - ;; - *5.*) - UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` - ;; - esac - # According to Compaq, /usr/sbin/psrinfo has been available on - # OSF/1 and Tru64 systems produced since 1995. I hope that - # covers most systems running today. This code pipes the CPU - # types through head -n 1, so we only detect the type of CPU 0. - ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` - case "$ALPHA_CPU_TYPE" in - "EV4 (21064)") - UNAME_MACHINE="alpha" ;; - "EV4.5 (21064)") - UNAME_MACHINE="alpha" ;; - "LCA4 (21066/21068)") - UNAME_MACHINE="alpha" ;; - "EV5 (21164)") - UNAME_MACHINE="alphaev5" ;; - "EV5.6 (21164A)") - UNAME_MACHINE="alphaev56" ;; - "EV5.6 (21164PC)") - UNAME_MACHINE="alphapca56" ;; - "EV5.7 (21164PC)") - UNAME_MACHINE="alphapca57" ;; - "EV6 (21264)") - UNAME_MACHINE="alphaev6" ;; - "EV6.7 (21264A)") - UNAME_MACHINE="alphaev67" ;; - "EV6.8CB (21264C)") - UNAME_MACHINE="alphaev68" ;; - "EV6.8AL (21264B)") - UNAME_MACHINE="alphaev68" ;; - "EV6.8CX (21264D)") - UNAME_MACHINE="alphaev68" ;; - "EV6.9A (21264/EV69A)") - UNAME_MACHINE="alphaev69" ;; - "EV7 (21364)") - UNAME_MACHINE="alphaev7" ;; - "EV7.9 (21364A)") - UNAME_MACHINE="alphaev79" ;; - esac - # A Pn.n version is a patched version. - # A Vn.n version is a released version. - # A Tn.n version is a released field test version. - # A Xn.n version is an unreleased experimental baselevel. - # 1.2 uses "1.2" for uname -r. - echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` - exit ;; - Alpha\ *:Windows_NT*:*) - # How do we know it's Interix rather than the generic POSIX subsystem? - # Should we change UNAME_MACHINE based on the output of uname instead - # of the specific Alpha model? - echo alpha-pc-interix - exit ;; - 21064:Windows_NT:50:3) - echo alpha-dec-winnt3.5 - exit ;; - Amiga*:UNIX_System_V:4.0:*) - echo m68k-unknown-sysv4 - exit ;; - *:[Aa]miga[Oo][Ss]:*:*) - echo ${UNAME_MACHINE}-unknown-amigaos - exit ;; - *:[Mm]orph[Oo][Ss]:*:*) - echo ${UNAME_MACHINE}-unknown-morphos - exit ;; - *:OS/390:*:*) - echo i370-ibm-openedition - exit ;; - *:z/VM:*:*) - echo s390-ibm-zvmoe - exit ;; - *:OS400:*:*) - echo powerpc-ibm-os400 - exit ;; - arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) - echo arm-acorn-riscix${UNAME_RELEASE} - exit ;; - arm:riscos:*:*|arm:RISCOS:*:*) - echo arm-unknown-riscos - exit ;; - SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) - echo hppa1.1-hitachi-hiuxmpp - exit ;; - Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) - # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. - if test "`(/bin/universe) 2>/dev/null`" = att ; then - echo pyramid-pyramid-sysv3 - else - echo pyramid-pyramid-bsd - fi - exit ;; - NILE*:*:*:dcosx) - echo pyramid-pyramid-svr4 - exit ;; - DRS?6000:unix:4.0:6*) - echo sparc-icl-nx6 - exit ;; - DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) - case `/usr/bin/uname -p` in - sparc) echo sparc-icl-nx7; exit ;; - esac ;; - s390x:SunOS:*:*) - echo ${UNAME_MACHINE}-ibm-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` - exit ;; - sun4H:SunOS:5.*:*) - echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` - exit ;; - sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) - echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` - exit ;; - i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) - eval $set_cc_for_build - SUN_ARCH="i386" - # If there is a compiler, see if it is configured for 64-bit objects. - # Note that the Sun cc does not turn __LP64__ into 1 like gcc does. - # This test works for both compilers. - if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then - if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \ - (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \ - grep IS_64BIT_ARCH >/dev/null - then - SUN_ARCH="x86_64" - fi - fi - echo ${SUN_ARCH}-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` - exit ;; - sun4*:SunOS:6*:*) - # According to config.sub, this is the proper way to canonicalize - # SunOS6. Hard to guess exactly what SunOS6 will be like, but - # it's likely to be more like Solaris than SunOS4. - echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` - exit ;; - sun4*:SunOS:*:*) - case "`/usr/bin/arch -k`" in - Series*|S4*) - UNAME_RELEASE=`uname -v` - ;; - esac - # Japanese Language versions have a version number like `4.1.3-JL'. - echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` - exit ;; - sun3*:SunOS:*:*) - echo m68k-sun-sunos${UNAME_RELEASE} - exit ;; - sun*:*:4.2BSD:*) - UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` - test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3 - case "`/bin/arch`" in - sun3) - echo m68k-sun-sunos${UNAME_RELEASE} - ;; - sun4) - echo sparc-sun-sunos${UNAME_RELEASE} - ;; - esac - exit ;; - aushp:SunOS:*:*) - echo sparc-auspex-sunos${UNAME_RELEASE} - exit ;; - # The situation for MiNT is a little confusing. The machine name - # can be virtually everything (everything which is not - # "atarist" or "atariste" at least should have a processor - # > m68000). The system name ranges from "MiNT" over "FreeMiNT" - # to the lowercase version "mint" (or "freemint"). Finally - # the system name "TOS" denotes a system which is actually not - # MiNT. But MiNT is downward compatible to TOS, so this should - # be no problem. - atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*) - echo m68k-atari-mint${UNAME_RELEASE} - exit ;; - atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*) - echo m68k-atari-mint${UNAME_RELEASE} - exit ;; - *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) - echo m68k-atari-mint${UNAME_RELEASE} - exit ;; - milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) - echo m68k-milan-mint${UNAME_RELEASE} - exit ;; - hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) - echo m68k-hades-mint${UNAME_RELEASE} - exit ;; - *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) - echo m68k-unknown-mint${UNAME_RELEASE} - exit ;; - m68k:machten:*:*) - echo m68k-apple-machten${UNAME_RELEASE} - exit ;; - powerpc:machten:*:*) - echo powerpc-apple-machten${UNAME_RELEASE} - exit ;; - RISC*:Mach:*:*) - echo mips-dec-mach_bsd4.3 - exit ;; - RISC*:ULTRIX:*:*) - echo mips-dec-ultrix${UNAME_RELEASE} - exit ;; - VAX*:ULTRIX*:*:*) - echo vax-dec-ultrix${UNAME_RELEASE} - exit ;; - 2020:CLIX:*:* | 2430:CLIX:*:*) - echo clipper-intergraph-clix${UNAME_RELEASE} - exit ;; - mips:*:*:UMIPS | mips:*:*:RISCos) - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c -#ifdef __cplusplus -#include /* for printf() prototype */ - int main (int argc, char *argv[]) { -#else - int main (argc, argv) int argc; char *argv[]; { -#endif - #if defined (host_mips) && defined (MIPSEB) - #if defined (SYSTYPE_SYSV) - printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0); - #endif - #if defined (SYSTYPE_SVR4) - printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0); - #endif - #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) - printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0); - #endif - #endif - exit (-1); - } -EOF - $CC_FOR_BUILD -o $dummy $dummy.c && - dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` && - SYSTEM_NAME=`$dummy $dummyarg` && - { echo "$SYSTEM_NAME"; exit; } - echo mips-mips-riscos${UNAME_RELEASE} - exit ;; - Motorola:PowerMAX_OS:*:*) - echo powerpc-motorola-powermax - exit ;; - Motorola:*:4.3:PL8-*) - echo powerpc-harris-powermax - exit ;; - Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) - echo powerpc-harris-powermax - exit ;; - Night_Hawk:Power_UNIX:*:*) - echo powerpc-harris-powerunix - exit ;; - m88k:CX/UX:7*:*) - echo m88k-harris-cxux7 - exit ;; - m88k:*:4*:R4*) - echo m88k-motorola-sysv4 - exit ;; - m88k:*:3*:R3*) - echo m88k-motorola-sysv3 - exit ;; - AViiON:dgux:*:*) - # DG/UX returns AViiON for all architectures - UNAME_PROCESSOR=`/usr/bin/uname -p` - if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ] - then - if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \ - [ ${TARGET_BINARY_INTERFACE}x = x ] - then - echo m88k-dg-dgux${UNAME_RELEASE} - else - echo m88k-dg-dguxbcs${UNAME_RELEASE} - fi - else - echo i586-dg-dgux${UNAME_RELEASE} - fi - exit ;; - M88*:DolphinOS:*:*) # DolphinOS (SVR3) - echo m88k-dolphin-sysv3 - exit ;; - M88*:*:R3*:*) - # Delta 88k system running SVR3 - echo m88k-motorola-sysv3 - exit ;; - XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) - echo m88k-tektronix-sysv3 - exit ;; - Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) - echo m68k-tektronix-bsd - exit ;; - *:IRIX*:*:*) - echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'` - exit ;; - ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. - echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id - exit ;; # Note that: echo "'`uname -s`'" gives 'AIX ' - i*86:AIX:*:*) - echo i386-ibm-aix - exit ;; - ia64:AIX:*:*) - if [ -x /usr/bin/oslevel ] ; then - IBM_REV=`/usr/bin/oslevel` - else - IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} - fi - echo ${UNAME_MACHINE}-ibm-aix${IBM_REV} - exit ;; - *:AIX:2:3) - if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c - #include - - main() - { - if (!__power_pc()) - exit(1); - puts("powerpc-ibm-aix3.2.5"); - exit(0); - } -EOF - if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` - then - echo "$SYSTEM_NAME" - else - echo rs6000-ibm-aix3.2.5 - fi - elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then - echo rs6000-ibm-aix3.2.4 - else - echo rs6000-ibm-aix3.2 - fi - exit ;; - *:AIX:*:[456]) - IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` - if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then - IBM_ARCH=rs6000 - else - IBM_ARCH=powerpc - fi - if [ -x /usr/bin/oslevel ] ; then - IBM_REV=`/usr/bin/oslevel` - else - IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} - fi - echo ${IBM_ARCH}-ibm-aix${IBM_REV} - exit ;; - *:AIX:*:*) - echo rs6000-ibm-aix - exit ;; - ibmrt:4.4BSD:*|romp-ibm:BSD:*) - echo romp-ibm-bsd4.4 - exit ;; - ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and - echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to - exit ;; # report: romp-ibm BSD 4.3 - *:BOSX:*:*) - echo rs6000-bull-bosx - exit ;; - DPX/2?00:B.O.S.:*:*) - echo m68k-bull-sysv3 - exit ;; - 9000/[34]??:4.3bsd:1.*:*) - echo m68k-hp-bsd - exit ;; - hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) - echo m68k-hp-bsd4.4 - exit ;; - 9000/[34678]??:HP-UX:*:*) - HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` - case "${UNAME_MACHINE}" in - 9000/31? ) HP_ARCH=m68000 ;; - 9000/[34]?? ) HP_ARCH=m68k ;; - 9000/[678][0-9][0-9]) - if [ -x /usr/bin/getconf ]; then - sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null` - sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null` - case "${sc_cpu_version}" in - 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0 - 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1 - 532) # CPU_PA_RISC2_0 - case "${sc_kernel_bits}" in - 32) HP_ARCH="hppa2.0n" ;; - 64) HP_ARCH="hppa2.0w" ;; - '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20 - esac ;; - esac - fi - if [ "${HP_ARCH}" = "" ]; then - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c - - #define _HPUX_SOURCE - #include - #include - - int main () - { - #if defined(_SC_KERNEL_BITS) - long bits = sysconf(_SC_KERNEL_BITS); - #endif - long cpu = sysconf (_SC_CPU_VERSION); - - switch (cpu) - { - case CPU_PA_RISC1_0: puts ("hppa1.0"); break; - case CPU_PA_RISC1_1: puts ("hppa1.1"); break; - case CPU_PA_RISC2_0: - #if defined(_SC_KERNEL_BITS) - switch (bits) - { - case 64: puts ("hppa2.0w"); break; - case 32: puts ("hppa2.0n"); break; - default: puts ("hppa2.0"); break; - } break; - #else /* !defined(_SC_KERNEL_BITS) */ - puts ("hppa2.0"); break; - #endif - default: puts ("hppa1.0"); break; - } - exit (0); - } -EOF - (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy` - test -z "$HP_ARCH" && HP_ARCH=hppa - fi ;; - esac - if [ ${HP_ARCH} = "hppa2.0w" ] - then - eval $set_cc_for_build - - # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating - # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler - # generating 64-bit code. GNU and HP use different nomenclature: - # - # $ CC_FOR_BUILD=cc ./config.guess - # => hppa2.0w-hp-hpux11.23 - # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess - # => hppa64-hp-hpux11.23 - - if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | - grep -q __LP64__ - then - HP_ARCH="hppa2.0w" - else - HP_ARCH="hppa64" - fi - fi - echo ${HP_ARCH}-hp-hpux${HPUX_REV} - exit ;; - ia64:HP-UX:*:*) - HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` - echo ia64-hp-hpux${HPUX_REV} - exit ;; - 3050*:HI-UX:*:*) - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c - #include - int - main () - { - long cpu = sysconf (_SC_CPU_VERSION); - /* The order matters, because CPU_IS_HP_MC68K erroneously returns - true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct - results, however. */ - if (CPU_IS_PA_RISC (cpu)) - { - switch (cpu) - { - case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; - case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; - case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; - default: puts ("hppa-hitachi-hiuxwe2"); break; - } - } - else if (CPU_IS_HP_MC68K (cpu)) - puts ("m68k-hitachi-hiuxwe2"); - else puts ("unknown-hitachi-hiuxwe2"); - exit (0); - } -EOF - $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` && - { echo "$SYSTEM_NAME"; exit; } - echo unknown-hitachi-hiuxwe2 - exit ;; - 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* ) - echo hppa1.1-hp-bsd - exit ;; - 9000/8??:4.3bsd:*:*) - echo hppa1.0-hp-bsd - exit ;; - *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) - echo hppa1.0-hp-mpeix - exit ;; - hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* ) - echo hppa1.1-hp-osf - exit ;; - hp8??:OSF1:*:*) - echo hppa1.0-hp-osf - exit ;; - i*86:OSF1:*:*) - if [ -x /usr/sbin/sysversion ] ; then - echo ${UNAME_MACHINE}-unknown-osf1mk - else - echo ${UNAME_MACHINE}-unknown-osf1 - fi - exit ;; - parisc*:Lites*:*:*) - echo hppa1.1-hp-lites - exit ;; - C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) - echo c1-convex-bsd - exit ;; - C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) - if getsysinfo -f scalar_acc - then echo c32-convex-bsd - else echo c2-convex-bsd - fi - exit ;; - C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) - echo c34-convex-bsd - exit ;; - C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) - echo c38-convex-bsd - exit ;; - C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) - echo c4-convex-bsd - exit ;; - CRAY*Y-MP:*:*:*) - echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' - exit ;; - CRAY*[A-Z]90:*:*:*) - echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \ - | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \ - -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ - -e 's/\.[^.]*$/.X/' - exit ;; - CRAY*TS:*:*:*) - echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' - exit ;; - CRAY*T3E:*:*:*) - echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' - exit ;; - CRAY*SV1:*:*:*) - echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' - exit ;; - *:UNICOS/mp:*:*) - echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' - exit ;; - F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) - FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` - FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` - FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'` - echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" - exit ;; - 5000:UNIX_System_V:4.*:*) - FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` - FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'` - echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" - exit ;; - i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) - echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE} - exit ;; - sparc*:BSD/OS:*:*) - echo sparc-unknown-bsdi${UNAME_RELEASE} - exit ;; - *:BSD/OS:*:*) - echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} - exit ;; - *:FreeBSD:*:*) - case ${UNAME_MACHINE} in - pc98) - echo i386-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; - amd64) - echo x86_64-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; - *) - echo ${UNAME_MACHINE}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; - esac - exit ;; - i*:CYGWIN*:*) - echo ${UNAME_MACHINE}-pc-cygwin - exit ;; - *:MINGW*:*) - echo ${UNAME_MACHINE}-pc-mingw32 - exit ;; - i*:windows32*:*) - # uname -m includes "-pc" on this system. - echo ${UNAME_MACHINE}-mingw32 - exit ;; - i*:PW*:*) - echo ${UNAME_MACHINE}-pc-pw32 - exit ;; - *:Interix*:[3456]*) - case ${UNAME_MACHINE} in - x86) - echo i586-pc-interix${UNAME_RELEASE} - exit ;; - EM64T | authenticamd | genuineintel) - echo x86_64-unknown-interix${UNAME_RELEASE} - exit ;; - IA64) - echo ia64-unknown-interix${UNAME_RELEASE} - exit ;; - esac ;; - [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*) - echo i${UNAME_MACHINE}-pc-mks - exit ;; - 8664:Windows_NT:*) - echo x86_64-pc-mks - exit ;; - i*:Windows_NT*:* | Pentium*:Windows_NT*:*) - # How do we know it's Interix rather than the generic POSIX subsystem? - # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we - # UNAME_MACHINE based on the output of uname instead of i386? - echo i586-pc-interix - exit ;; - i*:UWIN*:*) - echo ${UNAME_MACHINE}-pc-uwin - exit ;; - amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) - echo x86_64-unknown-cygwin - exit ;; - p*:CYGWIN*:*) - echo powerpcle-unknown-cygwin - exit ;; - prep*:SunOS:5.*:*) - echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` - exit ;; - *:GNU:*:*) - # the GNU system - echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'` - exit ;; - *:GNU/*:*:*) - # other systems with GNU libc and userland - echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-gnu - exit ;; - i*86:Minix:*:*) - echo ${UNAME_MACHINE}-pc-minix - exit ;; - arm*:Linux:*:*) - eval $set_cc_for_build - if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \ - | grep -q __ARM_EABI__ - then - echo ${UNAME_MACHINE}-unknown-linux-gnu - else - echo ${UNAME_MACHINE}-unknown-linux-gnueabi - fi - exit ;; - avr32*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - cris:Linux:*:*) - echo cris-axis-linux-gnu - exit ;; - crisv32:Linux:*:*) - echo crisv32-axis-linux-gnu - exit ;; - frv:Linux:*:*) - echo frv-unknown-linux-gnu - exit ;; - ia64:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - m32r*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - m68*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - mips:Linux:*:* | mips64:Linux:*:*) - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c - #undef CPU - #undef ${UNAME_MACHINE} - #undef ${UNAME_MACHINE}el - #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) - CPU=${UNAME_MACHINE}el - #else - #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) - CPU=${UNAME_MACHINE} - #else - CPU= - #endif - #endif -EOF - eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' - /^CPU/{ - s: ::g - p - }'`" - test x"${CPU}" != x && { echo "${CPU}-unknown-linux-gnu"; exit; } - ;; - or32:Linux:*:*) - echo or32-unknown-linux-gnu - exit ;; - ppc:Linux:*:*) - echo powerpc-unknown-linux-gnu - exit ;; - ppc64:Linux:*:*) - echo powerpc64-unknown-linux-gnu - exit ;; - alpha:Linux:*:*) - case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in - EV5) UNAME_MACHINE=alphaev5 ;; - EV56) UNAME_MACHINE=alphaev56 ;; - PCA56) UNAME_MACHINE=alphapca56 ;; - PCA57) UNAME_MACHINE=alphapca56 ;; - EV6) UNAME_MACHINE=alphaev6 ;; - EV67) UNAME_MACHINE=alphaev67 ;; - EV68*) UNAME_MACHINE=alphaev68 ;; - esac - objdump --private-headers /bin/sh | grep -q ld.so.1 - if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi - echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC} - exit ;; - padre:Linux:*:*) - echo sparc-unknown-linux-gnu - exit ;; - parisc:Linux:*:* | hppa:Linux:*:*) - # Look for CPU level - case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in - PA7*) echo hppa1.1-unknown-linux-gnu ;; - PA8*) echo hppa2.0-unknown-linux-gnu ;; - *) echo hppa-unknown-linux-gnu ;; - esac - exit ;; - parisc64:Linux:*:* | hppa64:Linux:*:*) - echo hppa64-unknown-linux-gnu - exit ;; - s390:Linux:*:* | s390x:Linux:*:*) - echo ${UNAME_MACHINE}-ibm-linux - exit ;; - sh64*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - sh*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - sparc:Linux:*:* | sparc64:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - vax:Linux:*:*) - echo ${UNAME_MACHINE}-dec-linux-gnu - exit ;; - x86_64:Linux:*:*) - echo x86_64-unknown-linux-gnu - exit ;; - xtensa*:Linux:*:*) - echo ${UNAME_MACHINE}-unknown-linux-gnu - exit ;; - i*86:Linux:*:*) - # The BFD linker knows what the default object file format is, so - # first see if it will tell us. cd to the root directory to prevent - # problems with other programs or directories called `ld' in the path. - # Set LC_ALL=C to ensure ld outputs messages in English. - ld_supported_targets=`cd /; LC_ALL=C ld --help 2>&1 \ - | sed -ne '/supported targets:/!d - s/[ ][ ]*/ /g - s/.*supported targets: *// - s/ .*// - p'` - case "$ld_supported_targets" in - elf32-i386) - TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu" - ;; - esac - # Determine whether the default compiler is a.out or elf - eval $set_cc_for_build - sed 's/^ //' << EOF >$dummy.c - #include - #ifdef __ELF__ - # ifdef __GLIBC__ - # if __GLIBC__ >= 2 - LIBC=gnu - # else - LIBC=gnulibc1 - # endif - # else - LIBC=gnulibc1 - # endif - #else - #if defined(__INTEL_COMPILER) || defined(__PGI) || defined(__SUNPRO_C) || defined(__SUNPRO_CC) - LIBC=gnu - #else - LIBC=gnuaout - #endif - #endif - #ifdef __dietlibc__ - LIBC=dietlibc - #endif -EOF - eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' - /^LIBC/{ - s: ::g - p - }'`" - test x"${LIBC}" != x && { - echo "${UNAME_MACHINE}-pc-linux-${LIBC}" - exit - } - test x"${TENTATIVE}" != x && { echo "${TENTATIVE}"; exit; } - ;; - i*86:DYNIX/ptx:4*:*) - # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. - # earlier versions are messed up and put the nodename in both - # sysname and nodename. - echo i386-sequent-sysv4 - exit ;; - i*86:UNIX_SV:4.2MP:2.*) - # Unixware is an offshoot of SVR4, but it has its own version - # number series starting with 2... - # I am not positive that other SVR4 systems won't match this, - # I just have to hope. -- rms. - # Use sysv4.2uw... so that sysv4* matches it. - echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION} - exit ;; - i*86:OS/2:*:*) - # If we were able to find `uname', then EMX Unix compatibility - # is probably installed. - echo ${UNAME_MACHINE}-pc-os2-emx - exit ;; - i*86:XTS-300:*:STOP) - echo ${UNAME_MACHINE}-unknown-stop - exit ;; - i*86:atheos:*:*) - echo ${UNAME_MACHINE}-unknown-atheos - exit ;; - i*86:syllable:*:*) - echo ${UNAME_MACHINE}-pc-syllable - exit ;; - i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*) - echo i386-unknown-lynxos${UNAME_RELEASE} - exit ;; - i*86:*DOS:*:*) - echo ${UNAME_MACHINE}-pc-msdosdjgpp - exit ;; - i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*) - UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'` - if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then - echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL} - else - echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL} - fi - exit ;; - i*86:*:5:[678]*) - # UnixWare 7.x, OpenUNIX and OpenServer 6. - case `/bin/uname -X | grep "^Machine"` in - *486*) UNAME_MACHINE=i486 ;; - *Pentium) UNAME_MACHINE=i586 ;; - *Pent*|*Celeron) UNAME_MACHINE=i686 ;; - esac - echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION} - exit ;; - i*86:*:3.2:*) - if test -f /usr/options/cb.name; then - UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then - UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')` - (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486 - (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \ - && UNAME_MACHINE=i586 - (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \ - && UNAME_MACHINE=i686 - (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ - && UNAME_MACHINE=i686 - echo ${UNAME_MACHINE}-pc-sco$UNAME_REL - else - echo ${UNAME_MACHINE}-pc-sysv32 - fi - exit ;; - pc:*:*:*) - # Left here for compatibility: - # uname -m prints for DJGPP always 'pc', but it prints nothing about - # the processor, so we play safe by assuming i586. - # Note: whatever this is, it MUST be the same as what config.sub - # prints for the "djgpp" host, or else GDB configury will decide that - # this is a cross-build. - echo i586-pc-msdosdjgpp - exit ;; - Intel:Mach:3*:*) - echo i386-pc-mach3 - exit ;; - paragon:*:*:*) - echo i860-intel-osf1 - exit ;; - i860:*:4.*:*) # i860-SVR4 - if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then - echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4 - else # Add other i860-SVR4 vendors below as they are discovered. - echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4 - fi - exit ;; - mini*:CTIX:SYS*5:*) - # "miniframe" - echo m68010-convergent-sysv - exit ;; - mc68k:UNIX:SYSTEM5:3.51m) - echo m68k-convergent-sysv - exit ;; - M680?0:D-NIX:5.3:*) - echo m68k-diab-dnix - exit ;; - M68*:*:R3V[5678]*:*) - test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; - 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0) - OS_REL='' - test -r /etc/.relid \ - && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` - /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ - && { echo i486-ncr-sysv4.3${OS_REL}; exit; } - /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ - && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; - 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) - /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ - && { echo i486-ncr-sysv4; exit; } ;; - NCR*:*:4.2:* | MPRAS*:*:4.2:*) - OS_REL='.3' - test -r /etc/.relid \ - && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` - /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ - && { echo i486-ncr-sysv4.3${OS_REL}; exit; } - /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ - && { echo i586-ncr-sysv4.3${OS_REL}; exit; } - /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \ - && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; - m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) - echo m68k-unknown-lynxos${UNAME_RELEASE} - exit ;; - mc68030:UNIX_System_V:4.*:*) - echo m68k-atari-sysv4 - exit ;; - TSUNAMI:LynxOS:2.*:*) - echo sparc-unknown-lynxos${UNAME_RELEASE} - exit ;; - rs6000:LynxOS:2.*:*) - echo rs6000-unknown-lynxos${UNAME_RELEASE} - exit ;; - PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*) - echo powerpc-unknown-lynxos${UNAME_RELEASE} - exit ;; - SM[BE]S:UNIX_SV:*:*) - echo mips-dde-sysv${UNAME_RELEASE} - exit ;; - RM*:ReliantUNIX-*:*:*) - echo mips-sni-sysv4 - exit ;; - RM*:SINIX-*:*:*) - echo mips-sni-sysv4 - exit ;; - *:SINIX-*:*:*) - if uname -p 2>/dev/null >/dev/null ; then - UNAME_MACHINE=`(uname -p) 2>/dev/null` - echo ${UNAME_MACHINE}-sni-sysv4 - else - echo ns32k-sni-sysv - fi - exit ;; - PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort - # says - echo i586-unisys-sysv4 - exit ;; - *:UNIX_System_V:4*:FTX*) - # From Gerald Hewes . - # How about differentiating between stratus architectures? -djm - echo hppa1.1-stratus-sysv4 - exit ;; - *:*:*:FTX*) - # From seanf@swdc.stratus.com. - echo i860-stratus-sysv4 - exit ;; - i*86:VOS:*:*) - # From Paul.Green@stratus.com. - echo ${UNAME_MACHINE}-stratus-vos - exit ;; - *:VOS:*:*) - # From Paul.Green@stratus.com. - echo hppa1.1-stratus-vos - exit ;; - mc68*:A/UX:*:*) - echo m68k-apple-aux${UNAME_RELEASE} - exit ;; - news*:NEWS-OS:6*:*) - echo mips-sony-newsos6 - exit ;; - R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) - if [ -d /usr/nec ]; then - echo mips-nec-sysv${UNAME_RELEASE} - else - echo mips-unknown-sysv${UNAME_RELEASE} - fi - exit ;; - BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. - echo powerpc-be-beos - exit ;; - BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. - echo powerpc-apple-beos - exit ;; - BePC:BeOS:*:*) # BeOS running on Intel PC compatible. - echo i586-pc-beos - exit ;; - BePC:Haiku:*:*) # Haiku running on Intel PC compatible. - echo i586-pc-haiku - exit ;; - SX-4:SUPER-UX:*:*) - echo sx4-nec-superux${UNAME_RELEASE} - exit ;; - SX-5:SUPER-UX:*:*) - echo sx5-nec-superux${UNAME_RELEASE} - exit ;; - SX-6:SUPER-UX:*:*) - echo sx6-nec-superux${UNAME_RELEASE} - exit ;; - SX-7:SUPER-UX:*:*) - echo sx7-nec-superux${UNAME_RELEASE} - exit ;; - SX-8:SUPER-UX:*:*) - echo sx8-nec-superux${UNAME_RELEASE} - exit ;; - SX-8R:SUPER-UX:*:*) - echo sx8r-nec-superux${UNAME_RELEASE} - exit ;; - Power*:Rhapsody:*:*) - echo powerpc-apple-rhapsody${UNAME_RELEASE} - exit ;; - *:Rhapsody:*:*) - echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} - exit ;; - *:Darwin:*:*) - UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown - case $UNAME_PROCESSOR in - unknown) UNAME_PROCESSOR=powerpc ;; - esac - echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE} - exit ;; - *:procnto*:*:* | *:QNX:[0123456789]*:*) - UNAME_PROCESSOR=`uname -p` - if test "$UNAME_PROCESSOR" = "x86"; then - UNAME_PROCESSOR=i386 - UNAME_MACHINE=pc - fi - echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE} - exit ;; - *:QNX:*:4*) - echo i386-pc-qnx - exit ;; - NSE-?:NONSTOP_KERNEL:*:*) - echo nse-tandem-nsk${UNAME_RELEASE} - exit ;; - NSR-?:NONSTOP_KERNEL:*:*) - echo nsr-tandem-nsk${UNAME_RELEASE} - exit ;; - *:NonStop-UX:*:*) - echo mips-compaq-nonstopux - exit ;; - BS2000:POSIX*:*:*) - echo bs2000-siemens-sysv - exit ;; - DS/*:UNIX_System_V:*:*) - echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE} - exit ;; - *:Plan9:*:*) - # "uname -m" is not consistent, so use $cputype instead. 386 - # is converted to i386 for consistency with other x86 - # operating systems. - if test "$cputype" = "386"; then - UNAME_MACHINE=i386 - else - UNAME_MACHINE="$cputype" - fi - echo ${UNAME_MACHINE}-unknown-plan9 - exit ;; - *:TOPS-10:*:*) - echo pdp10-unknown-tops10 - exit ;; - *:TENEX:*:*) - echo pdp10-unknown-tenex - exit ;; - KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) - echo pdp10-dec-tops20 - exit ;; - XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) - echo pdp10-xkl-tops20 - exit ;; - *:TOPS-20:*:*) - echo pdp10-unknown-tops20 - exit ;; - *:ITS:*:*) - echo pdp10-unknown-its - exit ;; - SEI:*:*:SEIUX) - echo mips-sei-seiux${UNAME_RELEASE} - exit ;; - *:DragonFly:*:*) - echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` - exit ;; - *:*VMS:*:*) - UNAME_MACHINE=`(uname -p) 2>/dev/null` - case "${UNAME_MACHINE}" in - A*) echo alpha-dec-vms ; exit ;; - I*) echo ia64-dec-vms ; exit ;; - V*) echo vax-dec-vms ; exit ;; - esac ;; - *:XENIX:*:SysV) - echo i386-pc-xenix - exit ;; - i*86:skyos:*:*) - echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//' - exit ;; - i*86:rdos:*:*) - echo ${UNAME_MACHINE}-pc-rdos - exit ;; - i*86:AROS:*:*) - echo ${UNAME_MACHINE}-pc-aros - exit ;; -esac - -#echo '(No uname command or uname output not recognized.)' 1>&2 -#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2 - -eval $set_cc_for_build -cat >$dummy.c < -# include -#endif -main () -{ -#if defined (sony) -#if defined (MIPSEB) - /* BFD wants "bsd" instead of "newsos". Perhaps BFD should be changed, - I don't know.... */ - printf ("mips-sony-bsd\n"); exit (0); -#else -#include - printf ("m68k-sony-newsos%s\n", -#ifdef NEWSOS4 - "4" -#else - "" -#endif - ); exit (0); -#endif -#endif - -#if defined (__arm) && defined (__acorn) && defined (__unix) - printf ("arm-acorn-riscix\n"); exit (0); -#endif - -#if defined (hp300) && !defined (hpux) - printf ("m68k-hp-bsd\n"); exit (0); -#endif - -#if defined (NeXT) -#if !defined (__ARCHITECTURE__) -#define __ARCHITECTURE__ "m68k" -#endif - int version; - version=`(hostinfo | sed -n 's/.*NeXT Mach \([0-9]*\).*/\1/p') 2>/dev/null`; - if (version < 4) - printf ("%s-next-nextstep%d\n", __ARCHITECTURE__, version); - else - printf ("%s-next-openstep%d\n", __ARCHITECTURE__, version); - exit (0); -#endif - -#if defined (MULTIMAX) || defined (n16) -#if defined (UMAXV) - printf ("ns32k-encore-sysv\n"); exit (0); -#else -#if defined (CMU) - printf ("ns32k-encore-mach\n"); exit (0); -#else - printf ("ns32k-encore-bsd\n"); exit (0); -#endif -#endif -#endif - -#if defined (__386BSD__) - printf ("i386-pc-bsd\n"); exit (0); -#endif - -#if defined (sequent) -#if defined (i386) - printf ("i386-sequent-dynix\n"); exit (0); -#endif -#if defined (ns32000) - printf ("ns32k-sequent-dynix\n"); exit (0); -#endif -#endif - -#if defined (_SEQUENT_) - struct utsname un; - - uname(&un); - - if (strncmp(un.version, "V2", 2) == 0) { - printf ("i386-sequent-ptx2\n"); exit (0); - } - if (strncmp(un.version, "V1", 2) == 0) { /* XXX is V1 correct? */ - printf ("i386-sequent-ptx1\n"); exit (0); - } - printf ("i386-sequent-ptx\n"); exit (0); - -#endif - -#if defined (vax) -# if !defined (ultrix) -# include -# if defined (BSD) -# if BSD == 43 - printf ("vax-dec-bsd4.3\n"); exit (0); -# else -# if BSD == 199006 - printf ("vax-dec-bsd4.3reno\n"); exit (0); -# else - printf ("vax-dec-bsd\n"); exit (0); -# endif -# endif -# else - printf ("vax-dec-bsd\n"); exit (0); -# endif -# else - printf ("vax-dec-ultrix\n"); exit (0); -# endif -#endif - -#if defined (alliant) && defined (i860) - printf ("i860-alliant-bsd\n"); exit (0); -#endif - - exit (1); -} -EOF - -$CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null && SYSTEM_NAME=`$dummy` && - { echo "$SYSTEM_NAME"; exit; } - -# Apollos put the system type in the environment. - -test -d /usr/apollo && { echo ${ISP}-apollo-${SYSTYPE}; exit; } - -# Convex versions that predate uname can use getsysinfo(1) - -if [ -x /usr/convex/getsysinfo ] -then - case `getsysinfo -f cpu_type` in - c1*) - echo c1-convex-bsd - exit ;; - c2*) - if getsysinfo -f scalar_acc - then echo c32-convex-bsd - else echo c2-convex-bsd - fi - exit ;; - c34*) - echo c34-convex-bsd - exit ;; - c38*) - echo c38-convex-bsd - exit ;; - c4*) - echo c4-convex-bsd - exit ;; - esac -fi - -cat >&2 < in order to provide the needed -information to handle your system. - -config.guess timestamp = $timestamp - -uname -m = `(uname -m) 2>/dev/null || echo unknown` -uname -r = `(uname -r) 2>/dev/null || echo unknown` -uname -s = `(uname -s) 2>/dev/null || echo unknown` -uname -v = `(uname -v) 2>/dev/null || echo unknown` - -/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null` -/bin/uname -X = `(/bin/uname -X) 2>/dev/null` - -hostinfo = `(hostinfo) 2>/dev/null` -/bin/universe = `(/bin/universe) 2>/dev/null` -/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null` -/bin/arch = `(/bin/arch) 2>/dev/null` -/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null` -/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null` - -UNAME_MACHINE = ${UNAME_MACHINE} -UNAME_RELEASE = ${UNAME_RELEASE} -UNAME_SYSTEM = ${UNAME_SYSTEM} -UNAME_VERSION = ${UNAME_VERSION} -EOF - -exit 1 - -# Local variables: -# eval: (add-hook 'write-file-hooks 'time-stamp) -# time-stamp-start: "timestamp='" -# time-stamp-format: "%:y-%02m-%02d" -# time-stamp-end: "'" -# End: diff --git a/release/src/router/radvd/config.h.in b/release/src/router/radvd/config.h.in deleted file mode 100644 index d4964438af..0000000000 --- a/release/src/router/radvd/config.h.in +++ /dev/null @@ -1,111 +0,0 @@ -/* config.h.in. Generated from configure.in by autoheader. */ - -/* Define to 1 if you have the header file. */ -#undef HAVE_GETOPT_H - -/* Define to 1 if you have the `getopt_long' function. */ -#undef HAVE_GETOPT_LONG - -/* Define to 1 if you have the header file. */ -#undef HAVE_IFADDRS_H - -/* whether struct in6_addr has u6_addrXX and defines s6_addrXX */ -#undef HAVE_IN6_ADDR_S6_ADDR - -/* Define to 1 if you have the header file. */ -#undef HAVE_INTTYPES_H - -/* Define to 1 if you have the `c' library (-lc). */ -#undef HAVE_LIBC - -/* Define to 1 if you have the header file. */ -#undef HAVE_MACHINE_LIMITS_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_MACHINE_PARAM_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_MEMORY_H - -/* Linux netlink */ -#undef HAVE_NETLINK - -/* Define to 1 if you have the header file. */ -#undef HAVE_NET_IF_ARP_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_NET_IF_DL_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_NET_IF_TYPES_H - -/* whether struct sockaddr_in6 has sin6_scope_id */ -#undef HAVE_SIN6_SCOPE_ID - -/* Define to 1 if you have the header file. */ -#undef HAVE_STDINT_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_STDLIB_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_STRINGS_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_STRING_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_SYS_PARAM_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_SYS_SOCKIO_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_SYS_STAT_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_SYS_TIME_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_SYS_TYPES_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_TIME_H - -/* Define to 1 if you have the header file. */ -#undef HAVE_UNISTD_H - -/* Define to the address where bug reports for this package should be sent. */ -#undef PACKAGE_BUGREPORT - -/* Define to the full name of this package. */ -#undef PACKAGE_NAME - -/* Define to the full name and version of this package. */ -#undef PACKAGE_STRING - -/* Define to the one symbol short name of this package. */ -#undef PACKAGE_TARNAME - -/* Define to the home page for this package. */ -#undef PACKAGE_URL - -/* Define to the version of this package. */ -#undef PACKAGE_VERSION - -/* Define to 1 if you have the ANSI C header files. */ -#undef STDC_HEADERS - -/* Define to 1 if you can safely include both and . */ -#undef TIME_WITH_SYS_TIME - -/* Define to 1 if `lex' declares `yytext' as a `char *' by default, not a - `char[]'. */ -#undef YYTEXT_POINTER - -/* whether compiling on Linux, glibc>=2.8 doesn't expose in6_pktinfo - otherwise.. */ -#undef _GNU_SOURCE - -/* Define to empty if `const' does not conform to ANSI C. */ -#undef const diff --git a/release/src/router/radvd/config.sub b/release/src/router/radvd/config.sub deleted file mode 100755 index eb0389a693..0000000000 --- a/release/src/router/radvd/config.sub +++ /dev/null @@ -1,1693 +0,0 @@ -#! /bin/sh -# Configuration validation subroutine script. -# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, -# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 -# Free Software Foundation, Inc. - -timestamp='2009-06-11' - -# This file is (in principle) common to ALL GNU software. -# The presence of a machine in this file suggests that SOME GNU software -# can handle that machine. It does not imply ALL GNU software can. -# -# This file 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; either version 2 of the License, or -# (at your option) any later version. -# -# 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, write to the Free Software -# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA -# 02110-1301, USA. -# -# As a special exception to the GNU General Public License, if you -# distribute this file as part of a program that contains a -# configuration script generated by Autoconf, you may include it under -# the same distribution terms that you use for the rest of that program. - - -# Please send patches to . Submit a context -# diff and a properly formatted ChangeLog entry. -# -# Configuration subroutine to validate and canonicalize a configuration type. -# Supply the specified configuration type as an argument. -# If it is invalid, we print an error message on stderr and exit with code 1. -# Otherwise, we print the canonical config type on stdout and succeed. - -# This file is supposed to be the same for all GNU packages -# and recognize all the CPU types, system types and aliases -# that are meaningful with *any* GNU software. -# Each package is responsible for reporting which valid configurations -# it does not support. The user should be able to distinguish -# a failure to support a valid configuration from a meaningless -# configuration. - -# The goal of this file is to map all the various variations of a given -# machine specification into a single specification in the form: -# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM -# or in some cases, the newer four-part form: -# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM -# It is wrong to echo any other type of specification. - -me=`echo "$0" | sed -e 's,.*/,,'` - -usage="\ -Usage: $0 [OPTION] CPU-MFR-OPSYS - $0 [OPTION] ALIAS - -Canonicalize a configuration name. - -Operation modes: - -h, --help print this help, then exit - -t, --time-stamp print date of last modification, then exit - -v, --version print version number, then exit - -Report bugs and patches to ." - -version="\ -GNU config.sub ($timestamp) - -Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, -2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. - -This is free software; see the source for copying conditions. There is NO -warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." - -help=" -Try \`$me --help' for more information." - -# Parse command line -while test $# -gt 0 ; do - case $1 in - --time-stamp | --time* | -t ) - echo "$timestamp" ; exit ;; - --version | -v ) - echo "$version" ; exit ;; - --help | --h* | -h ) - echo "$usage"; exit ;; - -- ) # Stop option processing - shift; break ;; - - ) # Use stdin as input. - break ;; - -* ) - echo "$me: invalid option $1$help" - exit 1 ;; - - *local*) - # First pass through any local machine types. - echo $1 - exit ;; - - * ) - break ;; - esac -done - -case $# in - 0) echo "$me: missing argument$help" >&2 - exit 1;; - 1) ;; - *) echo "$me: too many arguments$help" >&2 - exit 1;; -esac - -# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any). -# Here we must recognize all the valid KERNEL-OS combinations. -maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'` -case $maybe_os in - nto-qnx* | linux-gnu* | linux-dietlibc | linux-newlib* | linux-uclibc* | \ - uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* | \ - kopensolaris*-gnu* | \ - storm-chaos* | os2-emx* | rtmk-nova*) - os=-$maybe_os - basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'` - ;; - *) - basic_machine=`echo $1 | sed 's/-[^-]*$//'` - if [ $basic_machine != $1 ] - then os=`echo $1 | sed 's/.*-/-/'` - else os=; fi - ;; -esac - -### Let's recognize common machines as not being operating systems so -### that things like config.sub decstation-3100 work. We also -### recognize some manufacturers as not being operating systems, so we -### can provide default operating systems below. -case $os in - -sun*os*) - # Prevent following clause from handling this invalid input. - ;; - -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \ - -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \ - -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \ - -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\ - -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \ - -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \ - -apple | -axis | -knuth | -cray) - os= - basic_machine=$1 - ;; - -bluegene*) - os=-cnk - ;; - -sim | -cisco | -oki | -wec | -winbond) - os= - basic_machine=$1 - ;; - -scout) - ;; - -wrs) - os=-vxworks - basic_machine=$1 - ;; - -chorusos*) - os=-chorusos - basic_machine=$1 - ;; - -chorusrdb) - os=-chorusrdb - basic_machine=$1 - ;; - -hiux*) - os=-hiuxwe2 - ;; - -sco6) - os=-sco5v6 - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco5) - os=-sco3.2v5 - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco4) - os=-sco3.2v4 - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco3.2.[4-9]*) - os=`echo $os | sed -e 's/sco3.2./sco3.2v/'` - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco3.2v[4-9]*) - # Don't forget version if it is 3.2v4 or newer. - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco5v6*) - # Don't forget version if it is 3.2v4 or newer. - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -sco*) - os=-sco3.2v2 - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -udk*) - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -isc) - os=-isc2.2 - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -clix*) - basic_machine=clipper-intergraph - ;; - -isc*) - basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` - ;; - -lynx*) - os=-lynxos - ;; - -ptx*) - basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'` - ;; - -windowsnt*) - os=`echo $os | sed -e 's/windowsnt/winnt/'` - ;; - -psos*) - os=-psos - ;; - -mint | -mint[0-9]*) - basic_machine=m68k-atari - os=-mint - ;; -esac - -# Decode aliases for certain CPU-COMPANY combinations. -case $basic_machine in - # Recognize the basic CPU types without company name. - # Some are omitted here because they have special meanings below. - 1750a | 580 \ - | a29k \ - | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \ - | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \ - | am33_2.0 \ - | arc | arm | arm[bl]e | arme[lb] | armv[2345] | armv[345][lb] | avr | avr32 \ - | bfin \ - | c4x | clipper \ - | d10v | d30v | dlx | dsp16xx \ - | fido | fr30 | frv \ - | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \ - | i370 | i860 | i960 | ia64 \ - | ip2k | iq2000 \ - | lm32 \ - | m32c | m32r | m32rle | m68000 | m68k | m88k \ - | maxq | mb | microblaze | mcore | mep | metag \ - | mips | mipsbe | mipseb | mipsel | mipsle \ - | mips16 \ - | mips64 | mips64el \ - | mips64octeon | mips64octeonel \ - | mips64orion | mips64orionel \ - | mips64r5900 | mips64r5900el \ - | mips64vr | mips64vrel \ - | mips64vr4100 | mips64vr4100el \ - | mips64vr4300 | mips64vr4300el \ - | mips64vr5000 | mips64vr5000el \ - | mips64vr5900 | mips64vr5900el \ - | mipsisa32 | mipsisa32el \ - | mipsisa32r2 | mipsisa32r2el \ - | mipsisa64 | mipsisa64el \ - | mipsisa64r2 | mipsisa64r2el \ - | mipsisa64sb1 | mipsisa64sb1el \ - | mipsisa64sr71k | mipsisa64sr71kel \ - | mipstx39 | mipstx39el \ - | mn10200 | mn10300 \ - | moxie \ - | mt \ - | msp430 \ - | nios | nios2 \ - | ns16k | ns32k \ - | or32 \ - | pdp10 | pdp11 | pj | pjl \ - | powerpc | powerpc64 | powerpc64le | powerpcle | ppcbe \ - | pyramid \ - | score \ - | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \ - | sh64 | sh64le \ - | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \ - | sparcv8 | sparcv9 | sparcv9b | sparcv9v \ - | spu | strongarm \ - | tahoe | thumb | tic4x | tic80 | tron \ - | v850 | v850e \ - | we32k \ - | x86 | xc16x | xscale | xscalee[bl] | xstormy16 | xtensa \ - | z8k | z80) - basic_machine=$basic_machine-unknown - ;; - m6811 | m68hc11 | m6812 | m68hc12) - # Motorola 68HC11/12. - basic_machine=$basic_machine-unknown - os=-none - ;; - m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k) - ;; - ms1) - basic_machine=mt-unknown - ;; - - # We use `pc' rather than `unknown' - # because (1) that's what they normally are, and - # (2) the word "unknown" tends to confuse beginning users. - i*86 | x86_64) - basic_machine=$basic_machine-pc - ;; - # Object if more than one company name word. - *-*-*) - echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 - exit 1 - ;; - # Recognize the basic CPU types with company name. - 580-* \ - | a29k-* \ - | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \ - | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \ - | alphapca5[67]-* | alpha64pca5[67]-* | arc-* \ - | arm-* | armbe-* | armle-* | armeb-* | armv*-* \ - | avr-* | avr32-* \ - | bfin-* | bs2000-* \ - | c[123]* | c30-* | [cjt]90-* | c4x-* | c54x-* | c55x-* | c6x-* \ - | clipper-* | craynv-* | cydra-* \ - | d10v-* | d30v-* | dlx-* \ - | elxsi-* \ - | f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \ - | h8300-* | h8500-* \ - | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \ - | i*86-* | i860-* | i960-* | ia64-* \ - | ip2k-* | iq2000-* \ - | lm32-* \ - | m32c-* | m32r-* | m32rle-* \ - | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \ - | m88110-* | m88k-* | maxq-* | mcore-* | metag-* \ - | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \ - | mips16-* \ - | mips64-* | mips64el-* \ - | mips64octeon-* | mips64octeonel-* \ - | mips64orion-* | mips64orionel-* \ - | mips64r5900-* | mips64r5900el-* \ - | mips64vr-* | mips64vrel-* \ - | mips64vr4100-* | mips64vr4100el-* \ - | mips64vr4300-* | mips64vr4300el-* \ - | mips64vr5000-* | mips64vr5000el-* \ - | mips64vr5900-* | mips64vr5900el-* \ - | mipsisa32-* | mipsisa32el-* \ - | mipsisa32r2-* | mipsisa32r2el-* \ - | mipsisa64-* | mipsisa64el-* \ - | mipsisa64r2-* | mipsisa64r2el-* \ - | mipsisa64sb1-* | mipsisa64sb1el-* \ - | mipsisa64sr71k-* | mipsisa64sr71kel-* \ - | mipstx39-* | mipstx39el-* \ - | mmix-* \ - | mt-* \ - | msp430-* \ - | nios-* | nios2-* \ - | none-* | np1-* | ns16k-* | ns32k-* \ - | orion-* \ - | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \ - | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | ppcbe-* \ - | pyramid-* \ - | romp-* | rs6000-* \ - | sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \ - | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \ - | sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \ - | sparclite-* \ - | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | strongarm-* | sv1-* | sx?-* \ - | tahoe-* | thumb-* \ - | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* | tile-* \ - | tron-* \ - | v850-* | v850e-* | vax-* \ - | we32k-* \ - | x86-* | x86_64-* | xc16x-* | xps100-* | xscale-* | xscalee[bl]-* \ - | xstormy16-* | xtensa*-* \ - | ymp-* \ - | z8k-* | z80-*) - ;; - # Recognize the basic CPU types without company name, with glob match. - xtensa*) - basic_machine=$basic_machine-unknown - ;; - # Recognize the various machine names and aliases which stand - # for a CPU type and a company and sometimes even an OS. - 386bsd) - basic_machine=i386-unknown - os=-bsd - ;; - 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) - basic_machine=m68000-att - ;; - 3b*) - basic_machine=we32k-att - ;; - a29khif) - basic_machine=a29k-amd - os=-udi - ;; - abacus) - basic_machine=abacus-unknown - ;; - adobe68k) - basic_machine=m68010-adobe - os=-scout - ;; - alliant | fx80) - basic_machine=fx80-alliant - ;; - altos | altos3068) - basic_machine=m68k-altos - ;; - am29k) - basic_machine=a29k-none - os=-bsd - ;; - amd64) - basic_machine=x86_64-pc - ;; - amd64-*) - basic_machine=x86_64-`echo $basic_machine | sed 's/^[^-]*-//'` - ;; - amdahl) - basic_machine=580-amdahl - os=-sysv - ;; - amiga | amiga-*) - basic_machine=m68k-unknown - ;; - amigaos | amigados) - basic_machine=m68k-unknown - os=-amigaos - ;; - amigaunix | amix) - basic_machine=m68k-unknown - os=-sysv4 - ;; - apollo68) - basic_machine=m68k-apollo - os=-sysv - ;; - apollo68bsd) - basic_machine=m68k-apollo - os=-bsd - ;; - aros) - basic_machine=i386-pc - os=-aros - ;; - aux) - basic_machine=m68k-apple - os=-aux - ;; - balance) - basic_machine=ns32k-sequent - os=-dynix - ;; - blackfin) - basic_machine=bfin-unknown - os=-linux - ;; - blackfin-*) - basic_machine=bfin-`echo $basic_machine | sed 's/^[^-]*-//'` - os=-linux - ;; - bluegene*) - basic_machine=powerpc-ibm - os=-cnk - ;; - c90) - basic_machine=c90-cray - os=-unicos - ;; - cegcc) - basic_machine=arm-unknown - os=-cegcc - ;; - convex-c1) - basic_machine=c1-convex - os=-bsd - ;; - convex-c2) - basic_machine=c2-convex - os=-bsd - ;; - convex-c32) - basic_machine=c32-convex - os=-bsd - ;; - convex-c34) - basic_machine=c34-convex - os=-bsd - ;; - convex-c38) - basic_machine=c38-convex - os=-bsd - ;; - cray | j90) - basic_machine=j90-cray - os=-unicos - ;; - craynv) - basic_machine=craynv-cray - os=-unicosmp - ;; - cr16) - basic_machine=cr16-unknown - os=-elf - ;; - crds | unos) - basic_machine=m68k-crds - ;; - crisv32 | crisv32-* | etraxfs*) - basic_machine=crisv32-axis - ;; - cris | cris-* | etrax*) - basic_machine=cris-axis - ;; - crx) - basic_machine=crx-unknown - os=-elf - ;; - da30 | da30-*) - basic_machine=m68k-da30 - ;; - decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn) - basic_machine=mips-dec - ;; - decsystem10* | dec10*) - basic_machine=pdp10-dec - os=-tops10 - ;; - decsystem20* | dec20*) - basic_machine=pdp10-dec - os=-tops20 - ;; - delta | 3300 | motorola-3300 | motorola-delta \ - | 3300-motorola | delta-motorola) - basic_machine=m68k-motorola - ;; - delta88) - basic_machine=m88k-motorola - os=-sysv3 - ;; - dicos) - basic_machine=i686-pc - os=-dicos - ;; - djgpp) - basic_machine=i586-pc - os=-msdosdjgpp - ;; - dpx20 | dpx20-*) - basic_machine=rs6000-bull - os=-bosx - ;; - dpx2* | dpx2*-bull) - basic_machine=m68k-bull - os=-sysv3 - ;; - ebmon29k) - basic_machine=a29k-amd - os=-ebmon - ;; - elxsi) - basic_machine=elxsi-elxsi - os=-bsd - ;; - encore | umax | mmax) - basic_machine=ns32k-encore - ;; - es1800 | OSE68k | ose68k | ose | OSE) - basic_machine=m68k-ericsson - os=-ose - ;; - fx2800) - basic_machine=i860-alliant - ;; - genix) - basic_machine=ns32k-ns - ;; - gmicro) - basic_machine=tron-gmicro - os=-sysv - ;; - go32) - basic_machine=i386-pc - os=-go32 - ;; - h3050r* | hiux*) - basic_machine=hppa1.1-hitachi - os=-hiuxwe2 - ;; - h8300hms) - basic_machine=h8300-hitachi - os=-hms - ;; - h8300xray) - basic_machine=h8300-hitachi - os=-xray - ;; - h8500hms) - basic_machine=h8500-hitachi - os=-hms - ;; - harris) - basic_machine=m88k-harris - os=-sysv3 - ;; - hp300-*) - basic_machine=m68k-hp - ;; - hp300bsd) - basic_machine=m68k-hp - os=-bsd - ;; - hp300hpux) - basic_machine=m68k-hp - os=-hpux - ;; - hp3k9[0-9][0-9] | hp9[0-9][0-9]) - basic_machine=hppa1.0-hp - ;; - hp9k2[0-9][0-9] | hp9k31[0-9]) - basic_machine=m68000-hp - ;; - hp9k3[2-9][0-9]) - basic_machine=m68k-hp - ;; - hp9k6[0-9][0-9] | hp6[0-9][0-9]) - basic_machine=hppa1.0-hp - ;; - hp9k7[0-79][0-9] | hp7[0-79][0-9]) - basic_machine=hppa1.1-hp - ;; - hp9k78[0-9] | hp78[0-9]) - # FIXME: really hppa2.0-hp - basic_machine=hppa1.1-hp - ;; - hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893) - # FIXME: really hppa2.0-hp - basic_machine=hppa1.1-hp - ;; - hp9k8[0-9][13679] | hp8[0-9][13679]) - basic_machine=hppa1.1-hp - ;; - hp9k8[0-9][0-9] | hp8[0-9][0-9]) - basic_machine=hppa1.0-hp - ;; - hppa-next) - os=-nextstep3 - ;; - hppaosf) - basic_machine=hppa1.1-hp - os=-osf - ;; - hppro) - basic_machine=hppa1.1-hp - os=-proelf - ;; - i370-ibm* | ibm*) - basic_machine=i370-ibm - ;; -# I'm not sure what "Sysv32" means. Should this be sysv3.2? - i*86v32) - basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` - os=-sysv32 - ;; - i*86v4*) - basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` - os=-sysv4 - ;; - i*86v) - basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` - os=-sysv - ;; - i*86sol2) - basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` - os=-solaris2 - ;; - i386mach) - basic_machine=i386-mach - os=-mach - ;; - i386-vsta | vsta) - basic_machine=i386-unknown - os=-vsta - ;; - iris | iris4d) - basic_machine=mips-sgi - case $os in - -irix*) - ;; - *) - os=-irix4 - ;; - esac - ;; - isi68 | isi) - basic_machine=m68k-isi - os=-sysv - ;; - m68knommu) - basic_machine=m68k-unknown - os=-linux - ;; - m68knommu-*) - basic_machine=m68k-`echo $basic_machine | sed 's/^[^-]*-//'` - os=-linux - ;; - m88k-omron*) - basic_machine=m88k-omron - ;; - magnum | m3230) - basic_machine=mips-mips - os=-sysv - ;; - merlin) - basic_machine=ns32k-utek - os=-sysv - ;; - mingw32) - basic_machine=i386-pc - os=-mingw32 - ;; - mingw32ce) - basic_machine=arm-unknown - os=-mingw32ce - ;; - miniframe) - basic_machine=m68000-convergent - ;; - *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*) - basic_machine=m68k-atari - os=-mint - ;; - mips3*-*) - basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'` - ;; - mips3*) - basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown - ;; - monitor) - basic_machine=m68k-rom68k - os=-coff - ;; - morphos) - basic_machine=powerpc-unknown - os=-morphos - ;; - msdos) - basic_machine=i386-pc - os=-msdos - ;; - ms1-*) - basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'` - ;; - mvs) - basic_machine=i370-ibm - os=-mvs - ;; - ncr3000) - basic_machine=i486-ncr - os=-sysv4 - ;; - netbsd386) - basic_machine=i386-unknown - os=-netbsd - ;; - netwinder) - basic_machine=armv4l-rebel - os=-linux - ;; - news | news700 | news800 | news900) - basic_machine=m68k-sony - os=-newsos - ;; - news1000) - basic_machine=m68030-sony - os=-newsos - ;; - news-3600 | risc-news) - basic_machine=mips-sony - os=-newsos - ;; - necv70) - basic_machine=v70-nec - os=-sysv - ;; - next | m*-next ) - basic_machine=m68k-next - case $os in - -nextstep* ) - ;; - -ns2*) - os=-nextstep2 - ;; - *) - os=-nextstep3 - ;; - esac - ;; - nh3000) - basic_machine=m68k-harris - os=-cxux - ;; - nh[45]000) - basic_machine=m88k-harris - os=-cxux - ;; - nindy960) - basic_machine=i960-intel - os=-nindy - ;; - mon960) - basic_machine=i960-intel - os=-mon960 - ;; - nonstopux) - basic_machine=mips-compaq - os=-nonstopux - ;; - np1) - basic_machine=np1-gould - ;; - nsr-tandem) - basic_machine=nsr-tandem - ;; - op50n-* | op60c-*) - basic_machine=hppa1.1-oki - os=-proelf - ;; - openrisc | openrisc-*) - basic_machine=or32-unknown - ;; - os400) - basic_machine=powerpc-ibm - os=-os400 - ;; - OSE68000 | ose68000) - basic_machine=m68000-ericsson - os=-ose - ;; - os68k) - basic_machine=m68k-none - os=-os68k - ;; - pa-hitachi) - basic_machine=hppa1.1-hitachi - os=-hiuxwe2 - ;; - paragon) - basic_machine=i860-intel - os=-osf - ;; - parisc) - basic_machine=hppa-unknown - os=-linux - ;; - parisc-*) - basic_machine=hppa-`echo $basic_machine | sed 's/^[^-]*-//'` - os=-linux - ;; - pbd) - basic_machine=sparc-tti - ;; - pbb) - basic_machine=m68k-tti - ;; - pc532 | pc532-*) - basic_machine=ns32k-pc532 - ;; - pc98) - basic_machine=i386-pc - ;; - pc98-*) - basic_machine=i386-`echo $basic_machine | sed 's/^[^-]*-//'` - ;; - pentium | p5 | k5 | k6 | nexgen | viac3) - basic_machine=i586-pc - ;; - pentiumpro | p6 | 6x86 | athlon | athlon_*) - basic_machine=i686-pc - ;; - pentiumii | pentium2 | pentiumiii | pentium3) - basic_machine=i686-pc - ;; - pentium4) - basic_machine=i786-pc - ;; - pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*) - basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'` - ;; - pentiumpro-* | p6-* | 6x86-* | athlon-*) - basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` - ;; - pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*) - basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` - ;; - pentium4-*) - basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'` - ;; - pn) - basic_machine=pn-gould - ;; - power) basic_machine=power-ibm - ;; - ppc) basic_machine=powerpc-unknown - ;; - ppc-*) basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'` - ;; - ppcle | powerpclittle | ppc-le | powerpc-little) - basic_machine=powerpcle-unknown - ;; - ppcle-* | powerpclittle-*) - basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'` - ;; - ppc64) basic_machine=powerpc64-unknown - ;; - ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'` - ;; - ppc64le | powerpc64little | ppc64-le | powerpc64-little) - basic_machine=powerpc64le-unknown - ;; - ppc64le-* | powerpc64little-*) - basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'` - ;; - ps2) - basic_machine=i386-ibm - ;; - pw32) - basic_machine=i586-unknown - os=-pw32 - ;; - rdos) - basic_machine=i386-pc - os=-rdos - ;; - rom68k) - basic_machine=m68k-rom68k - os=-coff - ;; - rm[46]00) - basic_machine=mips-siemens - ;; - rtpc | rtpc-*) - basic_machine=romp-ibm - ;; - s390 | s390-*) - basic_machine=s390-ibm - ;; - s390x | s390x-*) - basic_machine=s390x-ibm - ;; - sa29200) - basic_machine=a29k-amd - os=-udi - ;; - sb1) - basic_machine=mipsisa64sb1-unknown - ;; - sb1el) - basic_machine=mipsisa64sb1el-unknown - ;; - sde) - basic_machine=mipsisa32-sde - os=-elf - ;; - sei) - basic_machine=mips-sei - os=-seiux - ;; - sequent) - basic_machine=i386-sequent - ;; - sh) - basic_machine=sh-hitachi - os=-hms - ;; - sh5el) - basic_machine=sh5le-unknown - ;; - sh64) - basic_machine=sh64-unknown - ;; - sparclite-wrs | simso-wrs) - basic_machine=sparclite-wrs - os=-vxworks - ;; - sps7) - basic_machine=m68k-bull - os=-sysv2 - ;; - spur) - basic_machine=spur-unknown - ;; - st2000) - basic_machine=m68k-tandem - ;; - stratus) - basic_machine=i860-stratus - os=-sysv4 - ;; - sun2) - basic_machine=m68000-sun - ;; - sun2os3) - basic_machine=m68000-sun - os=-sunos3 - ;; - sun2os4) - basic_machine=m68000-sun - os=-sunos4 - ;; - sun3os3) - basic_machine=m68k-sun - os=-sunos3 - ;; - sun3os4) - basic_machine=m68k-sun - os=-sunos4 - ;; - sun4os3) - basic_machine=sparc-sun - os=-sunos3 - ;; - sun4os4) - basic_machine=sparc-sun - os=-sunos4 - ;; - sun4sol2) - basic_machine=sparc-sun - os=-solaris2 - ;; - sun3 | sun3-*) - basic_machine=m68k-sun - ;; - sun4) - basic_machine=sparc-sun - ;; - sun386 | sun386i | roadrunner) - basic_machine=i386-sun - ;; - sv1) - basic_machine=sv1-cray - os=-unicos - ;; - symmetry) - basic_machine=i386-sequent - os=-dynix - ;; - t3e) - basic_machine=alphaev5-cray - os=-unicos - ;; - t90) - basic_machine=t90-cray - os=-unicos - ;; - tic54x | c54x*) - basic_machine=tic54x-unknown - os=-coff - ;; - tic55x | c55x*) - basic_machine=tic55x-unknown - os=-coff - ;; - tic6x | c6x*) - basic_machine=tic6x-unknown - os=-coff - ;; - tile*) - basic_machine=tile-unknown - os=-linux-gnu - ;; - tx39) - basic_machine=mipstx39-unknown - ;; - tx39el) - basic_machine=mipstx39el-unknown - ;; - toad1) - basic_machine=pdp10-xkl - os=-tops20 - ;; - tower | tower-32) - basic_machine=m68k-ncr - ;; - tpf) - basic_machine=s390x-ibm - os=-tpf - ;; - udi29k) - basic_machine=a29k-amd - os=-udi - ;; - ultra3) - basic_machine=a29k-nyu - os=-sym1 - ;; - v810 | necv810) - basic_machine=v810-nec - os=-none - ;; - vaxv) - basic_machine=vax-dec - os=-sysv - ;; - vms) - basic_machine=vax-dec - os=-vms - ;; - vpp*|vx|vx-*) - basic_machine=f301-fujitsu - ;; - vxworks960) - basic_machine=i960-wrs - os=-vxworks - ;; - vxworks68) - basic_machine=m68k-wrs - os=-vxworks - ;; - vxworks29k) - basic_machine=a29k-wrs - os=-vxworks - ;; - w65*) - basic_machine=w65-wdc - os=-none - ;; - w89k-*) - basic_machine=hppa1.1-winbond - os=-proelf - ;; - xbox) - basic_machine=i686-pc - os=-mingw32 - ;; - xps | xps100) - basic_machine=xps100-honeywell - ;; - ymp) - basic_machine=ymp-cray - os=-unicos - ;; - z8k-*-coff) - basic_machine=z8k-unknown - os=-sim - ;; - z80-*-coff) - basic_machine=z80-unknown - os=-sim - ;; - none) - basic_machine=none-none - os=-none - ;; - -# Here we handle the default manufacturer of certain CPU types. It is in -# some cases the only manufacturer, in others, it is the most popular. - w89k) - basic_machine=hppa1.1-winbond - ;; - op50n) - basic_machine=hppa1.1-oki - ;; - op60c) - basic_machine=hppa1.1-oki - ;; - romp) - basic_machine=romp-ibm - ;; - mmix) - basic_machine=mmix-knuth - ;; - rs6000) - basic_machine=rs6000-ibm - ;; - vax) - basic_machine=vax-dec - ;; - pdp10) - # there are many clones, so DEC is not a safe bet - basic_machine=pdp10-unknown - ;; - pdp11) - basic_machine=pdp11-dec - ;; - we32k) - basic_machine=we32k-att - ;; - sh[1234] | sh[24]a | sh[24]aeb | sh[34]eb | sh[1234]le | sh[23]ele) - basic_machine=sh-unknown - ;; - sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v) - basic_machine=sparc-sun - ;; - cydra) - basic_machine=cydra-cydrome - ;; - orion) - basic_machine=orion-highlevel - ;; - orion105) - basic_machine=clipper-highlevel - ;; - mac | mpw | mac-mpw) - basic_machine=m68k-apple - ;; - pmac | pmac-mpw) - basic_machine=powerpc-apple - ;; - *-unknown) - # Make sure to match an already-canonicalized machine name. - ;; - *) - echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 - exit 1 - ;; -esac - -# Here we canonicalize certain aliases for manufacturers. -case $basic_machine in - *-digital*) - basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'` - ;; - *-commodore*) - basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'` - ;; - *) - ;; -esac - -# Decode manufacturer-specific aliases for certain operating systems. - -if [ x"$os" != x"" ] -then -case $os in - # First match some system type aliases - # that might get confused with valid system types. - # -solaris* is a basic system type, with this one exception. - -solaris1 | -solaris1.*) - os=`echo $os | sed -e 's|solaris1|sunos4|'` - ;; - -solaris) - os=-solaris2 - ;; - -svr4*) - os=-sysv4 - ;; - -unixware*) - os=-sysv4.2uw - ;; - -gnu/linux*) - os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` - ;; - # First accept the basic system types. - # The portable systems comes first. - # Each alternative MUST END IN A *, to match a version number. - # -sysv* is not here because it comes later, after sysvr4. - -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \ - | -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\ - | -hpux* | -unos* | -osf* | -luna* | -dgux* | -solaris* | -sym* \ - | -kopensolaris* \ - | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \ - | -aos* | -aros* \ - | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ - | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ - | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \ - | -openbsd* | -solidbsd* \ - | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \ - | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \ - | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ - | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ - | -chorusos* | -chorusrdb* | -cegcc* \ - | -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ - | -mingw32* | -linux-gnu* | -linux-newlib* | -linux-uclibc* \ - | -uxpv* | -beos* | -mpeix* | -udk* \ - | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \ - | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \ - | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \ - | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \ - | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \ - | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ - | -skyos* | -haiku* | -rdos* | -toppers* | -drops*) - # Remember, each alternative MUST END IN *, to match a version number. - ;; - -qnx*) - case $basic_machine in - x86-* | i*86-*) - ;; - *) - os=-nto$os - ;; - esac - ;; - -nto-qnx*) - ;; - -nto*) - os=`echo $os | sed -e 's|nto|nto-qnx|'` - ;; - -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \ - | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \ - | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*) - ;; - -mac*) - os=`echo $os | sed -e 's|mac|macos|'` - ;; - -linux-dietlibc) - os=-linux-dietlibc - ;; - -linux*) - os=`echo $os | sed -e 's|linux|linux-gnu|'` - ;; - -sunos5*) - os=`echo $os | sed -e 's|sunos5|solaris2|'` - ;; - -sunos6*) - os=`echo $os | sed -e 's|sunos6|solaris3|'` - ;; - -opened*) - os=-openedition - ;; - -os400*) - os=-os400 - ;; - -wince*) - os=-wince - ;; - -osfrose*) - os=-osfrose - ;; - -osf*) - os=-osf - ;; - -utek*) - os=-bsd - ;; - -dynix*) - os=-bsd - ;; - -acis*) - os=-aos - ;; - -atheos*) - os=-atheos - ;; - -syllable*) - os=-syllable - ;; - -386bsd) - os=-bsd - ;; - -ctix* | -uts*) - os=-sysv - ;; - -nova*) - os=-rtmk-nova - ;; - -ns2 ) - os=-nextstep2 - ;; - -nsk*) - os=-nsk - ;; - # Preserve the version number of sinix5. - -sinix5.*) - os=`echo $os | sed -e 's|sinix|sysv|'` - ;; - -sinix*) - os=-sysv4 - ;; - -tpf*) - os=-tpf - ;; - -triton*) - os=-sysv3 - ;; - -oss*) - os=-sysv3 - ;; - -svr4) - os=-sysv4 - ;; - -svr3) - os=-sysv3 - ;; - -sysvr4) - os=-sysv4 - ;; - # This must come after -sysvr4. - -sysv*) - ;; - -ose*) - os=-ose - ;; - -es1800*) - os=-ose - ;; - -xenix) - os=-xenix - ;; - -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) - os=-mint - ;; - -aros*) - os=-aros - ;; - -kaos*) - os=-kaos - ;; - -zvmoe) - os=-zvmoe - ;; - -dicos*) - os=-dicos - ;; - -none) - ;; - *) - # Get rid of the `-' at the beginning of $os. - os=`echo $os | sed 's/[^-]*-//'` - echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 - exit 1 - ;; -esac -else - -# Here we handle the default operating systems that come with various machines. -# The value should be what the vendor currently ships out the door with their -# machine or put another way, the most popular os provided with the machine. - -# Note that if you're going to try to match "-MANUFACTURER" here (say, -# "-sun"), then you have to tell the case statement up towards the top -# that MANUFACTURER isn't an operating system. Otherwise, code above -# will signal an error saying that MANUFACTURER isn't an operating -# system, and we'll never get to this point. - -case $basic_machine in - score-*) - os=-elf - ;; - spu-*) - os=-elf - ;; - *-acorn) - os=-riscix1.2 - ;; - arm*-rebel) - os=-linux - ;; - arm*-semi) - os=-aout - ;; - c4x-* | tic4x-*) - os=-coff - ;; - # This must come before the *-dec entry. - pdp10-*) - os=-tops20 - ;; - pdp11-*) - os=-none - ;; - *-dec | vax-*) - os=-ultrix4.2 - ;; - m68*-apollo) - os=-domain - ;; - i386-sun) - os=-sunos4.0.2 - ;; - m68000-sun) - os=-sunos3 - # This also exists in the configure program, but was not the - # default. - # os=-sunos4 - ;; - m68*-cisco) - os=-aout - ;; - mep-*) - os=-elf - ;; - mips*-cisco) - os=-elf - ;; - mips*-*) - os=-elf - ;; - or32-*) - os=-coff - ;; - *-tti) # must be before sparc entry or we get the wrong os. - os=-sysv3 - ;; - sparc-* | *-sun) - os=-sunos4.1.1 - ;; - *-be) - os=-beos - ;; - *-haiku) - os=-haiku - ;; - *-ibm) - os=-aix - ;; - *-knuth) - os=-mmixware - ;; - *-wec) - os=-proelf - ;; - *-winbond) - os=-proelf - ;; - *-oki) - os=-proelf - ;; - *-hp) - os=-hpux - ;; - *-hitachi) - os=-hiux - ;; - i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent) - os=-sysv - ;; - *-cbm) - os=-amigaos - ;; - *-dg) - os=-dgux - ;; - *-dolphin) - os=-sysv3 - ;; - m68k-ccur) - os=-rtu - ;; - m88k-omron*) - os=-luna - ;; - *-next ) - os=-nextstep - ;; - *-sequent) - os=-ptx - ;; - *-crds) - os=-unos - ;; - *-ns) - os=-genix - ;; - i370-*) - os=-mvs - ;; - *-next) - os=-nextstep3 - ;; - *-gould) - os=-sysv - ;; - *-highlevel) - os=-bsd - ;; - *-encore) - os=-bsd - ;; - *-sgi) - os=-irix - ;; - *-siemens) - os=-sysv4 - ;; - *-masscomp) - os=-rtu - ;; - f30[01]-fujitsu | f700-fujitsu) - os=-uxpv - ;; - *-rom68k) - os=-coff - ;; - *-*bug) - os=-coff - ;; - *-apple) - os=-macos - ;; - *-atari*) - os=-mint - ;; - *) - os=-none - ;; -esac -fi - -# Here we handle the case where we know the os, and the CPU type, but not the -# manufacturer. We pick the logical manufacturer. -vendor=unknown -case $basic_machine in - *-unknown) - case $os in - -riscix*) - vendor=acorn - ;; - -sunos*) - vendor=sun - ;; - -cnk*|-aix*) - vendor=ibm - ;; - -beos*) - vendor=be - ;; - -hpux*) - vendor=hp - ;; - -mpeix*) - vendor=hp - ;; - -hiux*) - vendor=hitachi - ;; - -unos*) - vendor=crds - ;; - -dgux*) - vendor=dg - ;; - -luna*) - vendor=omron - ;; - -genix*) - vendor=ns - ;; - -mvs* | -opened*) - vendor=ibm - ;; - -os400*) - vendor=ibm - ;; - -ptx*) - vendor=sequent - ;; - -tpf*) - vendor=ibm - ;; - -vxsim* | -vxworks* | -windiss*) - vendor=wrs - ;; - -aux*) - vendor=apple - ;; - -hms*) - vendor=hitachi - ;; - -mpw* | -macos*) - vendor=apple - ;; - -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) - vendor=atari - ;; - -vos*) - vendor=stratus - ;; - esac - basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"` - ;; -esac - -echo $basic_machine$os -exit - -# Local variables: -# eval: (add-hook 'write-file-hooks 'time-stamp) -# time-stamp-start: "timestamp='" -# time-stamp-format: "%:y-%02m-%02d" -# time-stamp-end: "'" -# End: diff --git a/release/src/router/radvd/configure b/release/src/router/radvd/configure deleted file mode 100755 index 29f4982a9d..0000000000 --- a/release/src/router/radvd/configure +++ /dev/null @@ -1,6456 +0,0 @@ -#! /bin/sh -# From configure.in . -# Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.65. -# -# -# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, -# 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation, -# Inc. -# -# -# This configure script is free software; the Free Software Foundation -# gives unlimited permission to copy, distribute and modify it. -## -------------------- ## -## M4sh Initialization. ## -## -------------------- ## - -# Be more Bourne compatible -DUALCASE=1; export DUALCASE # for MKS sh -if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : - emulate sh - NULLCMD=: - # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which - # is contrary to our usage. Disable this feature. - alias -g '${1+"$@"}'='"$@"' - setopt NO_GLOB_SUBST -else - case `(set -o) 2>/dev/null` in #( - *posix*) : - set -o posix ;; #( - *) : - ;; -esac -fi - - -as_nl=' -' -export as_nl -# Printing a long string crashes Solaris 7 /usr/bin/printf. -as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' -as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo -as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo -# Prefer a ksh shell builtin over an external printf program on Solaris, -# but without wasting forks for bash or zsh. -if test -z "$BASH_VERSION$ZSH_VERSION" \ - && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then - as_echo='print -r --' - as_echo_n='print -rn --' -elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then - as_echo='printf %s\n' - as_echo_n='printf %s' -else - if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then - as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' - as_echo_n='/usr/ucb/echo -n' - else - as_echo_body='eval expr "X$1" : "X\\(.*\\)"' - as_echo_n_body='eval - arg=$1; - case $arg in #( - *"$as_nl"*) - expr "X$arg" : "X\\(.*\\)$as_nl"; - arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; - esac; - expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" - ' - export as_echo_n_body - as_echo_n='sh -c $as_echo_n_body as_echo' - fi - export as_echo_body - as_echo='sh -c $as_echo_body as_echo' -fi - -# The user is always right. -if test "${PATH_SEPARATOR+set}" != set; then - PATH_SEPARATOR=: - (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { - (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || - PATH_SEPARATOR=';' - } -fi - - -# IFS -# We need space, tab and new line, in precisely that order. Quoting is -# there to prevent editors from complaining about space-tab. -# (If _AS_PATH_WALK were called with IFS unset, it would disable word -# splitting by setting IFS to empty value.) -IFS=" "" $as_nl" - -# Find who we are. Look in the path if we contain no directory separator. -case $0 in #(( - *[\\/]* ) as_myself=$0 ;; - *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break - done -IFS=$as_save_IFS - - ;; -esac -# We did not find ourselves, most probably we were run as `sh COMMAND' -# in which case we are not to be found in the path. -if test "x$as_myself" = x; then - as_myself=$0 -fi -if test ! -f "$as_myself"; then - $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 - exit 1 -fi - -# Unset variables that we do not need and which cause bugs (e.g. in -# pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" -# suppresses any "Segmentation fault" message there. '((' could -# trigger a bug in pdksh 5.2.14. -for as_var in BASH_ENV ENV MAIL MAILPATH -do eval test x\${$as_var+set} = xset \ - && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : -done -PS1='$ ' -PS2='> ' -PS4='+ ' - -# NLS nuisances. -LC_ALL=C -export LC_ALL -LANGUAGE=C -export LANGUAGE - -# CDPATH. -(unset CDPATH) >/dev/null 2>&1 && unset CDPATH - -if test "x$CONFIG_SHELL" = x; then - as_bourne_compatible="if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then : - emulate sh - NULLCMD=: - # Pre-4.2 versions of Zsh do word splitting on \${1+\"\$@\"}, which - # is contrary to our usage. Disable this feature. - alias -g '\${1+\"\$@\"}'='\"\$@\"' - setopt NO_GLOB_SUBST -else - case \`(set -o) 2>/dev/null\` in #( - *posix*) : - set -o posix ;; #( - *) : - ;; -esac -fi -" - as_required="as_fn_return () { (exit \$1); } -as_fn_success () { as_fn_return 0; } -as_fn_failure () { as_fn_return 1; } -as_fn_ret_success () { return 0; } -as_fn_ret_failure () { return 1; } - -exitcode=0 -as_fn_success || { exitcode=1; echo as_fn_success failed.; } -as_fn_failure && { exitcode=1; echo as_fn_failure succeeded.; } -as_fn_ret_success || { exitcode=1; echo as_fn_ret_success failed.; } -as_fn_ret_failure && { exitcode=1; echo as_fn_ret_failure succeeded.; } -if ( set x; as_fn_ret_success y && test x = \"\$1\" ); then : - -else - exitcode=1; echo positional parameters were not saved. -fi -test x\$exitcode = x0 || exit 1" - as_suggested=" as_lineno_1=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_1a=\$LINENO - as_lineno_2=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_2a=\$LINENO - eval 'test \"x\$as_lineno_1'\$as_run'\" != \"x\$as_lineno_2'\$as_run'\" && - test \"x\`expr \$as_lineno_1'\$as_run' + 1\`\" = \"x\$as_lineno_2'\$as_run'\"' || exit 1 -test \$(( 1 + 1 )) = 2 || exit 1" - if (eval "$as_required") 2>/dev/null; then : - as_have_required=yes -else - as_have_required=no -fi - if test x$as_have_required = xyes && (eval "$as_suggested") 2>/dev/null; then : - -else - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -as_found=false -for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - as_found=: - case $as_dir in #( - /*) - for as_base in sh bash ksh sh5; do - # Try only shells that exist, to save several forks. - as_shell=$as_dir/$as_base - if { test -f "$as_shell" || test -f "$as_shell.exe"; } && - { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$as_shell"; } 2>/dev/null; then : - CONFIG_SHELL=$as_shell as_have_required=yes - if { $as_echo "$as_bourne_compatible""$as_suggested" | as_run=a "$as_shell"; } 2>/dev/null; then : - break 2 -fi -fi - done;; - esac - as_found=false -done -$as_found || { if { test -f "$SHELL" || test -f "$SHELL.exe"; } && - { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$SHELL"; } 2>/dev/null; then : - CONFIG_SHELL=$SHELL as_have_required=yes -fi; } -IFS=$as_save_IFS - - - if test "x$CONFIG_SHELL" != x; then : - # We cannot yet assume a decent shell, so we have to provide a - # neutralization value for shells without unset; and this also - # works around shells that cannot unset nonexistent variables. - BASH_ENV=/dev/null - ENV=/dev/null - (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV - export CONFIG_SHELL - exec "$CONFIG_SHELL" "$as_myself" ${1+"$@"} -fi - - if test x$as_have_required = xno; then : - $as_echo "$0: This script requires a shell more modern than all" - $as_echo "$0: the shells that I found on your system." - if test x${ZSH_VERSION+set} = xset ; then - $as_echo "$0: In particular, zsh $ZSH_VERSION has bugs and should" - $as_echo "$0: be upgraded to zsh 4.3.4 or later." - else - $as_echo "$0: Please tell bug-autoconf@gnu.org about your system, -$0: including any error possibly output before this -$0: message. Then install a modern shell, or manually run -$0: the script under such a shell if you do have one." - fi - exit 1 -fi -fi -fi -SHELL=${CONFIG_SHELL-/bin/sh} -export SHELL -# Unset more variables known to interfere with behavior of common tools. -CLICOLOR_FORCE= GREP_OPTIONS= -unset CLICOLOR_FORCE GREP_OPTIONS - -## --------------------- ## -## M4sh Shell Functions. ## -## --------------------- ## -# as_fn_unset VAR -# --------------- -# Portably unset VAR. -as_fn_unset () -{ - { eval $1=; unset $1;} -} -as_unset=as_fn_unset - -# as_fn_set_status STATUS -# ----------------------- -# Set $? to STATUS, without forking. -as_fn_set_status () -{ - return $1 -} # as_fn_set_status - -# as_fn_exit STATUS -# ----------------- -# Exit the shell with STATUS, even in a "trap 0" or "set -e" context. -as_fn_exit () -{ - set +e - as_fn_set_status $1 - exit $1 -} # as_fn_exit - -# as_fn_mkdir_p -# ------------- -# Create "$as_dir" as a directory, including parents if necessary. -as_fn_mkdir_p () -{ - - case $as_dir in #( - -*) as_dir=./$as_dir;; - esac - test -d "$as_dir" || eval $as_mkdir_p || { - as_dirs= - while :; do - case $as_dir in #( - *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( - *) as_qdir=$as_dir;; - esac - as_dirs="'$as_qdir' $as_dirs" - as_dir=`$as_dirname -- "$as_dir" || -$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$as_dir" : 'X\(//\)[^/]' \| \ - X"$as_dir" : 'X\(//\)$' \| \ - X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X"$as_dir" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - test -d "$as_dir" && break - done - test -z "$as_dirs" || eval "mkdir $as_dirs" - } || test -d "$as_dir" || as_fn_error "cannot create directory $as_dir" - - -} # as_fn_mkdir_p -# as_fn_append VAR VALUE -# ---------------------- -# Append the text in VALUE to the end of the definition contained in VAR. Take -# advantage of any shell optimizations that allow amortized linear growth over -# repeated appends, instead of the typical quadratic growth present in naive -# implementations. -if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : - eval 'as_fn_append () - { - eval $1+=\$2 - }' -else - as_fn_append () - { - eval $1=\$$1\$2 - } -fi # as_fn_append - -# as_fn_arith ARG... -# ------------------ -# Perform arithmetic evaluation on the ARGs, and store the result in the -# global $as_val. Take advantage of shells that can avoid forks. The arguments -# must be portable across $(()) and expr. -if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : - eval 'as_fn_arith () - { - as_val=$(( $* )) - }' -else - as_fn_arith () - { - as_val=`expr "$@" || test $? -eq 1` - } -fi # as_fn_arith - - -# as_fn_error ERROR [LINENO LOG_FD] -# --------------------------------- -# Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are -# provided, also output the error to LOG_FD, referencing LINENO. Then exit the -# script with status $?, using 1 if that was 0. -as_fn_error () -{ - as_status=$?; test $as_status -eq 0 && as_status=1 - if test "$3"; then - as_lineno=${as_lineno-"$2"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - $as_echo "$as_me:${as_lineno-$LINENO}: error: $1" >&$3 - fi - $as_echo "$as_me: error: $1" >&2 - as_fn_exit $as_status -} # as_fn_error - -if expr a : '\(a\)' >/dev/null 2>&1 && - test "X`expr 00001 : '.*\(...\)'`" = X001; then - as_expr=expr -else - as_expr=false -fi - -if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then - as_basename=basename -else - as_basename=false -fi - -if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then - as_dirname=dirname -else - as_dirname=false -fi - -as_me=`$as_basename -- "$0" || -$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ - X"$0" : 'X\(//\)$' \| \ - X"$0" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X/"$0" | - sed '/^.*\/\([^/][^/]*\)\/*$/{ - s//\1/ - q - } - /^X\/\(\/\/\)$/{ - s//\1/ - q - } - /^X\/\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - -# Avoid depending upon Character Ranges. -as_cr_letters='abcdefghijklmnopqrstuvwxyz' -as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' -as_cr_Letters=$as_cr_letters$as_cr_LETTERS -as_cr_digits='0123456789' -as_cr_alnum=$as_cr_Letters$as_cr_digits - - - as_lineno_1=$LINENO as_lineno_1a=$LINENO - as_lineno_2=$LINENO as_lineno_2a=$LINENO - eval 'test "x$as_lineno_1'$as_run'" != "x$as_lineno_2'$as_run'" && - test "x`expr $as_lineno_1'$as_run' + 1`" = "x$as_lineno_2'$as_run'"' || { - # Blame Lee E. McMahon (1931-1989) for sed's syntax. :-) - sed -n ' - p - /[$]LINENO/= - ' <$as_myself | - sed ' - s/[$]LINENO.*/&-/ - t lineno - b - :lineno - N - :loop - s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/ - t loop - s/-\n.*// - ' >$as_me.lineno && - chmod +x "$as_me.lineno" || - { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2; as_fn_exit 1; } - - # Don't try to exec as it changes $[0], causing all sort of problems - # (the dirname of $[0] is not the place where we might find the - # original and so on. Autoconf is especially sensitive to this). - . "./$as_me.lineno" - # Exit status is that of the last command. - exit -} - -ECHO_C= ECHO_N= ECHO_T= -case `echo -n x` in #((((( --n*) - case `echo 'xy\c'` in - *c*) ECHO_T=' ';; # ECHO_T is single tab character. - xy) ECHO_C='\c';; - *) echo `echo ksh88 bug on AIX 6.1` > /dev/null - ECHO_T=' ';; - esac;; -*) - ECHO_N='-n';; -esac - -rm -f conf$$ conf$$.exe conf$$.file -if test -d conf$$.dir; then - rm -f conf$$.dir/conf$$.file -else - rm -f conf$$.dir - mkdir conf$$.dir 2>/dev/null -fi -if (echo >conf$$.file) 2>/dev/null; then - if ln -s conf$$.file conf$$ 2>/dev/null; then - as_ln_s='ln -s' - # ... but there are two gotchas: - # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. - # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. - # In both cases, we have to default to `cp -p'. - ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || - as_ln_s='cp -p' - elif ln conf$$.file conf$$ 2>/dev/null; then - as_ln_s=ln - else - as_ln_s='cp -p' - fi -else - as_ln_s='cp -p' -fi -rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file -rmdir conf$$.dir 2>/dev/null - -if mkdir -p . 2>/dev/null; then - as_mkdir_p='mkdir -p "$as_dir"' -else - test -d ./-p && rmdir ./-p - as_mkdir_p=false -fi - -if test -x / >/dev/null 2>&1; then - as_test_x='test -x' -else - if ls -dL / >/dev/null 2>&1; then - as_ls_L_option=L - else - as_ls_L_option= - fi - as_test_x=' - eval sh -c '\'' - if test -d "$1"; then - test -d "$1/."; - else - case $1 in #( - -*)set "./$1";; - esac; - case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in #(( - ???[sx]*):;;*)false;;esac;fi - '\'' sh - ' -fi -as_executable_p=$as_test_x - -# Sed expression to map a string onto a valid CPP name. -as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" - -# Sed expression to map a string onto a valid variable name. -as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" - - -test -n "$DJDIR" || exec 7<&0 &1 - -# Name of the host. -# hostname on some systems (SVR3.2, Linux) returns a bogus exit status, -# so uname gets run too. -ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` - -# -# Initializations. -# -ac_default_prefix=/usr/local -ac_clean_files= -ac_config_libobj_dir=. -LIBOBJS= -cross_compiling=no -subdirs= -MFLAGS= -MAKEFLAGS= - -# Identity of this package. -PACKAGE_NAME= -PACKAGE_TARNAME= -PACKAGE_VERSION= -PACKAGE_STRING= -PACKAGE_BUGREPORT= -PACKAGE_URL= - -ac_unique_file="radvd.c" -# Factoring default headers for most tests. -ac_includes_default="\ -#include -#ifdef HAVE_SYS_TYPES_H -# include -#endif -#ifdef HAVE_SYS_STAT_H -# include -#endif -#ifdef STDC_HEADERS -# include -# include -#else -# ifdef HAVE_STDLIB_H -# include -# endif -#endif -#ifdef HAVE_STRING_H -# if !defined STDC_HEADERS && defined HAVE_MEMORY_H -# include -# endif -# include -#endif -#ifdef HAVE_STRINGS_H -# include -#endif -#ifdef HAVE_INTTYPES_H -# include -#endif -#ifdef HAVE_STDINT_H -# include -#endif -#ifdef HAVE_UNISTD_H -# include -#endif" - -ac_subst_vars='am__EXEEXT_FALSE -am__EXEEXT_TRUE -LTLIBOBJS -LIBOBJS -LOG_FACILITY -PATH_RADVD_LOG -PATH_RADVD_PID -PATH_RADVD_CONF -CONDITIONAL_SOURCES -EGREP -GREP -CPP -GZIP -TAR -LEXLIB -LEX_OUTPUT_ROOT -LEX -YFLAGS -YACC -LN -SED -RM -am__fastdepCC_FALSE -am__fastdepCC_TRUE -CCDEPMODE -AMDEPBACKSLASH -AMDEP_FALSE -AMDEP_TRUE -am__quote -am__include -DEPDIR -OBJEXT -EXEEXT -ac_ct_CC -CPPFLAGS -LDFLAGS -CFLAGS -CC -AM_BACKSLASH -AM_DEFAULT_VERBOSITY -am__untar -am__tar -AMTAR -am__leading_dot -SET_MAKE -AWK -mkdir_p -MKDIR_P -INSTALL_STRIP_PROGRAM -STRIP -install_sh -MAKEINFO -AUTOHEADER -AUTOMAKE -AUTOCONF -ACLOCAL -VERSION -PACKAGE -CYGPATH_W -am__isrc -INSTALL_DATA -INSTALL_SCRIPT -INSTALL_PROGRAM -target_os -target_vendor -target_cpu -target -host_os -host_vendor -host_cpu -host -build_os -build_vendor -build_cpu -build -target_alias -host_alias -build_alias -LIBS -ECHO_T -ECHO_N -ECHO_C -DEFS -mandir -localedir -libdir -psdir -pdfdir -dvidir -htmldir -infodir -docdir -oldincludedir -includedir -localstatedir -sharedstatedir -sysconfdir -datadir -datarootdir -libexecdir -sbindir -bindir -program_transform_name -prefix -exec_prefix -PACKAGE_URL -PACKAGE_BUGREPORT -PACKAGE_STRING -PACKAGE_VERSION -PACKAGE_TARNAME -PACKAGE_NAME -PATH_SEPARATOR -SHELL' -ac_subst_files='' -ac_user_opts=' -enable_option_checking -enable_silent_rules -enable_dependency_tracking -with_logfile -with_pidfile -with_configfile -with_facility -' - ac_precious_vars='build_alias -host_alias -target_alias -CC -CFLAGS -LDFLAGS -LIBS -CPPFLAGS -YACC -YFLAGS -CPP' - - -# Initialize some variables set by options. -ac_init_help= -ac_init_version=false -ac_unrecognized_opts= -ac_unrecognized_sep= -# The variables have the same names as the options, with -# dashes changed to underlines. -cache_file=/dev/null -exec_prefix=NONE -no_create= -no_recursion= -prefix=NONE -program_prefix=NONE -program_suffix=NONE -program_transform_name=s,x,x, -silent= -site= -srcdir= -verbose= -x_includes=NONE -x_libraries=NONE - -# Installation directory options. -# These are left unexpanded so users can "make install exec_prefix=/foo" -# and all the variables that are supposed to be based on exec_prefix -# by default will actually change. -# Use braces instead of parens because sh, perl, etc. also accept them. -# (The list follows the same order as the GNU Coding Standards.) -bindir='${exec_prefix}/bin' -sbindir='${exec_prefix}/sbin' -libexecdir='${exec_prefix}/libexec' -datarootdir='${prefix}/share' -datadir='${datarootdir}' -sysconfdir='${prefix}/etc' -sharedstatedir='${prefix}/com' -localstatedir='${prefix}/var' -includedir='${prefix}/include' -oldincludedir='/usr/include' -docdir='${datarootdir}/doc/${PACKAGE}' -infodir='${datarootdir}/info' -htmldir='${docdir}' -dvidir='${docdir}' -pdfdir='${docdir}' -psdir='${docdir}' -libdir='${exec_prefix}/lib' -localedir='${datarootdir}/locale' -mandir='${datarootdir}/man' - -ac_prev= -ac_dashdash= -for ac_option -do - # If the previous option needs an argument, assign it. - if test -n "$ac_prev"; then - eval $ac_prev=\$ac_option - ac_prev= - continue - fi - - case $ac_option in - *=*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;; - *) ac_optarg=yes ;; - esac - - # Accept the important Cygnus configure options, so we can diagnose typos. - - case $ac_dashdash$ac_option in - --) - ac_dashdash=yes ;; - - -bindir | --bindir | --bindi | --bind | --bin | --bi) - ac_prev=bindir ;; - -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) - bindir=$ac_optarg ;; - - -build | --build | --buil | --bui | --bu) - ac_prev=build_alias ;; - -build=* | --build=* | --buil=* | --bui=* | --bu=*) - build_alias=$ac_optarg ;; - - -cache-file | --cache-file | --cache-fil | --cache-fi \ - | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) - ac_prev=cache_file ;; - -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ - | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) - cache_file=$ac_optarg ;; - - --config-cache | -C) - cache_file=config.cache ;; - - -datadir | --datadir | --datadi | --datad) - ac_prev=datadir ;; - -datadir=* | --datadir=* | --datadi=* | --datad=*) - datadir=$ac_optarg ;; - - -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ - | --dataroo | --dataro | --datar) - ac_prev=datarootdir ;; - -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ - | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) - datarootdir=$ac_optarg ;; - - -disable-* | --disable-*) - ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && - as_fn_error "invalid feature name: $ac_useropt" - ac_useropt_orig=$ac_useropt - ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` - case $ac_user_opts in - *" -"enable_$ac_useropt" -"*) ;; - *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig" - ac_unrecognized_sep=', ';; - esac - eval enable_$ac_useropt=no ;; - - -docdir | --docdir | --docdi | --doc | --do) - ac_prev=docdir ;; - -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) - docdir=$ac_optarg ;; - - -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) - ac_prev=dvidir ;; - -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) - dvidir=$ac_optarg ;; - - -enable-* | --enable-*) - ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && - as_fn_error "invalid feature name: $ac_useropt" - ac_useropt_orig=$ac_useropt - ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` - case $ac_user_opts in - *" -"enable_$ac_useropt" -"*) ;; - *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig" - ac_unrecognized_sep=', ';; - esac - eval enable_$ac_useropt=\$ac_optarg ;; - - -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ - | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ - | --exec | --exe | --ex) - ac_prev=exec_prefix ;; - -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ - | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ - | --exec=* | --exe=* | --ex=*) - exec_prefix=$ac_optarg ;; - - -gas | --gas | --ga | --g) - # Obsolete; use --with-gas. - with_gas=yes ;; - - -help | --help | --hel | --he | -h) - ac_init_help=long ;; - -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) - ac_init_help=recursive ;; - -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) - ac_init_help=short ;; - - -host | --host | --hos | --ho) - ac_prev=host_alias ;; - -host=* | --host=* | --hos=* | --ho=*) - host_alias=$ac_optarg ;; - - -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) - ac_prev=htmldir ;; - -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ - | --ht=*) - htmldir=$ac_optarg ;; - - -includedir | --includedir | --includedi | --included | --include \ - | --includ | --inclu | --incl | --inc) - ac_prev=includedir ;; - -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ - | --includ=* | --inclu=* | --incl=* | --inc=*) - includedir=$ac_optarg ;; - - -infodir | --infodir | --infodi | --infod | --info | --inf) - ac_prev=infodir ;; - -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) - infodir=$ac_optarg ;; - - -libdir | --libdir | --libdi | --libd) - ac_prev=libdir ;; - -libdir=* | --libdir=* | --libdi=* | --libd=*) - libdir=$ac_optarg ;; - - -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ - | --libexe | --libex | --libe) - ac_prev=libexecdir ;; - -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ - | --libexe=* | --libex=* | --libe=*) - libexecdir=$ac_optarg ;; - - -localedir | --localedir | --localedi | --localed | --locale) - ac_prev=localedir ;; - -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) - localedir=$ac_optarg ;; - - -localstatedir | --localstatedir | --localstatedi | --localstated \ - | --localstate | --localstat | --localsta | --localst | --locals) - ac_prev=localstatedir ;; - -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ - | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) - localstatedir=$ac_optarg ;; - - -mandir | --mandir | --mandi | --mand | --man | --ma | --m) - ac_prev=mandir ;; - -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) - mandir=$ac_optarg ;; - - -nfp | --nfp | --nf) - # Obsolete; use --without-fp. - with_fp=no ;; - - -no-create | --no-create | --no-creat | --no-crea | --no-cre \ - | --no-cr | --no-c | -n) - no_create=yes ;; - - -no-recursion | --no-recursion | --no-recursio | --no-recursi \ - | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) - no_recursion=yes ;; - - -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ - | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ - | --oldin | --oldi | --old | --ol | --o) - ac_prev=oldincludedir ;; - -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ - | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ - | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) - oldincludedir=$ac_optarg ;; - - -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) - ac_prev=prefix ;; - -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) - prefix=$ac_optarg ;; - - -program-prefix | --program-prefix | --program-prefi | --program-pref \ - | --program-pre | --program-pr | --program-p) - ac_prev=program_prefix ;; - -program-prefix=* | --program-prefix=* | --program-prefi=* \ - | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) - program_prefix=$ac_optarg ;; - - -program-suffix | --program-suffix | --program-suffi | --program-suff \ - | --program-suf | --program-su | --program-s) - ac_prev=program_suffix ;; - -program-suffix=* | --program-suffix=* | --program-suffi=* \ - | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) - program_suffix=$ac_optarg ;; - - -program-transform-name | --program-transform-name \ - | --program-transform-nam | --program-transform-na \ - | --program-transform-n | --program-transform- \ - | --program-transform | --program-transfor \ - | --program-transfo | --program-transf \ - | --program-trans | --program-tran \ - | --progr-tra | --program-tr | --program-t) - ac_prev=program_transform_name ;; - -program-transform-name=* | --program-transform-name=* \ - | --program-transform-nam=* | --program-transform-na=* \ - | --program-transform-n=* | --program-transform-=* \ - | --program-transform=* | --program-transfor=* \ - | --program-transfo=* | --program-transf=* \ - | --program-trans=* | --program-tran=* \ - | --progr-tra=* | --program-tr=* | --program-t=*) - program_transform_name=$ac_optarg ;; - - -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) - ac_prev=pdfdir ;; - -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) - pdfdir=$ac_optarg ;; - - -psdir | --psdir | --psdi | --psd | --ps) - ac_prev=psdir ;; - -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) - psdir=$ac_optarg ;; - - -q | -quiet | --quiet | --quie | --qui | --qu | --q \ - | -silent | --silent | --silen | --sile | --sil) - silent=yes ;; - - -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) - ac_prev=sbindir ;; - -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ - | --sbi=* | --sb=*) - sbindir=$ac_optarg ;; - - -sharedstatedir | --sharedstatedir | --sharedstatedi \ - | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ - | --sharedst | --shareds | --shared | --share | --shar \ - | --sha | --sh) - ac_prev=sharedstatedir ;; - -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ - | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ - | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ - | --sha=* | --sh=*) - sharedstatedir=$ac_optarg ;; - - -site | --site | --sit) - ac_prev=site ;; - -site=* | --site=* | --sit=*) - site=$ac_optarg ;; - - -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) - ac_prev=srcdir ;; - -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) - srcdir=$ac_optarg ;; - - -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ - | --syscon | --sysco | --sysc | --sys | --sy) - ac_prev=sysconfdir ;; - -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ - | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) - sysconfdir=$ac_optarg ;; - - -target | --target | --targe | --targ | --tar | --ta | --t) - ac_prev=target_alias ;; - -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) - target_alias=$ac_optarg ;; - - -v | -verbose | --verbose | --verbos | --verbo | --verb) - verbose=yes ;; - - -version | --version | --versio | --versi | --vers | -V) - ac_init_version=: ;; - - -with-* | --with-*) - ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && - as_fn_error "invalid package name: $ac_useropt" - ac_useropt_orig=$ac_useropt - ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` - case $ac_user_opts in - *" -"with_$ac_useropt" -"*) ;; - *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig" - ac_unrecognized_sep=', ';; - esac - eval with_$ac_useropt=\$ac_optarg ;; - - -without-* | --without-*) - ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'` - # Reject names that are not valid shell variable names. - expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && - as_fn_error "invalid package name: $ac_useropt" - ac_useropt_orig=$ac_useropt - ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` - case $ac_user_opts in - *" -"with_$ac_useropt" -"*) ;; - *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig" - ac_unrecognized_sep=', ';; - esac - eval with_$ac_useropt=no ;; - - --x) - # Obsolete; use --with-x. - with_x=yes ;; - - -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ - | --x-incl | --x-inc | --x-in | --x-i) - ac_prev=x_includes ;; - -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ - | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) - x_includes=$ac_optarg ;; - - -x-libraries | --x-libraries | --x-librarie | --x-librari \ - | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) - ac_prev=x_libraries ;; - -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ - | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) - x_libraries=$ac_optarg ;; - - -*) as_fn_error "unrecognized option: \`$ac_option' -Try \`$0 --help' for more information." - ;; - - *=*) - ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` - # Reject names that are not valid shell variable names. - case $ac_envvar in #( - '' | [0-9]* | *[!_$as_cr_alnum]* ) - as_fn_error "invalid variable name: \`$ac_envvar'" ;; - esac - eval $ac_envvar=\$ac_optarg - export $ac_envvar ;; - - *) - # FIXME: should be removed in autoconf 3.0. - $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 - expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && - $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 - : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option} - ;; - - esac -done - -if test -n "$ac_prev"; then - ac_option=--`echo $ac_prev | sed 's/_/-/g'` - as_fn_error "missing argument to $ac_option" -fi - -if test -n "$ac_unrecognized_opts"; then - case $enable_option_checking in - no) ;; - fatal) as_fn_error "unrecognized options: $ac_unrecognized_opts" ;; - *) $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;; - esac -fi - -# Check all directory arguments for consistency. -for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ - datadir sysconfdir sharedstatedir localstatedir includedir \ - oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ - libdir localedir mandir -do - eval ac_val=\$$ac_var - # Remove trailing slashes. - case $ac_val in - */ ) - ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'` - eval $ac_var=\$ac_val;; - esac - # Be sure to have absolute directory names. - case $ac_val in - [\\/$]* | ?:[\\/]* ) continue;; - NONE | '' ) case $ac_var in *prefix ) continue;; esac;; - esac - as_fn_error "expected an absolute directory name for --$ac_var: $ac_val" -done - -# There might be people who depend on the old broken behavior: `$host' -# used to hold the argument of --host etc. -# FIXME: To remove some day. -build=$build_alias -host=$host_alias -target=$target_alias - -# FIXME: To remove some day. -if test "x$host_alias" != x; then - if test "x$build_alias" = x; then - cross_compiling=maybe - $as_echo "$as_me: WARNING: If you wanted to set the --build type, don't use --host. - If a cross compiler is detected then cross compile mode will be used." >&2 - elif test "x$build_alias" != "x$host_alias"; then - cross_compiling=yes - fi -fi - -ac_tool_prefix= -test -n "$host_alias" && ac_tool_prefix=$host_alias- - -test "$silent" = yes && exec 6>/dev/null - - -ac_pwd=`pwd` && test -n "$ac_pwd" && -ac_ls_di=`ls -di .` && -ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || - as_fn_error "working directory cannot be determined" -test "X$ac_ls_di" = "X$ac_pwd_ls_di" || - as_fn_error "pwd does not report name of working directory" - - -# Find the source files, if location was not specified. -if test -z "$srcdir"; then - ac_srcdir_defaulted=yes - # Try the directory containing this script, then the parent directory. - ac_confdir=`$as_dirname -- "$as_myself" || -$as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$as_myself" : 'X\(//\)[^/]' \| \ - X"$as_myself" : 'X\(//\)$' \| \ - X"$as_myself" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X"$as_myself" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - srcdir=$ac_confdir - if test ! -r "$srcdir/$ac_unique_file"; then - srcdir=.. - fi -else - ac_srcdir_defaulted=no -fi -if test ! -r "$srcdir/$ac_unique_file"; then - test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." - as_fn_error "cannot find sources ($ac_unique_file) in $srcdir" -fi -ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" -ac_abs_confdir=`( - cd "$srcdir" && test -r "./$ac_unique_file" || as_fn_error "$ac_msg" - pwd)` -# When building in place, set srcdir=. -if test "$ac_abs_confdir" = "$ac_pwd"; then - srcdir=. -fi -# Remove unnecessary trailing slashes from srcdir. -# Double slashes in file names in object file debugging info -# mess up M-x gdb in Emacs. -case $srcdir in -*/) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;; -esac -for ac_var in $ac_precious_vars; do - eval ac_env_${ac_var}_set=\${${ac_var}+set} - eval ac_env_${ac_var}_value=\$${ac_var} - eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} - eval ac_cv_env_${ac_var}_value=\$${ac_var} -done - -# -# Report the --help message. -# -if test "$ac_init_help" = "long"; then - # Omit some internal or obsolete options to make the list less imposing. - # This message is too long to be a string in the A/UX 3.1 sh. - cat <<_ACEOF -\`configure' configures this package to adapt to many kinds of systems. - -Usage: $0 [OPTION]... [VAR=VALUE]... - -To assign environment variables (e.g., CC, CFLAGS...), specify them as -VAR=VALUE. See below for descriptions of some of the useful variables. - -Defaults for the options are specified in brackets. - -Configuration: - -h, --help display this help and exit - --help=short display options specific to this package - --help=recursive display the short help of all the included packages - -V, --version display version information and exit - -q, --quiet, --silent do not print \`checking...' messages - --cache-file=FILE cache test results in FILE [disabled] - -C, --config-cache alias for \`--cache-file=config.cache' - -n, --no-create do not create output files - --srcdir=DIR find the sources in DIR [configure dir or \`..'] - -Installation directories: - --prefix=PREFIX install architecture-independent files in PREFIX - [$ac_default_prefix] - --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX - [PREFIX] - -By default, \`make install' will install all the files in -\`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify -an installation prefix other than \`$ac_default_prefix' using \`--prefix', -for instance \`--prefix=\$HOME'. - -For better control, use the options below. - -Fine tuning of the installation directories: - --bindir=DIR user executables [EPREFIX/bin] - --sbindir=DIR system admin executables [EPREFIX/sbin] - --libexecdir=DIR program executables [EPREFIX/libexec] - --sysconfdir=DIR read-only single-machine data [PREFIX/etc] - --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] - --localstatedir=DIR modifiable single-machine data [PREFIX/var] - --libdir=DIR object code libraries [EPREFIX/lib] - --includedir=DIR C header files [PREFIX/include] - --oldincludedir=DIR C header files for non-gcc [/usr/include] - --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] - --datadir=DIR read-only architecture-independent data [DATAROOTDIR] - --infodir=DIR info documentation [DATAROOTDIR/info] - --localedir=DIR locale-dependent data [DATAROOTDIR/locale] - --mandir=DIR man documentation [DATAROOTDIR/man] - --docdir=DIR documentation root [DATAROOTDIR/doc/PACKAGE] - --htmldir=DIR html documentation [DOCDIR] - --dvidir=DIR dvi documentation [DOCDIR] - --pdfdir=DIR pdf documentation [DOCDIR] - --psdir=DIR ps documentation [DOCDIR] -_ACEOF - - cat <<\_ACEOF - -Program names: - --program-prefix=PREFIX prepend PREFIX to installed program names - --program-suffix=SUFFIX append SUFFIX to installed program names - --program-transform-name=PROGRAM run sed PROGRAM on installed program names - -System types: - --build=BUILD configure for building on BUILD [guessed] - --host=HOST cross-compile to build programs to run on HOST [BUILD] - --target=TARGET configure for building compilers for TARGET [HOST] -_ACEOF -fi - -if test -n "$ac_init_help"; then - - cat <<\_ACEOF - -Optional Features: - --disable-option-checking ignore unrecognized --enable/--with options - --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) - --enable-FEATURE[=ARG] include FEATURE [ARG=yes] - --enable-silent-rules less verbose build output (undo: `make V=1') - --disable-silent-rules verbose build output (undo: `make V=0') - --disable-dependency-tracking speeds up one-time build - --enable-dependency-tracking do not reject slow dependency extractors - -Optional Packages: - --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] - --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) - --with-logfile Path to the radvd logfile /var/log/radvd.log - --with-pidfile Path to the radvd pidfile /var/run/radvd.pid - --with-configfile Path to the radvd config file SYSCONF/radvd.conf - --with-facility Syslog facility to use when using syslog logging - -Some influential environment variables: - CC C compiler command - CFLAGS C compiler flags - LDFLAGS linker flags, e.g. -L if you have libraries in a - nonstandard directory - LIBS libraries to pass to the linker, e.g. -l - CPPFLAGS (Objective) C/C++ preprocessor flags, e.g. -I if - you have headers in a nonstandard directory - YACC The `Yet Another C Compiler' implementation to use. Defaults to - the first program found out of: `bison -y', `byacc', `yacc'. - YFLAGS The list of arguments that will be passed by default to $YACC. - This script will default YFLAGS to the empty string to avoid a - default value of `-d' given by some make applications. - CPP C preprocessor - -Use these variables to override the choices made by `configure' or to help -it to find libraries and programs with nonstandard names/locations. - -Report bugs to the package provider. -_ACEOF -ac_status=$? -fi - -if test "$ac_init_help" = "recursive"; then - # If there are subdirs, report their specific --help. - for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue - test -d "$ac_dir" || - { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } || - continue - ac_builddir=. - -case "$ac_dir" in -.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; -*) - ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` - # A ".." for each directory in $ac_dir_suffix. - ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` - case $ac_top_builddir_sub in - "") ac_top_builddir_sub=. ac_top_build_prefix= ;; - *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; - esac ;; -esac -ac_abs_top_builddir=$ac_pwd -ac_abs_builddir=$ac_pwd$ac_dir_suffix -# for backward compatibility: -ac_top_builddir=$ac_top_build_prefix - -case $srcdir in - .) # We are building in place. - ac_srcdir=. - ac_top_srcdir=$ac_top_builddir_sub - ac_abs_top_srcdir=$ac_pwd ;; - [\\/]* | ?:[\\/]* ) # Absolute name. - ac_srcdir=$srcdir$ac_dir_suffix; - ac_top_srcdir=$srcdir - ac_abs_top_srcdir=$srcdir ;; - *) # Relative name. - ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix - ac_top_srcdir=$ac_top_build_prefix$srcdir - ac_abs_top_srcdir=$ac_pwd/$srcdir ;; -esac -ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix - - cd "$ac_dir" || { ac_status=$?; continue; } - # Check for guested configure. - if test -f "$ac_srcdir/configure.gnu"; then - echo && - $SHELL "$ac_srcdir/configure.gnu" --help=recursive - elif test -f "$ac_srcdir/configure"; then - echo && - $SHELL "$ac_srcdir/configure" --help=recursive - else - $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 - fi || ac_status=$? - cd "$ac_pwd" || { ac_status=$?; break; } - done -fi - -test -n "$ac_init_help" && exit $ac_status -if $ac_init_version; then - cat <<\_ACEOF -configure -generated by GNU Autoconf 2.65 - -Copyright (C) 2009 Free Software Foundation, Inc. -This configure script is free software; the Free Software Foundation -gives unlimited permission to copy, distribute and modify it. -_ACEOF - exit -fi - -## ------------------------ ## -## Autoconf initialization. ## -## ------------------------ ## - -# ac_fn_c_try_compile LINENO -# -------------------------- -# Try to compile conftest.$ac_ext, and return whether this succeeded. -ac_fn_c_try_compile () -{ - as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - rm -f conftest.$ac_objext - if { { ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_compile") 2>conftest.err - ac_status=$? - if test -s conftest.err; then - grep -v '^ *+' conftest.err >conftest.er1 - cat conftest.er1 >&5 - mv -f conftest.er1 conftest.err - fi - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest.$ac_objext; then : - ac_retval=0 -else - $as_echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_retval=1 -fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} - as_fn_set_status $ac_retval - -} # ac_fn_c_try_compile - -# ac_fn_c_try_link LINENO -# ----------------------- -# Try to link conftest.$ac_ext, and return whether this succeeded. -ac_fn_c_try_link () -{ - as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - rm -f conftest.$ac_objext conftest$ac_exeext - if { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>conftest.err - ac_status=$? - if test -s conftest.err; then - grep -v '^ *+' conftest.err >conftest.er1 - cat conftest.er1 >&5 - mv -f conftest.er1 conftest.err - fi - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } && { - test -z "$ac_c_werror_flag" || - test ! -s conftest.err - } && test -s conftest$ac_exeext && { - test "$cross_compiling" = yes || - $as_test_x conftest$ac_exeext - }; then : - ac_retval=0 -else - $as_echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_retval=1 -fi - # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information - # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would - # interfere with the next link command; also delete a directory that is - # left behind by Apple's compiler. We do this before executing the actions. - rm -rf conftest.dSYM conftest_ipa8_conftest.oo - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} - as_fn_set_status $ac_retval - -} # ac_fn_c_try_link - -# ac_fn_c_try_cpp LINENO -# ---------------------- -# Try to preprocess conftest.$ac_ext, and return whether this succeeded. -ac_fn_c_try_cpp () -{ - as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - if { { ac_try="$ac_cpp conftest.$ac_ext" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err - ac_status=$? - if test -s conftest.err; then - grep -v '^ *+' conftest.err >conftest.er1 - cat conftest.er1 >&5 - mv -f conftest.er1 conftest.err - fi - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } >/dev/null && { - test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || - test ! -s conftest.err - }; then : - ac_retval=0 -else - $as_echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_retval=1 -fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} - as_fn_set_status $ac_retval - -} # ac_fn_c_try_cpp - -# ac_fn_c_try_run LINENO -# ---------------------- -# Try to link conftest.$ac_ext, and return whether this succeeded. Assumes -# that executables *can* be run. -ac_fn_c_try_run () -{ - as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - if { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } && { ac_try='./conftest$ac_exeext' - { { case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; }; then : - ac_retval=0 -else - $as_echo "$as_me: program exited with status $ac_status" >&5 - $as_echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - - ac_retval=$ac_status -fi - rm -rf conftest.dSYM conftest_ipa8_conftest.oo - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} - as_fn_set_status $ac_retval - -} # ac_fn_c_try_run - -# ac_fn_c_check_header_mongrel LINENO HEADER VAR INCLUDES -# ------------------------------------------------------- -# Tests whether HEADER exists, giving a warning if it cannot be compiled using -# the include files in INCLUDES and setting the cache variable VAR -# accordingly. -ac_fn_c_check_header_mongrel () -{ - as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - if { as_var=$3; eval "test \"\${$as_var+set}\" = set"; }; then : - { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 -$as_echo_n "checking for $2... " >&6; } -if { as_var=$3; eval "test \"\${$as_var+set}\" = set"; }; then : - $as_echo_n "(cached) " >&6 -fi -eval ac_res=\$$3 - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 -$as_echo "$ac_res" >&6; } -else - # Is the header compilable? -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking $2 usability" >&5 -$as_echo_n "checking $2 usability... " >&6; } -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -$4 -#include <$2> -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - ac_header_compiler=yes -else - ac_header_compiler=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_header_compiler" >&5 -$as_echo "$ac_header_compiler" >&6; } - -# Is the header present? -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking $2 presence" >&5 -$as_echo_n "checking $2 presence... " >&6; } -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include <$2> -_ACEOF -if ac_fn_c_try_cpp "$LINENO"; then : - ac_header_preproc=yes -else - ac_header_preproc=no -fi -rm -f conftest.err conftest.$ac_ext -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_header_preproc" >&5 -$as_echo "$ac_header_preproc" >&6; } - -# So? What about this header? -case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in #(( - yes:no: ) - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: accepted by the compiler, rejected by the preprocessor!" >&5 -$as_echo "$as_me: WARNING: $2: accepted by the compiler, rejected by the preprocessor!" >&2;} - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: proceeding with the compiler's result" >&5 -$as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} - ;; - no:yes:* ) - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: present but cannot be compiled" >&5 -$as_echo "$as_me: WARNING: $2: present but cannot be compiled" >&2;} - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: check for missing prerequisite headers?" >&5 -$as_echo "$as_me: WARNING: $2: check for missing prerequisite headers?" >&2;} - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: see the Autoconf documentation" >&5 -$as_echo "$as_me: WARNING: $2: see the Autoconf documentation" >&2;} - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: section \"Present But Cannot Be Compiled\"" >&5 -$as_echo "$as_me: WARNING: $2: section \"Present But Cannot Be Compiled\"" >&2;} - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: proceeding with the compiler's result" >&5 -$as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} - ;; -esac - { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 -$as_echo_n "checking for $2... " >&6; } -if { as_var=$3; eval "test \"\${$as_var+set}\" = set"; }; then : - $as_echo_n "(cached) " >&6 -else - eval "$3=\$ac_header_compiler" -fi -eval ac_res=\$$3 - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 -$as_echo "$ac_res" >&6; } -fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} - -} # ac_fn_c_check_header_mongrel - -# ac_fn_c_check_header_compile LINENO HEADER VAR INCLUDES -# ------------------------------------------------------- -# Tests whether HEADER exists and can be compiled using the include files in -# INCLUDES, setting the cache variable VAR accordingly. -ac_fn_c_check_header_compile () -{ - as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 -$as_echo_n "checking for $2... " >&6; } -if { as_var=$3; eval "test \"\${$as_var+set}\" = set"; }; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -$4 -#include <$2> -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - eval "$3=yes" -else - eval "$3=no" -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -eval ac_res=\$$3 - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 -$as_echo "$ac_res" >&6; } - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} - -} # ac_fn_c_check_header_compile - -# ac_fn_c_check_func LINENO FUNC VAR -# ---------------------------------- -# Tests whether FUNC exists, setting the cache variable VAR accordingly -ac_fn_c_check_func () -{ - as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 -$as_echo_n "checking for $2... " >&6; } -if { as_var=$3; eval "test \"\${$as_var+set}\" = set"; }; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -/* Define $2 to an innocuous variant, in case declares $2. - For example, HP-UX 11i declares gettimeofday. */ -#define $2 innocuous_$2 - -/* System header to define __stub macros and hopefully few prototypes, - which can conflict with char $2 (); below. - Prefer to if __STDC__ is defined, since - exists even on freestanding compilers. */ - -#ifdef __STDC__ -# include -#else -# include -#endif - -#undef $2 - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char $2 (); -/* The GNU C library defines this for functions which it implements - to always fail with ENOSYS. Some functions are actually named - something starting with __ and the normal name is an alias. */ -#if defined __stub_$2 || defined __stub___$2 -choke me -#endif - -int -main () -{ -return $2 (); - ; - return 0; -} -_ACEOF -if ac_fn_c_try_link "$LINENO"; then : - eval "$3=yes" -else - eval "$3=no" -fi -rm -f core conftest.err conftest.$ac_objext \ - conftest$ac_exeext conftest.$ac_ext -fi -eval ac_res=\$$3 - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 -$as_echo "$ac_res" >&6; } - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} - -} # ac_fn_c_check_func -cat >config.log <<_ACEOF -This file contains any messages produced by compilers while -running configure, to aid debugging if configure makes a mistake. - -It was created by $as_me, which was -generated by GNU Autoconf 2.65. Invocation command line was - - $ $0 $@ - -_ACEOF -exec 5>>config.log -{ -cat <<_ASUNAME -## --------- ## -## Platform. ## -## --------- ## - -hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` -uname -m = `(uname -m) 2>/dev/null || echo unknown` -uname -r = `(uname -r) 2>/dev/null || echo unknown` -uname -s = `(uname -s) 2>/dev/null || echo unknown` -uname -v = `(uname -v) 2>/dev/null || echo unknown` - -/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` -/bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` - -/bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` -/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` -/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` -/usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` -/bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` -/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` -/bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` - -_ASUNAME - -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - $as_echo "PATH: $as_dir" - done -IFS=$as_save_IFS - -} >&5 - -cat >&5 <<_ACEOF - - -## ----------- ## -## Core tests. ## -## ----------- ## - -_ACEOF - - -# Keep a trace of the command line. -# Strip out --no-create and --no-recursion so they do not pile up. -# Strip out --silent because we don't want to record it for future runs. -# Also quote any args containing shell meta-characters. -# Make two passes to allow for proper duplicate-argument suppression. -ac_configure_args= -ac_configure_args0= -ac_configure_args1= -ac_must_keep_next=false -for ac_pass in 1 2 -do - for ac_arg - do - case $ac_arg in - -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; - -q | -quiet | --quiet | --quie | --qui | --qu | --q \ - | -silent | --silent | --silen | --sile | --sil) - continue ;; - *\'*) - ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; - esac - case $ac_pass in - 1) as_fn_append ac_configure_args0 " '$ac_arg'" ;; - 2) - as_fn_append ac_configure_args1 " '$ac_arg'" - if test $ac_must_keep_next = true; then - ac_must_keep_next=false # Got value, back to normal. - else - case $ac_arg in - *=* | --config-cache | -C | -disable-* | --disable-* \ - | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ - | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ - | -with-* | --with-* | -without-* | --without-* | --x) - case "$ac_configure_args0 " in - "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; - esac - ;; - -* ) ac_must_keep_next=true ;; - esac - fi - as_fn_append ac_configure_args " '$ac_arg'" - ;; - esac - done -done -{ ac_configure_args0=; unset ac_configure_args0;} -{ ac_configure_args1=; unset ac_configure_args1;} - -# When interrupted or exit'd, cleanup temporary files, and complete -# config.log. We remove comments because anyway the quotes in there -# would cause problems or look ugly. -# WARNING: Use '\'' to represent an apostrophe within the trap. -# WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. -trap 'exit_status=$? - # Save into config.log some information that might help in debugging. - { - echo - - cat <<\_ASBOX -## ---------------- ## -## Cache variables. ## -## ---------------- ## -_ASBOX - echo - # The following way of writing the cache mishandles newlines in values, -( - for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do - eval ac_val=\$$ac_var - case $ac_val in #( - *${as_nl}*) - case $ac_var in #( - *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 -$as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; - esac - case $ac_var in #( - _ | IFS | as_nl) ;; #( - BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( - *) { eval $ac_var=; unset $ac_var;} ;; - esac ;; - esac - done - (set) 2>&1 | - case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( - *${as_nl}ac_space=\ *) - sed -n \ - "s/'\''/'\''\\\\'\'''\''/g; - s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p" - ;; #( - *) - sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" - ;; - esac | - sort -) - echo - - cat <<\_ASBOX -## ----------------- ## -## Output variables. ## -## ----------------- ## -_ASBOX - echo - for ac_var in $ac_subst_vars - do - eval ac_val=\$$ac_var - case $ac_val in - *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; - esac - $as_echo "$ac_var='\''$ac_val'\''" - done | sort - echo - - if test -n "$ac_subst_files"; then - cat <<\_ASBOX -## ------------------- ## -## File substitutions. ## -## ------------------- ## -_ASBOX - echo - for ac_var in $ac_subst_files - do - eval ac_val=\$$ac_var - case $ac_val in - *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; - esac - $as_echo "$ac_var='\''$ac_val'\''" - done | sort - echo - fi - - if test -s confdefs.h; then - cat <<\_ASBOX -## ----------- ## -## confdefs.h. ## -## ----------- ## -_ASBOX - echo - cat confdefs.h - echo - fi - test "$ac_signal" != 0 && - $as_echo "$as_me: caught signal $ac_signal" - $as_echo "$as_me: exit $exit_status" - } >&5 - rm -f core *.core core.conftest.* && - rm -f -r conftest* confdefs* conf$$* $ac_clean_files && - exit $exit_status -' 0 -for ac_signal in 1 2 13 15; do - trap 'ac_signal='$ac_signal'; as_fn_exit 1' $ac_signal -done -ac_signal=0 - -# confdefs.h avoids OS command line length limits that DEFS can exceed. -rm -f -r conftest* confdefs.h - -$as_echo "/* confdefs.h */" > confdefs.h - -# Predefined preprocessor variables. - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_NAME "$PACKAGE_NAME" -_ACEOF - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_TARNAME "$PACKAGE_TARNAME" -_ACEOF - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_VERSION "$PACKAGE_VERSION" -_ACEOF - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_STRING "$PACKAGE_STRING" -_ACEOF - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" -_ACEOF - -cat >>confdefs.h <<_ACEOF -#define PACKAGE_URL "$PACKAGE_URL" -_ACEOF - - -# Let the site file select an alternate cache file if it wants to. -# Prefer an explicitly selected file to automatically selected ones. -ac_site_file1=NONE -ac_site_file2=NONE -if test -n "$CONFIG_SITE"; then - ac_site_file1=$CONFIG_SITE -elif test "x$prefix" != xNONE; then - ac_site_file1=$prefix/share/config.site - ac_site_file2=$prefix/etc/config.site -else - ac_site_file1=$ac_default_prefix/share/config.site - ac_site_file2=$ac_default_prefix/etc/config.site -fi -for ac_site_file in "$ac_site_file1" "$ac_site_file2" -do - test "x$ac_site_file" = xNONE && continue - if test /dev/null != "$ac_site_file" && test -r "$ac_site_file"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: loading site script $ac_site_file" >&5 -$as_echo "$as_me: loading site script $ac_site_file" >&6;} - sed 's/^/| /' "$ac_site_file" >&5 - . "$ac_site_file" - fi -done - -if test -r "$cache_file"; then - # Some versions of bash will fail to source /dev/null (special files - # actually), so we avoid doing that. DJGPP emulates it as a regular file. - if test /dev/null != "$cache_file" && test -f "$cache_file"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: loading cache $cache_file" >&5 -$as_echo "$as_me: loading cache $cache_file" >&6;} - case $cache_file in - [\\/]* | ?:[\\/]* ) . "$cache_file";; - *) . "./$cache_file";; - esac - fi -else - { $as_echo "$as_me:${as_lineno-$LINENO}: creating cache $cache_file" >&5 -$as_echo "$as_me: creating cache $cache_file" >&6;} - >$cache_file -fi - -# Check that the precious variables saved in the cache have kept the same -# value. -ac_cache_corrupted=false -for ac_var in $ac_precious_vars; do - eval ac_old_set=\$ac_cv_env_${ac_var}_set - eval ac_new_set=\$ac_env_${ac_var}_set - eval ac_old_val=\$ac_cv_env_${ac_var}_value - eval ac_new_val=\$ac_env_${ac_var}_value - case $ac_old_set,$ac_new_set in - set,) - { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 -$as_echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} - ac_cache_corrupted=: ;; - ,set) - { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was not set in the previous run" >&5 -$as_echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} - ac_cache_corrupted=: ;; - ,);; - *) - if test "x$ac_old_val" != "x$ac_new_val"; then - # differences in whitespace do not lead to failure. - ac_old_val_w=`echo x $ac_old_val` - ac_new_val_w=`echo x $ac_new_val` - if test "$ac_old_val_w" != "$ac_new_val_w"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' has changed since the previous run:" >&5 -$as_echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} - ac_cache_corrupted=: - else - { $as_echo "$as_me:${as_lineno-$LINENO}: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5 -$as_echo "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;} - eval $ac_var=\$ac_old_val - fi - { $as_echo "$as_me:${as_lineno-$LINENO}: former value: \`$ac_old_val'" >&5 -$as_echo "$as_me: former value: \`$ac_old_val'" >&2;} - { $as_echo "$as_me:${as_lineno-$LINENO}: current value: \`$ac_new_val'" >&5 -$as_echo "$as_me: current value: \`$ac_new_val'" >&2;} - fi;; - esac - # Pass precious variables to config.status. - if test "$ac_new_set" = set; then - case $ac_new_val in - *\'*) ac_arg=$ac_var=`$as_echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; - *) ac_arg=$ac_var=$ac_new_val ;; - esac - case " $ac_configure_args " in - *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. - *) as_fn_append ac_configure_args " '$ac_arg'" ;; - esac - fi -done -if $ac_cache_corrupted; then - { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} - { $as_echo "$as_me:${as_lineno-$LINENO}: error: changes in the environment can compromise the build" >&5 -$as_echo "$as_me: error: changes in the environment can compromise the build" >&2;} - as_fn_error "run \`make distclean' and/or \`rm $cache_file' and start over" "$LINENO" 5 -fi -## -------------------- ## -## Main body of script. ## -## -------------------- ## - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - - -ac_aux_dir= -for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do - for ac_t in install-sh install.sh shtool; do - if test -f "$ac_dir/$ac_t"; then - ac_aux_dir=$ac_dir - ac_install_sh="$ac_aux_dir/$ac_t -c" - break 2 - fi - done -done -if test -z "$ac_aux_dir"; then - as_fn_error "cannot find install-sh, install.sh, or shtool in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" "$LINENO" 5 -fi - -# These three variables are undocumented and unsupported, -# and are intended to be withdrawn in a future Autoconf release. -# They can cause serious problems if a builder's source tree is in a directory -# whose full name contains unusual characters. -ac_config_guess="$SHELL $ac_aux_dir/config.guess" # Please don't use this var. -ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. -ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. - - -# Make sure we can run config.sub. -$SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || - as_fn_error "cannot run $SHELL $ac_aux_dir/config.sub" "$LINENO" 5 - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 -$as_echo_n "checking build system type... " >&6; } -if test "${ac_cv_build+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - ac_build_alias=$build_alias -test "x$ac_build_alias" = x && - ac_build_alias=`$SHELL "$ac_aux_dir/config.guess"` -test "x$ac_build_alias" = x && - as_fn_error "cannot guess build type; you must specify one" "$LINENO" 5 -ac_cv_build=`$SHELL "$ac_aux_dir/config.sub" $ac_build_alias` || - as_fn_error "$SHELL $ac_aux_dir/config.sub $ac_build_alias failed" "$LINENO" 5 - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_build" >&5 -$as_echo "$ac_cv_build" >&6; } -case $ac_cv_build in -*-*-*) ;; -*) as_fn_error "invalid value of canonical build" "$LINENO" 5;; -esac -build=$ac_cv_build -ac_save_IFS=$IFS; IFS='-' -set x $ac_cv_build -shift -build_cpu=$1 -build_vendor=$2 -shift; shift -# Remember, the first character of IFS is used to create $*, -# except with old shells: -build_os=$* -IFS=$ac_save_IFS -case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 -$as_echo_n "checking host system type... " >&6; } -if test "${ac_cv_host+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test "x$host_alias" = x; then - ac_cv_host=$ac_cv_build -else - ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` || - as_fn_error "$SHELL $ac_aux_dir/config.sub $host_alias failed" "$LINENO" 5 -fi - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_host" >&5 -$as_echo "$ac_cv_host" >&6; } -case $ac_cv_host in -*-*-*) ;; -*) as_fn_error "invalid value of canonical host" "$LINENO" 5;; -esac -host=$ac_cv_host -ac_save_IFS=$IFS; IFS='-' -set x $ac_cv_host -shift -host_cpu=$1 -host_vendor=$2 -shift; shift -# Remember, the first character of IFS is used to create $*, -# except with old shells: -host_os=$* -IFS=$ac_save_IFS -case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking target system type" >&5 -$as_echo_n "checking target system type... " >&6; } -if test "${ac_cv_target+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test "x$target_alias" = x; then - ac_cv_target=$ac_cv_host -else - ac_cv_target=`$SHELL "$ac_aux_dir/config.sub" $target_alias` || - as_fn_error "$SHELL $ac_aux_dir/config.sub $target_alias failed" "$LINENO" 5 -fi - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_target" >&5 -$as_echo "$ac_cv_target" >&6; } -case $ac_cv_target in -*-*-*) ;; -*) as_fn_error "invalid value of canonical target" "$LINENO" 5;; -esac -target=$ac_cv_target -ac_save_IFS=$IFS; IFS='-' -set x $ac_cv_target -shift -target_cpu=$1 -target_vendor=$2 -shift; shift -# Remember, the first character of IFS is used to create $*, -# except with old shells: -target_os=$* -IFS=$ac_save_IFS -case $target_os in *\ *) target_os=`echo "$target_os" | sed 's/ /-/g'`;; esac - - -# The aliases save the names the user supplied, while $host etc. -# will get canonicalized. -test -n "$target_alias" && - test "$program_prefix$program_suffix$program_transform_name" = \ - NONENONEs,x,x, && - program_prefix=${target_alias}- - -VERSION=`cat ${srcdir}/VERSION | grep -v '^#' | tr -d '\012'` -am__api_version='1.11' - -# Find a good install program. We prefer a C program (faster), -# so one script is as good as another. But avoid the broken or -# incompatible versions: -# SysV /etc/install, /usr/sbin/install -# SunOS /usr/etc/install -# IRIX /sbin/install -# AIX /bin/install -# AmigaOS /C/install, which installs bootblocks on floppy discs -# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag -# AFS /usr/afsws/bin/install, which mishandles nonexistent args -# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" -# OS/2's system install, which has a completely different semantic -# ./install, which can be erroneously created by make from ./install.sh. -# Reject install programs that cannot install multiple files. -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a BSD-compatible install" >&5 -$as_echo_n "checking for a BSD-compatible install... " >&6; } -if test -z "$INSTALL"; then -if test "${ac_cv_path_install+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - # Account for people who put trailing slashes in PATH elements. -case $as_dir/ in #(( - ./ | .// | /[cC]/* | \ - /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ - ?:[\\/]os2[\\/]install[\\/]* | ?:[\\/]OS2[\\/]INSTALL[\\/]* | \ - /usr/ucb/* ) ;; - *) - # OSF1 and SCO ODT 3.0 have their own names for install. - # Don't use installbsd from OSF since it installs stuff as root - # by default. - for ac_prog in ginstall scoinst install; do - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_prog$ac_exec_ext" && $as_test_x "$as_dir/$ac_prog$ac_exec_ext"; }; then - if test $ac_prog = install && - grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then - # AIX install. It has an incompatible calling convention. - : - elif test $ac_prog = install && - grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then - # program-specific install script used by HP pwplus--don't use. - : - else - rm -rf conftest.one conftest.two conftest.dir - echo one > conftest.one - echo two > conftest.two - mkdir conftest.dir - if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" && - test -s conftest.one && test -s conftest.two && - test -s conftest.dir/conftest.one && - test -s conftest.dir/conftest.two - then - ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" - break 3 - fi - fi - fi - done - done - ;; -esac - - done -IFS=$as_save_IFS - -rm -rf conftest.one conftest.two conftest.dir - -fi - if test "${ac_cv_path_install+set}" = set; then - INSTALL=$ac_cv_path_install - else - # As a last resort, use the slow shell script. Don't cache a - # value for INSTALL within a source directory, because that will - # break other packages using the cache if that directory is - # removed, or if the value is a relative name. - INSTALL=$ac_install_sh - fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $INSTALL" >&5 -$as_echo "$INSTALL" >&6; } - -# Use test -z because SunOS4 sh mishandles braces in ${var-val}. -# It thinks the first close brace ends the variable substitution. -test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' - -test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' - -test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether build environment is sane" >&5 -$as_echo_n "checking whether build environment is sane... " >&6; } -# Just in case -sleep 1 -echo timestamp > conftest.file -# Reject unsafe characters in $srcdir or the absolute working directory -# name. Accept space and tab only in the latter. -am_lf=' -' -case `pwd` in - *[\\\"\#\$\&\'\`$am_lf]*) - as_fn_error "unsafe absolute working directory name" "$LINENO" 5;; -esac -case $srcdir in - *[\\\"\#\$\&\'\`$am_lf\ \ ]*) - as_fn_error "unsafe srcdir value: \`$srcdir'" "$LINENO" 5;; -esac - -# Do `set' in a subshell so we don't clobber the current shell's -# arguments. Must try -L first in case configure is actually a -# symlink; some systems play weird games with the mod time of symlinks -# (eg FreeBSD returns the mod time of the symlink's containing -# directory). -if ( - set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` - if test "$*" = "X"; then - # -L didn't work. - set X `ls -t "$srcdir/configure" conftest.file` - fi - rm -f conftest.file - if test "$*" != "X $srcdir/configure conftest.file" \ - && test "$*" != "X conftest.file $srcdir/configure"; then - - # If neither matched, then we have a broken ls. This can happen - # if, for instance, CONFIG_SHELL is bash and it inherits a - # broken ls alias from the environment. This has actually - # happened. Such a system could not be considered "sane". - as_fn_error "ls -t appears to fail. Make sure there is not a broken -alias in your environment" "$LINENO" 5 - fi - - test "$2" = conftest.file - ) -then - # Ok. - : -else - as_fn_error "newly created file is older than distributed files! -Check your system clock" "$LINENO" 5 -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -$as_echo "yes" >&6; } -test "$program_prefix" != NONE && - program_transform_name="s&^&$program_prefix&;$program_transform_name" -# Use a double $ so make ignores it. -test "$program_suffix" != NONE && - program_transform_name="s&\$&$program_suffix&;$program_transform_name" -# Double any \ or $. -# By default was `s,x,x', remove it if useless. -ac_script='s/[\\$]/&&/g;s/;s,x,x,$//' -program_transform_name=`$as_echo "$program_transform_name" | sed "$ac_script"` - -# expand $ac_aux_dir to an absolute path -am_aux_dir=`cd $ac_aux_dir && pwd` - -if test x"${MISSING+set}" != xset; then - case $am_aux_dir in - *\ * | *\ *) - MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; - *) - MISSING="\${SHELL} $am_aux_dir/missing" ;; - esac -fi -# Use eval to expand $SHELL -if eval "$MISSING --run true"; then - am_missing_run="$MISSING --run " -else - am_missing_run= - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: \`missing' script is too old or missing" >&5 -$as_echo "$as_me: WARNING: \`missing' script is too old or missing" >&2;} -fi - -if test x"${install_sh}" != xset; then - case $am_aux_dir in - *\ * | *\ *) - install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; - *) - install_sh="\${SHELL} $am_aux_dir/install-sh" - esac -fi - -# Installed binaries are usually stripped using `strip' when the user -# run `make install-strip'. However `strip' might not be the right -# tool to use in cross-compilation environments, therefore Automake -# will honor the `STRIP' environment variable to overrule this program. -if test "$cross_compiling" != no; then - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. -set dummy ${ac_tool_prefix}strip; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_STRIP+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$STRIP"; then - ac_cv_prog_STRIP="$STRIP" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_STRIP="${ac_tool_prefix}strip" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -STRIP=$ac_cv_prog_STRIP -if test -n "$STRIP"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 -$as_echo "$STRIP" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_STRIP"; then - ac_ct_STRIP=$STRIP - # Extract the first word of "strip", so it can be a program name with args. -set dummy strip; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$ac_ct_STRIP"; then - ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_STRIP="strip" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP -if test -n "$ac_ct_STRIP"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 -$as_echo "$ac_ct_STRIP" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - if test "x$ac_ct_STRIP" = x; then - STRIP=":" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 -$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} -ac_tool_warned=yes ;; -esac - STRIP=$ac_ct_STRIP - fi -else - STRIP="$ac_cv_prog_STRIP" -fi - -fi -INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a thread-safe mkdir -p" >&5 -$as_echo_n "checking for a thread-safe mkdir -p... " >&6; } -if test -z "$MKDIR_P"; then - if test "${ac_cv_path_mkdir+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH$PATH_SEPARATOR/opt/sfw/bin -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_prog in mkdir gmkdir; do - for ac_exec_ext in '' $ac_executable_extensions; do - { test -f "$as_dir/$ac_prog$ac_exec_ext" && $as_test_x "$as_dir/$ac_prog$ac_exec_ext"; } || continue - case `"$as_dir/$ac_prog$ac_exec_ext" --version 2>&1` in #( - 'mkdir (GNU coreutils) '* | \ - 'mkdir (coreutils) '* | \ - 'mkdir (fileutils) '4.1*) - ac_cv_path_mkdir=$as_dir/$ac_prog$ac_exec_ext - break 3;; - esac - done - done - done -IFS=$as_save_IFS - -fi - - test -d ./--version && rmdir ./--version - if test "${ac_cv_path_mkdir+set}" = set; then - MKDIR_P="$ac_cv_path_mkdir -p" - else - # As a last resort, use the slow shell script. Don't cache a - # value for MKDIR_P within a source directory, because that will - # break other packages using the cache if that directory is - # removed, or if the value is a relative name. - MKDIR_P="$ac_install_sh -d" - fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $MKDIR_P" >&5 -$as_echo "$MKDIR_P" >&6; } - -mkdir_p="$MKDIR_P" -case $mkdir_p in - [\\/$]* | ?:[\\/]*) ;; - */*) mkdir_p="\$(top_builddir)/$mkdir_p" ;; -esac - -for ac_prog in gawk mawk nawk awk -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_AWK+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$AWK"; then - ac_cv_prog_AWK="$AWK" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_AWK="$ac_prog" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -AWK=$ac_cv_prog_AWK -if test -n "$AWK"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AWK" >&5 -$as_echo "$AWK" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - test -n "$AWK" && break -done - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} sets \$(MAKE)" >&5 -$as_echo_n "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } -set x ${MAKE-make} -ac_make=`$as_echo "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` -if { as_var=ac_cv_prog_make_${ac_make}_set; eval "test \"\${$as_var+set}\" = set"; }; then : - $as_echo_n "(cached) " >&6 -else - cat >conftest.make <<\_ACEOF -SHELL = /bin/sh -all: - @echo '@@@%%%=$(MAKE)=@@@%%%' -_ACEOF -# GNU make sometimes prints "make[1]: Entering...", which would confuse us. -case `${MAKE-make} -f conftest.make 2>/dev/null` in - *@@@%%%=?*=@@@%%%*) - eval ac_cv_prog_make_${ac_make}_set=yes;; - *) - eval ac_cv_prog_make_${ac_make}_set=no;; -esac -rm -f conftest.make -fi -if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -$as_echo "yes" >&6; } - SET_MAKE= -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } - SET_MAKE="MAKE=${MAKE-make}" -fi - -rm -rf .tst 2>/dev/null -mkdir .tst 2>/dev/null -if test -d .tst; then - am__leading_dot=. -else - am__leading_dot=_ -fi -rmdir .tst 2>/dev/null - -if test "`cd $srcdir && pwd`" != "`pwd`"; then - # Use -I$(srcdir) only when $(srcdir) != ., so that make's output - # is not polluted with repeated "-I." - am__isrc=' -I$(srcdir)' - # test to see if srcdir already configured - if test -f $srcdir/config.status; then - as_fn_error "source directory already configured; run \"make distclean\" there first" "$LINENO" 5 - fi -fi - -# test whether we have cygpath -if test -z "$CYGPATH_W"; then - if (cygpath --version) >/dev/null 2>/dev/null; then - CYGPATH_W='cygpath -w' - else - CYGPATH_W=echo - fi -fi - - -# Define the identity of the package. - PACKAGE=radvd - VERSION=$VERSION - - -# Some tools Automake needs. - -ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} - - -AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} - - -AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} - - -AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} - - -MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} - -# We need awk for the "check" target. The system "awk" is bad on -# some platforms. -# Always define AMTAR for backward compatibility. - -AMTAR=${AMTAR-"${am_missing_run}tar"} - -am__tar='${AMTAR} chof - "$$tardir"'; am__untar='${AMTAR} xf -' - - - - - -# Check whether --enable-silent-rules was given. -if test "${enable_silent_rules+set}" = set; then : - enableval=$enable_silent_rules; -fi - -case $enable_silent_rules in -yes) AM_DEFAULT_VERBOSITY=0;; -no) AM_DEFAULT_VERBOSITY=1;; -*) AM_DEFAULT_VERBOSITY=0;; -esac -AM_BACKSLASH='\' - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking architecture" >&5 -$as_echo_n "checking architecture... " >&6; } -case "$target" in - *linux*) - { $as_echo "$as_me:${as_lineno-$LINENO}: result: linux" >&5 -$as_echo "linux" >&6; } - -$as_echo "#define _GNU_SOURCE /**/" >>confdefs.h - - arch=linux - ;; - *bsd*) - { $as_echo "$as_me:${as_lineno-$LINENO}: result: bsd44" >&5 -$as_echo "bsd44" >&6; } - arch=bsd44 - ;; - *darwin*) - { $as_echo "$as_me:${as_lineno-$LINENO}: result: bsd44 (darwin)" >&5 -$as_echo "bsd44 (darwin)" >&6; } - arch=bsd44 - ;; - *) - { $as_echo "$as_me:${as_lineno-$LINENO}: result: unknown: $target" >&5 -$as_echo "unknown: $target" >&6; } - as_fn_error "currently only Linux and BSD 4.4 with NRL's IPv6 code are -supported. If you have such a system and it is not guessed correctly -you must specifiy it with --target on the configure command line" "$LINENO" 5 - ;; -esac - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu -if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. -set dummy ${ac_tool_prefix}gcc; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_CC+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CC="${ac_tool_prefix}gcc" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -$as_echo "$CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - -fi -if test -z "$ac_cv_prog_CC"; then - ac_ct_CC=$CC - # Extract the first word of "gcc", so it can be a program name with args. -set dummy gcc; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_CC+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$ac_ct_CC"; then - ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_CC="gcc" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -ac_ct_CC=$ac_cv_prog_ac_ct_CC -if test -n "$ac_ct_CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 -$as_echo "$ac_ct_CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - if test "x$ac_ct_CC" = x; then - CC="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 -$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} -ac_tool_warned=yes ;; -esac - CC=$ac_ct_CC - fi -else - CC="$ac_cv_prog_CC" -fi - -if test -z "$CC"; then - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. -set dummy ${ac_tool_prefix}cc; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_CC+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CC="${ac_tool_prefix}cc" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -$as_echo "$CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - fi -fi -if test -z "$CC"; then - # Extract the first word of "cc", so it can be a program name with args. -set dummy cc; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_CC+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else - ac_prog_rejected=no -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then - ac_prog_rejected=yes - continue - fi - ac_cv_prog_CC="cc" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -if test $ac_prog_rejected = yes; then - # We found a bogon in the path, so make sure we never use it. - set dummy $ac_cv_prog_CC - shift - if test $# != 0; then - # We chose a different compiler from the bogus one. - # However, it has the same basename, so the bogon will be chosen - # first if we set CC to just the basename; use the full file name. - shift - ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" - fi -fi -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -$as_echo "$CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - -fi -if test -z "$CC"; then - if test -n "$ac_tool_prefix"; then - for ac_prog in cl.exe - do - # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. -set dummy $ac_tool_prefix$ac_prog; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_CC+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$CC"; then - ac_cv_prog_CC="$CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_CC="$ac_tool_prefix$ac_prog" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -CC=$ac_cv_prog_CC -if test -n "$CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 -$as_echo "$CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - test -n "$CC" && break - done -fi -if test -z "$CC"; then - ac_ct_CC=$CC - for ac_prog in cl.exe -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_CC+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$ac_ct_CC"; then - ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_ac_ct_CC="$ac_prog" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -ac_ct_CC=$ac_cv_prog_ac_ct_CC -if test -n "$ac_ct_CC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 -$as_echo "$ac_ct_CC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - test -n "$ac_ct_CC" && break -done - - if test "x$ac_ct_CC" = x; then - CC="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 -$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} -ac_tool_warned=yes ;; -esac - CC=$ac_ct_CC - fi -fi - -fi - - -test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error "no acceptable C compiler found in \$PATH -See \`config.log' for more details." "$LINENO" 5; } - -# Provide some information about the compiler. -$as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 -set X $ac_compile -ac_compiler=$2 -for ac_option in --version -v -V -qversion; do - { { ac_try="$ac_compiler $ac_option >&5" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_compiler $ac_option >&5") 2>conftest.err - ac_status=$? - if test -s conftest.err; then - sed '10a\ -... rest of stderr output deleted ... - 10q' conftest.err >conftest.er1 - cat conftest.er1 >&5 - fi - rm -f conftest.er1 conftest.err - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } -done - -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -ac_clean_files_save=$ac_clean_files -ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" -# Try to create an executable without -o first, disregard a.out. -# It will help us diagnose broken compilers, and finding out an intuition -# of exeext. -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 -$as_echo_n "checking whether the C compiler works... " >&6; } -ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` - -# The possible output files: -ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" - -ac_rmfiles= -for ac_file in $ac_files -do - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; - * ) ac_rmfiles="$ac_rmfiles $ac_file";; - esac -done -rm -f $ac_rmfiles - -if { { ac_try="$ac_link_default" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link_default") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; then : - # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. -# So ignore a value of `no', otherwise this would lead to `EXEEXT = no' -# in a Makefile. We should not override ac_cv_exeext if it was cached, -# so that the user can short-circuit this test for compilers unknown to -# Autoconf. -for ac_file in $ac_files '' -do - test -f "$ac_file" || continue - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) - ;; - [ab].out ) - # We found the default executable, but exeext='' is most - # certainly right. - break;; - *.* ) - if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; - then :; else - ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` - fi - # We set ac_cv_exeext here because the later test for it is not - # safe: cross compilers may not add the suffix if given an `-o' - # argument, so we may need to know it at that point already. - # Even if this section looks crufty: it has the advantage of - # actually working. - break;; - * ) - break;; - esac -done -test "$ac_cv_exeext" = no && ac_cv_exeext= - -else - ac_file='' -fi -if test -z "$ac_file"; then : - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -$as_echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -{ as_fn_set_status 77 -as_fn_error "C compiler cannot create executables -See \`config.log' for more details." "$LINENO" 5; }; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -$as_echo "yes" >&6; } -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 -$as_echo_n "checking for C compiler default output file name... " >&6; } -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 -$as_echo "$ac_file" >&6; } -ac_exeext=$ac_cv_exeext - -rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out -ac_clean_files=$ac_clean_files_save -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 -$as_echo_n "checking for suffix of executables... " >&6; } -if { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; then : - # If both `conftest.exe' and `conftest' are `present' (well, observable) -# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will -# work properly (i.e., refer to `conftest.exe'), while it won't with -# `rm'. -for ac_file in conftest.exe conftest conftest.*; do - test -f "$ac_file" || continue - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; - *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` - break;; - * ) break;; - esac -done -else - { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error "cannot compute suffix of executables: cannot compile and link -See \`config.log' for more details." "$LINENO" 5; } -fi -rm -f conftest conftest$ac_cv_exeext -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 -$as_echo "$ac_cv_exeext" >&6; } - -rm -f conftest.$ac_ext -EXEEXT=$ac_cv_exeext -ac_exeext=$EXEEXT -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -int -main () -{ -FILE *f = fopen ("conftest.out", "w"); - return ferror (f) || fclose (f) != 0; - - ; - return 0; -} -_ACEOF -ac_clean_files="$ac_clean_files conftest.out" -# Check that the compiler produces executables we can run. If not, either -# the compiler is broken, or we cross compile. -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 -$as_echo_n "checking whether we are cross compiling... " >&6; } -if test "$cross_compiling" != yes; then - { { ac_try="$ac_link" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_link") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } - if { ac_try='./conftest$ac_cv_exeext' - { { case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_try") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; }; then - cross_compiling=no - else - if test "$cross_compiling" = maybe; then - cross_compiling=yes - else - { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error "cannot run C compiled programs. -If you meant to cross compile, use \`--host'. -See \`config.log' for more details." "$LINENO" 5; } - fi - fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 -$as_echo "$cross_compiling" >&6; } - -rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out -ac_clean_files=$ac_clean_files_save -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 -$as_echo_n "checking for suffix of object files... " >&6; } -if test "${ac_cv_objext+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -rm -f conftest.o conftest.obj -if { { ac_try="$ac_compile" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$ac_compile") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; }; then : - for ac_file in conftest.o conftest.obj conftest.*; do - test -f "$ac_file" || continue; - case $ac_file in - *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; - *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` - break;; - esac -done -else - $as_echo "$as_me: failed program was:" >&5 -sed 's/^/| /' conftest.$ac_ext >&5 - -{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error "cannot compute suffix of object files: cannot compile -See \`config.log' for more details." "$LINENO" 5; } -fi -rm -f conftest.$ac_cv_objext conftest.$ac_ext -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 -$as_echo "$ac_cv_objext" >&6; } -OBJEXT=$ac_cv_objext -ac_objext=$OBJEXT -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 -$as_echo_n "checking whether we are using the GNU C compiler... " >&6; } -if test "${ac_cv_c_compiler_gnu+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ -#ifndef __GNUC__ - choke me -#endif - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - ac_compiler_gnu=yes -else - ac_compiler_gnu=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -ac_cv_c_compiler_gnu=$ac_compiler_gnu - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 -$as_echo "$ac_cv_c_compiler_gnu" >&6; } -if test $ac_compiler_gnu = yes; then - GCC=yes -else - GCC= -fi -ac_test_CFLAGS=${CFLAGS+set} -ac_save_CFLAGS=$CFLAGS -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 -$as_echo_n "checking whether $CC accepts -g... " >&6; } -if test "${ac_cv_prog_cc_g+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - ac_save_c_werror_flag=$ac_c_werror_flag - ac_c_werror_flag=yes - ac_cv_prog_cc_g=no - CFLAGS="-g" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - ac_cv_prog_cc_g=yes -else - CFLAGS="" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - -else - ac_c_werror_flag=$ac_save_c_werror_flag - CFLAGS="-g" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - ac_cv_prog_cc_g=yes -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - ac_c_werror_flag=$ac_save_c_werror_flag -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 -$as_echo "$ac_cv_prog_cc_g" >&6; } -if test "$ac_test_CFLAGS" = set; then - CFLAGS=$ac_save_CFLAGS -elif test $ac_cv_prog_cc_g = yes; then - if test "$GCC" = yes; then - CFLAGS="-g -O2" - else - CFLAGS="-g" - fi -else - if test "$GCC" = yes; then - CFLAGS="-O2" - else - CFLAGS= - fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 -$as_echo_n "checking for $CC option to accept ISO C89... " >&6; } -if test "${ac_cv_prog_cc_c89+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - ac_cv_prog_cc_c89=no -ac_save_CC=$CC -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -#include -#include -#include -/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ -struct buf { int x; }; -FILE * (*rcsopen) (struct buf *, struct stat *, int); -static char *e (p, i) - char **p; - int i; -{ - return p[i]; -} -static char *f (char * (*g) (char **, int), char **p, ...) -{ - char *s; - va_list v; - va_start (v,p); - s = g (p, va_arg (v,int)); - va_end (v); - return s; -} - -/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has - function prototypes and stuff, but not '\xHH' hex character constants. - These don't provoke an error unfortunately, instead are silently treated - as 'x'. The following induces an error, until -std is added to get - proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an - array size at least. It's necessary to write '\x00'==0 to get something - that's true only with -std. */ -int osf4_cc_array ['\x00' == 0 ? 1 : -1]; - -/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters - inside strings and character constants. */ -#define FOO(x) 'x' -int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; - -int test (int i, double x); -struct s1 {int (*f) (int a);}; -struct s2 {int (*f) (double a);}; -int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); -int argc; -char **argv; -int -main () -{ -return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; - ; - return 0; -} -_ACEOF -for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ - -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" -do - CC="$ac_save_CC $ac_arg" - if ac_fn_c_try_compile "$LINENO"; then : - ac_cv_prog_cc_c89=$ac_arg -fi -rm -f core conftest.err conftest.$ac_objext - test "x$ac_cv_prog_cc_c89" != "xno" && break -done -rm -f conftest.$ac_ext -CC=$ac_save_CC - -fi -# AC_CACHE_VAL -case "x$ac_cv_prog_cc_c89" in - x) - { $as_echo "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 -$as_echo "none needed" >&6; } ;; - xno) - { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 -$as_echo "unsupported" >&6; } ;; - *) - CC="$CC $ac_cv_prog_cc_c89" - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 -$as_echo "$ac_cv_prog_cc_c89" >&6; } ;; -esac -if test "x$ac_cv_prog_cc_c89" != xno; then : - -fi - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu -DEPDIR="${am__leading_dot}deps" - -ac_config_commands="$ac_config_commands depfiles" - - -am_make=${MAKE-make} -cat > confinc << 'END' -am__doit: - @echo this is the am__doit target -.PHONY: am__doit -END -# If we don't find an include directive, just comment out the code. -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5 -$as_echo_n "checking for style of include used by $am_make... " >&6; } -am__include="#" -am__quote= -_am_result=none -# First try GNU make style include. -echo "include confinc" > confmf -# Ignore all kinds of additional output from `make'. -case `$am_make -s -f confmf 2> /dev/null` in #( -*the\ am__doit\ target*) - am__include=include - am__quote= - _am_result=GNU - ;; -esac -# Now try BSD make style include. -if test "$am__include" = "#"; then - echo '.include "confinc"' > confmf - case `$am_make -s -f confmf 2> /dev/null` in #( - *the\ am__doit\ target*) - am__include=.include - am__quote="\"" - _am_result=BSD - ;; - esac -fi - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5 -$as_echo "$_am_result" >&6; } -rm -f confinc confmf - -# Check whether --enable-dependency-tracking was given. -if test "${enable_dependency_tracking+set}" = set; then : - enableval=$enable_dependency_tracking; -fi - -if test "x$enable_dependency_tracking" != xno; then - am_depcomp="$ac_aux_dir/depcomp" - AMDEPBACKSLASH='\' -fi - if test "x$enable_dependency_tracking" != xno; then - AMDEP_TRUE= - AMDEP_FALSE='#' -else - AMDEP_TRUE='#' - AMDEP_FALSE= -fi - - - -depcc="$CC" am_compiler_list= - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 -$as_echo_n "checking dependency style of $depcc... " >&6; } -if test "${am_cv_CC_dependencies_compiler_type+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then - # We make a subdir and do the tests there. Otherwise we can end up - # making bogus files that we don't know about and never remove. For - # instance it was reported that on HP-UX the gcc test will end up - # making a dummy file named `D' -- because `-MD' means `put the output - # in D'. - mkdir conftest.dir - # Copy depcomp to subdir because otherwise we won't find it if we're - # using a relative directory. - cp "$am_depcomp" conftest.dir - cd conftest.dir - # We will build objects and dependencies in a subdirectory because - # it helps to detect inapplicable dependency modes. For instance - # both Tru64's cc and ICC support -MD to output dependencies as a - # side effect of compilation, but ICC will put the dependencies in - # the current directory while Tru64 will put them in the object - # directory. - mkdir sub - - am_cv_CC_dependencies_compiler_type=none - if test "$am_compiler_list" = ""; then - am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` - fi - am__universal=false - case " $depcc " in #( - *\ -arch\ *\ -arch\ *) am__universal=true ;; - esac - - for depmode in $am_compiler_list; do - # Setup a source with many dependencies, because some compilers - # like to wrap large dependency lists on column 80 (with \), and - # we should not choose a depcomp mode which is confused by this. - # - # We need to recreate these files for each test, as the compiler may - # overwrite some of them when testing with obscure command lines. - # This happens at least with the AIX C compiler. - : > sub/conftest.c - for i in 1 2 3 4 5 6; do - echo '#include "conftst'$i'.h"' >> sub/conftest.c - # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with - # Solaris 8's {/usr,}/bin/sh. - touch sub/conftst$i.h - done - echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf - - # We check with `-c' and `-o' for the sake of the "dashmstdout" - # mode. It turns out that the SunPro C++ compiler does not properly - # handle `-M -o', and we need to detect this. Also, some Intel - # versions had trouble with output in subdirs - am__obj=sub/conftest.${OBJEXT-o} - am__minus_obj="-o $am__obj" - case $depmode in - gcc) - # This depmode causes a compiler race in universal mode. - test "$am__universal" = false || continue - ;; - nosideeffect) - # after this tag, mechanisms are not by side-effect, so they'll - # only be used when explicitly requested - if test "x$enable_dependency_tracking" = xyes; then - continue - else - break - fi - ;; - msvisualcpp | msvcmsys) - # This compiler won't grok `-c -o', but also, the minuso test has - # not run yet. These depmodes are late enough in the game, and - # so weak that their functioning should not be impacted. - am__obj=conftest.${OBJEXT-o} - am__minus_obj= - ;; - none) break ;; - esac - if depmode=$depmode \ - source=sub/conftest.c object=$am__obj \ - depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ - $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ - >/dev/null 2>conftest.err && - grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && - grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && - grep $am__obj sub/conftest.Po > /dev/null 2>&1 && - ${MAKE-make} -s -f confmf > /dev/null 2>&1; then - # icc doesn't choke on unknown options, it will just issue warnings - # or remarks (even with -Werror). So we grep stderr for any message - # that says an option was ignored or not supported. - # When given -MP, icc 7.0 and 7.1 complain thusly: - # icc: Command line warning: ignoring option '-M'; no argument required - # The diagnosis changed in icc 8.0: - # icc: Command line remark: option '-MP' not supported - if (grep 'ignoring option' conftest.err || - grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else - am_cv_CC_dependencies_compiler_type=$depmode - break - fi - fi - done - - cd .. - rm -rf conftest.dir -else - am_cv_CC_dependencies_compiler_type=none -fi - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CC_dependencies_compiler_type" >&5 -$as_echo "$am_cv_CC_dependencies_compiler_type" >&6; } -CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type - - if - test "x$enable_dependency_tracking" != xno \ - && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then - am__fastdepCC_TRUE= - am__fastdepCC_FALSE='#' -else - am__fastdepCC_TRUE='#' - am__fastdepCC_FALSE= -fi - - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking netlink" >&5 -$as_echo_n "checking netlink... " >&6; } - -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -#include -#include -#include -#include - -int -main () -{ - -int -main(int argc, char * argv[]) -{ - int sock; - struct sockaddr_nl snl; - - sock = socket(PF_NETLINK, SOCK_RAW, NETLINK_ROUTE); - - snl.nl_family = AF_NETLINK; - snl.nl_groups = RTMGRP_LINK; - - return 0; -} - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - - -$as_echo "#define HAVE_NETLINK 1" >>confdefs.h - -CONDITIONAL_SOURCES=netlink.${OBJEXT} -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -$as_echo "yes" >&6; } - -else - -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } - -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - - -# Extract the first word of "rm", so it can be a program name with args. -set dummy rm; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_RM+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - case $RM in - [\\/]* | ?:[\\/]*) - ac_cv_path_RM="$RM" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_path_RM="$as_dir/$ac_word$ac_exec_ext" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - - test -z "$ac_cv_path_RM" && ac_cv_path_RM="NOTFOUND" - ;; -esac -fi -RM=$ac_cv_path_RM -if test -n "$RM"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $RM" >&5 -$as_echo "$RM" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - -if test "x$RM" = xNOTFOUND; then - as_fn_error "can't find rm in your path - check PATH" "$LINENO" 5 -fi -# Extract the first word of "sed", so it can be a program name with args. -set dummy sed; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_SED+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - case $SED in - [\\/]* | ?:[\\/]*) - ac_cv_path_SED="$SED" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_path_SED="$as_dir/$ac_word$ac_exec_ext" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - - test -z "$ac_cv_path_SED" && ac_cv_path_SED="NOTFOUND" - ;; -esac -fi -SED=$ac_cv_path_SED -if test -n "$SED"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $SED" >&5 -$as_echo "$SED" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - -if test "x$SED" = xNOTFOUND; then - as_fn_error "can't find sed in your path - check PATH" "$LINENO" 5 -fi -# Extract the first word of "ln", so it can be a program name with args. -set dummy ln; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_LN+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - case $LN in - [\\/]* | ?:[\\/]*) - ac_cv_path_LN="$LN" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_path_LN="$as_dir/$ac_word$ac_exec_ext" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - - ;; -esac -fi -LN=$ac_cv_path_LN -if test -n "$LN"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LN" >&5 -$as_echo "$LN" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - -for ac_prog in 'bison -y' byacc -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_YACC+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$YACC"; then - ac_cv_prog_YACC="$YACC" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_YACC="$ac_prog" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -YACC=$ac_cv_prog_YACC -if test -n "$YACC"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $YACC" >&5 -$as_echo "$YACC" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - test -n "$YACC" && break -done -test -n "$YACC" || YACC="yacc" - -for ac_prog in flex lex -do - # Extract the first word of "$ac_prog", so it can be a program name with args. -set dummy $ac_prog; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_LEX+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -n "$LEX"; then - ac_cv_prog_LEX="$LEX" # Let the user override the test. -else -as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_prog_LEX="$ac_prog" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - -fi -fi -LEX=$ac_cv_prog_LEX -if test -n "$LEX"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LEX" >&5 -$as_echo "$LEX" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - test -n "$LEX" && break -done -test -n "$LEX" || LEX=":" - -if test "x$LEX" != "x:"; then - cat >conftest.l <<_ACEOF -%% -a { ECHO; } -b { REJECT; } -c { yymore (); } -d { yyless (1); } -e { yyless (input () != 0); } -f { unput (yytext[0]); } -. { BEGIN INITIAL; } -%% -#ifdef YYTEXT_POINTER -extern char *yytext; -#endif -int -main (void) -{ - return ! yylex () + ! yywrap (); -} -_ACEOF -{ { ac_try="$LEX conftest.l" -case "(($ac_try" in - *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; - *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 - (eval "$LEX conftest.l") 2>&5 - ac_status=$? - $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 - test $ac_status = 0; } -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking lex output file root" >&5 -$as_echo_n "checking lex output file root... " >&6; } -if test "${ac_cv_prog_lex_root+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - -if test -f lex.yy.c; then - ac_cv_prog_lex_root=lex.yy -elif test -f lexyy.c; then - ac_cv_prog_lex_root=lexyy -else - as_fn_error "cannot find output from $LEX; giving up" "$LINENO" 5 -fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_lex_root" >&5 -$as_echo "$ac_cv_prog_lex_root" >&6; } -LEX_OUTPUT_ROOT=$ac_cv_prog_lex_root - -if test -z "${LEXLIB+set}"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: checking lex library" >&5 -$as_echo_n "checking lex library... " >&6; } -if test "${ac_cv_lib_lex+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - - ac_save_LIBS=$LIBS - ac_cv_lib_lex='none needed' - for ac_lib in '' -lfl -ll; do - LIBS="$ac_lib $ac_save_LIBS" - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -`cat $LEX_OUTPUT_ROOT.c` -_ACEOF -if ac_fn_c_try_link "$LINENO"; then : - ac_cv_lib_lex=$ac_lib -fi -rm -f core conftest.err conftest.$ac_objext \ - conftest$ac_exeext conftest.$ac_ext - test "$ac_cv_lib_lex" != 'none needed' && break - done - LIBS=$ac_save_LIBS - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_lex" >&5 -$as_echo "$ac_cv_lib_lex" >&6; } - test "$ac_cv_lib_lex" != 'none needed' && LEXLIB=$ac_cv_lib_lex -fi - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether yytext is a pointer" >&5 -$as_echo_n "checking whether yytext is a pointer... " >&6; } -if test "${ac_cv_prog_lex_yytext_pointer+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - # POSIX says lex can declare yytext either as a pointer or an array; the -# default is implementation-dependent. Figure out which it is, since -# not all implementations provide the %pointer and %array declarations. -ac_cv_prog_lex_yytext_pointer=no -ac_save_LIBS=$LIBS -LIBS="$LEXLIB $ac_save_LIBS" -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#define YYTEXT_POINTER 1 -`cat $LEX_OUTPUT_ROOT.c` -_ACEOF -if ac_fn_c_try_link "$LINENO"; then : - ac_cv_prog_lex_yytext_pointer=yes -fi -rm -f core conftest.err conftest.$ac_objext \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_save_LIBS - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_lex_yytext_pointer" >&5 -$as_echo "$ac_cv_prog_lex_yytext_pointer" >&6; } -if test $ac_cv_prog_lex_yytext_pointer = yes; then - -$as_echo "#define YYTEXT_POINTER 1" >>confdefs.h - -fi -rm -f conftest.l $LEX_OUTPUT_ROOT.c - -fi -if test "$LEX" = :; then - LEX=${am_missing_run}flex -fi -# Extract the first word of "tar", so it can be a program name with args. -set dummy tar; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TAR+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - case $TAR in - [\\/]* | ?:[\\/]*) - ac_cv_path_TAR="$TAR" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_path_TAR="$as_dir/$ac_word$ac_exec_ext" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - - ;; -esac -fi -TAR=$ac_cv_path_TAR -if test -n "$TAR"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $TAR" >&5 -$as_echo "$TAR" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - -# Extract the first word of "gzip", so it can be a program name with args. -set dummy gzip; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_GZIP+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - case $GZIP in - [\\/]* | ?:[\\/]*) - ac_cv_path_GZIP="$GZIP" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_path_GZIP="$as_dir/$ac_word$ac_exec_ext" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - - ;; -esac -fi -GZIP=$ac_cv_path_GZIP -if test -n "$GZIP"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $GZIP" >&5 -$as_echo "$GZIP" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking where to put logfile" >&5 -$as_echo_n "checking where to put logfile... " >&6; } - -# Check whether --with-logfile was given. -if test "${with_logfile+set}" = set; then : - withval=$with_logfile; PATH_RADVD_LOG=$withval -else - PATH_RADVD_LOG=/var/log/radvd.log -fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $PATH_RADVD_LOG" >&5 -$as_echo "$PATH_RADVD_LOG" >&6; } - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking where to put pidfile" >&5 -$as_echo_n "checking where to put pidfile... " >&6; } - -# Check whether --with-pidfile was given. -if test "${with_pidfile+set}" = set; then : - withval=$with_pidfile; PATH_RADVD_PID=$withval -else - PATH_RADVD_PID=/var/run/radvd.pid -fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $PATH_RADVD_PID" >&5 -$as_echo "$PATH_RADVD_PID" >&6; } - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking where to find configfile" >&5 -$as_echo_n "checking where to find configfile... " >&6; } - -# Check whether --with-configfile was given. -if test "${with_configfile+set}" = set; then : - withval=$with_configfile; PATH_RADVD_CONF=$withval -else - eval PATH_RADVD_CONF=${sysconfdir}/radvd.conf -fi - -PATH_RADVD_CONF=$(echo $PATH_RADVD_CONF | sed 's/NONE//1') -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $PATH_RADVD_CONF" >&5 -$as_echo "$PATH_RADVD_CONF" >&6; } - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking which syslog facility to use" >&5 -$as_echo_n "checking which syslog facility to use... " >&6; } - -# Check whether --with-facility was given. -if test "${with_facility+set}" = set; then : - withval=$with_facility; LOG_FACILITY=$withval -else - LOG_FACILITY=LOG_DAEMON -fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $LOG_FACILITY" >&5 -$as_echo "$LOG_FACILITY" >&6; } - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for inet_ntop in -lc" >&5 -$as_echo_n "checking for inet_ntop in -lc... " >&6; } -if test "${ac_cv_lib_c_inet_ntop+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - ac_check_lib_save_LIBS=$LIBS -LIBS="-lc $LIBS" -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char inet_ntop (); -int -main () -{ -return inet_ntop (); - ; - return 0; -} -_ACEOF -if ac_fn_c_try_link "$LINENO"; then : - ac_cv_lib_c_inet_ntop=yes -else - ac_cv_lib_c_inet_ntop=no -fi -rm -f core conftest.err conftest.$ac_objext \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_check_lib_save_LIBS -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_c_inet_ntop" >&5 -$as_echo "$ac_cv_lib_c_inet_ntop" >&6; } -if test "x$ac_cv_lib_c_inet_ntop" = x""yes; then : - cat >>confdefs.h <<_ACEOF -#define HAVE_LIBC 1 -_ACEOF - - LIBS="-lc $LIBS" - -else - { $as_echo "$as_me:${as_lineno-$LINENO}: checking for inet_ntop in -linet6" >&5 -$as_echo_n "checking for inet_ntop in -linet6... " >&6; } -if test "${ac_cv_lib_inet6_inet_ntop+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - ac_check_lib_save_LIBS=$LIBS -LIBS="-linet6 $LIBS" -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -/* Override any GCC internal prototype to avoid an error. - Use char because int might match the return type of a GCC - builtin and then its argument prototype would still apply. */ -#ifdef __cplusplus -extern "C" -#endif -char inet_ntop (); -int -main () -{ -return inet_ntop (); - ; - return 0; -} -_ACEOF -if ac_fn_c_try_link "$LINENO"; then : - ac_cv_lib_inet6_inet_ntop=yes -else - ac_cv_lib_inet6_inet_ntop=no -fi -rm -f core conftest.err conftest.$ac_objext \ - conftest$ac_exeext conftest.$ac_ext -LIBS=$ac_check_lib_save_LIBS -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_inet6_inet_ntop" >&5 -$as_echo "$ac_cv_lib_inet6_inet_ntop" >&6; } -if test "x$ac_cv_lib_inet6_inet_ntop" = x""yes; then : - LIBS="$LIBS -linet6" - -else - as_fn_error "can't continue without libinet6.a library - check your LDFLAGS" "$LINENO" 5 - -fi - - -fi - -# prevent caching -unset ac_cv_lib_inet6_inet_ntop - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C preprocessor" >&5 -$as_echo_n "checking how to run the C preprocessor... " >&6; } -# On Suns, sometimes $CPP names a directory. -if test -n "$CPP" && test -d "$CPP"; then - CPP= -fi -if test -z "$CPP"; then - if test "${ac_cv_prog_CPP+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - # Double quotes because CPP needs to be expanded - for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" - do - ac_preproc_ok=false -for ac_c_preproc_warn_flag in '' yes -do - # Use a header file that comes with gcc, so configuring glibc - # with a fresh cross-compiler works. - # Prefer to if __STDC__ is defined, since - # exists even on freestanding compilers. - # On the NeXT, cc -E runs the code through the compiler's parser, - # not just through cpp. "Syntax error" is here to catch this case. - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#ifdef __STDC__ -# include -#else -# include -#endif - Syntax error -_ACEOF -if ac_fn_c_try_cpp "$LINENO"; then : - -else - # Broken: fails on valid input. -continue -fi -rm -f conftest.err conftest.$ac_ext - - # OK, works on sane cases. Now check whether nonexistent headers - # can be detected and how. - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -_ACEOF -if ac_fn_c_try_cpp "$LINENO"; then : - # Broken: success on invalid input. -continue -else - # Passes both tests. -ac_preproc_ok=: -break -fi -rm -f conftest.err conftest.$ac_ext - -done -# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. -rm -f conftest.err conftest.$ac_ext -if $ac_preproc_ok; then : - break -fi - - done - ac_cv_prog_CPP=$CPP - -fi - CPP=$ac_cv_prog_CPP -else - ac_cv_prog_CPP=$CPP -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $CPP" >&5 -$as_echo "$CPP" >&6; } -ac_preproc_ok=false -for ac_c_preproc_warn_flag in '' yes -do - # Use a header file that comes with gcc, so configuring glibc - # with a fresh cross-compiler works. - # Prefer to if __STDC__ is defined, since - # exists even on freestanding compilers. - # On the NeXT, cc -E runs the code through the compiler's parser, - # not just through cpp. "Syntax error" is here to catch this case. - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#ifdef __STDC__ -# include -#else -# include -#endif - Syntax error -_ACEOF -if ac_fn_c_try_cpp "$LINENO"; then : - -else - # Broken: fails on valid input. -continue -fi -rm -f conftest.err conftest.$ac_ext - - # OK, works on sane cases. Now check whether nonexistent headers - # can be detected and how. - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -_ACEOF -if ac_fn_c_try_cpp "$LINENO"; then : - # Broken: success on invalid input. -continue -else - # Passes both tests. -ac_preproc_ok=: -break -fi -rm -f conftest.err conftest.$ac_ext - -done -# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. -rm -f conftest.err conftest.$ac_ext -if $ac_preproc_ok; then : - -else - { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 -$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} -as_fn_error "C preprocessor \"$CPP\" fails sanity check -See \`config.log' for more details." "$LINENO" 5; } -fi - -ac_ext=c -ac_cpp='$CPP $CPPFLAGS' -ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -ac_compiler_gnu=$ac_cv_c_compiler_gnu - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 -$as_echo_n "checking for grep that handles long lines and -e... " >&6; } -if test "${ac_cv_path_GREP+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if test -z "$GREP"; then - ac_path_GREP_found=false - # Loop through the user's path and test for each of PROGNAME-LIST - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_prog in grep ggrep; do - for ac_exec_ext in '' $ac_executable_extensions; do - ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext" - { test -f "$ac_path_GREP" && $as_test_x "$ac_path_GREP"; } || continue -# Check for GNU ac_path_GREP and select it if it is found. - # Check for GNU $ac_path_GREP -case `"$ac_path_GREP" --version 2>&1` in -*GNU*) - ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;; -*) - ac_count=0 - $as_echo_n 0123456789 >"conftest.in" - while : - do - cat "conftest.in" "conftest.in" >"conftest.tmp" - mv "conftest.tmp" "conftest.in" - cp "conftest.in" "conftest.nl" - $as_echo 'GREP' >> "conftest.nl" - "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break - diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break - as_fn_arith $ac_count + 1 && ac_count=$as_val - if test $ac_count -gt ${ac_path_GREP_max-0}; then - # Best one so far, save it but keep looking for a better one - ac_cv_path_GREP="$ac_path_GREP" - ac_path_GREP_max=$ac_count - fi - # 10*(2^10) chars as input seems more than enough - test $ac_count -gt 10 && break - done - rm -f conftest.in conftest.tmp conftest.nl conftest.out;; -esac - - $ac_path_GREP_found && break 3 - done - done - done -IFS=$as_save_IFS - if test -z "$ac_cv_path_GREP"; then - as_fn_error "no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 - fi -else - ac_cv_path_GREP=$GREP -fi - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_GREP" >&5 -$as_echo "$ac_cv_path_GREP" >&6; } - GREP="$ac_cv_path_GREP" - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 -$as_echo_n "checking for egrep... " >&6; } -if test "${ac_cv_path_EGREP+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 - then ac_cv_path_EGREP="$GREP -E" - else - if test -z "$EGREP"; then - ac_path_EGREP_found=false - # Loop through the user's path and test for each of PROGNAME-LIST - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_prog in egrep; do - for ac_exec_ext in '' $ac_executable_extensions; do - ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext" - { test -f "$ac_path_EGREP" && $as_test_x "$ac_path_EGREP"; } || continue -# Check for GNU ac_path_EGREP and select it if it is found. - # Check for GNU $ac_path_EGREP -case `"$ac_path_EGREP" --version 2>&1` in -*GNU*) - ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;; -*) - ac_count=0 - $as_echo_n 0123456789 >"conftest.in" - while : - do - cat "conftest.in" "conftest.in" >"conftest.tmp" - mv "conftest.tmp" "conftest.in" - cp "conftest.in" "conftest.nl" - $as_echo 'EGREP' >> "conftest.nl" - "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break - diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break - as_fn_arith $ac_count + 1 && ac_count=$as_val - if test $ac_count -gt ${ac_path_EGREP_max-0}; then - # Best one so far, save it but keep looking for a better one - ac_cv_path_EGREP="$ac_path_EGREP" - ac_path_EGREP_max=$ac_count - fi - # 10*(2^10) chars as input seems more than enough - test $ac_count -gt 10 && break - done - rm -f conftest.in conftest.tmp conftest.nl conftest.out;; -esac - - $ac_path_EGREP_found && break 3 - done - done - done -IFS=$as_save_IFS - if test -z "$ac_cv_path_EGREP"; then - as_fn_error "no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 - fi -else - ac_cv_path_EGREP=$EGREP -fi - - fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_EGREP" >&5 -$as_echo "$ac_cv_path_EGREP" >&6; } - EGREP="$ac_cv_path_EGREP" - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5 -$as_echo_n "checking for ANSI C header files... " >&6; } -if test "${ac_cv_header_stdc+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -#include -#include -#include - -int -main () -{ - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - ac_cv_header_stdc=yes -else - ac_cv_header_stdc=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -if test $ac_cv_header_stdc = yes; then - # SunOS 4.x string.h does not declare mem*, contrary to ANSI. - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include - -_ACEOF -if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | - $EGREP "memchr" >/dev/null 2>&1; then : - -else - ac_cv_header_stdc=no -fi -rm -f conftest* - -fi - -if test $ac_cv_header_stdc = yes; then - # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include - -_ACEOF -if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | - $EGREP "free" >/dev/null 2>&1; then : - -else - ac_cv_header_stdc=no -fi -rm -f conftest* - -fi - -if test $ac_cv_header_stdc = yes; then - # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. - if test "$cross_compiling" = yes; then : - : -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -#include -#if ((' ' & 0x0FF) == 0x020) -# define ISLOWER(c) ('a' <= (c) && (c) <= 'z') -# define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) -#else -# define ISLOWER(c) \ - (('a' <= (c) && (c) <= 'i') \ - || ('j' <= (c) && (c) <= 'r') \ - || ('s' <= (c) && (c) <= 'z')) -# define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) -#endif - -#define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) -int -main () -{ - int i; - for (i = 0; i < 256; i++) - if (XOR (islower (i), ISLOWER (i)) - || toupper (i) != TOUPPER (i)) - return 2; - return 0; -} -_ACEOF -if ac_fn_c_try_run "$LINENO"; then : - -else - ac_cv_header_stdc=no -fi -rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ - conftest.$ac_objext conftest.beam conftest.$ac_ext -fi - -fi -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_stdc" >&5 -$as_echo "$ac_cv_header_stdc" >&6; } -if test $ac_cv_header_stdc = yes; then - -$as_echo "#define STDC_HEADERS 1" >>confdefs.h - -fi - -# On IRIX 5.3, sys/types and inttypes.h are conflicting. -for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ - inttypes.h stdint.h unistd.h -do : - as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` -ac_fn_c_check_header_compile "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default -" -eval as_val=\$$as_ac_Header - if test "x$as_val" = x""yes; then : - cat >>confdefs.h <<_ACEOF -#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 -_ACEOF - -fi - -done - - -for ac_header in \ - getopt.h \ - ifaddrs.h \ - machine/limits.h \ - machine/param.h \ - net/if_arp.h \ - net/if_dl.h \ - net/if_types.h \ - sys/param.h \ - sys/sockio.h \ - sys/time.h \ - time.h \ - -do : - as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` -ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default" -eval as_val=\$$as_ac_Header - if test "x$as_val" = x""yes; then : - cat >>confdefs.h <<_ACEOF -#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 -_ACEOF - -fi - -done - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether time.h and sys/time.h may both be included" >&5 -$as_echo_n "checking whether time.h and sys/time.h may both be included... " >&6; } -if test "${ac_cv_header_time+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -#include -#include - -int -main () -{ -if ((struct tm *) 0) -return 0; - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - ac_cv_header_time=yes -else - ac_cv_header_time=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_time" >&5 -$as_echo "$ac_cv_header_time" >&6; } -if test $ac_cv_header_time = yes; then - -$as_echo "#define TIME_WITH_SYS_TIME 1" >>confdefs.h - -fi - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for an ANSI C-conforming const" >&5 -$as_echo_n "checking for an ANSI C-conforming const... " >&6; } -if test "${ac_cv_c_const+set}" = set; then : - $as_echo_n "(cached) " >&6 -else - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - -int -main () -{ -/* FIXME: Include the comments suggested by Paul. */ -#ifndef __cplusplus - /* Ultrix mips cc rejects this. */ - typedef int charset[2]; - const charset cs; - /* SunOS 4.1.1 cc rejects this. */ - char const *const *pcpcc; - char **ppc; - /* NEC SVR4.0.2 mips cc rejects this. */ - struct point {int x, y;}; - static struct point const zero = {0,0}; - /* AIX XL C 1.02.0.0 rejects this. - It does not let you subtract one const X* pointer from another in - an arm of an if-expression whose if-part is not a constant - expression */ - const char *g = "string"; - pcpcc = &g + (g ? g-g : 0); - /* HPUX 7.0 cc rejects these. */ - ++pcpcc; - ppc = (char**) pcpcc; - pcpcc = (char const *const *) ppc; - { /* SCO 3.2v4 cc rejects this. */ - char *t; - char const *s = 0 ? (char *) 0 : (char const *) 0; - - *t++ = 0; - if (s) return 0; - } - { /* Someone thinks the Sun supposedly-ANSI compiler will reject this. */ - int x[] = {25, 17}; - const int *foo = &x[0]; - ++foo; - } - { /* Sun SC1.0 ANSI compiler rejects this -- but not the above. */ - typedef const int *iptr; - iptr p = 0; - ++p; - } - { /* AIX XL C 1.02.0.0 rejects this saying - "k.c", line 2.27: 1506-025 (S) Operand must be a modifiable lvalue. */ - struct s { int j; const int *ap[3]; }; - struct s *b; b->j = 5; - } - { /* ULTRIX-32 V3.1 (Rev 9) vcc rejects this */ - const int foo = 10; - if (!foo) return 0; - } - return !cs[0] && !zero.x; -#endif - - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - ac_cv_c_const=yes -else - ac_cv_c_const=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_const" >&5 -$as_echo "$ac_cv_c_const" >&6; } -if test $ac_cv_c_const = no; then - -$as_echo "#define const /**/" >>confdefs.h - -fi - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether struct sockaddr_in6 has sin6_scope_id" >&5 -$as_echo_n "checking whether struct sockaddr_in6 has sin6_scope_id... " >&6; } -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -#include -int -main () -{ -static struct sockaddr_in6 ac_sin6; int ac_size = -sizeof (ac_sin6.sin6_scope_id); - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -$as_echo "yes" >&6; }; -$as_echo "#define HAVE_SIN6_SCOPE_ID 1" >>confdefs.h - -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether struct in6_addr has u6_addrXX and defines s6_addrXX" >&5 -$as_echo_n "checking whether struct in6_addr has u6_addrXX and defines s6_addrXX... " >&6; } -cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ -#include -int -main () -{ -static struct in6_addr in6_u; -int u = in6_u.s6_addr16; - ; - return 0; -} -_ACEOF -if ac_fn_c_try_compile "$LINENO"; then : - { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -$as_echo "yes" >&6; }; -$as_echo "#define HAVE_IN6_ADDR_S6_ADDR 1" >>confdefs.h - -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -for ac_func in getopt_long -do : - ac_fn_c_check_func "$LINENO" "getopt_long" "ac_cv_func_getopt_long" -if test "x$ac_cv_func_getopt_long" = x""yes; then : - cat >>confdefs.h <<_ACEOF -#define HAVE_GETOPT_LONG 1 -_ACEOF - -fi -done - - -CONDITIONAL_SOURCES="device-${arch}.${OBJEXT} privsep-${arch}.${OBJEXT} ${CONDITIONAL_SOURCES}" - - - - - - - - -ac_config_headers="$ac_config_headers config.h" - -ac_config_files="$ac_config_files Makefile" - -cat >confcache <<\_ACEOF -# This file is a shell script that caches the results of configure -# tests run on this system so they can be shared between configure -# scripts and configure runs, see configure's option --config-cache. -# It is not useful on other systems. If it contains results you don't -# want to keep, you may remove or edit it. -# -# config.status only pays attention to the cache file if you give it -# the --recheck option to rerun configure. -# -# `ac_cv_env_foo' variables (set or unset) will be overridden when -# loading this file, other *unset* `ac_cv_foo' will be assigned the -# following values. - -_ACEOF - -# The following way of writing the cache mishandles newlines in values, -# but we know of no workaround that is simple, portable, and efficient. -# So, we kill variables containing newlines. -# Ultrix sh set writes to stderr and can't be redirected directly, -# and sets the high bit in the cache file unless we assign to the vars. -( - for ac_var in `(set) 2>&1 | sed -n 's/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'`; do - eval ac_val=\$$ac_var - case $ac_val in #( - *${as_nl}*) - case $ac_var in #( - *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 -$as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; - esac - case $ac_var in #( - _ | IFS | as_nl) ;; #( - BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( - *) { eval $ac_var=; unset $ac_var;} ;; - esac ;; - esac - done - - (set) 2>&1 | - case $as_nl`(ac_space=' '; set) 2>&1` in #( - *${as_nl}ac_space=\ *) - # `set' does not quote correctly, so add quotes: double-quote - # substitution turns \\\\ into \\, and sed turns \\ into \. - sed -n \ - "s/'/'\\\\''/g; - s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" - ;; #( - *) - # `set' quotes correctly as required by POSIX, so do not add quotes. - sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" - ;; - esac | - sort -) | - sed ' - /^ac_cv_env_/b end - t clear - :clear - s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/ - t end - s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ - :end' >>confcache -if diff "$cache_file" confcache >/dev/null 2>&1; then :; else - if test -w "$cache_file"; then - test "x$cache_file" != "x/dev/null" && - { $as_echo "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 -$as_echo "$as_me: updating cache $cache_file" >&6;} - cat confcache >$cache_file - else - { $as_echo "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 -$as_echo "$as_me: not updating unwritable cache $cache_file" >&6;} - fi -fi -rm -f confcache - -test "x$prefix" = xNONE && prefix=$ac_default_prefix -# Let make expand exec_prefix. -test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' - -DEFS=-DHAVE_CONFIG_H - -ac_libobjs= -ac_ltlibobjs= -for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue - # 1. Remove the extension, and $U if already installed. - ac_script='s/\$U\././;s/\.o$//;s/\.obj$//' - ac_i=`$as_echo "$ac_i" | sed "$ac_script"` - # 2. Prepend LIBOBJDIR. When used with automake>=1.10 LIBOBJDIR - # will be set to the directory where LIBOBJS objects are built. - as_fn_append ac_libobjs " \${LIBOBJDIR}$ac_i\$U.$ac_objext" - as_fn_append ac_ltlibobjs " \${LIBOBJDIR}$ac_i"'$U.lo' -done -LIBOBJS=$ac_libobjs - -LTLIBOBJS=$ac_ltlibobjs - - - if test -n "$EXEEXT"; then - am__EXEEXT_TRUE= - am__EXEEXT_FALSE='#' -else - am__EXEEXT_TRUE='#' - am__EXEEXT_FALSE= -fi - -if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then - as_fn_error "conditional \"AMDEP\" was never defined. -Usually this means the macro was only invoked conditionally." "$LINENO" 5 -fi -if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then - as_fn_error "conditional \"am__fastdepCC\" was never defined. -Usually this means the macro was only invoked conditionally." "$LINENO" 5 -fi - -: ${CONFIG_STATUS=./config.status} -ac_write_fail=0 -ac_clean_files_save=$ac_clean_files -ac_clean_files="$ac_clean_files $CONFIG_STATUS" -{ $as_echo "$as_me:${as_lineno-$LINENO}: creating $CONFIG_STATUS" >&5 -$as_echo "$as_me: creating $CONFIG_STATUS" >&6;} -as_write_fail=0 -cat >$CONFIG_STATUS <<_ASEOF || as_write_fail=1 -#! $SHELL -# Generated by $as_me. -# Run this file to recreate the current configuration. -# Compiler output produced by configure, useful for debugging -# configure, is in config.log if it exists. - -debug=false -ac_cs_recheck=false -ac_cs_silent=false - -SHELL=\${CONFIG_SHELL-$SHELL} -export SHELL -_ASEOF -cat >>$CONFIG_STATUS <<\_ASEOF || as_write_fail=1 -## -------------------- ## -## M4sh Initialization. ## -## -------------------- ## - -# Be more Bourne compatible -DUALCASE=1; export DUALCASE # for MKS sh -if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : - emulate sh - NULLCMD=: - # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which - # is contrary to our usage. Disable this feature. - alias -g '${1+"$@"}'='"$@"' - setopt NO_GLOB_SUBST -else - case `(set -o) 2>/dev/null` in #( - *posix*) : - set -o posix ;; #( - *) : - ;; -esac -fi - - -as_nl=' -' -export as_nl -# Printing a long string crashes Solaris 7 /usr/bin/printf. -as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' -as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo -as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo -# Prefer a ksh shell builtin over an external printf program on Solaris, -# but without wasting forks for bash or zsh. -if test -z "$BASH_VERSION$ZSH_VERSION" \ - && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then - as_echo='print -r --' - as_echo_n='print -rn --' -elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then - as_echo='printf %s\n' - as_echo_n='printf %s' -else - if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then - as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' - as_echo_n='/usr/ucb/echo -n' - else - as_echo_body='eval expr "X$1" : "X\\(.*\\)"' - as_echo_n_body='eval - arg=$1; - case $arg in #( - *"$as_nl"*) - expr "X$arg" : "X\\(.*\\)$as_nl"; - arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; - esac; - expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" - ' - export as_echo_n_body - as_echo_n='sh -c $as_echo_n_body as_echo' - fi - export as_echo_body - as_echo='sh -c $as_echo_body as_echo' -fi - -# The user is always right. -if test "${PATH_SEPARATOR+set}" != set; then - PATH_SEPARATOR=: - (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { - (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || - PATH_SEPARATOR=';' - } -fi - - -# IFS -# We need space, tab and new line, in precisely that order. Quoting is -# there to prevent editors from complaining about space-tab. -# (If _AS_PATH_WALK were called with IFS unset, it would disable word -# splitting by setting IFS to empty value.) -IFS=" "" $as_nl" - -# Find who we are. Look in the path if we contain no directory separator. -case $0 in #(( - *[\\/]* ) as_myself=$0 ;; - *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break - done -IFS=$as_save_IFS - - ;; -esac -# We did not find ourselves, most probably we were run as `sh COMMAND' -# in which case we are not to be found in the path. -if test "x$as_myself" = x; then - as_myself=$0 -fi -if test ! -f "$as_myself"; then - $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 - exit 1 -fi - -# Unset variables that we do not need and which cause bugs (e.g. in -# pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" -# suppresses any "Segmentation fault" message there. '((' could -# trigger a bug in pdksh 5.2.14. -for as_var in BASH_ENV ENV MAIL MAILPATH -do eval test x\${$as_var+set} = xset \ - && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : -done -PS1='$ ' -PS2='> ' -PS4='+ ' - -# NLS nuisances. -LC_ALL=C -export LC_ALL -LANGUAGE=C -export LANGUAGE - -# CDPATH. -(unset CDPATH) >/dev/null 2>&1 && unset CDPATH - - -# as_fn_error ERROR [LINENO LOG_FD] -# --------------------------------- -# Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are -# provided, also output the error to LOG_FD, referencing LINENO. Then exit the -# script with status $?, using 1 if that was 0. -as_fn_error () -{ - as_status=$?; test $as_status -eq 0 && as_status=1 - if test "$3"; then - as_lineno=${as_lineno-"$2"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - $as_echo "$as_me:${as_lineno-$LINENO}: error: $1" >&$3 - fi - $as_echo "$as_me: error: $1" >&2 - as_fn_exit $as_status -} # as_fn_error - - -# as_fn_set_status STATUS -# ----------------------- -# Set $? to STATUS, without forking. -as_fn_set_status () -{ - return $1 -} # as_fn_set_status - -# as_fn_exit STATUS -# ----------------- -# Exit the shell with STATUS, even in a "trap 0" or "set -e" context. -as_fn_exit () -{ - set +e - as_fn_set_status $1 - exit $1 -} # as_fn_exit - -# as_fn_unset VAR -# --------------- -# Portably unset VAR. -as_fn_unset () -{ - { eval $1=; unset $1;} -} -as_unset=as_fn_unset -# as_fn_append VAR VALUE -# ---------------------- -# Append the text in VALUE to the end of the definition contained in VAR. Take -# advantage of any shell optimizations that allow amortized linear growth over -# repeated appends, instead of the typical quadratic growth present in naive -# implementations. -if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : - eval 'as_fn_append () - { - eval $1+=\$2 - }' -else - as_fn_append () - { - eval $1=\$$1\$2 - } -fi # as_fn_append - -# as_fn_arith ARG... -# ------------------ -# Perform arithmetic evaluation on the ARGs, and store the result in the -# global $as_val. Take advantage of shells that can avoid forks. The arguments -# must be portable across $(()) and expr. -if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : - eval 'as_fn_arith () - { - as_val=$(( $* )) - }' -else - as_fn_arith () - { - as_val=`expr "$@" || test $? -eq 1` - } -fi # as_fn_arith - - -if expr a : '\(a\)' >/dev/null 2>&1 && - test "X`expr 00001 : '.*\(...\)'`" = X001; then - as_expr=expr -else - as_expr=false -fi - -if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then - as_basename=basename -else - as_basename=false -fi - -if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then - as_dirname=dirname -else - as_dirname=false -fi - -as_me=`$as_basename -- "$0" || -$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ - X"$0" : 'X\(//\)$' \| \ - X"$0" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X/"$0" | - sed '/^.*\/\([^/][^/]*\)\/*$/{ - s//\1/ - q - } - /^X\/\(\/\/\)$/{ - s//\1/ - q - } - /^X\/\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - -# Avoid depending upon Character Ranges. -as_cr_letters='abcdefghijklmnopqrstuvwxyz' -as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' -as_cr_Letters=$as_cr_letters$as_cr_LETTERS -as_cr_digits='0123456789' -as_cr_alnum=$as_cr_Letters$as_cr_digits - -ECHO_C= ECHO_N= ECHO_T= -case `echo -n x` in #((((( --n*) - case `echo 'xy\c'` in - *c*) ECHO_T=' ';; # ECHO_T is single tab character. - xy) ECHO_C='\c';; - *) echo `echo ksh88 bug on AIX 6.1` > /dev/null - ECHO_T=' ';; - esac;; -*) - ECHO_N='-n';; -esac - -rm -f conf$$ conf$$.exe conf$$.file -if test -d conf$$.dir; then - rm -f conf$$.dir/conf$$.file -else - rm -f conf$$.dir - mkdir conf$$.dir 2>/dev/null -fi -if (echo >conf$$.file) 2>/dev/null; then - if ln -s conf$$.file conf$$ 2>/dev/null; then - as_ln_s='ln -s' - # ... but there are two gotchas: - # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. - # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. - # In both cases, we have to default to `cp -p'. - ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || - as_ln_s='cp -p' - elif ln conf$$.file conf$$ 2>/dev/null; then - as_ln_s=ln - else - as_ln_s='cp -p' - fi -else - as_ln_s='cp -p' -fi -rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file -rmdir conf$$.dir 2>/dev/null - - -# as_fn_mkdir_p -# ------------- -# Create "$as_dir" as a directory, including parents if necessary. -as_fn_mkdir_p () -{ - - case $as_dir in #( - -*) as_dir=./$as_dir;; - esac - test -d "$as_dir" || eval $as_mkdir_p || { - as_dirs= - while :; do - case $as_dir in #( - *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( - *) as_qdir=$as_dir;; - esac - as_dirs="'$as_qdir' $as_dirs" - as_dir=`$as_dirname -- "$as_dir" || -$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$as_dir" : 'X\(//\)[^/]' \| \ - X"$as_dir" : 'X\(//\)$' \| \ - X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X"$as_dir" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - test -d "$as_dir" && break - done - test -z "$as_dirs" || eval "mkdir $as_dirs" - } || test -d "$as_dir" || as_fn_error "cannot create directory $as_dir" - - -} # as_fn_mkdir_p -if mkdir -p . 2>/dev/null; then - as_mkdir_p='mkdir -p "$as_dir"' -else - test -d ./-p && rmdir ./-p - as_mkdir_p=false -fi - -if test -x / >/dev/null 2>&1; then - as_test_x='test -x' -else - if ls -dL / >/dev/null 2>&1; then - as_ls_L_option=L - else - as_ls_L_option= - fi - as_test_x=' - eval sh -c '\'' - if test -d "$1"; then - test -d "$1/."; - else - case $1 in #( - -*)set "./$1";; - esac; - case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in #(( - ???[sx]*):;;*)false;;esac;fi - '\'' sh - ' -fi -as_executable_p=$as_test_x - -# Sed expression to map a string onto a valid CPP name. -as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" - -# Sed expression to map a string onto a valid variable name. -as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" - - -exec 6>&1 -## ----------------------------------- ## -## Main body of $CONFIG_STATUS script. ## -## ----------------------------------- ## -_ASEOF -test $as_write_fail = 0 && chmod +x $CONFIG_STATUS || ac_write_fail=1 - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -# Save the log message, to keep $0 and so on meaningful, and to -# report actual input values of CONFIG_FILES etc. instead of their -# values after options handling. -ac_log=" -This file was extended by $as_me, which was -generated by GNU Autoconf 2.65. Invocation command line was - - CONFIG_FILES = $CONFIG_FILES - CONFIG_HEADERS = $CONFIG_HEADERS - CONFIG_LINKS = $CONFIG_LINKS - CONFIG_COMMANDS = $CONFIG_COMMANDS - $ $0 $@ - -on `(hostname || uname -n) 2>/dev/null | sed 1q` -" - -_ACEOF - -case $ac_config_files in *" -"*) set x $ac_config_files; shift; ac_config_files=$*;; -esac - -case $ac_config_headers in *" -"*) set x $ac_config_headers; shift; ac_config_headers=$*;; -esac - - -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -# Files that config.status was made for. -config_files="$ac_config_files" -config_headers="$ac_config_headers" -config_commands="$ac_config_commands" - -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -ac_cs_usage="\ -\`$as_me' instantiates files and other configuration actions -from templates according to the current configuration. Unless the files -and actions are specified as TAGs, all are instantiated by default. - -Usage: $0 [OPTION]... [TAG]... - - -h, --help print this help, then exit - -V, --version print version number and configuration settings, then exit - --config print configuration, then exit - -q, --quiet, --silent - do not print progress messages - -d, --debug don't remove temporary files - --recheck update $as_me by reconfiguring in the same conditions - --file=FILE[:TEMPLATE] - instantiate the configuration file FILE - --header=FILE[:TEMPLATE] - instantiate the configuration header FILE - -Configuration files: -$config_files - -Configuration headers: -$config_headers - -Configuration commands: -$config_commands - -Report bugs to the package provider." - -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" -ac_cs_version="\\ -config.status -configured by $0, generated by GNU Autoconf 2.65, - with options \\"\$ac_cs_config\\" - -Copyright (C) 2009 Free Software Foundation, Inc. -This config.status script is free software; the Free Software Foundation -gives unlimited permission to copy, distribute and modify it." - -ac_pwd='$ac_pwd' -srcdir='$srcdir' -INSTALL='$INSTALL' -MKDIR_P='$MKDIR_P' -AWK='$AWK' -test -n "\$AWK" || AWK=awk -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -# The default lists apply if the user does not specify any file. -ac_need_defaults=: -while test $# != 0 -do - case $1 in - --*=*) - ac_option=`expr "X$1" : 'X\([^=]*\)='` - ac_optarg=`expr "X$1" : 'X[^=]*=\(.*\)'` - ac_shift=: - ;; - *) - ac_option=$1 - ac_optarg=$2 - ac_shift=shift - ;; - esac - - case $ac_option in - # Handling of the options. - -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) - ac_cs_recheck=: ;; - --version | --versio | --versi | --vers | --ver | --ve | --v | -V ) - $as_echo "$ac_cs_version"; exit ;; - --config | --confi | --conf | --con | --co | --c ) - $as_echo "$ac_cs_config"; exit ;; - --debug | --debu | --deb | --de | --d | -d ) - debug=: ;; - --file | --fil | --fi | --f ) - $ac_shift - case $ac_optarg in - *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; - esac - as_fn_append CONFIG_FILES " '$ac_optarg'" - ac_need_defaults=false;; - --header | --heade | --head | --hea ) - $ac_shift - case $ac_optarg in - *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; - esac - as_fn_append CONFIG_HEADERS " '$ac_optarg'" - ac_need_defaults=false;; - --he | --h) - # Conflict between --help and --header - as_fn_error "ambiguous option: \`$1' -Try \`$0 --help' for more information.";; - --help | --hel | -h ) - $as_echo "$ac_cs_usage"; exit ;; - -q | -quiet | --quiet | --quie | --qui | --qu | --q \ - | -silent | --silent | --silen | --sile | --sil | --si | --s) - ac_cs_silent=: ;; - - # This is an error. - -*) as_fn_error "unrecognized option: \`$1' -Try \`$0 --help' for more information." ;; - - *) as_fn_append ac_config_targets " $1" - ac_need_defaults=false ;; - - esac - shift -done - -ac_configure_extra_args= - -if $ac_cs_silent; then - exec 6>/dev/null - ac_configure_extra_args="$ac_configure_extra_args --silent" -fi - -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -if \$ac_cs_recheck; then - set X '$SHELL' '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion - shift - \$as_echo "running CONFIG_SHELL=$SHELL \$*" >&6 - CONFIG_SHELL='$SHELL' - export CONFIG_SHELL - exec "\$@" -fi - -_ACEOF -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -exec 5>>config.log -{ - echo - sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX -## Running $as_me. ## -_ASBOX - $as_echo "$ac_log" -} >&5 - -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -# -# INIT-COMMANDS -# -AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" - -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 - -# Handling of arguments. -for ac_config_target in $ac_config_targets -do - case $ac_config_target in - "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; - "config.h") CONFIG_HEADERS="$CONFIG_HEADERS config.h" ;; - "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;; - - *) as_fn_error "invalid argument: \`$ac_config_target'" "$LINENO" 5;; - esac -done - - -# If the user did not use the arguments to specify the items to instantiate, -# then the envvar interface is used. Set only those that are not. -# We use the long form for the default assignment because of an extremely -# bizarre bug on SunOS 4.1.3. -if $ac_need_defaults; then - test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files - test "${CONFIG_HEADERS+set}" = set || CONFIG_HEADERS=$config_headers - test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands -fi - -# Have a temporary directory for convenience. Make it in the build tree -# simply because there is no reason against having it here, and in addition, -# creating and moving files from /tmp can sometimes cause problems. -# Hook for its removal unless debugging. -# Note that there is a small window in which the directory will not be cleaned: -# after its creation but before its name has been assigned to `$tmp'. -$debug || -{ - tmp= - trap 'exit_status=$? - { test -z "$tmp" || test ! -d "$tmp" || rm -fr "$tmp"; } && exit $exit_status -' 0 - trap 'as_fn_exit 1' 1 2 13 15 -} -# Create a (secure) tmp directory for tmp files. - -{ - tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && - test -n "$tmp" && test -d "$tmp" -} || -{ - tmp=./conf$$-$RANDOM - (umask 077 && mkdir "$tmp") -} || as_fn_error "cannot create a temporary directory in ." "$LINENO" 5 - -# Set up the scripts for CONFIG_FILES section. -# No need to generate them if there are no CONFIG_FILES. -# This happens for instance with `./config.status config.h'. -if test -n "$CONFIG_FILES"; then - - -ac_cr=`echo X | tr X '\015'` -# On cygwin, bash can eat \r inside `` if the user requested igncr. -# But we know of no other shell where ac_cr would be empty at this -# point, so we can use a bashism as a fallback. -if test "x$ac_cr" = x; then - eval ac_cr=\$\'\\r\' -fi -ac_cs_awk_cr=`$AWK 'BEGIN { print "a\rb" }' /dev/null` -if test "$ac_cs_awk_cr" = "a${ac_cr}b"; then - ac_cs_awk_cr='\r' -else - ac_cs_awk_cr=$ac_cr -fi - -echo 'BEGIN {' >"$tmp/subs1.awk" && -_ACEOF - - -{ - echo "cat >conf$$subs.awk <<_ACEOF" && - echo "$ac_subst_vars" | sed 's/.*/&!$&$ac_delim/' && - echo "_ACEOF" -} >conf$$subs.sh || - as_fn_error "could not make $CONFIG_STATUS" "$LINENO" 5 -ac_delim_num=`echo "$ac_subst_vars" | grep -c '$'` -ac_delim='%!_!# ' -for ac_last_try in false false false false false :; do - . ./conf$$subs.sh || - as_fn_error "could not make $CONFIG_STATUS" "$LINENO" 5 - - ac_delim_n=`sed -n "s/.*$ac_delim\$/X/p" conf$$subs.awk | grep -c X` - if test $ac_delim_n = $ac_delim_num; then - break - elif $ac_last_try; then - as_fn_error "could not make $CONFIG_STATUS" "$LINENO" 5 - else - ac_delim="$ac_delim!$ac_delim _$ac_delim!! " - fi -done -rm -f conf$$subs.sh - -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -cat >>"\$tmp/subs1.awk" <<\\_ACAWK && -_ACEOF -sed -n ' -h -s/^/S["/; s/!.*/"]=/ -p -g -s/^[^!]*!// -:repl -t repl -s/'"$ac_delim"'$// -t delim -:nl -h -s/\(.\{148\}\)..*/\1/ -t more1 -s/["\\]/\\&/g; s/^/"/; s/$/\\n"\\/ -p -n -b repl -:more1 -s/["\\]/\\&/g; s/^/"/; s/$/"\\/ -p -g -s/.\{148\}// -t nl -:delim -h -s/\(.\{148\}\)..*/\1/ -t more2 -s/["\\]/\\&/g; s/^/"/; s/$/"/ -p -b -:more2 -s/["\\]/\\&/g; s/^/"/; s/$/"\\/ -p -g -s/.\{148\}// -t delim -' >$CONFIG_STATUS || ac_write_fail=1 -rm -f conf$$subs.awk -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -_ACAWK -cat >>"\$tmp/subs1.awk" <<_ACAWK && - for (key in S) S_is_set[key] = 1 - FS = "" - -} -{ - line = $ 0 - nfields = split(line, field, "@") - substed = 0 - len = length(field[1]) - for (i = 2; i < nfields; i++) { - key = field[i] - keylen = length(key) - if (S_is_set[key]) { - value = S[key] - line = substr(line, 1, len) "" value "" substr(line, len + keylen + 3) - len += length(value) + length(field[++i]) - substed = 1 - } else - len += 1 + keylen - } - - print line -} - -_ACAWK -_ACEOF -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then - sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" -else - cat -fi < "$tmp/subs1.awk" > "$tmp/subs.awk" \ - || as_fn_error "could not setup config files machinery" "$LINENO" 5 -_ACEOF - -# VPATH may cause trouble with some makes, so we remove $(srcdir), -# ${srcdir} and @srcdir@ from VPATH if srcdir is ".", strip leading and -# trailing colons and then remove the whole line if VPATH becomes empty -# (actually we leave an empty line to preserve line numbers). -if test "x$srcdir" = x.; then - ac_vpsub='/^[ ]*VPATH[ ]*=/{ -s/:*\$(srcdir):*/:/ -s/:*\${srcdir}:*/:/ -s/:*@srcdir@:*/:/ -s/^\([^=]*=[ ]*\):*/\1/ -s/:*$// -s/^[^=]*=[ ]*$// -}' -fi - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -fi # test -n "$CONFIG_FILES" - -# Set up the scripts for CONFIG_HEADERS section. -# No need to generate them if there are no CONFIG_HEADERS. -# This happens for instance with `./config.status Makefile'. -if test -n "$CONFIG_HEADERS"; then -cat >"$tmp/defines.awk" <<\_ACAWK || -BEGIN { -_ACEOF - -# Transform confdefs.h into an awk script `defines.awk', embedded as -# here-document in config.status, that substitutes the proper values into -# config.h.in to produce config.h. - -# Create a delimiter string that does not exist in confdefs.h, to ease -# handling of long lines. -ac_delim='%!_!# ' -for ac_last_try in false false :; do - ac_t=`sed -n "/$ac_delim/p" confdefs.h` - if test -z "$ac_t"; then - break - elif $ac_last_try; then - as_fn_error "could not make $CONFIG_HEADERS" "$LINENO" 5 - else - ac_delim="$ac_delim!$ac_delim _$ac_delim!! " - fi -done - -# For the awk script, D is an array of macro values keyed by name, -# likewise P contains macro parameters if any. Preserve backslash -# newline sequences. - -ac_word_re=[_$as_cr_Letters][_$as_cr_alnum]* -sed -n ' -s/.\{148\}/&'"$ac_delim"'/g -t rset -:rset -s/^[ ]*#[ ]*define[ ][ ]*/ / -t def -d -:def -s/\\$// -t bsnl -s/["\\]/\\&/g -s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ -D["\1"]=" \3"/p -s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2"/p -d -:bsnl -s/["\\]/\\&/g -s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ -D["\1"]=" \3\\\\\\n"\\/p -t cont -s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2\\\\\\n"\\/p -t cont -d -:cont -n -s/.\{148\}/&'"$ac_delim"'/g -t clear -:clear -s/\\$// -t bsnlc -s/["\\]/\\&/g; s/^/"/; s/$/"/p -d -:bsnlc -s/["\\]/\\&/g; s/^/"/; s/$/\\\\\\n"\\/p -b cont -' >$CONFIG_STATUS || ac_write_fail=1 - -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 - for (key in D) D_is_set[key] = 1 - FS = "" -} -/^[\t ]*#[\t ]*(define|undef)[\t ]+$ac_word_re([\t (]|\$)/ { - line = \$ 0 - split(line, arg, " ") - if (arg[1] == "#") { - defundef = arg[2] - mac1 = arg[3] - } else { - defundef = substr(arg[1], 2) - mac1 = arg[2] - } - split(mac1, mac2, "(") #) - macro = mac2[1] - prefix = substr(line, 1, index(line, defundef) - 1) - if (D_is_set[macro]) { - # Preserve the white space surrounding the "#". - print prefix "define", macro P[macro] D[macro] - next - } else { - # Replace #undef with comments. This is necessary, for example, - # in the case of _POSIX_SOURCE, which is predefined and required - # on some systems where configure will not decide to define it. - if (defundef == "undef") { - print "/*", prefix defundef, macro, "*/" - next - } - } -} -{ print } -_ACAWK -_ACEOF -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 - as_fn_error "could not setup config headers machinery" "$LINENO" 5 -fi # test -n "$CONFIG_HEADERS" - - -eval set X " :F $CONFIG_FILES :H $CONFIG_HEADERS :C $CONFIG_COMMANDS" -shift -for ac_tag -do - case $ac_tag in - :[FHLC]) ac_mode=$ac_tag; continue;; - esac - case $ac_mode$ac_tag in - :[FHL]*:*);; - :L* | :C*:*) as_fn_error "invalid tag \`$ac_tag'" "$LINENO" 5;; - :[FH]-) ac_tag=-:-;; - :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; - esac - ac_save_IFS=$IFS - IFS=: - set x $ac_tag - IFS=$ac_save_IFS - shift - ac_file=$1 - shift - - case $ac_mode in - :L) ac_source=$1;; - :[FH]) - ac_file_inputs= - for ac_f - do - case $ac_f in - -) ac_f="$tmp/stdin";; - *) # Look for the file first in the build tree, then in the source tree - # (if the path is not absolute). The absolute path cannot be DOS-style, - # because $ac_f cannot contain `:'. - test -f "$ac_f" || - case $ac_f in - [\\/$]*) false;; - *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; - esac || - as_fn_error "cannot find input file: \`$ac_f'" "$LINENO" 5;; - esac - case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac - as_fn_append ac_file_inputs " '$ac_f'" - done - - # Let's still pretend it is `configure' which instantiates (i.e., don't - # use $as_me), people would be surprised to read: - # /* config.h. Generated by config.status. */ - configure_input='Generated from '` - $as_echo "$*" | sed 's|^[^:]*/||;s|:[^:]*/|, |g' - `' by configure.' - if test x"$ac_file" != x-; then - configure_input="$ac_file. $configure_input" - { $as_echo "$as_me:${as_lineno-$LINENO}: creating $ac_file" >&5 -$as_echo "$as_me: creating $ac_file" >&6;} - fi - # Neutralize special characters interpreted by sed in replacement strings. - case $configure_input in #( - *\&* | *\|* | *\\* ) - ac_sed_conf_input=`$as_echo "$configure_input" | - sed 's/[\\\\&|]/\\\\&/g'`;; #( - *) ac_sed_conf_input=$configure_input;; - esac - - case $ac_tag in - *:-:* | *:-) cat >"$tmp/stdin" \ - || as_fn_error "could not create $ac_file" "$LINENO" 5 ;; - esac - ;; - esac - - ac_dir=`$as_dirname -- "$ac_file" || -$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$ac_file" : 'X\(//\)[^/]' \| \ - X"$ac_file" : 'X\(//\)$' \| \ - X"$ac_file" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X"$ac_file" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - as_dir="$ac_dir"; as_fn_mkdir_p - ac_builddir=. - -case "$ac_dir" in -.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; -*) - ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` - # A ".." for each directory in $ac_dir_suffix. - ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` - case $ac_top_builddir_sub in - "") ac_top_builddir_sub=. ac_top_build_prefix= ;; - *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; - esac ;; -esac -ac_abs_top_builddir=$ac_pwd -ac_abs_builddir=$ac_pwd$ac_dir_suffix -# for backward compatibility: -ac_top_builddir=$ac_top_build_prefix - -case $srcdir in - .) # We are building in place. - ac_srcdir=. - ac_top_srcdir=$ac_top_builddir_sub - ac_abs_top_srcdir=$ac_pwd ;; - [\\/]* | ?:[\\/]* ) # Absolute name. - ac_srcdir=$srcdir$ac_dir_suffix; - ac_top_srcdir=$srcdir - ac_abs_top_srcdir=$srcdir ;; - *) # Relative name. - ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix - ac_top_srcdir=$ac_top_build_prefix$srcdir - ac_abs_top_srcdir=$ac_pwd/$srcdir ;; -esac -ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix - - - case $ac_mode in - :F) - # - # CONFIG_FILE - # - - case $INSTALL in - [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; - *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;; - esac - ac_MKDIR_P=$MKDIR_P - case $MKDIR_P in - [\\/$]* | ?:[\\/]* ) ;; - */*) ac_MKDIR_P=$ac_top_build_prefix$MKDIR_P ;; - esac -_ACEOF - -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -# If the template does not know about datarootdir, expand it. -# FIXME: This hack should be removed a few years after 2.60. -ac_datarootdir_hack=; ac_datarootdir_seen= -ac_sed_dataroot=' -/datarootdir/ { - p - q -} -/@datadir@/p -/@docdir@/p -/@infodir@/p -/@localedir@/p -/@mandir@/p' -case `eval "sed -n \"\$ac_sed_dataroot\" $ac_file_inputs"` in -*datarootdir*) ac_datarootdir_seen=yes;; -*@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*) - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5 -$as_echo "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;} -_ACEOF -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 - ac_datarootdir_hack=' - s&@datadir@&$datadir&g - s&@docdir@&$docdir&g - s&@infodir@&$infodir&g - s&@localedir@&$localedir&g - s&@mandir@&$mandir&g - s&\\\${datarootdir}&$datarootdir&g' ;; -esac -_ACEOF - -# Neutralize VPATH when `$srcdir' = `.'. -# Shell code in configure.ac might set extrasub. -# FIXME: do we really want to maintain this feature? -cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -ac_sed_extra="$ac_vpsub -$extrasub -_ACEOF -cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 -:t -/@[a-zA-Z_][a-zA-Z_0-9]*@/!b -s|@configure_input@|$ac_sed_conf_input|;t t -s&@top_builddir@&$ac_top_builddir_sub&;t t -s&@top_build_prefix@&$ac_top_build_prefix&;t t -s&@srcdir@&$ac_srcdir&;t t -s&@abs_srcdir@&$ac_abs_srcdir&;t t -s&@top_srcdir@&$ac_top_srcdir&;t t -s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t -s&@builddir@&$ac_builddir&;t t -s&@abs_builddir@&$ac_abs_builddir&;t t -s&@abs_top_builddir@&$ac_abs_top_builddir&;t t -s&@INSTALL@&$ac_INSTALL&;t t -s&@MKDIR_P@&$ac_MKDIR_P&;t t -$ac_datarootdir_hack -" -eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$tmp/subs.awk" >$tmp/out \ - || as_fn_error "could not create $ac_file" "$LINENO" 5 - -test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && - { ac_out=`sed -n '/\${datarootdir}/p' "$tmp/out"`; test -n "$ac_out"; } && - { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' "$tmp/out"`; test -z "$ac_out"; } && - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' -which seems to be undefined. Please make sure it is defined." >&5 -$as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' -which seems to be undefined. Please make sure it is defined." >&2;} - - rm -f "$tmp/stdin" - case $ac_file in - -) cat "$tmp/out" && rm -f "$tmp/out";; - *) rm -f "$ac_file" && mv "$tmp/out" "$ac_file";; - esac \ - || as_fn_error "could not create $ac_file" "$LINENO" 5 - ;; - :H) - # - # CONFIG_HEADER - # - if test x"$ac_file" != x-; then - { - $as_echo "/* $configure_input */" \ - && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" - } >"$tmp/config.h" \ - || as_fn_error "could not create $ac_file" "$LINENO" 5 - if diff "$ac_file" "$tmp/config.h" >/dev/null 2>&1; then - { $as_echo "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 -$as_echo "$as_me: $ac_file is unchanged" >&6;} - else - rm -f "$ac_file" - mv "$tmp/config.h" "$ac_file" \ - || as_fn_error "could not create $ac_file" "$LINENO" 5 - fi - else - $as_echo "/* $configure_input */" \ - && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" \ - || as_fn_error "could not create -" "$LINENO" 5 - fi -# Compute "$ac_file"'s index in $config_headers. -_am_arg="$ac_file" -_am_stamp_count=1 -for _am_header in $config_headers :; do - case $_am_header in - $_am_arg | $_am_arg:* ) - break ;; - * ) - _am_stamp_count=`expr $_am_stamp_count + 1` ;; - esac -done -echo "timestamp for $_am_arg" >`$as_dirname -- "$_am_arg" || -$as_expr X"$_am_arg" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$_am_arg" : 'X\(//\)[^/]' \| \ - X"$_am_arg" : 'X\(//\)$' \| \ - X"$_am_arg" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X"$_am_arg" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'`/stamp-h$_am_stamp_count - ;; - - :C) { $as_echo "$as_me:${as_lineno-$LINENO}: executing $ac_file commands" >&5 -$as_echo "$as_me: executing $ac_file commands" >&6;} - ;; - esac - - - case $ac_file$ac_mode in - "depfiles":C) test x"$AMDEP_TRUE" != x"" || { - # Autoconf 2.62 quotes --file arguments for eval, but not when files - # are listed without --file. Let's play safe and only enable the eval - # if we detect the quoting. - case $CONFIG_FILES in - *\'*) eval set x "$CONFIG_FILES" ;; - *) set x $CONFIG_FILES ;; - esac - shift - for mf - do - # Strip MF so we end up with the name of the file. - mf=`echo "$mf" | sed -e 's/:.*$//'` - # Check whether this is an Automake generated Makefile or not. - # We used to match only the files named `Makefile.in', but - # some people rename them; so instead we look at the file content. - # Grep'ing the first line is not enough: some people post-process - # each Makefile.in and add a new line on top of each file to say so. - # Grep'ing the whole file is not good either: AIX grep has a line - # limit of 2048, but all sed's we know have understand at least 4000. - if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then - dirpart=`$as_dirname -- "$mf" || -$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$mf" : 'X\(//\)[^/]' \| \ - X"$mf" : 'X\(//\)$' \| \ - X"$mf" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X"$mf" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - else - continue - fi - # Extract the definition of DEPDIR, am__include, and am__quote - # from the Makefile without running `make'. - DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` - test -z "$DEPDIR" && continue - am__include=`sed -n 's/^am__include = //p' < "$mf"` - test -z "am__include" && continue - am__quote=`sed -n 's/^am__quote = //p' < "$mf"` - # When using ansi2knr, U may be empty or an underscore; expand it - U=`sed -n 's/^U = //p' < "$mf"` - # Find all dependency output files, they are included files with - # $(DEPDIR) in their names. We invoke sed twice because it is the - # simplest approach to changing $(DEPDIR) to its actual value in the - # expansion. - for file in `sed -n " - s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ - sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do - # Make sure the directory exists. - test -f "$dirpart/$file" && continue - fdir=`$as_dirname -- "$file" || -$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$file" : 'X\(//\)[^/]' \| \ - X"$file" : 'X\(//\)$' \| \ - X"$file" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X"$file" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q'` - as_dir=$dirpart/$fdir; as_fn_mkdir_p - # echo "creating $dirpart/$file" - echo '# dummy' > "$dirpart/$file" - done - done -} - ;; - - esac -done # for ac_tag - - -as_fn_exit 0 -_ACEOF -ac_clean_files=$ac_clean_files_save - -test $ac_write_fail = 0 || - as_fn_error "write failure creating $CONFIG_STATUS" "$LINENO" 5 - - -# configure is writing to config.log, and then calls config.status. -# config.status does its own redirection, appending to config.log. -# Unfortunately, on DOS this fails, as config.log is still kept open -# by configure, so config.status won't be able to write to it; its -# output is simply discarded. So we exec the FD to /dev/null, -# effectively closing config.log, so it can be properly (re)opened and -# appended to by config.status. When coming back to configure, we -# need to make the FD available again. -if test "$no_create" != yes; then - ac_cs_success=: - ac_config_status_args= - test "$silent" = yes && - ac_config_status_args="$ac_config_status_args --quiet" - exec 5>/dev/null - $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false - exec 5>>config.log - # Use ||, not &&, to avoid exiting from the if with $? = 1, which - # would make configure fail if this is the last instruction. - $ac_cs_success || as_fn_exit $? -fi -if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unrecognized options: $ac_unrecognized_opts" >&5 -$as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} -fi - - -cat << EOF - -Your build configuration: - - CFLAGS = $CFLAGS - LDFLAGS = $LDFLAGS - Arch = ${arch} - Extras: ${CONDITIONAL_SOURCES} - prefix: $prefix - PID file: $PATH_RADVD_PID - Log file: $PATH_RADVD_LOG - Config file: $PATH_RADVD_CONF - Radvd version: $VERSION - -EOF - diff --git a/release/src/router/radvd/configure.in b/release/src/router/radvd/configure.in deleted file mode 100644 index 1ed22804c3..0000000000 --- a/release/src/router/radvd/configure.in +++ /dev/null @@ -1,205 +0,0 @@ -dnl -dnl $Id: configure.in,v 1.25 2011/02/25 06:14:05 reubenhwk Exp $ -dnl -dnl Authors: -dnl Lars Fenneberg -dnl -dnl This software is Copyright 1996-2000 by the above mentioned author(s), -dnl All Rights Reserved. -dnl -dnl The license which is distributed with this software in the file COPYRIGHT -dnl applies to this software. If your distribution is missing this file, you -dnl may request it from . -dnl -dnl - -AC_REVISION ($Id: configure.in,v 1.25 2011/02/25 06:14:05 reubenhwk Exp $) -AC_INIT(radvd.c) - -AC_CANONICAL_SYSTEM -VERSION=`cat ${srcdir}/VERSION | grep -v '^#' | tr -d '\012'` -AM_INIT_AUTOMAKE(radvd,$VERSION,true) -m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES(yes)]) - -AC_MSG_CHECKING([architecture]) -case "$target" in - *linux*) - AC_MSG_RESULT(linux) - AC_DEFINE([_GNU_SOURCE], [], [whether compiling on Linux, glibc>=2.8 doesn't expose in6_pktinfo otherwise..]) - arch=linux - ;; - *bsd*) - AC_MSG_RESULT(bsd44) - arch=bsd44 - ;; - *darwin*) - AC_MSG_RESULT([bsd44 (darwin)]) - arch=bsd44 - ;; - *) - AC_MSG_RESULT(unknown: $target) - AC_MSG_ERROR( -[currently only Linux and BSD 4.4 with NRL's IPv6 code are -supported. If you have such a system and it is not guessed correctly -you must specifiy it with --target on the configure command line]) - ;; -esac - -dnl Determine CC and preset CFLAGS -AC_PROG_CC - -dnl Determine of netlink is available -AC_MSG_CHECKING(netlink) -AC_TRY_COMPILE([ -#include -#include -#include -#include -],[ -int -main(int argc, char * argv[]) -{ - int sock; - struct sockaddr_nl snl; - - sock = socket(PF_NETLINK, SOCK_RAW, NETLINK_ROUTE); - - snl.nl_family = AF_NETLINK; - snl.nl_groups = RTMGRP_LINK; - - return 0; -} -],[ -AC_DEFINE(HAVE_NETLINK, 1, [Linux netlink]) -CONDITIONAL_SOURCES=netlink.${OBJEXT} -AC_MSG_RESULT(yes) -],[ -AC_MSG_RESULT(no) -]) - -dnl Needed for normal compile -AC_PROG_INSTALL -AC_PATH_PROG(RM, rm, NOTFOUND) -if test "x$RM" = xNOTFOUND; then - AC_MSG_ERROR(can't find rm in your path - check PATH) -fi -AC_PATH_PROG(SED, sed, NOTFOUND) -if test "x$SED" = xNOTFOUND; then - AC_MSG_ERROR(can't find sed in your path - check PATH) -fi -dnl Not needed -AC_PATH_PROG(LN, ln) -AC_PROG_YACC -AM_PROG_LEX -AC_PATH_PROG(TAR, tar) -AC_PATH_PROG(GZIP, gzip) - -dnl Check where to put the logfile -AC_MSG_CHECKING(where to put logfile) -AC_ARG_WITH(logfile, -[ --with-logfile Path to the radvd logfile [/var/log/radvd.log]], - PATH_RADVD_LOG=$withval, - PATH_RADVD_LOG=/var/log/radvd.log) -AC_MSG_RESULT($PATH_RADVD_LOG) - -dnl Check where to put the pidfile -AC_MSG_CHECKING(where to put pidfile) -AC_ARG_WITH(pidfile, -[ --with-pidfile Path to the radvd pidfile [/var/run/radvd.pid]], - PATH_RADVD_PID=$withval, - PATH_RADVD_PID=/var/run/radvd.pid) -AC_MSG_RESULT($PATH_RADVD_PID) - -dnl Check where to put the configfile -AC_MSG_CHECKING(where to find configfile) -AC_ARG_WITH(configfile, -[ --with-configfile Path to the radvd config file [SYSCONF/radvd.conf]], - PATH_RADVD_CONF=$withval, - [eval PATH_RADVD_CONF=${sysconfdir}/radvd.conf]) -PATH_RADVD_CONF=$(echo $PATH_RADVD_CONF | sed 's/NONE//1') -AC_MSG_RESULT($PATH_RADVD_CONF) - -dnl Checking which syslog facility to use -AC_MSG_CHECKING(which syslog facility to use) -AC_ARG_WITH(facility, -[ --with-facility Syslog facility to use when using syslog logging], - LOG_FACILITY=$withval, - LOG_FACILITY=LOG_DAEMON) -AC_MSG_RESULT($LOG_FACILITY) - -dnl Checks for libraries. - -AC_CHECK_LIB(c, inet_ntop,, - AC_CHECK_LIB(inet6, inet_ntop, - LIBS="$LIBS -linet6" - , - AC_MSG_ERROR(can't continue without libinet6.a library - check your LDFLAGS) - ) -) -# prevent caching -unset ac_cv_lib_inet6_inet_ntop - -dnl Checks for header files. -AC_HEADER_STDC -AC_CHECK_HEADERS( \ - getopt.h \ - ifaddrs.h \ - machine/limits.h \ - machine/param.h \ - net/if_arp.h \ - net/if_dl.h \ - net/if_types.h \ - sys/param.h \ - sys/sockio.h \ - sys/time.h \ - time.h \ -) -AC_HEADER_TIME - -dnl Checks for typedefs, structures, and compiler characteristics. -AC_C_CONST - -AC_MSG_CHECKING(whether struct sockaddr_in6 has sin6_scope_id) -AC_TRY_COMPILE([#include -#include ], [static struct sockaddr_in6 ac_sin6; int ac_size = -sizeof (ac_sin6.sin6_scope_id);], [AC_MSG_RESULT(yes); AC_DEFINE([HAVE_SIN6_SCOPE_ID], -1, [whether struct sockaddr_in6 has sin6_scope_id])], -AC_MSG_RESULT(no)) - -AC_MSG_CHECKING(whether struct in6_addr has u6_addrXX and defines s6_addrXX) -AC_TRY_COMPILE([#include ], [static struct in6_addr in6_u; -int u = in6_u.s6_addr16;], [AC_MSG_RESULT(yes); AC_DEFINE([HAVE_IN6_ADDR_S6_ADDR], -1, [whether struct in6_addr has u6_addrXX and defines s6_addrXX])], -AC_MSG_RESULT(no)) - -dnl Checks for library functions. -AC_CHECK_FUNCS(getopt_long) - -CONDITIONAL_SOURCES="device-${arch}.${OBJEXT} privsep-${arch}.${OBJEXT} ${CONDITIONAL_SOURCES}" -AC_SUBST(CONDITIONAL_SOURCES) - -AC_SUBST(VERSION) -AC_SUBST(PATH_RADVD_CONF) -AC_SUBST(PATH_RADVD_PID) -AC_SUBST(PATH_RADVD_LOG) -AC_SUBST(LOG_FACILITY) - -AM_CONFIG_HEADER(config.h) -AC_OUTPUT(Makefile) - -cat << EOF - -Your build configuration: - - CFLAGS = $CFLAGS - LDFLAGS = $LDFLAGS - Arch = ${arch} - Extras: ${CONDITIONAL_SOURCES} - prefix: $prefix - PID file: $PATH_RADVD_PID - Log file: $PATH_RADVD_LOG - Config file: $PATH_RADVD_CONF - Radvd version: $VERSION - -EOF - diff --git a/release/src/router/radvd/copyright.blurb b/release/src/router/radvd/copyright.blurb deleted file mode 100644 index 57c92aae45..0000000000 --- a/release/src/router/radvd/copyright.blurb +++ /dev/null @@ -1,14 +0,0 @@ -/* - * $Id: copyright.blurb,v 1.3 2005/10/18 19:17:29 lutchann Exp $ - * - * Authors: - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ diff --git a/release/src/router/radvd/defaults.h b/release/src/router/radvd/defaults.h deleted file mode 100644 index 55f44d52ba..0000000000 --- a/release/src/router/radvd/defaults.h +++ /dev/null @@ -1,254 +0,0 @@ -/* - * $Id: defaults.h,v 1.31 2011/05/04 18:03:57 reubenhwk Exp $ - * - * Authors: - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#ifndef DEFAULTS_H -#define DEFAULTS_H - -#include "config.h" -#include "includes.h" -#include "radvd.h" - -/* maximum message size for incoming and outgoing RSs and RAs */ -#define MSG_SIZE_RECV 1500 -#define MSG_SIZE_SEND 1452 - -#define MAX2(X,Y) ( (( X ) >= ( Y )) ? ( X ) : ( Y )) - - -/* Router Configuration Variables: */ - -/* For each multicast interface: */ - -#define DFLT_IgnoreIfMissing 1 -#define DFLT_AdvSendAdv 0 -#define DFLT_MaxRtrAdvInterval 600 -#define DFLT_MinRtrAdvInterval(iface) (0.33 * (iface)->MaxRtrAdvInterval) -#define DFLT_AdvManagedFlag 0 -#define DFLT_AdvOtherConfigFlag 0 -#define DFLT_AdvLinkMTU 0 -#define DFLT_AdvReachableTime 0 -#define DFLT_AdvRetransTimer 0 -#define DFLT_AdvCurHopLimit 64 /* as per RFC 1700 or the - next incarnation of it :) */ -#define DFLT_AdvDefaultLifetime(iface) MAX2(1, (int)(3.0 * (iface)->MaxRtrAdvInterval)) -#define DFLT_MinDelayBetweenRAs MIN_DELAY_BETWEEN_RAS -#define DFLT_AdvDefaultPreference 0 - -/* Options sent with RA */ - -#define DFLT_AdvSourceLLAddress 1 - -/* Each prefix has an associated: */ - -#define DFLT_AdvValidLifetime 86400 /* seconds */ -#define DFLT_AdvOnLinkFlag 1 -#define DFLT_AdvPreferredLifetime 14400 /* seconds */ -#define DFLT_AdvAutonomousFlag 1 -#define DFLT_DeprecatePrefixFlag 0 -#define DFLT_DecrementLifetimesFlag 0 - -/* Each route has an associated: */ -#define DFLT_AdvRouteLifetime(iface) (3 * (iface)->MaxRtrAdvInterval) - -#define DFLT_AdvRoutePreference 0 /* medium*/ -#define DFLT_RemoveRouteFlag 1 - -/* RDNSS */ -#define DFLT_AdvRDNSSLifetime(iface) (iface)->MaxRtrAdvInterval -#define DFLT_FlushRDNSSFlag 1 - -/* DNSSL */ -#define DFLT_AdvDNSSLLifetime(iface) (iface)->MaxRtrAdvInterval -#define DFLT_FlushDNSSLFlag 1 - -/* Protocol (RFC4861) constants: */ - -/* Router constants: */ - -#define MAX_INITIAL_RTR_ADVERT_INTERVAL 16 -#define MAX_INITIAL_RTR_ADVERTISEMENTS 3 -#define MAX_FINAL_RTR_ADVERTISEMENTS 3 -#define MIN_DELAY_BETWEEN_RAS 3.0 -#define MIN_DELAY_BETWEEN_RAS_MIPv6 (30.0/1000.0) -#define MAX_RA_DELAY_TIME (1000.0/2.0) /* milliseconds */ - -/* Host constants: */ - -#define MAX_RTR_SOLICITATION_DELAY 1 -#define RTR_SOLICITATION_INTERVAL 4 -#define MAX_RTR_SOLICITATIONS 3 - -/* Node constants: */ - -#define MAX_MULTICAST_SOLICIT 3 -#define MAX_UNICAST_SOLICIT 3 -#define MAX_ANYCAST_DELAY_TIME 1 -#define MAX_NEIGHBOR_ADVERTISEMENT 3 -#define REACHABLE_TIME 30000 /* milliseconds */ -#define RETRANS_TIMER 1000 /* milliseconds */ -#define DELAY_FIRST_PROBE_TIME 5 -#define MIN_RANDOM_FACTOR (1.0/2.0) -#define MAX_RANDOM_FACTOR (3.0/2.0) - -/* MAX and MIN (RFC4861), Mobile IPv6 extensions will override if in use */ - -#define MIN_MaxRtrAdvInterval 4 -#define MAX_MaxRtrAdvInterval 1800 - -#define MIN_MinRtrAdvInterval 3 -#define MAX_MinRtrAdvInterval(iface) (0.75 * (iface)->MaxRtrAdvInterval) - -#define MIN_AdvDefaultLifetime(iface) (MAX2(1,(iface)->MaxRtrAdvInterval)) -#define MAX_AdvDefaultLifetime 9000 - -#define MIN_AdvLinkMTU 1280 -#define MAX_AdvLinkMTU 131072 - -#define MIN_AdvReachableTime 100 -#define MAX_AdvReachableTime 3600000 /* 1 hour in milliseconds */ - -#define MIN_AdvRetransTimer 10 -#define MAX_AdvRetransTimer 3600000 - -#define MIN_AdvCurHopLimit 2 -#define MAX_AdvCurHopLimit 255 - -#define MAX_PrefixLen 128 - -/* SLAAC (RFC4862) Constants and Derived Values */ -#define MIN_AdvValidLifetime 7203 /* slight >2 hours in secs */ - -/* - * Mobile IPv6 extensions, off by default - */ - -#define DFLT_AdvRouterAddr 0 -#define DFLT_AdvHomeAgentFlag 0 -#define DFLT_AdvIntervalOpt 0 -#define DFLT_AdvHomeAgentInfo 0 - -/* Option types (defined also at least in glibc 2.2's netinet/icmp6.h) */ - -#ifndef ND_OPT_RTR_ADV_INTERVAL -#define ND_OPT_RTR_ADV_INTERVAL 7 -#endif -#ifndef ND_OPT_HOME_AGENT_INFO -#define ND_OPT_HOME_AGENT_INFO 8 -#endif - -/* de-facto codepoint used by many implementations was '9', - the official IANA assignment is '24' */ -#undef ND_OPT_ROUTE_INFORMATION -#define ND_OPT_ROUTE_INFORMATION 24 - -/* XXX: some libc's like KAME already had nd_opt_route_info! */ -struct nd_opt_route_info_local /* route information */ - { - uint8_t nd_opt_ri_type; - uint8_t nd_opt_ri_len; - uint8_t nd_opt_ri_prefix_len; - uint8_t nd_opt_ri_flags_reserved; - uint32_t nd_opt_ri_lifetime; - struct in6_addr nd_opt_ri_prefix; - }; - -/* the reserved field is 8 bits and we're interested of the middle two: 000xx000 */ -#define ND_OPT_RI_PRF_SHIFT 3 -#define ND_OPT_RI_PRF_MASK (3 << ND_OPT_RI_PRF_SHIFT) /* 00011000 = 0x18 */ - -#undef ND_OPT_RDNSS_INFORMATION -#define ND_OPT_RDNSS_INFORMATION 25 - -/* */ -struct nd_opt_rdnss_info_local -{ - uint8_t nd_opt_rdnssi_type; - uint8_t nd_opt_rdnssi_len; - uint16_t nd_opt_rdnssi_pref_flag_reserved; - uint32_t nd_opt_rdnssi_lifetime; - struct in6_addr nd_opt_rdnssi_addr1; - struct in6_addr nd_opt_rdnssi_addr2; - struct in6_addr nd_opt_rdnssi_addr3; -}; -/* pref/flag/reserved field : yyyyx00000000000 (big endian) - 00000000yyyyx000 (little indian); where yyyy = pref, x = flag */ -#if BYTE_ORDER == BIG_ENDIAN -#define ND_OPT_RDNSSI_PREF_SHIFT 12 -#else -#define ND_OPT_RDNSSI_PREF_SHIFT 4 -#endif -#define ND_OPT_RDNSSI_PREF_MASK (0xf << ND_OPT_RDNSSI_PREF_SHIFT) - -#undef ND_OPT_DNSSL_INFORMATION -#define ND_OPT_DNSSL_INFORMATION 31 - -/* */ -struct nd_opt_dnssl_info_local -{ - uint8_t nd_opt_dnssli_type; - uint8_t nd_opt_dnssli_len; - uint16_t nd_opt_dnssli_reserved; - uint32_t nd_opt_dnssli_lifetime; - char nd_opt_dnssli_suffixes[]; -}; - -/* Flags */ - -#ifndef ND_RA_FLAG_HOME_AGENT -#define ND_RA_FLAG_HOME_AGENT 0x20 -#endif -#ifndef ND_OPT_PI_FLAG_RADDR -#define ND_OPT_PI_FLAG_RADDR 0x20 -#endif -#ifndef ND_OPT_RDNSSI_FLAG_S -#if BYTE_ORDER == BIG_ENDIAN -#define ND_OPT_RDNSSI_FLAG_S 0x0800 -#else -#define ND_OPT_RDNSSI_FLAG_S 0x0008 -#endif -#endif - -/* Configurable values */ - -#define DFLT_HomeAgentPreference 0 -#define DFLT_HomeAgentLifetime(iface) ((iface)->AdvDefaultLifetime) - -/* Other */ - -#define MIN_MinRtrAdvInterval_MIPv6 (3.0/100.0) -#define MIN_MaxRtrAdvInterval_MIPv6 (7.0/100.0) -#define RTR_SOLICITATION_INTERVAL_MIPv6 1 /* Recommended value by MIPv6 */ - -#define Cautious_MaxRtrAdvInterval (2.0/10.0) -#define Cautious_MaxRtrAdvInterval_Leeway (2.0/100.0) - -#define MIN_HomeAgentLifetime 1 /* 0 must NOT be used */ -#define MAX_HomeAgentLifetime 65520 /* 18.2 hours in secs */ - -/* #define MAX_RTR_SOLICITATIONS This MAY be ignored by MIPv6 */ - -/* NEMO extensions, off by default */ -#define DFLT_AdvMobRtrSupportFlag 0 - -/* Flags */ - -#ifndef ND_OPT_HAI_FLAG_SUPPORT_MR -#if BYTE_ORDER == BIG_ENDIAN -#define ND_OPT_HAI_FLAG_SUPPORT_MR 0x8000 -#else /* BYTE_ORDER == LITTLE_ENDIAN */ -#define ND_OPT_HAI_FLAG_SUPPORT_MR 0x0080 -#endif -#endif - -#endif diff --git a/release/src/router/radvd/depcomp b/release/src/router/radvd/depcomp deleted file mode 100755 index df8eea7e4c..0000000000 --- a/release/src/router/radvd/depcomp +++ /dev/null @@ -1,630 +0,0 @@ -#! /bin/sh -# depcomp - compile a program generating dependencies as side-effects - -scriptversion=2009-04-28.21; # UTC - -# Copyright (C) 1999, 2000, 2003, 2004, 2005, 2006, 2007, 2009 Free -# Software Foundation, Inc. - -# 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; either version 2, or (at your option) -# any later version. - -# 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 . - -# As a special exception to the GNU General Public License, if you -# distribute this file as part of a program that contains a -# configuration script generated by Autoconf, you may include it under -# the same distribution terms that you use for the rest of that program. - -# Originally written by Alexandre Oliva . - -case $1 in - '') - echo "$0: No command. Try \`$0 --help' for more information." 1>&2 - exit 1; - ;; - -h | --h*) - cat <<\EOF -Usage: depcomp [--help] [--version] PROGRAM [ARGS] - -Run PROGRAMS ARGS to compile a file, generating dependencies -as side-effects. - -Environment variables: - depmode Dependency tracking mode. - source Source file read by `PROGRAMS ARGS'. - object Object file output by `PROGRAMS ARGS'. - DEPDIR directory where to store dependencies. - depfile Dependency file to output. - tmpdepfile Temporary file to use when outputing dependencies. - libtool Whether libtool is used (yes/no). - -Report bugs to . -EOF - exit $? - ;; - -v | --v*) - echo "depcomp $scriptversion" - exit $? - ;; -esac - -if test -z "$depmode" || test -z "$source" || test -z "$object"; then - echo "depcomp: Variables source, object and depmode must be set" 1>&2 - exit 1 -fi - -# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. -depfile=${depfile-`echo "$object" | - sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} -tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} - -rm -f "$tmpdepfile" - -# Some modes work just like other modes, but use different flags. We -# parameterize here, but still list the modes in the big case below, -# to make depend.m4 easier to write. Note that we *cannot* use a case -# here, because this file can only contain one case statement. -if test "$depmode" = hp; then - # HP compiler uses -M and no extra arg. - gccflag=-M - depmode=gcc -fi - -if test "$depmode" = dashXmstdout; then - # This is just like dashmstdout with a different argument. - dashmflag=-xM - depmode=dashmstdout -fi - -cygpath_u="cygpath -u -f -" -if test "$depmode" = msvcmsys; then - # This is just like msvisualcpp but w/o cygpath translation. - # Just convert the backslash-escaped backslashes to single forward - # slashes to satisfy depend.m4 - cygpath_u="sed s,\\\\\\\\,/,g" - depmode=msvisualcpp -fi - -case "$depmode" in -gcc3) -## gcc 3 implements dependency tracking that does exactly what -## we want. Yay! Note: for some reason libtool 1.4 doesn't like -## it if -MD -MP comes after the -MF stuff. Hmm. -## Unfortunately, FreeBSD c89 acceptance of flags depends upon -## the command line argument order; so add the flags where they -## appear in depend2.am. Note that the slowdown incurred here -## affects only configure: in makefiles, %FASTDEP% shortcuts this. - for arg - do - case $arg in - -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; - *) set fnord "$@" "$arg" ;; - esac - shift # fnord - shift # $arg - done - "$@" - stat=$? - if test $stat -eq 0; then : - else - rm -f "$tmpdepfile" - exit $stat - fi - mv "$tmpdepfile" "$depfile" - ;; - -gcc) -## There are various ways to get dependency output from gcc. Here's -## why we pick this rather obscure method: -## - Don't want to use -MD because we'd like the dependencies to end -## up in a subdir. Having to rename by hand is ugly. -## (We might end up doing this anyway to support other compilers.) -## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like -## -MM, not -M (despite what the docs say). -## - Using -M directly means running the compiler twice (even worse -## than renaming). - if test -z "$gccflag"; then - gccflag=-MD, - fi - "$@" -Wp,"$gccflag$tmpdepfile" - stat=$? - if test $stat -eq 0; then : - else - rm -f "$tmpdepfile" - exit $stat - fi - rm -f "$depfile" - echo "$object : \\" > "$depfile" - alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz -## The second -e expression handles DOS-style file names with drive letters. - sed -e 's/^[^:]*: / /' \ - -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" -## This next piece of magic avoids the `deleted header file' problem. -## The problem is that when a header file which appears in a .P file -## is deleted, the dependency causes make to die (because there is -## typically no way to rebuild the header). We avoid this by adding -## dummy dependencies for each header file. Too bad gcc doesn't do -## this for us directly. - tr ' ' ' -' < "$tmpdepfile" | -## Some versions of gcc put a space before the `:'. On the theory -## that the space means something, we add a space to the output as -## well. -## Some versions of the HPUX 10.20 sed can't process this invocation -## correctly. Breaking it into two sed invocations is a workaround. - sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" - rm -f "$tmpdepfile" - ;; - -hp) - # This case exists only to let depend.m4 do its work. It works by - # looking at the text of this script. This case will never be run, - # since it is checked for above. - exit 1 - ;; - -sgi) - if test "$libtool" = yes; then - "$@" "-Wp,-MDupdate,$tmpdepfile" - else - "$@" -MDupdate "$tmpdepfile" - fi - stat=$? - if test $stat -eq 0; then : - else - rm -f "$tmpdepfile" - exit $stat - fi - rm -f "$depfile" - - if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files - echo "$object : \\" > "$depfile" - - # Clip off the initial element (the dependent). Don't try to be - # clever and replace this with sed code, as IRIX sed won't handle - # lines with more than a fixed number of characters (4096 in - # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; - # the IRIX cc adds comments like `#:fec' to the end of the - # dependency line. - tr ' ' ' -' < "$tmpdepfile" \ - | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \ - tr ' -' ' ' >> "$depfile" - echo >> "$depfile" - - # The second pass generates a dummy entry for each header file. - tr ' ' ' -' < "$tmpdepfile" \ - | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ - >> "$depfile" - else - # The sourcefile does not contain any dependencies, so just - # store a dummy comment line, to avoid errors with the Makefile - # "include basename.Plo" scheme. - echo "#dummy" > "$depfile" - fi - rm -f "$tmpdepfile" - ;; - -aix) - # The C for AIX Compiler uses -M and outputs the dependencies - # in a .u file. In older versions, this file always lives in the - # current directory. Also, the AIX compiler puts `$object:' at the - # start of each line; $object doesn't have directory information. - # Version 6 uses the directory in both cases. - dir=`echo "$object" | sed -e 's|/[^/]*$|/|'` - test "x$dir" = "x$object" && dir= - base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'` - if test "$libtool" = yes; then - tmpdepfile1=$dir$base.u - tmpdepfile2=$base.u - tmpdepfile3=$dir.libs/$base.u - "$@" -Wc,-M - else - tmpdepfile1=$dir$base.u - tmpdepfile2=$dir$base.u - tmpdepfile3=$dir$base.u - "$@" -M - fi - stat=$? - - if test $stat -eq 0; then : - else - rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" - exit $stat - fi - - for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" - do - test -f "$tmpdepfile" && break - done - if test -f "$tmpdepfile"; then - # Each line is of the form `foo.o: dependent.h'. - # Do two passes, one to just change these to - # `$object: dependent.h' and one to simply `dependent.h:'. - sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile" - # That's a tab and a space in the []. - sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile" - else - # The sourcefile does not contain any dependencies, so just - # store a dummy comment line, to avoid errors with the Makefile - # "include basename.Plo" scheme. - echo "#dummy" > "$depfile" - fi - rm -f "$tmpdepfile" - ;; - -icc) - # Intel's C compiler understands `-MD -MF file'. However on - # icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c - # ICC 7.0 will fill foo.d with something like - # foo.o: sub/foo.c - # foo.o: sub/foo.h - # which is wrong. We want: - # sub/foo.o: sub/foo.c - # sub/foo.o: sub/foo.h - # sub/foo.c: - # sub/foo.h: - # ICC 7.1 will output - # foo.o: sub/foo.c sub/foo.h - # and will wrap long lines using \ : - # foo.o: sub/foo.c ... \ - # sub/foo.h ... \ - # ... - - "$@" -MD -MF "$tmpdepfile" - stat=$? - if test $stat -eq 0; then : - else - rm -f "$tmpdepfile" - exit $stat - fi - rm -f "$depfile" - # Each line is of the form `foo.o: dependent.h', - # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. - # Do two passes, one to just change these to - # `$object: dependent.h' and one to simply `dependent.h:'. - sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" - # Some versions of the HPUX 10.20 sed can't process this invocation - # correctly. Breaking it into two sed invocations is a workaround. - sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" | - sed -e 's/$/ :/' >> "$depfile" - rm -f "$tmpdepfile" - ;; - -hp2) - # The "hp" stanza above does not work with aCC (C++) and HP's ia64 - # compilers, which have integrated preprocessors. The correct option - # to use with these is +Maked; it writes dependencies to a file named - # 'foo.d', which lands next to the object file, wherever that - # happens to be. - # Much of this is similar to the tru64 case; see comments there. - dir=`echo "$object" | sed -e 's|/[^/]*$|/|'` - test "x$dir" = "x$object" && dir= - base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'` - if test "$libtool" = yes; then - tmpdepfile1=$dir$base.d - tmpdepfile2=$dir.libs/$base.d - "$@" -Wc,+Maked - else - tmpdepfile1=$dir$base.d - tmpdepfile2=$dir$base.d - "$@" +Maked - fi - stat=$? - if test $stat -eq 0; then : - else - rm -f "$tmpdepfile1" "$tmpdepfile2" - exit $stat - fi - - for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" - do - test -f "$tmpdepfile" && break - done - if test -f "$tmpdepfile"; then - sed -e "s,^.*\.[a-z]*:,$object:," "$tmpdepfile" > "$depfile" - # Add `dependent.h:' lines. - sed -ne '2,${ - s/^ *// - s/ \\*$// - s/$/:/ - p - }' "$tmpdepfile" >> "$depfile" - else - echo "#dummy" > "$depfile" - fi - rm -f "$tmpdepfile" "$tmpdepfile2" - ;; - -tru64) - # The Tru64 compiler uses -MD to generate dependencies as a side - # effect. `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'. - # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put - # dependencies in `foo.d' instead, so we check for that too. - # Subdirectories are respected. - dir=`echo "$object" | sed -e 's|/[^/]*$|/|'` - test "x$dir" = "x$object" && dir= - base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'` - - if test "$libtool" = yes; then - # With Tru64 cc, shared objects can also be used to make a - # static library. This mechanism is used in libtool 1.4 series to - # handle both shared and static libraries in a single compilation. - # With libtool 1.4, dependencies were output in $dir.libs/$base.lo.d. - # - # With libtool 1.5 this exception was removed, and libtool now - # generates 2 separate objects for the 2 libraries. These two - # compilations output dependencies in $dir.libs/$base.o.d and - # in $dir$base.o.d. We have to check for both files, because - # one of the two compilations can be disabled. We should prefer - # $dir$base.o.d over $dir.libs/$base.o.d because the latter is - # automatically cleaned when .libs/ is deleted, while ignoring - # the former would cause a distcleancheck panic. - tmpdepfile1=$dir.libs/$base.lo.d # libtool 1.4 - tmpdepfile2=$dir$base.o.d # libtool 1.5 - tmpdepfile3=$dir.libs/$base.o.d # libtool 1.5 - tmpdepfile4=$dir.libs/$base.d # Compaq CCC V6.2-504 - "$@" -Wc,-MD - else - tmpdepfile1=$dir$base.o.d - tmpdepfile2=$dir$base.d - tmpdepfile3=$dir$base.d - tmpdepfile4=$dir$base.d - "$@" -MD - fi - - stat=$? - if test $stat -eq 0; then : - else - rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4" - exit $stat - fi - - for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4" - do - test -f "$tmpdepfile" && break - done - if test -f "$tmpdepfile"; then - sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile" - # That's a tab and a space in the []. - sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile" - else - echo "#dummy" > "$depfile" - fi - rm -f "$tmpdepfile" - ;; - -#nosideeffect) - # This comment above is used by automake to tell side-effect - # dependency tracking mechanisms from slower ones. - -dashmstdout) - # Important note: in order to support this mode, a compiler *must* - # always write the preprocessed file to stdout, regardless of -o. - "$@" || exit $? - - # Remove the call to Libtool. - if test "$libtool" = yes; then - while test "X$1" != 'X--mode=compile'; do - shift - done - shift - fi - - # Remove `-o $object'. - IFS=" " - for arg - do - case $arg in - -o) - shift - ;; - $object) - shift - ;; - *) - set fnord "$@" "$arg" - shift # fnord - shift # $arg - ;; - esac - done - - test -z "$dashmflag" && dashmflag=-M - # Require at least two characters before searching for `:' - # in the target name. This is to cope with DOS-style filenames: - # a dependency such as `c:/foo/bar' could be seen as target `c' otherwise. - "$@" $dashmflag | - sed 's:^[ ]*[^: ][^:][^:]*\:[ ]*:'"$object"'\: :' > "$tmpdepfile" - rm -f "$depfile" - cat < "$tmpdepfile" > "$depfile" - tr ' ' ' -' < "$tmpdepfile" | \ -## Some versions of the HPUX 10.20 sed can't process this invocation -## correctly. Breaking it into two sed invocations is a workaround. - sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" - rm -f "$tmpdepfile" - ;; - -dashXmstdout) - # This case only exists to satisfy depend.m4. It is never actually - # run, as this mode is specially recognized in the preamble. - exit 1 - ;; - -makedepend) - "$@" || exit $? - # Remove any Libtool call - if test "$libtool" = yes; then - while test "X$1" != 'X--mode=compile'; do - shift - done - shift - fi - # X makedepend - shift - cleared=no eat=no - for arg - do - case $cleared in - no) - set ""; shift - cleared=yes ;; - esac - if test $eat = yes; then - eat=no - continue - fi - case "$arg" in - -D*|-I*) - set fnord "$@" "$arg"; shift ;; - # Strip any option that makedepend may not understand. Remove - # the object too, otherwise makedepend will parse it as a source file. - -arch) - eat=yes ;; - -*|$object) - ;; - *) - set fnord "$@" "$arg"; shift ;; - esac - done - obj_suffix=`echo "$object" | sed 's/^.*\././'` - touch "$tmpdepfile" - ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" - rm -f "$depfile" - cat < "$tmpdepfile" > "$depfile" - sed '1,2d' "$tmpdepfile" | tr ' ' ' -' | \ -## Some versions of the HPUX 10.20 sed can't process this invocation -## correctly. Breaking it into two sed invocations is a workaround. - sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" - rm -f "$tmpdepfile" "$tmpdepfile".bak - ;; - -cpp) - # Important note: in order to support this mode, a compiler *must* - # always write the preprocessed file to stdout. - "$@" || exit $? - - # Remove the call to Libtool. - if test "$libtool" = yes; then - while test "X$1" != 'X--mode=compile'; do - shift - done - shift - fi - - # Remove `-o $object'. - IFS=" " - for arg - do - case $arg in - -o) - shift - ;; - $object) - shift - ;; - *) - set fnord "$@" "$arg" - shift # fnord - shift # $arg - ;; - esac - done - - "$@" -E | - sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ - -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' | - sed '$ s: \\$::' > "$tmpdepfile" - rm -f "$depfile" - echo "$object : \\" > "$depfile" - cat < "$tmpdepfile" >> "$depfile" - sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" - rm -f "$tmpdepfile" - ;; - -msvisualcpp) - # Important note: in order to support this mode, a compiler *must* - # always write the preprocessed file to stdout. - "$@" || exit $? - - # Remove the call to Libtool. - if test "$libtool" = yes; then - while test "X$1" != 'X--mode=compile'; do - shift - done - shift - fi - - IFS=" " - for arg - do - case "$arg" in - -o) - shift - ;; - $object) - shift - ;; - "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") - set fnord "$@" - shift - shift - ;; - *) - set fnord "$@" "$arg" - shift - shift - ;; - esac - done - "$@" -E 2>/dev/null | - sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" - rm -f "$depfile" - echo "$object : \\" > "$depfile" - sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile" - echo " " >> "$depfile" - sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" - rm -f "$tmpdepfile" - ;; - -msvcmsys) - # This case exists only to let depend.m4 do its work. It works by - # looking at the text of this script. This case will never be run, - # since it is checked for above. - exit 1 - ;; - -none) - exec "$@" - ;; - -*) - echo "Unknown depmode $depmode" 1>&2 - exit 1 - ;; -esac - -exit 0 - -# Local Variables: -# mode: shell-script -# sh-indentation: 2 -# eval: (add-hook 'write-file-hooks 'time-stamp) -# time-stamp-start: "scriptversion=" -# time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-time-zone: "UTC" -# time-stamp-end: "; # UTC" -# End: diff --git a/release/src/router/radvd/device-bsd44.c b/release/src/router/radvd/device-bsd44.c deleted file mode 100644 index ac84bebf52..0000000000 --- a/release/src/router/radvd/device-bsd44.c +++ /dev/null @@ -1,231 +0,0 @@ -/* - * $Id: device-bsd44.c,v 1.29 2011/02/06 03:41:38 reubenhwk Exp $ - * - * Authors: - * Craig Metz - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" -#include "defaults.h" -#include "pathnames.h" /* for PATH_PROC_NET_IF_INET6 */ - -static uint8_t ll_prefix[] = { 0xfe, 0x80 }; - -/* - * this function gets the hardware type and address of an interface, - * determines the link layer token length and checks it against - * the defined prefixes - */ -int -setup_deviceinfo(struct Interface *iface) -{ - struct ifaddrs *addresses = 0, *ifa; - - struct ifreq ifr; - struct AdvPrefix *prefix; - char zero[sizeof(iface->if_addr)]; - - if(if_nametoindex(iface->Name) == 0){ - flog(LOG_ERR, "%s not found: %s", iface->Name, strerror(errno)); - goto ret; - } - - memset(&ifr, 0, sizeof(ifr)); - strncpy(ifr.ifr_name, iface->Name, IFNAMSIZ-1); - ifr.ifr_name[IFNAMSIZ-1] = '\0'; - - if (ioctl(sock, SIOCGIFMTU, &ifr) < 0) { - flog(LOG_ERR, "ioctl(SIOCGIFMTU) failed for %s: %s", iface->Name, strerror(errno)); - goto ret; - } - - dlog(LOG_DEBUG, 3, "mtu for %s is %d", iface->Name, ifr.ifr_mtu); - iface->if_maxmtu = ifr.ifr_mtu; - - if (getifaddrs(&addresses) != 0) - { - flog(LOG_ERR, "getifaddrs failed: %s(%d)", strerror(errno), errno); - goto ret; - } - - for (ifa = addresses; ifa != NULL; ifa = ifa->ifa_next) - { - if (strcmp(ifa->ifa_name, iface->Name) != 0) - continue; - - if (ifa->ifa_addr == NULL) - continue; - - if (ifa->ifa_addr->sa_family != AF_LINK) - continue; - - struct sockaddr_dl *dl = (struct sockaddr_dl*)ifa->ifa_addr; - - - if (dl->sdl_alen > sizeof(iface->if_addr)) - { - flog(LOG_ERR, "address length %d too big for", - dl->sdl_alen, - iface->Name); - goto ret; - } - - memcpy(iface->if_hwaddr, LLADDR(dl), dl->sdl_alen); - iface->if_hwaddr_len = dl->sdl_alen << 3; - - switch(dl->sdl_type) { - case IFT_ETHER: - case IFT_ISO88023: - iface->if_prefix_len = 64; - break; - case IFT_FDDI: - iface->if_prefix_len = 64; - break; - default: - iface->if_prefix_len = -1; - iface->if_maxmtu = -1; - break; - } - - dlog(LOG_DEBUG, 3, "link layer token length for %s is %d", iface->Name, - iface->if_hwaddr_len); - - dlog(LOG_DEBUG, 3, "prefix length for %s is %d", iface->Name, - iface->if_prefix_len); - - if (iface->if_prefix_len != -1) { - memset(zero, 0, dl->sdl_alen); - if (!memcmp(iface->if_hwaddr, zero, dl->sdl_alen)) - flog(LOG_WARNING, "WARNING, MAC address on %s is all zero!", - iface->Name); - } - - prefix = iface->AdvPrefixList; - while (prefix) - { - if ((iface->if_prefix_len != -1) && - (iface->if_prefix_len != prefix->PrefixLen)) - { - flog(LOG_WARNING, "prefix length should be %d for %s", - iface->if_prefix_len, iface->Name); - } - - prefix = prefix->next; - } - - freeifaddrs(addresses); - return 0; - } - - -ret: - iface->if_maxmtu = -1; - iface->if_hwaddr_len = -1; - iface->if_prefix_len = -1; - if (addresses != 0) - freeifaddrs(addresses); - return -1; -} - -/* - * Saves the first link local address seen on the specified interface to iface->if_addr - * - */ -int setup_linklocal_addr(struct Interface *iface) -{ - struct ifaddrs *addresses = 0, *ifa; - - if (getifaddrs(&addresses) != 0) - { - flog(LOG_ERR, "getifaddrs failed: %s(%d)", strerror(errno), errno); - goto ret; - } - - for (ifa = addresses; ifa != NULL; ifa = ifa->ifa_next) - { - if (strcmp(ifa->ifa_name, iface->Name) != 0) - continue; - - if (ifa->ifa_addr == NULL) - continue; - - if (ifa->ifa_addr->sa_family == AF_LINK) { - struct sockaddr_dl *dl = (struct sockaddr_dl*)ifa->ifa_addr; - if (memcmp(iface->Name, dl->sdl_data, dl->sdl_nlen) == 0) - iface->if_index = dl->sdl_index; - continue; - } - - if (ifa->ifa_addr->sa_family != AF_INET6) - continue; - - struct sockaddr_in6 *a6 = (struct sockaddr_in6*)ifa->ifa_addr; - - /* Skip if it is not a linklocal address */ - if (memcmp(&(a6->sin6_addr), ll_prefix, sizeof(ll_prefix)) != 0) - continue; - - memcpy(&iface->if_addr, &(a6->sin6_addr), sizeof(struct in6_addr)); - freeifaddrs(addresses); - return 0; - } - -ret: - if(addresses) - freeifaddrs(addresses); - flog(LOG_ERR, "no linklocal address configured for %s", iface->Name); - return -1; -} - -int setup_allrouters_membership(struct Interface *iface) -{ - return (0); -} - -int check_allrouters_membership(struct Interface *iface) -{ - return (0); -} - -int -set_interface_linkmtu(const char *iface, uint32_t mtu) -{ - dlog(LOG_DEBUG, 4, "setting LinkMTU (%u) for %s is not supported", - mtu, iface); - return -1; -} - -int -set_interface_curhlim(const char *iface, uint8_t hlim) -{ - dlog(LOG_DEBUG, 4, "setting CurHopLimit (%u) for %s is not supported", - hlim, iface); - return -1; -} - -int -set_interface_reachtime(const char *iface, uint32_t rtime) -{ - dlog(LOG_DEBUG, 4, "setting BaseReachableTime (%u) for %s is not supported", - rtime, iface); - return -1; -} - -int -set_interface_retranstimer(const char *iface, uint32_t rettimer) -{ - dlog(LOG_DEBUG, 4, "setting RetransTimer (%u) for %s is not supported", - rettimer, iface); - return -1; -} - diff --git a/release/src/router/radvd/device-common.c b/release/src/router/radvd/device-common.c deleted file mode 100644 index 1a52200cae..0000000000 --- a/release/src/router/radvd/device-common.c +++ /dev/null @@ -1,104 +0,0 @@ -/* - * $Id: device-common.c,v 1.12 2011/02/06 03:41:38 reubenhwk Exp $ - * - * Authors: - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" -#include "defaults.h" - -int -check_device(struct Interface *iface) -{ - struct ifreq ifr; - - strncpy(ifr.ifr_name, iface->Name, IFNAMSIZ-1); - ifr.ifr_name[IFNAMSIZ-1] = '\0'; - - if (ioctl(sock, SIOCGIFFLAGS, &ifr) < 0) - { - if (!iface->IgnoreIfMissing) - flog(LOG_ERR, "ioctl(SIOCGIFFLAGS) failed for %s: %s", - iface->Name, strerror(errno)); - return (-1); - } - - if (!(ifr.ifr_flags & IFF_UP)) - { - if (!iface->IgnoreIfMissing) - flog(LOG_ERR, "interface %s is not UP", iface->Name); - return (-1); - } - if (!(ifr.ifr_flags & IFF_RUNNING)) - { - if (!iface->IgnoreIfMissing) - flog(LOG_ERR, "interface %s is not RUNNING", iface->Name); - return (-1); - } - - if (! iface->UnicastOnly && !(ifr.ifr_flags & IFF_MULTICAST)) - { - flog(LOG_WARNING, "interface %s does not support multicast", - iface->Name); - flog(LOG_WARNING, " do you need to add the UnicastOnly flag?"); - } - - if (! iface->UnicastOnly && !(ifr.ifr_flags & IFF_BROADCAST)) - { - flog(LOG_WARNING, "interface %s does not support broadcast", - iface->Name); - flog(LOG_WARNING, " do you need to add the UnicastOnly flag?"); - } - - return 0; -} - -int -get_v4addr(const char *ifn, unsigned int *dst) -{ - struct ifreq ifr; - struct sockaddr_in *addr; - int fd; - - if( ( fd = socket(AF_INET,SOCK_DGRAM,0) ) < 0 ) - { - flog(LOG_ERR, "create socket for IPv4 ioctl failed for %s: %s", - ifn, strerror(errno)); - return (-1); - } - - memset(&ifr, 0, sizeof(ifr)); - strncpy(ifr.ifr_name, ifn, IFNAMSIZ-1); - ifr.ifr_name[IFNAMSIZ-1] = '\0'; - ifr.ifr_addr.sa_family = AF_INET; - - if (ioctl(fd, SIOCGIFADDR, &ifr) < 0) - { - flog(LOG_ERR, "ioctl(SIOCGIFADDR) failed for %s: %s", - ifn, strerror(errno)); - close( fd ); - return (-1); - } - - addr = (struct sockaddr_in *)(&ifr.ifr_addr); - - dlog(LOG_DEBUG, 3, "IPv4 address for %s is %s", ifn, - inet_ntoa( addr->sin_addr ) ); - - *dst = addr->sin_addr.s_addr; - - close( fd ); - - return 0; -} diff --git a/release/src/router/radvd/device-linux.c b/release/src/router/radvd/device-linux.c deleted file mode 100644 index 3bb0beb665..0000000000 --- a/release/src/router/radvd/device-linux.c +++ /dev/null @@ -1,323 +0,0 @@ -/* - * $Id: device-linux.c,v 1.28 2011/02/06 03:41:38 reubenhwk Exp $ - * - * Authors: - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" -#include "defaults.h" -#include "pathnames.h" /* for PATH_PROC_NET_IF_INET6 */ - -#ifndef IPV6_ADDR_LINKLOCAL -#define IPV6_ADDR_LINKLOCAL 0x0020U -#endif - -/* - * this function gets the hardware type and address of an interface, - * determines the link layer token length and checks it against - * the defined prefixes - */ -int -setup_deviceinfo(struct Interface *iface) -{ - struct ifreq ifr; - struct AdvPrefix *prefix; - char zero[sizeof(iface->if_addr)]; - - strncpy(ifr.ifr_name, iface->Name, IFNAMSIZ-1); - ifr.ifr_name[IFNAMSIZ-1] = '\0'; - - if (ioctl(sock, SIOCGIFMTU, &ifr) < 0) { - flog(LOG_ERR, "ioctl(SIOCGIFMTU) failed for %s: %s", - iface->Name, strerror(errno)); - return (-1); - } - - dlog(LOG_DEBUG, 3, "mtu for %s is %d", iface->Name, ifr.ifr_mtu); - iface->if_maxmtu = ifr.ifr_mtu; - - if (ioctl(sock, SIOCGIFHWADDR, &ifr) < 0) - { - flog(LOG_ERR, "ioctl(SIOCGIFHWADDR) failed for %s: %s", - iface->Name, strerror(errno)); - return (-1); - } - - dlog(LOG_DEBUG, 3, "hardware type for %s is %d", iface->Name, - ifr.ifr_hwaddr.sa_family); - - switch(ifr.ifr_hwaddr.sa_family) - { - case ARPHRD_ETHER: - iface->if_hwaddr_len = 48; - iface->if_prefix_len = 64; - break; -#ifdef ARPHRD_FDDI - case ARPHRD_FDDI: - iface->if_hwaddr_len = 48; - iface->if_prefix_len = 64; - break; -#endif /* ARPHDR_FDDI */ -#ifdef ARPHRD_ARCNET - case ARPHRD_ARCNET: - iface->if_hwaddr_len = 8; - iface->if_prefix_len = -1; - iface->if_maxmtu = -1; - break; -#endif /* ARPHDR_ARCNET */ - default: - iface->if_hwaddr_len = -1; - iface->if_prefix_len = -1; - iface->if_maxmtu = -1; - break; - } - - dlog(LOG_DEBUG, 3, "link layer token length for %s is %d", iface->Name, - iface->if_hwaddr_len); - - dlog(LOG_DEBUG, 3, "prefix length for %s is %d", iface->Name, - iface->if_prefix_len); - - if (iface->if_hwaddr_len != -1) { - unsigned int if_hwaddr_len_bytes = (iface->if_hwaddr_len + 7) >> 3; - - if (if_hwaddr_len_bytes > sizeof(iface->if_hwaddr)) { - flog(LOG_ERR, "address length %d too big for %s", if_hwaddr_len_bytes, iface->Name); - return(-2); - } - memcpy(iface->if_hwaddr, ifr.ifr_hwaddr.sa_data, if_hwaddr_len_bytes); - - memset(zero, 0, sizeof(zero)); - if (!memcmp(iface->if_hwaddr, zero, if_hwaddr_len_bytes)) - flog(LOG_WARNING, "WARNING, MAC address on %s is all zero!", - iface->Name); - } - - prefix = iface->AdvPrefixList; - while (prefix) - { - if ((iface->if_prefix_len != -1) && - (iface->if_prefix_len != prefix->PrefixLen)) - { - flog(LOG_WARNING, "prefix length should be %d for %s", - iface->if_prefix_len, iface->Name); - } - - prefix = prefix->next; - } - - return (0); -} - -/* - * this function extracts the link local address and interface index - * from PATH_PROC_NET_IF_INET6. Note: 'sock' unused in Linux. - */ -int setup_linklocal_addr(struct Interface *iface) -{ - FILE *fp; - char str_addr[40]; - unsigned int plen, scope, dad_status, if_idx; - char devname[IFNAMSIZ]; - - if ((fp = fopen(PATH_PROC_NET_IF_INET6, "r")) == NULL) - { - flog(LOG_ERR, "can't open %s: %s", PATH_PROC_NET_IF_INET6, - strerror(errno)); - return (-1); - } - - while (fscanf(fp, "%32s %x %02x %02x %02x %15s\n", - str_addr, &if_idx, &plen, &scope, &dad_status, - devname) != EOF) - { - if (scope == IPV6_ADDR_LINKLOCAL && - strcmp(devname, iface->Name) == 0) - { - struct in6_addr addr; - unsigned int ap; - int i; - - for (i=0; i<16; i++) - { - sscanf(str_addr + i * 2, "%02x", &ap); - addr.s6_addr[i] = (unsigned char)ap; - } - memcpy(&iface->if_addr, &addr, sizeof(iface->if_addr)); - - iface->if_index = if_idx; - fclose(fp); - return 0; - } - } - - flog(LOG_ERR, "no linklocal address configured for %s", iface->Name); - fclose(fp); - return (-1); -} - -int setup_allrouters_membership(struct Interface *iface) -{ - struct ipv6_mreq mreq; - - memset(&mreq, 0, sizeof(mreq)); - mreq.ipv6mr_interface = iface->if_index; - - /* ipv6-allrouters: ff02::2 */ - mreq.ipv6mr_multiaddr.s6_addr32[0] = htonl(0xFF020000); - mreq.ipv6mr_multiaddr.s6_addr32[3] = htonl(0x2); - - if (setsockopt(sock, SOL_IPV6, IPV6_ADD_MEMBERSHIP, &mreq, sizeof(mreq)) < 0) - { - /* linux-2.6.12-bk4 returns error with HUP signal but keep listening */ - if (errno != EADDRINUSE) - { - flog(LOG_ERR, "can't join ipv6-allrouters on %s", iface->Name); - return (-1); - } - } - - return (0); -} - -int check_allrouters_membership(struct Interface *iface) -{ - #define ALL_ROUTERS_MCAST "ff020000000000000000000000000002" - - FILE *fp; - unsigned int if_idx, allrouters_ok=0; - char addr[32+1]; - char buffer[301] = {""}, *str; - int ret=0; - - if ((fp = fopen(PATH_PROC_NET_IGMP6, "r")) == NULL) - { - flog(LOG_ERR, "can't open %s: %s", PATH_PROC_NET_IGMP6, - strerror(errno)); - return (-1); - } - - str = fgets(buffer, 300, fp); - - while (str && (ret = sscanf(str, "%u %*s %32[0-9A-Fa-f]", &if_idx, addr)) ) { - if (ret == 2) { - if (iface->if_index == if_idx) { - if (strncmp(addr, ALL_ROUTERS_MCAST, sizeof(addr)) == 0){ - allrouters_ok = 1; - break; - } - } - } - str = fgets(buffer, 300, fp); - } - - fclose(fp); - - if (!allrouters_ok) { - flog(LOG_WARNING, "resetting ipv6-allrouters membership on %s", iface->Name); - setup_allrouters_membership(iface); - } - - return(0); -} - -/* note: also called from the root context */ -int -set_interface_var(const char *iface, - const char *var, const char *name, - uint32_t val) -{ - FILE *fp; - char spath[64+IFNAMSIZ]; /* XXX: magic constant */ - if (snprintf(spath, sizeof(spath), var, iface) >= sizeof(spath)) - return -1; - - if (access(spath, F_OK) != 0) - return -1; - - fp = fopen(spath, "w"); - if (!fp) { - if (name) - flog(LOG_ERR, "failed to set %s (%u) for %s: %s", - name, val, iface, strerror(errno)); - return -1; - } - fprintf(fp, "%u", val); - fclose(fp); - - return 0; -} - -int -set_interface_linkmtu(const char *iface, uint32_t mtu) -{ - if (privsep_enabled()) - return privsep_interface_linkmtu(iface, mtu); - - return set_interface_var(iface, - PROC_SYS_IP6_LINKMTU, "LinkMTU", - mtu); -} - -int -set_interface_curhlim(const char *iface, uint8_t hlim) -{ - if (privsep_enabled()) - return privsep_interface_curhlim(iface, hlim); - - return set_interface_var(iface, - PROC_SYS_IP6_CURHLIM, "CurHopLimit", - hlim); -} - -int -set_interface_reachtime(const char *iface, uint32_t rtime) -{ - int ret; - - if (privsep_enabled()) - return privsep_interface_reachtime(iface, rtime); - - ret = set_interface_var(iface, - PROC_SYS_IP6_BASEREACHTIME_MS, - NULL, - rtime); - if (ret) - ret = set_interface_var(iface, - PROC_SYS_IP6_BASEREACHTIME, - "BaseReachableTimer", - rtime / 1000); /* sec */ - return ret; -} - -int -set_interface_retranstimer(const char *iface, uint32_t rettimer) -{ - int ret; - - if (privsep_enabled()) - return privsep_interface_retranstimer(iface, rettimer); - - ret = set_interface_var(iface, - PROC_SYS_IP6_RETRANSTIMER_MS, - NULL, - rettimer); - if (ret) - ret = set_interface_var(iface, - PROC_SYS_IP6_RETRANSTIMER, - "RetransTimer", - rettimer / 1000 * USER_HZ); /* XXX user_hz */ - return ret; -} - diff --git a/release/src/router/radvd/gram.y b/release/src/router/radvd/gram.y deleted file mode 100644 index 77e27b3ba7..0000000000 --- a/release/src/router/radvd/gram.y +++ /dev/null @@ -1,986 +0,0 @@ -/* - * $Id: gram.y,v 1.39.2.1 2011/08/22 12:30:47 reubenhwk Exp $ - * - * Authors: - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996-2000 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ -%{ -#include "config.h" -#include "includes.h" -#include "radvd.h" -#include "defaults.h" - -extern struct Interface *IfaceList; -struct Interface *iface = NULL; -struct AdvPrefix *prefix = NULL; -struct AdvRoute *route = NULL; -struct AdvRDNSS *rdnss = NULL; -struct AdvDNSSL *dnssl = NULL; - -extern char *conf_file; -extern int num_lines; -extern char *yytext; - -static void cleanup(void); -static void yyerror(char *msg); -static int countbits(int b); -static int count_mask(struct sockaddr_in6 *m); -static struct in6_addr get_prefix6(struct in6_addr const *addr, struct in6_addr const *mask); - -#if 0 /* no longer necessary? */ -#ifndef HAVE_IN6_ADDR_S6_ADDR -# ifdef __FreeBSD__ -# define s6_addr32 __u6_addr.__u6_addr32 -# define s6_addr16 __u6_addr.__u6_addr16 -# endif -#endif -#endif - -#define ABORT do { cleanup(); YYABORT; } while (0); -#define ADD_TO_LL(type, list, value) \ - do { \ - if (iface->list == NULL) \ - iface->list = value; \ - else { \ - type *current = iface->list; \ - while (current->next != NULL) \ - current = current->next; \ - current->next = value; \ - } \ - } while (0) - - -%} - -%token T_INTERFACE -%token T_PREFIX -%token T_ROUTE -%token T_RDNSS -%token T_DNSSL -%token T_CLIENTS - -%token STRING -%token NUMBER -%token SIGNEDNUMBER -%token DECIMAL -%token SWITCH -%token IPV6ADDR -%token INFINITY - -%token T_IgnoreIfMissing -%token T_AdvSendAdvert -%token T_MaxRtrAdvInterval -%token T_MinRtrAdvInterval -%token T_MinDelayBetweenRAs -%token T_AdvManagedFlag -%token T_AdvOtherConfigFlag -%token T_AdvLinkMTU -%token T_AdvReachableTime -%token T_AdvRetransTimer -%token T_AdvCurHopLimit -%token T_AdvDefaultLifetime -%token T_AdvDefaultPreference -%token T_AdvSourceLLAddress - -%token T_AdvOnLink -%token T_AdvAutonomous -%token T_AdvValidLifetime -%token T_AdvPreferredLifetime -%token T_DeprecatePrefix -%token T_DecrementLifetimes - -%token T_AdvRouterAddr -%token T_AdvHomeAgentFlag -%token T_AdvIntervalOpt -%token T_AdvHomeAgentInfo - -%token T_Base6Interface -%token T_Base6to4Interface -%token T_UnicastOnly - -%token T_HomeAgentPreference -%token T_HomeAgentLifetime - -%token T_AdvRoutePreference -%token T_AdvRouteLifetime -%token T_RemoveRoute - -%token T_AdvRDNSSPreference -%token T_AdvRDNSSOpenFlag -%token T_AdvRDNSSLifetime -%token T_FlushRDNSS - -%token T_AdvDNSSLLifetime -%token T_FlushDNSSL - -%token T_AdvMobRtrSupportFlag - -%token T_BAD_TOKEN - -%type name -%type prefixdef -%type clientslist v6addrlist -%type routedef -%type rdnssdef -%type dnssldef -%type number_or_infinity - -%union { - unsigned int num; - int snum; - double dec; - struct in6_addr *addr; - char *str; - struct AdvPrefix *pinfo; - struct AdvRoute *rinfo; - struct AdvRDNSS *rdnssinfo; - struct AdvDNSSL *dnsslinfo; - struct Clients *ainfo; -}; - -%% - -grammar : grammar ifacedef - | ifacedef - ; - -ifacedef : ifacehead '{' ifaceparams '}' ';' - { - struct Interface *iface2; - - iface2 = IfaceList; - while (iface2) - { - if (!strcmp(iface2->Name, iface->Name)) - { - flog(LOG_ERR, "duplicate interface " - "definition for %s", iface->Name); - ABORT; - } - iface2 = iface2->next; - } - - if (check_device(iface) < 0) { - if (iface->IgnoreIfMissing) { - dlog(LOG_DEBUG, 4, "interface %s did not exist, ignoring the interface", iface->Name); - } - else { - flog(LOG_ERR, "interface %s does not exist", iface->Name); - ABORT; - } - } - if (setup_deviceinfo(iface) < 0) - if (!iface->IgnoreIfMissing) - ABORT; - if (check_iface(iface) < 0) - if (!iface->IgnoreIfMissing) - ABORT; - if (setup_linklocal_addr(iface) < 0) - if (!iface->IgnoreIfMissing) - ABORT; - if (setup_allrouters_membership(iface) < 0) - if (!iface->IgnoreIfMissing) - ABORT; - - dlog(LOG_DEBUG, 4, "interface definition for %s is ok", iface->Name); - - iface->next = IfaceList; - IfaceList = iface; - - iface = NULL; - }; - -ifacehead : T_INTERFACE name - { - iface = malloc(sizeof(struct Interface)); - - if (iface == NULL) { - flog(LOG_CRIT, "malloc failed: %s", strerror(errno)); - ABORT; - } - - iface_init_defaults(iface); - strncpy(iface->Name, $2, IFNAMSIZ-1); - iface->Name[IFNAMSIZ-1] = '\0'; - } - ; - -name : STRING - { - /* check vality */ - $$ = $1; - } - ; - -ifaceparams : - /* empty */ - | ifaceparam ifaceparams - ; - -ifaceparam : ifaceval - | prefixdef { ADD_TO_LL(struct AdvPrefix, AdvPrefixList, $1); } - | clientslist { ADD_TO_LL(struct Clients, ClientList, $1); } - | routedef { ADD_TO_LL(struct AdvRoute, AdvRouteList, $1); } - | rdnssdef { ADD_TO_LL(struct AdvRDNSS, AdvRDNSSList, $1); } - | dnssldef { ADD_TO_LL(struct AdvDNSSL, AdvDNSSLList, $1); } - ; - -ifaceval : T_MinRtrAdvInterval NUMBER ';' - { - iface->MinRtrAdvInterval = $2; - } - | T_MaxRtrAdvInterval NUMBER ';' - { - iface->MaxRtrAdvInterval = $2; - } - | T_MinDelayBetweenRAs NUMBER ';' - { - iface->MinDelayBetweenRAs = $2; - } - | T_MinRtrAdvInterval DECIMAL ';' - { - iface->MinRtrAdvInterval = $2; - } - | T_MaxRtrAdvInterval DECIMAL ';' - { - iface->MaxRtrAdvInterval = $2; - } - | T_MinDelayBetweenRAs DECIMAL ';' - { - iface->MinDelayBetweenRAs = $2; - } - | T_IgnoreIfMissing SWITCH ';' - { - iface->IgnoreIfMissing = $2; - } - | T_AdvSendAdvert SWITCH ';' - { - iface->AdvSendAdvert = $2; - } - | T_AdvManagedFlag SWITCH ';' - { - iface->AdvManagedFlag = $2; - } - | T_AdvOtherConfigFlag SWITCH ';' - { - iface->AdvOtherConfigFlag = $2; - } - | T_AdvLinkMTU NUMBER ';' - { - iface->AdvLinkMTU = $2; - } - | T_AdvReachableTime NUMBER ';' - { - iface->AdvReachableTime = $2; - } - | T_AdvRetransTimer NUMBER ';' - { - iface->AdvRetransTimer = $2; - } - | T_AdvDefaultLifetime NUMBER ';' - { - iface->AdvDefaultLifetime = $2; - } - | T_AdvDefaultPreference SIGNEDNUMBER ';' - { - iface->AdvDefaultPreference = $2; - } - | T_AdvCurHopLimit NUMBER ';' - { - iface->AdvCurHopLimit = $2; - } - | T_AdvSourceLLAddress SWITCH ';' - { - iface->AdvSourceLLAddress = $2; - } - | T_AdvIntervalOpt SWITCH ';' - { - iface->AdvIntervalOpt = $2; - } - | T_AdvHomeAgentInfo SWITCH ';' - { - iface->AdvHomeAgentInfo = $2; - } - | T_AdvHomeAgentFlag SWITCH ';' - { - iface->AdvHomeAgentFlag = $2; - } - | T_HomeAgentPreference NUMBER ';' - { - iface->HomeAgentPreference = $2; - } - | T_HomeAgentLifetime NUMBER ';' - { - iface->HomeAgentLifetime = $2; - } - | T_UnicastOnly SWITCH ';' - { - iface->UnicastOnly = $2; - } - | T_AdvMobRtrSupportFlag SWITCH ';' - { - iface->AdvMobRtrSupportFlag = $2; - } - ; - -clientslist : T_CLIENTS '{' v6addrlist '}' ';' - { - $$ = $3; - } - ; - -v6addrlist : IPV6ADDR ';' - { - struct Clients *new = calloc(1, sizeof(struct Clients)); - if (new == NULL) { - flog(LOG_CRIT, "calloc failed: %s", strerror(errno)); - ABORT; - } - - memcpy(&(new->Address), $1, sizeof(struct in6_addr)); - $$ = new; - } - | v6addrlist IPV6ADDR ';' - { - struct Clients *new = calloc(1, sizeof(struct Clients)); - if (new == NULL) { - flog(LOG_CRIT, "calloc failed: %s", strerror(errno)); - ABORT; - } - - memcpy(&(new->Address), $2, sizeof(struct in6_addr)); - new->next = $1; - $$ = new; - } - ; - - -prefixdef : prefixhead optional_prefixplist ';' - { - if (prefix) { - unsigned int dst; - - if (prefix->AdvPreferredLifetime > prefix->AdvValidLifetime) - { - flog(LOG_ERR, "AdvValidLifeTime must be " - "greater than AdvPreferredLifetime in %s, line %d", - conf_file, num_lines); - ABORT; - } - - if ( prefix->if6[0] && prefix->if6to4[0]) { - flog(LOG_ERR, "Base6Interface and Base6to4Interface are mutually exclusive at this time."); - ABORT; - } - - if ( prefix->if6to4[0] ) - { - if (get_v4addr(prefix->if6to4, &dst) < 0) - { - flog(LOG_ERR, "interface %s has no IPv4 addresses, disabling 6to4 prefix", prefix->if6to4 ); - prefix->enabled = 0; - } - else - { - *((uint16_t *)(prefix->Prefix.s6_addr)) = htons(0x2002); - memcpy( prefix->Prefix.s6_addr + 2, &dst, sizeof( dst ) ); - } - } - - if ( prefix->if6[0] ) - { -#ifndef HAVE_IFADDRS_H - flog(LOG_ERR, "Base6Interface not supported in %s, line %d", conf_file, num_lines); - ABORT; -#else - struct ifaddrs *ifap = 0, *ifa = 0; - struct AdvPrefix *next = prefix->next; - - if (prefix->PrefixLen != 64) { - flog(LOG_ERR, "Only /64 is allowed with Base6Interface. %s:%d", conf_file, num_lines); - ABORT; - } - - if (getifaddrs(&ifap) != 0) - flog(LOG_ERR, "getifaddrs failed: %s", strerror(errno)); - - for (ifa = ifap; ifa; ifa = ifa->ifa_next) { - struct sockaddr_in6 *s6 = 0; - struct sockaddr_in6 *mask = (struct sockaddr_in6 *)ifa->ifa_netmask; - struct in6_addr base6prefix; - char buf[INET6_ADDRSTRLEN]; - int i; - - if (strncmp(ifa->ifa_name, prefix->if6, IFNAMSIZ)) - continue; - - if (ifa->ifa_addr->sa_family != AF_INET6) - continue; - - s6 = (struct sockaddr_in6 *)(ifa->ifa_addr); - - if (IN6_IS_ADDR_LINKLOCAL(&s6->sin6_addr)) - continue; - - base6prefix = get_prefix6(&s6->sin6_addr, &mask->sin6_addr); - for (i = 0; i < 8; ++i) { - prefix->Prefix.s6_addr[i] &= ~mask->sin6_addr.s6_addr[i]; - prefix->Prefix.s6_addr[i] |= base6prefix.s6_addr[i]; - } - memset(&prefix->Prefix.s6_addr[8], 0, 8); - prefix->AdvRouterAddr = 1; - prefix->AutoSelected = 1; - prefix->next = next; - - if (inet_ntop(ifa->ifa_addr->sa_family, (void *)&(prefix->Prefix), buf, sizeof(buf)) == NULL) - flog(LOG_ERR, "%s: inet_ntop failed in %s, line %d!", ifa->ifa_name, conf_file, num_lines); - else - dlog(LOG_DEBUG, 3, "auto-selected prefix %s/%d on interface %s from interface %s", - buf, prefix->PrefixLen, iface->Name, ifa->ifa_name); - - /* Taking only one prefix from the Base6Interface. Taking more than one would require allocating new - prefixes and building a list. I'm not sure how to do that from here. So for now, break. */ - break; - } - - if (ifap) - freeifaddrs(ifap); -#endif /* ifndef HAVE_IFADDRS_H */ - } - } - $$ = prefix; - prefix = NULL; - } - ; - -prefixhead : T_PREFIX IPV6ADDR '/' NUMBER - { - struct in6_addr zeroaddr; - memset(&zeroaddr, 0, sizeof(zeroaddr)); - - if (!memcmp($2, &zeroaddr, sizeof(struct in6_addr))) { -#ifndef HAVE_IFADDRS_H - flog(LOG_ERR, "invalid all-zeros prefix in %s, line %d", conf_file, num_lines); - ABORT; -#else - struct ifaddrs *ifap = 0, *ifa = 0; - struct AdvPrefix *next = iface->AdvPrefixList; - - while (next) { - if (next->AutoSelected) { - flog(LOG_ERR, "auto selecting prefixes works only once per interface. See %s, line %d", conf_file, num_lines); - ABORT; - } - next = next->next; - } - next = 0; - - dlog(LOG_DEBUG, 5, "all-zeros prefix in %s, line %d, parsing..", conf_file, num_lines); - - if (getifaddrs(&ifap) != 0) - flog(LOG_ERR, "getifaddrs failed: %s", strerror(errno)); - - for (ifa = ifap; ifa; ifa = ifa->ifa_next) { - struct sockaddr_in6 *s6 = (struct sockaddr_in6 *)ifa->ifa_addr; - struct sockaddr_in6 *mask = (struct sockaddr_in6 *)ifa->ifa_netmask; - char buf[INET6_ADDRSTRLEN]; - - if (strncmp(ifa->ifa_name, iface->Name, IFNAMSIZ)) - continue; - - if (ifa->ifa_addr->sa_family != AF_INET6) - continue; - - s6 = (struct sockaddr_in6 *)(ifa->ifa_addr); - - if (IN6_IS_ADDR_LINKLOCAL(&s6->sin6_addr)) - continue; - - prefix = malloc(sizeof(struct AdvPrefix)); - - if (prefix == NULL) { - flog(LOG_CRIT, "malloc failed: %s", strerror(errno)); - ABORT; - } - - prefix_init_defaults(prefix); - prefix->Prefix = get_prefix6(&s6->sin6_addr, &mask->sin6_addr); - prefix->AdvRouterAddr = 1; - prefix->AutoSelected = 1; - prefix->next = next; - next = prefix; - - if (prefix->PrefixLen == 0) - prefix->PrefixLen = count_mask(mask); - - if (inet_ntop(ifa->ifa_addr->sa_family, (void *)&(prefix->Prefix), buf, sizeof(buf)) == NULL) - flog(LOG_ERR, "%s: inet_ntop failed in %s, line %d!", ifa->ifa_name, conf_file, num_lines); - else - dlog(LOG_DEBUG, 3, "auto-selected prefix %s/%d on interface %s", buf, prefix->PrefixLen, ifa->ifa_name); - } - - if (!prefix) { - flog(LOG_WARNING, "no auto-selected prefix on interface %s, disabling advertisements", iface->Name); - } - - if (ifap) - freeifaddrs(ifap); -#endif /* ifndef HAVE_IFADDRS_H */ - } - else { - prefix = malloc(sizeof(struct AdvPrefix)); - - if (prefix == NULL) { - flog(LOG_CRIT, "malloc failed: %s", strerror(errno)); - ABORT; - } - - prefix_init_defaults(prefix); - - if ($4 > MAX_PrefixLen) - { - flog(LOG_ERR, "invalid prefix length in %s, line %d", conf_file, num_lines); - ABORT; - } - - prefix->PrefixLen = $4; - - memcpy(&prefix->Prefix, $2, sizeof(struct in6_addr)); - } - } - ; - -optional_prefixplist: /* empty */ - | '{' /* somewhat empty */ '}' - | '{' prefixplist '}' - ; - -prefixplist : prefixplist prefixparms - | prefixparms - ; - -prefixparms : T_AdvOnLink SWITCH ';' - { - if (prefix) { - if (prefix->AutoSelected) { - struct AdvPrefix *p = prefix; - do { - p->AdvOnLinkFlag = $2; - p = p->next; - } while (p && p->AutoSelected); - } - else - prefix->AdvOnLinkFlag = $2; - } - } - | T_AdvAutonomous SWITCH ';' - { - if (prefix) { - if (prefix->AutoSelected) { - struct AdvPrefix *p = prefix; - do { - p->AdvAutonomousFlag = $2; - p = p->next; - } while (p && p->AutoSelected); - } - else - prefix->AdvAutonomousFlag = $2; - } - } - | T_AdvRouterAddr SWITCH ';' - { - if (prefix) { - if (prefix->AutoSelected && $2 == 0) - flog(LOG_WARNING, "prefix automatically selected, AdvRouterAddr always enabled, ignoring config line %d", num_lines); - else - prefix->AdvRouterAddr = $2; - } - } - | T_AdvValidLifetime number_or_infinity ';' - { - if (prefix) { - if (prefix->AutoSelected) { - struct AdvPrefix *p = prefix; - do { - p->AdvValidLifetime = $2; - p->curr_validlft = $2; - p = p->next; - } while (p && p->AutoSelected); - } - else - prefix->AdvValidLifetime = $2; - prefix->curr_validlft = $2; - } - } - | T_AdvPreferredLifetime number_or_infinity ';' - { - if (prefix) { - if (prefix->AutoSelected) { - struct AdvPrefix *p = prefix; - do { - p->AdvPreferredLifetime = $2; - p->curr_preferredlft = $2; - p = p->next; - } while (p && p->AutoSelected); - } - else - prefix->AdvPreferredLifetime = $2; - prefix->curr_preferredlft = $2; - } - } - | T_DeprecatePrefix SWITCH ';' - { - prefix->DeprecatePrefixFlag = $2; - } - | T_DecrementLifetimes SWITCH ';' - { - prefix->DecrementLifetimesFlag = $2; - } - | T_Base6Interface name ';' - { - if (prefix) { - if (prefix->AutoSelected) { - flog(LOG_ERR, "automatically selecting the prefix and Base6to4Interface are mutually exclusive"); - ABORT; - } /* fallthrough */ - dlog(LOG_DEBUG, 4, "using prefixes on interface %s for prefixes on interface %s", $2, iface->Name); - strncpy(prefix->if6, $2, IFNAMSIZ-1); - prefix->if6[IFNAMSIZ-1] = '\0'; - } - } - - | T_Base6to4Interface name ';' - { - if (prefix) { - if (prefix->AutoSelected) { - flog(LOG_ERR, "automatically selecting the prefix and Base6to4Interface are mutually exclusive"); - ABORT; - } /* fallthrough */ - dlog(LOG_DEBUG, 4, "using interface %s for 6to4 prefixes on interface %s", $2, iface->Name); - strncpy(prefix->if6to4, $2, IFNAMSIZ-1); - prefix->if6to4[IFNAMSIZ-1] = '\0'; - } - } - ; - -routedef : routehead '{' optional_routeplist '}' ';' - { - $$ = route; - route = NULL; - } - ; - - -routehead : T_ROUTE IPV6ADDR '/' NUMBER - { - route = malloc(sizeof(struct AdvRoute)); - - if (route == NULL) { - flog(LOG_CRIT, "malloc failed: %s", strerror(errno)); - ABORT; - } - - route_init_defaults(route, iface); - - if ($4 > MAX_PrefixLen) - { - flog(LOG_ERR, "invalid route prefix length in %s, line %d", conf_file, num_lines); - ABORT; - } - - route->PrefixLen = $4; - - memcpy(&route->Prefix, $2, sizeof(struct in6_addr)); - } - ; - - -optional_routeplist: /* empty */ - | routeplist - ; - -routeplist : routeplist routeparms - | routeparms - ; - - -routeparms : T_AdvRoutePreference SIGNEDNUMBER ';' - { - route->AdvRoutePreference = $2; - } - | T_AdvRouteLifetime number_or_infinity ';' - { - route->AdvRouteLifetime = $2; - } - | T_RemoveRoute SWITCH ';' - { - route->RemoveRouteFlag = $2; - } - ; - -rdnssdef : rdnsshead '{' optional_rdnssplist '}' ';' - { - $$ = rdnss; - rdnss = NULL; - } - ; - -rdnssaddrs : rdnssaddrs rdnssaddr - | rdnssaddr - ; - -rdnssaddr : IPV6ADDR - { - if (!rdnss) { - /* first IP found */ - rdnss = malloc(sizeof(struct AdvRDNSS)); - - if (rdnss == NULL) { - flog(LOG_CRIT, "malloc failed: %s", strerror(errno)); - ABORT; - } - - rdnss_init_defaults(rdnss, iface); - } - - switch (rdnss->AdvRDNSSNumber) { - case 0: - memcpy(&rdnss->AdvRDNSSAddr1, $1, sizeof(struct in6_addr)); - rdnss->AdvRDNSSNumber++; - break; - case 1: - memcpy(&rdnss->AdvRDNSSAddr2, $1, sizeof(struct in6_addr)); - rdnss->AdvRDNSSNumber++; - break; - case 2: - memcpy(&rdnss->AdvRDNSSAddr3, $1, sizeof(struct in6_addr)); - rdnss->AdvRDNSSNumber++; - break; - default: - flog(LOG_CRIT, "Too many addresses in RDNSS section"); - ABORT; - } - - } - ; - -rdnsshead : T_RDNSS rdnssaddrs - { - if (!rdnss) { - flog(LOG_CRIT, "No address specified in RDNSS section"); - ABORT; - } - } - ; - -optional_rdnssplist: /* empty */ - | rdnssplist - ; - -rdnssplist : rdnssplist rdnssparms - | rdnssparms - ; - - -rdnssparms : T_AdvRDNSSPreference NUMBER ';' - { - flog(LOG_WARNING, "Ignoring deprecated RDNSS preference."); - } - | T_AdvRDNSSOpenFlag SWITCH ';' - { - flog(LOG_WARNING, "Ignoring deprecated RDNSS open flag."); - } - | T_AdvRDNSSLifetime number_or_infinity ';' - { - if ($2 < iface->MaxRtrAdvInterval && $2 != 0) { - flog(LOG_ERR, "AdvRDNSSLifetime must be at least MaxRtrAdvInterval"); - ABORT; - } - if ($2 > 2*(iface->MaxRtrAdvInterval)) - flog(LOG_WARNING, "Warning: AdvRDNSSLifetime <= 2*MaxRtrAdvInterval would allow stale DNS servers to be deleted faster"); - - rdnss->AdvRDNSSLifetime = $2; - } - | T_FlushRDNSS SWITCH ';' - { - rdnss->FlushRDNSSFlag = $2; - } - ; - -dnssldef : dnsslhead '{' optional_dnsslplist '}' ';' - { - $$ = dnssl; - dnssl = NULL; - } - ; - -dnsslsuffixes : dnsslsuffixes dnsslsuffix - | dnsslsuffix - ; - -dnsslsuffix : STRING - { - char *ch; - for (ch = $1;*ch != '\0';ch++) { - if (*ch >= 'A' && *ch <= 'Z') - continue; - if (*ch >= 'a' && *ch <= 'z') - continue; - if (*ch >= '0' && *ch <= '9') - continue; - if (*ch == '-' || *ch == '.') - continue; - - flog(LOG_CRIT, "Invalid domain suffix specified"); - ABORT; - } - - if (!dnssl) { - /* first domain found */ - dnssl = malloc(sizeof(struct AdvDNSSL)); - - if (dnssl == NULL) { - flog(LOG_CRIT, "malloc failed: %s", strerror(errno)); - ABORT; - } - - dnssl_init_defaults(dnssl, iface); - } - - dnssl->AdvDNSSLNumber++; - dnssl->AdvDNSSLSuffixes = - realloc(dnssl->AdvDNSSLSuffixes, - dnssl->AdvDNSSLNumber * sizeof(char*)); - if (dnssl->AdvDNSSLSuffixes == NULL) { - flog(LOG_CRIT, "realloc failed: %s", strerror(errno)); - ABORT; - } - - dnssl->AdvDNSSLSuffixes[dnssl->AdvDNSSLNumber - 1] = strdup($1); - } - ; - -dnsslhead : T_DNSSL dnsslsuffixes - { - if (!dnssl) { - flog(LOG_CRIT, "No domain specified in DNSSL section"); - ABORT; - } - } - ; - -optional_dnsslplist: /* empty */ - | dnsslplist - ; - -dnsslplist : dnsslplist dnsslparms - | dnsslparms - ; - - -dnsslparms : T_AdvDNSSLLifetime number_or_infinity ';' - { - if ($2 < iface->MaxRtrAdvInterval && $2 != 0) { - flog(LOG_ERR, "AdvDNSSLLifetime must be at least MaxRtrAdvInterval"); - ABORT; - } - if ($2 > 2*(iface->MaxRtrAdvInterval)) - flog(LOG_WARNING, "Warning: AdvDNSSLLifetime <= 2*MaxRtrAdvInterval would allow stale DNS suffixes to be deleted faster"); - - dnssl->AdvDNSSLLifetime = $2; - } - | T_FlushDNSSL SWITCH ';' - { - dnssl->FlushDNSSLFlag = $2; - } - ; - -number_or_infinity : NUMBER - { - $$ = $1; - } - | INFINITY - { - $$ = (uint32_t)~0; - } - ; - -%% - -static -int countbits(int b) -{ - int count; - - for (count = 0; b != 0; count++) { - b &= b - 1; // this clears the LSB-most set bit - } - - return (count); -} - -static -int count_mask(struct sockaddr_in6 *m) -{ - struct in6_addr *in6 = &m->sin6_addr; - int i; - int count = 0; - - for (i = 0; i < 16; ++i) { - count += countbits(in6->s6_addr[i]); - } - return count; -} - -static -struct in6_addr get_prefix6(struct in6_addr const *addr, struct in6_addr const *mask) -{ - struct in6_addr prefix = *addr; - int i = 0; - - for (; i < 16; ++i) { - prefix.s6_addr[i] &= mask->s6_addr[i]; - } - - return prefix; -} - -static -void cleanup(void) -{ - if (iface) - free(iface); - - if (prefix) - free(prefix); - - if (route) - free(route); - - if (rdnss) - free(rdnss); - - if (dnssl) { - int i; - for (i = 0;i < dnssl->AdvDNSSLNumber;i++) - free(dnssl->AdvDNSSLSuffixes[i]); - free(dnssl->AdvDNSSLSuffixes); - free(dnssl); - } -} - -static void -yyerror(char *msg) -{ - cleanup(); - flog(LOG_ERR, "%s in %s, line %d: %s", msg, conf_file, num_lines, yytext); -} diff --git a/release/src/router/radvd/includes.h b/release/src/router/radvd/includes.h deleted file mode 100644 index ebd14d5d96..0000000000 --- a/release/src/router/radvd/includes.h +++ /dev/null @@ -1,102 +0,0 @@ -/* - * $Id: includes.h,v 1.15 2010/12/14 11:58:21 psavola Exp $ - * - * Authors: - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#ifndef INCLUDES_H -#define INCLUDES_H - -#include "config.h" - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include -#ifdef HAVE_INTTYPES_H -# include -#endif - -#ifdef HAVE_SYS_PARAM_H -# include -#else -# ifdef HAVE_MACHINE_PARAM_H -# include -# endif -# ifdef HAVE_MACHINE_LIMITS_H -# include -# endif -#endif - -#if TIME_WITH_SYS_TIME -# include -# include -#else -# if HAVE_SYS_TIME_H -# include -# else -# include -# endif -#endif - -#include -#include -#include -#include - -#include -#include - -#include - -#include -#include - -#include - -#include - -#include - -#ifdef HAVE_NET_IF_DL_H -# include -#endif -#ifdef HAVE_NET_IF_TYPES_H -# include -#endif -#if defined(HAVE_NET_IF_ARP_H) && !defined(ARPHRD_ETHER) -# include -#endif /* defined(HAVE_NET_IF_ARP_H) && !defined(ARPHRD_ETHER) */ - -#ifdef HAVE_SYS_SOCKIO_H -# include -#endif - -#ifdef HAVE_GETOPT_H -# include -#endif - -#ifdef HAVE_IFADDRS_H -# include -#endif - -#endif /* INCLUDES_H */ diff --git a/release/src/router/radvd/install-sh b/release/src/router/radvd/install-sh deleted file mode 100755 index 6781b987bd..0000000000 --- a/release/src/router/radvd/install-sh +++ /dev/null @@ -1,520 +0,0 @@ -#!/bin/sh -# install - install a program, script, or datafile - -scriptversion=2009-04-28.21; # UTC - -# This originates from X11R5 (mit/util/scripts/install.sh), which was -# later released in X11R6 (xc/config/util/install.sh) with the -# following copyright and license. -# -# Copyright (C) 1994 X Consortium -# -# Permission is hereby granted, free of charge, to any person obtaining a copy -# of this software and associated documentation files (the "Software"), to -# deal in the Software without restriction, including without limitation the -# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or -# sell copies of the Software, and to permit persons to whom the Software is -# furnished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in -# all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- -# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -# -# Except as contained in this notice, the name of the X Consortium shall not -# be used in advertising or otherwise to promote the sale, use or other deal- -# ings in this Software without prior written authorization from the X Consor- -# tium. -# -# -# FSF changes to this file are in the public domain. -# -# Calling this script install-sh is preferred over install.sh, to prevent -# `make' implicit rules from creating a file called install from it -# when there is no Makefile. -# -# This script is compatible with the BSD install script, but was written -# from scratch. - -nl=' -' -IFS=" "" $nl" - -# set DOITPROG to echo to test this script - -# Don't use :- since 4.3BSD and earlier shells don't like it. -doit=${DOITPROG-} -if test -z "$doit"; then - doit_exec=exec -else - doit_exec=$doit -fi - -# Put in absolute file names if you don't have them in your path; -# or use environment vars. - -chgrpprog=${CHGRPPROG-chgrp} -chmodprog=${CHMODPROG-chmod} -chownprog=${CHOWNPROG-chown} -cmpprog=${CMPPROG-cmp} -cpprog=${CPPROG-cp} -mkdirprog=${MKDIRPROG-mkdir} -mvprog=${MVPROG-mv} -rmprog=${RMPROG-rm} -stripprog=${STRIPPROG-strip} - -posix_glob='?' -initialize_posix_glob=' - test "$posix_glob" != "?" || { - if (set -f) 2>/dev/null; then - posix_glob= - else - posix_glob=: - fi - } -' - -posix_mkdir= - -# Desired mode of installed file. -mode=0755 - -chgrpcmd= -chmodcmd=$chmodprog -chowncmd= -mvcmd=$mvprog -rmcmd="$rmprog -f" -stripcmd= - -src= -dst= -dir_arg= -dst_arg= - -copy_on_change=false -no_target_directory= - -usage="\ -Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE - or: $0 [OPTION]... SRCFILES... DIRECTORY - or: $0 [OPTION]... -t DIRECTORY SRCFILES... - or: $0 [OPTION]... -d DIRECTORIES... - -In the 1st form, copy SRCFILE to DSTFILE. -In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. -In the 4th, create DIRECTORIES. - -Options: - --help display this help and exit. - --version display version info and exit. - - -c (ignored) - -C install only if different (preserve the last data modification time) - -d create directories instead of installing files. - -g GROUP $chgrpprog installed files to GROUP. - -m MODE $chmodprog installed files to MODE. - -o USER $chownprog installed files to USER. - -s $stripprog installed files. - -t DIRECTORY install into DIRECTORY. - -T report an error if DSTFILE is a directory. - -Environment variables override the default commands: - CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG - RMPROG STRIPPROG -" - -while test $# -ne 0; do - case $1 in - -c) ;; - - -C) copy_on_change=true;; - - -d) dir_arg=true;; - - -g) chgrpcmd="$chgrpprog $2" - shift;; - - --help) echo "$usage"; exit $?;; - - -m) mode=$2 - case $mode in - *' '* | *' '* | *' -'* | *'*'* | *'?'* | *'['*) - echo "$0: invalid mode: $mode" >&2 - exit 1;; - esac - shift;; - - -o) chowncmd="$chownprog $2" - shift;; - - -s) stripcmd=$stripprog;; - - -t) dst_arg=$2 - shift;; - - -T) no_target_directory=true;; - - --version) echo "$0 $scriptversion"; exit $?;; - - --) shift - break;; - - -*) echo "$0: invalid option: $1" >&2 - exit 1;; - - *) break;; - esac - shift -done - -if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then - # When -d is used, all remaining arguments are directories to create. - # When -t is used, the destination is already specified. - # Otherwise, the last argument is the destination. Remove it from $@. - for arg - do - if test -n "$dst_arg"; then - # $@ is not empty: it contains at least $arg. - set fnord "$@" "$dst_arg" - shift # fnord - fi - shift # arg - dst_arg=$arg - done -fi - -if test $# -eq 0; then - if test -z "$dir_arg"; then - echo "$0: no input file specified." >&2 - exit 1 - fi - # It's OK to call `install-sh -d' without argument. - # This can happen when creating conditional directories. - exit 0 -fi - -if test -z "$dir_arg"; then - trap '(exit $?); exit' 1 2 13 15 - - # Set umask so as not to create temps with too-generous modes. - # However, 'strip' requires both read and write access to temps. - case $mode in - # Optimize common cases. - *644) cp_umask=133;; - *755) cp_umask=22;; - - *[0-7]) - if test -z "$stripcmd"; then - u_plus_rw= - else - u_plus_rw='% 200' - fi - cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;; - *) - if test -z "$stripcmd"; then - u_plus_rw= - else - u_plus_rw=,u+rw - fi - cp_umask=$mode$u_plus_rw;; - esac -fi - -for src -do - # Protect names starting with `-'. - case $src in - -*) src=./$src;; - esac - - if test -n "$dir_arg"; then - dst=$src - dstdir=$dst - test -d "$dstdir" - dstdir_status=$? - else - - # Waiting for this to be detected by the "$cpprog $src $dsttmp" command - # might cause directories to be created, which would be especially bad - # if $src (and thus $dsttmp) contains '*'. - if test ! -f "$src" && test ! -d "$src"; then - echo "$0: $src does not exist." >&2 - exit 1 - fi - - if test -z "$dst_arg"; then - echo "$0: no destination specified." >&2 - exit 1 - fi - - dst=$dst_arg - # Protect names starting with `-'. - case $dst in - -*) dst=./$dst;; - esac - - # If destination is a directory, append the input filename; won't work - # if double slashes aren't ignored. - if test -d "$dst"; then - if test -n "$no_target_directory"; then - echo "$0: $dst_arg: Is a directory" >&2 - exit 1 - fi - dstdir=$dst - dst=$dstdir/`basename "$src"` - dstdir_status=0 - else - # Prefer dirname, but fall back on a substitute if dirname fails. - dstdir=` - (dirname "$dst") 2>/dev/null || - expr X"$dst" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$dst" : 'X\(//\)[^/]' \| \ - X"$dst" : 'X\(//\)$' \| \ - X"$dst" : 'X\(/\)' \| . 2>/dev/null || - echo X"$dst" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ - s//\1/ - q - } - /^X\(\/\/\)[^/].*/{ - s//\1/ - q - } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ - s//\1/ - q - } - s/.*/./; q' - ` - - test -d "$dstdir" - dstdir_status=$? - fi - fi - - obsolete_mkdir_used=false - - if test $dstdir_status != 0; then - case $posix_mkdir in - '') - # Create intermediate dirs using mode 755 as modified by the umask. - # This is like FreeBSD 'install' as of 1997-10-28. - umask=`umask` - case $stripcmd.$umask in - # Optimize common cases. - *[2367][2367]) mkdir_umask=$umask;; - .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;; - - *[0-7]) - mkdir_umask=`expr $umask + 22 \ - - $umask % 100 % 40 + $umask % 20 \ - - $umask % 10 % 4 + $umask % 2 - `;; - *) mkdir_umask=$umask,go-w;; - esac - - # With -d, create the new directory with the user-specified mode. - # Otherwise, rely on $mkdir_umask. - if test -n "$dir_arg"; then - mkdir_mode=-m$mode - else - mkdir_mode= - fi - - posix_mkdir=false - case $umask in - *[123567][0-7][0-7]) - # POSIX mkdir -p sets u+wx bits regardless of umask, which - # is incompatible with FreeBSD 'install' when (umask & 300) != 0. - ;; - *) - tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ - trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0 - - if (umask $mkdir_umask && - exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1 - then - if test -z "$dir_arg" || { - # Check for POSIX incompatibilities with -m. - # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or - # other-writeable bit of parent directory when it shouldn't. - # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. - ls_ld_tmpdir=`ls -ld "$tmpdir"` - case $ls_ld_tmpdir in - d????-?r-*) different_mode=700;; - d????-?--*) different_mode=755;; - *) false;; - esac && - $mkdirprog -m$different_mode -p -- "$tmpdir" && { - ls_ld_tmpdir_1=`ls -ld "$tmpdir"` - test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" - } - } - then posix_mkdir=: - fi - rmdir "$tmpdir/d" "$tmpdir" - else - # Remove any dirs left behind by ancient mkdir implementations. - rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null - fi - trap '' 0;; - esac;; - esac - - if - $posix_mkdir && ( - umask $mkdir_umask && - $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir" - ) - then : - else - - # The umask is ridiculous, or mkdir does not conform to POSIX, - # or it failed possibly due to a race condition. Create the - # directory the slow way, step by step, checking for races as we go. - - case $dstdir in - /*) prefix='/';; - -*) prefix='./';; - *) prefix='';; - esac - - eval "$initialize_posix_glob" - - oIFS=$IFS - IFS=/ - $posix_glob set -f - set fnord $dstdir - shift - $posix_glob set +f - IFS=$oIFS - - prefixes= - - for d - do - test -z "$d" && continue - - prefix=$prefix$d - if test -d "$prefix"; then - prefixes= - else - if $posix_mkdir; then - (umask=$mkdir_umask && - $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break - # Don't fail if two instances are running concurrently. - test -d "$prefix" || exit 1 - else - case $prefix in - *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;; - *) qprefix=$prefix;; - esac - prefixes="$prefixes '$qprefix'" - fi - fi - prefix=$prefix/ - done - - if test -n "$prefixes"; then - # Don't fail if two instances are running concurrently. - (umask $mkdir_umask && - eval "\$doit_exec \$mkdirprog $prefixes") || - test -d "$dstdir" || exit 1 - obsolete_mkdir_used=true - fi - fi - fi - - if test -n "$dir_arg"; then - { test -z "$chowncmd" || $doit $chowncmd "$dst"; } && - { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } && - { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false || - test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1 - else - - # Make a couple of temp file names in the proper directory. - dsttmp=$dstdir/_inst.$$_ - rmtmp=$dstdir/_rm.$$_ - - # Trap to clean up those temp files at exit. - trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 - - # Copy the file name to the temp name. - (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") && - - # and set any options; do chmod last to preserve setuid bits. - # - # If any of these fail, we abort the whole thing. If we want to - # ignore errors from any of these, just make sure not to ignore - # errors from the above "$doit $cpprog $src $dsttmp" command. - # - { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } && - { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } && - { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } && - { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } && - - # If -C, don't bother to copy if it wouldn't change the file. - if $copy_on_change && - old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` && - new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` && - - eval "$initialize_posix_glob" && - $posix_glob set -f && - set X $old && old=:$2:$4:$5:$6 && - set X $new && new=:$2:$4:$5:$6 && - $posix_glob set +f && - - test "$old" = "$new" && - $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1 - then - rm -f "$dsttmp" - else - # Rename the file to the real destination. - $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null || - - # The rename failed, perhaps because mv can't rename something else - # to itself, or perhaps because mv is so ancient that it does not - # support -f. - { - # Now remove or move aside any old file at destination location. - # We try this two ways since rm can't unlink itself on some - # systems and the destination file might be busy for other - # reasons. In this case, the final cleanup might fail but the new - # file should still install successfully. - { - test ! -f "$dst" || - $doit $rmcmd -f "$dst" 2>/dev/null || - { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null && - { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; } - } || - { echo "$0: cannot unlink or rename $dst" >&2 - (exit 1); exit 1 - } - } && - - # Now rename the file to the real destination. - $doit $mvcmd "$dsttmp" "$dst" - } - fi || exit 1 - - trap '' 0 - fi -done - -# Local variables: -# eval: (add-hook 'write-file-hooks 'time-stamp) -# time-stamp-start: "scriptversion=" -# time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-time-zone: "UTC" -# time-stamp-end: "; # UTC" -# End: diff --git a/release/src/router/radvd/interface.c b/release/src/router/radvd/interface.c deleted file mode 100644 index abdbc89adb..0000000000 --- a/release/src/router/radvd/interface.c +++ /dev/null @@ -1,257 +0,0 @@ -/* - * $Id: interface.c,v 1.27 2011/04/28 15:08:40 reubenhwk Exp $ - * - * Authors: - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" -#include "defaults.h" - -void -iface_init_defaults(struct Interface *iface) -{ - memset(iface, 0, sizeof(struct Interface)); - - iface->cease_adv = 0; - - iface->HasFailed = 0; - iface->IgnoreIfMissing = DFLT_IgnoreIfMissing; - iface->AdvSendAdvert = DFLT_AdvSendAdv; - iface->MaxRtrAdvInterval = DFLT_MaxRtrAdvInterval; - iface->AdvSourceLLAddress = DFLT_AdvSourceLLAddress; - iface->AdvReachableTime = DFLT_AdvReachableTime; - iface->AdvRetransTimer = DFLT_AdvRetransTimer; - iface->AdvLinkMTU = DFLT_AdvLinkMTU; - iface->AdvCurHopLimit = DFLT_AdvCurHopLimit; - iface->AdvIntervalOpt = DFLT_AdvIntervalOpt; - iface->AdvHomeAgentInfo = DFLT_AdvHomeAgentInfo; - iface->AdvHomeAgentFlag = DFLT_AdvHomeAgentFlag; - iface->HomeAgentPreference = DFLT_HomeAgentPreference; - iface->MinDelayBetweenRAs = DFLT_MinDelayBetweenRAs; - iface->AdvMobRtrSupportFlag = DFLT_AdvMobRtrSupportFlag; - - iface->MinRtrAdvInterval = -1; - iface->AdvDefaultLifetime = -1; - iface->AdvDefaultPreference = DFLT_AdvDefaultPreference; - iface->HomeAgentLifetime = -1; -} - -void -prefix_init_defaults(struct AdvPrefix *prefix) -{ - memset(prefix, 0, sizeof(struct AdvPrefix)); - - prefix->AdvOnLinkFlag = DFLT_AdvOnLinkFlag; - prefix->AdvAutonomousFlag = DFLT_AdvAutonomousFlag; - prefix->AdvRouterAddr = DFLT_AdvRouterAddr; - prefix->AdvValidLifetime = DFLT_AdvValidLifetime; - prefix->AdvPreferredLifetime = DFLT_AdvPreferredLifetime; - prefix->DeprecatePrefixFlag = DFLT_DeprecatePrefixFlag; - prefix->DecrementLifetimesFlag = DFLT_DecrementLifetimesFlag; - prefix->if6to4[0] = 0; - prefix->enabled = 1; - - prefix->curr_validlft = prefix->AdvValidLifetime; - prefix->curr_preferredlft = prefix->AdvPreferredLifetime; -} - -void -route_init_defaults(struct AdvRoute *route, struct Interface *iface) -{ - memset(route, 0, sizeof(struct AdvRoute)); - - route->AdvRouteLifetime = DFLT_AdvRouteLifetime(iface); - route->AdvRoutePreference = DFLT_AdvRoutePreference; - route->RemoveRouteFlag = DFLT_RemoveRouteFlag; -} - -void -rdnss_init_defaults(struct AdvRDNSS *rdnss, struct Interface *iface) -{ - memset(rdnss, 0, sizeof(struct AdvRDNSS)); - - rdnss->AdvRDNSSLifetime = DFLT_AdvRDNSSLifetime(iface); - rdnss->AdvRDNSSNumber = 0; - rdnss->FlushRDNSSFlag = DFLT_FlushRDNSSFlag; -} - -void -dnssl_init_defaults(struct AdvDNSSL *dnssl, struct Interface *iface) -{ - memset(dnssl, 0, sizeof(struct AdvDNSSL)); - - dnssl->AdvDNSSLLifetime = DFLT_AdvDNSSLLifetime(iface); - dnssl->FlushDNSSLFlag = DFLT_FlushDNSSLFlag; -} - -int -check_iface(struct Interface *iface) -{ - struct AdvPrefix *prefix; - struct AdvRoute *route; - int res = 0; - int MIPv6 = 0; - - /* Check if we use Mobile IPv6 extensions */ - if (iface->AdvHomeAgentFlag || iface->AdvHomeAgentInfo || - iface->AdvIntervalOpt) - { - MIPv6 = 1; - flog(LOG_INFO, "using Mobile IPv6 extensions"); - } - - prefix = iface->AdvPrefixList; - while (!MIPv6 && prefix) - { - if (prefix->AdvRouterAddr) - { - MIPv6 = 1; - } - prefix = prefix->next; - } - - if (iface->MinRtrAdvInterval < 0) - iface->MinRtrAdvInterval = DFLT_MinRtrAdvInterval(iface); - - if ((iface->MinRtrAdvInterval < (MIPv6 ? MIN_MinRtrAdvInterval_MIPv6 : MIN_MinRtrAdvInterval)) || - (iface->MinRtrAdvInterval > MAX_MinRtrAdvInterval(iface))) - { - flog(LOG_ERR, - "MinRtrAdvInterval for %s (%.2f) must be at least %.2f but no more than 3/4 of MaxRtrAdvInterval (%.2f)", - iface->Name, iface->MinRtrAdvInterval, - MIPv6 ? MIN_MinRtrAdvInterval_MIPv6 : (int)MIN_MinRtrAdvInterval, - MAX_MinRtrAdvInterval(iface)); - res = -1; - } - - if ((iface->MaxRtrAdvInterval < (MIPv6 ? MIN_MaxRtrAdvInterval_MIPv6 : MIN_MaxRtrAdvInterval)) - || (iface->MaxRtrAdvInterval > MAX_MaxRtrAdvInterval)) - { - flog(LOG_ERR, - "MaxRtrAdvInterval for %s (%.2f) must be between %.2f and %d", - iface->Name, iface->MaxRtrAdvInterval, - MIPv6 ? MIN_MaxRtrAdvInterval_MIPv6 : (int)MIN_MaxRtrAdvInterval, - MAX_MaxRtrAdvInterval); - res = -1; - } - - if (iface->MinDelayBetweenRAs < (MIPv6 ? MIN_DELAY_BETWEEN_RAS_MIPv6 : MIN_DELAY_BETWEEN_RAS)) - { - flog(LOG_ERR, - "MinDelayBetweenRAs for %s (%.2f) must be at least %.2f", - iface->Name, iface->MinDelayBetweenRAs, - MIPv6 ? MIN_DELAY_BETWEEN_RAS_MIPv6 : MIN_DELAY_BETWEEN_RAS); - res = -1; - } - - if ((iface->AdvLinkMTU != 0) && - ((iface->AdvLinkMTU < MIN_AdvLinkMTU) || - (iface->if_maxmtu != -1 && (iface->AdvLinkMTU > iface->if_maxmtu)))) - { - flog(LOG_ERR, "AdvLinkMTU for %s (%u) must be zero or between %u and %u", - iface->Name, iface->AdvLinkMTU, MIN_AdvLinkMTU, iface->if_maxmtu); - res = -1; - } - - if (iface->AdvReachableTime > MAX_AdvReachableTime) - { - flog(LOG_ERR, - "AdvReachableTime for %s (%u) must not be greater than %u", - iface->Name, iface->AdvReachableTime, MAX_AdvReachableTime); - res = -1; - } - - if (iface->AdvDefaultLifetime < 0) - iface->AdvDefaultLifetime = DFLT_AdvDefaultLifetime(iface); - - if ((iface->AdvDefaultLifetime != 0) && - ((iface->AdvDefaultLifetime > MAX_AdvDefaultLifetime) || - (iface->AdvDefaultLifetime < MIN_AdvDefaultLifetime(iface)))) - { - flog(LOG_ERR, - "AdvDefaultLifetime for %s (%u) must be zero or between %u and %u", - iface->Name, iface->AdvDefaultLifetime, (int)MIN_AdvDefaultLifetime(iface), - MAX_AdvDefaultLifetime); - res = -1; - } - - /* Mobile IPv6 ext */ - if (iface->HomeAgentLifetime < 0) - iface->HomeAgentLifetime = DFLT_HomeAgentLifetime(iface); - - /* Mobile IPv6 ext */ - if (iface->AdvHomeAgentInfo) - { - if ((iface->HomeAgentLifetime > MAX_HomeAgentLifetime) || - (iface->HomeAgentLifetime < MIN_HomeAgentLifetime)) - { - flog(LOG_ERR, - "HomeAgentLifetime for %s (%u) must be between %u and %u", - iface->Name, iface->HomeAgentLifetime, - MIN_HomeAgentLifetime, MAX_HomeAgentLifetime); - res = -1; - } - } - - /* Mobile IPv6 ext */ - if (iface->AdvHomeAgentInfo && !(iface->AdvHomeAgentFlag)) - { - flog(LOG_ERR, - "AdvHomeAgentFlag for %s must be set with HomeAgentInfo", iface->Name); - res = -1; - } - if (iface->AdvMobRtrSupportFlag && !(iface->AdvHomeAgentInfo)) - { - flog(LOG_ERR, - "AdvHomeAgentInfo for %s must be set with AdvMobRtrSupportFlag", iface->Name); - res = -1; - } - - /* XXX: need this? prefix = iface->AdvPrefixList; */ - - while (prefix) - { - if (prefix->PrefixLen > MAX_PrefixLen) - { - flog(LOG_ERR, "invalid prefix length (%u) for %s", prefix->PrefixLen, iface->Name); - res = -1; - } - - if (prefix->AdvPreferredLifetime > prefix->AdvValidLifetime) - { - flog(LOG_ERR, "AdvValidLifetime for %s (%u) must be " - "greater than AdvPreferredLifetime for", - iface->Name, prefix->AdvValidLifetime); - res = -1; - } - - prefix = prefix->next; - } - - - route = iface->AdvRouteList; - - while(route) - { - if (route->PrefixLen > MAX_PrefixLen) - { - flog(LOG_ERR, "invalid route prefix length (%u) for %s", route->PrefixLen, iface->Name); - res = -1; - } - - route = route->next; - } - - return res; -} diff --git a/release/src/router/radvd/log.c b/release/src/router/radvd/log.c deleted file mode 100644 index abc726dd43..0000000000 --- a/release/src/router/radvd/log.c +++ /dev/null @@ -1,180 +0,0 @@ -/* - * $Id: log.c,v 1.12 2010/12/14 11:58:21 psavola Exp $ - * - * Authors: - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file - * COPYRIGHT applies to this software. If your distribution is missing - * this file, you may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" - -static int log_method = L_NONE; -static char *log_ident; -static char *log_file; -static FILE *log_file_fd; -static int log_facility; -static int debug_level = 0; - -int -log_open(int method, char *ident, char *log, int facility) -{ - log_method = method; - log_ident = ident; - - switch (log_method) { - case L_NONE: - case L_STDERR: - break; - case L_STDERR_SYSLOG: - /* fallthrough */ - case L_SYSLOG: - if (facility == -1) - log_facility = LOG_DAEMON; - else - log_facility = facility; - - openlog(log_ident, LOG_PID, log_facility); - break; - case L_LOGFILE: - if (!log) - { - fprintf(stderr, "%s: no logfile specified\n", log_ident); - return (-1); - } - log_file = log; - if ((log_file_fd = fopen(log_file, "a")) == NULL) - { - fprintf(stderr, "%s: can't open %s: %s\n", log_ident, log_file, strerror(errno)); - return (-1); - } - break; - default: - fprintf(stderr, "%s: unknown logging method: %d\n", log_ident, log_method); - log_method = L_NONE; - return (-1); - } - return 0; -} - -/* note: [dfv]log() is also called from root context */ -static int -vlog(int prio, char *format, va_list ap) -{ - char tstamp[64], buff[1024]; - struct tm *tm; - time_t current; - - vsnprintf(buff, sizeof(buff), format, ap); - - switch (log_method) { - case L_NONE: - break; - case L_SYSLOG: - syslog(prio, "%s", buff); - break; - case L_STDERR_SYSLOG: - syslog(prio, "%s", buff); - if (prio > LOG_ERR) /* fall through for messages with high priority */ - break; - case L_STDERR: - current = time(NULL); - tm = localtime(¤t); - (void) strftime(tstamp, sizeof(tstamp), LOG_TIME_FORMAT, tm); - - fprintf(stderr, "[%s] %s: %s\n", tstamp, log_ident, buff); - fflush(stderr); - break; - case L_LOGFILE: - current = time(NULL); - tm = localtime(¤t); - (void) strftime(tstamp, sizeof(tstamp), LOG_TIME_FORMAT, tm); - - fprintf(log_file_fd, "[%s] %s: %s\n", tstamp, log_ident, buff); - fflush(log_file_fd); - break; - default: - fprintf(stderr, "%s: unknown logging method: %d\n", log_ident, log_method); - log_method = L_NONE; - return (-1); - } - return 0; -} - -void -dlog(int prio, int level, char *format, ...) -{ - va_list ap; - int res; - - if (debug_level < level) - return; - - va_start(ap, format); - res = vlog(prio, format, ap); - va_end(ap); - - /* XXX: should we do something if res < 0.. */ -} - -void -flog(int prio, char *format, ...) -{ - va_list ap; - int res; - - va_start(ap, format); - res = vlog(prio, format, ap); - va_end(ap); - - /* XXX: should we do something if res < 0.. */ -} - -int -log_close(void) -{ - switch (log_method) { - case L_NONE: - case L_STDERR: - break; - case L_STDERR_SYSLOG: - case L_SYSLOG: - closelog(); - break; - case L_LOGFILE: - fclose(log_file_fd); - break; - default: - fprintf(stderr, "%s: unknown logging method: %d\n", log_ident, log_method); - log_method = L_NONE; - return (-1); - } - return 0; -} - -int -log_reopen(void) -{ - log_close(); - return log_open(log_method, log_ident, log_file, log_facility); -} - -void -set_debuglevel(int level) -{ - debug_level = level; -} - -int -get_debuglevel(void) -{ - return debug_level; -} diff --git a/release/src/router/radvd/log.h b/release/src/router/radvd/log.h deleted file mode 100644 index 35fb3e0a02..0000000000 --- a/release/src/router/radvd/log.h +++ /dev/null @@ -1,31 +0,0 @@ -/* - * $Id: log.h,v 1.1 2011/02/07 00:26:48 reubenhwk Exp $ - * - * Authors: - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#define L_NONE 0 -#define L_SYSLOG 1 -#define L_STDERR 2 -#define L_STDERR_SYSLOG 3 -#define L_LOGFILE 4 - -#define LOG_TIME_FORMAT "%b %d %H:%M:%S" - -int log_open(int, char *, char*, int); -void flog(int, char *, ...); -void dlog(int, int, char *, ...); -int log_close(void); -int log_reopen(void); -void set_debuglevel(int); -int get_debuglevel(void); - diff --git a/release/src/router/radvd/missing b/release/src/router/radvd/missing deleted file mode 100755 index 28055d2ae6..0000000000 --- a/release/src/router/radvd/missing +++ /dev/null @@ -1,376 +0,0 @@ -#! /bin/sh -# Common stub for a few missing GNU programs while installing. - -scriptversion=2009-04-28.21; # UTC - -# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003, 2004, 2005, 2006, -# 2008, 2009 Free Software Foundation, Inc. -# Originally by Fran,cois Pinard , 1996. - -# 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; either version 2, or (at your option) -# any later version. - -# 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 . - -# As a special exception to the GNU General Public License, if you -# distribute this file as part of a program that contains a -# configuration script generated by Autoconf, you may include it under -# the same distribution terms that you use for the rest of that program. - -if test $# -eq 0; then - echo 1>&2 "Try \`$0 --help' for more information" - exit 1 -fi - -run=: -sed_output='s/.* --output[ =]\([^ ]*\).*/\1/p' -sed_minuso='s/.* -o \([^ ]*\).*/\1/p' - -# In the cases where this matters, `missing' is being run in the -# srcdir already. -if test -f configure.ac; then - configure_ac=configure.ac -else - configure_ac=configure.in -fi - -msg="missing on your system" - -case $1 in ---run) - # Try to run requested program, and just exit if it succeeds. - run= - shift - "$@" && exit 0 - # Exit code 63 means version mismatch. This often happens - # when the user try to use an ancient version of a tool on - # a file that requires a minimum version. In this case we - # we should proceed has if the program had been absent, or - # if --run hadn't been passed. - if test $? = 63; then - run=: - msg="probably too old" - fi - ;; - - -h|--h|--he|--hel|--help) - echo "\ -$0 [OPTION]... PROGRAM [ARGUMENT]... - -Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an -error status if there is no known handling for PROGRAM. - -Options: - -h, --help display this help and exit - -v, --version output version information and exit - --run try to run the given command, and emulate it if it fails - -Supported PROGRAM values: - aclocal touch file \`aclocal.m4' - autoconf touch file \`configure' - autoheader touch file \`config.h.in' - autom4te touch the output file, or create a stub one - automake touch all \`Makefile.in' files - bison create \`y.tab.[ch]', if possible, from existing .[ch] - flex create \`lex.yy.c', if possible, from existing .c - help2man touch the output file - lex create \`lex.yy.c', if possible, from existing .c - makeinfo touch the output file - tar try tar, gnutar, gtar, then tar without non-portable flags - yacc create \`y.tab.[ch]', if possible, from existing .[ch] - -Version suffixes to PROGRAM as well as the prefixes \`gnu-', \`gnu', and -\`g' are ignored when checking the name. - -Send bug reports to ." - exit $? - ;; - - -v|--v|--ve|--ver|--vers|--versi|--versio|--version) - echo "missing $scriptversion (GNU Automake)" - exit $? - ;; - - -*) - echo 1>&2 "$0: Unknown \`$1' option" - echo 1>&2 "Try \`$0 --help' for more information" - exit 1 - ;; - -esac - -# normalize program name to check for. -program=`echo "$1" | sed ' - s/^gnu-//; t - s/^gnu//; t - s/^g//; t'` - -# Now exit if we have it, but it failed. Also exit now if we -# don't have it and --version was passed (most likely to detect -# the program). This is about non-GNU programs, so use $1 not -# $program. -case $1 in - lex*|yacc*) - # Not GNU programs, they don't have --version. - ;; - - tar*) - if test -n "$run"; then - echo 1>&2 "ERROR: \`tar' requires --run" - exit 1 - elif test "x$2" = "x--version" || test "x$2" = "x--help"; then - exit 1 - fi - ;; - - *) - if test -z "$run" && ($1 --version) > /dev/null 2>&1; then - # We have it, but it failed. - exit 1 - elif test "x$2" = "x--version" || test "x$2" = "x--help"; then - # Could not run --version or --help. This is probably someone - # running `$TOOL --version' or `$TOOL --help' to check whether - # $TOOL exists and not knowing $TOOL uses missing. - exit 1 - fi - ;; -esac - -# If it does not exist, or fails to run (possibly an outdated version), -# try to emulate it. -case $program in - aclocal*) - echo 1>&2 "\ -WARNING: \`$1' is $msg. You should only need it if - you modified \`acinclude.m4' or \`${configure_ac}'. You might want - to install the \`Automake' and \`Perl' packages. Grab them from - any GNU archive site." - touch aclocal.m4 - ;; - - autoconf*) - echo 1>&2 "\ -WARNING: \`$1' is $msg. You should only need it if - you modified \`${configure_ac}'. You might want to install the - \`Autoconf' and \`GNU m4' packages. Grab them from any GNU - archive site." - touch configure - ;; - - autoheader*) - echo 1>&2 "\ -WARNING: \`$1' is $msg. You should only need it if - you modified \`acconfig.h' or \`${configure_ac}'. You might want - to install the \`Autoconf' and \`GNU m4' packages. Grab them - from any GNU archive site." - files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}` - test -z "$files" && files="config.h" - touch_files= - for f in $files; do - case $f in - *:*) touch_files="$touch_files "`echo "$f" | - sed -e 's/^[^:]*://' -e 's/:.*//'`;; - *) touch_files="$touch_files $f.in";; - esac - done - touch $touch_files - ;; - - automake*) - echo 1>&2 "\ -WARNING: \`$1' is $msg. You should only need it if - you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'. - You might want to install the \`Automake' and \`Perl' packages. - Grab them from any GNU archive site." - find . -type f -name Makefile.am -print | - sed 's/\.am$/.in/' | - while read f; do touch "$f"; done - ;; - - autom4te*) - echo 1>&2 "\ -WARNING: \`$1' is needed, but is $msg. - You might have modified some files without having the - proper tools for further handling them. - You can get \`$1' as part of \`Autoconf' from any GNU - archive site." - - file=`echo "$*" | sed -n "$sed_output"` - test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"` - if test -f "$file"; then - touch $file - else - test -z "$file" || exec >$file - echo "#! /bin/sh" - echo "# Created by GNU Automake missing as a replacement of" - echo "# $ $@" - echo "exit 0" - chmod +x $file - exit 1 - fi - ;; - - bison*|yacc*) - echo 1>&2 "\ -WARNING: \`$1' $msg. You should only need it if - you modified a \`.y' file. You may need the \`Bison' package - in order for those modifications to take effect. You can get - \`Bison' from any GNU archive site." - rm -f y.tab.c y.tab.h - if test $# -ne 1; then - eval LASTARG="\${$#}" - case $LASTARG in - *.y) - SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'` - if test -f "$SRCFILE"; then - cp "$SRCFILE" y.tab.c - fi - SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'` - if test -f "$SRCFILE"; then - cp "$SRCFILE" y.tab.h - fi - ;; - esac - fi - if test ! -f y.tab.h; then - echo >y.tab.h - fi - if test ! -f y.tab.c; then - echo 'main() { return 0; }' >y.tab.c - fi - ;; - - lex*|flex*) - echo 1>&2 "\ -WARNING: \`$1' is $msg. You should only need it if - you modified a \`.l' file. You may need the \`Flex' package - in order for those modifications to take effect. You can get - \`Flex' from any GNU archive site." - rm -f lex.yy.c - if test $# -ne 1; then - eval LASTARG="\${$#}" - case $LASTARG in - *.l) - SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'` - if test -f "$SRCFILE"; then - cp "$SRCFILE" lex.yy.c - fi - ;; - esac - fi - if test ! -f lex.yy.c; then - echo 'main() { return 0; }' >lex.yy.c - fi - ;; - - help2man*) - echo 1>&2 "\ -WARNING: \`$1' is $msg. You should only need it if - you modified a dependency of a manual page. You may need the - \`Help2man' package in order for those modifications to take - effect. You can get \`Help2man' from any GNU archive site." - - file=`echo "$*" | sed -n "$sed_output"` - test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"` - if test -f "$file"; then - touch $file - else - test -z "$file" || exec >$file - echo ".ab help2man is required to generate this page" - exit $? - fi - ;; - - makeinfo*) - echo 1>&2 "\ -WARNING: \`$1' is $msg. You should only need it if - you modified a \`.texi' or \`.texinfo' file, or any other file - indirectly affecting the aspect of the manual. The spurious - call might also be the consequence of using a buggy \`make' (AIX, - DU, IRIX). You might want to install the \`Texinfo' package or - the \`GNU make' package. Grab either from any GNU archive site." - # The file to touch is that specified with -o ... - file=`echo "$*" | sed -n "$sed_output"` - test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"` - if test -z "$file"; then - # ... or it is the one specified with @setfilename ... - infile=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'` - file=`sed -n ' - /^@setfilename/{ - s/.* \([^ ]*\) *$/\1/ - p - q - }' $infile` - # ... or it is derived from the source name (dir/f.texi becomes f.info) - test -z "$file" && file=`echo "$infile" | sed 's,.*/,,;s,.[^.]*$,,'`.info - fi - # If the file does not exist, the user really needs makeinfo; - # let's fail without touching anything. - test -f $file || exit 1 - touch $file - ;; - - tar*) - shift - - # We have already tried tar in the generic part. - # Look for gnutar/gtar before invocation to avoid ugly error - # messages. - if (gnutar --version > /dev/null 2>&1); then - gnutar "$@" && exit 0 - fi - if (gtar --version > /dev/null 2>&1); then - gtar "$@" && exit 0 - fi - firstarg="$1" - if shift; then - case $firstarg in - *o*) - firstarg=`echo "$firstarg" | sed s/o//` - tar "$firstarg" "$@" && exit 0 - ;; - esac - case $firstarg in - *h*) - firstarg=`echo "$firstarg" | sed s/h//` - tar "$firstarg" "$@" && exit 0 - ;; - esac - fi - - echo 1>&2 "\ -WARNING: I can't seem to be able to run \`tar' with the given arguments. - You may want to install GNU tar or Free paxutils, or check the - command line arguments." - exit 1 - ;; - - *) - echo 1>&2 "\ -WARNING: \`$1' is needed, and is $msg. - You might have modified some files without having the - proper tools for further handling them. Check the \`README' file, - it often tells you about the needed prerequisites for installing - this package. You may also peek at any GNU archive site, in case - some other package would contain this missing \`$1' program." - exit 1 - ;; -esac - -exit 0 - -# Local variables: -# eval: (add-hook 'write-file-hooks 'time-stamp) -# time-stamp-start: "scriptversion=" -# time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-time-zone: "UTC" -# time-stamp-end: "; # UTC" -# End: diff --git a/release/src/router/radvd/netlink.c b/release/src/router/radvd/netlink.c deleted file mode 100644 index 21d7bfa3ae..0000000000 --- a/release/src/router/radvd/netlink.c +++ /dev/null @@ -1,96 +0,0 @@ -/* - * $Id: netlink.c,v 1.1 2011/02/25 04:17:23 reubenhwk Exp $ - * - * Authors: - * Lars Fenneberg - * Reuben Hawkins - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "radvd.h" -#include "log.h" -#include "netlink.h" - -#include -#include -#include -#include -#include -#include -#include -#include -#include - -void process_netlink_msg(int sock) -{ - int len; - char buf[4096]; - struct iovec iov = { buf, sizeof(buf) }; - struct sockaddr_nl sa; - struct msghdr msg = { (void *)&sa, sizeof(sa), &iov, 1, NULL, 0, 0 }; - struct nlmsghdr *nh; - struct ifinfomsg * ifinfo; - char ifname[IF_NAMESIZE] = {""}; - char * rc = 0; - - len = recvmsg (sock, &msg, 0); - if (len == -1) { - flog(LOG_ERR, "recvmsg failed: %s", strerror(errno)); - } - - for (nh = (struct nlmsghdr *) buf; NLMSG_OK (nh, len); nh = NLMSG_NEXT (nh, len)) { - /* The end of multipart message. */ - if (nh->nlmsg_type == NLMSG_DONE) - return; - - if (nh->nlmsg_type == NLMSG_ERROR) { - flog(LOG_ERR, "%s:%d Some type of netlink error.\n", __FILE__, __LINE__); - abort(); - } - - /* Continue with parsing payload. */ - ifinfo = NLMSG_DATA(nh); - rc = if_indextoname(ifinfo->ifi_index, ifname); - if (ifinfo->ifi_flags & IFF_RUNNING) { - dlog(LOG_DEBUG, 3, "%s, ifindex %d, flags is running", ifname, ifinfo->ifi_index); - } - else { - dlog(LOG_DEBUG, 3, "%s, ifindex %d, flags is *NOT* running", ifname, ifinfo->ifi_index); - } - config_interface(); - kickoff_adverts(); - } -} - -int netlink_socket(void) -{ - int rc, sock; - struct sockaddr_nl snl; - - sock = socket(PF_NETLINK, SOCK_RAW, NETLINK_ROUTE); - if (sock == -1) { - flog(LOG_ERR, "Unable to open netlink socket: %s", strerror(errno)); - } - - memset(&snl, 0, sizeof(snl)); - snl.nl_family = AF_NETLINK; - snl.nl_groups = RTMGRP_LINK; - - rc = bind(sock, (struct sockaddr*)&snl, sizeof(snl)); - if (rc == -1) { - flog(LOG_ERR, "Unable to bind netlink socket: %s", strerror(errno)); - close(sock); - sock = -1; - } - - return sock; -} - diff --git a/release/src/router/radvd/netlink.h b/release/src/router/radvd/netlink.h deleted file mode 100644 index 8add6e0278..0000000000 --- a/release/src/router/radvd/netlink.h +++ /dev/null @@ -1,21 +0,0 @@ -/* - * $Id: netlink.h,v 1.1 2011/02/25 04:17:23 reubenhwk Exp $ - * - * Authors: - * Lars Fenneberg - * Reuben Hawkins - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#pragma once - -void process_netlink_msg(int sock); -int netlink_socket(void); - diff --git a/release/src/router/radvd/pathnames.h b/release/src/router/radvd/pathnames.h deleted file mode 100644 index 19eb70ce6c..0000000000 --- a/release/src/router/radvd/pathnames.h +++ /dev/null @@ -1,48 +0,0 @@ -/* - * $Id: pathnames.h,v 1.9 2010/12/14 11:58:21 psavola Exp $ - * - * Authors: - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#ifndef PATHNAMES_H -#define PATHNAMES_H - -#ifndef PATH_RADVD_CONF -#define PATH_RADVD_CONF "/etc/radvd.conf" -#endif - -#ifndef PATH_RADVD_PID -#define PATH_RADVD_PID "/var/run/radvd.pid" -#endif - -#ifndef PATH_RADVD_LOG -#define PATH_RADVD_LOG "/var/log/radvd.log" -#endif - -#define PATH_PROC_NET_IF_INET6 "/proc/net/if_inet6" -#define PATH_PROC_NET_IGMP6 "/proc/net/igmp6" - -#ifdef __linux__ -#define SYSCTL_IP6_FORWARDING CTL_NET, NET_IPV6, NET_IPV6_CONF, NET_PROTO_CONF_ALL, NET_IPV6_FORWARDING -#define PROC_SYS_IP6_FORWARDING "/proc/sys/net/ipv6/conf/all/forwarding" -#define PROC_SYS_IP6_LINKMTU "/proc/sys/net/ipv6/conf/%s/mtu" -#define PROC_SYS_IP6_CURHLIM "/proc/sys/net/ipv6/conf/%s/hop_limit" -#define PROC_SYS_IP6_BASEREACHTIME_MS "/proc/sys/net/ipv6/neigh/%s/base_reachable_time_ms" -#define PROC_SYS_IP6_BASEREACHTIME "/proc/sys/net/ipv6/neigh/%s/base_reachable_time" -#define PROC_SYS_IP6_RETRANSTIMER_MS "/proc/sys/net/ipv6/neigh/%s/retrans_time_ms" -#define PROC_SYS_IP6_RETRANSTIMER "/proc/sys/net/ipv6/neigh/%s/retrans_time" -#else /* BSD */ -#define SYSCTL_IP6_FORWARDING CTL_NET, PF_INET6, IPPROTO_IPV6, IPV6CTL_FORWARDING -#endif - -#endif diff --git a/release/src/router/radvd/privsep-bsd44.c b/release/src/router/radvd/privsep-bsd44.c deleted file mode 100644 index 565261f7a6..0000000000 --- a/release/src/router/radvd/privsep-bsd44.c +++ /dev/null @@ -1,34 +0,0 @@ -/* - * $Id: privsep-bsd44.c,v 1.2 2010/12/14 11:58:21 psavola Exp $ - * - * Authors: - * Jim Paris - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996,1997,2008 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" -#include "pathnames.h" - -/* Not available */ -int -privsep_init(void) -{ - return 0; -} - -int -privsep_enabled(void) -{ - return 0; -} diff --git a/release/src/router/radvd/privsep-linux.c b/release/src/router/radvd/privsep-linux.c deleted file mode 100644 index d6717bfe08..0000000000 --- a/release/src/router/radvd/privsep-linux.c +++ /dev/null @@ -1,229 +0,0 @@ -/* - * $Id: privsep-linux.c,v 1.6 2011/02/28 10:53:07 reubenhwk Exp $ - * - * Authors: - * Jim Paris - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996,1997,2008 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" -#include "pathnames.h" - -int privsep_set(const char *iface, const char *var, uint32_t val); -void privsep_read_loop(void); - -/* For reading or writing, depending on process */ -static int pfd = -1; - -/* Command types */ -enum privsep_type { - SET_INTERFACE_LINKMTU, - SET_INTERFACE_CURHLIM, - SET_INTERFACE_REACHTIME, - SET_INTERFACE_RETRANSTIMER, -}; - -/* Command sent over pipe is a fixed size binary structure. */ -struct privsep_command { - int type; - char iface[IFNAMSIZ]; - uint32_t val; -}; - -/* Privileged read loop */ -void -privsep_read_loop(void) -{ - struct privsep_command cmd; - int ret; - - while (1) { - ret = readn(pfd, &cmd, sizeof(cmd)); - if (ret <= 0) { - /* Error or EOF, give up */ - if (ret < 0) { - flog(LOG_ERR, "Exiting, privsep_read_loop had readn error: %s\n", - strerror(errno)); - } else { - flog(LOG_ERR, "Exiting, privsep_read_loop had readn return 0 bytes\n"); - } - close(pfd); - _exit(0); - } - if (ret != sizeof(cmd)) { - /* Short read, ignore */ - continue; - } - - cmd.iface[IFNAMSIZ-1] = '\0'; - - switch(cmd.type) { - - case SET_INTERFACE_LINKMTU: - if (cmd.val < MIN_AdvLinkMTU || cmd.val > MAX_AdvLinkMTU) { - flog(LOG_ERR, "(privsep) %s: LinkMTU (%u) is not within the defined bounds, ignoring", cmd.iface, cmd.val); - break; - } - ret = set_interface_var(cmd.iface, PROC_SYS_IP6_LINKMTU, "LinkMTU", cmd.val); - break; - - case SET_INTERFACE_CURHLIM: - if (cmd.val < MIN_AdvCurHopLimit || cmd.val > MAX_AdvCurHopLimit) { - flog(LOG_ERR, "(privsep) %s: CurHopLimit (%u) is not within the defined bounds, ignoring", cmd.iface, cmd.val); - break; - } - ret = set_interface_var(cmd.iface, PROC_SYS_IP6_CURHLIM, "CurHopLimit", cmd.val); - break; - - case SET_INTERFACE_REACHTIME: - if (cmd.val < MIN_AdvReachableTime || cmd.val > MAX_AdvReachableTime) { - flog(LOG_ERR, "(privsep) %s: BaseReachableTimer (%u) is not within the defined bounds, ignoring", cmd.iface, cmd.val); - break; - } - ret = set_interface_var(cmd.iface, PROC_SYS_IP6_BASEREACHTIME_MS, "BaseReachableTimer (ms)", cmd.val); - if (ret == 0) - break; - set_interface_var(cmd.iface, PROC_SYS_IP6_BASEREACHTIME, "BaseReachableTimer", cmd.val / 1000); - break; - - case SET_INTERFACE_RETRANSTIMER: - if (cmd.val < MIN_AdvRetransTimer || cmd.val > MAX_AdvRetransTimer) { - flog(LOG_ERR, "(privsep) %s: RetransTimer (%u) is not within the defined bounds, ignoring", cmd.iface, cmd.val); - break; - } - ret = set_interface_var(cmd.iface, PROC_SYS_IP6_RETRANSTIMER_MS, "RetransTimer (ms)", cmd.val); - if (ret == 0) - break; - set_interface_var(cmd.iface, PROC_SYS_IP6_RETRANSTIMER, "RetransTimer", cmd.val / 1000 * USER_HZ); /* XXX user_hz */ - break; - - default: - /* Bad command */ - break; - } - } -} - -/* Return 1 if privsep is currently enabled */ -int -privsep_enabled(void) -{ - if (pfd < 0) - return 0; - return 1; -} - -/* Fork to create privileged process connected by a pipe */ -int -privsep_init(void) -{ - int pipefds[2]; - pid_t pid; - - if (privsep_enabled()) - return 0; - - if (pipe(pipefds) != 0) { - flog(LOG_ERR, "Couldn't create privsep pipe."); - return (-1); - } - - pid = fork(); - if (pid == -1) { - flog(LOG_ERR, "Couldn't fork for privsep."); - return (-1); - } - - if (pid == 0) { - int nullfd; - - /* This will be the privileged child */ - close(pipefds[1]); - pfd = pipefds[0]; - - /* Detach from stdio */ - nullfd = open("/dev/null", O_RDONLY); - if (nullfd < 0) { - perror("/dev/null"); - close(pfd); - _exit(1); - } - dup2(nullfd, 0); - dup2(nullfd, 1); - /* XXX: we'll keep stderr open in debug mode for better logging */ - if (get_debuglevel() == 0) - dup2(nullfd, 2); - - privsep_read_loop(); - close(pfd); - flog(LOG_ERR, "Exiting, privsep_read_loop is complete.\n"); - _exit(0); - } - - /* Continue execution (will drop privileges soon) */ - close(pipefds[0]); - pfd = pipefds[1]; - - return 0; -} - -/* Interface calls for the unprivileged process */ -int -privsep_interface_linkmtu(const char *iface, uint32_t mtu) -{ - struct privsep_command cmd; - cmd.type = SET_INTERFACE_LINKMTU; - strncpy(cmd.iface, iface, sizeof(cmd.iface)); - cmd.val = mtu; - - if (writen(pfd, &cmd, sizeof(cmd)) != sizeof(cmd)) - return (-1); - return 0; -} - -int -privsep_interface_curhlim(const char *iface, uint32_t hlim) -{ - struct privsep_command cmd; - cmd.type = SET_INTERFACE_CURHLIM; - strncpy(cmd.iface, iface, sizeof(cmd.iface)); - cmd.val = hlim; - if (writen(pfd, &cmd, sizeof(cmd)) != sizeof(cmd)) - return (-1); - return 0; -} - -int -privsep_interface_reachtime(const char *iface, uint32_t rtime) -{ - struct privsep_command cmd; - cmd.type = SET_INTERFACE_REACHTIME; - strncpy(cmd.iface, iface, sizeof(cmd.iface)); - cmd.val = rtime; - if (writen(pfd, &cmd, sizeof(cmd)) != sizeof(cmd)) - return (-1); - return 0; -} - -int -privsep_interface_retranstimer(const char *iface, uint32_t rettimer) -{ - struct privsep_command cmd; - cmd.type = SET_INTERFACE_RETRANSTIMER; - strncpy(cmd.iface, iface, sizeof(cmd.iface)); - cmd.val = rettimer; - if (writen(pfd, &cmd, sizeof(cmd)) != sizeof(cmd)) - return (-1); - return 0; -} diff --git a/release/src/router/radvd/process.c b/release/src/router/radvd/process.c deleted file mode 100644 index 75e6aae587..0000000000 --- a/release/src/router/radvd/process.c +++ /dev/null @@ -1,491 +0,0 @@ -/* - * $Id: process.c,v 1.26.2.3 2011/08/22 12:30:47 reubenhwk Exp $ - * - * Authors: - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" - -static void process_rs(struct Interface *, unsigned char *msg, - int len, struct sockaddr_in6 *); -static void process_ra(struct Interface *, unsigned char *msg, int len, - struct sockaddr_in6 *); -static int addr_match(struct in6_addr *a1, struct in6_addr *a2, - int prefixlen); - -void -process(struct Interface *ifacel, unsigned char *msg, int len, - struct sockaddr_in6 *addr, struct in6_pktinfo *pkt_info, int hoplimit) -{ - struct Interface *iface; - struct icmp6_hdr *icmph; - char addr_str[INET6_ADDRSTRLEN]; - - print_addr(&addr->sin6_addr, addr_str); - - if ( ! pkt_info ) - { - flog(LOG_WARNING, "received packet with no pkt_info from %s!", addr_str ); - return; - } - - /* - * can this happen? - */ - - if (len < sizeof(struct icmp6_hdr)) - { - flog(LOG_WARNING, "received icmpv6 packet with invalid length (%d) from %s", - len, addr_str); - return; - } - - icmph = (struct icmp6_hdr *) msg; - - if (icmph->icmp6_type != ND_ROUTER_SOLICIT && - icmph->icmp6_type != ND_ROUTER_ADVERT) - { - /* - * We just want to listen to RSs and RAs - */ - - flog(LOG_ERR, "icmpv6 filter failed"); - return; - } - - if (icmph->icmp6_type == ND_ROUTER_ADVERT) - { - if (len < sizeof(struct nd_router_advert)) { - flog(LOG_WARNING, "received icmpv6 RA packet with invalid length (%d) from %s", - len, addr_str); - return; - } - - if (!IN6_IS_ADDR_LINKLOCAL(&addr->sin6_addr)) { - flog(LOG_WARNING, "received icmpv6 RA packet with non-linklocal source address from %s", addr_str); - return; - } - } - - if (icmph->icmp6_type == ND_ROUTER_SOLICIT) - { - if (len < sizeof(struct nd_router_solicit)) { - flog(LOG_WARNING, "received icmpv6 RS packet with invalid length (%d) from %s", - len, addr_str); - return; - } - } - - if (icmph->icmp6_code != 0) - { - flog(LOG_WARNING, "received icmpv6 RS/RA packet with invalid code (%d) from %s", - icmph->icmp6_code, addr_str); - return; - } - - dlog(LOG_DEBUG, 4, "if_index %u", pkt_info->ipi6_ifindex); - - /* get iface by received if_index */ - - for (iface = ifacel; iface; iface=iface->next) - { - if (iface->if_index == pkt_info->ipi6_ifindex) - { - break; - } - } - - if (iface == NULL) - { - dlog(LOG_DEBUG, 2, "received packet from unknown interface: %d", - pkt_info->ipi6_ifindex); - return; - } - - if (hoplimit != 255) - { - print_addr(&addr->sin6_addr, addr_str); - flog(LOG_WARNING, "received RS or RA with invalid hoplimit %d from %s", - hoplimit, addr_str); - return; - } - - if (!iface->AdvSendAdvert) - { - dlog(LOG_DEBUG, 2, "AdvSendAdvert is off for %s", iface->Name); - return; - } - - dlog(LOG_DEBUG, 4, "found Interface: %s", iface->Name); - - if (icmph->icmp6_type == ND_ROUTER_SOLICIT) - { - dlog(LOG_DEBUG, 2, "received RS from %s", addr_str); - process_rs(iface, msg, len, addr); - } - else if (icmph->icmp6_type == ND_ROUTER_ADVERT) - { - dlog(LOG_DEBUG, 2, "received RA from %s", addr_str); - process_ra(iface, msg, len, addr); - } -} - -static void -process_rs(struct Interface *iface, unsigned char *msg, int len, - struct sockaddr_in6 *addr) -{ - double delay; - double next; - struct timeval tv; - uint8_t *opt_str; - - /* validation */ - len -= sizeof(struct nd_router_solicit); - - opt_str = (uint8_t *)(msg + sizeof(struct nd_router_solicit)); - - while (len > 0) - { - int optlen; - - if (len < 2) - { - flog(LOG_WARNING, "trailing garbage in RS"); - return; - } - - optlen = (opt_str[1] << 3); - - if (optlen == 0) - { - flog(LOG_WARNING, "zero length option in RS"); - return; - } - else if (optlen > len) - { - flog(LOG_WARNING, "option length greater than total length in RS"); - return; - } - - if (*opt_str == ND_OPT_SOURCE_LINKADDR && - IN6_IS_ADDR_UNSPECIFIED(&addr->sin6_addr)) { - flog(LOG_WARNING, "received icmpv6 RS packet with unspecified source address and there is a lladdr option"); - return; - } - - len -= optlen; - opt_str += optlen; - } - - gettimeofday(&tv, NULL); - - delay = MAX_RA_DELAY_TIME * rand() / (RAND_MAX +1.0); - - if (iface->UnicastOnly) { - dlog(LOG_DEBUG, 5, "random mdelay for %s: %g seconds.", iface->Name, delay/1000.0); - mdelay(delay); - send_ra_forall(iface, &addr->sin6_addr); - } - else if ( timevaldiff(&tv, &iface->last_multicast) / 1000.0 < iface->MinDelayBetweenRAs ) { - /* last RA was sent only a few moments ago, don't send another immediately. */ - next = iface->MinDelayBetweenRAs - (tv.tv_sec + tv.tv_usec / 1000000.0) + (iface->last_multicast.tv_sec + iface->last_multicast.tv_usec / 1000000.0) + delay/1000.0; - iface->next_multicast = next_timeval(next); - } - else { - /* no RA sent in a while, send a multicast reply */ - send_ra_forall(iface, NULL); - next = rand_between(iface->MinRtrAdvInterval, iface->MaxRtrAdvInterval); - iface->next_multicast = next_timeval(next); - } -} - -/* - * check router advertisements according to RFC 4861, 6.2.7 - */ -static void -process_ra(struct Interface *iface, unsigned char *msg, int len, - struct sockaddr_in6 *addr) -{ - struct nd_router_advert *radvert; - char addr_str[INET6_ADDRSTRLEN]; - uint8_t *opt_str; - - print_addr(&addr->sin6_addr, addr_str); - - radvert = (struct nd_router_advert *) msg; - - if ((radvert->nd_ra_curhoplimit && iface->AdvCurHopLimit) && - (radvert->nd_ra_curhoplimit != iface->AdvCurHopLimit)) - { - flog(LOG_WARNING, "our AdvCurHopLimit on %s doesn't agree with %s", - iface->Name, addr_str); - } - - if ((radvert->nd_ra_flags_reserved & ND_RA_FLAG_MANAGED) && !iface->AdvManagedFlag) - { - flog(LOG_WARNING, "our AdvManagedFlag on %s doesn't agree with %s", - iface->Name, addr_str); - } - - if ((radvert->nd_ra_flags_reserved & ND_RA_FLAG_OTHER) && !iface->AdvOtherConfigFlag) - { - flog(LOG_WARNING, "our AdvOtherConfigFlag on %s doesn't agree with %s", - iface->Name, addr_str); - } - - /* note: we don't check the default router preference here, because they're likely different */ - - if ((radvert->nd_ra_reachable && iface->AdvReachableTime) && - (ntohl(radvert->nd_ra_reachable) != iface->AdvReachableTime)) - { - flog(LOG_WARNING, "our AdvReachableTime on %s doesn't agree with %s", - iface->Name, addr_str); - } - - if ((radvert->nd_ra_retransmit && iface->AdvRetransTimer) && - (ntohl(radvert->nd_ra_retransmit) != iface->AdvRetransTimer)) - { - flog(LOG_WARNING, "our AdvRetransTimer on %s doesn't agree with %s", - iface->Name, addr_str); - } - - len -= sizeof(struct nd_router_advert); - - if (len == 0) - return; - - opt_str = (uint8_t *)(msg + sizeof(struct nd_router_advert)); - - while (len > 0) - { - int optlen; - struct nd_opt_prefix_info *pinfo; - struct nd_opt_rdnss_info_local *rdnssinfo; - struct nd_opt_dnssl_info_local *dnsslinfo; - struct nd_opt_mtu *mtu; - struct AdvPrefix *prefix; - struct AdvRDNSS *rdnss; - char prefix_str[INET6_ADDRSTRLEN]; - char rdnss_str[INET6_ADDRSTRLEN]; - char suffix[256]; - int offset, label_len; - uint32_t preferred, valid, count; - - if (len < 2) - { - flog(LOG_ERR, "trailing garbage in RA on %s from %s", - iface->Name, addr_str); - break; - } - - optlen = (opt_str[1] << 3); - - if (optlen == 0) - { - flog(LOG_ERR, "zero length option in RA on %s from %s", - iface->Name, addr_str); - break; - } - else if (optlen > len) - { - flog(LOG_ERR, "option length greater than total" - " length in RA on %s from %s", - iface->Name, addr_str); - break; - } - - switch (*opt_str) - { - case ND_OPT_MTU: - mtu = (struct nd_opt_mtu *)opt_str; - - if (iface->AdvLinkMTU && (ntohl(mtu->nd_opt_mtu_mtu) != iface->AdvLinkMTU)) - { - flog(LOG_WARNING, "our AdvLinkMTU on %s doesn't agree with %s", - iface->Name, addr_str); - } - break; - case ND_OPT_PREFIX_INFORMATION: - pinfo = (struct nd_opt_prefix_info *) opt_str; - preferred = ntohl(pinfo->nd_opt_pi_preferred_time); - valid = ntohl(pinfo->nd_opt_pi_valid_time); - - prefix = iface->AdvPrefixList; - while (prefix) - { - if (prefix->enabled && - (prefix->PrefixLen == pinfo->nd_opt_pi_prefix_len) && - addr_match(&prefix->Prefix, &pinfo->nd_opt_pi_prefix, - prefix->PrefixLen)) - { - print_addr(&prefix->Prefix, prefix_str); - - if (!prefix->DecrementLifetimesFlag && valid != prefix->AdvValidLifetime) - { - flog(LOG_WARNING, "our AdvValidLifetime on" - " %s for %s doesn't agree with %s", - iface->Name, - prefix_str, - addr_str - ); - } - if (!prefix->DecrementLifetimesFlag && preferred != prefix->AdvPreferredLifetime) - { - flog(LOG_WARNING, "our AdvPreferredLifetime on" - " %s for %s doesn't agree with %s", - iface->Name, - prefix_str, - addr_str - ); - } - } - - prefix = prefix->next; - } - break; - case ND_OPT_ROUTE_INFORMATION: - /* not checked: these will very likely vary a lot */ - break; - case ND_OPT_SOURCE_LINKADDR: - /* not checked */ - break; - case ND_OPT_TARGET_LINKADDR: - case ND_OPT_REDIRECTED_HEADER: - flog(LOG_ERR, "invalid option %d in RA on %s from %s", - (int)*opt_str, iface->Name, addr_str); - break; - /* Mobile IPv6 extensions */ - case ND_OPT_RTR_ADV_INTERVAL: - case ND_OPT_HOME_AGENT_INFO: - /* not checked */ - break; - case ND_OPT_RDNSS_INFORMATION: - rdnssinfo = (struct nd_opt_rdnss_info_local *) opt_str; - count = rdnssinfo->nd_opt_rdnssi_len; - - /* Check the RNDSS addresses received */ - switch (count) { - case 7: - rdnss = iface->AdvRDNSSList; - if (!check_rdnss_presence(rdnss, &rdnssinfo->nd_opt_rdnssi_addr3 )) { - /* no match found in iface->AdvRDNSSList */ - print_addr(&rdnssinfo->nd_opt_rdnssi_addr3, rdnss_str); - flog(LOG_WARNING, "RDNSS address %s received on %s from %s is not advertised by us", - rdnss_str, iface->Name, addr_str); - } - /* FALLTHROUGH */ - case 5: - rdnss = iface->AdvRDNSSList; - if (!check_rdnss_presence(rdnss, &rdnssinfo->nd_opt_rdnssi_addr2 )) { - /* no match found in iface->AdvRDNSSList */ - print_addr(&rdnssinfo->nd_opt_rdnssi_addr2, rdnss_str); - flog(LOG_WARNING, "RDNSS address %s received on %s from %s is not advertised by us", - rdnss_str, iface->Name, addr_str); - } - /* FALLTHROUGH */ - case 3: - rdnss = iface->AdvRDNSSList; - if (!check_rdnss_presence(rdnss, &rdnssinfo->nd_opt_rdnssi_addr1 )) { - /* no match found in iface->AdvRDNSSList */ - print_addr(&rdnssinfo->nd_opt_rdnssi_addr1, rdnss_str); - flog(LOG_WARNING, "RDNSS address %s received on %s from %s is not advertised by us", - rdnss_str, iface->Name, addr_str); - } - - break; - default: - flog(LOG_ERR, "invalid len %i in RDNSS option on %s from %s", - count, iface->Name, addr_str); - } - - break; - case ND_OPT_DNSSL_INFORMATION: - dnsslinfo = (struct nd_opt_dnssl_info_local *) opt_str; - suffix[0] = '\0'; - for (offset = 0; offset < (dnsslinfo->nd_opt_dnssli_len-1)*8;) { - label_len = dnsslinfo->nd_opt_dnssli_suffixes[offset++]; - - if (label_len == 0) { - /* - * Ignore empty suffixes. They're - * probably just padding... - */ - if (suffix[0] == '\0') - continue; - - if (!check_dnssl_presence(iface->AdvDNSSLList, suffix)) { - flog(LOG_WARNING, "DNSSL suffix %s received on %s from %s is not advertised by us", - suffix, iface->Name, addr_str); - } - - suffix[0] = '\0'; - continue; - } - - if ((sizeof(suffix) - strlen(suffix)) < (label_len + 2)) { - flog(LOG_ERR, "oversized suffix in DNSSL option on %s from %s", - iface->Name, addr_str); - break; - } - - if (suffix[0] != '\0') - strcat(suffix, "."); - strncat(suffix, &dnsslinfo->nd_opt_dnssli_suffixes[offset], label_len); - offset += label_len; - } - break; - default: - dlog(LOG_DEBUG, 1, "unknown option %d in RA on %s from %s", - (int)*opt_str, iface->Name, addr_str); - break; - } - - len -= optlen; - opt_str += optlen; - } -} - -static int -addr_match(struct in6_addr *a1, struct in6_addr *a2, int prefixlen) -{ - unsigned int pdw; - unsigned int pbi; - - pdw = prefixlen >> 0x05; /* num of whole uint32_t in prefix */ - pbi = prefixlen & 0x1f; /* num of bits in incomplete uint32_t in prefix */ - - if (pdw) - { - if (memcmp(a1, a2, pdw << 2)) - return 0; - } - - if (pbi) - { - uint32_t w1, w2; - uint32_t mask; - - w1 = *((uint32_t *)a1 + pdw); - w2 = *((uint32_t *)a2 + pdw); - - mask = htonl(((uint32_t) 0xffffffff) << (0x20 - pbi)); - - if ((w1 ^ w2) & mask) - return 0; - } - - return 1; -} - diff --git a/release/src/router/radvd/radvd.8.man b/release/src/router/radvd/radvd.8.man deleted file mode 100644 index 25a1173260..0000000000 --- a/release/src/router/radvd/radvd.8.man +++ /dev/null @@ -1,188 +0,0 @@ -.\" -.\" $Id: radvd.8.man,v 1.15 2011/01/05 08:19:23 psavola Exp $ -.\" -.\" Authors: -.\" Lars Fenneberg -.\" -.\" This software is Copyright 1996-2000 by the above mentioned author(s), -.\" All Rights Reserved. -.\" -.\" The license which is distributed with this software in the file COPYRIGHT -.\" applies to this software. If your distribution is missing this file, you -.\" may request it from . -.\" -.\" -.\" -.TH RADVD 8 "14 Dec 2010" "radvd @VERSION@" "" -.SH NAME -radvd \- router advertisement daemon for IPv6 -.SH SYNOPSIS -.B radvd -.B "[ \-hsvc ]" -.BI "[ \-d " debuglevel " ]" -.BI "[ \-C " configfile " ]" -.BI "[ \-p " pidfile " ]" -.BI "[ \-m " logmethod " ]" -.BI "[ \-l " logfile " ]" -.BI "[ \-f " facility " ]" -.BI "[ \-t " chrootdir " ]" -.BI "[ \-u " username " ]" - -.SH DESCRIPTION -.B radvd -is the router advertisement daemon for IPv6. It listens to router -solicitations and sends router advertisements as described in -"Neighbor Discovery for IP Version 6 (IPv6)" (RFC 4861). -With these advertisements hosts can automatically configure their -addresses and some other parameters. They also can choose a default -router based on these advertisements. - -Note that if debugging is not enabled, -.B radvd -will not start if IPv6 forwarding is disabled. IPv6 forwarding can be -controlled via sysctl(8), -.B net.ipv6.conf.all.forwarding -on Linux or -.B net.inet6.ip6.forwarding -on BSD. - -Similarly, the configuration file must not be writable by others, and if -non-root operation is requested, not even by self/own group. - -.SH OPTIONS - -For every one character option there is also a long option, which -is listed right next to the "short" option name: - -.TP -.BR "\-v" , " \-\-version" -Displays the version of -.I radvd -and then aborts. -.TP -.BR "\-h" , " \-\-help" -Displays a short usage description and then aborts. -.TP -.BR "\-s" , " \-\-singleprocess" -On Linux if -.I username -is specified, privilege separation is enabled and there will be -two processes. -This option disables privilege separation, and as a result, -the non-privileged radvd process does not have permissions to -change interface configuration. -.TP -.BR "\-c" , " \-\-configtest" -Test configuration and do startup tests and then exit. -.TP -.BR "\-d " debuglevel, " \-\-debug " debuglevel -With this option you turn on debugging information. The debugging level is -an integer in the range from 1 to 5, from quiet to very verbose. A -debugging level of 0 completely turns off debugging. If a debugging level -greater than 0 is used, -.I radvd -doesn't background itself on start. The default debugging level is 0. -.TP -.BR "\-C " configfile, " \-\-config " configfile -Specifies an alternate config file. Normally the compiled in default -.I @PATH_RADVD_CONF@ -is used. -.TP -.BR "\-p " pidfile, " \-\-pidfile " pidfile -Specifies an alternate pidfile. Normally the compiled in default -.I @PATH_RADVD_PID@ -is used. -.TP -.BR "\-m " method, " \-\-logmethod " method -Specifies the logging method to use. Possibly values are: -.RS -.TP -.B none -Completely disables any logging. -.TP -.B logfile -Logs to the logfile which is specified by the -.I \-l -option. If no logfile is specified on the command line, then -a compiled in default is used (see next option). -.TP -.B stderr -Logs to standard error. -.TP -.B stderr_syslog -Logs only the high messages (of at least LOG_ERR priority) to standard -error, and everything to syslog (default method). -.TP -.B syslog -Logs to syslog. -.RE -.PP -.TP -.BR "\-l " logfile, " \-\-logfile " logfile -Specifies the logfile to use when using the logging method -.IR logfile . -The default logfile is -.IR @PATH_RADVD_LOG@ . -.TP -.BR "\-f " facility, " \-\-facility " facility -Specifies the facility (as an integer) when using syslog logging. Default -is @LOG_FACILITY@. -.TP -.BR "\-t " chrootdir, " \-\-chrootdir " chrootdir -If specified, switches to -.I chrootdir -before doing anything else. This directory and its -subdirectories must have been populated first. -For security reasons, -.I \-u -must always be used when using -.IR chrootdir . - -Note that on Linux -.I radvd -requires access to the -.I /proc -filesystem, -so it is more challenging to set up the chroot environment. -.TP -.BR "\-u " username, " \-\-username " username -If specified, drops root privileges and changes user ID to -.I username -and group ID to the primary group of -.IR username . -This is recommended for security reasons. -You might also need to use -.I \-p -to point to a file in a -.I username --writable directory (e.g. /var/run/radvd/radvd.pid). -.SH FILES - -.nf -@sbindir@/radvd -@PATH_RADVD_CONF@ -@PATH_RADVD_PID@ -@PATH_RADVD_LOG@ -.fi -.SH BUGS - -There certainly are some bugs. If you find them or have other -suggestions please contact Pekka Savola . - -.SH "SEE ALSO" - -.BR radvd.conf (5), -.BR radvdump (8) -.SH AUTHORS - -.nf -Pedro Roque - wrote first version for Linux -Lars Fenneberg - previous maintainer -Nathan Lutchansky - previous maintainer -Pekka Savola - current maintainer -Craig Metz - port to NRL's IPv6 code for BSD4.4 -Marko Myllynen - RFC 2461 update, Mobile IPv6 support -Jim Paris - Privilege separation support -Reuben Hawkins - Many fixes and cleanups -Pierre Ossman - RFC6106 (DNSSL) support -.fi diff --git a/release/src/router/radvd/radvd.c b/release/src/router/radvd/radvd.c deleted file mode 100644 index e21459e188..0000000000 --- a/release/src/router/radvd/radvd.c +++ /dev/null @@ -1,862 +0,0 @@ -/* - * $Id: radvd.c,v 1.61.2.1 2011/08/22 12:28:46 reubenhwk Exp $ - * - * Authors: - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996-2000 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" -#include "pathnames.h" - -#ifdef HAVE_NETLINK -#include "netlink.h" -#endif - -#include - -struct Interface *IfaceList = NULL; - -#ifdef HAVE_GETOPT_LONG - -char usage_str[] = { -"\n" -" -c, --configtest Parse the config file and exit.\n" -" -C, --config=PATH Sets the config file. Default is /etc/radvd.conf.\n" -" -d, --debug=NUM Sets the debug level. Values can be 1, 2, 3, 4 or 5.\n" -" -f, --facility=NUM Sets the logging facility.\n" -" -h, --help Show this help screen.\n" -" -l, --logfile=PATH Sets the log file.\n" -" -m, --logmethod=X Sets the log method to one of: syslog, stderr, stderr_syslog, logfile, or none.\n" -" -p, --pidfile=PATH Sets the pid file.\n" -" -s, --singleprocess Use privsep.\n" -" -t, --chrootdir=PATH Chroot to the specified path.\n" -" -u, --username=USER Switch to the specified user.\n" -" -v, --version Print the version and quit.\n" -}; - -struct option prog_opt[] = { - {"debug", 1, 0, 'd'}, - {"configtest", 0, 0, 'c'}, - {"config", 1, 0, 'C'}, - {"pidfile", 1, 0, 'p'}, - {"logfile", 1, 0, 'l'}, - {"logmethod", 1, 0, 'm'}, - {"facility", 1, 0, 'f'}, - {"username", 1, 0, 'u'}, - {"chrootdir", 1, 0, 't'}, - {"version", 0, 0, 'v'}, - {"help", 0, 0, 'h'}, - {"singleprocess", 0, 0, 's'}, - {NULL, 0, 0, 0} -}; - -#else - -char usage_str[] = - "[-hsvc] [-d level] [-C config_file] [-m log_method] [-l log_file]\n" - "\t[-f facility] [-p pid_file] [-u username] [-t chrootdir]"; - -#endif - -extern FILE *yyin; - -char *conf_file = NULL; -char *pname; -int sock = -1; - -volatile int sighup_received = 0; -volatile int sigterm_received = 0; -volatile int sigint_received = 0; -volatile int sigusr1_received = 0; - -void sighup_handler(int sig); -void sigterm_handler(int sig); -void sigint_handler(int sig); -void sigusr1_handler(int sig); -void timer_handler(void *data); -void config_interface(void); -void kickoff_adverts(void); -void stop_adverts(void); -void version(void); -void usage(void); -int drop_root_privileges(const char *); -int readin_config(char *); -int check_conffile_perm(const char *, const char *); -void main_loop(void); - -int -main(int argc, char *argv[]) -{ - char pidstr[16]; - ssize_t ret; - int c, log_method; - char *logfile, *pidfile; - int facility, fd; - char *username = NULL; - char *chrootdir = NULL; - int configtest = 0; - int singleprocess = 0; -#ifdef HAVE_GETOPT_LONG - int opt_idx; -#endif - - pname = ((pname=strrchr(argv[0],'/')) != NULL)?pname+1:argv[0]; - - srand((unsigned int)time(NULL)); - - log_method = L_STDERR_SYSLOG; - logfile = PATH_RADVD_LOG; - conf_file = PATH_RADVD_CONF; - facility = LOG_FACILITY; - pidfile = PATH_RADVD_PID; - - /* parse args */ -#define OPTIONS_STR "d:C:l:m:p:t:u:vhcs" -#ifdef HAVE_GETOPT_LONG - while ((c = getopt_long(argc, argv, OPTIONS_STR, prog_opt, &opt_idx)) > 0) -#else - while ((c = getopt(argc, argv, OPTIONS_STR)) > 0) -#endif - { - switch (c) { - case 'C': - conf_file = optarg; - break; - case 'd': - set_debuglevel(atoi(optarg)); - break; - case 'f': - facility = atoi(optarg); - break; - case 'l': - logfile = optarg; - break; - case 'p': - pidfile = optarg; - break; - case 'm': - if (!strcmp(optarg, "syslog")) - { - log_method = L_SYSLOG; - } - else if (!strcmp(optarg, "stderr_syslog")) - { - log_method = L_STDERR_SYSLOG; - } - else if (!strcmp(optarg, "stderr")) - { - log_method = L_STDERR; - } - else if (!strcmp(optarg, "logfile")) - { - log_method = L_LOGFILE; - } - else if (!strcmp(optarg, "none")) - { - log_method = L_NONE; - } - else - { - fprintf(stderr, "%s: unknown log method: %s\n", pname, optarg); - exit(1); - } - break; - case 't': - chrootdir = strdup(optarg); - break; - case 'u': - username = strdup(optarg); - break; - case 'v': - version(); - break; - case 'c': - configtest = 1; - break; - case 's': - singleprocess = 1; - break; - case 'h': - usage(); -#ifdef HAVE_GETOPT_LONG - case ':': - fprintf(stderr, "%s: option %s: parameter expected\n", pname, - prog_opt[opt_idx].name); - exit(1); -#endif - case '?': - exit(1); - } - } - - if (chrootdir) { - if (!username) { - fprintf(stderr, "Chroot as root is not safe, exiting\n"); - exit(1); - } - - if (chroot(chrootdir) == -1) { - perror("chroot"); - exit (1); - } - - if (chdir("/") == -1) { - perror("chdir"); - exit (1); - } - /* username will be switched later */ - } - - if (configtest) { - log_method = L_STDERR; - } - - if (log_open(log_method, pname, logfile, facility) < 0) { - perror("log_open"); - exit(1); - } - - if (!configtest) { - flog(LOG_INFO, "version %s started", VERSION); - } - - /* get a raw socket for sending and receiving ICMPv6 messages */ - sock = open_icmpv6_socket(); - if (sock < 0) { - perror("open_icmpv6_socket"); - exit(1); - } - - /* check that 'other' cannot write the file - * for non-root, also that self/own group can't either - */ - if (check_conffile_perm(username, conf_file) < 0) { - if (get_debuglevel() == 0) { - flog(LOG_ERR, "Exiting, permissions on conf_file invalid.\n"); - exit(1); - } - else - flog(LOG_WARNING, "Insecure file permissions, but continuing anyway"); - } - - /* if we know how to do it, check whether forwarding is enabled */ - if (check_ip6_forwarding()) { - flog(LOG_WARNING, "IPv6 forwarding seems to be disabled, but continuing anyway."); - } - - /* parse config file */ - if (readin_config(conf_file) < 0) { - flog(LOG_ERR, "Exiting, failed to read config file.\n"); - exit(1); - } - - if (configtest) { - fprintf(stderr, "Syntax OK\n"); - exit(0); - } - - /* drop root privileges if requested. */ - if (username) { - if (!singleprocess) { - dlog(LOG_DEBUG, 3, "Initializing privsep"); - if (privsep_init() < 0) - flog(LOG_WARNING, "Failed to initialize privsep."); - } - - if (drop_root_privileges(username) < 0) { - perror("drop_root_privileges"); - exit(1); - } - } - - if ((fd = open(pidfile, O_RDONLY, 0)) > 0) - { - ret = read(fd, pidstr, sizeof(pidstr) - 1); - if (ret < 0) - { - flog(LOG_ERR, "cannot read radvd pid file, terminating: %s", strerror(errno)); - exit(1); - } - pidstr[ret] = '\0'; - if (!kill((pid_t)atol(pidstr), 0)) - { - flog(LOG_ERR, "radvd already running, terminating."); - exit(1); - } - close(fd); - fd = open(pidfile, O_CREAT|O_TRUNC|O_WRONLY, 0644); - } - else /* FIXME: not atomic if pidfile is on an NFS mounted volume */ - fd = open(pidfile, O_CREAT|O_EXCL|O_WRONLY, 0644); - - if (fd < 0) - { - flog(LOG_ERR, "cannot create radvd pid file, terminating: %s", strerror(errno)); - exit(1); - } - - /* - * okay, config file is read in, socket and stuff is setup, so - * lets fork now... - */ - - if (get_debuglevel() == 0) { - - /* Detach from controlling terminal */ - if (daemon(0, 0) < 0) - perror("daemon"); - - /* close old logfiles, including stderr */ - log_close(); - - /* reopen logfiles, but don't log to stderr unless explicitly requested */ - if (log_method == L_STDERR_SYSLOG) - log_method = L_SYSLOG; - if (log_open(log_method, pname, logfile, facility) < 0) { - perror("log_open"); - exit(1); - } - - } - - /* - * config signal handlers - */ - signal(SIGHUP, sighup_handler); - signal(SIGTERM, sigterm_handler); - signal(SIGINT, sigint_handler); - signal(SIGUSR1, sigusr1_handler); - - snprintf(pidstr, sizeof(pidstr), "%ld\n", (long)getpid()); - - ret = write(fd, pidstr, strlen(pidstr)); - if (ret != strlen(pidstr)) - { - flog(LOG_ERR, "cannot write radvd pid file, terminating: %s", strerror(errno)); - exit(1); - } - - close(fd); - - config_interface(); - kickoff_adverts(); - main_loop(); - stop_adverts(); - unlink(pidfile); - - return 0; -} - -void main_loop(void) -{ - struct pollfd fds[2]; - - memset(fds, 0, sizeof(fds)); - - fds[0].fd = sock; - fds[0].events = POLLIN; - fds[0].revents = 0; - -#if HAVE_NETLINK - fds[1].fd = netlink_socket(); - fds[1].events = POLLIN; - fds[1].revents = 0; -#else - fds[1].fd = -1; - fds[1].events = 0; - fds[1].revents = 0; -#endif - - for (;;) { - struct Interface *next = NULL; - struct Interface *iface; - int timeout = -1; - int rc; - - if (IfaceList) { - timeout = next_time_msec(IfaceList); - next = IfaceList; - for (iface = IfaceList; iface; iface = iface->next) { - int t; - t = next_time_msec(iface); - if (timeout > t) { - timeout = t; - next = iface; - } - } - } - - dlog(LOG_DEBUG, 5, "polling for %g seconds.", timeout/1000.0); - - rc = poll(fds, sizeof(fds)/sizeof(fds[0]), timeout); - - if (rc > 0) { - if (fds[0].revents & (POLLERR | POLLHUP | POLLNVAL)) { - flog(LOG_WARNING, "socket error on fds[0].fd"); - } - else if (fds[0].revents & POLLIN) { - int len, hoplimit; - struct sockaddr_in6 rcv_addr; - struct in6_pktinfo *pkt_info = NULL; - unsigned char msg[MSG_SIZE_RECV]; - - len = recv_rs_ra(msg, &rcv_addr, &pkt_info, &hoplimit); - if (len > 0) { - process(IfaceList, msg, len, - &rcv_addr, pkt_info, hoplimit); - } - } -#ifdef HAVE_NETLINK - if (fds[1].revents & (POLLERR | POLLHUP | POLLNVAL)) { - flog(LOG_WARNING, "socket error on fds[1].fd"); - } - else if (fds[1].revents & POLLIN) { - process_netlink_msg(fds[1].fd); - } -#endif - } - else if ( rc == 0 ) { - if (next) - timer_handler(next); - } - else if ( rc == -1 && errno != EINTR ) { - flog(LOG_ERR, "poll error: %s", strerror(errno)); - } - - if (sigterm_received || sigint_received) { - flog(LOG_WARNING, "Exiting, sigterm or sigint received.\n"); - break; - } - - if (sighup_received) - { - reload_config(); - sighup_received = 0; - } - - if (sigusr1_received) - { - reset_prefix_lifetimes(); - sigusr1_received = 0; - } - - } -} - -void -timer_handler(void *data) -{ - struct Interface *iface = (struct Interface *) data; - double next; - - dlog(LOG_DEBUG, 4, "timer_handler called for %s", iface->Name); - - if (send_ra_forall(iface, NULL) != 0) { - return; - } - - next = rand_between(iface->MinRtrAdvInterval, iface->MaxRtrAdvInterval); - - if (iface->init_racount < MAX_INITIAL_RTR_ADVERTISEMENTS) - { - iface->init_racount++; - next = min(MAX_INITIAL_RTR_ADVERT_INTERVAL, next); - } - - iface->next_multicast = next_timeval(next); -} - -void -config_interface(void) -{ - struct Interface *iface; - for(iface=IfaceList; iface; iface=iface->next) - { - if (iface->AdvLinkMTU) - set_interface_linkmtu(iface->Name, iface->AdvLinkMTU); - if (iface->AdvCurHopLimit) - set_interface_curhlim(iface->Name, iface->AdvCurHopLimit); - if (iface->AdvReachableTime) - set_interface_reachtime(iface->Name, iface->AdvReachableTime); - if (iface->AdvRetransTimer) - set_interface_retranstimer(iface->Name, iface->AdvRetransTimer); - } -} - -void -kickoff_adverts(void) -{ - struct Interface *iface; - - /* - * send initial advertisement and set timers - */ - - for(iface=IfaceList; iface; iface=iface->next) - { - double next; - - - gettimeofday(&iface->last_ra_time, NULL); - - if( iface->UnicastOnly ) - continue; - - gettimeofday(&iface->last_multicast, NULL); - - if (!iface->AdvSendAdvert) - continue; - - /* send an initial advertisement */ - if (send_ra_forall(iface, NULL) == 0) { - - iface->init_racount++; - - next = min(MAX_INITIAL_RTR_ADVERT_INTERVAL, iface->MaxRtrAdvInterval); - iface->next_multicast = next_timeval(next); - } - } -} - -void -stop_adverts(void) -{ - struct Interface *iface; - - /* - * send final RA (a SHOULD in RFC4861 section 6.2.5) - */ - - for (iface=IfaceList; iface; iface=iface->next) { - if( ! iface->UnicastOnly ) { - if (iface->AdvSendAdvert) { - /* send a final advertisement with zero Router Lifetime */ - iface->cease_adv = 1; - send_ra_forall(iface, NULL); - } - } - } -} - -void reload_config(void) -{ - struct Interface *iface; - - flog(LOG_INFO, "attempting to reread config file"); - - dlog(LOG_DEBUG, 4, "reopening log"); - if (log_reopen() < 0) { - perror("log_reopen"); - exit(1); - } - - iface=IfaceList; - while(iface) - { - struct Interface *next_iface = iface->next; - struct AdvPrefix *prefix; - struct AdvRoute *route; - struct AdvRDNSS *rdnss; - struct AdvDNSSL *dnssl; - - dlog(LOG_DEBUG, 4, "freeing interface %s", iface->Name); - - prefix = iface->AdvPrefixList; - while (prefix) - { - struct AdvPrefix *next_prefix = prefix->next; - - free(prefix); - prefix = next_prefix; - } - - route = iface->AdvRouteList; - while (route) - { - struct AdvRoute *next_route = route->next; - - free(route); - route = next_route; - } - - rdnss = iface->AdvRDNSSList; - while (rdnss) - { - struct AdvRDNSS *next_rdnss = rdnss->next; - - free(rdnss); - rdnss = next_rdnss; - } - - dnssl = iface->AdvDNSSLList; - while (dnssl) - { - struct AdvDNSSL *next_dnssl = dnssl->next; - int i; - - for (i = 0; i < dnssl->AdvDNSSLNumber; i++) - free(dnssl->AdvDNSSLSuffixes[i]); - free(dnssl->AdvDNSSLSuffixes); - free(dnssl); - - dnssl = next_dnssl; - } - - free(iface); - iface = next_iface; - } - - IfaceList = NULL; - - /* reread config file */ - if (readin_config(conf_file) < 0) { - perror("readin_config failed."); - exit(1); - } - - /* XXX: fails due to lack of permissions with non-root user */ - config_interface(); - kickoff_adverts(); - - flog(LOG_INFO, "resuming normal operation"); -} - -void -sighup_handler(int sig) -{ - /* Linux has "one-shot" signals, reinstall the signal handler */ - signal(SIGHUP, sighup_handler); - - dlog(LOG_DEBUG, 4, "sighup_handler called"); - - sighup_received = 1; -} - -void -sigterm_handler(int sig) -{ - /* Linux has "one-shot" signals, reinstall the signal handler */ - signal(SIGTERM, sigterm_handler); - - dlog(LOG_DEBUG, 4, "sigterm_handler called"); - - ++sigterm_received; - - if(sigterm_received > 1){ - dlog(LOG_ERR, 1, "sigterm_handler called %d times...aborting...", sigterm_received); - abort(); - } -} - -void -sigint_handler(int sig) -{ - /* Linux has "one-shot" signals, reinstall the signal handler */ - signal(SIGINT, sigint_handler); - - dlog(LOG_DEBUG, 4, "sigint_handler called"); - - ++sigint_received; - - if(sigint_received > 1){ - dlog(LOG_ERR, 1, "sigint_handler called %d times...aborting...", sigint_received); - abort(); - } -} - - -void reset_prefix_lifetimes(void) -{ - struct Interface *iface; - struct AdvPrefix *prefix; - char pfx_str[INET6_ADDRSTRLEN]; - - - flog(LOG_INFO, "Resetting prefix lifetimes"); - - for (iface = IfaceList; iface; iface = iface->next) - { - for (prefix = iface->AdvPrefixList; prefix; - prefix = prefix->next) - { - if (prefix->DecrementLifetimesFlag) - { - print_addr(&prefix->Prefix, pfx_str); - dlog(LOG_DEBUG, 4, "%s/%u%%%s plft reset from %u to %u secs", pfx_str, prefix->PrefixLen, iface->Name, prefix->curr_preferredlft, prefix->AdvPreferredLifetime); - dlog(LOG_DEBUG, 4, "%s/%u%%%s vlft reset from %u to %u secs", pfx_str, prefix->PrefixLen, iface->Name, prefix->curr_validlft, prefix->AdvValidLifetime); - prefix->curr_validlft = - prefix->AdvValidLifetime; - prefix->curr_preferredlft = - prefix->AdvPreferredLifetime; - } - } - - } - -} - -void sigusr1_handler(int sig) -{ - - /* Linux has "one-shot" signals, reinstall the signal handler */ - signal(SIGUSR1, sigusr1_handler); - - dlog(LOG_DEBUG, 4, "sigusr1_handler called"); - - sigusr1_received = 1; - -} - -int -drop_root_privileges(const char *username) -{ - struct passwd *pw = NULL; - pw = getpwnam(username); - if (pw) { - if (initgroups(username, pw->pw_gid) != 0 || setgid(pw->pw_gid) != 0 || setuid(pw->pw_uid) != 0) { - flog(LOG_ERR, "Couldn't change to '%.32s' uid=%d gid=%d", - username, pw->pw_uid, pw->pw_gid); - return (-1); - } - } - else { - flog(LOG_ERR, "Couldn't find user '%.32s'", username); - return (-1); - } - return 0; -} - -int -check_conffile_perm(const char *username, const char *conf_file) -{ -#if CHECK_PERM - struct stat stbuf; - struct passwd *pw = NULL; - FILE *fp = fopen(conf_file, "r"); - - if (fp == NULL) { - flog(LOG_ERR, "can't open %s: %s", conf_file, strerror(errno)); - return (-1); - } - fclose(fp); - - if (!username) - username = "root"; - - pw = getpwnam(username); - - if (stat(conf_file, &stbuf) || pw == NULL) - return (-1); - - if (stbuf.st_mode & S_IWOTH) { - flog(LOG_ERR, "Insecure file permissions (writable by others): %s", conf_file); - return (-1); - } - - /* for non-root: must not be writable by self/own group */ - if (strncmp(username, "root", 5) != 0 && - ((stbuf.st_mode & S_IWGRP && pw->pw_gid == stbuf.st_gid) || - (stbuf.st_mode & S_IWUSR && pw->pw_uid == stbuf.st_uid))) { - flog(LOG_ERR, "Insecure file permissions (writable by self/group): %s", conf_file); - return (-1); - } - - return 0; -#else - return 0; -#endif -} - -int -check_ip6_forwarding(void) -{ - int forw_sysctl[] = { SYSCTL_IP6_FORWARDING }; - int value; - size_t size = sizeof(value); - FILE *fp = NULL; - static int warned = 0; - -#ifdef __linux__ - fp = fopen(PROC_SYS_IP6_FORWARDING, "r"); - if (fp) { - int rc = fscanf(fp, "%d", &value); - if(rc != 1){ - flog(LOG_ERR, "cannot read value from %s: %s", PROC_SYS_IP6_FORWARDING, strerror(errno)); - exit(1); - } - fclose(fp); - } - else - flog(LOG_DEBUG, "Correct IPv6 forwarding procfs entry not found, " - "perhaps the procfs is disabled, " - "or the kernel interface has changed?"); -#endif /* __linux__ */ - - if (!fp && sysctl(forw_sysctl, sizeof(forw_sysctl)/sizeof(forw_sysctl[0]), - &value, &size, NULL, 0) < 0) { - flog(LOG_DEBUG, "Correct IPv6 forwarding sysctl branch not found, " - "perhaps the kernel interface has changed?"); - return(0); /* this is of advisory value only */ - } - - if (value != 1 && !warned) { - warned = 1; - flog(LOG_DEBUG, "IPv6 forwarding setting is: %u, should be 1", value); - return(-1); - } - - return(0); -} - -int -readin_config(char *fname) -{ - if ((yyin = fopen(fname, "r")) == NULL) - { - flog(LOG_ERR, "can't open %s: %s", fname, strerror(errno)); - return (-1); - } - - if (yyparse() != 0) - { - flog(LOG_ERR, "error parsing or activating the config file: %s", fname); - return (-1); - } - - fclose(yyin); - return 0; -} - -void -version(void) -{ - fprintf(stderr, "Version: %s\n\n", VERSION); - fprintf(stderr, "Compiled in settings:\n"); - fprintf(stderr, " default config file \"%s\"\n", PATH_RADVD_CONF); - fprintf(stderr, " default pidfile \"%s\"\n", PATH_RADVD_PID); - fprintf(stderr, " default logfile \"%s\"\n", PATH_RADVD_LOG); - fprintf(stderr, " default syslog facility %d\n", LOG_FACILITY); - fprintf(stderr, "Please send bug reports or suggestions to %s.\n", - CONTACT_EMAIL); - - exit(1); -} - -void -usage(void) -{ - fprintf(stderr, "usage: %s %s\n", pname, usage_str); - exit(1); -} - diff --git a/release/src/router/radvd/radvd.conf.5.man b/release/src/router/radvd/radvd.conf.5.man deleted file mode 100644 index 318c2cb60b..0000000000 --- a/release/src/router/radvd/radvd.conf.5.man +++ /dev/null @@ -1,704 +0,0 @@ -.\" -.\" $Id: radvd.conf.5.man,v 1.41 2011/05/10 21:55:10 reubenhwk Exp $ -.\" -.\" Authors: -.\" Lars Fenneberg -.\" Marko Myllynen -.\" -.\" This software is Copyright 1996-2000 by the above mentioned author(s), -.\" All Rights Reserved. -.\" -.\" The license which is distributed with this software in the file COPYRIGHT -.\" applies to this software. If your distribution is missing this file, you -.\" may request it from . -.\" -.\" -.\" -.TH RADVD.CONF 5 "4 Jan 2011" "radvd @VERSION@" "" -.SH NAME -radvd.conf \- configuration file of the router advertisement daemon -.B radvd -.SH DESCRIPTION -This file describes the information which is included in the router -advertisement (RA) of a specific interface. -.P -The file contains one or more interface definitions of the form: - -.nf -.BR "interface " "name " { - list of interface specific options - list of prefix definitions - list of clients (IPv6 addresses) to advertise to - list of route definitions - list of RDNSS definitions - list of DNSSL definitions -.B }; -.fi - -All the possible interface specific options are detailed below. Each -option has to be terminated by a semicolon. - -Prefix definitions are of the form: - -.nf -.BR "prefix " prefix / "length " { - list of prefix specific options -.B }; -.fi - -Prefix can be network prefix or the address of the inferface. -The address of interface should be used when using Mobile IPv6 -extensions. - -Special prefix "::/64" is also supported on systems that implement getifaddrs() -(on other systems, configuration activation fails and radvd exits). -When configured, radvd -picks all non-link-local prefix assigned to the interface and starts advertising -it. This may be applicable in non-6to4 scenarios where the upstream prefix might -change. This option is incompatible with Base6to4Interface option. -AdvRouterAddr option is always enabled when this configuration is used. - -All the possible prefix specific options are described below. Each -option has to be terminated by a semicolon. - -Decimal values are allowed only for MinDelayBetweenRAs, -MaxRtrAdvInterval and MinRtrAdvInterval. Decimal values should -be used only when using Mobile IPv6 extensions. - -Route definitions are of the form: - -.nf -.BR "route " prefix / "length " { - list of route specific options -.B }; -.fi - -The prefix of a route definition should be network prefix; it can be used to -advertise more specific routes to the hosts. - -RDNSS (Recursive DNS server) definitions are of the form: - -.nf -.BR "RDNSS " "ip [ip] [ip] " { - list of rdnss specific options -.B }; -.fi - -DNSSL (DNS Search List) definitions are of the form: - -.nf -.BR "DNSSL " "suffix [suffix] [suffix] [...] " { - list of dnssl specific options -.B }; -.fi - -By default radvd will send route advertisements so that every node on the link can use them. -The list of clients (IPv6 address) to advertise to, and accept route solicitations from can be configured. -If done, radvd does not send send messages to the multicast addresses but -to the configured unicast addresses only. Solicitations from other addresses are refused. -This is similar to UnicastOnly but includes periodic messages and incoming client access -configuration. See examples section for a use case of this. - -The definitions are of the form: - -.nf -.BR "clients " { - list of IPv6 addresses -.B }; -.fi - -.SH INTERFACE SPECIFIC OPTIONS - -.TP -.BR IgnoreIfMissing " " on | off - -A flag indicating whether or not the interface is ignored -if it does not exist at start-up. By default, radvd exits. - -This is useful for dynamic interfaces which are not active when radvd -starts or which are dynamically disabled and re-enabled during the time -radvd runs. - -Current versions of radvd automatically try to re-enable interfaces. - -Enabling IgnoreIfMissing also quenches certain warnings in log messages -relating to missing interfaces. - -Default: on - -.TP -.BR AdvSendAdvert " " on | off - -A flag indicating whether or not the router sends -periodic router advertisements and responds to -router solicitations. - -This option no longer has to be specified first, but it -needs to be -.B on -to enable advertisement on this interface. - -Default: off - -.TP -.BR UnicastOnly " " on | off - -Indicates that the interface link type only supports unicast. -This will prevent unsolicited advertisements from being sent, and -will cause solicited advertisements to be unicast to the -soliciting node. This option is necessary for non-broadcast, -multiple-access links, such as ISATAP. - -Default: off - -.TP -.BR "MaxRtrAdvInterval " seconds - -The maximum time allowed between sending unsolicited multicast -router advertisements from the interface, in seconds. - -Must be no less than 4 seconds and no greater than 1800 seconds. - -Minimum when using Mobile IPv6 extensions: 0.07. - -For values less than 0.2 seconds, 0.02 seconds is added to account for -scheduling granularities as specified in RFC3775. - -Default: 600 seconds - -.TP -.BR "MinRtrAdvInterval " seconds - -The minimum time allowed between sending unsolicited multicast -router advertisements from the interface, in seconds. - -Must be no less than 3 seconds and no greater than 0.75 * -MaxRtrAdvInterval. - -Minimum when using Mobile IPv6 extensions: 0.03. - -Default: 0.33 * MaxRtrAdvInterval - -.TP -.BR "MinDelayBetweenRAs " seconds - -The minimum time allowed between sending multicast -router advertisements from the interface, in seconds. - -This applies to solicited multicast RAs. -This is defined as the protocol constant MIN_DELAY_BETWEEN_RAS in RFC4861. -MIPv6 redefines this parameter to have a minimum of 0.03 seconds. - -Minimum when using Mobile IPv6 extensions: 0.03. - -Default: 3 - -.TP -.BR AdvManagedFlag " " on | off - -When set, hosts use the administered (stateful) protocol for address -autoconfiguration in addition to any addresses autoconfigured using -stateless address autoconfiguration. The use of this flag is -described in RFC 4862. - -Default: off - -.TP -.BR AdvOtherConfigFlag " " on | off - -When set, hosts use the administered (stateful) protocol for -autoconfiguration of other (non-address) information. The use of -this flag is described in RFC 4862. - -Default: off - -.TP -.BR "AdvLinkMTU " integer - -The MTU option is used in router advertisement messages to insure -that all nodes on a link use the same MTU value in those cases where -the link MTU is not well known. - -If specified, i.e. not 0, must not be smaller than 1280 and not greater -than the maximum MTU allowed for this link (e.g. ethernet has -a maximum MTU of 1500. See RFC 4864). - -Default: 0 - -.TP -.BR "AdvReachableTime " milliseconds - -The time, in milliseconds, that a node assumes a neighbor is -reachable after having received a reachability confirmation. Used -by the Neighbor Unreachability Detection algorithm (see Section -7.3 of RFC 4861). A value of zero means unspecified (by this router). - -Must be no greater than 3,600,000 milliseconds (1 hour). - -Default: 0 - -.TP -.BR "AdvRetransTimer " milliseconds - -The time, in milliseconds, between retransmitted Neighbor -Solicitation messages. Used by address resolution and the Neighbor -Unreachability Detection algorithm (see Sections 7.2 and 7.3 of RFC 4861). -A value of zero means unspecified (by this router). - -Default: 0 - -.TP -.BR "AdvCurHopLimit " integer - -The default value that should be placed in the Hop Count field of -the IP header for outgoing (unicast) IP packets. The value should -be set to the current diameter of the Internet. The value zero -means unspecified (by this router). - -Default: 64 - -.TP -.BR "AdvDefaultLifetime " seconds - -The lifetime associated with the default router in units of seconds. -The maximum value corresponds to 18.2 hours. A lifetime of 0 -indicates that the router is not a default router and should not -appear on the default router list. The router lifetime applies only -to the router's usefulness as a default router; it does not apply to -information contained in other message fields or options. Options -that need time limits for their information include their own -lifetime fields. - -Must be either zero or between MaxRtrAdvInterval and 9000 seconds. - -Default: 3 * MaxRtrAdvInterval (Minimum 1 second). - -.TP -.BR AdvDefaultPreference " " low | medium | high - -The preference associated with the default router, as either "low", -"medium", or "high". - -Default: medium - -.TP -.BR AdvSourceLLAddress " " on | off - -When set, the link-layer address of the outgoing interface is -included in the RA. - -Default: on - -.TP -.BR AdvHomeAgentFlag " " on | off - -When set, indicates that sending router is able to serve as Mobile -IPv6 Home Agent. When set, minimum limits specified by Mobile IPv6 -are used for MinRtrAdvInterval and MaxRtrAdvInterval. - -Default: off - -.TP -.BR AdvHomeAgentInfo " " on | off - -When set, Home Agent Information Option (specified by Mobile IPv6) -is included in Router Advertisements. AdvHomeAgentFlag must also -be set when using this option. - -Default: off - -.TP -.BR "HomeAgentLifetime " seconds - -The length of time in seconds (relative to the time the packet is -sent) that the router is offering Mobile IPv6 Home Agent services. -A value 0 must not be used. The maximum lifetime is 65520 seconds -(18.2 hours). This option is ignored, if AdvHomeAgentInfo is not -set. - -If both HomeAgentLifetime and HomeAgentPreference are set to their -default values, Home Agent Information Option will not be sent. - -Default: AdvDefaultLifetime - -.TP -.BR "HomeAgentPreference " integer - -The preference for the Home Agent sending this Router Advertisement. -Values greater than 0 indicate more preferable Home Agent, values -less than 0 indicate less preferable Home Agent. This option is -ignored, if AdvHomeAgentInfo is not set. - -If both HomeAgentLifetime and HomeAgentPreference are set to their -default values, Home Agent Information Option will not be sent. - -Default: 0 - -.TP -.BR AdvMobRtrSupportFlag " " on | off - -When set, the Home Agent signals it supports Mobile Router -registrations (specified by NEMO Basic). AdvHomeAgentInfo must also -be set when using this option. - -Default: off - -.TP -.BR AdvIntervalOpt " " on | off - -When set, Advertisement Interval Option (specified by Mobile IPv6) -is included in Router Advertisements. When set, minimum limits -specified by Mobile IPv6 are used for MinRtrAdvInterval and -MaxRtrAdvInterval. - -The advertisement interval is based on the configured MaxRtrAdvInterval -parameter except where this is less than 200ms. In this case, -the advertised interval is ( MaxRtrAdvInterval + 20ms ). - -Default: off - -.SH PREFIX SPECIFIC OPTIONS - -.TP -.BR AdvOnLink " " on | off - -When set, indicates that this prefix can be used for on-link -determination. When not set the advertisement makes no statement -about on-link or off-link properties of the prefix. For instance, -the prefix might be used for address configuration with some of the -addresses belonging to the prefix being on-link and others being -off-link. - -Default: on - -.TP -.BR AdvAutonomous " " on | off - -When set, indicates that this prefix can be used for autonomous -address configuration as specified in RFC 4862. - -Default: on - -.TP -.BR AdvRouterAddr " " on | off - -When set, indicates that the address of interface is sent instead of -network prefix, as is required by Mobile IPv6. When set, minimum -limits specified by Mobile IPv6 are used for MinRtrAdvInterval and -MaxRtrAdvInterval. - -Default: off - -.TP -.BR "AdvValidLifetime " seconds "" | infinity - -The length of time in seconds (relative to the time the packet is -sent) that the prefix is valid for the purpose of on-link -determination. The symbolic value -.B infinity -represents infinity (i.e. a value of all one bits (0xffffffff)). -The valid lifetime is also used by RFC 4862. - -Note that clients will ignore AdvValidLifetime of an existing prefix -if the lifetime is below two hours, as required in RFC 4862 Section 5.5.3 -point e). - -Note: RFC4861's suggested default value is significantly longer: 30 days. - -Default: 86400 seconds (1 day) - -.TP -.BR "AdvPreferredLifetime " seconds "" | infinity - -The length of time in seconds (relative to the time the packet is -sent) that addresses generated from the prefix via stateless address -autoconfiguration remain preferred. -The symbolic value -.B infinity -represents infinity (i.e. a value of all one bits (0xffffffff)). -See RFC 4862. - -Note: RFC4861's suggested default value is significantly longer: 7 days. - -Default: 14400 seconds (4 hours) - -.TP -.BR DeprecatePrefix " " on | off - -Upon shutdown, this option will cause radvd to deprecate the prefix by announcing it in the radvd shutdown RA with a zero preferred lifetime and a valid lifetime slightly greater than 2 hours. This will encourage end-nodes using this prefix to deprecate any associated addresses immediately. Note that this option should only be used when only one router is announcing the prefix onto the link, otherwise end-nodes will deprecate associated addresses despite the prefix still being valid for preferred use. - -See RFC4862, section 5.5.3., "Router Advertisement Processing", part (e). - -Default: off - -.TP -.BR DecrementLifetimes " " on | off - -This option causes radvd to decrement the values of the preferred and valid lifetimes for the prefix over time. The lifetimes are decremented by the number of seconds since the last RA. If radvd receives a SIGUSR1 signal, it will reset the values of the preferred and valid lifetimes back to the initial values used by radvd when it started. If radvd never receives a SIGUSR1 signal, it will continue to decrement the lifetimes until the preferred lifetime reaches zero. After a final RA with a zero value preferred lifetime, radvd will cease to announce the prefix. If a SIGUSR1 signal then causes the lifetimes to be reset, the prefix will then re-appear in the RAs. - -This option is intended to be used in conjunction with a DHCPv6 client that is using the Identity Association for Prefix Delegation (IA_PD) option to acquire a prefix from a Delegating Router for use by a Requesting Router. In this scenario, the prefix(es) from within the delegated prefix that are announced by radvd would age in parallel with and at the same rate as the delegated prefix, and expire at approximately the same time, if the delegated prefix's life isn't extended. - -See RFC3633, "IPv6 Prefix Options for Dynamic Host Configuration Protocol (DHCP) version 6". - -Default: off - -.TP -.BR "Base6Interface " name - -If this options is specified, this prefix will be combined with the -IPv6 address of the interface specified by -.B name. -The resulting prefix length will be 64. - -.TP -.BR "Base6to4Interface " name - -If this option is specified, this prefix will be combined with the -IPv4 address of interface -.B name -to produce a valid 6to4 prefix. The first 16 bits of this prefix -will be replaced by -.B 2002 -and the next 32 bits of this prefix will be replaced by the IPv4 -address assigned to interface -.B name -at configuration time. The remaining 80 bits of the prefix (including -the SLA ID) will be advertised as specified in the configuration file. -See the next section for an example. - -If interface -.B name -is not available at configuration time, a warning will be written to -the log and this prefix will be disabled until radvd is reconfigured. - -This option enables systems with dynamic IPv4 addresses to update their -advertised 6to4 prefixes simply by restarting radvd or sending a SIGHUP -signal to cause radvd to reconfigure itself. - -Note that 6to4 prefixes derived from dynamically-assigned IPv4 addresses -should be advertised with a significantly shorter lifetime (see the -.B AdvValidLifetime -and -.B AdvPreferredLifetime -options). - -For more information on 6to4, see RFC 3056. - -Default: 6to4 is not used - -.SH ROUTE SPECIFIC OPTIONS - -.TP -.BR "AdvRouteLifetime " seconds "" | infinity - -The lifetime associated with the route in units of seconds. -The symbolic value -.B infinity -represents infinity (i.e. a value of all one bits (0xffffffff)). - -Default: 3 * MaxRtrAdvInterval - -.TP -.BR AdvRoutePreference " " low | medium | high - -The preference associated with the default router, as either "low", -"medium", or "high". - -Default: medium - -.TP -.BR RemoveRoute " " on | off - -Upon shutdown, announce this route with a zero second lifetime. This should cause the route to be immediately removed from the receiving end-nodes' route table. - -Default: on - -.SH RDNSS SPECIFIC OPTIONS - -.TP -.BR "AdvRDNSSLifetime " seconds | infinity -The maximum duration how long the RDNSS entries are used for name resolution. A value of 0 means the nameserver must no longer be used. The value, if not 0, must be at least MaxRtrAdvInterval. To ensure stale RDNSS info gets removed in a timely fashion, this should not be greater than 2*MaxRtrAdvInterval. - -Default: 2*MaxRtrAdvInterval - -.TP -.BR FlushRDNSS " " on | off - -Upon shutdown, announce the RDNSS entries with a zero second lifetime. This should cause the RDNSS addresses to be immediately removed from the end-nodes' list of Recursive DNS Servers. - -Default: on - -.SH DNSSL SPECIFIC OPTIONS - -.TP -.BR "AdvDNSSLLifetime " seconds | infinity; -The maximum duration how long the DNSSL entries are used for name resolution. -A value of 0 means the suffix should no longer be used. -The value, if not 0, must be at least MaxRtrAdvInterval. To ensure stale -DNSSL info gets removed in a timely fashion, this should not be greater than -2*MaxRtrAdvInterval. - -Default: 2*MaxRtrAdvInterval - -.TP -.BR FlushDNSSL " " on | off - -Upon shutdown, announce the DNSSL entries with a zero second lifetime. This should cause the DNSSL entries to be immediately removed from the end-nodes' DNS search list. - -Default: on - -.SH EXAMPLES - -.nf -interface eth0 -{ - AdvSendAdvert on; - prefix 2001:db8:0:1::/64 - { - AdvOnLink on; - AdvAutonomous on; - }; -}; -.fi - -It says that router advertisement daemon should advertise -(AdvSendAdvert on;) the prefix 2001:db8:0:1:: which has a lenght of 64 -on the interface eth0. Also the prefix should be marked as autonomous -(AdvAutonomous on;) and as on-link (AdvOnLink on;). All the other -options are left on their default values. - -To support movement detection of Mobile IPv6 Mobile Nodes, the -address of interface should be used instead of network prefix: - -.nf -interface eth0 -{ - AdvSendAdvert on; - prefix 2001:db8:0:1::4/64 - { - AdvOnLink on; - AdvAutonomous on; - AdvRouterAddr on; - }; -}; -.fi - -For 6to4 support, include the -.B Base6to4Interface -option in each prefix section. When using a dynamic IPv4 address, set -small prefix lifetimes to prevent hosts from retaining unreachable -prefixes after a new IPv4 address has been assigned. When advertising to on -a dynamic interface (e.g., Bluetooth), skip the interface if it is not -active yet. - -.nf -interface bnep0 -{ - IgnoreIfMissing on; - AdvSendAdvert on; - - # Advertise at least every 30 seconds - MaxRtrAdvInterval 30; - - prefix 0:0:0:5678::/64 - { - AdvOnLink on; - AdvAutonomous on; - Base6to4Interface ppp0; - - # Very short lifetimes for dynamic addresses - AdvValidLifetime 300; - AdvPreferredLifetime 120; - }; -}; -.fi - -Since 6to4 is enabled, the prefix will be advertised as -2002:WWXX:YYZZ:5678::/64, where WW.XX.YY.ZZ is the IPv4 address of -ppp0 at configuration time. (IPv6 addresses are written in hexadecimal -whereas IPv4 addresses are written in decimal, so the IPv4 address -WW.XX.YY.ZZ in the 6to4 prefix will be represented in hex.) - -In this specific case, the configuration scripts may send HUP signal to -radvd when taking bnep0 up or down to notify about the status; in the -current radvd releases, sending HUP is no longer mandatory when the link -comes back up. - -.nf -interface eth0 -{ - AdvSendAdvert on; - prefix 2001:db8:0:1::/64 - { - AdvOnLink on; - AdvAutonomous on; - }; - clients - { - fe80::21f:16ff:fe06:3aab; - fe80::21d:72ff:fe96:aaff; - }; -}; -.fi - -This configuration would only announce the prefix to fe80::21f:16ff:fe06:3aab and fe80::21d:72ff:fe96:aaff. -Furthermore, all RA requests of other clients are denied. - -This may come in handy if you want to roll out IPv6 only partially because -some clients are broken or untested. - - -.SH FILES - -.nf -@sbindir@/radvd -@PATH_RADVD_CONF@ -@PATH_RADVD_PID@ -@PATH_RADVD_LOG@ -.fi - -.SH CREDIT -The description of the different flags and variables is in large -parts taken from RFC 4861. - -.SH RFCS -Narten, T., Nordmark, E., Simpson, W., and H. Soliman, "Neighbor Discovery for IP -Version 6 (IPv6)", RFC 4861, September 2007. -.PP -Thomson, S., Narten, T., T. Jinmei, "IPv6 Stateless Address Autoconfiguration", -RFC 4862, September 2007. -.PP -Deering, S., and R. Hinden, "IP Version 6 Addressing -Architecture", RFC 4291, February 2006. -.PP -Conta, A., Deering, S., and M. Gupta "Internet Control Message Protocol (ICMPv6) -for the Internet Protocol Version 6 (IPv6)", RFC 4443, March 2006. -.PP -Crawford, M., "Transmission of IPv6 Packets over Ethernet Networks", -RFC 2464, December 1998. -.PP -Carpenter B., K. Moore, "Connection of IPv6 Domains via IPv4 Clouds", -RFC 3056, February 2001. (6to4 specification) -.PP -Draves, R., D. Thaler, "Default Router Preferences and More-Specific Routes", -RFC 4191, November 2005. -.PP -Johnson, D., Perkins, C., and J. Arkko, "Mobility Support in IPv6", -RFC 3775, June 2004. -.PP -Devarapalli, V., Wakikawa, R., Petrescu, A., and P. Thubert "Network Mobility (NEMO) Basic Support Protocol", -RFC 3963, January 2005. -.PP -J. Jeong, S. Park, L. Beloeil, and S. Madanapalli, "IPv6 Router Advertisement Options for DNS Configuration", -RFC 6106, November 2010. - -.SH "SEE ALSO" - -.BR radvd (8), -.BR radvdump (8) - -.SH BUGS -radvd does not support splitting up RAs to multiple packets (RFC4861 6.2.3 last paragraph). -In practise this limits advertising to ~45 prefixes on a link, but there is no reason to -be able to so. - diff --git a/release/src/router/radvd/radvd.conf.example b/release/src/router/radvd/radvd.conf.example deleted file mode 100644 index 9933300bb6..0000000000 --- a/release/src/router/radvd/radvd.conf.example +++ /dev/null @@ -1,124 +0,0 @@ -# -# NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE -# NOTE NOTE -# NOTE This is an EXAMPLE, which serves only to demonstrate the NOTE -# NOTE syntax of radvd.conf, and is not meant to be used for a NOTE -# NOTE real radvd configuration. NOTE -# NOTE NOTE -# NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE NOTE -# - -interface eth0 -{ - AdvSendAdvert on; - -# This may be needed on some interfaces which are not active when -# radvd starts, but become available later on; see man page for details. - - # IgnoreIfMissing on; - -# -# These settings cause advertisements to be sent every 3-10 seconds. This -# range is good for 6to4 with a dynamic IPv4 address, but can be greatly -# increased when not using 6to4 prefixes. -# - - MinRtrAdvInterval 3; - MaxRtrAdvInterval 10; - -# -# You can use AdvDefaultPreference setting to advertise the preference of -# the router for the purposes of default router determination. -# NOTE: This feature is still being specified and is not widely supported! -# - AdvDefaultPreference low; - -# -# Disable Mobile IPv6 support -# - AdvHomeAgentFlag off; - -# -# example of a standard prefix -# - prefix 2001:db8:1:0::/64 - { - AdvOnLink on; - AdvAutonomous on; - AdvRouterAddr off; - }; - -# -# example of a 6to4 prefix -# -# Note that the first 48 bits are specified here as zeros. These will be -# replaced with the appropriate 6to4 address when radvd starts or is -# reconfigured. Be sure that the SLA ID (1234 in this case) is specified -# here! -# - prefix 0:0:0:1234::/64 - { - AdvOnLink on; - AdvAutonomous on; - AdvRouterAddr off; - -# -# This setting causes radvd to replace the first 48 bits of the prefix -# with the 6to4 address generated from the specified interface. For example, -# if the address of ppp0 is 192.0.2.25 when radvd configures itself, this -# prefix will be advertised as 2002:C000:0219:1234::/64. -# -# If ppp0 is not available at configuration time, this prefix will not be -# advertised, but other prefixes listed in the configuration will be -# advertised as usual. -# -# When using the Base6to4Interface option, make sure radvd receives a -# SIGHUP every time the ppp0 interface goes up, down, or is assigned a -# new IPv4 address. The SIGHUP will cause radvd to recognize that the -# ppp0 interface has changed and will adjust the advertisements -# accordingly. -# - - Base6to4Interface ppp0; - -# -# If the IP address of ppp0 is assigned dynamically, be sure to set the -# lifetimes for this prefix to be small. Otherwise, hosts on your network -# may continue to use a prefix that no longer corresponds to the address -# on ppp0! -# - AdvPreferredLifetime 120; - AdvValidLifetime 300; - }; -# -# example of a more specific route -# NOTE: This feature is not very widely supported! You may also need to -# enable it manually (e.g. on Linux, change the value of -# sysctl accept_ra_rt_info_max_plen to 48 or 64) -# - route 2001:db0:fff::/48 - { - AdvRoutePreference high; - AdvRouteLifetime 3600; - }; - -# -# RDNSS -# NOTE: This feature is not very widely implemented. -# - RDNSS 2001:db8::1 2001:db8::2 - { - AdvRDNSSLifetime 30; - }; - -# -# DNS Search Lists -# - DNSSL branch.example.com example.com - { - AdvDNSSLLifetime 30; - }; - - -}; - diff --git a/release/src/router/radvd/radvd.h b/release/src/router/radvd/radvd.h deleted file mode 100644 index 82cbfbe6f5..0000000000 --- a/release/src/router/radvd/radvd.h +++ /dev/null @@ -1,280 +0,0 @@ -/* - * $Id: radvd.h,v 1.42 2011/04/28 15:08:40 reubenhwk Exp $ - * - * Authors: - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#ifndef RADV_H -#define RADV_H - -#include "config.h" -#include "includes.h" -#include "defaults.h" -#include "log.h" - -#define CONTACT_EMAIL "Pekka Savola " - -extern int sock; - -#define min(a,b) (((a) < (b)) ? (a) : (b)) - -struct AdvPrefix; -struct Clients; - -#define HWADDR_MAX 16 -#define USER_HZ 100 - -struct Interface { - char Name[IFNAMSIZ]; /* interface name */ - - struct in6_addr if_addr; - unsigned int if_index; - - uint8_t init_racount; /* Initial RAs */ - - uint8_t if_hwaddr[HWADDR_MAX]; - int if_hwaddr_len; - int if_prefix_len; - int if_maxmtu; - - int cease_adv; - - struct timeval last_ra_time; - - int IgnoreIfMissing; - int AdvSendAdvert; - double MaxRtrAdvInterval; - double MinRtrAdvInterval; - double MinDelayBetweenRAs; - int AdvManagedFlag; - int AdvOtherConfigFlag; - uint32_t AdvLinkMTU; - uint32_t AdvReachableTime; - uint32_t AdvRetransTimer; - uint8_t AdvCurHopLimit; - int32_t AdvDefaultLifetime; /* XXX: really uint16_t but we need to use -1 */ - int AdvDefaultPreference; - int AdvSourceLLAddress; - int UnicastOnly; - - /* Mobile IPv6 extensions */ - int AdvIntervalOpt; - int AdvHomeAgentInfo; - int AdvHomeAgentFlag; - uint16_t HomeAgentPreference; - int32_t HomeAgentLifetime; /* XXX: really uint16_t but we need to use -1 */ - - /* NEMO extensions */ - int AdvMobRtrSupportFlag; - - struct AdvPrefix *AdvPrefixList; - struct AdvRoute *AdvRouteList; - struct AdvRDNSS *AdvRDNSSList; - struct AdvDNSSL *AdvDNSSLList; - struct Clients *ClientList; - struct timeval last_multicast; - struct timeval next_multicast; - - /* Info whether this interface has failed in the past (and may need to be reinitialized) */ - int HasFailed; - - struct Interface *next; -}; - -struct Clients { - struct in6_addr Address; - struct Clients *next; -}; - -struct AdvPrefix { - struct in6_addr Prefix; - uint8_t PrefixLen; - - int AdvOnLinkFlag; - int AdvAutonomousFlag; - uint32_t AdvValidLifetime; - uint32_t AdvPreferredLifetime; - int DeprecatePrefixFlag; - int DecrementLifetimesFlag; - - uint32_t curr_validlft; - uint32_t curr_preferredlft; - - /* Mobile IPv6 extensions */ - int AdvRouterAddr; - - /* 6to4 etc. extensions */ - char if6to4[IFNAMSIZ]; - int enabled; - int AutoSelected; - - /* Select prefixes from this interface. */ - char if6[IFNAMSIZ]; - - struct AdvPrefix *next; -}; - -/* More-Specific Routes extensions */ - -struct AdvRoute { - struct in6_addr Prefix; - uint8_t PrefixLen; - - int AdvRoutePreference; - uint32_t AdvRouteLifetime; - int RemoveRouteFlag; - - struct AdvRoute *next; -}; - -/* Options for DNS configuration */ - -struct AdvRDNSS { - int AdvRDNSSNumber; - uint32_t AdvRDNSSLifetime; - int FlushRDNSSFlag; - struct in6_addr AdvRDNSSAddr1; - struct in6_addr AdvRDNSSAddr2; - struct in6_addr AdvRDNSSAddr3; - - struct AdvRDNSS *next; -}; - -struct AdvDNSSL { - uint32_t AdvDNSSLLifetime; - - int AdvDNSSLNumber; - int FlushDNSSLFlag; - char **AdvDNSSLSuffixes; - - struct AdvDNSSL *next; -}; - -/* Mobile IPv6 extensions */ - -struct AdvInterval { - uint8_t type; - uint8_t length; - uint16_t reserved; - uint32_t adv_ival; -}; - -struct HomeAgentInfo { - uint8_t type; - uint8_t length; - uint16_t flags_reserved; - uint16_t preference; - uint16_t lifetime; -}; - - -/* gram.y */ -int yyparse(void); - -/* scanner.l */ -int yylex(void); - -/* radvd.c */ -int check_ip6_forwarding(void); -void reload_config(void); -void reset_prefix_lifetimes(void); - -/* timer.c */ -struct timeval next_timeval(double next); -int timevaldiff(struct timeval const *a, struct timeval const *b); -int next_time_msec(struct Interface const * iface); -int expired(struct Interface const * iface); - -/* device.c */ -int setup_deviceinfo(struct Interface *); -int check_device(struct Interface *); -int setup_linklocal_addr(struct Interface *); -int setup_allrouters_membership(struct Interface *); -int check_allrouters_membership(struct Interface *); -int get_v4addr(const char *, unsigned int *); -int set_interface_var(const char *, const char *, const char *, uint32_t); -int set_interface_linkmtu(const char *, uint32_t); -int set_interface_curhlim(const char *, uint8_t); -int set_interface_reachtime(const char *, uint32_t); -int set_interface_retranstimer(const char *, uint32_t); - -/* interface.c */ -void iface_init_defaults(struct Interface *); -void prefix_init_defaults(struct AdvPrefix *); -void route_init_defaults(struct AdvRoute *, struct Interface *); -void rdnss_init_defaults(struct AdvRDNSS *, struct Interface *); -void dnssl_init_defaults(struct AdvDNSSL *, struct Interface *); -int check_iface(struct Interface *); - -/* socket.c */ -int open_icmpv6_socket(void); - -/* send.c */ -int send_ra(struct Interface *iface, struct in6_addr *dest); -int send_ra_forall(struct Interface *iface, struct in6_addr *dest); - -/* process.c */ -void process(struct Interface *, unsigned char *, int, - struct sockaddr_in6 *, struct in6_pktinfo *, int); - -/* recv.c */ -int recv_rs_ra(unsigned char *, struct sockaddr_in6 *, struct in6_pktinfo **, int *); - -/* util.c */ -void mdelay(double); -double rand_between(double, double); -void print_addr(struct in6_addr *, char *); -int check_rdnss_presence(struct AdvRDNSS *, struct in6_addr *); -int check_dnssl_presence(struct AdvDNSSL *, const char *); -ssize_t readn(int fd, void *buf, size_t count); -ssize_t writen(int fd, const void *buf, size_t count); - -/* privsep.c */ -int privsep_init(void); -int privsep_enabled(void); -int privsep_interface_linkmtu(const char *iface, uint32_t mtu); -int privsep_interface_curhlim(const char *iface, uint32_t hlim); -int privsep_interface_reachtime(const char *iface, uint32_t rtime); -int privsep_interface_retranstimer(const char *iface, uint32_t rettimer); - -/* - * compat hacks in case libc and kernel get out of sync: - * - * glibc 2.4 and uClibc 0.9.29 introduce IPV6_RECVPKTINFO etc. and change IPV6_PKTINFO - * This is only supported in Linux kernel >= 2.6.14 - * - * This is only an approximation because the kernel version that libc was compiled against - * could be older or newer than the one being run. But this should not be a problem -- - * we just keep using the old kernel interface. - * - * these are placed here because they're needed in all of socket.c, recv.c and send.c - */ -#ifdef __linux__ -# if defined IPV6_RECVHOPLIMIT || defined IPV6_RECVPKTINFO -# include -# if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,14) -# if defined IPV6_RECVHOPLIMIT && defined IPV6_2292HOPLIMIT -# undef IPV6_RECVHOPLIMIT -# define IPV6_RECVHOPLIMIT IPV6_2292HOPLIMIT -# endif -# if defined IPV6_RECVPKTINFO && defined IPV6_2292PKTINFO -# undef IPV6_RECVPKTINFO -# undef IPV6_PKTINFO -# define IPV6_RECVPKTINFO IPV6_2292PKTINFO -# define IPV6_PKTINFO IPV6_2292PKTINFO -# endif -# endif -# endif -#endif - -#endif diff --git a/release/src/router/radvd/radvdump.8.man b/release/src/router/radvd/radvdump.8.man deleted file mode 100644 index 234f088c65..0000000000 --- a/release/src/router/radvd/radvdump.8.man +++ /dev/null @@ -1,87 +0,0 @@ -.\" -.\" $Id: radvdump.8.man,v 1.7 2011/01/05 08:21:42 psavola Exp $ -.\" -.\" Authors: -.\" Lars Fenneberg -.\" Marko Myllynen -.\" -.\" This software is Copyright 1996 by the above mentioned author(s), -.\" All Rights Reserved. -.\" -.\" The license which is distributed with this software in the file COPYRIGHT -.\" applies to this software. If your distribution is missing this file, you -.\" may request it from . -.\" -.\" -.\" -.TH RADVDUMP 8 "31 Mar 2008" "radvd @VERSION@" "" -.SH NAME -radvdump \- dump router advertisements -.SH SYNOPSIS -.B radvdump -.B "[ \-vhfe ]" -.BI "[ \-d " debuglevel " ]" - -.SH DESCRIPTION -.B radvdump -prints out the contents of incoming router advertisements sent by -.B radvd -or some other software implementing (parts of) -"Neighbor Discovery for IP Version 6 (IPv6)" (RFC 4861). - -.SH OPTIONS - -For every one character option there is also a long option, which -is listed right next to the "short" option name: - -.TP -.BR "\-v" , " \-\-version" -Displays the version of -.I radvdump -and then aborts. -.TP -.BR "\-h" , " \-\-help" -Displays a short usage description and then aborts. -.TP -.BR "\-f" , " \-\-file\-format" -Output received router advertisements in the format of the -.B radvd -configuration file. -Since radvd 0.9, this is the default and the switch is provided -for backward compatibility only. -.TP -.BR "\-e" , " \-\-exclude-defaults" -Exclude default valued options from configuration file format. -This option is ignored if option -.B "\-f" -is not set. -.TP -.BR "\-d " debuglevel, " \-\-debug " debuglevel -With this option you turn on debugging information. The debugging level is -an integer in the range from 1 to 4, from quiet to very verbose. A -debugging level of 0 completely turns off debugging. - -The default debugging level is 0. - -.SH FILES - -.nf -@sbindir@/radvdump -.fi -.SH BUGS - -There certainly are some bugs. If you find them or have other -suggestions please contact Pekka Savola . - -.SH "SEE ALSO" - -.BR radvd (8), -.BR radvd.conf (5) -.SH AUTHORS - -.nf -Lars Fenneberg - previous maintainer -Nathan Lutchansky - previous maintainer -Pekka Savola - current maintainer -Marko Myllynen - Mobile IPv6 support -.fi diff --git a/release/src/router/radvd/radvdump.c b/release/src/router/radvd/radvdump.c deleted file mode 100644 index 46ad609883..0000000000 --- a/release/src/router/radvd/radvdump.c +++ /dev/null @@ -1,524 +0,0 @@ -/* - * $Id: radvdump.c,v 1.25 2011/02/28 10:53:07 reubenhwk Exp $ - * - * Authors: - * Lars Fenneberg - * Marko Myllynen - * - * This software is Copyright 1996-2000 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" - -char usage_str[] = "[-vhfe] [-d level]"; - -#ifdef HAVE_GETOPT_LONG -struct option prog_opt[] = { - {"debug", 1, 0, 'd'}, - {"file-format", 0, 0, 'f'}, - {"exclude-defaults", 0, 0, 'e'}, - {"version", 0, 0, 'v'}, - {"help", 0, 0, 'h'}, - {NULL, 0, 0, 0} -}; -#endif - -char *pname; -int sock = -1; - -void version(void); -void usage(void); -void print_ff(unsigned char *, int, struct sockaddr_in6 *, int, unsigned int, int); -void print_preferences(int); - -int -main(int argc, char *argv[]) -{ - unsigned char msg[MSG_SIZE_RECV]; - int c, len, hoplimit; - int edefs = 0; - struct sockaddr_in6 rcv_addr; - struct in6_pktinfo *pkt_info = NULL; -#ifdef HAVE_GETOPT_LONG - int opt_idx; -#endif - - pname = ((pname=strrchr(argv[0],'/')) != NULL)?pname+1:argv[0]; - - /* parse args */ -#ifdef HAVE_GETOPT_LONG - while ((c = getopt_long(argc, argv, "d:fehv", prog_opt, &opt_idx)) > 0) -#else - while ((c = getopt(argc, argv, "d:fehv")) > 0) -#endif - { - switch (c) { - case 'd': - set_debuglevel(atoi(optarg)); - break; - case 'f': - break; - case 'e': - edefs = 1; - break; - case 'v': - version(); - break; - case 'h': - usage(); -#ifdef HAVE_GETOPT_LONG - case ':': - fprintf(stderr, "%s: option %s: parameter expected\n", pname, - prog_opt[opt_idx].name); - exit(1); -#endif - case '?': - exit(1); - } - } - - if (log_open(L_STDERR, pname, NULL, 0) < 0) { - perror("log_open"); - exit(1); - } - - /* get a raw socket for sending and receiving ICMPv6 messages */ - sock = open_icmpv6_socket(); - if (sock < 0) { - perror("open_icmpv6_socket"); - exit(1); - } - - for(;;) - { - len = recv_rs_ra(msg, &rcv_addr, &pkt_info, &hoplimit); - if (len > 0) - { - struct icmp6_hdr *icmph; - - /* - * can this happen? - */ - - if (len < sizeof(struct icmp6_hdr)) - { - flog(LOG_WARNING, "received icmpv6 packet with invalid length: %d", - len); - exit(1); - } - - icmph = (struct icmp6_hdr *) msg; - - if (icmph->icmp6_type != ND_ROUTER_SOLICIT && - icmph->icmp6_type != ND_ROUTER_ADVERT) - { - /* - * We just want to listen to RSs and RAs - */ - - flog(LOG_ERR, "icmpv6 filter failed"); - exit(1); - } - - dlog(LOG_DEBUG, 4, "receiver if_index: %u", pkt_info->ipi6_ifindex); - - if (icmph->icmp6_type == ND_ROUTER_SOLICIT) - { - /* not yet */ - } - else if (icmph->icmp6_type == ND_ROUTER_ADVERT) - print_ff(msg, len, &rcv_addr, hoplimit, (unsigned int)pkt_info->ipi6_ifindex, edefs); - } - else if (len == 0) - { - flog(LOG_ERR, "received zero lenght packet"); - exit(1); - } - else - { - flog(LOG_ERR, "recv_rs_ra: %s", strerror(errno)); - exit(1); - } - } - - exit(0); -} - -void -print_ff(unsigned char *msg, int len, struct sockaddr_in6 *addr, int hoplimit, unsigned int if_index, int edefs) -{ - /* XXX: hoplimit not being used for anything here.. */ - struct nd_router_advert *radvert; - char addr_str[INET6_ADDRSTRLEN]; - uint8_t *opt_str; - int orig_len = len; - char if_name[IFNAMSIZ] = ""; - - print_addr(&addr->sin6_addr, addr_str); - printf("#\n# radvd configuration generated by radvdump %s\n", VERSION); - printf("# based on Router Advertisement from %s\n", addr_str); - if_indextoname(if_index, if_name); - printf("# received by interface %s\n", if_name); - printf("#\n\ninterface %s\n{\n\tAdvSendAdvert on;\n", if_name); - - printf("\t# Note: {Min,Max}RtrAdvInterval cannot be obtained with radvdump\n"); - - radvert = (struct nd_router_advert *) msg; - - if (!edefs || DFLT_AdvManagedFlag != (ND_RA_FLAG_MANAGED == (radvert->nd_ra_flags_reserved & ND_RA_FLAG_MANAGED))) - printf("\tAdvManagedFlag %s;\n", - (radvert->nd_ra_flags_reserved & ND_RA_FLAG_MANAGED)?"on":"off"); - - if (!edefs || DFLT_AdvOtherConfigFlag != (ND_RA_FLAG_OTHER == (radvert->nd_ra_flags_reserved & ND_RA_FLAG_OTHER))) - printf("\tAdvOtherConfigFlag %s;\n", - (radvert->nd_ra_flags_reserved & ND_RA_FLAG_OTHER)?"on":"off"); - - if (!edefs || DFLT_AdvReachableTime != ntohl(radvert->nd_ra_reachable)) - printf("\tAdvReachableTime %u;\n", ntohl(radvert->nd_ra_reachable)); - - if (!edefs || DFLT_AdvRetransTimer != ntohl(radvert->nd_ra_retransmit)) - printf("\tAdvRetransTimer %u;\n", ntohl(radvert->nd_ra_retransmit)); - - if (!edefs || DFLT_AdvCurHopLimit != radvert->nd_ra_curhoplimit) - printf("\tAdvCurHopLimit %u;\n", radvert->nd_ra_curhoplimit); - - if (!edefs || (3*DFLT_MaxRtrAdvInterval) != ntohs(radvert->nd_ra_router_lifetime)) - printf("\tAdvDefaultLifetime %hu;\n", ntohs(radvert->nd_ra_router_lifetime)); - - /* Mobile IPv6 ext */ - if (!edefs || DFLT_AdvHomeAgentFlag != (ND_RA_FLAG_HOME_AGENT == (radvert->nd_ra_flags_reserved & ND_RA_FLAG_HOME_AGENT))) - printf("\tAdvHomeAgentFlag %s;\n", - (radvert->nd_ra_flags_reserved & ND_RA_FLAG_HOME_AGENT)?"on":"off"); - - /* Route Preferences and more specific routes */ - /* XXX two middlemost bits from 8 bit field */ - if (!edefs || (((radvert->nd_ra_flags_reserved & 0x18) >> 3) & 0xff) != DFLT_AdvDefaultPreference) { - printf("\tAdvDefaultPreference "); - print_preferences(((radvert->nd_ra_flags_reserved & 0x18) >> 3) & 0xff); - printf(";\n"); - } - - len -= sizeof(struct nd_router_advert); - - if (len == 0) - return; - - opt_str = (uint8_t *)(msg + sizeof(struct nd_router_advert)); - - while (len > 0) - { - int optlen; - struct nd_opt_mtu *mtu; - struct HomeAgentInfo *ha_info; - - if (len < 2) - { - flog(LOG_ERR, "trailing garbage in RA from %s", - addr_str); - break; - } - - optlen = (opt_str[1] << 3); - - if (optlen == 0) - { - flog(LOG_ERR, "zero length option in RA"); - break; - } - else if (optlen > len) - { - flog(LOG_ERR, "option length greater than total" - " length in RA (type %d, optlen %d, len %d)", - (int)*opt_str, optlen, len); - break; - } - - switch (*opt_str) - { - case ND_OPT_MTU: - mtu = (struct nd_opt_mtu *)opt_str; - - if (!edefs || DFLT_AdvLinkMTU != ntohl(mtu->nd_opt_mtu_mtu)) - printf("\tAdvLinkMTU %u;\n", ntohl(mtu->nd_opt_mtu_mtu)); - break; - case ND_OPT_SOURCE_LINKADDR: - /* XXX: !DFLT depends on current DFLT_ value */ - if (!edefs || !DFLT_AdvSourceLLAddress) - printf("\tAdvSourceLLAddress on;\n"); - break; - /* Mobile IPv6 ext */ - case ND_OPT_RTR_ADV_INTERVAL: - /* XXX: !DFLT depends on current DFLT_ value */ - if (!edefs || !DFLT_AdvIntervalOpt) - printf("\tAdvIntervalOpt on;\n"); - break; - /* Mobile IPv6 ext */ - case ND_OPT_HOME_AGENT_INFO: - ha_info = (struct HomeAgentInfo *)opt_str; - - /* XXX: we check DFLT_HomeAgentInfo by interface, and it's outside - of context here, so we always need to print it out.. */ - printf("\tAdvHomeAgentInfo on;\n"); - - /* NEMO ext */ - if (!edefs || DFLT_AdvMobRtrSupportFlag != (ha_info->flags_reserved & ND_OPT_HAI_FLAG_SUPPORT_MR)) - printf("\tAdvMobRtrSupportFlag %s;\n", (ha_info->flags_reserved & ND_OPT_HAI_FLAG_SUPPORT_MR)?"on":"off"); - - if (!edefs || DFLT_HomeAgentPreference != ntohs(ha_info->preference)) - printf("\tHomeAgentPreference %hu;\n", ntohs(ha_info->preference)); - /* Hum.. */ - if (!edefs || (3*DFLT_MaxRtrAdvInterval) != ntohs(ha_info->lifetime)) - printf("\tHomeAgentLifetime %hu;\n", ntohs(ha_info->lifetime)); - break; - case ND_OPT_TARGET_LINKADDR: - case ND_OPT_REDIRECTED_HEADER: - flog(LOG_ERR, "invalid option %d in RA", (int)*opt_str); - break; - case ND_OPT_PREFIX_INFORMATION: - break; - case ND_OPT_ROUTE_INFORMATION: - break; - case ND_OPT_RDNSS_INFORMATION: - break; - case ND_OPT_DNSSL_INFORMATION: - break; - default: - dlog(LOG_DEBUG, 1, "unknown option %d in RA", - (int)*opt_str); - break; - } - - len -= optlen; - opt_str += optlen; - } - - orig_len -= sizeof(struct nd_router_advert); - - if (orig_len == 0) - return; - - opt_str = (uint8_t *)(msg + sizeof(struct nd_router_advert)); - - while (orig_len > 0) - { - int optlen; - struct nd_opt_prefix_info *pinfo; - struct nd_opt_route_info_local *rinfo; - struct nd_opt_rdnss_info_local *rdnss_info; - struct nd_opt_dnssl_info_local *dnssl_info; - char prefix_str[INET6_ADDRSTRLEN]; - char suffix[256]; - int offset, label_len; - - if (orig_len < 2) - { - flog(LOG_ERR, "trailing garbage in RA from %s", - addr_str); - break; - } - - optlen = (opt_str[1] << 3); - - if (optlen == 0) - { - flog(LOG_ERR, "zero length option in RA"); - break; - } - else if (optlen > orig_len) - { - flog(LOG_ERR, "option length greater than total" - " length in RA (type %d, optlen %d, len %d)", - (int)*opt_str, optlen, orig_len); - break; - } - - switch (*opt_str) - { - case ND_OPT_PREFIX_INFORMATION: - pinfo = (struct nd_opt_prefix_info *) opt_str; - - print_addr(&pinfo->nd_opt_pi_prefix, prefix_str); - - printf("\n\tprefix %s/%d\n\t{\n", prefix_str, pinfo->nd_opt_pi_prefix_len); - - if (ntohl(pinfo->nd_opt_pi_valid_time) == 0xffffffff) - { - if (!edefs || DFLT_AdvValidLifetime != 0xffffffff) - printf("\t\tAdvValidLifetime infinity; # (0xffffffff)\n"); - } - else - { - if (!edefs || DFLT_AdvValidLifetime != ntohl(pinfo->nd_opt_pi_valid_time)) - printf("\t\tAdvValidLifetime %u;\n", ntohl(pinfo->nd_opt_pi_valid_time)); - } - if (ntohl(pinfo->nd_opt_pi_preferred_time) == 0xffffffff) - { - if (!edefs || DFLT_AdvPreferredLifetime != 0xffffffff) - printf("\t\tAdvPreferredLifetime infinity; # (0xffffffff)\n"); - } - else - { - if (!edefs || DFLT_AdvPreferredLifetime != ntohl(pinfo->nd_opt_pi_preferred_time)) - printf("\t\tAdvPreferredLifetime %u;\n", ntohl(pinfo->nd_opt_pi_preferred_time)); - } - - if (!edefs || DFLT_AdvOnLinkFlag != (ND_OPT_PI_FLAG_ONLINK == (pinfo->nd_opt_pi_flags_reserved & ND_OPT_PI_FLAG_ONLINK))) - printf("\t\tAdvOnLink %s;\n", - (pinfo->nd_opt_pi_flags_reserved & ND_OPT_PI_FLAG_ONLINK)?"on":"off"); - - if (!edefs || DFLT_AdvAutonomousFlag != (ND_OPT_PI_FLAG_AUTO == (pinfo->nd_opt_pi_flags_reserved & ND_OPT_PI_FLAG_AUTO))) - printf("\t\tAdvAutonomous %s;\n", - (pinfo->nd_opt_pi_flags_reserved & ND_OPT_PI_FLAG_AUTO)?"on":"off"); - - /* Mobile IPv6 ext */ - if (!edefs || DFLT_AdvRouterAddr != (ND_OPT_PI_FLAG_RADDR == (pinfo->nd_opt_pi_flags_reserved & ND_OPT_PI_FLAG_RADDR))) - printf("\t\tAdvRouterAddr %s;\n", - (pinfo->nd_opt_pi_flags_reserved & ND_OPT_PI_FLAG_RADDR)?"on":"off"); - - printf("\t}; # End of prefix definition\n\n"); - break; - case ND_OPT_ROUTE_INFORMATION: - rinfo = (struct nd_opt_route_info_local *) opt_str; - - print_addr(&rinfo->nd_opt_ri_prefix, prefix_str); - - printf("\n\troute %s/%d\n\t{\n", prefix_str, rinfo->nd_opt_ri_prefix_len); - - if (!edefs || (((radvert->nd_ra_flags_reserved & 0x18) >> 3) & 0xff) != DFLT_AdvRoutePreference) { - printf("\t\tAdvRoutePreference "); - print_preferences(((rinfo->nd_opt_ri_flags_reserved & 0x18) >> 3) & 0xff); - printf(";\n"); - } - - /* XXX: we check DFLT_AdvRouteLifetime by interface, and it's outside of context here */ - if (ntohl(rinfo->nd_opt_ri_lifetime) == 0xffffffff) - printf("\t\tAdvRouteLifetime infinity; # (0xffffffff)\n"); - else - printf("\t\tAdvRouteLifetime %u;\n", ntohl(rinfo->nd_opt_ri_lifetime)); - - printf("\t}; # End of route definition\n\n"); - break; - case ND_OPT_RDNSS_INFORMATION: - rdnss_info = (struct nd_opt_rdnss_info_local *) opt_str; - - printf("\n\tRDNSS"); - - print_addr(&rdnss_info->nd_opt_rdnssi_addr1, prefix_str); - printf(" %s", prefix_str); - - if (rdnss_info->nd_opt_rdnssi_len >= 5) { - print_addr(&rdnss_info->nd_opt_rdnssi_addr2, prefix_str); - printf(" %s", prefix_str); - } - if (rdnss_info->nd_opt_rdnssi_len >= 7) { - print_addr(&rdnss_info->nd_opt_rdnssi_addr3, prefix_str); - printf(" %s", prefix_str); - } - - printf("\n\t{\n"); - /* as AdvRDNSSLifetime may depend on MaxRtrAdvInterval, it could change */ - if (ntohl(rdnss_info->nd_opt_rdnssi_lifetime) == 0xffffffff) - printf("\t\tAdvRDNSSLifetime infinity; # (0xffffffff)\n"); - else - printf("\t\tAdvRDNSSLifetime %u;\n", ntohl(rdnss_info->nd_opt_rdnssi_lifetime)); - - printf("\t}; # End of RDNSS definition\n\n"); - break; - case ND_OPT_DNSSL_INFORMATION: - dnssl_info = (struct nd_opt_dnssl_info_local *) opt_str; - - printf("\n\tDNSSL"); - suffix[0] = '\0'; - - for (offset = 0;offset < (dnssl_info->nd_opt_dnssli_len-1)*8;) { - label_len = dnssl_info->nd_opt_dnssli_suffixes[offset++]; - - if (label_len == 0) { - /* - * Ignore empty suffixes. They're - * probably just padding... - */ - if (suffix[0] == '\0') - continue; - - printf(" %s", suffix); - - suffix[0] = '\0'; - continue; - } - - if ((sizeof(suffix) - strlen(suffix)) < (label_len + 2)) { - flog(LOG_ERR, "oversized suffix in DNSSL option from %s", - addr_str); - break; - } - - if (suffix[0] != '\0') - strcat(suffix, "."); - strncat(suffix, &dnssl_info->nd_opt_dnssli_suffixes[offset], label_len); - offset += label_len; - } - - printf("\n\t{\n"); - /* as AdvDNSSLLifetime may depend on MaxRtrAdvInterval, it could change */ - if (ntohl(dnssl_info->nd_opt_dnssli_lifetime) == 0xffffffff) - printf("\t\tAdvDNSSLLifetime infinity; # (0xffffffff)\n"); - else - printf("\t\tAdvDNSSLLifetime %u;\n", ntohl(dnssl_info->nd_opt_dnssli_lifetime)); - - printf("\t}; # End of DNSSL definition\n\n"); - break; - default: - break; - } - orig_len -= optlen; - opt_str += optlen; - } - - printf("}; # End of interface definition\n"); - - fflush(stdout); -} - -void -print_preferences(int p) -{ - switch (p) { - case 0: - printf("medium"); - break; - case 1: - printf("high"); - break; - case 2: - /* reserved, ignore */ - break; - case 3: - printf("low"); - break; - } -} - -void -version(void) -{ - fprintf(stderr,"Version: %s\n\n", VERSION); - fprintf(stderr,"Please send bug reports and suggestions to %s\n", - CONTACT_EMAIL); - exit(1); -} - -void -usage(void) -{ - fprintf(stderr,"usage: %s %s\n", pname, usage_str); - exit(1); -} diff --git a/release/src/router/radvd/recv.c b/release/src/router/radvd/recv.c deleted file mode 100644 index aa5a19e28c..0000000000 --- a/release/src/router/radvd/recv.c +++ /dev/null @@ -1,119 +0,0 @@ -/* - * $Id: recv.c,v 1.14 2011/02/06 03:41:38 reubenhwk Exp $ - * - * Authors: - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" - -int -recv_rs_ra(unsigned char *msg, struct sockaddr_in6 *addr, - struct in6_pktinfo **pkt_info, int *hoplimit) -{ - struct msghdr mhdr; - struct cmsghdr *cmsg; - struct iovec iov; - static unsigned char *chdr = NULL; - static unsigned int chdrlen = 0; - int len; - fd_set rfds; - - if( ! chdr ) - { - chdrlen = CMSG_SPACE(sizeof(struct in6_pktinfo)) + - CMSG_SPACE(sizeof(int)); - if ((chdr = malloc(chdrlen)) == NULL) { - flog(LOG_ERR, "recv_rs_ra: malloc: %s", strerror(errno)); - return -1; - } - } - - FD_ZERO( &rfds ); - FD_SET( sock, &rfds ); - - if( select( sock+1, &rfds, NULL, NULL, NULL ) < 0 ) - { - if (errno != EINTR) - flog(LOG_ERR, "select: %s", strerror(errno)); - - return -1; - } - - iov.iov_len = MSG_SIZE_RECV; - iov.iov_base = (caddr_t) msg; - - memset(&mhdr, 0, sizeof(mhdr)); - mhdr.msg_name = (caddr_t)addr; - mhdr.msg_namelen = sizeof(*addr); - mhdr.msg_iov = &iov; - mhdr.msg_iovlen = 1; - mhdr.msg_control = (void *)chdr; - mhdr.msg_controllen = chdrlen; - - len = recvmsg(sock, &mhdr, 0); - - if (len < 0) - { - if (errno != EINTR) - flog(LOG_ERR, "recvmsg: %s", strerror(errno)); - - return len; - } - - *hoplimit = 255; - - for (cmsg = CMSG_FIRSTHDR(&mhdr); cmsg != NULL; cmsg = CMSG_NXTHDR(&mhdr, cmsg)) - { - if (cmsg->cmsg_level != IPPROTO_IPV6) - continue; - - switch(cmsg->cmsg_type) - { -#ifdef IPV6_HOPLIMIT - case IPV6_HOPLIMIT: - if ((cmsg->cmsg_len == CMSG_LEN(sizeof(int))) && - (*(int *)CMSG_DATA(cmsg) >= 0) && - (*(int *)CMSG_DATA(cmsg) < 256)) - { - *hoplimit = *(int *)CMSG_DATA(cmsg); - } - else - { - flog(LOG_ERR, "received a bogus IPV6_HOPLIMIT from the kernel! len=%d, data=%d", - cmsg->cmsg_len, *(int *)CMSG_DATA(cmsg)); - return (-1); - } - break; -#endif /* IPV6_HOPLIMIT */ - case IPV6_PKTINFO: - if ((cmsg->cmsg_len == CMSG_LEN(sizeof(struct in6_pktinfo))) && - ((struct in6_pktinfo *)CMSG_DATA(cmsg))->ipi6_ifindex) - { - *pkt_info = (struct in6_pktinfo *)CMSG_DATA(cmsg); - } - else - { - flog(LOG_ERR, "received a bogus IPV6_PKTINFO from the kernel! len=%d, index=%d", - cmsg->cmsg_len, ((struct in6_pktinfo *)CMSG_DATA(cmsg))->ipi6_ifindex); - return (-1); - } - break; - } - } - - dlog(LOG_DEBUG, 4, "recvmsg len=%d", len); - - return len; -} diff --git a/release/src/router/radvd/redhat/radvd-tmpfs.conf b/release/src/router/radvd/redhat/radvd-tmpfs.conf deleted file mode 100644 index 590652c4ef..0000000000 --- a/release/src/router/radvd/redhat/radvd-tmpfs.conf +++ /dev/null @@ -1 +0,0 @@ -d /var/run/radvd 0755 radvd radvd diff --git a/release/src/router/radvd/redhat/radvd.conf.empty b/release/src/router/radvd/redhat/radvd.conf.empty deleted file mode 100644 index c006f86313..0000000000 --- a/release/src/router/radvd/redhat/radvd.conf.empty +++ /dev/null @@ -1,18 +0,0 @@ -# NOTE: there is no such thing as a working "by-default" configuration file. -# At least the prefix needs to be specified. Please consult the radvd.conf(5) -# man page and/or /usr/share/doc/radvd-*/radvd.conf.example for help. -# -# -#interface eth0 -#{ -# AdvSendAdvert on; -# MinRtrAdvInterval 30; -# MaxRtrAdvInterval 100; -# prefix 2001:db8:1:0::/64 -# { -# AdvOnLink on; -# AdvAutonomous on; -# AdvRouterAddr off; -# }; -# -#}; diff --git a/release/src/router/radvd/redhat/radvd.init b/release/src/router/radvd/redhat/radvd.init deleted file mode 100644 index 6e406c5350..0000000000 --- a/release/src/router/radvd/redhat/radvd.init +++ /dev/null @@ -1,93 +0,0 @@ -#! /bin/sh -# -# $Id: radvd.init,v 1.7 2010/03/05 12:14:47 psavola Exp $ -# -# chkconfig: - 54 46 -# description: radvd is the router advertisement daemon for IPv6. It \ -# listens to router solicitations and sends router \ -# advertisements as described in "Neighbor Discovery for IP \ -# Version 6 (IPv6)" (RFC 2461). With these advertisements \ -# hosts can automatically configure their addresses and some \ -# other parameters. They also can choose a default router \ -# based on these advertisements. -# -# processname: radvd -# pidfile: /var/run/radvd.pid -# config: /etc/radvd.conf -# config: /etc/sysconfig/radvd - -### BEGIN INIT INFO -# Provides: radvd -# Short-Description: router advertisement daemon for IPv6 -### END INIT INFO - -# Source function library. -. /etc/rc.d/init.d/functions - -# Get config. -. /etc/sysconfig/network - -[ -f /etc/sysconfig/radvd ] && . /etc/sysconfig/radvd - -RETVAL=0 -PROG="radvd" -LOCKFILE=/var/lock/subsys/radvd - -# See how we were called. -case "$1" in - start) - if [ ! -f /etc/radvd.conf ]; then - echo $"Configuration file /etc/radvd.conf missing" 1>&2 - exit 6 - fi - if [ `id -u` -ne 0 ]; then - echo $"Insufficient privilege" 1>&2 - exit 4 - fi - echo -n $"Starting $PROG: " - daemon radvd $OPTIONS - RETVAL=$? - echo - if [ $RETVAL -eq 0 ]; then - touch $LOCKFILE - else - if [ -f $LOCKFILE ]; then - RETVAL=0 - fi - fi - ;; - stop) - echo -n $"Stopping $PROG: " - killproc radvd - RETVAL=$? - echo - [ $RETVAL -eq 0 ] && rm -f $LOCKFILE - ;; - status) - status radvd - RETVAL=$? - ;; - restart) - $0 stop - $0 start - RETVAL=$? - ;; - reload|force-reload) - echo -n $"Reloading $PROG: " - killproc radvd -HUP - RETVAL=$? - echo - ;; - condrestart|try-restart) - if [ -f $LOCKFILE ]; then - $0 stop - $0 start - RETVAL=$? - fi - ;; - *) - echo $"Usage: $0 {start|stop|status|restart|try-restart|reload|force-reload}" - exit 2 -esac - -exit $RETVAL diff --git a/release/src/router/radvd/redhat/radvd.spec b/release/src/router/radvd/redhat/radvd.spec deleted file mode 100644 index 9029a61b68..0000000000 --- a/release/src/router/radvd/redhat/radvd.spec +++ /dev/null @@ -1,247 +0,0 @@ -# $Id: radvd.spec,v 1.31 2011/05/06 14:32:12 reubenhwk Exp $ - -%define initdir %{_sysconfdir}/rc.d/init.d - -%define RADVD_UID 75 - -Summary: A Router Advertisement daemon -Name: radvd -Version: 1.8 -Release: 1 -# The code includes the advertising clause, so it's GPL-incompatible -License: BSD with advertising -Group: System Environment/Daemons -URL: http://www.litech.org/radvd/ -Source: http://www.litech.org/radvd/dist/%{name}-%{version}.tar.gz -Requires(postun): chkconfig, initscripts -Requires(preun): chkconfig, initscripts -Requires(post): chkconfig -Requires(pre): /usr/sbin/useradd -BuildRequires: flex, byacc -BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) - -%description -radvd is the router advertisement daemon for IPv6. It listens to router -solicitations and sends router advertisements as described in "Neighbor -Discovery for IP Version 6 (IPv6)" (RFC 2461). With these advertisements -hosts can automatically configure their addresses and some other -parameters. They also can choose a default router based on these -advertisements. - -Install radvd if you are setting up IPv6 network and/or Mobile IPv6 -services. - -%prep -%setup -q - -%build -export CFLAGS="$RPM_OPT_FLAGS -D_GNU_SOURCE -fPIE" -export LDFLAGS='-pie -Wl,-z,relro,-z,now,-z,noexecstack,-z,nodlopen' -%configure --with-pidfile=%{_localstatedir}/run/radvd/radvd.pid -make -# make %{?_smp_mflags} -# Parallel builds still fail because seds that transform y.tab.x into -# scanner/gram.x are not executed before compile of scanner/gram.x -# - -%install -[ $RPM_BUILD_ROOT != "/" ] && rm -rf $RPM_BUILD_ROOT - -make DESTDIR=$RPM_BUILD_ROOT install - -mkdir -p $RPM_BUILD_ROOT%{_sysconfdir}/sysconfig -mkdir -p $RPM_BUILD_ROOT%{initdir} -mkdir -p $RPM_BUILD_ROOT%{_localstatedir}/run/radvd - -install -m 644 redhat/radvd.conf.empty $RPM_BUILD_ROOT%{_sysconfdir}/radvd.conf -install -m 755 redhat/radvd.init $RPM_BUILD_ROOT%{initdir}/radvd -install -m 644 redhat/radvd.sysconfig $RPM_BUILD_ROOT%{_sysconfdir}/sysconfig/radvd - -install -d -m 755 $RPM_BUILD_ROOT%{_sysconfdir}/tmpfiles.d -install -p -m 644 redhat/radvd-tmpfs.conf $RPM_BUILD_ROOT%{_sysconfdir}/tmpfiles.d/radvd.conf - -%clean -[ $RPM_BUILD_ROOT != "/" ] && rm -rf $RPM_BUILD_ROOT - -%postun -if [ "$1" -ge "1" ]; then - /sbin/service radvd condrestart >/dev/null 2>&1 -fi - -%post -/sbin/chkconfig --add radvd - -%preun -if [ $1 = 0 ]; then - /sbin/service radvd stop >/dev/null 2>&1 - /sbin/chkconfig --del radvd -fi - -%pre -getent group radvd >/dev/null || groupadd -g %RADVD_UID -r radvd -getent passwd radvd >/dev/null || \ - useradd -r -u %RADVD_UID -g radvd -d / -s /sbin/nologin -c "radvd user" radvd -exit 0 - -%files -%defattr(-,root,root,-) -%doc COPYRIGHT README CHANGES INTRO.html TODO -%config(noreplace) %{_sysconfdir}/radvd.conf -%config(noreplace) %{_sysconfdir}/sysconfig/radvd -%config(noreplace) %{_sysconfdir}/tmpfiles.d/radvd.conf -%{initdir}/radvd -%dir %attr(-,radvd,radvd) %{_localstatedir}/run/radvd/ -%doc radvd.conf.example -%{_mandir}/*/* -%{_sbindir}/radvd -%{_sbindir}/radvdump - -%changelog -* Fri May 6 2011 Reuben Hawkins 1.8-1 -- 1.8 -- IgnoreIfMissing now defaults to on -- Added FlushRoute -- Added DeprecatePrefix -- Added DecrementLifetimes -- Using netlink (on linux) to instantly detect changes in interface states -- Timer code removed, replaces with poll -- build system overhaul -- Some bug fixes - -* Sat Jan 1 2011 Pekka Savola 1.7-1 -- 1.7 -- Deprecate old, pre-RFC5006 parameters. -- Support RFC6106 by adding DNS Search List support. -- Add '-c' flag to test configuration -- Fix a segmentation fault on reload_config() timer list - corruption that only occurs with multiple interfaces -- Fix radvd skipping multiple interfaces when - UnicastOnly is on or AdvSendAdvert is off. - This got broken in radvd 1.3. Patch from Cedric BAIL -- OSX build -- minor code cleanups - -* Fri Mar 5 2010 Pekka Savola 1.6-1 -- 1.6 -- Updated the spec file from Fedora (remove userdel at postun), - use compile flags -- Updated init script from Fedora. - -* Thu Sep 10 2009 Pekka Savola 1.5-1 -- 1.5 - -* Mon Aug 3 2009 Pekka Savola 1.4-1 -- 1.4 - -* Tue Jul 7 2009 Pekka Savola 1.3-1 -- 1.3; some improvements to the init script - -* Tue Oct 28 2008 Pekka Savola 1.2-1 -- 1.2; remove -D_GNU_SOURCE - -* Mon Feb 4 2008 Pekka Savola 1.1-1 -- 1.1 - -* Wed Nov 1 2006 Pekka Savola 1.0-1 -- 1.0; add BuildRequires - -* Fri Jan 13 2006 Pekka Savola 0.9.1-1 -- 0.9.1 - -* Tue Oct 18 2005 Pekka Savola 0.9-1 -- 0.9 (also minor spec file cleanup in %%configure). - -* Fri Jul 8 2005 Pekka Savola 0.8-1 -- 0.8. -- Ship the example config file as %%doc (Red Hat's #159005) - -* Mon Feb 21 2005 Pekka Savola 0.7.3-1 -- 0.7.3. - -* Mon Oct 28 2002 Pekka Savola -- 0.7.2. - -* Tue May 7 2002 Pekka Savola -- remove '-g %%{RADVD_GID}' when creating the user, which may be problematic - if the user didn't exist before. - -* Wed Jan 14 2002 Pekka Savola -- 0.7.1. - -* Tue Jan 8 2002 Pekka Savola -- Change 'reload' to signal HUP to radvd instead or restarting. - -* Fri Dec 28 2001 Pekka Savola -- License unfortunately is BSD *with* advertising clause, so to be pedantic, - change License: to 'BSD-style'. - -* Wed Nov 14 2001 Pekka Savola -- spec file cleanups -- update to 0.7.0. - -* Wed Jun 20 2001 Pekka Savola -- use /sbin/service. -- update to 0.6.2pl4. - -* Sat Apr 28 2001 Pekka Savola -- update to 0.6.2pl3. - -* Wed Apr 11 2001 Pekka Savola -- update to 0.6.2pl2. - -* Wed Apr 4 2001 Pekka Savola -- update to 0.62pl1. Bye bye patches! -- Require: initscripts (should really be with a version providing IPv6) -- clean up the init script, make condrestart work properly -- Use a static /etc/rc.d/init.d; init.d/radvd required it anyway. - -* Sun Apr 1 2001 Pekka Savola -- add patch to chroot (doesn't work well yet, as /proc is used directly) -- clean up droproot patch, drop the rights earlier; require user-writable -pidfile directory -- set up the pidfile directory at compile time. - -* Sat Mar 31 2001 Pekka Savola -- add select/kill signals patch from Nathan Lutchansky . -- add address syntax checked fix from Marko Myllynen . -- add patch to check the pid file before fork. -- add support for OPTIONS sourced from /etc/sysconfig/radvd, provide a nice -default one. -- add/delete radvd user, change the pidfile to /var/run/radvd/radvd.pid. -- fix initscript NETWORKING_IPV6 check. - -* Sun Mar 18 2001 Pekka Savola -- add droproot patch, change to nobody by default (should use radvd:radvd or -the like, really). - -* Mon Mar 5 2001 Tim Powers -- applied patch supplied by Pekka Savola in #30508 -- made changes to initscript as per Pekka's suggestions - -* Thu Feb 15 2001 Tim Powers -- needed -D_GNU_SOURCE to build properly - -* Tue Feb 6 2001 Tim Powers -- use %%configure and %%makeinstall, just glob the manpages, cleans - things up -- fixed initscript so that it can be internationalized in the future - -* Fri Feb 2 2001 Pekka Savola -- Create a single package(source) for glibc21 and glibc22 (automatic -Requires can handle this just fine). -- use %%{_mandir} and friends -- add more flesh to %doc -- streamline %config file %attrs -- streamline init.d file a bit: - * add a default chkconfig: (default to disable for security etc. reasons; - also, the default config isn't generic enough..) - * add reload/condrestart - * minor tweaks - * missing: localization support (initscripts-5.60) -- use %%initdir macro - -* Thu Feb 1 2001 Lars Fenneberg -- updated to new release 0.6.2 - -* Thu Feb 1 2001 Marko Myllynen -- initial version, radvd version 0.6.1 diff --git a/release/src/router/radvd/redhat/radvd.sysconfig b/release/src/router/radvd/redhat/radvd.sysconfig deleted file mode 100644 index 75b519cf5a..0000000000 --- a/release/src/router/radvd/redhat/radvd.sysconfig +++ /dev/null @@ -1,7 +0,0 @@ -# $Id: radvd.sysconfig,v 1.1 2001/11/14 19:58:11 lutchann Exp $ - -# No chroot; /var/run/radvd must be owned by -u. -OPTIONS="-u radvd" - -# Chroot; directory structure under /var/chroot/radvd has to be populated. -#OPTIONS="-u radvd -t /var/chroot/radvd" diff --git a/release/src/router/radvd/scanner.l b/release/src/router/radvd/scanner.l deleted file mode 100644 index 35ec8bbf7b..0000000000 --- a/release/src/router/radvd/scanner.l +++ /dev/null @@ -1,158 +0,0 @@ -/* - * $Id: scanner.l,v 1.29 2011/05/07 02:09:40 reubenhwk Exp $ - * - * Authors: - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996-2000 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -%option nounput noinput noyywrap - -%{ -#include -#include "config.h" -#include "includes.h" -#include "log.h" -#include "gram.h" - -extern char *conf_file; - -int num_lines = 1; - -#define YY_NO_INPUT -%} - -digit [0-9] -number ({digit})+ -snum -?({digit})+ -decimal ({number}"."{number}) -hexdigit ([a-f]|[A-F]|[0-9]) -addr1 {hexdigit}{1,4}":"({hexdigit}{1,4}":")*(":"{hexdigit}{1,4})+ -addr2 {hexdigit}{1,4}(":"{hexdigit}{1,4})*"::" -addr3 ({hexdigit}{1,4}":"){7}{hexdigit}{1,4} -addr ({addr1}|{addr2}|{addr3}|"::") -whitespace ([ \t])+ -string [a-zA-Z0-9`~!@#$%\^&*()_\-+=:\[\]<>,\.?\\]+ -%% - -#.*$ {/* ignore comments */} -\n {num_lines++;} -{whitespace} {} - -interface { return T_INTERFACE; } -prefix { return T_PREFIX; } -route { return T_ROUTE; } -RDNSS { return T_RDNSS; } -DNSSL { return T_DNSSL; } -clients { return T_CLIENTS; } - -IgnoreIfMissing { return T_IgnoreIfMissing; } -AdvSendAdvert { return T_AdvSendAdvert; } -MaxRtrAdvInterval { return T_MaxRtrAdvInterval; } -MinRtrAdvInterval { return T_MinRtrAdvInterval; } -AdvManagedFlag { return T_AdvManagedFlag; } -AdvOtherConfigFlag { return T_AdvOtherConfigFlag; } -AdvLinkMTU { return T_AdvLinkMTU; } -AdvReachableTime { return T_AdvReachableTime; } -AdvRetransTimer { return T_AdvRetransTimer; } -AdvCurHopLimit { return T_AdvCurHopLimit; } -AdvDefaultLifetime { return T_AdvDefaultLifetime; } -AdvDefaultPreference { return T_AdvDefaultPreference; } -AdvSourceLLAddress { return T_AdvSourceLLAddress; } - -AdvOnLink { return T_AdvOnLink; } -AdvAutonomous { return T_AdvAutonomous; } -AdvValidLifetime { return T_AdvValidLifetime; } -AdvPreferredLifetime { return T_AdvPreferredLifetime; } -DeprecatePrefix { return T_DeprecatePrefix; } -DecrementLifetimes { return T_DecrementLifetimes; } - -AdvRouterAddr { return T_AdvRouterAddr; } -AdvHomeAgentFlag { return T_AdvHomeAgentFlag; } -AdvIntervalOpt { return T_AdvIntervalOpt; } -AdvHomeAgentInfo { return T_AdvHomeAgentInfo; } -UnicastOnly { return T_UnicastOnly; } - -Base6Interface { return T_Base6Interface; } -Base6to4Interface { return T_Base6to4Interface; } - -HomeAgentPreference { return T_HomeAgentPreference; } -HomeAgentLifetime { return T_HomeAgentLifetime; } - -AdvRoutePreference { return T_AdvRoutePreference; } -AdvRouteLifetime { return T_AdvRouteLifetime; } -RemoveRoute { return T_RemoveRoute; } - -AdvRDNSSPreference { return T_AdvRDNSSPreference; } -AdvRDNSSOpen { return T_AdvRDNSSOpenFlag; } -AdvRDNSSLifetime { return T_AdvRDNSSLifetime; } -FlushRDNSS { return T_FlushRDNSS; } - -AdvDNSSLLifetime { return T_AdvDNSSLLifetime; } -FlushDNSSL { return T_FlushDNSSL; } - -MinDelayBetweenRAs { return T_MinDelayBetweenRAs; } - -AdvMobRtrSupportFlag { return T_AdvMobRtrSupportFlag; } - -{addr} { - static struct in6_addr addr; - if (inet_pton(AF_INET6, yytext, &addr) < 1) { - flog(LOG_ERR, "invalid address in %s, line %d", conf_file, - num_lines); - return T_BAD_TOKEN; - } - - yylval.addr = &addr; - return IPV6ADDR; - } - -{number} { - unsigned long lnum; - char *endp; - lnum = strtoul(yytext, &endp, 10); - if (*yytext == '\0' || *endp != '\0') - return T_BAD_TOKEN; - if (lnum > 0xFFFFFFFFUL) - return T_BAD_TOKEN; /* XXX */ - yylval.num = lnum; - return NUMBER; - } - -{snum} { yylval.snum = atoi(yytext); return SIGNEDNUMBER; } - -{decimal} { yylval.dec = atof(yytext); return DECIMAL; } - -infinity { return INFINITY; } - -on { yylval.num = 1; return SWITCH; } - -off { yylval.num = 0; return SWITCH; } - -low { yylval.snum = -1; return SIGNEDNUMBER; } - -medium { yylval.snum = 0; return SIGNEDNUMBER; } - -high { yylval.snum = 1; return SIGNEDNUMBER; } - -{string} { - static char string[256]; - - strncpy(string, yytext, sizeof(string)); - string[sizeof(string)-1] = '\0'; - yylval.str = string; - return STRING; - } - -"{"|"}"|";"|"/" { return *yytext; } - -. { return T_BAD_TOKEN; } -%% diff --git a/release/src/router/radvd/send.c b/release/src/router/radvd/send.c deleted file mode 100644 index 1c24833d65..0000000000 --- a/release/src/router/radvd/send.c +++ /dev/null @@ -1,518 +0,0 @@ -/* - * $Id: send.c,v 1.48 2011/05/06 07:51:54 reubenhwk Exp $ - * - * Authors: - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" - -/* - * Sends an advertisement for all specified clients of this interface - * (or via broadcast, if there are no restrictions configured). - * - * If a destination address is given, the RA will be sent to the destination - * address only, but only if it was configured. - * - */ -int -send_ra_forall(struct Interface *iface, struct in6_addr *dest) -{ - struct Clients *current; - - /* If no list of clients was specified for this interface, we broadcast */ - if (iface->ClientList == NULL) - return send_ra(iface, dest); - - /* If clients are configured, send the advertisement to all of them via unicast */ - for (current = iface->ClientList; current; current = current->next) - { - char address_text[INET6_ADDRSTRLEN]; - memset(address_text, 0, sizeof(address_text)); - if (get_debuglevel() >= 5) - inet_ntop(AF_INET6, ¤t->Address, address_text, INET6_ADDRSTRLEN); - - /* If a non-authorized client sent a solicitation, ignore it (logging later) */ - if (dest != NULL && memcmp(dest, ¤t->Address, sizeof(struct in6_addr)) != 0) - continue; - dlog(LOG_DEBUG, 5, "Sending RA to %s", address_text); - send_ra(iface, &(current->Address)); - - /* If we should only send the RA to a specific address, we are done */ - if (dest != NULL) - return 0; - } - if (dest == NULL) - return 0; - - /* If we refused a client's solicitation, log it if debugging is high enough */ - char address_text[INET6_ADDRSTRLEN]; - memset(address_text, 0, sizeof(address_text)); - if (get_debuglevel() >= 5) - inet_ntop(AF_INET6, dest, address_text, INET6_ADDRSTRLEN); - - dlog(LOG_DEBUG, 5, "Not answering request from %s, not configured", address_text); - return 0; -} - -static void -send_ra_inc_len(size_t *len, int add) -{ - *len += add; - if(*len >= MSG_SIZE_SEND) - { - flog(LOG_ERR, "Too many prefixes or routes. Exiting."); - exit(1); - } -} - -static time_t -time_diff_secs(const struct timeval *time_x, const struct timeval *time_y) -{ - time_t secs_diff; - - secs_diff = time_x->tv_sec - time_y->tv_sec; - if ((time_x->tv_usec - time_y->tv_usec) >= 500000) - secs_diff++; - - return secs_diff; - -} - -static void -decrement_lifetime(const time_t secs, uint32_t *lifetime) -{ - - if (*lifetime > secs) { - *lifetime -= secs; - } else { - *lifetime = 0; - } -} - -static void cease_adv_pfx_msg(const char *if_name, struct in6_addr *pfx, const int pfx_len) -{ - char pfx_str[INET6_ADDRSTRLEN]; - - print_addr(pfx, pfx_str); - - dlog(LOG_DEBUG, 3, "Will cease advertising %s/%u%%%s, preferred lifetime is 0", pfx_str, pfx_len, if_name); - -} - -int -send_ra(struct Interface *iface, struct in6_addr *dest) -{ - uint8_t all_hosts_addr[] = {0xff,0x02,0,0,0,0,0,0,0,0,0,0,0,0,0,1}; - struct sockaddr_in6 addr; - struct in6_pktinfo *pkt_info; - struct msghdr mhdr; - struct cmsghdr *cmsg; - struct iovec iov; - char __attribute__((aligned(8))) chdr[CMSG_SPACE(sizeof(struct in6_pktinfo))]; - struct nd_router_advert *radvert; - struct AdvPrefix *prefix; - struct AdvRoute *route; - struct AdvRDNSS *rdnss; - struct AdvDNSSL *dnssl; - struct timeval time_now; - time_t secs_since_last_ra; - - unsigned char buff[MSG_SIZE_SEND]; - size_t len = 0; - ssize_t err; - - /* First we need to check that the interface hasn't been removed or deactivated */ - if(check_device(iface) < 0) { - if (iface->IgnoreIfMissing) /* a bit more quiet warning message.. */ - dlog(LOG_DEBUG, 4, "interface %s does not exist, ignoring the interface", iface->Name); - else { - flog(LOG_WARNING, "interface %s does not exist, ignoring the interface", iface->Name); - } - iface->HasFailed = 1; - /* not really a 'success', but we need to schedule new timers.. */ - return 0; - } else { - /* check_device was successful, act if it has failed previously */ - if (iface->HasFailed == 1) { - flog(LOG_WARNING, "interface %s seems to have come back up, trying to reinitialize", iface->Name); - iface->HasFailed = 0; - /* - * return -1 so timer_handler() doesn't schedule new timers, - * reload_config() will kick off new timers anyway. This avoids - * timer list corruption. - */ - reload_config(); - return -1; - } - } - - /* Make sure that we've joined the all-routers multicast group */ - if (check_allrouters_membership(iface) < 0) - flog(LOG_WARNING, "problem checking all-routers membership on %s", iface->Name); - - dlog(LOG_DEBUG, 3, "sending RA on %s", iface->Name); - - if (dest == NULL) - { - dest = (struct in6_addr *)all_hosts_addr; - gettimeofday(&iface->last_multicast, NULL); - } - - gettimeofday(&time_now, NULL); - secs_since_last_ra = time_diff_secs(&time_now, &iface->last_ra_time); - if (secs_since_last_ra < 0) { - secs_since_last_ra = 0; - flog(LOG_WARNING, "gettimeofday() went backwards!"); - } - iface->last_ra_time = time_now; - - memset((void *)&addr, 0, sizeof(addr)); - addr.sin6_family = AF_INET6; - addr.sin6_port = htons(IPPROTO_ICMPV6); - memcpy(&addr.sin6_addr, dest, sizeof(struct in6_addr)); - - memset(buff, 0, sizeof(buff)); - radvert = (struct nd_router_advert *) buff; - - radvert->nd_ra_type = ND_ROUTER_ADVERT; - radvert->nd_ra_code = 0; - radvert->nd_ra_cksum = 0; - - radvert->nd_ra_curhoplimit = iface->AdvCurHopLimit; - radvert->nd_ra_flags_reserved = - (iface->AdvManagedFlag)?ND_RA_FLAG_MANAGED:0; - radvert->nd_ra_flags_reserved |= - (iface->AdvOtherConfigFlag)?ND_RA_FLAG_OTHER:0; - /* Mobile IPv6 ext */ - radvert->nd_ra_flags_reserved |= - (iface->AdvHomeAgentFlag)?ND_RA_FLAG_HOME_AGENT:0; - - if (iface->cease_adv) { - radvert->nd_ra_router_lifetime = 0; - } else { - /* if forwarding is disabled, send zero router lifetime */ - radvert->nd_ra_router_lifetime = !check_ip6_forwarding() ? htons(iface->AdvDefaultLifetime) : 0; - } - radvert->nd_ra_flags_reserved |= - (iface->AdvDefaultPreference << ND_OPT_RI_PRF_SHIFT) & ND_OPT_RI_PRF_MASK; - - radvert->nd_ra_reachable = htonl(iface->AdvReachableTime); - radvert->nd_ra_retransmit = htonl(iface->AdvRetransTimer); - - len = sizeof(struct nd_router_advert); - - prefix = iface->AdvPrefixList; - - /* - * add prefix options - */ - - while(prefix) - { - if( prefix->enabled && prefix->curr_preferredlft > 0 ) - { - struct nd_opt_prefix_info *pinfo; - - pinfo = (struct nd_opt_prefix_info *) (buff + len); - - pinfo->nd_opt_pi_type = ND_OPT_PREFIX_INFORMATION; - pinfo->nd_opt_pi_len = 4; - pinfo->nd_opt_pi_prefix_len = prefix->PrefixLen; - - pinfo->nd_opt_pi_flags_reserved = - (prefix->AdvOnLinkFlag)?ND_OPT_PI_FLAG_ONLINK:0; - pinfo->nd_opt_pi_flags_reserved |= - (prefix->AdvAutonomousFlag)?ND_OPT_PI_FLAG_AUTO:0; - /* Mobile IPv6 ext */ - pinfo->nd_opt_pi_flags_reserved |= - (prefix->AdvRouterAddr)?ND_OPT_PI_FLAG_RADDR:0; - - if (iface->cease_adv && prefix->DeprecatePrefixFlag) { - /* RFC4862, 5.5.3, step e) */ - pinfo->nd_opt_pi_valid_time = htonl(MIN_AdvValidLifetime); - pinfo->nd_opt_pi_preferred_time = 0; - } else { - if (prefix->DecrementLifetimesFlag) { - decrement_lifetime(secs_since_last_ra, - &prefix->curr_validlft); - - decrement_lifetime(secs_since_last_ra, - &prefix->curr_preferredlft); - if (prefix->curr_preferredlft == 0) - cease_adv_pfx_msg(iface->Name, &prefix->Prefix, prefix->PrefixLen); - } - pinfo->nd_opt_pi_valid_time = htonl(prefix->curr_validlft); - pinfo->nd_opt_pi_preferred_time = htonl(prefix->curr_preferredlft); - - } - pinfo->nd_opt_pi_reserved2 = 0; - - memcpy(&pinfo->nd_opt_pi_prefix, &prefix->Prefix, - sizeof(struct in6_addr)); - - send_ra_inc_len(&len, sizeof(*pinfo)); - } - - prefix = prefix->next; - } - - route = iface->AdvRouteList; - - /* - * add route options - */ - - while(route) - { - struct nd_opt_route_info_local *rinfo; - - rinfo = (struct nd_opt_route_info_local *) (buff + len); - - rinfo->nd_opt_ri_type = ND_OPT_ROUTE_INFORMATION; - /* XXX: the prefixes are allowed to be sent in smaller chunks as well */ - rinfo->nd_opt_ri_len = 3; - rinfo->nd_opt_ri_prefix_len = route->PrefixLen; - - rinfo->nd_opt_ri_flags_reserved = - (route->AdvRoutePreference << ND_OPT_RI_PRF_SHIFT) & ND_OPT_RI_PRF_MASK; - if (iface->cease_adv && route->RemoveRouteFlag) { - rinfo->nd_opt_ri_lifetime = 0; - } else { - rinfo->nd_opt_ri_lifetime = htonl(route->AdvRouteLifetime); - } - - memcpy(&rinfo->nd_opt_ri_prefix, &route->Prefix, - sizeof(struct in6_addr)); - send_ra_inc_len(&len, sizeof(*rinfo)); - - route = route->next; - } - - rdnss = iface->AdvRDNSSList; - - /* - * add rdnss options - */ - - while(rdnss) - { - struct nd_opt_rdnss_info_local *rdnssinfo; - - rdnssinfo = (struct nd_opt_rdnss_info_local *) (buff + len); - - rdnssinfo->nd_opt_rdnssi_type = ND_OPT_RDNSS_INFORMATION; - rdnssinfo->nd_opt_rdnssi_len = 1 + 2*rdnss->AdvRDNSSNumber; - rdnssinfo->nd_opt_rdnssi_pref_flag_reserved = 0; - - if (iface->cease_adv && rdnss->FlushRDNSSFlag) { - rdnssinfo->nd_opt_rdnssi_lifetime = 0; - } else { - rdnssinfo->nd_opt_rdnssi_lifetime = htonl(rdnss->AdvRDNSSLifetime); - } - - memcpy(&rdnssinfo->nd_opt_rdnssi_addr1, &rdnss->AdvRDNSSAddr1, - sizeof(struct in6_addr)); - memcpy(&rdnssinfo->nd_opt_rdnssi_addr2, &rdnss->AdvRDNSSAddr2, - sizeof(struct in6_addr)); - memcpy(&rdnssinfo->nd_opt_rdnssi_addr3, &rdnss->AdvRDNSSAddr3, - sizeof(struct in6_addr)); - send_ra_inc_len(&len, sizeof(*rdnssinfo) - (3-rdnss->AdvRDNSSNumber)*sizeof(struct in6_addr)); - - rdnss = rdnss->next; - } - - dnssl = iface->AdvDNSSLList; - - /* - * add dnssl options - */ - - while(dnssl) - { - struct nd_opt_dnssl_info_local *dnsslinfo; - int i; - char *buff_ptr; - - dnsslinfo = (struct nd_opt_dnssl_info_local *) (buff + len); - - dnsslinfo->nd_opt_dnssli_type = ND_OPT_DNSSL_INFORMATION; - dnsslinfo->nd_opt_dnssli_len = 1; /* more further down */ - dnsslinfo->nd_opt_dnssli_reserved = 0; - - if (iface->cease_adv && dnssl->FlushDNSSLFlag) { - dnsslinfo->nd_opt_dnssli_lifetime = 0; - } else { - dnsslinfo->nd_opt_dnssli_lifetime = htonl(dnssl->AdvDNSSLLifetime); - } - - buff_ptr = dnsslinfo->nd_opt_dnssli_suffixes; - for (i = 0; i < dnssl->AdvDNSSLNumber; i++) { - char *label; - int label_len; - - label = dnssl->AdvDNSSLSuffixes[i]; - - while (label[0] != '\0') { - if (strchr(label, '.') == NULL) - label_len = strlen(label); - else - label_len = strchr(label, '.') - label; - - *buff_ptr++ = label_len; - - memcpy(buff_ptr, label, label_len); - buff_ptr += label_len; - - label += label_len; - - if (label[0] == '.') - label++; - else - *buff_ptr++ = 0; - } - } - - dnsslinfo->nd_opt_dnssli_len += ((buff_ptr-dnsslinfo->nd_opt_dnssli_suffixes)+7)/8; - - send_ra_inc_len(&len, dnsslinfo->nd_opt_dnssli_len * 8); - - dnssl = dnssl->next; - } - - /* - * add MTU option - */ - - if (iface->AdvLinkMTU != 0) { - struct nd_opt_mtu *mtu; - - mtu = (struct nd_opt_mtu *) (buff + len); - - mtu->nd_opt_mtu_type = ND_OPT_MTU; - mtu->nd_opt_mtu_len = 1; - mtu->nd_opt_mtu_reserved = 0; - mtu->nd_opt_mtu_mtu = htonl(iface->AdvLinkMTU); - - send_ra_inc_len(&len, sizeof(*mtu)); - } - - /* - * add Source Link-layer Address option - */ - - if (iface->AdvSourceLLAddress && iface->if_hwaddr_len > 0) - { - uint8_t *ucp; - unsigned int i; - - ucp = (uint8_t *) (buff + len); - - *ucp++ = ND_OPT_SOURCE_LINKADDR; - *ucp++ = (uint8_t) ((iface->if_hwaddr_len + 16 + 63) >> 6); - - send_ra_inc_len(&len, 2 * sizeof(uint8_t)); - - i = (iface->if_hwaddr_len + 7) >> 3; - memcpy(buff + len, iface->if_hwaddr, i); - send_ra_inc_len(&len, i); - } - - /* - * Mobile IPv6 ext: Advertisement Interval Option to support - * movement detection of mobile nodes - */ - - if(iface->AdvIntervalOpt) - { - struct AdvInterval a_ival; - uint32_t ival; - if(iface->MaxRtrAdvInterval < Cautious_MaxRtrAdvInterval){ - ival = ((iface->MaxRtrAdvInterval + - Cautious_MaxRtrAdvInterval_Leeway ) * 1000); - - } - else { - ival = (iface->MaxRtrAdvInterval * 1000); - } - a_ival.type = ND_OPT_RTR_ADV_INTERVAL; - a_ival.length = 1; - a_ival.reserved = 0; - a_ival.adv_ival = htonl(ival); - - memcpy(buff + len, &a_ival, sizeof(a_ival)); - send_ra_inc_len(&len, sizeof(a_ival)); - } - - /* - * Mobile IPv6 ext: Home Agent Information Option to support - * Dynamic Home Agent Address Discovery - */ - - if(iface->AdvHomeAgentInfo && - (iface->AdvMobRtrSupportFlag || iface->HomeAgentPreference != 0 || - iface->HomeAgentLifetime != iface->AdvDefaultLifetime)) - - { - struct HomeAgentInfo ha_info; - ha_info.type = ND_OPT_HOME_AGENT_INFO; - ha_info.length = 1; - ha_info.flags_reserved = - (iface->AdvMobRtrSupportFlag)?ND_OPT_HAI_FLAG_SUPPORT_MR:0; - ha_info.preference = htons(iface->HomeAgentPreference); - ha_info.lifetime = htons(iface->HomeAgentLifetime); - - memcpy(buff + len, &ha_info, sizeof(ha_info)); - send_ra_inc_len(&len, sizeof(ha_info)); - } - - iov.iov_len = len; - iov.iov_base = (caddr_t) buff; - - memset(chdr, 0, sizeof(chdr)); - cmsg = (struct cmsghdr *) chdr; - - cmsg->cmsg_len = CMSG_LEN(sizeof(struct in6_pktinfo)); - cmsg->cmsg_level = IPPROTO_IPV6; - cmsg->cmsg_type = IPV6_PKTINFO; - - pkt_info = (struct in6_pktinfo *)CMSG_DATA(cmsg); - pkt_info->ipi6_ifindex = iface->if_index; - memcpy(&pkt_info->ipi6_addr, &iface->if_addr, sizeof(struct in6_addr)); - -#ifdef HAVE_SIN6_SCOPE_ID - if (IN6_IS_ADDR_LINKLOCAL(&addr.sin6_addr) || - IN6_IS_ADDR_MC_LINKLOCAL(&addr.sin6_addr)) - addr.sin6_scope_id = iface->if_index; -#endif - - memset(&mhdr, 0, sizeof(mhdr)); - mhdr.msg_name = (caddr_t)&addr; - mhdr.msg_namelen = sizeof(struct sockaddr_in6); - mhdr.msg_iov = &iov; - mhdr.msg_iovlen = 1; - mhdr.msg_control = (void *) cmsg; - mhdr.msg_controllen = sizeof(chdr); - - err = sendmsg(sock, &mhdr, 0); - - if (err < 0) { - if (!iface->IgnoreIfMissing || !(errno == EINVAL || errno == ENODEV)) - flog(LOG_WARNING, "sendmsg: %s", strerror(errno)); - else - dlog(LOG_DEBUG, 3, "sendmsg: %s", strerror(errno)); - } - - return 0; -} diff --git a/release/src/router/radvd/socket.c b/release/src/router/radvd/socket.c deleted file mode 100644 index 6f1acfe9a2..0000000000 --- a/release/src/router/radvd/socket.c +++ /dev/null @@ -1,107 +0,0 @@ -/* - * $Id: socket.c,v 1.8 2010/12/14 11:58:21 psavola Exp $ - * - * Authors: - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" - -/* Note: these are applicable to receiving sockopts only */ -#if defined IPV6_HOPLIMIT && !defined IPV6_RECVHOPLIMIT -# define IPV6_RECVHOPLIMIT IPV6_HOPLIMIT -#endif - -#if defined IPV6_PKTINFO && !defined IPV6_RECVPKTINFO -# define IPV6_RECVPKTINFO IPV6_PKTINFO -#endif - -int -open_icmpv6_socket(void) -{ - int sock; - struct icmp6_filter filter; - int err, val; - - sock = socket(AF_INET6, SOCK_RAW, IPPROTO_ICMPV6); - if (sock < 0) - { - flog(LOG_ERR, "can't create socket(AF_INET6): %s", strerror(errno)); - return (-1); - } - - val = 1; - err = setsockopt(sock, IPPROTO_IPV6, IPV6_RECVPKTINFO, &val, sizeof(val)); - if (err < 0) - { - flog(LOG_ERR, "setsockopt(IPV6_RECVPKTINFO): %s", strerror(errno)); - return (-1); - } - - val = 2; -#ifdef __linux__ - err = setsockopt(sock, IPPROTO_RAW, IPV6_CHECKSUM, &val, sizeof(val)); -#else - err = setsockopt(sock, IPPROTO_IPV6, IPV6_CHECKSUM, &val, sizeof(val)); -#endif - if (err < 0) - { - flog(LOG_ERR, "setsockopt(IPV6_CHECKSUM): %s", strerror(errno)); - return (-1); - } - - val = 255; - err = setsockopt(sock, IPPROTO_IPV6, IPV6_UNICAST_HOPS, &val, sizeof(val)); - if (err < 0) - { - flog(LOG_ERR, "setsockopt(IPV6_UNICAST_HOPS): %s", strerror(errno)); - return (-1); - } - - val = 255; - err = setsockopt(sock, IPPROTO_IPV6, IPV6_MULTICAST_HOPS, &val, sizeof(val)); - if (err < 0) - { - flog(LOG_ERR, "setsockopt(IPV6_MULTICAST_HOPS): %s", strerror(errno)); - return (-1); - } - -#ifdef IPV6_RECVHOPLIMIT - val = 1; - err = setsockopt(sock, IPPROTO_IPV6, IPV6_RECVHOPLIMIT, &val, sizeof(val)); - if (err < 0) - { - flog(LOG_ERR, "setsockopt(IPV6_RECVHOPLIMIT): %s", strerror(errno)); - return (-1); - } -#endif - - /* - * setup ICMP filter - */ - - ICMP6_FILTER_SETBLOCKALL(&filter); - ICMP6_FILTER_SETPASS(ND_ROUTER_SOLICIT, &filter); - ICMP6_FILTER_SETPASS(ND_ROUTER_ADVERT, &filter); - - err = setsockopt(sock, IPPROTO_ICMPV6, ICMP6_FILTER, &filter, - sizeof(filter)); - if (err < 0) - { - flog(LOG_ERR, "setsockopt(ICMPV6_FILTER): %s", strerror(errno)); - return (-1); - } - - return sock; -} diff --git a/release/src/router/radvd/timer.c b/release/src/router/radvd/timer.c deleted file mode 100644 index 30d29628c1..0000000000 --- a/release/src/router/radvd/timer.c +++ /dev/null @@ -1,59 +0,0 @@ -/* - * $Id: timer.c,v 1.12 2011/02/22 00:20:40 reubenhwk Exp $ - * - * Authors: - * Pedro Roque - * Lars Fenneberg - * - * This software is Copyright 1996-2000 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "radvd.h" - -struct timeval -next_timeval(double next) -{ - struct timeval tv; - gettimeofday(&tv, NULL); - tv.tv_sec += (int)next; - tv.tv_usec += 1000000 * (next - (int)next); - return tv; -} - -int -timevaldiff(struct timeval const *a, struct timeval const *b) -{ - int msec; - msec = (a->tv_sec - b->tv_sec) * 1000; - msec += (a->tv_usec - b->tv_usec) / 1000; - return msec; -} - - -/* Returns when the next time should expire in milliseconds. */ -int -next_time_msec(struct Interface const * iface) -{ - struct timeval tv; - int retval; - gettimeofday(&tv, NULL); - retval = timevaldiff(&iface->next_multicast, &tv); - return retval >= 1 ? retval : 1; -} - -int -expired(struct Interface const * iface) -{ - struct timeval tv; - gettimeofday(&tv, NULL); - if(timevaldiff(&iface->next_multicast, &tv) > 0) - return 0; - return 1; -} - diff --git a/release/src/router/radvd/util.c b/release/src/router/radvd/util.c deleted file mode 100644 index 6c7ad029f3..0000000000 --- a/release/src/router/radvd/util.c +++ /dev/null @@ -1,125 +0,0 @@ -/* - * $Id: util.c,v 1.12 2010/12/14 11:58:21 psavola Exp $ - * - * Authors: - * Lars Fenneberg - * - * This software is Copyright 1996,1997 by the above mentioned author(s), - * All Rights Reserved. - * - * The license which is distributed with this software in the file COPYRIGHT - * applies to this software. If your distribution is missing this file, you - * may request it from . - * - */ - -#include "config.h" -#include "includes.h" -#include "radvd.h" - -void -mdelay(double msecs) -{ - struct timeval tv; - - tv.tv_sec = (time_t)(msecs / 1000.0); - tv.tv_usec = (suseconds_t)((msecs - tv.tv_sec * 1000.0) * 1000.0); - - select(0,(fd_set *)NULL,(fd_set *)NULL,(fd_set *)NULL, &tv); -} - -double -rand_between(double lower, double upper) -{ - return ((upper - lower) / (RAND_MAX + 1.0) * rand() + lower); -} - -void -print_addr(struct in6_addr *addr, char *str) -{ - const char *res; - - /* XXX: overflows 'str' if it isn't big enough */ - res = inet_ntop(AF_INET6, (void *)addr, str, INET6_ADDRSTRLEN); - - if (res == NULL) - { - flog(LOG_ERR, "print_addr: inet_ntop: %s", strerror(errno)); - strcpy(str, "[invalid address]"); - } -} - -/* Check if an in6_addr exists in the rdnss list */ -int -check_rdnss_presence(struct AdvRDNSS *rdnss, struct in6_addr *addr) -{ - while (rdnss) { - if ( !memcmp(&rdnss->AdvRDNSSAddr1, addr, sizeof(struct in6_addr)) - || !memcmp(&rdnss->AdvRDNSSAddr2, addr, sizeof(struct in6_addr)) - || !memcmp(&rdnss->AdvRDNSSAddr3, addr, sizeof(struct in6_addr)) ) - break; /* rdnss address found in the list */ - else - rdnss = rdnss->next; /* no match */ - } - return (rdnss != NULL); -} - -/* Check if a suffix exists in the dnssl list */ -int -check_dnssl_presence(struct AdvDNSSL *dnssl, const char *suffix) -{ - int i; - while (dnssl) { - for (i = 0; i < dnssl->AdvDNSSLNumber; i++) { - if (strcmp(dnssl->AdvDNSSLSuffixes[i], suffix) == 0) - break; /* suffix found in the list */ - } - if (i != dnssl->AdvDNSSLNumber) - break; - - dnssl = dnssl->next; /* no match */ - } - return (dnssl != NULL); -} - -/* Like read(), but retries in case of partial read */ -ssize_t -readn(int fd, void *buf, size_t count) -{ - size_t n = 0; - while (count > 0) { - int r = read(fd, buf, count); - if (r < 0) { - if (errno == EINTR) - continue; - return r; - } - if (r == 0) - return n; - buf = (char *)buf + r; - count -= r; - n += r; - } - return n; -} - -/* Like write(), but retries in case of partial write */ -ssize_t -writen(int fd, const void *buf, size_t count) -{ - size_t n = 0; - while (count > 0) { - int r = write(fd, buf, count); - if (r < 0) { - if (errno == EINTR) - continue; - return r; - } - if (r == 0) - return n; - buf = (const char *)buf + r; - count -= r; - n += r; - } - return n; -} diff --git a/release/src/router/radvd/ylwrap b/release/src/router/radvd/ylwrap deleted file mode 100755 index 84d563405e..0000000000 --- a/release/src/router/radvd/ylwrap +++ /dev/null @@ -1,222 +0,0 @@ -#! /bin/sh -# ylwrap - wrapper for lex/yacc invocations. - -scriptversion=2009-04-28.21; # UTC - -# Copyright (C) 1996, 1997, 1998, 1999, 2001, 2002, 2003, 2004, 2005, -# 2007, 2009 Free Software Foundation, Inc. -# -# Written by Tom Tromey . -# -# 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; either version 2, or (at your option) -# any later version. -# -# 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 . - -# As a special exception to the GNU General Public License, if you -# distribute this file as part of a program that contains a -# configuration script generated by Autoconf, you may include it under -# the same distribution terms that you use for the rest of that program. - -# This file is maintained in Automake, please report -# bugs to or send patches to -# . - -case "$1" in - '') - echo "$0: No files given. Try \`$0 --help' for more information." 1>&2 - exit 1 - ;; - --basedir) - basedir=$2 - shift 2 - ;; - -h|--h*) - cat <<\EOF -Usage: ylwrap [--help|--version] INPUT [OUTPUT DESIRED]... -- PROGRAM [ARGS]... - -Wrapper for lex/yacc invocations, renaming files as desired. - - INPUT is the input file - OUTPUT is one file PROG generates - DESIRED is the file we actually want instead of OUTPUT - PROGRAM is program to run - ARGS are passed to PROG - -Any number of OUTPUT,DESIRED pairs may be used. - -Report bugs to . -EOF - exit $? - ;; - -v|--v*) - echo "ylwrap $scriptversion" - exit $? - ;; -esac - - -# The input. -input="$1" -shift -case "$input" in - [\\/]* | ?:[\\/]*) - # Absolute path; do nothing. - ;; - *) - # Relative path. Make it absolute. - input="`pwd`/$input" - ;; -esac - -pairlist= -while test "$#" -ne 0; do - if test "$1" = "--"; then - shift - break - fi - pairlist="$pairlist $1" - shift -done - -# The program to run. -prog="$1" -shift -# Make any relative path in $prog absolute. -case "$prog" in - [\\/]* | ?:[\\/]*) ;; - *[\\/]*) prog="`pwd`/$prog" ;; -esac - -# FIXME: add hostname here for parallel makes that run commands on -# other machines. But that might take us over the 14-char limit. -dirname=ylwrap$$ -trap "cd '`pwd`'; rm -rf $dirname > /dev/null 2>&1" 1 2 3 15 -mkdir $dirname || exit 1 - -cd $dirname - -case $# in - 0) "$prog" "$input" ;; - *) "$prog" "$@" "$input" ;; -esac -ret=$? - -if test $ret -eq 0; then - set X $pairlist - shift - first=yes - # Since DOS filename conventions don't allow two dots, - # the DOS version of Bison writes out y_tab.c instead of y.tab.c - # and y_tab.h instead of y.tab.h. Test to see if this is the case. - y_tab_nodot="no" - if test -f y_tab.c || test -f y_tab.h; then - y_tab_nodot="yes" - fi - - # The directory holding the input. - input_dir=`echo "$input" | sed -e 's,\([\\/]\)[^\\/]*$,\1,'` - # Quote $INPUT_DIR so we can use it in a regexp. - # FIXME: really we should care about more than `.' and `\'. - input_rx=`echo "$input_dir" | sed 's,\\\\,\\\\\\\\,g;s,\\.,\\\\.,g'` - - while test "$#" -ne 0; do - from="$1" - # Handle y_tab.c and y_tab.h output by DOS - if test $y_tab_nodot = "yes"; then - if test $from = "y.tab.c"; then - from="y_tab.c" - else - if test $from = "y.tab.h"; then - from="y_tab.h" - fi - fi - fi - if test -f "$from"; then - # If $2 is an absolute path name, then just use that, - # otherwise prepend `../'. - case "$2" in - [\\/]* | ?:[\\/]*) target="$2";; - *) target="../$2";; - esac - - # We do not want to overwrite a header file if it hasn't - # changed. This avoid useless recompilations. However the - # parser itself (the first file) should always be updated, - # because it is the destination of the .y.c rule in the - # Makefile. Divert the output of all other files to a temporary - # file so we can compare them to existing versions. - if test $first = no; then - realtarget="$target" - target="tmp-`echo $target | sed s/.*[\\/]//g`" - fi - # Edit out `#line' or `#' directives. - # - # We don't want the resulting debug information to point at - # an absolute srcdir; it is better for it to just mention the - # .y file with no path. - # - # We want to use the real output file name, not yy.lex.c for - # instance. - # - # We want the include guards to be adjusted too. - FROM=`echo "$from" | sed \ - -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/'\ - -e 's/[^ABCDEFGHIJKLMNOPQRSTUVWXYZ]/_/g'` - TARGET=`echo "$2" | sed \ - -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/'\ - -e 's/[^ABCDEFGHIJKLMNOPQRSTUVWXYZ]/_/g'` - - sed -e "/^#/!b" -e "s,$input_rx,," -e "s,$from,$2," \ - -e "s,$FROM,$TARGET," "$from" >"$target" || ret=$? - - # Check whether header files must be updated. - if test $first = no; then - if test -f "$realtarget" && cmp -s "$realtarget" "$target"; then - echo "$2" is unchanged - rm -f "$target" - else - echo updating "$2" - mv -f "$target" "$realtarget" - fi - fi - else - # A missing file is only an error for the first file. This - # is a blatant hack to let us support using "yacc -d". If -d - # is not specified, we don't want an error when the header - # file is "missing". - if test $first = yes; then - ret=1 - fi - fi - shift - shift - first=no - done -else - ret=$? -fi - -# Remove the directory. -cd .. -rm -rf $dirname - -exit $ret - -# Local Variables: -# mode: shell-script -# sh-indentation: 2 -# eval: (add-hook 'write-file-hooks 'time-stamp) -# time-stamp-start: "scriptversion=" -# time-stamp-format: "%:y-%02m-%02d.%02H" -# time-stamp-time-zone: "UTC" -# time-stamp-end: "; # UTC" -# End: diff --git a/release/src/router/rc/services.c b/release/src/router/rc/services.c index 300675f50e..44dd1a2486 100644 --- a/release/src/router/rc/services.c +++ b/release/src/router/rc/services.c @@ -369,6 +369,12 @@ void start_dnsmasq() write_pptpd_dnsmasq_config(f); #endif +#ifdef TCONFIG_IPV6 + if (ipv6_enabled() && nvram_get_int("ipv6_radvd")) { + fprintf(f, "enable-ra\n"); + } +#endif + fprintf(f, "%s\n\n", nvram_safe_get("dnsmasq_custom")); fappend(f, "/etc/dnsmasq.custom"); @@ -564,9 +570,9 @@ void start_ipv6_tunnel(void) eval("ip", "addr", "add", ip, "dev", (char *)tun_dev); eval("ip", "route", "add", "::/0", "dev", (char *)tun_dev); - // (re)start radvd + // (re)start radvd - now dnsmasq provided if (service == IPV6_ANYCAST_6TO4) - start_radvd(); + start_dnsmasq(); } void stop_ipv6_tunnel(void) @@ -579,112 +585,6 @@ void stop_ipv6_tunnel(void) modprobe_r("sit"); } -static pid_t pid_radvd = -1; - -void start_radvd(void) -{ - FILE *f; - char *prefix, *ip, *mtu; - int do_dns, do_6to4; - char *argv[] = { "radvd", NULL, NULL, NULL }; - int pid, argc, service, cnt; - - if (getpid() != 1) { - start_service("radvd"); - return; - } - - stop_radvd(); - - if (ipv6_enabled() && nvram_get_int("ipv6_radvd")) { - service = get_ipv6_service(); - do_6to4 = (service == IPV6_ANYCAST_6TO4); - mtu = NULL; - - switch (service) { - case IPV6_NATIVE_DHCP: - prefix = "::"; - break; - case IPV6_ANYCAST_6TO4: - case IPV6_6IN4: - mtu = (nvram_get_int("ipv6_tun_mtu") > 0) ? nvram_safe_get("ipv6_tun_mtu") : "1480"; - // fall through - default: - prefix = do_6to4 ? "0:0:0:1::" : nvram_safe_get("ipv6_prefix"); - break; - } - if (!(*prefix)) prefix = "::"; - - // Create radvd.conf - if ((f = fopen("/etc/radvd.conf", "w")) == NULL) return; - - ip = (char *)ipv6_router_address(NULL); - do_dns = (*ip) && nvram_match("dhcpd_dmdns", "1"); - - fprintf(f, - "interface %s\n" - "{\n" - " IgnoreIfMissing on;\n" - " AdvSendAdvert on;\n" - " MaxRtrAdvInterval 60;\n" - " AdvHomeAgentFlag off;\n" - " AdvManagedFlag off;\n" - "%s%s%s" - " prefix %s/64 \n" - " {\n" - " AdvOnLink on;\n" - " AdvAutonomous on;\n" - "%s" - "%s%s%s" - " };\n", - nvram_safe_get("lan_ifname"), - mtu ? " AdvLinkMTU " : "", mtu ? : "", mtu ? ";\n" : "", - prefix, - do_6to4 ? " AdvValidLifetime 300;\n AdvPreferredLifetime 120;\n" : "", - do_6to4 ? " Base6to4Interface " : "", - do_6to4 ? get_wanface() : "", - do_6to4 ? ";\n" : ""); - - if (do_dns) { - fprintf(f, " RDNSS %s {};\n", ip); - } - else { - cnt = write_ipv6_dns_servers(f, " RDNSS ", nvram_safe_get("ipv6_dns"), " ", 1); - if (cnt == 0 || nvram_get_int("dns_addget")) - cnt += write_ipv6_dns_servers(f, (cnt) ? "" : " RDNSS ", nvram_safe_get("ipv6_get_dns"), " ", 1); - if (cnt) fprintf(f, "{};\n"); - } - - fprintf(f, - "};\n"); // close "interface" section - fclose(f); - - // Start radvd - argc = 1; - if (nvram_get_int("debug_ipv6")) { - argv[argc++] = "-d"; - argv[argc++] = "10"; - } - argv[argc] = NULL; - _eval(argv, NULL, 0, &pid); - - if (!nvram_contains_word("debug_norestart", "radvd")) { - pid_radvd = -2; - } - } -} - -void stop_radvd(void) -{ - if (getpid() != 1) { - stop_service("radvd"); - return; - } - - pid_radvd = -1; - killall_tk("radvd"); -} - void start_ipv6(void) { int service; @@ -2058,9 +1958,6 @@ void check_services(void) _check(pid_dnsmasq, "dnsmasq", start_dnsmasq); _check(pid_crond, "crond", start_cron); _check(pid_igmp, "igmpproxy", start_igmp_proxy); -#ifdef TCONFIG_IPV6 - _check(pid_radvd, "radvd", start_radvd); -#endif // #ifdef TCONFIG_NOCAT // if (nvram_get_int("NC_enable")) @@ -2096,14 +1993,6 @@ void start_services(void) #ifdef TCONFIG_PPTPD start_pptpd(); #endif -#ifdef TCONFIG_IPV6 - /* note: starting radvd here might be too early in case of - * DHCPv6 or 6to4 because we won't have received a prefix and - * so it will disable advertisements. To restart them, we have - * to send radvd a SIGHUP, or restart it. - */ - start_radvd(); -#endif restart_nas_services(1, 1); // !!TB - Samba, FTP and Media Server #ifdef TCONFIG_SNMP @@ -2130,9 +2019,14 @@ void stop_services(void) stop_snmp(); #endif -#ifdef TCONFIG_IPV6 - stop_radvd(); +#ifdef TCONFIG_TOR + stop_tor(); +#endif + +#ifdef TCONFIG_NFS + stop_nfs(); #endif + restart_nas_services(1, 0); // stop Samba, FTP and Media Server #ifdef TCONFIG_PPTPD stop_pptpd(); #endif @@ -2304,26 +2198,16 @@ TOP: #ifdef TCONFIG_IPV6 if (strcmp(service, "ipv6") == 0) { if (action & A_STOP) { - stop_radvd(); + stop_dnsmasq(); stop_ipv6(); } if (action & A_START) { start_ipv6(); - start_radvd(); + start_dnsmasq(); } goto CLEAR; } - if (strcmp(service, "radvd") == 0) { - if (action & A_STOP) { - stop_radvd(); - } - if (action & A_START) { - start_radvd(); - } - goto CLEAR; - } - if (strncmp(service, "dhcp6", 5) == 0) { if (action & A_STOP) { stop_dhcp6c(); @@ -2506,9 +2390,6 @@ TOP: #ifdef TCONFIG_USB stop_nas_services(); #endif -#ifdef TCONFIG_IPV6 - stop_radvd(); -#endif stop_httpd(); stop_dnsmasq(); stop_nas(); @@ -2525,9 +2406,6 @@ TOP: start_nas(); start_dnsmasq(); start_httpd(); -#ifdef TCONFIG_IPV6 - start_radvd(); -#endif start_wl(); #ifdef TCONFIG_USB start_nas_services(); diff --git a/release/src/router/www/advanced-dhcpdns.asp b/release/src/router/www/advanced-dhcpdns.asp index 92aa529ffa..8c60c19277 100644 --- a/release/src/router/www/advanced-dhcpdns.asp +++ b/release/src/router/www/advanced-dhcpdns.asp @@ -29,7 +29,7 @@ textarea { diff --git a/release/src/router/www/basic-ipv6.asp b/release/src/router/www/basic-ipv6.asp index 525dc42a48..92e7f809fb 100644 --- a/release/src/router/www/basic-ipv6.asp +++ b/release/src/router/www/basic-ipv6.asp @@ -21,7 +21,7 @@