configure.in 96.7 KB
Newer Older
Tinderbox User's avatar
Tinderbox User committed
1
# Copyright (C) 2004-2013  Internet Systems Consortium, Inc. ("ISC")
Mark Andrews's avatar
Mark Andrews committed
2 3 4 5 6 7 8 9 10 11 12 13 14
# Copyright (C) 1998-2003  Internet Software Consortium.
#
# Permission to use, copy, modify, and/or distribute this software for any
# purpose with or without fee is hereby granted, provided that the above
# copyright notice and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
# REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
# AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
# INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
# LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
# OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
# PERFORMANCE OF THIS SOFTWARE.
David Lawrence's avatar
David Lawrence committed
15

16
dnl
17
AC_DIVERT_PUSH(1)dnl
18 19
esyscmd([sed "s/^/# /" COPYRIGHT])dnl
AC_DIVERT_POP()dnl
David Lawrence's avatar
David Lawrence committed
20

21
AC_REVISION($Revision: 1.533.34.1 $)
22

23
AC_INIT(lib/dns/name.c)
24
AC_PREREQ(2.59)
Bob Halley's avatar
Bob Halley committed
25 26

AC_CONFIG_HEADER(config.h)
27
AC_CONFIG_MACRO_DIR([libtool.m4])
Bob Halley's avatar
Bob Halley committed
28 29 30

AC_CANONICAL_HOST

31
AC_PROG_MAKE_SET
32 33 34 35 36 37 38 39 40 41 42 43 44

#
# GNU libtool support
#
case $build_os in
sunos*)
    # Just set the maximum command line length for sunos as it otherwise
    # takes a exceptionally long time to work it out. Required for libtool.
     
    lt_cv_sys_max_cmd_len=4096;
    ;;
esac

45
AC_PROG_LIBTOOL
46
AC_PROG_INSTALL
47
AC_PROG_LN_S
48 49 50 51

AC_SUBST(STD_CINCLUDES)
AC_SUBST(STD_CDEFINES)
AC_SUBST(STD_CWARNINGS)
52
AC_SUBST(CCOPT)
53

54 55 56 57 58 59 60 61 62 63 64 65
# Warn if the user specified libbind, which is now deprecated
AC_ARG_ENABLE(libbind, [  --enable-libbind	  deprecated])

case "$enable_libbind" in
	yes)
		AC_MSG_ERROR(['libbind' is no longer part of the BIND 9 distribution.
It is available from http://www.isc.org as a separate download.])
		;;
	no|'')
		;;
esac

66
AC_ARG_ENABLE(developer, [  --enable-developer      enable developer build settings])
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
case "$enable_developer" in
yes)
	test "${enable_fixed_rrset+set}" = set || enable_fixed_rrset=yes
	test "${with_atf+set}" = set || with_atf=yes
	test "${enable_filter_aaaa+set}" = set || enable_filter_aaaa=yes
	test "${enable_rpz_nsip+set}" = set || enable_rpz_nsip=yes
	test "${enable_rpz_nsdname+set}" = set || enable_rpz_nsdname=yes
	test "${with_dlz_filesystem+set}" = set || with_dlz_filesystem=yes
	case "$host" in
	*-darwin*)
		test "${enable_exportlib+set}" = set || enable_exportlib=yes
		;;
	*-linux*)
		test "${enable_exportlib+set}" = set || enable_exportlib=yes
		;;
	esac
	;;
esac
85 86 87
#
# Make very sure that these are the first files processed by
# config.status, since we use the processed output as the input for
Francis Dupont's avatar
Francis Dupont committed
88
# AC_SUBST_FILE() substitutions in other files.
89 90 91
#
AC_CONFIG_FILES([make/rules make/includes])

David Lawrence's avatar
David Lawrence committed
92 93 94 95 96
AC_PATH_PROG(AR, ar)
ARFLAGS="cruv"
AC_SUBST(AR)
AC_SUBST(ARFLAGS)

97 98 99 100 101
# The POSIX ln(1) program.  Non-POSIX systems may substitute
# "copy" or something.
LN=ln
AC_SUBST(LN)

102 103 104 105 106 107 108 109 110 111
case "$AR" in
	"")
		AC_MSG_ERROR([
ar program not found.  Please fix your PATH to include the directory in
which ar resides, or set AR in the environment with the full path to ar.
])

		;;
esac

Bob Halley's avatar
Bob Halley committed
112 113 114
#
# Etags.
#
115
AC_PATH_PROGS(ETAGS, etags emacs-etags)
Andreas Gustafsson's avatar
Andreas Gustafsson committed
116

Bob Halley's avatar
Bob Halley committed
117 118 119 120 121 122 123 124 125 126 127 128 129
#
# Some systems, e.g. RH7, have the Exuberant Ctags etags instead of
# GNU emacs etags, and it requires the -L flag.
#
if test "X$ETAGS" != "X"; then
	AC_MSG_CHECKING(for Exuberant Ctags etags)
	if $ETAGS --version 2>&1 | grep 'Exuberant Ctags' >/dev/null 2>&1; then
		AC_MSG_RESULT(yes)
		ETAGS="$ETAGS -L"
	else
		AC_MSG_RESULT(no)
	fi
fi
130 131
AC_SUBST(ETAGS)

132 133
#
# Perl is optional; it is used only by some of the system test scripts.
134 135
# Note: the backtrace feature (see below) uses perl to build the symbol table,
# but it still compiles without perl, in which case an empty table will be used.
136 137 138 139
#
AC_PATH_PROGS(PERL, perl5 perl)
AC_SUBST(PERL)

140 141 142 143 144
#
# Python is also optional; it is used by the tools in bin/python.
# If python is unavailable, we simply don't build those.
#
AC_ARG_WITH(python,
145
[  --with-python=PATH      Specify path to python interpreter],
146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181
    use_python="$withval", use_python="unspec")

case "$use_python" in
	no)
		AC_MSG_RESULT(disabled)
		;;
	unspec|yes|*)
		case "$use_python" in
		unspec|yes|'')
			AC_PATH_PROGS(PYTHON, python)
			;;
		*)
			AC_PATH_PROGS(PYTHON, $use_python)
			;;
		esac
		if test "X$PYTHON" == "X"
		then
			case "$use_python" in
			unspec)
				AC_MSG_RESULT(disabled)
				;;
			yes|*)
				AC_MSG_ERROR([missing python])
				;;
			esac
			break
		fi
                testscript='try: import argparse
except: exit(1)'
		AC_MSG_CHECKING([python module 'argparse'])
                if $PYTHON -c "$testscript"; then
                        AC_MSG_RESULT([found, using $PYTHON])
                else
			case "$use_python" in
			unspec)
				PYTHON=""
182
				AC_SUBST(CHECKDS)
183 184 185 186 187 188 189 190 191 192 193 194
				AC_MSG_RESULT([not found, python disabled])
				;;
			yes)
                        AC_MSG_RESULT([no found])
                        AC_MSG_ERROR([python 'argparse' module not supported])
				;;
			esac
                fi
		;;
esac

PYTHON_TOOLS=''
195
CHECKDS=''
196 197
if test "X$PYTHON" != "X"; then
        PYTHON_TOOLS=python
198
	CHECKDS=checkds
199
fi
200
AC_SUBST(CHECKDS)
201 202
AC_SUBST(PYTHON_TOOLS)

203 204 205
#
# Special processing of paths depending on whether --prefix,
# --sysconfdir or --localstatedir arguments were given.  What's
Mark Andrews's avatar
Mark Andrews committed
206
# desired is some compatibility with the way previous versions
207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222
# of BIND built; they defaulted to /usr/local for most parts of
# the installation, but named.boot/named.conf was in /etc
# and named.pid was in /var/run.
#
# So ... if none of --prefix, --sysconfdir or --localstatedir are
# specified, set things up that way.  If --prefix is given, use
# it for sysconfdir and localstatedir the way configure normally
# would.  To change the prefix for everything but leave named.conf
# in /etc or named.pid in /var/run, then do this the usual configure way:
# ./configure --prefix=/somewhere --sysconfdir=/etc
# ./configure --prefix=/somewhere --localstatedir=/var
#
# To put named.conf and named.pid in /usr/local with everything else,
# set the prefix explicitly to /usr/local even though that's the default:
# ./configure --prefix=/usr/local
#
223
case "$prefix" in
224 225 226 227 228 229 230 231 232 233 234 235
	NONE)
		case "$sysconfdir" in
			'${prefix}/etc')
				sysconfdir=/etc
				;;
		esac
		case "$localstatedir" in
			'${prefix}/var')
				localstatedir=/var
				;;
		esac
		;;
236 237
esac

238 239 240 241 242 243 244 245
#
# Make sure INSTALL uses an absolute path, else it will be wrong in all
# Makefiles, since they use make/rules.in and INSTALL will be adjusted by
# configure based on the location of the file where it is substituted.
# Since in BIND9 INSTALL is only substituted into make/rules.in, an immediate
# subdirectory of install-sh, This relative path will be wrong for all
# directories more than one level down from install-sh.
#
246 247
case "$INSTALL" in
	/*)
248 249 250 251 252 253 254 255 256 257 258 259 260 261
		;;
	*)
		#
		# Not all systems have dirname.
		#
		changequote({, })
		ac_dir="`echo $INSTALL | sed 's%/[^/]*$%%'`"
		changequote([, ])

		ac_prog="`echo $INSTALL | sed 's%.*/%%'`"
		test "$ac_dir" = "$ac_prog" && ac_dir=.
		test -d "$ac_dir" && ac_dir="`(cd \"$ac_dir\" && pwd)`"
		INSTALL="$ac_dir/$ac_prog"
		;;
262 263
esac

264 265 266 267 268 269 270 271
#
# On these hosts, we really want to use cc, not gcc, even if it is
# found.  The gcc that these systems have will not correctly handle
# pthreads.
#
# However, if the user sets $CC to be something, let that override
# our change.
#
272 273 274 275 276
if test "X$CC" = "X" ; then
	case "$host" in
		*-dec-osf*)
			CC="cc"
			;;
277
		*-solaris*)
278 279 280 281 282 283
			# Use Sun's cc if it is available, but watch
			# out for /usr/ucb/cc; it will never be the right
			# compiler to use.
			#
			# If setting CC here fails, the AC_PROG_CC done
			# below might still find gcc.
284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299
			IFS="${IFS=	}"; ac_save_ifs="$IFS"; IFS=":"
			for ac_dir in $PATH; do
				test -z "$ac_dir" && ac_dir=.
				case "$ac_dir" in
				/usr/ucb)
					# exclude
					;;
				*)
					if test -f "$ac_dir/cc"; then
						CC="$ac_dir/cc"
						break
					fi
					;;
				esac
			done
			IFS="$ac_save_ifs"
300 301 302 303 304 305 306 307 308 309
			;;
		*-hp-hpux*)
			CC="cc"
			;;
		mips-sgi-irix*)
			CC="cc"
			;;
	esac
fi

310 311
AC_PROG_CC

312 313 314 315 316
#
# gcc's optimiser is broken at -02 for ultrasparc
#
if test "$ac_env_CFLAGS_set" != set -a "X$GCC" = "Xyes"; then
	case "$host" in
317
	sparc-*)
318 319 320 321 322
		CCFLAGS="-g -O1"
		;;
	esac
fi

323
#
324
# OS dependent CC flags
325 326
#
case "$host" in
Francis Dupont's avatar
Francis Dupont committed
327
	# OSF 5.0: recv/send are only available with -D_POSIX_PII_SOCKET or
328
	# -D_XOPEN_SOURCE_EXTENDED.
329 330 331 332
	*-dec-osf*)
		STD_CDEFINES="$STD_CDEFINES -D_POSIX_PII_SOCKET"
		CPPFLAGS="$CPPFLAGS -D_POSIX_PII_SOCKET"
		;;
333 334 335 336 337 338 339 340 341 342 343
	#HP-UX: need -D_XOPEN_SOURCE_EXTENDED and -lxnet for CMSG macros
	*-hp-hpux*)
		STD_CDEFINES="$STD_CDEFINES -D_XOPEN_SOURCE_EXTENDED"
		CPPFLAGS="$CPPFLAGS -D_XOPEN_SOURCE_EXTENDED"
		LIBS="-lxnet $LIBS"
		;;
	# Solaris: need -D_XPG4_2 and -D__EXTENSIONS__ for CMSG macros
	*-solaris*)
		STD_CDEFINES="$STD_CDEFINES -D_XPG4_2 -D__EXTENSIONS__"
		CPPFLAGS="$CPPFLAGS -D_XPG4_2 -D__EXTENSIONS__"
		;;
344 345 346 347 348
	# POSIX doesn't include the IPv6 Advanced Socket API and glibc hides
	# parts of the IPv6 Advanced Socket API as a result.  This is stupid
	# as it breaks how the two halves (Basic and Advanced) of the IPv6
	# Socket API were designed to be used but we have to live with it.
	# Define _GNU_SOURCE to pull in the IPv6 Advanced Socket API.
349
	*-linux* | *-kfreebsd*-gnu)
350 351 352
		STD_CDEFINES="$STD_CDEFINES -D_GNU_SOURCE"
		CPPFLAGS="$CPPFLAGS -D_GNU_SOURCE"
		;;
353 354 355 356 357 358 359 360
	#
	# Starting with OSX 10.7 (Lion) we must choose which IPv6 API to use.
	# Setting this is sufficient to select the correct behavior for BIND 9.
	#
	*-darwin*)
	  STD_CDEFINES="$STD_CDEFINES -D__APPLE_USE_RFC_3542"
	  CPPFLAGS="$CPPFLAGS -D__APPLE_USE_RFC_3542"
	  ;;
361 362
esac

363 364
AC_HEADER_STDC

Evan Hunt's avatar
Evan Hunt committed
365
AC_CHECK_HEADERS(fcntl.h regex.h sys/time.h unistd.h sys/mman.h sys/sockio.h sys/select.h sys/param.h sys/sysctl.h net/if6.h,,,
366 367 368 369 370
[$ac_includes_default
#ifdef HAVE_SYS_PARAM_H
# include <sys/param.h>
#endif
])
371 372 373

AC_C_CONST
AC_C_INLINE
374
AC_C_VOLATILE
Mark Andrews's avatar
Mark Andrews committed
375
AC_CHECK_FUNC(sysctlbyname, AC_DEFINE(HAVE_SYSCTLBYNAME))
376
AC_C_FLEXIBLE_ARRAY_MEMBER
377

Evan Hunt's avatar
Evan Hunt committed
378 379 380 381 382
#
# Check for the existence of mmap to enable the fast format zones
#
AC_CHECK_FUNCS(mmap)

383 384 385 386 387 388
#
# Older versions of HP/UX don't define seteuid() and setegid()
#
AC_CHECK_FUNCS(seteuid setresuid)
AC_CHECK_FUNCS(setegid setresgid)

389 390 391 392 393
#
# UnixWare 7.1.1 with the feature supplement to the UDK compiler
# is reported to not support "static inline" (RT #1212).
#
AC_MSG_CHECKING(for static inline breakage)
394 395 396 397 398 399 400 401 402 403 404
AC_TRY_COMPILE(, [
		foo1();
	}

	static inline int foo1() {
		return 0;
	}

	static inline int foo2() {
		return foo1();
	],
405 406
	[AC_MSG_RESULT(no)],
	[AC_MSG_RESULT(yes)
407
	 AC_DEFINE(inline, ,[Define to empty if your compiler does not support "static inline".])])
408

409
AC_TYPE_SIZE_T
Mark Andrews's avatar
Mark Andrews committed
410
AC_CHECK_TYPE(ssize_t, int)
411
AC_CHECK_TYPE(uintptr_t,unsigned long)
412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428
AC_CHECK_TYPE(socklen_t,
[AC_DEFINE(ISC_SOCKADDR_LEN_T, socklen_t)],
[
AC_TRY_COMPILE(
[
#include <sys/types.h>
#include <sys/socket.h>
int getsockname(int, struct sockaddr *, size_t *);
],[],
[AC_DEFINE(ISC_SOCKADDR_LEN_T, size_t)],
[AC_DEFINE(ISC_SOCKADDR_LEN_T, int)])
],
[
#include <sys/types.h>
#include <sys/socket.h>
])
AC_SUBST(ISC_SOCKADDR_LEN_T)
429
AC_HEADER_TIME
Mark Andrews's avatar
Mark Andrews committed
430 431 432 433 434 435 436
AC_MSG_CHECKING(for long long)
AC_TRY_COMPILE([],[long long i = 0; return (0);],
	[AC_MSG_RESULT(yes)
		ISC_PLATFORM_HAVELONGLONG="#define ISC_PLATFORM_HAVELONGLONG 1"],
	[AC_MSG_RESULT(no)
		ISC_PLATFORM_HAVELONGLONG="#undef ISC_PLATFORM_HAVELONGLONG"])
AC_SUBST(ISC_PLATFORM_HAVELONGLONG)
437

Francis Dupont's avatar
Francis Dupont committed
438 439 440 441 442 443 444 445 446 447
#
# check for GCC noreturn attribute
#
AC_MSG_CHECKING(for GCC noreturn attribute)
AC_TRY_COMPILE([],[void foo() __attribute__((noreturn));],
	[AC_MSG_RESULT(yes)
		ISC_PLATFORM_NORETURN_PRE="#define ISC_PLATFORM_NORETURN_PRE"
		ISC_PLATFORM_NORETURN_POST="#define ISC_PLATFORM_NORETURN_POST __attribute__((noreturn))"],
	[AC_MSG_RESULT(no)
		ISC_PLATFORM_NORETURN_PRE="#define ISC_PLATFORM_NORETURN_PRE"
448
		ISC_PLATFORM_NORETURN_POST="#define ISC_PLATFORM_NORETURN_POST"])
Francis Dupont's avatar
Francis Dupont committed
449 450 451
AC_SUBST(ISC_PLATFORM_NORETURN_PRE)
AC_SUBST(ISC_PLATFORM_NORETURN_POST)

452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471
#
# check if we have lifconf
#
AC_MSG_CHECKING(for struct lifconf)
AC_TRY_COMPILE([
#include <sys/types.h>
#include <sys/socket.h>
#include <net/if.h>
],
[
struct lifconf lifconf;
lifconf.lifc_len = 0;
]
,
	[AC_MSG_RESULT(yes)
		ISC_PLATFORM_HAVELIFCONF="#define ISC_PLATFORM_HAVELIFCONF 1"],
	[AC_MSG_RESULT(no)
		ISC_PLATFORM_HAVELIFCONF="#undef ISC_PLATFORM_HAVELIFCONF"])
AC_SUBST(ISC_PLATFORM_HAVELIFCONF)

472 473 474
#
# check if we have kqueue
#
475 476 477 478
AC_ARG_ENABLE(kqueue,
	[  --enable-kqueue         use BSD kqueue when available [[default=yes]]],
	      want_kqueue="$enableval",  want_kqueue="yes")
case $want_kqueue in
479
yes)
480 481 482 483 484 485 486 487 488
	AC_CHECK_FUNC(kqueue, ac_cv_have_kqueue=yes, ac_cv_have_kqueue=no)
	case $ac_cv_have_kqueue in
	yes)
		ISC_PLATFORM_HAVEKQUEUE="#define ISC_PLATFORM_HAVEKQUEUE 1"
		;;
	*)
		ISC_PLATFORM_HAVEKQUEUE="#undef ISC_PLATFORM_HAVEKQUEUE"
		;;
	esac
489 490 491 492 493 494 495 496
	;;
*)
	ISC_PLATFORM_HAVEKQUEUE="#undef ISC_PLATFORM_HAVEKQUEUE"
	;;
esac
AC_SUBST(ISC_PLATFORM_HAVEKQUEUE)

#
497 498
# check if we have epoll.  Linux kernel 2.4 has epoll_create() which fails,
# so we need to try running the code, not just test its existence.
499
#
500
AC_ARG_ENABLE(epoll,
501 502
[  --enable-epoll          use Linux epoll when available [[default=auto]]],
	      want_epoll="$enableval",  want_epoll="auto")
503
case $want_epoll in
504
auto)
505 506 507 508 509 510 511 512 513 514 515 516
	AC_MSG_CHECKING(epoll support)
	AC_TRY_RUN([
#include <sys/epoll.h>
int main() {
	if (epoll_create(1) < 0)
		return (1);
	return (0);
}
],
	[AC_MSG_RESULT(yes)
	ISC_PLATFORM_HAVEEPOLL="#define ISC_PLATFORM_HAVEEPOLL 1"],
	[AC_MSG_RESULT(no)
517 518
	ISC_PLATFORM_HAVEEPOLL="#undef ISC_PLATFORM_HAVEEPOLL"],
	[AC_MSG_RESULT(no)
519
	ISC_PLATFORM_HAVEEPOLL="#undef ISC_PLATFORM_HAVEEPOLL"])
520
	;;
521 522 523
yes)
	ISC_PLATFORM_HAVEEPOLL="#define ISC_PLATFORM_HAVEEPOLL 1"
	;;
524 525 526 527 528 529 530 531 532
*)
	ISC_PLATFORM_HAVEEPOLL="#undef ISC_PLATFORM_HAVEEPOLL"
	;;
esac
AC_SUBST(ISC_PLATFORM_HAVEEPOLL)

#
# check if we support /dev/poll
#
533 534 535 536 537
AC_ARG_ENABLE(devpoll,
	[  --enable-devpoll        use /dev/poll when available [[default=yes]]],
	      want_devpoll="$enableval",  want_devpoll="yes")
case $want_devpoll in
yes)
538
	AC_CHECK_HEADERS(sys/devpoll.h devpoll.h,
539 540 541 542 543 544 545 546 547
	ISC_PLATFORM_HAVEDEVPOLL="#define ISC_PLATFORM_HAVEDEVPOLL 1"
	,
	ISC_PLATFORM_HAVEDEVPOLL="#undef ISC_PLATFORM_HAVEDEVPOLL"
	)
	;;
*)
	ISC_PLATFORM_HAVEDEVPOLL="#undef ISC_PLATFORM_HAVEDEVPOLL"
	;;
esac
548
AC_SUBST(ISC_PLATFORM_HAVEDEVPOLL)
549

550 551 552 553 554
#
# check if we need to #include sys/select.h explicitly
#
case $ac_cv_header_unistd_h in
yes)
555
AC_MSG_CHECKING(if unistd.h or sys/types.h defines fd_set)
556
AC_TRY_COMPILE([
557
#include <sys/types.h> /* Ultrix */
558 559 560 561 562 563
#include <unistd.h>],
[fd_set read_set; return (0);],
	[AC_MSG_RESULT(yes)
	 ISC_PLATFORM_NEEDSYSSELECTH="#undef ISC_PLATFORM_NEEDSYSSELECTH"
	 LWRES_PLATFORM_NEEDSYSSELECTH="#undef LWRES_PLATFORM_NEEDSYSSELECTH"],
	[AC_MSG_RESULT(no)
564
	case $ac_cv_header_sys_select_h in
565
	yes)
566
	 ISC_PLATFORM_NEEDSYSSELECTH="#define ISC_PLATFORM_NEEDSYSSELECTH 1"
567 568 569 570 571 572 573 574 575
	 LWRES_PLATFORM_NEEDSYSSELECTH="#define LWRES_PLATFORM_NEEDSYSSELECTH 1"
		;;
	no)
		AC_MSG_ERROR([need either working unistd.h or sys/select.h])
		;;
	esac
	])
	;;
no)
576
	case $ac_cv_header_sys_select_h in
577
	yes)
578
	     ISC_PLATFORM_NEEDSYSSELECTH="#define ISC_PLATFORM_NEEDSYSSELECTH 1"
579 580 581 582 583 584 585 586 587 588 589
	     LWRES_PLATFORM_NEEDSYSSELECTH="#define LWRES_PLATFORM_NEEDSYSSELECTH 1"
		;;
	no)
		AC_MSG_ERROR([need either unistd.h or sys/select.h])
		;;
	esac
	;;
esac
AC_SUBST(ISC_PLATFORM_NEEDSYSSELECTH)
AC_SUBST(LWRES_PLATFORM_NEEDSYSSELECTH)

590 591 592 593 594
#
# Find the machine's endian flavor.
#
AC_C_BIGENDIAN

Michael Graff's avatar
Michael Graff committed
595 596 597
#
# was --with-openssl specified?
#
598
OPENSSL_WARNING=
599
AC_MSG_CHECKING(for OpenSSL library)
Michael Graff's avatar
Michael Graff committed
600
AC_ARG_WITH(openssl,
601
[  --with-openssl[=PATH]     Build with OpenSSL [yes|no|path].
602
			  (Required for DNSSEC)],
603
    use_openssl="$withval", use_openssl="auto")
Michael Graff's avatar
Michael Graff committed
604

605
openssldirs="/usr /usr/local /usr/local/ssl /usr/pkg /usr/sfw"
606 607 608 609 610 611 612 613 614 615 616
if test "$use_openssl" = "auto"
then
	for d in $openssldirs
	do
		if test -f $d/include/openssl/opensslv.h
		then
			use_openssl=$d
			break
		fi
	done
fi
617
OPENSSL_ECDSA=""
618
OPENSSL_GOST=""
619 620
case "$use_openssl" in
	no)
621 622 623
		AC_MSG_RESULT(no)
		DST_OPENSSL_INC=""
		USE_OPENSSL=""
Mark Andrews's avatar
CHANGES  
Mark Andrews committed
624 625
		OPENSSLLINKOBJS=""
		OPENSSLLINKSRCS=""
626
		;;
627 628 629
	auto)
		DST_OPENSSL_INC=""
		USE_OPENSSL=""
Mark Andrews's avatar
CHANGES  
Mark Andrews committed
630 631
		OPENSSLLINKOBJS=""
		OPENSSLLINKSRCS=""
632 633 634
		AC_MSG_ERROR(
[OpenSSL was not found in any of $openssldirs; use --with-openssl=/path
If you don't want OpenSSL, use --without-openssl])
635
		;;
636
	*)
637
		if test "$use_openssl" = "yes"
638
		then
639
			# User did not specify a path - guess it
640 641 642 643
			for d in $openssldirs
			do
				if test -f $d/include/openssl/opensslv.h
				then
644
					use_openssl=$d
645 646 647 648
					break
				fi
			done
			if test "$use_openssl" = "yes"
649
			then
650
				AC_MSG_RESULT(not found)
651
				AC_MSG_ERROR(
Andreas Gustafsson's avatar
typo  
Andreas Gustafsson committed
652
[OpenSSL was not found in any of $openssldirs; use --with-openssl=/path])
653
			fi
654 655 656
		elif ! test -f "$use_openssl"/include/openssl/opensslv.h
		then
			AC_MSG_ERROR(["$use_openssl/include/openssl/opensslv.h" not found])
657
		fi
658
		USE_OPENSSL='-DOPENSSL'
659 660 661 662 663 664 665 666 667 668
		if test "$use_openssl" = "/usr"
		then
			DST_OPENSSL_INC=""
			DNS_OPENSSL_LIBS="-lcrypto"
		else
			DST_OPENSSL_INC="-I$use_openssl/include"
			case $host in
			*-solaris*)
				DNS_OPENSSL_LIBS="-L$use_openssl/lib -R$use_openssl/lib -lcrypto"
				;;
669 670 671
			*-hp-hpux*)
				DNS_OPENSSL_LIBS="-L$use_openssl/lib -Wl,+b: -lcrypto"
				;;
672 673 674 675 676 677 678 679 680 681 682 683 684 685 686
			*-apple-darwin*)
				#
				# Apple's ld seaches for serially for dynamic
				# then static libraries.  This means you can't
				# use -L to override dynamic system libraries
				# with static ones when linking.  Instead
				# we specify a absolute path.
				#
				if test -f "$use_openssl/lib/libcrypto.dylib"
				then
					DNS_OPENSSL_LIBS="-L$use_openssl/lib -lcrypto"
				else
					DNS_OPENSSL_LIBS="$use_openssl/lib/libcrypto.a"
				fi
				;;
687 688 689 690 691
			*)
				DNS_OPENSSL_LIBS="-L$use_openssl/lib -lcrypto"
				;;
			esac
		fi
692
		AC_MSG_RESULT(using OpenSSL from $use_openssl/lib and $use_openssl/include)
693 694 695 696 697

		saved_cflags="$CFLAGS"
		saved_libs="$LIBS"
		CFLAGS="$CFLAGS $DST_OPENSSL_INC"
		LIBS="$LIBS $DNS_OPENSSL_LIBS"
698 699 700 701 702
		AC_MSG_CHECKING(whether linking with OpenSSL works)
		AC_TRY_RUN([
#include <openssl/err.h>
int main() {
	ERR_clear_error();
703
	return (0);
704 705
}
],
706
		[AC_MSG_RESULT(yes)],
707
		[AC_MSG_RESULT(no)
Andreas Gustafsson's avatar
tweaked  
Andreas Gustafsson committed
708 709 710 711
		 AC_MSG_ERROR(Could not run test program using OpenSSL from
$use_openssl/lib and $use_openssl/include.
Please check the argument to --with-openssl and your
shared library configuration (e.g., LD_LIBRARY_PATH).)],
712
		[AC_MSG_RESULT(assuming it does work on target platform)])
713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732

		AC_MSG_CHECKING(whether linking with OpenSSL requires -ldl)
		AC_TRY_LINK([
#include <openssl/err.h>],
[ DSO_METHOD_dlfcn(); ],
		[AC_MSG_RESULT(no)],
		[LIBS="$LIBS -ldl"
		AC_TRY_LINK([
#include <openssl/err.h>
],[ DSO_METHOD_dlfcn(); ],
		[AC_MSG_RESULT(yes)
		DNS_OPENSSL_LIBS="$DNS_OPENSSL_LIBS -ldl"
		],
		 [AC_MSG_RESULT(unknown)
		 AC_MSG_ERROR(OpenSSL has unsupported dynamic loading)],
		[AC_MSG_RESULT(assuming it does work on target platform)])
		],
		[AC_MSG_RESULT(assuming it does work on target platform)]
		)
		 
733 734
AC_ARG_ENABLE(openssl-version-check,
[AC_HELP_STRING([--enable-openssl-version-check],
735
	[Check OpenSSL Version @<:@default=yes@:>@])])
736 737
case "$enable_openssl_version_check" in
yes|'')
738
		AC_MSG_CHECKING(OpenSSL library version)
739
		AC_TRY_RUN([
740
#include <stdio.h>
741 742
#include <openssl/opensslv.h>
int main() {
743
	if ((OPENSSL_VERSION_NUMBER >= 0x009070cfL &&
744
	     OPENSSL_VERSION_NUMBER < 0x00908000L) ||
745
	     OPENSSL_VERSION_NUMBER >= 0x0090804fL)
746
		return (0);
747 748
	printf("\n\nFound   OPENSSL_VERSION_NUMBER %#010x\n",
		OPENSSL_VERSION_NUMBER);
749 750
	printf("Require OPENSSL_VERSION_NUMBER 0x009070cf or greater (0.9.7l)\n"
	       "Require OPENSSL_VERSION_NUMBER 0x0090804f or greater (0.9.8d)\n\n");
751
	return (1);
752
}
753
		],
754
		[AC_MSG_RESULT(ok)],
755
		[AC_MSG_RESULT(not compatible)
756
		 OPENSSL_WARNING=yes
757
		],
758 759 760 761 762 763 764
		[AC_MSG_RESULT(assuming target platform has compatible version)])
;;
no)
	AC_MSG_RESULT(Skipped OpenSSL version check)
;;
esac

765 766 767 768 769 770 771 772
        AC_MSG_CHECKING(for OpenSSL DSA support)
        if test -f $use_openssl/include/openssl/dsa.h
        then
                AC_DEFINE(HAVE_OPENSSL_DSA)
                AC_MSG_RESULT(yes)
        else
                AC_MSG_RESULT(no)
        fi
773

774
        AC_CHECK_FUNCS(EVP_sha256 EVP_sha384 EVP_sha512)
775

776 777 778
        AC_MSG_CHECKING(for OpenSSL ECDSA support)
        have_ecdsa=""
        AC_TRY_RUN([
779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794
#include <stdio.h>
#include <openssl/ecdsa.h>
#include <openssl/objects.h>
int main() {
	EC_KEY *ec256, *ec384;

#if !defined(HAVE_EVP_SHA256) || !defined(HAVE_EVP_SHA384)
	return (1);
#endif
	ec256 = EC_KEY_new_by_curve_name(NID_X9_62_prime256v1);
	ec384 = EC_KEY_new_by_curve_name(NID_secp384r1);
	if (ec256 == NULL || ec384 == NULL)
		return (2);
	return (0);
}
],
795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830
        [AC_MSG_RESULT(yes)
        have_ecdsa="yes"],
        [AC_MSG_RESULT(no)
        have_ecdsa="no"],
        [AC_MSG_RESULT(using --with-ecdsa)])
        AC_ARG_WITH(ecdsa, [  --with-ecdsa            OpenSSL ECDSA],
	            with_ecdsa="$withval", with_ecdsa="auto")
        case "$with_ecdsa" in
        yes)
            case "$have_ecdsa" in
            no)  AC_MSG_ERROR([ecdsa not supported]) ;;
            *)  have_ecdsa=yes ;;
            esac
            ;;
        no)
            have_ecdsa=no ;;
        *)
            case "$have_ecdsa" in
            yes|no) ;;
            *) AC_MSG_ERROR([need --with-ecdsa=[[yes or no]]]) ;;
            esac
            ;;
        esac
        case $have_ecdsa in
        yes)
                OPENSSL_ECDSA="yes"
                AC_DEFINE(HAVE_OPENSSL_ECDSA, 1,
                          [Define if your OpenSSL version supports ECDSA.])
                ;;
        *)
                ;;
        esac

        AC_MSG_CHECKING(for OpenSSL GOST support)
        have_gost=""
        AC_TRY_RUN([
831 832 833 834 835
#include <openssl/conf.h>
#include <openssl/engine.h>
int main() {
#if (OPENSSL_VERSION_NUMBER >= 0x10000000L)
	ENGINE *e;
Francis Dupont's avatar
Francis Dupont committed
836
	EC_KEY *ek;
837

Francis Dupont's avatar
Francis Dupont committed
838
	ek = NULL;
839 840 841 842 843 844 845 846 847 848 849 850 851
	OPENSSL_config(NULL);

	e = ENGINE_by_id("gost");
	if (e == NULL)
		return (1);
	if (ENGINE_init(e) <= 0)
		return (1);
	return (0);
#else
	return (1);
#endif
}
],
852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887
        [AC_MSG_RESULT(yes)
        have_gost="yes"],
        [AC_MSG_RESULT(no)
        have_gost="no"],
        [AC_MSG_RESULT(using --with-gost)])
        AC_ARG_WITH(gost, [  --with-gost             OpenSSL GOST],
                    with_gost="$withval", with_gost="auto")
        case "$with_gost" in
        yes)
            case "$have_gost" in
            no)  AC_MSG_ERROR([gost not supported]) ;;
            *)  have_gost=yes ;;
            esac
            ;;
        no)
            have_gost=no ;;
        *)
            case "$have_gost" in
            yes|no) ;;
            *) AC_MSG_ERROR([need --with-gost=[[yes or no]]]) ;;
            esac
            ;;
        esac
        case $have_gost in
        yes)
                OPENSSL_GOST="yes"
                AC_DEFINE(HAVE_OPENSSL_GOST, 1,
                          [Define if your OpenSSL version supports GOST.])
                ;;
        *)
                ;;
        esac
        CFLAGS="$saved_cflags"
        LIBS="$saved_libs"
        OPENSSLLINKOBJS='${OPENSSLLINKOBJS}'
        OPENSSLLINKSRCS='${OPENSSLLINKSRCS}'
888

889
        ;;
890
esac
891 892 893 894 895 896

#
# This would include the system openssl path (and linker options to use
# it as needed) if it is found.
#

897
AC_SUBST(USE_OPENSSL)
898
AC_SUBST(DST_OPENSSL_INC)
Mark Andrews's avatar
CHANGES  
Mark Andrews committed
899 900
AC_SUBST(OPENSSLLINKOBJS)
AC_SUBST(OPENSSLLINKSRCS)
901
AC_SUBST(OPENSSL_ECDSA)
902
AC_SUBST(OPENSSL_GOST)
903

904
DNS_CRYPTO_LIBS="$DNS_CRYPTO_LIBS $DNS_OPENSSL_LIBS"
905

Francis Dupont's avatar
Francis Dupont committed
906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929
#
# Use OpenSSL for hash functions
#

AC_ARG_ENABLE(openssl-hash,
	[  --enable-openssl-hash   use OpenSSL for hash functions [[default=no]]],
	want_openssl_hash="$enableval", want_openssl_hash="no")
case $want_openssl_hash in
	yes)
		if test "$USE_OPENSSL" = ""
		then
			AC_MSG_ERROR([No OpenSSL for hash functions])
		fi
		ISC_PLATFORM_OPENSSLHASH="#define ISC_PLATFORM_OPENSSLHASH 1"
		ISC_OPENSSL_INC="$DST_OPENSSL_INC"
		;;
	no)
		ISC_PLATFORM_OPENSSLHASH="#undef ISC_PLATFORM_OPENSSLHASH"
		ISC_OPENSSL_INC=""
		;;
esac
AC_SUBST(ISC_PLATFORM_OPENSSLHASH)
AC_SUBST(ISC_OPENSSL_INC)

Francis Dupont's avatar
Francis Dupont committed
930 931 932 933 934 935 936 937
#
# PKCS11 (aka crypto hardware) support
#
# This works only with the right OpenSSL with PKCS11 engine!
#

AC_MSG_CHECKING(for PKCS11 support)
AC_ARG_WITH(pkcs11,
Francis Dupont's avatar
Francis Dupont committed
938 939 940
[  --with-pkcs11[=PATH]      Build with PKCS11 support [yes|no|path]
                          (PATH is for the PKCS11 provider)],
   use_pkcs11="$withval", use_pkcs11="no")
Francis Dupont's avatar
Francis Dupont committed
941 942

case "$use_pkcs11" in
Francis Dupont's avatar
Francis Dupont committed
943
	no|'')
Francis Dupont's avatar
Francis Dupont committed
944
		AC_MSG_RESULT(disabled)
Francis Dupont's avatar
Francis Dupont committed
945
		USE_PKCS11=''
946
		PKCS11_TOOLS=''
Francis Dupont's avatar
Francis Dupont committed
947
		;;
Francis Dupont's avatar
Francis Dupont committed
948
	yes|*)
Francis Dupont's avatar
Francis Dupont committed
949 950
		AC_MSG_RESULT(using OpenSSL with PKCS11 support)
		USE_PKCS11='-DUSE_PKCS11'
951
		PKCS11_TOOLS=pkcs11
Francis Dupont's avatar
Francis Dupont committed
952 953 954
		;;
esac
AC_SUBST(USE_PKCS11)
955
AC_SUBST(PKCS11_TOOLS)
Francis Dupont's avatar
Francis Dupont committed
956

Francis Dupont's avatar
Francis Dupont committed
957 958 959 960 961 962 963 964 965 966 967 968 969
AC_MSG_CHECKING(for PKCS11 tools)
case "$use_pkcs11" in
	no|yes|'')
		AC_MSG_RESULT(disabled)
		PKCS11_PROVIDER="undefined"
		;;
       *)
		AC_MSG_RESULT(PKCS11 provider is "$use_pkcs11")
		PKCS11_PROVIDER="$use_pkcs11"
		;;
esac
AC_SUBST(PKCS11_PROVIDER)

970 971
AC_MSG_CHECKING(for GSSAPI library)
AC_ARG_WITH(gssapi,
972 973
[  --with-gssapi=PATH      Specify path for system-supplied GSSAPI [[default=yes]]],
    use_gssapi="$withval", use_gssapi="yes")
974

975 976 977
# gssapi is just the framework, we really require kerberos v5, so
# look for those headers (the gssapi headers must be there, too)
# The problem with this implementation is that it doesn't allow
978 979 980
# for the specification of gssapi and krb5 headers in different locations,
# which probably ought to be fixed although fixing might raise the issue of
# trying to build with incompatible versions of gssapi and krb5.
981 982
if test "$use_gssapi" = "yes"
then
983 984 985
	# first, deal with the obvious
	if test \( -f /usr/include/kerberosv5/krb5.h -o \
		   -f /usr/include/krb5/krb5.h -o \
986
		   -f /usr/include/krb5.h \)   -a \
Scott Mann's avatar
Scott Mann committed
987
		\( -f /usr/include/gssapi.h -o \
988
		   -f /usr/include/gssapi/gssapi.h \)
989 990 991 992 993 994 995 996
	then
		use_gssapi=/usr
	else
	    krb5dirs="/usr/local /usr/local/krb5 /usr/local/kerberosv5 /usr/local/kerberos /usr/pkg /usr/krb5 /usr/kerberosv5 /usr/kerberos /usr"
	    for d in $krb5dirs
	    do
		if test -f $d/include/gssapi/gssapi_krb5.h -o \
		        -f $d/include/krb5.h
997
		then
998 999
			if test -f $d/include/gssapi/gssapi.h -o \
			        -f $d/include/gssapi.h
1000 1001 1002 1003
			then
				use_gssapi=$d
				break
			fi
1004
		fi
1005
		use_gssapi="no"
1006 1007
	    done
	fi
1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029
fi

case "$use_gssapi" in
	no)
		AC_MSG_RESULT(disabled)
		USE_GSSAPI=''
		;;
	yes)
		AC_MSG_ERROR([--with-gssapi must specify a path])
		;;
	*)
		AC_MSG_RESULT(looking in $use_gssapi/lib)
		USE_GSSAPI='-DGSSAPI'
		saved_cppflags="$CPPFLAGS"
		CPPFLAGS="-I$use_gssapi/include $CPPFLAGS"
		AC_CHECK_HEADERS(gssapi.h gssapi/gssapi.h,
		    [ISC_PLATFORM_GSSAPIHEADER="#define ISC_PLATFORM_GSSAPIHEADER <$ac_header>"])

		if test "$ISC_PLATFORM_GSSAPIHEADER" = ""; then
		    AC_MSG_ERROR([gssapi.h not found])
		fi

1030 1031 1032
		AC_CHECK_HEADERS(gssapi_krb5.h gssapi/gssapi_krb5.h,
		    [ISC_PLATFORM_GSSAPI_KRB5_HEADER="#define ISC_PLATFORM_GSSAPI_KRB5_HEADER <$ac_header>"])

1033
		AC_CHECK_HEADERS(krb5.h krb5/krb5.h kerberosv5/krb5.h,
1034 1035 1036
		    [ISC_PLATFORM_KRB5HEADER="#define ISC_PLATFORM_KRB5HEADER <$ac_header>"])

		if test "$ISC_PLATFORM_KRB5HEADER" = ""; then
1037
		    AC_MSG_ERROR([krb5.h not found])
1038 1039
		fi

1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069
		CPPFLAGS="$saved_cppflags"

		#
		# XXXDCL This probably doesn't work right on all systems.
		# It will need to be worked on as problems become evident.
		#
		# Essentially the problems here relate to two different
		# areas.  The first area is building with either KTH
		# or MIT Kerberos, particularly when both are present on
		# the machine.  The other is static versus dynamic linking.
		#
		# On the KTH vs MIT issue, Both have libkrb5 that can mess
		# up the works if one implementation ends up trying to
		# use the other's krb.  This is unfortunately a situation
		# that very easily arises.
		#
		# Dynamic linking when the dependency information is built
		# into MIT's libgssapi_krb5 or KTH's libgssapi magically makes
		# all such problems go away, but when that setup is not
		# present, because either the dynamic libraries lack
		# dependencies or static linking is being done, then the
		# problems start to show up.
		saved_libs="$LIBS"
		for TRY_LIBS in \
		    "-lgssapi_krb5" \
		    "-lgssapi_krb5 -lkrb5 -lk5crypto -lcom_err" \
		    "-lgssapi_krb5 -lkrb5 -lk5crypto -lcom_err -lresolv" \
		    "-lgssapi" \
		    "-lgssapi -lkrb5 -ldes -lcrypt -lasn1 -lroken -lcom_err" \
		    "-lgssapi -lkrb5 -lcrypto -lcrypt -lasn1 -lroken -lcom_err" \
Mark Andrews's avatar
Mark Andrews committed
1070
		    "-lgss -lkrb5"
1071 1072 1073 1074 1075 1076
		do
		    # Note that this does not include $saved_libs, because
		    # on FreeBSD machines this configure script has added
		    # -L/usr/local/lib to LIBS, which can make the
		    # -lgssapi_krb5 test succeed with shared libraries even
		    # when you are trying to build with KTH in /usr/lib.
1077 1078 1079 1080 1081 1082
		    if test "$use_gssapi" = "/usr"
		    then
			    LIBS="$TRY_LIBS"
		    else
			    LIBS="-L$use_gssapi/lib $TRY_LIBS"
		    fi
1083
		    AC_MSG_CHECKING(linking as $TRY_LIBS)
Mark Andrews's avatar
Mark Andrews committed
1084
		    AC_TRY_LINK( , [gss_acquire_cred();krb5_init_context()],
1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145
				gssapi_linked=yes, gssapi_linked=no)
		    case $gssapi_linked in
		    yes) AC_MSG_RESULT(yes); break ;;
		    no)  AC_MSG_RESULT(no) ;;
		    esac
		done

		case $gssapi_linked in
		no) AC_MSG_ERROR(could not determine proper GSSAPI linkage) ;;
		esac

		#
		# XXXDCL Major kludge.  Tries to cope with KTH in /usr/lib
		# but MIT in /usr/local/lib and trying to build with KTH.
		# /usr/local/lib can end up earlier on the link lines.
		# Like most kludges, this one is not only inelegant it
		# is also likely to be the wrong thing to do at least as
		# many times as it is the right thing.  Something better
		# needs to be done.
		#
		if test "$use_gssapi" = "/usr" -a \
			-f /usr/local/lib/libkrb5.a; then
		    FIX_KTH_VS_MIT=yes
		fi

		case "$FIX_KTH_VS_MIT" in
		yes)
		    case "$enable_static_linking" in
		    yes) gssapi_lib_suffix=".a"  ;;
		    *)   gssapi_lib_suffix=".so" ;;
		    esac

		    for lib in $LIBS; do
			case $lib in
			-L*)
			    ;;
			-l*)
			    new_lib=`echo $lib |
				     sed -e s%^-l%$use_gssapi/lib/lib% \
					 -e s%$%$gssapi_lib_suffix%`
			    NEW_LIBS="$NEW_LIBS $new_lib"
			    ;;
			*)
			   AC_MSG_ERROR([KTH vs MIT Kerberos confusion!])
			    ;;
			esac
		    done
		    LIBS="$NEW_LIBS"
		    ;;
		esac

		DST_GSSAPI_INC="-I$use_gssapi/include"
		DNS_GSSAPI_LIBS="$LIBS"

		AC_MSG_RESULT(using GSSAPI from $use_gssapi/lib and $use_gssapi/include)
		LIBS="$saved_libs"
		;;
esac

AC_SUBST(ISC_PLATFORM_HAVEGSSAPI)
AC_SUBST(ISC_PLATFORM_GSSAPIHEADER)
1146
AC_SUBST(ISC_PLATFORM_GSSAPI_KRB5_HEADER)
1147
AC_SUBST(ISC_PLATFORM_KRB5HEADER)
Brian Wellington's avatar
Brian Wellington committed
1148 1149 1150

AC_SUBST(USE_GSSAPI)
AC_SUBST(DST_GSSAPI_INC)
1151 1152
AC_SUBST(DNS_GSSAPI_LIBS)
DNS_CRYPTO_LIBS="$DNS_GSSAPI_LIBS $DNS_CRYPTO_LIBS"
1153 1154 1155 1156 1157 1158

#
# Applications linking with libdns also need to link with these libraries.
#

AC_SUBST(DNS_CRYPTO_LIBS)
Brian Wellington's avatar
Brian Wellington committed
1159

1160 1161 1162 1163 1164
#
# was --with-randomdev specified?
#
AC_MSG_CHECKING(for random device)
AC_ARG_WITH(randomdev,
1165
[  --with-randomdev=PATH   Specify path for random device],
1166 1167 1168 1169
    use_randomdev="$withval", use_randomdev="unspec")

case "$use_randomdev" in
	unspec)
1170 1171 1172 1173 1174
		case "$cross_compiling" in
		yes)
			AC_MSG_RESULT(unspecified)
			AC_MSG_ERROR([ need --with-randomdev=PATH or --with-randomdev=no])
		esac
1175 1176
		case "$host" in
			*-openbsd*)
1177
				devrandom=/dev/arandom
1178 1179
				;;
			*)
1180
				devrandom=/dev/random
1181 1182
				;;
		esac
1183
		AC_MSG_RESULT($devrandom)
1184
		AC_CHECK_FILE($devrandom,
1185 1186
			      AC_DEFINE_UNQUOTED(PATH_RANDOMDEV,
						 "$devrandom"),)
1187
			      
1188 1189 1190 1191
		;;
	yes)
		AC_MSG_ERROR([--with-randomdev must specify a path])
		;;
1192 1193 1194
	no)
		AC_MSG_RESULT(disabled)
		;;
1195
	*)
1196
		AC_DEFINE_UNQUOTED(PATH_RANDOMDEV, "$use_randomdev")
1197 1198 1199 1200
		AC_MSG_RESULT(using "$use_randomdev")
		;;
esac

1201 1202 1203 1204 1205
#
# Do we have arc4random() ?
#
AC_CHECK_FUNC(arc4random, AC_DEFINE(HAVE_ARC4RANDOM))

1206
sinclude(config.threads.in)dnl
Andreas Gustafsson's avatar
Andreas Gustafsson committed
1207

1208 1209
if $use_threads
then
1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252
	if test "X$GCC" = "Xyes"; then
		case "$host" in
		*-freebsd*)
			CC="$CC -pthread"
			CCOPT="$CCOPT -pthread"
			STD_CDEFINES="$STD_CDEFINES -D_THREAD_SAFE"
			;;
		*-openbsd*)
			CC="$CC -pthread"
			CCOPT="$CCOPT -pthread"
			;;
		*-solaris*)
			LIBS="$LIBS -lthread"
			;;
		*-ibm-aix*)
			STD_CDEFINES="$STD_CDEFINES -D_THREAD_SAFE"
			;;
		esac
	else
		case $host in
		*-dec-osf*)
			CC="$CC -pthread"
			CCOPT="$CCOPT -pthread"
			;;
		*-solaris*)
			CC="$CC -mt"
			CCOPT="$CCOPT -mt"
			;;
		*-ibm-aix*)
			STD_CDEFINES="$STD_CDEFINES -D_THREAD_SAFE"
			;;
		*-sco-sysv*uw*|*-*-sysv*UnixWare*)
			CC="$CC -Kthread"
			CCOPT="$CCOPT -Kthread"
			;;
		*-*-sysv*OpenUNIX*)
			CC="$CC -Kpthread"
			CCOPT="$CCOPT -Kpthread"
			;;
		esac
	fi
	ALWAYS_DEFINES="-D_REENTRANT"
	ISC_PLATFORM_USETHREADS="#define ISC_PLATFORM_USETHREADS 1"
Mark Andrews's avatar
CHANGES  
Mark Andrews committed
1253 1254
	THREADOPTOBJS='${THREADOPTOBJS}'
	THREADOPTSRCS='${THREADOPTSRCS}'
1255
	thread_dir=pthreads
Brian Wellington's avatar
Brian Wellington committed
1256
	#
Andreas Gustafsson's avatar
Andreas Gustafsson committed
1257
	# We'd like to use sigwait() too
Brian Wellington's avatar
Brian Wellington committed
1258
	#
1259 1260 1261 1262 1263 1264 1265
	AC_CHECK_FUNC(sigwait,
		      AC_DEFINE(HAVE_SIGWAIT),
		      AC_CHECK_LIB(c, sigwait,
		      AC_DEFINE(HAVE_SIGWAIT),
		      AC_CHECK_LIB(pthread, sigwait,
				   AC_DEFINE(HAVE_SIGWAIT),
				   AC_CHECK_LIB(pthread, _Psigwait,
1266
						AC_DEFINE(HAVE_SIGWAIT),))))
Brian Wellington's avatar
Brian Wellington committed
1267

1268 1269 1270
	AC_CHECK_FUNC(pthread_attr_getstacksize,
		      AC_DEFINE(HAVE_PTHREAD_ATTR_GETSTACKSIZE),)

1271 1272 1273
	AC_CHECK_FUNC(pthread_attr_setstacksize,
		      AC_DEFINE(HAVE_PTHREAD_ATTR_SETSTACKSIZE),)

Andreas Gustafsson's avatar
Andreas Gustafsson committed
1274 1275 1276
	#
	# Additional OS-specific issues related to pthreads and sigwait.
	#
1277
	case "$host" in
Andreas Gustafsson's avatar
Andreas Gustafsson committed
1278 1279 1280 1281 1282
		#
		# One more place to look for sigwait.
		#
		*-freebsd*)
			AC_CHECK_LIB(c_r, sigwait, AC_DEFINE(HAVE_SIGWAIT),)
1283
			case $host in
1284 1285 1286 1287 1288
			*-freebsd5.[[012]]|*-freebsd5.[[012]].*);;
			*-freebsd5.[[3456789]]|*-freebsd5.[[3456789]].*)
				AC_DEFINE(NEED_PTHREAD_SCOPE_SYSTEM)
				;;
			*-freebsd6.*)
1289 1290 1291
				AC_DEFINE(NEED_PTHREAD_SCOPE_SYSTEM)
				;;
			esac
Andreas Gustafsson's avatar
Andreas Gustafsson committed
1292 1293
			;;
		#
1294
		# BSDI 3.0 through 4.0.1 needs pthread_init() to be
Andreas Gustafsson's avatar
Andreas Gustafsson committed
1295 1296 1297
		# called before certain pthreads calls.	 This is deprecated
		# in BSD/OS 4.1.
		#
1298
		*-bsdi3.*|*-bsdi4.0*)
Andreas Gustafsson's avatar
Andreas Gustafsson committed
1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319
			AC_DEFINE(NEED_PTHREAD_INIT)
			;;
		#
		# LinuxThreads requires some changes to the way we
		# deal with signals.
		#
		*-linux*)
			AC_DEFINE(HAVE_LINUXTHREADS)
			;;
		#
		# Ensure the right sigwait() semantics on Solaris and make<