fileserver])],
,
[enable_namei_fileserver="default"])
-AC_ARG_ENABLE([cache-bypass],
- [AS_HELP_STRING([--enable-cache-bypass],
- [enable client support for cache bypass])],
- ,
- [enable_cache_bypass="no"])
AC_ARG_ENABLE([supergroups],
[AS_HELP_STRING([--enable-supergroups],
[enable support for nested pts groups])],
,
[enable_supergroups="no"])
-AC_ARG_ENABLE([fast-restart],
- [AS_HELP_STRING([--enable-fast-restart],
- [enable fast startup of file server without salvaging])],
- ,
- [enable_fast_restart="no"])
AC_ARG_ENABLE([bitmap-later],
[AS_HELP_STRING([--enable-bitmap-later],
[enable fast startup of file server by not reading bitmap till
needed])],
,
[enable_bitmap_later="no"])
-AC_ARG_ENABLE([demand-attach-fs],
- [AS_HELP_STRING([--enable-demand-attach-fs],
- [enable Demand Attach Fileserver (please see documentation)])],
- ,
- [enable_demand_attach_fs="no"])
-AC_ARG_ENABLE([disconnected],
- [AS_HELP_STRING([--enable-disconnected],
- [enable disconnected support in cache manager (experimental)])],
- ,
- [enable_disconnected="no"])
AC_ARG_ENABLE([unix-sockets],
- [AS_HELP_STRING([--enable-unix-sockets],
- [enable use of unix domain sockets for fssync])],
+ [AS_HELP_STRING([--disable-unix-sockets],
+ [disable use of unix domain sockets for fssync (defaults to enabled)])],
,
[enable_unix_sockets="yes"])
-AC_ARG_ENABLE([icmp-pmtu-discovery],
- [AS_HELP_STRING([--enable-icmp-pmtu-discovery],
- [enable path MTU discovery by decoding ICMP unreachable replies])],
- ,
- [enable_icmp_pmtu_discovery="no"])
AC_ARG_ENABLE([tivoli-tsm],
[AS_HELP_STRING([--enable-tivoli-tsm],
[enable use of the Tivoli TSM API libraries for butc support])],
[enable_pthreaded_ubik="no"])
dnl Kernel module build options.
-AC_ARG_WITH([dux-kernel-headers],
- [AS_HELP_STRING([--with-dux-kernel-headers=path],
- [use the kernel headers found at path (optional, defaults to first
- match in /usr/sys)])])
AC_ARG_WITH([linux-kernel-headers],
[AS_HELP_STRING([--with-linux-kernel-headers=path],
[use the kernel headers found at path (optional, defaults to
,
[enable_optimize_pam="yes"])
AC_ARG_ENABLE([linux-syscall-probing],
- [AS_HELP_STRING([--disable-linux-syscall-probing],
- [disabling Linux syscall probing (defaults to enabled)])],
+ [AS_HELP_STRING([--enable-linux-syscall-probing],
+ [enable Linux syscall probing (defaults to autodetect)])],
,
- [AC_DEFINE(ENABLE_LINUX_SYSCALL_PROBING, 1,
- [define to enable syscall table probes])])
+ [enable_linux_syscall_probing="maybe"])
AC_ARG_WITH([xslt-processor],
AC_PROG_RANLIB
AC_PROG_YACC
AM_PROG_LEX
+dnl if we are flex, be lex-compatible
+OPENAFS_LEX_IS_FLEX([AC_SUBST([LEX], ["$LEX -l"])])
+OPENAFS_FORCE_ABS_INSTALL
OPENAFS_CHECK_BIGENDIAN
OPENAFS_PRINTF_TAKES_Z_LEN
MKAFS_OSTYPE=AIX
AC_MSG_RESULT(rs_aix)
;;
- *-osf*)
- MKAFS_OSTYPE=DUX
- AC_MSG_RESULT(alpha_dux)
+ arm-*-darwin*)
+ MKAFS_OSTYPE=DARWIN
+ AC_MSG_RESULT(arm_darwin)
;;
powerpc-*-darwin*)
MKAFS_OSTYPE=DARWIN
MKAFS_OSTYPE=DARWIN
AC_MSG_RESULT(x86_darwin)
;;
+ x86_64-*-darwin*)
+ MKAFS_OSTYPE=DARWIN
+ AC_MSG_RESULT(x86_darwin)
+ ;;
i386-*-freebsd*)
MKAFS_OSTYPE=FBSD
AC_MSG_RESULT(i386_fbsd)
MKAFS_OSTYPE=OBSD
AC_MSG_RESULT(amd64_obsd)
;;
- i386-openbsd*)
+ i386-*-openbsd*)
MKAFS_OSTYPE=OBSD
AC_MSG_RESULT(i386_obsd)
;;
vm=${v#*.}
AFS_SYSNAME="amd64_fbsd_${vM}${vm}"
;;
- i386-*-dragonfly2.2*)
- AFS_SYSNAME="i386_dfbsd_23"
- ;;
- i386-*-dragonfly2.3*)
- AFS_SYSNAME="i386_dfbsd_23"
- ;;
- i?86-*-netbsd*1.5*)
- AFS_SYSNAME="i386_nbsd15"
- ;;
- alpha-*-netbsd*1.5*)
- AFS_SYSNAME="alpha_nbsd15"
+ i386-*-dragonfly?.*)
+ v=${host#*dragonfly}
+ vM=${v%.*}
+ vm=${v#*.}
+ AFS_SYSNAME="i386_dfbsd_${vM}${vm}"
;;
i?86-*-netbsd*1.6[[M-Z]]*)
AFS_SYSNAME="i386_nbsd20"
powerpc-*-netbsd*1.6[[M-Z]]*)
AFS_SYSNAME="ppc_nbsd20"
;;
- i?86-*-netbsd*2.0*)
- AFS_SYSNAME="i386_nbsd20"
- ;;
- amd64-*-netbsd*2.0*)
- AFS_SYSNAME="amd64_nbsd20"
- ;;
- x86_64-*-netbsd*3.[[0-8]]*)
-# XXX AFS_PARAM_COMMON handled separately, redundant?
- AFS_PARAM_COMMON=param.nbsd30.h
- AFS_SYSNAME="amd64_nbsd30"
- ;;
- x86_64-*-netbsd*4.[[0-8]]*)
-# XXX AFS_PARAM_COMMON handled separately, redundant?
- AFS_PARAM_COMMON=param.nbsd40.h
- AFS_SYSNAME="amd64_nbsd40"
- ;;
- powerpc-*-netbsd*2.0*)
- AFS_SYSNAME="ppc_nbsd20"
- ;;
- i?86-*-netbsd*1.6*)
- AFS_SYSNAME="i386_nbsd16"
- ;;
- alpha-*-netbsd*1.6*)
- AFS_SYSNAME="alpha_nbsd16"
- ;;
- powerpc-*-netbsd*1.6*)
- AFS_SYSNAME="ppc_nbsd16"
- ;;
- i?86-*-netbsd*2.1*)
- AFS_SYSNAME="i386_nbsd21"
- ;;
- i?86-*-netbsd*2.99*)
- AFS_SYSNAME="i386_nbsd30"
- ;;
- i?86-*-netbsd*3.[[0-8]]*)
- AFS_SYSNAME="i386_nbsd30"
- ;;
- i?86-*-netbsd*3.99*)
- AFS_SYSNAME="i386_nbsd30"
- ;;
- i?86-*-netbsd*4.[[0-8]]*)
- AFS_SYSNAME="i386_nbsd40"
- ;;
- i?86-*-netbsd*4.99*)
- AFS_SYSNAME="i386_nbsd40"
+ *-*-netbsd*)
+ arch=${host%%-unknown*}
+ arch=$(echo $arch |sed -e 's/x86_64/amd64/g' \
+ -e 's/powerpc/ppc/g')
+ v=${host#*netbsd}
+ v=${v#*aout}
+ v=${v#*ecoff}
+ v=${v#*elf}
+ vM=${v%%.*}
+ vM=${vM%.*}
+ v=${v#*.}
+ vm=${v%%.*}
+ vm=${vm%.*}
+ vm=${vm%%[[_A-Z]]*}
+ if test $vm -eq 99 ; then
+ vM=$((vM+1))
+ fi
+ if test $vM -gt 1 ; then
+ vm=0
+ fi
+ AFS_SYSNAME="${arch}_nbsd${vM}${vm}"
;;
hppa*-hp-hpux11.0*)
AFS_SYSNAME="hp_ux110"
i?86-apple-darwin10.*)
AFS_SYSNAME="x86_darwin_100"
;;
+ x86_64-apple-darwin10.*)
+ AFS_SYSNAME="x86_darwin_100"
+ ;;
sparc-sun-solaris2.5*)
AFS_SYSNAME="sun4x_55"
enable_login="yes"
case $AFS_SYSNAME in
*_darwin*)
+ AC_CHECK_HEADERS(crt_externs.h)
DARWIN_PLIST=src/libafs/afs.${AFS_SYSNAME}.plist
DARWIN_INFOFILE=afs.${AFS_SYSNAME}.plist
;;
*_nbsd21) AFS_PARAM_COMMON=param.nbsd21.h ;;
*_nbsd30) AFS_PARAM_COMMON=param.nbsd30.h ;;
*_nbsd40) AFS_PARAM_COMMON=param.nbsd40.h ;;
+ *_nbsd50) AFS_PARAM_COMMON=param.nbsd50.h ;;
*_obsd31) AFS_PARAM_COMMON=param.obsd31.h ;;
*_obsd32) AFS_PARAM_COMMON=param.obsd32.h ;;
*_obsd33) AFS_PARAM_COMMON=param.obsd33.h ;;
*_obsd44) AFS_PARAM_COMMON=param.obsd44.h ;;
*_obsd45) AFS_PARAM_COMMON=param.obsd45.h ;;
*_obsd46) AFS_PARAM_COMMON=param.obsd46.h ;;
+ *_obsd47) AFS_PARAM_COMMON=param.obsd47.h ;;
+ *_obsd48) AFS_PARAM_COMMON=param.obsd48.h ;;
*_linux22) AFS_PARAM_COMMON=param.linux22.h ;;
*_linux24) AFS_PARAM_COMMON=param.linux24.h ;;
*_linux26) AFS_PARAM_COMMON=param.linux26.h ;;
+# Linux alpha adds an extra underscore for no good reason.
+ *_linux_22) AFS_PARAM_COMMON=param.linux22.h ;;
+ *_linux_24) AFS_PARAM_COMMON=param.linux24.h ;;
+ *_linux_26) AFS_PARAM_COMMON=param.linux26.h ;;
esac
case $AFS_SYSNAME in *_linux* | *_umlinux*)
[write_begin], [fs.h])
AC_CHECK_LINUX_STRUCT([backing_dev_info], [name],
[backing-dev.h])
+ AC_CHECK_LINUX_STRUCT([ctl_table], [ctl_name], [sysctl.h])
AC_CHECK_LINUX_STRUCT([inode], [i_alloc_sem], [fs.h])
AC_CHECK_LINUX_STRUCT([inode], [i_blkbits], [fs.h])
AC_CHECK_LINUX_STRUCT([inode], [i_blksize], [fs.h])
AC_CHECK_LINUX_STRUCT([inode], [i_security], [fs.h])
AC_CHECK_LINUX_STRUCT([file_operations], [flock], [fs.h])
AC_CHECK_LINUX_STRUCT([file_operations], [sendfile], [fs.h])
+ AC_CHECK_LINUX_STRUCT([file_system_type], [mount], [fs.h])
AC_CHECK_LINUX_STRUCT([nameidata], [path], [namei.h])
AC_CHECK_LINUX_STRUCT([proc_dir_entry], [owner], [proc_fs.h])
AC_CHECK_LINUX_STRUCT([super_block], [s_bdi], [fs.h])
+ AC_CHECK_LINUX_STRUCT([super_block], [s_d_op], [fs.h])
AC_CHECK_LINUX_STRUCT([super_operations], [alloc_inode],
[fs.h])
+ AC_CHECK_LINUX_STRUCT([super_operations], [evict_inode],
+ [fs.h])
AC_CHECK_LINUX_STRUCT([task_struct], [cred], [sched.h])
AC_CHECK_LINUX_STRUCT([task_struct], [exit_state], [sched.h])
AC_CHECK_LINUX_STRUCT([task_struct], [parent], [sched.h])
AC_CHECK_LINUX_FUNC([bdi_init],
[#include <linux/backing-dev.h>],
[bdi_init(NULL);])
- AC_CHECK_LINUX_FUNC([ctl_table], [ctl_name], [sysctl.h])
+ AC_CHECK_LINUX_FUNC([PageChecked],
+ [#include <linux/mm.h>
+#include <linux/page-flags.h>],
+ [struct page *_page;
+ int bchecked = PageChecked(_page);])
+ AC_CHECK_LINUX_FUNC([PageFsMisc],
+ [#include <linux/mm.h>
+#include <linux/page-flags.h>],
+ [struct page *_page;
+ int bchecked = PageFsMisc(_page);])
AC_CHECK_LINUX_FUNC([current_kernel_time],
[#include <linux/time.h>],
[struct timespec s;
s = current_kernel_time();])
AC_CHECK_LINUX_FUNC([d_alloc_anon],
- [#include <linux/dcache.h>],
+ [#include <linux/fs.h>],
[d_alloc_anon(NULL);])
AC_CHECK_LINUX_FUNC([do_sync_read],
[#include <linux/fs.h>],
AC_CHECK_LINUX_FUNC([i_size_read],
[#include <linux/fs.h>],
[i_size_read(NULL);])
- AC_CHECK_LINUX_FUNC([iget],
+ AC_CHECK_LINUX_FUNC([inode_setattr],
[#include <linux/fs.h>],
- [iget(NULL, NULL);])
+ [inode_setattr(NULL, NULL);])
AC_CHECK_LINUX_FUNC([kernel_setsockopt],
[#include <linux/net.h>],
[kernel_setsockopt(NULL, 0, 0, NULL, 0);])
AC_CHECK_LINUX_FUNC([svc_addr_in],
[#include <linux/sunrpc/svc.h>],
[svc_addr_in(NULL);])
- AC_CHECK_LINUX_FUNC([vfs_llseek],
- [#include <linux/fs.h>],
- [vfs_llseek(NULL, 0, 0);])
AC_CHECK_LINUX_FUNC([zero_user_segments],
[#include <linux/highmem.h>],
[zero_user_segments(NULL, 0, 0, 0, 0);])
dnl Consequences - things which get set as a result of the
dnl above tests
- AS_IF([test "x$ac_cv_linux_func_iget" = "xno"],
- [AC_DEFINE([LINUX_USE_FH], 1,
- [define to use linux file handles for cache files])])
AS_IF([test "x$ac_cv_linux_func_d_alloc_anon" = "xno"],
[AC_DEFINE([AFS_NONFSTRANS], 1,
[define to disable the nfs translator])])
LINUX_EXPORTS_PROC_ROOT_FS
LINUX_KMEM_CACHE_INIT
LINUX_HAVE_KMEM_CACHE_T
+ LINUX_KMEM_CACHE_CREATE_TAKES_DTOR
LINUX_KMEM_CACHE_CREATE_CTOR_TAKES_VOID
LINUX_D_PATH_TAKES_STRUCT_PATH
LINUX_NEW_EXPORT_OPS
LINUX_INODE_SETATTR_RETURN_TYPE
LINUX_IOP_I_CREATE_TAKES_NAMEIDATA
LINUX_IOP_I_LOOKUP_TAKES_NAMEIDATA
+ LINUX_IOP_I_PERMISSION_TAKES_FLAGS
LINUX_IOP_I_PERMISSION_TAKES_NAMEIDATA
LINUX_IOP_I_PUT_LINK_TAKES_COOKIE
LINUX_DOP_D_REVALIDATE_TAKES_NAMEIDATA
LINUX_FOP_F_FLUSH_TAKES_FL_OWNER_T
+ LINUX_FOP_F_FSYNC_TAKES_DENTRY
LINUX_AOP_WRITEBACK_CONTROL
LINUX_FS_STRUCT_FOP_HAS_SPLICE
LINUX_KERNEL_POSIX_LOCK_FILE_WAIT_ARG
LINUX_POSIX_TEST_LOCK_CONFLICT_ARG
LINUX_KERNEL_SOCK_CREATE
LINUX_EXPORTS_KEY_TYPE_KEYRING
- LINUX_KEYS_HAVE_SESSION_TO_PARENT
LINUX_NEED_RHCONFIG
LINUX_RECALC_SIGPENDING_ARG_TYPE
LINUX_EXPORTS_TASKLIST_LOCK
LINUX_KEY_ALLOC_NEEDS_CRED
LINUX_INIT_WORK_HAS_DATA
LINUX_REGISTER_SYSCTL_TABLE_NOFLAG
- LINUX_EXPORTS_INIT_MM
- LINUX_EXPORTS_SYS_CHDIR
- LINUX_EXPORTS_SYS_OPEN
+ LINUX_HAVE_DCACHE_LOCK
+ LINUX_D_COUNT_IS_INT
+
+ dnl If we are guaranteed that keyrings will work - that is
+ dnl a) The kernel has keyrings enabled
+ dnl b) The code is new enough to give us a key_type_keyring
+ dnl then we just disable syscall probing unless we've been
+ dnl told otherwise
+
+ AS_IF([test "$enable_linux_syscall_probing" = "maybe"],
+ [AS_IF([test "$ac_cv_linux_keyring_support" = "yes" -a "$ac_cv_linux_exports_key_type_keyring" = "yes"],
+ [enable_linux_syscall_probing="no"],
+ [enable_linux_syscall_probing="yes"])
+ ])
+
+ dnl Syscall probing needs a few tests of its own, and just
+ dnl won't work if the kernel doesn't export init_mm
+ AS_IF([test "$enable_linux_syscall_probing" = "yes"], [
+ LINUX_EXPORTS_INIT_MM
+ AS_IF([test "$ac_cv_linux_exports_init_mm" = "no"], [
+ AC_MSG_ERROR(
+ [Can't do syscall probing without exported init_mm])
+ ])
+ LINUX_EXPORTS_SYS_CHDIR
+ LINUX_EXPORTS_SYS_OPEN
+ AC_DEFINE(ENABLE_LINUX_SYSCALL_PROBING, 1,
+ [define to enable syscall table probes])
+ ])
dnl Packaging and SMP build
- if test "x$with_linux_kernel_packaging" = "xno" ; then
+ if test "x$with_linux_kernel_packaging" != "xyes" ; then
LINUX_WHICH_MODULES
else
AC_SUBST(MPS,'SP')
dnl Syscall probing
if test "x$ac_cv_linux_config_modversions" = "xno" -o $AFS_SYSKVERS -ge 26; then
- AC_MSG_WARN([Cannot determine sys_call_table status. assuming it isn't exported])
+ AS_IF([test "$enable_linux_syscall_probing" = "yes"], [
+ AC_MSG_WARN([Cannot determine sys_call_table status. assuming it isn't exported])
+ ])
ac_cv_linux_exports_sys_call_table=no
if test -f "$LINUX_KERNEL_PATH/include/asm/ia32_unistd.h"; then
ac_cv_linux_exports_ia32_sys_call_table=yes
fi
:
fi
+dnl Linux-only, but just enable always.
+ AC_DEFINE(AFS_CACHE_BYPASS, 1, [define to activate cache bypassing Unix client])
esac
-AC_CACHE_VAL(ac_cv_sockaddr_len,
-[
-AC_MSG_CHECKING([if struct sockaddr has sa_len field])
-AC_TRY_COMPILE( [#include <sys/types.h>
+AC_CACHE_CHECK([if compiler has __sync_add_and_fetch],
+ [ac_cv_sync_fetch_and_add],
+ [AC_TRY_LINK(, [int var; return __sync_add_and_fetch(&var, 1);],
+ [ac_cv_sync_fetch_and_add=yes],
+ [ac_cv_sync_fetch_and_add=no])
+])
+AS_IF([test "$ac_cv_sync_fetch_and_add" = "yes"],
+ [AC_DEFINE(HAVE_SYNC_FETCH_AND_ADD, 1,
+ [define if your C compiler has __sync_add_and_fetch])])
+
+AC_CACHE_CHECK([if struct sockaddr has sa_len field],
+ [ac_cv_sockaddr_len],
+ [AC_TRY_COMPILE( [#include <sys/types.h>
#include <sys/socket.h>],
-[struct sockaddr *a;
-a->sa_len=0;], ac_cv_sockaddr_len=yes, ac_cv_sockaddr_len=no)
-AC_MSG_RESULT($ac_cv_sockaddr_len)])
-if test "$ac_cv_sockaddr_len" = "yes"; then
- AC_DEFINE(STRUCT_SOCKADDR_HAS_SA_LEN, 1, [define if you struct sockaddr sa_len])
-fi
+ [struct sockaddr *a; a->sa_len=0;],
+ [ac_cv_sockaddr_len=yes],
+ [ac_cv_sockaddr_len=no])
+])
+AS_IF([test "$ac_cv_sockaddr_len" = "yes"],
+ [AC_DEFINE(STRUCT_SOCKADDR_HAS_SA_LEN, 1,
+ [define if you struct sockaddr sa_len])])
+
if test "x${MKAFS_OSTYPE}" = "xIRIX"; then
echo Skipping library tests because they confuse Irix.
else
AC_CHECK_RESOLV_RETRANS
-AC_CACHE_VAL(ac_cv_setsockopt_iprecverr,
-[
-AC_MSG_CHECKING([for setsockopt(, SOL_IP, IP_RECVERR)])
-AC_TRY_COMPILE( [#include <sys/types.h>
+AC_CACHE_CHECK([for setsockopt(, SOL_IP, IP_RECVERR)],
+ [ac_cv_setsockopt_iprecverr],
+ [AC_TRY_COMPILE( [
+#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>],
[int on=1;
-setsockopt(0, SOL_IP, IP_RECVERR, &on, sizeof(on));], ac_cv_setsockopt_iprecverr=yes, ac_cv_setsockopt_iprecverr=no)
-AC_MSG_RESULT($ac_cv_setsockopt_iprecverr)])
-if test "$ac_cv_setsockopt_iprecverr" = "yes"; then
- AC_DEFINE(ADAPT_PMTU_RECVERR, 1, [define if asynchronous socket errors can be received])
-fi
+setsockopt(0, SOL_IP, IP_RECVERR, &on, sizeof(on));],
+ [ac_cv_setsockopt_iprecverr=yes],
+ [ac_cv_setsockopt_iprecverr=no])])
+
+AS_IF([test "$ac_cv_setsockopt_iprecverr" = "yes"],
+ [AC_DEFINE(ADAPT_PMTU_RECVERR, 1,
+ [define if asynchronous socket errors can be received])])
PTHREAD_LIBS=error
if test "x$MKAFS_OSTYPE" = OBSD; then
BSD_KERNEL_BUILD="$with_bsd_kernel_build"
else
case $AFS_SYSNAME in
- *_fbsd_4?)
- BSD_KERNEL_BUILD="${BSD_KERNEL_PATH}/compile/GENERIC"
- ;;
*_fbsd_*)
BSD_KERNEL_BUILD="${BSD_KERNEL_PATH}/${HOST_CPU}/compile/GENERIC"
;;
+ *_nbsd*)
+ BSD_KERNEL_BUILD="${BSD_KERNEL_PATH}/arch/${HOST_CPU}/compile/GENERIC"
esac
fi
AC_DEFINE(SUPERGROUPS, 1, [define if you want to have support for nested pts groups])
fi
-if test "$enable_fast_restart" = "yes"; then
- AC_DEFINE(FAST_RESTART, 1, [define if you want to have fast restart])
-fi
-
if test "$enable_bitmap_later" = "yes"; then
AC_DEFINE(BITMAP_LATER, 1, [define if you want to salvager to check bitmasks later])
fi
-if test "$enable_demand_attach_fs" = "yes"; then
- AC_DEFINE(DEMAND_ATTACH_ENABLE, 1, [define if you want the demand attach fileserver])
- DEMAND_ATTACH="yes"
-else
- DEMAND_ATTACH="no"
-fi
-AC_SUBST(DEMAND_ATTACH)
-
-if test "$enable_disconnected" = "yes"; then
- AC_DEFINE(AFS_DISCON_ENV, 1, [define if you want support for disconnected operation])
-fi
-
if test "$enable_unix_sockets" = "yes"; then
AC_DEFINE(USE_UNIX_SOCKETS, 1, [define if you want to use UNIX sockets for fssync.])
USE_UNIX_SOCKETS="yes"
fi
AC_SUBST(USE_UNIX_SOCKETS)
-if test "$enable_fast_restart" = "yes" &&
- test "$enable_demand_attach_fs" = "yes" ; then
- AC_MSG_ERROR([The Demand Attach and Fast Restart extensions are mutually exclusive. Demand Attach fileservers automatically salvage volumes in the background, thereby making Fast Restart pointless.])
- exit 1
-fi
-
-if test "$enable_icmp_pmtu_discovery" = "yes"; then
- if test "$ac_cv_setsockopt_iprecverr" = "yes"; then
- AC_DEFINE(ADAPT_PMTU, 1, [define if you want to decode icmp unreachable packets to discover path mtu])
- fi
-fi
-
-if test "$enable_cache_bypass" = "yes"; then
- AC_DEFINE(AFS_CACHE_BYPASS, 1, [define to activate cache bypassing Unix client])
-fi
+dnl if test "$ac_cv_setsockopt_iprecverr" = "yes"; then
+dnl AC_DEFINE(ADAPT_PMTU, 1, [define if you want to decode icmp unreachable packets to discover path mtu])
+dnl fi
if test "$enable_namei_fileserver" = "yes"; then
AC_DEFINE(AFS_NAMEI_ENV, 1, [define if you want to want namei fileserver])
AC_HEADER_STDC
AC_HEADER_SYS_WAIT
AC_HEADER_DIRENT
-AC_CHECK_HEADERS(stdlib.h string.h unistd.h fcntl.h sys/time.h sys/file.h grp.h)
-AC_CHECK_HEADERS(netinet/in.h netdb.h sys/fcntl.h sys/mnttab.h sys/mntent.h)
-AC_CHECK_HEADERS(mntent.h sys/vfs.h sys/param.h sys/fs_types.h sys/fstyp.h)
-AC_CHECK_HEADERS(sys/mount.h strings.h termios.h signal.h sys/pag.h)
-AC_CHECK_HEADERS(windows.h direct.h sys/ipc.h)
-AC_CHECK_HEADERS(security/pam_modules.h ucontext.h regex.h sys/statvfs.h sys/statfs.h sys/bitypes.h)
+AC_CHECK_HEADERS([ \
+ curses.h\
+ direct.h \
+ et/com_err.h \
+ errno.h \
+ fcntl.h \
+ grp.h \
+ mntent.h \
+ ncurses.h \
+ netdb.h \
+ netinet/in.h \
+ regex.h \
+ security/pam_modules.h \
+ signal.h \
+ stdint.h \
+ stdio_ext.h \
+ stdlib.h \
+ string.h \
+ strings.h \
+ sys/bitypes.h \
+ sys/bswap.h \
+ sys/fcntl.h \
+ sys/file.h \
+ sys/fs_types.h \
+ sys/fstyp.h \
+ sys/ioctl.h \
+ sys/ipc.h \
+ sys/mount.h \
+ sys/mntent.h \
+ sys/mnttab.h \
+ sys/pag.h \
+ sys/param.h \
+ sys/resource.h \
+ sys/statfs.h \
+ sys/statvfs.h \
+ sys/socket.h \
+ sys/time.h \
+ sys/types.h \
+ sys/un.h \
+ sys/vfs.h \
+ syslog.h \
+ termios.h \
+ time.h \
+ ucontext.h \
+ unistd.h \
+ windows.h \
+ ])
+
AC_CHECK_HEADERS(linux/errqueue.h,,,[#include <linux/types.h>])
-AC_CHECK_HEADERS(et/com_err.h)
AC_CHECK_TYPES([fsblkcnt_t],,,[
#include <sys/types.h>
#endif
])
+dnl check for curses-lib
+save_LIBS=$LIBS
+AC_CHECK_LIB( [ncurses], [setupterm],
+[LIB_curses=-lncurses],
+ [AC_CHECK_LIB([Hcurses], [setupterm], [LIB_curses=-lHcurses],
+ [AC_CHECK_LIB([curses], [setupterm], [LIB_curses=-lcurses])
+ ])
+])
+LIBS=$save_LIBS
+AC_SUBST(LIB_curses)
+
OPENAFS_TEST_PACKAGE(libintl,[#include <libintl.h>],[-lintl],,,INTL)
dnl Don't build PAM on IRIX; the interface doesn't work for us.
fi
AC_SUBST(BUILD_LOGIN)
-AC_CHECK_FUNCS(snprintf strlcat strlcpy flock)
-AC_CHECK_FUNCS(setprogname getprogname sigaction mkstemp vsnprintf strerror strcasestr)
-AC_CHECK_FUNCS(setvbuf vsyslog getcwd)
-AC_CHECK_FUNCS(regcomp regexec regerror)
+AC_CHECK_FUNCS([ \
+ arc4random \
+ flock \
+ fseeko64 \
+ ftello64 \
+ getcwd \
+ getegid \
+ geteuid \
+ getgid \
+ getuid \
+ getprogname \
+ getrlimit \
+ issetugid \
+ mkstemp \
+ pread \
+ preadv \
+ pwrite \
+ pwritev \
+ regcomp \
+ regerror \
+ regexec \
+ setitimer \
+ setprogname \
+ setvbuf \
+ sigaction \
+ strcasestr \
+ strerror \
+ timegm \
+])
+
+OPENAFS_ROKEN()
+OPENAFS_C_ATTRIBUTE()
+
+dnl Functions that Heimdal's libroken provides, but that we
+dnl haven't found a need for yet, and so haven't imported
+AC_CHECK_FUNCS([ \
+ chown \
+ fchown \
+ getdtablesize \
+ gethostname \
+ gettimeofday \
+ localtime_r \
+ lstat \
+ inet_aton \
+ inet_ntop \
+ inet_pton \
+ readv \
+ strdup \
+ strftime \
+ strndup \
+ strsep \
+])
+
+dnl Functions that are in objects that we always build from libroken
+AC_CHECK_FUNCS([ \
+ asprintf \
+ asnprintf \
+ vasprintf \
+ vasnprintf \
+ vsnprintf \
+ snprintf \
+])
+
+dnl Functions that we're going to try and get from libroken
+AC_REPLACE_FUNCS([ \
+ daemon \
+ ecalloc \
+ emalloc \
+ erealloc \
+ err \
+ errx \
+ getopt \
+ getprogname \
+ mkstemp \
+ strcasecmp \
+ strlcat \
+ strnlen \
+ strlcpy \
+ strsep \
+ verr \
+ verrx \
+ vsyslog \
+ vwarn \
+ vwarnx \
+ warn \
+ warnx \
+])
+
+dnl Headers that we're going to try and get from libroken
+AC_CHECK_HEADERS([ \
+ err.h \
+])
+
+AC_CHECK_DECLS([h_errno], [], [], [
+#include <sys/types.h>
+#ifdef HAVE_NETDB_H
+#include <netdb.h>
+#endif
+])
+
+AC_HEADER_TIME
+
+ROKEN_HEADERS=
+AS_IF([test "$ac_cv_header_err_h" != "yes" ],
+ [ROKEN_HEADERS="$ROKEN_HEADERS \$(TOP_INCDIR)/err.h"],
+ [])
+AC_SUBST(ROKEN_HEADERS)
+
+dnl Stuff that's harder ...
+AC_MSG_CHECKING([for bswap16])
+AC_LINK_IFELSE([AC_LANG_PROGRAM([
+#ifdef HAVE_SYS_TYPES_H
+#include <sys/types.h>
+#endif
+#ifdef HAVE_SYS_BSWAP_H
+#include <sys/bswap.h>
+#endif
+],
+[short a, b; b = bswap16(a); ])],
+[AC_MSG_RESULT(yes)
+ AC_DEFINE(HAVE_BSWAP16, 1, [Define to 1 if you have the bswap16 function])
+],
+[AC_MSG_RESULT(no)])
+
+AC_MSG_CHECKING([for bswap32])
+AC_LINK_IFELSE([AC_LANG_PROGRAM([#ifdef HAVE_SYS_TYPES_H
+#include <sys/types.h>
+#endif
+#ifdef HAVE_SYS_BSWAP_H
+#include <sys/bswap.h>
+#endif
+],
+[int a, b; b = bswap32(a); ])],
+[AC_MSG_RESULT(yes)
+ AC_DEFINE(HAVE_BSWAP32, 1, [Define to 1 if you have the bswap32 function])
+],
+[AC_MSG_RESULT(no)])
+
+case $AFS_SYSNAME in
+*hp_ux* | *hpux*)
+ AC_MSG_WARN([Some versions of HP-UX have a buggy positional I/O implementation. Forcing no positional I/O.])
+ ;;
+*)
+ AC_MSG_CHECKING([for positional I/O])
+ if test "$ac_cv_func_pread" = "yes" && \
+ test "$ac_cv_func_pwrite" = "yes"; then
+ AC_DEFINE(HAVE_PIO, 1, [define if you have pread() and pwrite()])
+ AC_MSG_RESULT(yes)
+ else
+ AC_MSG_RESULT(no)
+ fi
+ AC_MSG_CHECKING([for vectored positional I/O])
+ if test "$ac_cv_func_preadv" = "yes" && \
+ test "$ac_cv_func_pwritev" = "yes"; then
+ AC_DEFINE(HAVE_PIOV, 1, [define if you have preadv() and pwritev()])
+ AC_MSG_RESULT(yes)
+ else
+ AC_MSG_RESULT(no)
+ fi
+ ;;
+esac
+
AC_MSG_CHECKING([for POSIX regex library])
if test "$ac_cv_header_regex_h" = "yes" && \
test "$ac_cv_func_regcomp" = "yes" && \
AC_MSG_RESULT(no)
fi
-AC_TYPE_SOCKLEN_T
AC_TYPE_SIGNAL
+OPENAFS_RETSIGTYPE
AC_CHECK_SIZEOF(void *)
AC_CHECK_SIZEOF(unsigned long long)
AC_CHECK_SIZEOF(unsigned long)
AC_CHECK_SIZEOF(unsigned int)
AC_TYPE_INTPTR_T
AC_TYPE_UINTPTR_T
-AC_CHECK_TYPE(ssize_t, int)
-AC_CHECK_TYPE([sig_atomic_t], ,
+AC_TYPE_SSIZE_T
+AC_CHECK_TYPE([sig_atomic_t],[],
[AC_DEFINE([sig_atomic_t], [int],
[Define to int if <signal.h> does not define.])],
[#include <sys/types.h>
#include <signal.h>])
+AC_CHECK_TYPE([socklen_t],[],
+ [AC_DEFINE([socklen_t], [int],
+ [Define to int if <sys/socket.h> does not define.])],
+[#include <sys/types.h>
+#include <sys/socket.h>])
+AC_CHECK_TYPES(off64_t)
+AC_CHECK_TYPES([ssize_t], [], [], [#include <unistd.h>])
+AC_CHECK_TYPES([struct winsize], [], [], [
+#ifdef HAVE_TERMIOS_H
+# include <termios.h>
+#else
+# include <sys/termios.h>
+#endif
+#include <sys/ioctl.h>])
+AC_CHECK_TYPES([sa_family_t, socklen_t, struct sockaddr,
+ struct sockaddr_storage],
+ [], [], [
+#include <sys/types.h>
+#include <sys/socket.h>
+])
+AC_CHECK_TYPES([sa_family_t], [], [], [
+#include <sys/types.h>
+#include <sys/socket.h>
+])
+AC_CHECK_TYPES([struct addrinfo], [], [], [
+#include <sys/types.h>
+#ifdef HAVE_NETDB_H
+#include <netdb.h>
+#endif
+])
+AC_CHECK_TYPES([long long], [], [], [])
+
AC_SIZEOF_TYPE(long)
AC_HEADER_PAM_CONST
-AC_CHECK_FUNCS(timegm)
-AC_CHECK_FUNCS(daemon)
dnl Directory PATH handling
if test "x$enable_transarc_paths" = "xyes" ; then
AC_SUBST(XSLTPROC)
OPENAFS_OSCONF
-OPENAFS_KRB5CONF
OPENAFS_FUSE
TOP_SRCDIR="${srcdir}/src"
mkdir -p ${TOP_OBJDIR}/src/JAVA/libjafs
+dnl Check to see if crypt lives in a different library
+AC_CHECK_LIB(crypt, crypt, LIB_crypt="-lcrypt")
+AC_SUBST(LIB_crypt)
+
+dnl Check to see if the compiler support labels in structs
+AC_MSG_CHECKING(for label support in structs)
+AC_TRY_COMPILE([], [
+extern void osi_UFSOpen(void);
+struct labeltest {
+ void (*open) (void);
+};
+struct labeltest struct_labeltest = {
+ .open = osi_UFSOpen,
+}
+],
+[AC_MSG_RESULT(yes)
+ AC_DEFINE(HAVE_STRUCT_LABEL_SUPPORT, 1, [Define to 1 if your compiler supports labels in structs.])
+],
+[AC_MSG_RESULT(no)
+])
+
+AC_MSG_CHECKING([checking for dirfd])
+AC_LINK_IFELSE([AC_LANG_PROGRAM([[#include <sys/types.h>
+#ifdef HAVE_DIRENT_H
+#include <dirent.h>
+#endif
+]],
+ [[DIR *d = 0; dirfd(d);]])],
+ [ac_rk_have_dirfd=yes], [ac_rk_have_dirfd=no])
+if test "$ac_rk_have_dirfd" = "yes" ; then
+ AC_DEFINE_UNQUOTED(HAVE_DIRFD, 1, [have a dirfd function/macro])
+fi
+AC_MSG_RESULT($ac_rk_have_dirfd)
+
+OPENAFS_HAVE_STRUCT_FIELD(DIR, dd_fd, [#include <sys/types.h>
+#ifdef HAVE_DIRENT_H
+#include <dirent.h>
+#endif])
+
+dnl Eventually, this will look for the system one, or for OpenSSL
+LIB_hcrypto="-lafshcrypto"
+AC_SUBST(LIB_hcrypto)
+])
+
+AC_DEFUN([SUMMARY], [
+ # Print a configuration summary
+echo
+echo "**************************************"
+echo configure summary
+echo
+AS_IF([test $LIB_curses],[
+echo "LIB_curses : $LIB_curses" ],[
+echo "XXX LIB_curses not found! not building scout and afsmonitor!"
+])
+echo
+echo "**************************************"
])