]> andersk Git - openssh.git/blame - configure.in
- OpenBSD CVS update:
[openssh.git] / configure.in
CommitLineData
4cca272e 1AC_INIT(ssh.c)
5881cd60 2
3AC_CONFIG_HEADER(config.h)
b14b2ae7 4AC_PROG_CC
a7effaac 5AC_CANONICAL_HOST
5881cd60 6
a0391976 7# Checks for programs.
4cca272e 8AC_PROG_CPP
5881cd60 9AC_PROG_RANLIB
cf8dd513 10AC_PROG_INSTALL
d4f11b59 11AC_CHECK_PROG(AR, ar, ar)
a0f84251 12AC_PATH_PROG(PERL, perl)
13AC_SUBST(PERL)
ad85db64 14AC_PATH_PROG(ENT, ent)
15AC_SUBST(ENT)
f498ed15 16
d423d822 17if test -z "$LD" ; then
18 LD=$CC
19fi
20AC_SUBST(LD)
21
22# C Compiler features
23AC_C_INLINE
24if test "$GCC" = "yes"; then
25 CFLAGS="$CFLAGS -Wall"
26fi
27
a0391976 28# Check for some target-specific stuff
a7effaac 29case "$host" in
9d6b1b96 30*-*-aix*)
31 AFS_LIBS="-lld"
84afc958 32 CFLAGS="$CFLAGS -I/usr/local/include"
33 LDFLAGS="$LDFLAGS -L/usr/local/lib"
bd499f9e 34 if test "$LD" != "gcc" -a -z "$blibpath"; then
35 blibpath="/usr/lib:/lib:/usr/local/lib"
36 fi
c1ef8333 37 AC_CHECK_FUNC(authenticate, [AC_DEFINE(WITH_AIXAUTHENTICATE)])
4c8ef3fb 38 AC_DEFINE(BROKEN_GETADDRINFO)
9d6b1b96 39 ;;
a7effaac 40*-*-hpux10*)
41 if test -z "$GCC"; then
42 CFLAGS="$CFLAGS -Aa"
43 fi
44 CFLAGS="$CFLAGS -D_HPUX_SOURCE"
84afc958 45 CFLAGS="$CFLAGS -I/usr/local/include"
46 LDFLAGS="$LDFLAGS -L/usr/local/lib"
a7effaac 47 AC_DEFINE(IPADDR_IN_DISPLAY)
f498ed15 48 AC_DEFINE(USE_UTMPX)
a7effaac 49 AC_MSG_CHECKING(for HPUX trusted system password database)
50 if test -f /tcb/files/auth/system/default; then
51 AC_MSG_RESULT(yes)
52 AC_DEFINE(HAVE_HPUX_TRUSTED_SYSTEM_PW)
53 LIBS="$LIBS -lsec"
dfb95100 54 AC_MSG_WARN([This configuration is untested])
a7effaac 55 else
56 AC_MSG_RESULT(no)
57 AC_DEFINE(DISABLE_SHADOW)
58 fi
c54a6257 59 MANTYPE='$(CATMAN)'
60 mansubdir=cat
a7effaac 61 ;;
2b763e31 62*-*-hpux11*)
63 if test -z "$GCC"; then
64 CFLAGS="$CFLAGS -Ae"
65 fi
66 CFLAGS="$CFLAGS -D_HPUX_SOURCE"
67 CFLAGS="$CFLAGS -I/usr/local/include"
68 LDFLAGS="$LDFLAGS -L/usr/local/lib"
69 AC_DEFINE(IPADDR_IN_DISPLAY)
70 AC_DEFINE(USE_UTMPX)
71 AC_MSG_CHECKING(for HPUX trusted system password database)
72 if test -f /tcb/files/auth/system/default; then
73 AC_MSG_RESULT(yes)
74 AC_DEFINE(HAVE_HPUX_TRUSTED_SYSTEM_PW)
75 LIBS="$LIBS -lsec"
76 AC_MSG_WARN([This configuration is untested])
77 else
78 AC_MSG_RESULT(no)
79 AC_DEFINE(DISABLE_SHADOW)
80 fi
81 MANTYPE='$(CATMAN)'
82 mansubdir=cat
83 ;;
d94aa2ae 84*-*-irix5*)
84afc958 85 CFLAGS="$CFLAGS -I/usr/local/include"
86 LDFLAGS="$LDFLAGS -L/usr/local/lib"
8eb34e02 87 MANTYPE='$(CATMAN)'
b9795b89 88 no_libsocket=1
89 no_libnsl=1
90 ;;
91*-*-irix6*)
84afc958 92 CFLAGS="$CFLAGS -I/usr/local/include"
93 LDFLAGS="$LDFLAGS -L/usr/local/lib"
8eb34e02 94 MANTYPE='$(CATMAN)'
95 AC_MSG_WARN([*** Irix 6.x is not tested, please report you experiences *** ])
d94aa2ae 96 no_libsocket=1
97 no_libnsl=1
98 ;;
5cdfe03f 99*-*-linux*)
100 no_dev_ptmx=1
80faa19f 101 AC_DEFINE(DONT_TRY_OTHER_AF)
102 inet6_default_4in6=yes
5cdfe03f 103 ;;
d468fc76 104*-*-netbsd*)
a0391976 105 need_dash_r=1
d468fc76 106 ;;
9d6b1b96 107*-*-solaris*)
84afc958 108 CFLAGS="$CFLAGS -I/usr/local/include"
4696775a 109 LDFLAGS="$LDFLAGS -L/usr/local/lib -R/usr/local/lib -L/usr/ucblib -R/usr/ucblib"
a0391976 110 need_dash_r=1
9d6b1b96 111 AC_DEFINE(USE_UTMPX)
112 ;;
113*-*-sysv*)
84afc958 114 CFLAGS="$CFLAGS -I/usr/local/include"
115 LDFLAGS="$LDFLAGS -L/usr/local/lib"
9755cbdb 116 AC_DEFINE(USE_UTMPX)
117 MANTYPE='$(CATMAN)'
118 mansubdir=cat
9d6b1b96 119 LIBS="$LIBS -lgen -lsocket"
120 ;;
a7effaac 121esac
122
a0391976 123# Checks for libraries.
4cca272e 124AC_CHECK_LIB(z, deflate, ,AC_MSG_ERROR([*** zlib missing - please install first ***]))
125AC_CHECK_LIB(util, login, AC_DEFINE(HAVE_LIBUTIL_LOGIN) LIBS="$LIBS -lutil")
4cca272e 126
d94aa2ae 127if test -z "$no_libsocket" ; then
128 AC_CHECK_LIB(nsl, yp_match, , )
129fi
130if test -z "$no_libnsl" ; then
131 AC_CHECK_LIB(socket, main, , )
f74efc8d 132fi
4cca272e 133
a0391976 134# Checks for header files.
52bcc044 135AC_CHECK_HEADERS(bstring.h endian.h lastlog.h login.h maillock.h netdb.h netgroup.h netinet/in_systm.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)
4cca272e 136
a0391976 137# Checks for library functions.
1d1ffb87 138AC_CHECK_FUNCS(arc4random b64_ntop bindresvport_af clock freeaddrinfo gai_strerror getaddrinfo getnameinfo getrusage innetgr md5_crypt mkdtemp openpty rresvport_af setenv seteuid setlogin setproctitle setreuid snprintf strlcat strlcpy updwtmpx vsnprintf vhangup _getpty __b64_ntop)
76cd7316 139
beb43d31 140AC_CHECK_FUNC(login,
141 [AC_DEFINE(HAVE_LOGIN)],
142 [AC_CHECK_LIB(bsd, login, [LIBS="$LIBS -lbsd"; AC_DEFINE(HAVE_LOGIN)])]
143)
144
145AC_CHECK_FUNC(daemon,
146 [AC_DEFINE(HAVE_DAEMON)],
147 [AC_CHECK_LIB(bsd, daemon, [LIBS="$LIBS -lbsd"; AC_DEFINE(HAVE_DAEMON)])]
148)
149
aa6bd60a 150AC_CHECK_FUNC(getpagesize,
151 [AC_DEFINE(HAVE_GETPAGESIZE)],
152 [AC_CHECK_LIB(ucb, getpagesize, [LIBS="$LIBS -lucb"; AC_DEFINE(HAVE_GETPAGESIZE)])]
153)
154
a0391976 155AC_ARG_WITH(pam,
156 [ --without-pam Disable PAM support ],
157 [
158 if test "x$withval" = "xno" ; then
159 no_pam=1
160 AC_DEFINE(DISABLE_PAM)
161 fi
162 ]
163)
164if test -z "$no_pam" -a "x$ac_cv_header_security_pam_appl_h" = "xyes" ; then
165 AC_CHECK_LIB(dl, dlopen, , )
166 LIBS="$LIBS -lpam"
167
28c1d5ce 168 AC_CHECK_FUNCS(pam_getenvlist)
2b763e31 169
a0391976 170 # Check PAM strerror arguments (old PAM)
171 AC_MSG_CHECKING([whether pam_strerror takes only one argument])
172 AC_TRY_COMPILE(
173 [
18ba2aab 174#include <stdlib.h>
175#include <security/pam_appl.h>
a0391976 176 ],
177 [(void)pam_strerror((pam_handle_t *)NULL, -1);],
178 [AC_MSG_RESULT(no)],
179 [
180 AC_DEFINE(HAVE_OLD_PAM)
181 AC_MSG_RESULT(yes)
182 ]
183 )
184fi
185
186# The big search for OpenSSL
187AC_ARG_WITH(ssl-dir,
188 [ --with-ssl-dir=PATH Specify path to OpenSSL installation ],
189 [
190 if test "x$withval" != "$xno" ; then
191 tryssldir=$withval
192 fi
193 ]
194)
195
196saved_LIBS="$LIBS"
cb0b7ea4 197saved_LDFLAGS="$LDFLAGS"
a0391976 198saved_CFLAGS="$CFLAGS"
199if test "x$prefix" != "xNONE" ; then
200 tryssldir="$tryssldir $prefix"
201fi
58d100bf 202AC_CACHE_CHECK([for OpenSSL directory], ac_cv_openssldir, [
203
204 for ssldir in "" $tryssldir /usr/local/openssl /usr/lib/openssl /usr/local/ssl /usr/lib/ssl /usr/local /usr/pkg /opt /opt/openssl ; do
205 if test ! -z "$ssldir" ; then
206 LDFLAGS="$saved_LDFLAGS -L$ssldir/lib -L$ssldir"
207 CFLAGS="$saved_CFLAGS -I$ssldir/include"
208 if test ! -z "$need_dash_r" ; then
209 LDFLAGS="$LDFLAGS -R$ssldir/lib -R$ssldir"
210 fi
211 else
212 LDFLAGS="$saved_LDFLAGS"
a0391976 213 fi
a0391976 214
58d100bf 215 for WANTS_RSAREF in "" 1 ; do
bcf36c78 216
58d100bf 217 if test -z "$WANTS_RSAREF" ; then
218 LIBS="$saved_LIBS -lcrypto"
219 else
220 LIBS="$saved_LIBS -lcrypto -lRSAglue -lrsaref"
221 fi
bcf36c78 222
58d100bf 223 AC_TRY_RUN(
224 [
44fb55e9 225#include <string.h>
226#include <openssl/rand.h>
18ba2aab 227#include <openssl/rsa.h>
228#include <openssl/bn.h>
229#include <openssl/sha.h>
230int main(void)
231{
232 RSA *key; char a[2048],b[2048];;
233 memset(a, 0, sizeof(a));memset(b, 0, sizeof(b));
234 RAND_add(a, sizeof(a), sizeof(a));
235 key=RSA_generate_key(32,3,NULL,NULL);
236 if (key==NULL) return(1);
237 return(-1==RSA_private_decrypt(RSA_size(key),a,b,key,RSA_NO_PADDING));
238}
58d100bf 239 ],
240 [
241 found_crypto=1
242 break;
243 ], []
244 )
245 done
246
247 if test ! -z "$found_crypto" ; then
248 break;
249 fi
bcf36c78 250 done
251
58d100bf 252 if test -z "$found_crypto" ; then
253 AC_MSG_ERROR([Could not find working SSLeay / OpenSSL libraries, please install])
254 fi
255 if test -z "$ssldir" ; then
256 ssldir="(system)"
bcf36c78 257 fi
a0391976 258
58d100bf 259 ac_cv_openssldir=$ssldir
260])
261
262if test ! -z "$ac_cv_openssldir" -a ! "x$ac_cv_openssldir" = "x(system)" ; then
263 AC_DEFINE(HAVE_OPENSSL)
264 dnl Need to recover ssldir - test above runs in subshell
265 ssldir=$ac_cv_openssldir
cb0b7ea4 266 CFLAGS="$saved_CFLAGS -I$ssldir/include"
267 LDFLAGS="$saved_LDFLAGS -L$ssldir/lib -L$ssldir"
268 if test ! -z "$need_dash_r" ; then
269 LDFLAGS="$LDFLAGS -R$ssldir/lib -R$ssldir"
a0391976 270 fi
bd499f9e 271 if test ! -z "$blibpath" ; then
272 blibpath="$blibpath:$ssldir:$ssldir/lib"
273 fi
a0391976 274fi
cb0b7ea4 275if test -z "$WANTS_RSAREF" ; then
276 LIBS="$saved_LIBS -lcrypto"
277else
278 LIBS="$saved_LIBS -lcrypto -lRSAglue -lrsaref"
bcf36c78 279fi
58d100bf 280
a0391976 281
282# Checks for data types
976f7e19 283AC_CHECK_SIZEOF(char, 1)
2b942fe0 284AC_CHECK_SIZEOF(short int, 2)
285AC_CHECK_SIZEOF(int, 4)
286AC_CHECK_SIZEOF(long int, 4)
287AC_CHECK_SIZEOF(long long int, 8)
288
a0391976 289# More checks for data types
58d100bf 290AC_CACHE_CHECK([for intXX_t types], ac_cv_have_intxx_t, [
291 AC_TRY_COMPILE(
292 [ #include <sys/types.h> ],
293 [ int8_t a; int16_t b; int32_t c; a = b = c = 1;],
294 [ ac_cv_have_intxx_t="yes" ],
295 [ ac_cv_have_intxx_t="no" ]
296 )
297])
298if test "x$ac_cv_have_intxx_t" = "xyes" ; then
299 AC_DEFINE(HAVE_INTXX_T)
300 have_intxx_t=1
301fi
302
303AC_CACHE_CHECK([for u_intXX_t types], ac_cv_have_u_intxx_t, [
304 AC_TRY_COMPILE(
305 [ #include <sys/types.h> ],
306 [ u_int8_t a; u_int16_t b; u_int32_t c; a = b = c = 1;],
307 [ ac_cv_have_u_intxx_t="yes" ],
308 [ ac_cv_have_u_intxx_t="no" ]
309 )
310])
311if test "x$ac_cv_have_u_intxx_t" = "xyes" ; then
312 AC_DEFINE(HAVE_U_INTXX_T)
313 have_u_intxx_t=1
314fi
2b942fe0 315
2b942fe0 316
20af321f 317if test -z "$have_u_intxx_t" -o -z "$have_intxx_t" -a \
5cdfe03f 318 "x$ac_cv_header_sys_bitypes_h" = "xyes"
319then
320 AC_MSG_CHECKING([for intXX_t and u_intXX_t types in sys/bitypes.h])
321 AC_TRY_COMPILE(
58d100bf 322 [
323#include <sys/bitypes.h>
324 ],
5cdfe03f 325 [
837c30b8 326 int8_t a; int16_t b; int32_t c;
327 u_int8_t e; u_int16_t f; u_int32_t g;
328 a = b = c = e = f = g = 1;
5cdfe03f 329 ],
330 [
331 AC_DEFINE(HAVE_U_INTXX_T)
332 AC_DEFINE(HAVE_INTXX_T)
333 AC_MSG_RESULT(yes)
334 ],
335 [AC_MSG_RESULT(no)]
336 )
337fi
338
474b5fef 339if test -z "$have_u_intxx_t" ; then
58d100bf 340 AC_CACHE_CHECK([for uintXX_t types], ac_cv_have_uintxx_t, [
341 AC_TRY_COMPILE(
342 [
343#include <sys/types.h>
344 ],
345 [ uint8_t a; uint16_t b; uint32_t c; a = b = c = 1; ],
346 [ ac_cv_have_uintxx_t="yes" ],
347 [ ac_cv_have_uintxx_t="no" ]
348 )
349 ])
350 if test "x$ac_cv_have_uintxx_t" = "xyes" ; then
351 AC_DEFINE(HAVE_UINTXX_T)
352 fi
353fi
354
355AC_CACHE_CHECK([for socklen_t], ac_cv_have_socklen_t, [
474b5fef 356 AC_TRY_COMPILE(
474b5fef 357 [
58d100bf 358#include <sys/types.h>
359#include <sys/socket.h>
474b5fef 360 ],
58d100bf 361 [socklen_t foo; foo = 1235;],
362 [ ac_cv_have_socklen_t="yes" ],
363 [ ac_cv_have_socklen_t="no" ]
364 )
365])
366if test "x$ac_cv_have_socklen_t" = "xyes" ; then
367 AC_DEFINE(HAVE_SOCKLEN_T)
474b5fef 368fi
2b942fe0 369
58d100bf 370AC_CACHE_CHECK([for size_t], ac_cv_have_size_t, [
371 AC_TRY_COMPILE(
372 [
18ba2aab 373#include <sys/types.h>
58d100bf 374 ],
375 [ size_t foo; foo = 1235; ],
376 [ ac_cv_have_size_t="yes" ],
377 [ ac_cv_have_size_t="no" ]
378 )
379])
380if test "x$ac_cv_have_size_t" = "xyes" ; then
381 AC_DEFINE(HAVE_SIZE_T)
382fi
ea1970a3 383
e3a93db0 384
58d100bf 385AC_CACHE_CHECK([for struct sockaddr_storage], ac_cv_have_struct_sockaddr_storage, [
386 AC_TRY_COMPILE(
387 [
18ba2aab 388#include <sys/types.h>
389#include <sys/socket.h>
58d100bf 390 ],
391 [ struct sockaddr_storage s; ],
392 [ ac_cv_have_struct_sockaddr_storage="yes" ],
393 [ ac_cv_have_struct_sockaddr_storage="no" ]
394 )
395])
396if test "x$ac_cv_have_struct_sockaddr_storage" = "xyes" ; then
397 AC_DEFINE(HAVE_STRUCT_SOCKADDR_STORAGE)
398fi
48e671d5 399
58d100bf 400AC_CACHE_CHECK([for struct sockaddr_in6], ac_cv_have_struct_sockaddr_in6, [
401 AC_TRY_COMPILE(
402 [
403#include <netinet/in.h>
404 ],
405 [ struct sockaddr_in6 s; s.sin6_family = 0; ],
406 [ ac_cv_have_struct_sockaddr_in6="yes" ],
407 [ ac_cv_have_struct_sockaddr_in6="no" ]
408 )
409])
410if test "x$ac_cv_have_struct_sockaddr_in6" = "xyes" ; then
411 AC_DEFINE(HAVE_STRUCT_SOCKADDR_IN6)
412fi
48e671d5 413
58d100bf 414AC_CACHE_CHECK([for struct in6_addr], ac_cv_have_struct_in6_addr, [
415 AC_TRY_COMPILE(
416 [
417#include <netinet/in.h>
418 ],
419 [ struct in6_addr s; s.s6_addr[0] = 0; ],
420 [ ac_cv_have_struct_in6_addr="yes" ],
421 [ ac_cv_have_struct_in6_addr="no" ]
422 )
423])
424if test "x$ac_cv_have_struct_in6_addr" = "xyes" ; then
425 AC_DEFINE(HAVE_STRUCT_IN6_ADDR)
426fi
48e671d5 427
58d100bf 428AC_CACHE_CHECK([for struct addrinfo], ac_cv_have_struct_addrinfo, [
429 AC_TRY_COMPILE(
430 [
18ba2aab 431#include <sys/types.h>
432#include <sys/socket.h>
433#include <netdb.h>
58d100bf 434 ],
435 [ struct addrinfo s; s.ai_flags = AI_PASSIVE; ],
436 [ ac_cv_have_struct_addrinfo="yes" ],
437 [ ac_cv_have_struct_addrinfo="no" ]
438 )
439])
440if test "x$ac_cv_have_struct_addrinfo" = "xyes" ; then
441 AC_DEFINE(HAVE_STRUCT_ADDRINFO)
442fi
443
48e671d5 444
a0391976 445# Checks for structure members
48e671d5 446
58d100bf 447OSSH_CHECK_HEADER_FOR_FIELD(ut_host, utmp.h, HAVE_HOST_IN_UTMP)
448OSSH_CHECK_HEADER_FOR_FIELD(ut_host, utmpx.h, HAVE_HOST_IN_UTMPX)
449OSSH_CHECK_HEADER_FOR_FIELD(syslen, utmpx.h, HAVE_SYSLEN_IN_UTMPX)
450OSSH_CHECK_HEADER_FOR_FIELD(ut_pid, utmp.h, HAVE_PID_IN_UTMP)
451OSSH_CHECK_HEADER_FOR_FIELD(ut_type, utmp.h, HAVE_TYPE_IN_UTMP)
452OSSH_CHECK_HEADER_FOR_FIELD(ut_tv, utmp.h, HAVE_TV_IN_UTMP)
453OSSH_CHECK_HEADER_FOR_FIELD(ut_id, utmp.h, HAVE_ID_IN_UTMP)
454OSSH_CHECK_HEADER_FOR_FIELD(ut_addr, utmp.h, HAVE_ADDR_IN_UTMP)
455OSSH_CHECK_HEADER_FOR_FIELD(ut_addr, utmpx.h, HAVE_ADDR_IN_UTMPX)
456OSSH_CHECK_HEADER_FOR_FIELD(ut_addr_v6, utmp.h, HAVE_ADDR_V6_IN_UTMP)
457OSSH_CHECK_HEADER_FOR_FIELD(ut_addr_v6, utmpx.h, HAVE_ADDR_V6_IN_UTMPX)
458
459
460AC_CACHE_CHECK([for ss_family field in struct sockaddr_storage],
461 ac_cv_have_ss_family_in_struct_ss, [
462 AC_TRY_COMPILE(
463 [
18ba2aab 464#include <sys/types.h>
465#include <sys/socket.h>
58d100bf 466 ],
467 [ struct sockaddr_storage s; s.ss_family = 1; ],
468 [ ac_cv_have_ss_family_in_struct_ss="yes" ],
469 [ ac_cv_have_ss_family_in_struct_ss="no" ],
470 )
471])
472if test "x$ac_cv_have_ss_family_in_struct_ss" = "xyes" ; then
473 AC_DEFINE(HAVE_SS_FAMILY_IN_SS)
474fi
475
476
477AC_CACHE_CHECK([for __ss_family field in struct sockaddr_storage],
478 ac_cv_have___ss_family_in_struct_ss, [
479 AC_TRY_COMPILE(
480 [
18ba2aab 481#include <sys/types.h>
482#include <sys/socket.h>
58d100bf 483 ],
484 [ struct sockaddr_storage s; s.__ss_family = 1; ],
485 [ ac_cv_have___ss_family_in_struct_ss="yes" ],
486 [ ac_cv_have___ss_family_in_struct_ss="no" ]
487 )
488])
489if test "x$ac_cv_have___ss_family_in_struct_ss" = "xyes" ; then
490 AC_DEFINE(HAVE___SS_FAMILY_IN_SS)
491fi
492
493
494AC_CACHE_CHECK([if libc defines __progname], ac_cv_libc_defines___progname, [
495 AC_TRY_LINK([],
496 [ extern char *__progname; printf("%s", __progname); ],
497 [ ac_cv_libc_defines___progname="yes" ],
498 [ ac_cv_libc_defines___progname="no" ]
499 )
500])
501if test "x$ac_cv_libc_defines___progname" = "xyes" ; then
502 AC_DEFINE(HAVE___PROGNAME)
503fi
8946db53 504
a0391976 505
506# Looking for programs, paths and files
507AC_ARG_WITH(rsh,
508 [ --with-rsh=PATH Specify path to remote shell program ],
509 [
bcf36c78 510 if test "x$withval" != "$no" ; then
a0391976 511 AC_DEFINE_UNQUOTED(RSH_PATH, "$withval")
512 fi
513 ],
514 [
515 AC_PATH_PROG(rsh_path, rsh)
516 ]
517)
518
519AC_ARG_WITH(xauth,
520 [ --with-xauth=PATH Specify path to xauth program ],
521 [
522 if test "x$withval" != "$xno" ; then
523 AC_DEFINE_UNQUOTED(XAUTH_PATH, "$withval")
524 fi
525 ],
526 [
527 AC_PATH_PROG(xauth_path, xauth)
528 if test ! -z "$xauth_path" -a -x "/usr/openwin/bin/xauth" ; then
529 xauth_path="/usr/openwin/bin/xauth"
530 fi
531 ]
532)
533
534if test ! -z "$xauth_path" ; then
535 AC_DEFINE_UNQUOTED(XAUTH_PATH, "$xauth_path")
536fi
537if test ! -z "$rsh_path" ; then
538 AC_DEFINE_UNQUOTED(RSH_PATH, "$rsh_path")
539fi
540
541# Check for mail directory (last resort if we cannot get it from headers)
542if test ! -z "$MAIL" ; then
543 maildir=`dirname $MAIL`
544 AC_DEFINE_UNQUOTED(MAIL_DIRECTORY, "$maildir")
545fi
546
547# Look for lastlog location
a7effaac 548AC_ARG_WITH(lastlog,
cb807f40 549 [ --with-lastlog=FILE Location of lastlog file],
a7effaac 550 [
551 if test "x$withval" = "xno" ; then
552 AC_DEFINE(DISABLE_LASTLOG)
553 else
554 AC_DEFINE_UNQUOTED(LASTLOG_LOCATION, "$withval")
555 fi
556 ],
557 [
558 AC_MSG_CHECKING([location of lastlog file])
f9507c24 559 for lastlog in /var/log/lastlog /var/adm/lastlog /usr/adm/lastlog /etc/security/lastlog ; do
a7effaac 560 if test -f $lastlog ; then
561 gotlastlog="file"
562 break
563 fi
564 if test -d $lastlog ; then
565 gotlastlog="dir"
566 break
567 fi
568 done
569 if test -z "$gotlastlog" ; then
d94aa2ae 570 AC_MSG_RESULT(not found)
a7effaac 571 nolastlog=1
572 else
573 if test "x$gotlastlog" = "xdir" ; then
d94aa2ae 574 AC_MSG_RESULT(${lastlog}/)
a7effaac 575 AC_DEFINE(LASTLOG_IS_DIR)
d94aa2ae 576 else
577 AC_MSG_RESULT($lastlog)
578 AC_DEFINE_UNQUOTED(LASTLOG_LOCATION, "$lastlog")
a7effaac 579 fi
a7effaac 580 fi
581 ]
582)
583
584if test ! -z "$nolastlog" ; then
585 AC_MSG_WARN([*** Disabling lastlog support *** ])
586 AC_DEFINE(DISABLE_LASTLOG)
587fi
f601d847 588
a0391976 589if test -z "$no_dev_ptmx" ; then
3276571c 590 AC_CHECK_FILE("/dev/ptmx",
591 [
592 AC_DEFINE_UNQUOTED(HAVE_DEV_PTMX)
593 have_dev_ptmx=1
594 ]
595 )
596fi
597AC_CHECK_FILE("/dev/ptc",
598 [
599 AC_DEFINE_UNQUOTED(HAVE_DEV_PTS_AND_PTC)
600 have_dev_ptc=1
601 ]
602)
603
a0391976 604# Options from here on. Some of these are preset by platform above
605
a0391976 606# Check for user-specified random device, otherwise check /dev/urandom
607AC_ARG_WITH(random,
608 [ --with-random=FILE read randomness from FILE (default=/dev/urandom)],
609 [
bfc9a610 610 if test "x$withval" != "xno" ; then
611 RANDOM_POOL="$withval";
612 AC_DEFINE_UNQUOTED(RANDOM_POOL, "$RANDOM_POOL")
613 fi
a0391976 614 ],
615 [
616 # Check for random device
617 AC_CHECK_FILE("/dev/urandom",
618 [
619 RANDOM_POOL="/dev/urandom";
620 AC_SUBST(RANDOM_POOL)
621 AC_DEFINE_UNQUOTED(RANDOM_POOL, "$RANDOM_POOL")
622 ]
623 )
624 ]
625)
626
627# Check for EGD pool file
628AC_ARG_WITH(egd-pool,
629 [ --with-egd-pool=FILE read randomness from EGD pool FILE (default none)],
630 [
bfc9a610 631 if test "x$withval" != "xno" ; then
632 EGD_SOCKET="$withval";
633 AC_DEFINE_UNQUOTED(EGD_SOCKET, "$EGD_SOCKET")
634 fi
a0391976 635 ]
636)
637
d3083fbd 638# detect pathnames for entropy gathering commands, if we need them
639INSTALL_SSH_PRNG_CMDS=""
640rm -f prng_commands
9d98aaf6 641if test -z "$RANDOM_POOL" -a -z "$EGD_SOCKET" ; then
642 # Use these commands to collect entropy
58d100bf 643 OSSH_PATH_ENTROPY_PROG(PROG_LS, ls)
644 OSSH_PATH_ENTROPY_PROG(PROG_NETSTAT, netstat)
645 OSSH_PATH_ENTROPY_PROG(PROG_ARP, arp)
646 OSSH_PATH_ENTROPY_PROG(PROG_IFCONFIG, ifconfig)
647 OSSH_PATH_ENTROPY_PROG(PROG_PS, ps)
648 OSSH_PATH_ENTROPY_PROG(PROG_W, w)
649 OSSH_PATH_ENTROPY_PROG(PROG_WHO, who)
650 OSSH_PATH_ENTROPY_PROG(PROG_LAST, last)
651 OSSH_PATH_ENTROPY_PROG(PROG_LASTLOG, lastlog)
652 OSSH_PATH_ENTROPY_PROG(PROG_DF, df)
653 OSSH_PATH_ENTROPY_PROG(PROG_VMSTAT, vmstat)
654 OSSH_PATH_ENTROPY_PROG(PROG_UPTIME, uptime)
655 OSSH_PATH_ENTROPY_PROG(PROG_IPCS, ipcs)
656 OSSH_PATH_ENTROPY_PROG(PROG_TAIL, tail)
657 OSSH_PATH_ENTROPY_PROG(PROG_LS, ls)
d3083fbd 658
659 INSTALL_SSH_PRNG_CMDS="yes"
9d98aaf6 660fi
d3083fbd 661AC_SUBST(INSTALL_SSH_PRNG_CMDS)
662
9d98aaf6 663
c54a6257 664AC_ARG_WITH(catman,
665 [ --with-catman=man|cat Install preformatted manpages[no]],
666 [
667 MANTYPE='$(CATMAN)'
668 if test x"$withval" != x"yes" ; then
669 mansubdir=$withval
670 else
671 mansubdir=cat
672 fi
673 ], [
674 if test -z "$MANTYPE" ; then
675 MANTYPE='$(TROFFMAN)'
676 mansubdir=man
677 fi
678 ]
679)
680AC_SUBST(MANTYPE)
681AC_SUBST(mansubdir)
0bc5b6fb 682
a0391976 683# Check whether user wants Kerberos support
91b8065d 684AC_ARG_WITH(kerberos4,
dfb95100 685 [ --with-kerberos4=PATH Enable Kerberos 4 support],
91b8065d 686 [
bcf36c78 687 if test "x$withval" != "xno" ; then
dfb95100 688
689 if test "x$withval" != "$xyes" ; then
690 CFLAGS="$CFLAGS -I${withval}/include"
691 LDFLAGS="$LDFLAGS -L${withval}/lib"
bd499f9e 692 if test ! -z "$need_dash_r" ; then
693 LDFLAGS="$LDFLAGS -R${withval}/lib"
694 fi
695 if test ! -z "$blibpath" ; then
696 blibpath="$blibpath:${withval}/lib"
697 fi
dfb95100 698 else
699 if test -d /usr/include/kerberosIV ; then
700 CFLAGS="$CFLAGS -I/usr/include/kerberosIV"
701 fi
702 fi
703
704 AC_CHECK_HEADERS(krb.h)
705 AC_CHECK_LIB(krb, main)
706 if test "$ac_cv_header_krb_h" != yes; then
707 AC_MSG_WARN([Cannot find krb.h, build may fail])
708 fi
709 if test "$ac_cv_lib_krb_main" != yes; then
710 AC_MSG_WARN([Cannot find libkrb, build may fail])
711 fi
712
587120ad 713 KLIBS="-lkrb -ldes"
dfb95100 714 AC_CHECK_LIB(resolv, dn_expand, , )
715 KRB4=yes
0bc5b6fb 716 AC_DEFINE(KRB4)
0bc5b6fb 717 fi
91b8065d 718 ]
719)
720
a0391976 721# Check whether user wants AFS support
2b942fe0 722AC_ARG_WITH(afs,
dfb95100 723 [ --with-afs=PATH Enable AFS support],
91b8065d 724 [
bcf36c78 725 if test "x$withval" != "xno" ; then
dfb95100 726
727 if test "x$withval" != "$xyes" ; then
728 CFLAGS="$CFLAGS -I${withval}/include"
729 LFLAGS="$LFLAGS -L${withval}/lib"
730 fi
731
732 if test -z "$KRB4" ; then
733 AC_MSG_WARN([AFS requires Kerberos IV support, build may fail])
734 fi
735
0bc5b6fb 736 LIBS="$LIBS -lkafs"
dfb95100 737 if test ! -z "$AFS_LIBS" ; then
738 LIBS="$LIBS $AFS_LIBS"
739 fi
740 AC_DEFINE(AFS)
0bc5b6fb 741 fi
91b8065d 742 ]
743)
587120ad 744LIBS="$LIBS $KLIBS"
91b8065d 745
a0391976 746# Check whether user wants S/Key support
91b8065d 747AC_ARG_WITH(skey,
748 [ --with-skey Enable S/Key support],
749 [
bcf36c78 750 if test "x$withval" != "xno" ; then
0bc5b6fb 751 AC_DEFINE(SKEY)
752 LIBS="$LIBS -lskey"
753 fi
91b8065d 754 ]
755)
756
a0391976 757# Check whether user wants TCP wrappers support
2ddcfdf3 758AC_ARG_WITH(tcp-wrappers,
91b8065d 759 [ --with-tcp-wrappers Enable tcpwrappers support],
760 [
bcf36c78 761 if test "x$withval" != "xno" ; then
9fc7867e 762 saved_LIBS="$LIBS"
dfb95100 763 LIBS="$LIBS -lwrap"
9fc7867e 764 AC_MSG_CHECKING(for libwrap)
765 AC_TRY_LINK(
766 [
18ba2aab 767#include <tcpd.h>
9fc7867e 768 int deny_severity = 0, allow_severity = 0;
769 ],
770 [hosts_access(0);],
771 [
772 AC_MSG_RESULT(yes)
773 AC_DEFINE(LIBWRAP)
774 ],
775 [
776 AC_MSG_RESULT(no)
777 AC_MSG_WARN([*** libwrap missing - tcpwrapper support disabled ***])
778 LIBS="$saved_LIBS"
779 ]
780 )
0bc5b6fb 781 fi
91b8065d 782 ]
783)
784
a0391976 785# Check whether to enable MD5 passwords
2ddcfdf3 786AC_ARG_WITH(md5-passwords,
caf3bc51 787 [ --with-md5-passwords Enable use of MD5 passwords],
0bc5b6fb 788 [
bcf36c78 789 if test "x$withval" != "xno" ; then
0bc5b6fb 790 AC_DEFINE(HAVE_MD5_PASSWORDS)
791 fi
792 ]
caf3bc51 793)
794
a0391976 795# Check whether to enable utmpx support
92f90c57 796AC_ARG_WITH(utmpx,
797 [ --with-utmpx Enable utmpx support],
a7effaac 798 [
799 if test "x$withval" != "xno" ; then
800 AC_DEFINE(USE_UTMPX)
801 fi
802 ]
92f90c57 803)
804
a0391976 805# Whether to disable shadow password support
a7effaac 806AC_ARG_WITH(shadow,
807 [ --without-shadow Disable shadow password support],
808 [
809 if test "x$withval" = "xno" ; then
810 AC_DEFINE(DISABLE_SHADOW)
811 fi
812 ]
813)
814
a0391976 815# Use ip address instead of hostname in $DISPLAY
a7effaac 816AC_ARG_WITH(ipaddr-display,
817 [ --with-ipaddr-display Use ip address instead of hostname in \$DISPLAY],
818 [
5957fd29 819 if test "x$withval" = "xno" ; then
a7effaac 820 AC_DEFINE(IPADDR_IN_DISPLAY)
821 fi
822 ]
823)
824
a0391976 825# Whether to mess with the default path
c43d69a9 826AC_ARG_WITH(default-path,
cb807f40 827 [ --with-default-path=PATH Specify default \$PATH environment for server],
828 [
829 if test "x$withval" != "xno" ; then
c73a0cb5 830 AC_DEFINE_UNQUOTED(USER_PATH, "$withval")
cb807f40 831 fi
832 ]
833)
834
a0391976 835# Whether to force IPv4 by default (needed on broken glibc Linux)
59e76f33 836AC_ARG_WITH(ipv4-default,
837 [ --with-ipv4-default Use IPv4 by connections unless '-6' specified],
838 [
839 if test "x$withval" != "xno" ; then
840 AC_DEFINE(IPV4_DEFAULT)
841 fi
842 ]
843)
844
58d100bf 845AC_MSG_CHECKING([if we need to convert IPv4 in IPv6-mapped addresses])
80faa19f 846AC_ARG_WITH(4in6,
847 [ --with-4in6 Check for and convert IPv4 in IPv6 mapped addresses],
848 [
849 if test "x$withval" != "xno" ; then
850 AC_MSG_RESULT(yes)
851 AC_DEFINE(IPV4_IN_IPV6)
852 else
853 AC_MSG_RESULT(no)
854 fi
855 ],[
856 if test "x$inet6_default_4in6" = "xyes"; then
857 AC_MSG_RESULT([yes (default)])
858 AC_DEFINE(IPV4_IN_IPV6)
859 else
860 AC_MSG_RESULT([no (default)])
861 fi
862 ]
863)
864
a0391976 865# Where to place sshd.pid
19d9ac2a 866piddir=/var/run
47e45e44 867AC_ARG_WITH(pid-dir,
868 [ --with-pid-dir=PATH Specify location of ssh.pid file],
869 [
870 if test "x$withval" != "xno" ; then
19d9ac2a 871 piddir=$withval
47e45e44 872 fi
873 ]
874)
b7a87eea 875
a63a7f37 876AC_DEFINE_UNQUOTED(PIDDIR, "$piddir")
19d9ac2a 877AC_SUBST(piddir)
47e45e44 878
b7a87eea 879
880# Change default command timeout for builtin PRNG
881entropy_timeout=100
882AC_ARG_WITH(entropy-timeout,
883 [ --with-entropy-timeout Specify entropy gathering command timeout (msec)],
884 [
885 if test "x$withval" != "xno" ; then
886 entropy_timeout=$withval
887 fi
888 ]
889)
890AC_DEFINE_UNQUOTED(ENTROPY_TIMEOUT_MSEC, $entropy_timeout)
891
892
bd499f9e 893if test ! -z "$blibpath" ; then
894 LDFLAGS="$LDFLAGS -blibpath:$blibpath"
895 AC_MSG_WARN([Please check and edit -blibpath in LDFLAGS in Makefile])
896fi
897
d3083fbd 898AC_OUTPUT(Makefile ssh_prng_cmds)
899
900
This page took 0.217112 seconds and 5 git commands to generate.