[AS_HELP_STRING([--with-afs-sysname=sys], [use sys for the afs sysname])])
dnl General feature options.
-AC_ARG_ENABLE([pam],
- [AS_HELP_STRING([--disable-pam], [disable PAM support])],
- ,
- [enable_pam="yes"])
AC_ARG_ENABLE([gtx],
AS_HELP_STRING([--disable-gtx], [disable gtx curses-based terminal tools]))
AC_ARG_ENABLE([uss],
[AS_HELP_STRING([--enable-bitmap-later],
[enable fast startup of file server by not reading bitmap till
needed])],
- ,
+ [AS_IF([test x"$withval" = xyes],
+ [AC_MSG_WARN([bitmap-later is only used by non-demand-attach
+ fileservers. Please migrate to demand-attach instead.])])],
[enable_bitmap_later="no"])
AC_ARG_ENABLE([unix-sockets],
[AS_HELP_STRING([--disable-unix-sockets],
,
[enable_tivoli_tsm="no"])
AC_ARG_ENABLE([pthreaded-ubik],
- [AS_HELP_STRING([--enable-pthreaded-ubik],
- [enable installation of pthreaded ubik applications (defaults to
- disabled)])],
+ [AS_HELP_STRING([--disable-pthreaded-ubik],
+ [disable installation of pthreaded ubik applications (defaults to
+ enabled)])],
,
- [enable_pthreaded_ubik="no"])
+ [enable_pthreaded_ubik="yes"])
dnl Kernel module build options.
AC_ARG_WITH([linux-kernel-headers],
dnl Deprecated crypto
AC_ARG_ENABLE([kauth],
- [AS_HELP_STRING([--disable-kauth],
- [do not install the deprecated kauth server and utilities (defaults to
- enabled)])],
- ,
- [enable_kauth="yes"])
+ [AS_HELP_STRING([--enable-kauth],
+ [install the deprecated kauth server, pam modules, and utilities
+ (defaults to disabled)])],
+ [enable_pam="yes"],
+ [enable_kauth="no"
+ enable_pam="no"])
dnl Optimization and debugging flags.
AC_ARG_ENABLE([strip-binaries],
AC_WARN([Docbook stylesheets not found; some documentation can't be built])
fi)
+AC_ARG_WITH([dot],
+ AS_HELP_STRING([--with-dot@<:@=PATH@:>@],
+ [use graphviz dot to generate dependency graphs with doxygen (defaults to autodetect)]),
+ [], [with_dot="maybe"])
+
enable_login="no"
dnl Check whether kindlegen exists. If not, we'll suppress that part of the
dnl documentation build.
AC_CHECK_PROGS([KINDLEGEN], [kindlegen])
+AC_CHECK_PROGS([DOXYGEN], [doxygen])
+
+dnl Optionally generate graphs with doxygen.
+case "$with_dot" in
+maybe)
+ AC_CHECK_PROGS([DOT], [dot])
+ AS_IF([test "x$DOT" = "x"], [HAVE_DOT="no"], [HAVE_DOT="yes"])
+ ;;
+yes)
+ HAVE_DOT="yes"
+ ;;
+no)
+ HAVE_DOT="no"
+ ;;
+*)
+ HAVE_DOT="yes"
+ DOT_PATH=$with_dot
+esac
+AC_SUBST(HAVE_DOT)
+AC_SUBST(DOT_PATH)
-dnl weird ass systems
-dnl AC_AIX
+dnl Checks for UNIX variants.
AC_ISC_POSIX
-dnl AC_MINIX
dnl Various compiler setup.
AC_TYPE_PID_T
AFS_SYSNAME="x86_darwin_120"
OSXSDK="macosx10.8"
;;
+ x86_64-apple-darwin13.*)
+ AFS_SYSNAME="x86_darwin_130"
+ OSXSDK="macosx10.9"
+ ;;
+ i?86-apple-darwin13.*)
+ AFS_SYSNAME="x86_darwin_130"
+ OSXSDK="macosx10.9"
+ ;;
+ x86_64-apple-darwin14.*)
+ AFS_SYSNAME="x86_darwin_140"
+ OSXSDK="macosx10.10"
+ ;;
+ i?86-apple-darwin14.*)
+ AFS_SYSNAME="x86_darwin_140"
+ OSXSDK="macosx10.10"
+ ;;
sparc-sun-solaris2.8)
AFS_SYSNAME="sun4x_58"
;;
;;
mips-sgi-irix6.5)
AFS_SYSNAME="sgi_65"
+ enable_pam="no"
;;
ia64-*-linux*)
AFS_SYSNAME="ia64_linuxXX"
*_nbsd40) AFS_PARAM_COMMON=param.nbsd40.h ;;
*_nbsd50) AFS_PARAM_COMMON=param.nbsd50.h ;;
*_nbsd60) AFS_PARAM_COMMON=param.nbsd60.h ;;
+ *_nbsd70) AFS_PARAM_COMMON=param.nbsd70.h ;;
*_obsd31) AFS_PARAM_COMMON=param.obsd31.h ;;
*_obsd32) AFS_PARAM_COMMON=param.obsd32.h ;;
*_obsd33) AFS_PARAM_COMMON=param.obsd33.h ;;
*_obsd51) AFS_PARAM_COMMON=param.obsd51.h ;;
*_obsd52) AFS_PARAM_COMMON=param.obsd52.h ;;
*_obsd53) AFS_PARAM_COMMON=param.obsd53.h ;;
+ *_obsd54) AFS_PARAM_COMMON=param.obsd54.h ;;
*_linux22) AFS_PARAM_COMMON=param.linux22.h ;;
*_linux24) AFS_PARAM_COMMON=param.linux24.h ;;
*_linux26) AFS_PARAM_COMMON=param.linux26.h ;;
*_linux_22) AFS_PARAM_COMMON=param.linux22.h ;;
*_linux_24) AFS_PARAM_COMMON=param.linux24.h ;;
*_linux_26) AFS_PARAM_COMMON=param.linux26.h ;;
+ *_fbsd_*) AFS_PARAM_COMMON=param.generic_fbsd.h ;;
esac
OPENAFS_OSCONF
dnl Type existence checks
AC_CHECK_LINUX_TYPE([struct vfs_path], [dcache.h])
+ AC_CHECK_LINUX_TYPE([kuid_t], [uidgid.h])
dnl Check for structure elements
AC_CHECK_LINUX_STRUCT([address_space_operations],
AC_CHECK_LINUX_STRUCT([inode], [i_security], [fs.h])
AC_CHECK_LINUX_STRUCT([file_operations], [flock], [fs.h])
AC_CHECK_LINUX_STRUCT([file_operations], [iterate], [fs.h])
+ AC_CHECK_LINUX_STRUCT([file_operations], [read_iter], [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([filename], [name], [fs.h])
AC_CHECK_LINUX_STRUCT([inode_operations], [truncate], [fs.h])
+ AC_CHECK_LINUX_STRUCT([key_type], [instantiate_prep], [key-type.h])
+ AC_CHECK_LINUX_STRUCT([key_type], [match_preparse], [key-type.h])
AC_CHECK_LINUX_STRUCT([key_type], [preparse], [key-type.h])
AC_CHECK_LINUX_STRUCT([nameidata], [path], [namei.h])
AC_CHECK_LINUX_STRUCT([proc_dir_entry], [owner], [proc_fs.h])
AC_CHECK_LINUX_FUNC([inode_setattr],
[#include <linux/fs.h>],
[inode_setattr(NULL, NULL);])
+ AC_CHECK_LINUX_FUNC([iter_file_splice_write],
+ [#include <linux/fs.h>],
+ [iter_file_splice_write(NULL,NULL,NULL,0,0);])
AC_CHECK_LINUX_FUNC([kernel_setsockopt],
[#include <linux/net.h>],
[kernel_setsockopt(NULL, 0, 0, NULL, 0);])
AC_CHECK_LINUX_FUNC([set_nlink],
[#include <linux/fs.h>],
[set_nlink(NULL, 1);])
+ AC_CHECK_LINUX_FUNC([sock_create_kern],
+ [#include <linux/net.h>],
+ [sock_create_kern(0, 0, 0, NULL);])
AC_CHECK_LINUX_FUNC([splice_direct_to_actor],
[#include <linux/splice.h>],
[splice_direct_to_actor(NULL,NULL,NULL);])
LINUX_IOP_I_CREATE_TAKES_BOOL
LINUX_DOP_D_REVALIDATE_TAKES_UNSIGNED
LINUX_IOP_LOOKUP_TAKES_UNSIGNED
+ LINUX_D_INVALIDATE_IS_VOID
dnl If we are guaranteed that keyrings will work - that is
dnl a) The kernel has keyrings enabled
arpa/nameser.h \
curses.h\
direct.h \
- et/com_err.h \
errno.h \
fcntl.h \
grp.h \
AC_DEFINE(OPR_DEBUG_LOCKS, 1, [turn on lock debugging in opr])
fi
-dnl Don't build PAM on IRIX; the interface doesn't work for us.
if test "$ac_cv_header_security_pam_modules_h" = yes -a "$enable_pam" = yes; then
- case $AFS_SYSNAME in
- sgi_*)
- HAVE_PAM="no"
- ;;
- *)
- HAVE_PAM="yes"
- ;;
- esac
+ HAVE_PAM="YES"
else
HAVE_PAM="no"
fi
])
OPENAFS_ROKEN()
+OPENAFS_HCRYPTO()
OPENAFS_C_ATTRIBUTE()
dnl Functions that Heimdal's libroken provides, but that we
gethostname \
lstat \
inet_aton \
- inet_ntop \
- inet_pton \
putenv \
readv \
setenv \
err \
errx \
flock \
+ freeaddrinfo \
+ gai_strerror \
+ getaddrinfo \
getdtablesize \
+ getnameinfo \
getopt \
getprogname \
gettimeofday \
+ inet_ntop \
+ inet_pton \
localtime_r \
mkstemp \
setenv \
#include <dirent.h>
#endif])
-dnl Eventually, this will look for the system one, or for OpenSSL
-LIB_hcrypto="-lafshcrypto"
-LDFLAGS_hcrypto="-L\$(TOP_LIBDIR)"
-AC_SUBST(LIB_hcrypto)
-AC_SUBST(LDFLAGS_hcrypto)
+OPENAFS_HAVE_STRUCT_FIELD(struct rusage, ru_idrss,
+[#ifdef HAVE_SYS_RESOURCE_H
+#include <sys/resource.h>
+#endif])
dnl Check for UUID library
AC_CHECK_HEADERS([uuid/uuid.h])
])
-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 "**************************************"
-])