3 AC_CONFIG_HEADER(config.h)
7 if test "$GCC" = "yes"; then CFLAGS="$CFLAGS -Wall"; fi
10 # Checks for programs.
15 AC_CHECK_PROG(AR, ar, ar)
16 AC_PATH_PROG(PERL, perl)
19 # Check for some target-specific stuff
23 AC_DEFINE(BROKEN_GETADDRINFO)
26 if test -z "$GCC"; then
29 CFLAGS="$CFLAGS -D_HPUX_SOURCE"
30 AC_DEFINE(IPADDR_IN_DISPLAY)
32 AC_MSG_CHECKING(for HPUX trusted system password database)
33 if test -f /tcb/files/auth/system/default; then
35 AC_DEFINE(HAVE_HPUX_TRUSTED_SYSTEM_PW)
37 AC_MSG_WARN([This configuration is untested])
40 AC_DEFINE(DISABLE_SHADOW)
52 AC_MSG_WARN([*** Irix 6.x is not tested, please report you experiences *** ])
58 need_pty_removed_on_close=1
71 LIBS="$LIBS -lgen -lsocket"
75 # Checks for libraries.
76 AC_CHECK_LIB(z, deflate, ,AC_MSG_ERROR([*** zlib missing - please install first ***]))
77 AC_CHECK_LIB(util, login, AC_DEFINE(HAVE_LIBUTIL_LOGIN) LIBS="$LIBS -lutil")
79 if test -z "$no_libsocket" ; then
80 AC_CHECK_LIB(nsl, yp_match, , )
82 if test -z "$no_libnsl" ; then
83 AC_CHECK_LIB(socket, main, , )
86 # Checks for header files.
87 AC_CHECK_HEADERS(bstring.h endian.h lastlog.h login.h maillock.h netdb.h netgroup.h paths.h poll.h pty.h shadow.h security/pam_appl.h sys/bitypes.h sys/bsdtty.h sys/cdefs.h sys/poll.h sys/select.h sys/stropts.h sys/sysmacros.h sys/time.h sys/ttcompat.h stddef.h util.h utmp.h utmpx.h)
89 # Checks for library functions.
90 AC_CHECK_FUNCS(arc4random bindresvport_af freeaddrinfo gai_strerror getaddrinfo getpagesize getnameinfo innetgr md5_crypt mkdtemp openpty rresvport_af setenv seteuid setlogin setproctitle setreuid snprintf strlcat strlcpy updwtmpx vsnprintf _getpty)
93 [AC_DEFINE(HAVE_LOGIN)],
94 [AC_CHECK_LIB(bsd, login, [LIBS="$LIBS -lbsd"; AC_DEFINE(HAVE_LOGIN)])]
98 [AC_DEFINE(HAVE_DAEMON)],
99 [AC_CHECK_LIB(bsd, daemon, [LIBS="$LIBS -lbsd"; AC_DEFINE(HAVE_DAEMON)])]
103 [ --without-pam Disable PAM support ],
105 if test "x$withval" = "xno" ; then
107 AC_DEFINE(DISABLE_PAM)
111 if test -z "$no_pam" -a "x$ac_cv_header_security_pam_appl_h" = "xyes" ; then
112 AC_CHECK_LIB(dl, dlopen, , )
115 # Check PAM strerror arguments (old PAM)
116 AC_MSG_CHECKING([whether pam_strerror takes only one argument])
120 #include <security/pam_appl.h>
122 [(void)pam_strerror((pam_handle_t *)NULL, -1);],
125 AC_DEFINE(HAVE_OLD_PAM)
131 # The big search for OpenSSL
133 [ --with-ssl-dir=PATH Specify path to OpenSSL installation ],
135 if test "x$withval" != "$xno" ; then
142 saved_CFLAGS="$CFLAGS"
143 if test "x$prefix" != "xNONE" ; then
144 tryssldir="$tryssldir $prefix"
146 AC_MSG_CHECKING([for OpenSSL/SSLeay directory])
147 for ssldir in "" $tryssldir /usr /usr/local/openssl /usr/lib/openssl /usr/local/ssl /usr/lib/ssl /usr/local /usr/pkg /opt /opt/openssl ; do
148 if test ! -z "$ssldir" ; then
149 LIBS="$saved_LIBS -L$ssldir"
150 CFLAGS="$CFLAGS -I$ssldir/include"
151 if test "x$need_dash_r" = "x1" ; then
152 LIBS="$LIBS -R$ssldir"
155 LIBS="$LIBS -lcrypto"
159 #include <openssl/rsa.h>
160 #include <openssl/bn.h>
161 #include <openssl/sha.h>
163 {RSA *key; char seed[2048];memset(seed, 0, sizeof(seed));
164 RAND_seed(seed, sizeof(seed));key=RSA_generate_key(32,3,NULL,NULL);
168 AC_DEFINE(HAVE_OPENSSL)
179 {RSA *key; char seed[2048];memset(seed, 0, sizeof(seed));
180 RAND_seed(seed, sizeof(seed));key=RSA_generate_key(32,3,NULL,NULL);
191 if test -z "$found_crypto" ; then
192 AC_MSG_ERROR([Could not find working SSLeay / OpenSSL libraries, please install])
194 if test -z "$ssldir" ; then
197 CFLAGS="$CFLAGS -I$ssldir/include"
198 LDFLAGS="$LDFLAGS -L$ssldir/lib"
199 if test "x$need_dash_r" = "x1" ; then
200 LDFLAGS="$LDFLAGS -R$ssldir"
203 LIBS="$saved_LIBS -lcrypto"
204 AC_MSG_RESULT($ssldir)
206 # Checks for data types
207 AC_CHECK_SIZEOF(char, 1)
208 AC_CHECK_SIZEOF(short int, 2)
209 AC_CHECK_SIZEOF(int, 4)
210 AC_CHECK_SIZEOF(long int, 4)
211 AC_CHECK_SIZEOF(long long int, 8)
213 # More checks for data types
214 AC_MSG_CHECKING([for intXX_t types])
216 [#include <sys/types.h>],
217 [int16_t a; int32_t b; a = 1235; b = 1235;],
219 AC_DEFINE(HAVE_INTXX_T)
226 AC_MSG_CHECKING([for u_intXX_t types])
228 [#include <sys/types.h>],
229 [u_int16_t c; u_int32_t d; c = 1235; d = 1235;],
231 AC_DEFINE(HAVE_U_INTXX_T)
238 if test -z "$have_u_intxx_t" -o -z "$have_intxx_t" -a \
239 "x$ac_cv_header_sys_bitypes_h" = "xyes"
241 AC_MSG_CHECKING([for intXX_t and u_intXX_t types in sys/bitypes.h])
243 [#include <sys/bitypes.h>],
245 u_int16_t c; u_int32_t d;
246 int16_t e; int32_t f;
251 AC_DEFINE(HAVE_U_INTXX_T)
252 AC_DEFINE(HAVE_INTXX_T)
259 AC_MSG_CHECKING([for uintXX_t types])
261 [#include <sys/types.h>],
262 [uint16_t c; uint32_t d; c = 1235; d = 1235;],
264 AC_DEFINE(HAVE_UINTXX_T)
270 AC_MSG_CHECKING([for socklen_t])
273 #include <sys/types.h>
274 #include <sys/socket.h>
276 [socklen_t foo; foo = 1235;],
278 AC_DEFINE(HAVE_SOCKLEN_T)
284 AC_MSG_CHECKING([for size_t])
286 [#include <sys/types.h>],
287 [size_t foo; foo = 1235;],
289 AC_DEFINE(HAVE_SIZE_T)
295 AC_MSG_CHECKING([for struct sockaddr_storage])
298 #include <sys/types.h>
299 #include <sys/socket.h>
301 [struct sockaddr_storage s;],
303 AC_DEFINE(HAVE_STRUCT_SOCKADDR_STORAGE)
309 AC_MSG_CHECKING([for struct sockaddr_in6])
311 [#include <netinet/in.h>],
312 [struct sockaddr_in6 s; s.sin6_family = 0;],
314 AC_DEFINE(HAVE_STRUCT_SOCKADDR_IN6)
320 AC_MSG_CHECKING([for struct in6_addr])
322 [#include <netinet/in.h>],
323 [struct in6_addr s; s.s6_addr[0] = 0;],
325 AC_DEFINE(HAVE_STRUCT_IN6_ADDR)
331 AC_MSG_CHECKING([for struct addrinfo])
334 #include <sys/types.h>
335 #include <sys/socket.h>
338 [struct addrinfo s; s.ai_flags = AI_PASSIVE;],
340 AC_DEFINE(HAVE_STRUCT_ADDRINFO)
346 # Checks for structure members
347 AC_MSG_CHECKING([whether utmp.h has ut_host field])
348 AC_EGREP_HEADER(ut_host, utmp.h,
349 [AC_DEFINE(HAVE_HOST_IN_UTMP) AC_MSG_RESULT(yes); ],
352 AC_MSG_CHECKING([whether utmpx.h has ut_host field])
353 AC_EGREP_HEADER(ut_host, utmpx.h,
354 [AC_DEFINE(HAVE_HOST_IN_UTMPX) AC_MSG_RESULT(yes); ],
357 AC_MSG_CHECKING([whether utmpx.h has syslen field])
358 AC_EGREP_HEADER(syslen, utmpx.h,
359 [AC_DEFINE(HAVE_SYSLEN_IN_UTMPX) AC_MSG_RESULT(yes); ],
362 AC_MSG_CHECKING([whether utmp.h has ut_pid field])
363 AC_EGREP_HEADER(ut_pid, utmp.h,
364 [AC_DEFINE(HAVE_PID_IN_UTMP) AC_MSG_RESULT(yes); ],
367 AC_MSG_CHECKING([whether utmp.h has ut_type field])
368 AC_EGREP_HEADER(ut_type, utmp.h,
369 [AC_DEFINE(HAVE_TYPE_IN_UTMP) AC_MSG_RESULT(yes); ],
372 AC_MSG_CHECKING([whether utmp.h has ut_tv field])
373 AC_EGREP_HEADER(ut_tv, utmp.h,
374 [AC_DEFINE(HAVE_TV_IN_UTMP) AC_MSG_RESULT(yes); ],
377 AC_MSG_CHECKING([whether utmp.h has ut_id field])
378 AC_EGREP_HEADER(ut_id, utmp.h,
379 [AC_DEFINE(HAVE_ID_IN_UTMP) AC_MSG_RESULT(yes); ],
382 AC_MSG_CHECKING([whether utmp.h has ut_addr field])
383 AC_EGREP_HEADER(ut_addr, utmp.h,
384 [AC_DEFINE(HAVE_ADDR_IN_UTMP) AC_MSG_RESULT(yes); ],
387 AC_MSG_CHECKING([whether utmpx.h has ut_addr field])
388 AC_EGREP_HEADER(ut_addr, utmpx.h,
389 [AC_DEFINE(HAVE_ADDR_IN_UTMPX) AC_MSG_RESULT(yes); ],
392 AC_MSG_CHECKING([whether utmp.h has ut_addr_v6 field])
393 AC_EGREP_HEADER(ut_addr_v6, utmp.h,
394 [AC_DEFINE(HAVE_ADDR_V6_IN_UTMP) AC_MSG_RESULT(yes); ],
397 AC_MSG_CHECKING([whether utmpx.h has ut_addr_v6 field])
398 AC_EGREP_HEADER(ut_addr_v6, utmpx.h,
399 [AC_DEFINE(HAVE_ADDR_V6_IN_UTMPX) AC_MSG_RESULT(yes); ],
403 AC_MSG_CHECKING([whether struct sockaddr_storage has ss_family field])
406 #include <sys/types.h>
407 #include <sys/socket.h>
409 [struct sockaddr_storage s; s.ss_family = 1;],
411 AC_DEFINE(HAVE_SS_FAMILY_IN_SS)
416 AC_MSG_CHECKING([whether struct sockaddr_storage has __ss_family field])
419 #include <sys/types.h>
420 #include <sys/socket.h>
422 [struct sockaddr_storage s; s.__ss_family = 1;],
424 AC_DEFINE(HAVE___SS_FAMILY_IN_SS)
430 AC_MSG_CHECKING([whether libc defines __progname])
432 [extern char *__progname; printf("%s", __progname);],
434 AC_DEFINE(HAVE___PROGNAME)
442 # Looking for programs, paths and files
444 [ --with-rsh=PATH Specify path to remote shell program ],
446 if test "x$withval" != "$xno" ; then
447 AC_DEFINE_UNQUOTED(RSH_PATH, "$withval")
451 AC_PATH_PROG(rsh_path, rsh)
456 [ --with-xauth=PATH Specify path to xauth program ],
458 if test "x$withval" != "$xno" ; then
459 AC_DEFINE_UNQUOTED(XAUTH_PATH, "$withval")
463 AC_PATH_PROG(xauth_path, xauth)
464 if test ! -z "$xauth_path" -a -x "/usr/openwin/bin/xauth" ; then
465 xauth_path="/usr/openwin/bin/xauth"
470 if test ! -z "$xauth_path" ; then
471 AC_DEFINE_UNQUOTED(XAUTH_PATH, "$xauth_path")
473 if test ! -z "$rsh_path" ; then
474 AC_DEFINE_UNQUOTED(RSH_PATH, "$rsh_path")
477 # Check for mail directory (last resort if we cannot get it from headers)
478 if test ! -z "$MAIL" ; then
479 maildir=`dirname $MAIL`
480 AC_DEFINE_UNQUOTED(MAIL_DIRECTORY, "$maildir")
483 # Look for lastlog location
485 [ --with-lastlog=FILE Location of lastlog file],
487 if test "x$withval" = "xno" ; then
488 AC_DEFINE(DISABLE_LASTLOG)
490 AC_DEFINE_UNQUOTED(LASTLOG_LOCATION, "$withval")
494 AC_MSG_CHECKING([location of lastlog file])
495 for lastlog in /var/log/lastlog /var/adm/lastlog /usr/adm/lastlog /etc/security/lastlog ; do
496 if test -f $lastlog ; then
500 if test -d $lastlog ; then
505 if test -z "$gotlastlog" ; then
506 AC_MSG_RESULT(not found)
509 if test "x$gotlastlog" = "xdir" ; then
510 AC_MSG_RESULT(${lastlog}/)
511 AC_DEFINE(LASTLOG_IS_DIR)
513 AC_MSG_RESULT($lastlog)
514 AC_DEFINE_UNQUOTED(LASTLOG_LOCATION, "$lastlog")
520 if test ! -z "$nolastlog" ; then
521 AC_MSG_WARN([*** Disabling lastlog support *** ])
522 AC_DEFINE(DISABLE_LASTLOG)
525 if test -z "$no_dev_ptmx" ; then
526 AC_CHECK_FILE("/dev/ptmx",
528 AC_DEFINE_UNQUOTED(HAVE_DEV_PTMX)
533 AC_CHECK_FILE("/dev/ptc",
535 AC_DEFINE_UNQUOTED(HAVE_DEV_PTS_AND_PTC)
540 # Some systems (defined in platform-specific code above) automagically remove
541 # Unix98 ptys when they are closed
542 if test "x$ac_cv_func_openpty" = "xyes" -o "x$have_dev_ptmx" = "x1" -o "x$have_dev_ptc" = "x1" ; then
543 if test "x$need_pty_removed_on_close" = "x1" ; then
544 AC_DEFINE(PTY_REMOVED_ON_CLOSE)
548 # Options from here on. Some of these are preset by platform above
550 # Check whether user wants GNOME ssh-askpass
551 AC_MSG_CHECKING([whether to build GNOME ssh-askpass])
552 AC_ARG_WITH(gnome-askpass,
553 [ --with-gnome-askpass Build the GNOME passphrase requester (default=no)],
555 if test x$withval = xno ; then
558 GNOME_ASKPASS="gnome-ssh-askpass";
561 AC_SUBST(GNOME_ASKPASS)
563 if test -z "$GNOME_ASKPASS" ; then
569 # Check for user-specified random device, otherwise check /dev/urandom
571 [ --with-random=FILE read randomness from FILE (default=/dev/urandom)],
573 RANDOM_POOL="$withval";
574 AC_DEFINE_UNQUOTED(RANDOM_POOL, "$RANDOM_POOL")
577 # Check for random device
578 AC_CHECK_FILE("/dev/urandom",
580 RANDOM_POOL="/dev/urandom";
581 AC_SUBST(RANDOM_POOL)
582 AC_DEFINE_UNQUOTED(RANDOM_POOL, "$RANDOM_POOL")
588 # Check for EGD pool file
589 AC_ARG_WITH(egd-pool,
590 [ --with-egd-pool=FILE read randomness from EGD pool FILE (default none)],
592 RANDOM_POOL="$withval";
594 AC_SUBST(RANDOM_POOL)
595 AC_DEFINE_UNQUOTED(RANDOM_POOL, "$RANDOM_POOL")
599 # Make sure we have some random number support
600 if test -z "$RANDOM_POOL" -a -z "$EGD_POOL"; then
601 AC_MSG_ERROR([No random device found, and no EGD random pool specified])
605 [ --with-catman=man|cat Install preformatted manpages[no]],
608 if test x"$withval" != x"yes" ; then
614 if test -z "$MANTYPE" ; then
615 MANTYPE='$(TROFFMAN)'
623 # Check whether user wants Kerberos support
624 AC_ARG_WITH(kerberos4,
625 [ --with-kerberos4=PATH Enable Kerberos 4 support],
627 if test "x$withval" != "$xno" ; then
629 if test "x$withval" != "$xyes" ; then
630 CFLAGS="$CFLAGS -I${withval}/include"
631 LDFLAGS="$LDFLAGS -L${withval}/lib"
633 if test -d /usr/include/kerberosIV ; then
634 CFLAGS="$CFLAGS -I/usr/include/kerberosIV"
638 AC_CHECK_HEADERS(krb.h)
639 AC_CHECK_LIB(krb, main)
640 if test "$ac_cv_header_krb_h" != yes; then
641 AC_MSG_WARN([Cannot find krb.h, build may fail])
643 if test "$ac_cv_lib_krb_main" != yes; then
644 AC_MSG_WARN([Cannot find libkrb, build may fail])
648 AC_CHECK_LIB(resolv, dn_expand, , )
655 # Check whether user wants AFS support
657 [ --with-afs=PATH Enable AFS support],
659 if test "x$withval" != "$xno" ; then
661 if test "x$withval" != "$xyes" ; then
662 CFLAGS="$CFLAGS -I${withval}/include"
663 LFLAGS="$LFLAGS -L${withval}/lib"
666 if test -z "$KRB4" ; then
667 AC_MSG_WARN([AFS requires Kerberos IV support, build may fail])
671 if test ! -z "$AFS_LIBS" ; then
672 LIBS="$LIBS $AFS_LIBS"
680 # Check whether user wants S/Key support
682 [ --with-skey Enable S/Key support],
684 if test "x$withval" != "$xno" ; then
691 # Check whether user wants TCP wrappers support
692 AC_ARG_WITH(tcp-wrappers,
693 [ --with-tcp-wrappers Enable tcpwrappers support],
695 if test "x$withval" != "$xno" ; then
702 # Check whether to enable MD5 passwords
703 AC_ARG_WITH(md5-passwords,
704 [ --with-md5-passwords Enable use of MD5 passwords],
706 if test "x$withval" != "$xno" ; then
707 AC_DEFINE(HAVE_MD5_PASSWORDS)
712 # Check whether to enable utmpx support
714 [ --with-utmpx Enable utmpx support],
716 if test "x$withval" != "xno" ; then
722 # Whether to disable shadow password support
724 [ --without-shadow Disable shadow password support],
726 if test "x$withval" = "xno" ; then
727 AC_DEFINE(DISABLE_SHADOW)
732 # Use ip address instead of hostname in $DISPLAY
733 AC_ARG_WITH(ipaddr-display,
734 [ --with-ipaddr-display Use ip address instead of hostname in \$DISPLAY],
736 if test "x$withval" = "xno" ; then
737 AC_DEFINE(IPADDR_IN_DISPLAY)
742 # Whether to mess with the default path
743 AC_ARG_WITH(default-path,
744 [ --with-default-path=PATH Specify default \$PATH environment for server],
746 if test "x$withval" != "xno" ; then
747 AC_DEFINE_UNQUOTED(USER_PATH, "$withval")
752 # Whether to force IPv4 by default (needed on broken glibc Linux)
753 AC_ARG_WITH(ipv4-default,
754 [ --with-ipv4-default Use IPv4 by connections unless '-6' specified],
756 if test "x$withval" != "xno" ; then
757 AC_DEFINE(IPV4_DEFAULT)
762 # Where to place sshd.pid
765 [ --with-pid-dir=PATH Specify location of ssh.pid file],
767 if test "x$withval" != "xno" ; then
772 AC_DEFINE_UNQUOTED(PIDDIR, "$piddir")