# # $Id: configure.ac 5530 2023-08-01 11:00:21Z chrfranke $ # dnl Process this file with autoconf to produce a configure script. AC_PREREQ([2.64]) AC_INIT([smartmontools],[7.4],[smartmontools-support@listi.jpberlin.de],[],[https://www.smartmontools.org/]) AM_INIT_AUTOMAKE([1.10 foreign]) # Version of drive database branch smartmontools_drivedb_version=7.3 # Set by 'do_release' script, commented out when release number is bumped. smartmontools_release_date=2023-08-01 smartmontools_release_time="10:59:45 UTC" if test -n "$smartmontools_release_date"; then AC_DEFINE_UNQUOTED(SMARTMONTOOLS_RELEASE_DATE, "$smartmontools_release_date", [smartmontools Release Date]) AC_DEFINE_UNQUOTED(SMARTMONTOOLS_RELEASE_TIME, "$smartmontools_release_time", [smartmontools Release Time]) AC_SUBST(releaseversion, ['${PACKAGE}-${VERSION}']) else # Add "pre-" also on man pages. AC_SUBST(releaseversion, ['${PACKAGE}-pre-${VERSION}']) fi smartmontools_cvs_tag=`echo '$Id: configure.ac 5530 2023-08-01 11:00:21Z chrfranke $'` AC_DEFINE_UNQUOTED(SMARTMONTOOLS_CONFIGURE_ARGS, "$ac_configure_args", [smartmontools Configure Arguments]) AC_DEFINE_UNQUOTED(CONFIG_H_CVSID, "$smartmontools_cvs_tag", [smartmontools CVS Tag]) AC_CONFIG_SRCDIR([smartctl.cpp]) AC_CONFIG_HEADERS([config.h]) AM_MAINTAINER_MODE AC_LANG([C++]) dnl Checks for programs. AC_PROG_CXX AM_PROG_AS AC_PROG_INSTALL m4_pattern_forbid([^PKG_PROG_]) if test "$cross_compiling" = "no"; then m4_ifdef([PKG_PROG_PKG_CONFIG], [PKG_PROG_PKG_CONFIG], [AC_MSG_WARN([m4/pkg.m4 missing, systemd detection disabled])]) fi AC_ARG_VAR(NM, [Symbol list command]) AC_ARG_VAR(WINDMC, [Windows message compiler command]) AC_ARG_VAR(WINDRES, [Windows resource compiler command]) AC_ARG_VAR(MAKENSIS, [NSIS compiler command]) AC_CANONICAL_HOST AC_CHECK_TOOL(NM, [nm]) case "$host_os" in mingw*) AC_CHECK_TOOL(WINDMC, [windmc]) AC_CHECK_TOOL(WINDRES, [windres]) test -n "$WINDRES" || AC_MSG_ERROR([Missing Windows resource compiler (windres)]) AC_CHECK_PROG(MAKENSIS, [makensis], [makensis]) if test -z "$MAKENSIS" && test -n "$PROGRAMFILES"; then AC_MSG_CHECKING([for makensis at default install location]) for x in '' ' (x86)'; do if test -f "${PROGRAMFILES}${x}/NSIS/makensis.exe"; then MAKENSIS="${PROGRAMFILES}${x}/NSIS/makensis"; break fi; done AC_MSG_RESULT([${MAKENSIS:-no}]) fi ;; esac AC_MSG_CHECKING([whether reproducible build is selected (SOURCE_DATE_EPOCH)]) res=no if test -n "$SOURCE_DATE_EPOCH"; then res=yes test -z "`echo "$SOURCE_DATE_EPOCH" | sed 's,[[0-9]]*,,'`" || res=error fi AC_MSG_RESULT([$res]) case $res in error) AC_MSG_ERROR([Malformed SOURCE_DATE_EPOCH]) ;; yes) CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }-DSOURCE_DATE_EPOCH=$SOURCE_DATE_EPOCH" ;; esac # Check for SVN. AC_MSG_CHECKING([whether this is a build from SVN]) is_svn_build=no svn_deps= if test -f "$srcdir/.svn/wc.db"; then # SVN >= 1.7 working copy svn_deps='${srcdir}/.svn/wc.db' is_svn_build=unknown if (cd "$srcdir" && svn --version && svnversion && svn info) >/dev/null 2>&1; then is_svn_build=yes fi fi AC_SUBST([svn_deps]) AM_CONDITIONAL(IS_SVN_BUILD, [test "$is_svn_build" = "yes"]) AC_MSG_RESULT([$is_svn_build]) # Checks for header files. AC_CHECK_HEADERS([locale.h]) AC_CHECK_HEADERS([byteswap.h], [], [], []) case "$host" in *-*-freebsd*|*-*-dragonfly*|*-*-kfreebsd*-gnu*) # Check for FreeBSD twe and twa include files AC_CHECK_HEADERS([sys/tweio.h sys/twereg.h sys/tw_osl_ioctl.h]) # Check for the FreeBSD CCISS system header and use internal one if not found AC_CHECK_HEADERS([dev/ciss/cissio.h], [AC_DEFINE([CISS_LOCATION],[],[freebsd ciss header location])], [AC_DEFINE([CISS_LOCATION],["cissio_freebsd.h"],[freebsd ciss header location])]) ;; *-*-linux*) # is needed for cciss_ioctl.h at least on SuSE LINUX AC_CHECK_HEADERS([sys/sysmacros.h linux/compiler.h]) # Check for Linux CCISS include file AC_CHECK_HEADERS([linux/cciss_ioctl.h], [], [], [AC_INCLUDES_DEFAULT #ifdef HAVE_LINUX_COMPILER_H # include #endif ]) ;; *-*-netbsd*|*-*-openbsd*) AC_CHECK_HEADERS([dev/ata/atavar.h]) ;; *-*-mingw*) # Older MinGW-w64 (5.0.3) require -lwinpthread AC_SEARCH_LIBS([clock_gettime], [winpthread]) ;; esac # Checks for typedefs, and compiler characteristics. AC_CHECK_TYPES([__int128]) AC_TYPE_LONG_DOUBLE_WIDER # Checks for library functions. AC_CHECK_FUNCS([getopt_long], [need_getopt_long=no], [need_getopt_long=yes]) AM_CONDITIONAL(NEED_GETOPT_LONG, [test "$need_getopt_long" = "yes"]) # Check byte ordering (defines WORDS_BIGENDIAN) AC_C_BIGENDIAN # check for __attribute__((packed)) # (sizeof() check is required to avoid false positives if other # __attribute__((x)) are supported) AC_MSG_CHECKING([whether $CXX supports __attribute__((packed))]) AC_COMPILE_IFELSE([AC_LANG_PROGRAM(, [[ struct s { char a; short b; } __attribute__((packed)); typedef char t[sizeof(struct s) == 3 ? 1 : -1];]])], [gcc_have_attr_packed=yes], [gcc_have_attr_packed=no]) AC_SUBST(gcc_have_attr_packed) if test "$gcc_have_attr_packed" = "yes"; then AC_DEFINE(HAVE_ATTR_PACKED, 1, [Define to 1 if C++ compiler supports __attribute__((packed))]) fi AC_MSG_RESULT([$gcc_have_attr_packed]) AC_SUBST(CPPFLAGS) AC_SUBST(LDFLAGS) AC_SUBST(ASFLAGS) initddir= AC_ARG_WITH(initscriptdir, [AS_HELP_STRING([--with-initscriptdir=@<:@DIR|no@:>@], [Location of init scripts [no]])], [ case "$withval" in auto|yes) AC_MSG_ERROR(['--with-initscriptdir=$withval' is no longer supported]) ;; no) ;; *) initddir="$withval" ;; esac ]) AC_SUBST(initddir) AM_CONDITIONAL(INSTALL_INITSCRIPT, [test -n "$initddir"]) # use different init script templates for different OS case "${host}" in *-*-freebsd*) initdfile="smartd.freebsd.initd" ;; *-apple-darwin*) initdfile="com.smartmontools.smartd.plist" ;; *-*-cygwin*) initdfile="smartd.cygwin.initd" ;; *) initdfile="smartd.initd" ;; esac AC_SUBST(initdfile) AC_ARG_WITH(exampledir, [AS_HELP_STRING([--with-exampledir=DIR], [Location of example scripts [DOCDIR/examplescripts]])], [exampledir="$withval"], [exampledir='${docdir}/examplescripts']) AC_SUBST(exampledir) drivedbdir='${datadir}/${PACKAGE}' drivedbinstdir= AC_ARG_WITH(drivedbinstdir, [AS_HELP_STRING([--with-drivedbinstdir@<:@=DIR|yes|no@:>@], [Optional separate install location of drive database file [no] (yes=DATADIR/smartmontools)])], [ case "$withval" in no) ;; yes) drivedbinstdir=$drivedbdir; drivedbdir='${localstatedir}/lib/${PACKAGE}' ;; *) drivedbinstdir=$withval; drivedbdir='${localstatedir}/lib/${PACKAGE}' ;; esac ]) AC_ARG_WITH(drivedbdir, [AS_HELP_STRING([--with-drivedbdir@<:@=DIR|yes|no@:>@], [Location of drive database file [DATADIR/smartmontools or LOCALSTATEDIR/lib/smartmontools if separate INSTDIR]])], [case "$withval" in yes) ;; no) drivedbdir= ;; *) drivedbdir="$withval" ;; esac]) test -n "$drivedbinstdir" || drivedbinstdir=$drivedbdir AC_SUBST(drivedbinstdir) AC_SUBST(drivedbdir) AM_CONDITIONAL(ENABLE_DRIVEDB, [test -n "$drivedbdir"]) drivedb_version=$smartmontools_drivedb_version AC_ARG_WITH(update-smart_drivedb, [AS_HELP_STRING([--with-update-smart-drivedb@<:@=yes|no|X.Y@:>@], [Install update-smart-drivedb script (and backport it to branches/RELEASE_X_Y_DRIVEDB) [yes]])], [ case "$withval" in yes|no) ;; 5.4[[0-3]]|6.[[0-6]]|7.[[023]]) drivedb_version=$withval; with_update_smart_drivedb=yes ;; *) AC_MSG_ERROR([Invalid drivedb branch version: $withval]) ;; esac ], [with_update_smart_drivedb=yes]) test -n "$drivedbdir" || with_update_smart_drivedb=no AC_SUBST(with_update_smart_drivedb) AM_CONDITIONAL(ENABLE_UPDATE_SMART_DRIVEDB, [test "$with_update_smart_drivedb" = "yes"]) gnupg="gpg" # Also check for '--with-gnupg[=yes]' because 'yes' is a valid command with infinite output AC_ARG_WITH(gnupg, [AS_HELP_STRING([--with-gnupg@<:@=FILE|yes|no@:>@], [GnuPG used to verify drivedb.h [gpg]])], [case "$withval" in yes) ;; no) gnupg= ;; *) gnupg="$withval" ;; esac], []) AC_SUBST(gnupg) AC_ARG_WITH(smartdscriptdir, [AS_HELP_STRING([--with-smartdscriptdir=DIR], [Location of smartd_warning.sh script [SYSCONFDIR]])], [smartdscriptdir="$withval"], [smartdscriptdir='${sysconfdir}']) AC_SUBST(smartdscriptdir) AC_ARG_WITH(smartdplugindir, [AS_HELP_STRING([--with-smartdplugindir=@<:@DIR|no@:>@], [Location of smartd_warning.sh plugin scripts [SMARTDSCRIPTDIR/smartd_warning.d]])], [smartdplugindir=; test "$withval" != "no" && smartdplugindir="$withval"], [smartdplugindir='${smartdscriptdir}/smartd_warning.d']) AC_SUBST(smartdplugindir) AC_ARG_WITH(scriptpath, [AS_HELP_STRING([--with-scriptpath=@<:@PATH|no@:>@], [PATH variable set within scripts [/usr/local/bin:/usr/bin:/bin]])], [scriptpath=; test "$withval" != "no" && scriptpath="$withval"], [scriptpath="/usr/local/bin:/usr/bin:/bin"]) AC_SUBST(scriptpath) AM_CONDITIONAL(ENABLE_SCRIPTPATH, [test -n "$scriptpath"]) savestates= AC_ARG_WITH(savestates, [AS_HELP_STRING([--with-savestates@<:@=PREFIX|yes|no@:>@], [Enable default smartd state files [no] (yes=LOCALSTATEDIR/lib/smartmontools/smartd.)])], [case "$withval" in yes) savestates='${localstatedir}/lib/${PACKAGE}/smartd.' ;; no) ;; *) savestates="$withval" ;; esac]) savestatesdir="${savestates%/*}" AC_SUBST(savestates) AC_SUBST(savestatesdir) AM_CONDITIONAL(ENABLE_SAVESTATES, [test -n "$savestates"]) attributelog= AC_ARG_WITH(attributelog, [AS_HELP_STRING([--with-attributelog@<:@=PREFIX|yes|no@:>@], [Enable default smartd attribute log files [no] (yes=LOCALSTATEDIR/lib/smartmontools/attrlog.)])], [case "$withval" in yes) attributelog='${localstatedir}/lib/${PACKAGE}/attrlog.' ;; no) ;; *) attributelog="$withval" ;; esac]) attributelogdir="${attributelog%/*}" AC_SUBST(attributelog) AC_SUBST(attributelogdir) AM_CONDITIONAL(ENABLE_ATTRIBUTELOG, [test -n "$attributelog"]) AC_ARG_ENABLE(sample, [AS_HELP_STRING([--enable-sample], [Enables appending .sample to the installed smartd rc script and configuration file])], [smartd_suffix=; test "$enableval" = "yes" && smartd_suffix=".sample"], [smartd_suffix=;]) AC_SUBST(smartd_suffix) AC_ARG_ENABLE([scsi-cdb-check], [AS_HELP_STRING([--enable-scsi-cdb-check], [do sanity check on each SCSI cdb])], [ if test "$enableval" = "yes"; then AC_DEFINE(SCSI_CDB_CHECK, 1, [Define to 1 to enable check on each SCSI cdb]) fi ],[]) AC_ARG_ENABLE([fast-lebe], [AS_HELP_STRING([--disable-fast-lebe], [use generic little-endian/big-endian code instead])], [ if test "$enableval" = "no"; then AC_DEFINE(IGNORE_FAST_LEBE, 1, [Define to 1 to use generic LE/BE code instead]) fi ],[]) AC_ARG_WITH(os-deps, [AS_HELP_STRING([--with-os-deps='os_module.o ...'], [Specify OS dependent module(s) [guessed]])], [ for x in $with_os_deps; do case $x in *.o) ;; *) AC_MSG_ERROR([non-object file specified by --with-os-deps]) ;; esac done ],[]) AC_ARG_WITH(selinux, [AS_HELP_STRING([--with-selinux@<:@=yes|no@:>@], [Enables SELinux support [no]])], [ if test "$withval" = "yes"; then AC_CHECK_HEADERS([selinux/selinux.h], [], [AC_MSG_ERROR([Missing SELinux header files])]) AC_CHECK_LIB(selinux, matchpathcon, [], [AC_MSG_ERROR([Missing or incorrect SELinux library files])]) fi ],[]) AC_ARG_WITH(libcap-ng, [AS_HELP_STRING([--with-libcap-ng@<:@=auto|yes|no@:>@], [Add Libcap-ng support to smartd [auto]])], [], [with_libcap_ng=auto]) use_libcap_ng=no case "$with_libcap_ng:$host_os" in auto:linux*|yes:*) AC_CHECK_HEADERS([cap-ng.h], [AC_CHECK_LIB([cap-ng], [capng_clear], [AC_DEFINE(HAVE_LIBCAP_NG, 1, [Define to 1 if you have the `cap-ng' library (-lcap-ng).]) dnl `vim syntax CAPNG_LDADD="-lcap-ng"; use_libcap_ng=yes], [test "$with_libcap_ng" != "yes" || AC_MSG_ERROR([libcap-ng headers found but library is missing])])], [test "$with_libcap_ng" != "yes" || AC_MSG_ERROR([Missing libcap-ng header files])]) ;; esac AC_SUBST(CAPNG_LDADD) AC_ARG_WITH(libsystemd, [AS_HELP_STRING([--with-libsystemd@<:@=auto|yes|no@:>@], [Add systemd 'Type=notify' support to smartd [auto]])], [], [with_libsystemd=auto]) use_libsystemd=no case "$with_libsystemd:$host_os" in auto:linux*|yes:*) AC_CHECK_HEADERS([systemd/sd-daemon.h], [AC_CHECK_LIB([systemd], [sd_notify], [AC_DEFINE(HAVE_LIBSYSTEMD, 1, [Define to 1 if you have the `systemd' library (-lsystemd).]) dnl `vim syntax SYSTEMD_LDADD="-lsystemd"; use_libsystemd=yes], [test "$with_libsystemd" != "yes" || AC_MSG_ERROR([libsystemd headers found but library is missing])])], [test "$with_libsystemd" != "yes" || AC_MSG_ERROR([Missing libsystemd header files])]) ;; esac AC_SUBST(SYSTEMD_LDADD) AC_ARG_WITH(systemdsystemunitdir, [AS_HELP_STRING([--with-systemdsystemunitdir@<:@=DIR|auto|yes|no@:>@], [Location of systemd service files [auto]])], [], [with_systemdsystemunitdir=auto]) systemdsystemunitdir= case "$with_systemdsystemunitdir:$use_libsystemd" in auto:yes|yes:yes) if test -n "$PKG_CONFIG"; then AC_MSG_CHECKING([for systemdsystemunitdir]) systemdsystemunitdir=`$PKG_CONFIG --variable=systemdsystemunitdir systemd 2>/dev/null` AC_MSG_RESULT([${systemdsystemunitdir:-no}]) fi case "$with_systemdsystemunitdir:$sysconfdir:$systemdsystemunitdir" in yes:*:) AC_MSG_ERROR([Location of systemd service files not found]) ;; yes:*:*|auto:*:|auto:/etc:*) ;; *) systemdsystemunitdir='${prefix}'$systemdsystemunitdir ;; esac ;; auto:*|no:*) ;; *:yes) systemdsystemunitdir="$with_systemdsystemunitdir" ;; *) AC_MSG_ERROR(['--with-systemdsystemunitdir=$with_systemdsystemunitdir' now requires '--with-libsystemd']) ;; esac AC_SUBST(systemdsystemunitdir) AM_CONDITIONAL(INSTALL_SYSTEMDUNIT, [test -n "$systemdsystemunitdir"]) AC_ARG_WITH(systemdenvfile, [AS_HELP_STRING([--with-systemdenvfile@<:@=FILE|auto|yes|no@:>@], [Path of systemd EnvironmentFile [auto]])], [], [with_systemdenvfile=auto]) systemdenvfile= case "$with_systemdenvfile:$cross_compiling:$systemdsystemunitdir" in auto:no:?*|yes:*:?*) AC_MSG_CHECKING([for path of systemd EnvironmentFile]) for dir in sysconfig default; do if test -d /etc/$dir; then systemdenvfile='${sysconfdir}'/$dir/smartmontools break fi done AC_MSG_RESULT([${systemdenvfile:-no}]) case "$with_systemdenvfile:$systemdenvfile" in yes:) AC_MSG_ERROR([Path of systemd EnvironmentFile not found]) ;; esac ;; auto:*|no:*) ;; *:*:) AC_MSG_ERROR([Location of systemd service files not found]) ;; *) systemdenvfile="$with_systemdenvfile" esac AC_SUBST(systemdenvfile) # TODO: Remove when NVMe support is no longer EXPERIMENTAL AC_ARG_WITH(nvme-devicescan, [AS_HELP_STRING([--with-nvme-devicescan@<:@=yes|no@:>@], [Include NVMe devices in smartctl --scan and smartd DEVICESCAN [Darwin,FreeBSD,Linux,Windows:yes;NetBSD:no]])]) # TODO: Remove after smartmontools 7.4 AC_ARG_WITH(signal-func, [AS_HELP_STRING([--with-signal-func=@<:@sigaction|sigset|signal@:>@], [Function to set signal(2) action [sigaction]])], [], [with_signal_func=sigaction]) case "$host:$with_signal_func" in *-*-mingw*:*) ;; *:sigaction) AC_CHECK_FUNCS([sigaction], [], AC_MSG_ERROR([Missing function 'sigaction()'. Try '--with-signal-func=sigset' or '--with-signal-func=signal'. Please send info about your system to $PACKAGE_BUGREPORT.])) ;; *:sigset) AC_CHECK_FUNCS([sigset], [], AC_MSG_ERROR([Missing function 'sigset()'])) ;; *:signal) ;; *) AC_MSG_ERROR([Invalid option '--with-signal-func=$with_signal_func']) ;; esac AC_ARG_WITH(cxx11-option, [AS_HELP_STRING([--with-cxx11-option=@<:@OPTION|auto|no@:>@], [Compiler option to enable C++11 support, 'no' to skip check [auto]])], [], [with_cxx11_option=auto]) # check_cxx_options "MESSAGE" MINVER MAXVER "OPTION..." check_cxx_options() { AC_MSG_CHECKING([for $CXX option to accept $1]) res=unknown save_CXXFLAGS=$CXXFLAGS for option in "" $4; do CXXFLAGS="$save_CXXFLAGS $option" AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[ #if __cplusplus < $2 || $3 <= __cplusplus #error false #endif]])], [res=$option]) test "$res" = "unknown" || break done CXXFLAGS=$save_CXXFLAGS AC_MSG_RESULT([${res:-none needed}]) } cxx_missing= case "$with_cxx11_option" in no) ;; auto) check_cxx_options "C++17" 201703 999999 "-std=gnu++17 -std=gnu++1z -std=c++17 -std=c++1z" cxx17_option=$res; check_cxx_options "C++14 but not C++17" 201402 201703 "-std=gnu++14 -std=gnu++1y -std=c++14 -std=c++1y" cxx14_option=$res; case "$cxx17_option:$cxx14_option" in unknown:unknown) cxx_missing=14 ;; unknown:*) cxx_missing=17 ;; esac check_cxx_options "C++11 but not C++14" 201103 201402 "-std=gnu++11 -std=gnu++0x -std=c++11 -std=c++0x" test "$res" != "unknown" || res=$cxx14_option test "$res" != "unknown" || res=$cxx17_option test "$res" != "unknown" || AC_MSG_ERROR([ This script was unable to determine a compiler option to accept C++11. Use option '--with-cxx11-option=OPTION' to specify a compiler option. Use option '--without-cxx11-option' to try anyway without this check. In both cases, please send info about compiler and platform to $PACKAGE_BUGREPORT - Thanks!]) CXXFLAGS="$CXXFLAGS${res:+ }$res" ;; *) AC_MSG_CHECKING([whether $CXX $with_cxx11_option accepts C++11]) CXXFLAGS="$CXXFLAGS${with_cxx11_option:+ }$with_cxx11_option" AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[ #if __cplusplus < 201103 #error false #endif]])], [res=yes], [res=no]) AC_MSG_RESULT([$res]) test "$res" = "yes" || AC_MSG_ERROR([$CXX $with_cxx11_option does not accept C++11]) ;; esac case "$host_os: $CPPFLAGS $CXXFLAGS" in mingw*:*\ -U__USE_MINGW_ANSI_STDIO\ ) ;; mingw*:*) # MinGW 4.6.* did not properly define PRI?64 if __USE_MINGW_ANSI_STDIO is set. # MinGW 4.9.* set __USE_MINGW_ANSI_STDIO in first C++ include which may be too late. # MinGW 8.0.0 and later may automatically set __USE_MINGW_ANSI_STDIO in certain # configurations. __USE_MINGW_ANSI_STDIO is not needed if the UCRT is used. # Make sure __USE_MINGW_ANSI_STDIO or _UCRT is set and fail if format check fails. AC_MSG_CHECKING([whether __USE_MINGW_ANSI_STDIO=1 or _UCRT is predefined]) AC_COMPILE_IFELSE([AC_LANG_SOURCE([[ #include #if !(__USE_MINGW_ANSI_STDIO == 1 || defined(_UCRT)) #error fail #endif]])], [res=yes], [res=no; CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }-D__USE_MINGW_ANSI_STDIO"]) AC_MSG_RESULT([$res]) AC_MSG_CHECKING([whether $CXX supports __USE_MINGW_ANSI_STDIO or UCRT]) save_CXXFLAGS=$CXXFLAGS CXXFLAGS="$CXXFLAGS -Wformat -Werror" AC_COMPILE_IFELSE([AC_LANG_SOURCE([[ #define __STDC_FORMAT_MACROS 1 #include #include void f(char * p, size_t s) { snprintf(p, s, "%lld %" PRId64, (long long)s, (int64_t)s); }]])], [res=yes], [res=no]) AC_MSG_RESULT([$res]) if test "$res" != "yes"; then AC_MSG_ERROR([ This version of $CXX does not support __USE_MINGW_ANSI_STDIO or UCRT. Use option 'CPPFLAGS=-U__USE_MINGW_ANSI_STDIO' to skip this check. Please send info about your system to $PACKAGE_BUGREPORT. ]) fi CXXFLAGS=$save_CXXFLAGS ;; esac AC_ARG_WITH(mingw-aslr, [AS_HELP_STRING([--with-mingw-aslr@<:@=auto|yes|low|no@:>@], [Enable ASLR for MinGW executables [auto]])], [], [with_mingw_aslr=auto]) LDFLAGS_set=${LDFLAGS+yes}; test "$LDFLAGS_set" = "yes" || LDFLAGS_set=no # MinGW defaults: link statically and indicate DEP and TS compatibility case "$host_os:$LDFLAGS_set" in mingw*:no) LDFLAGS="-static -Wl,--nxcompat,--tsaware" ;; esac # Newer versions of MinGW-w64 toolchain enable ASLR and relocation info by default. case "$host_os:$with_mingw_aslr:$LDFLAGS_set" in mingw*:auto:no) AC_MSG_CHECKING([whether this $CXX version enables ASLR by default]) # Yes: g++ 11.4.0, 12.2.0, clang 15.0.7 # No: g++ 6.*, 7.3.* AC_COMPILE_IFELSE([AC_LANG_SOURCE([[ #if !(__GNUC__ >= 11 || __clang_major__ >= 15) #error fail #endif]])], [res=yes],[res=no]) AC_MSG_RESULT([$res]) test "$res" != "yes" || with_mingw_aslr=default esac # ASLR related issues of older MinGW-w64 toolchains and workarounds: # 1. '--dynamicbase' only sets DYNAMIC_BASE flag but does not enable relocation info: # Add '-pie' (works despite 'man ld' says: "... currently only supported on ELF platforms") # 2. If both '-static' and '-pie' are specified, the entry point is not set properly: # Specify entry point with '-emainCRTStartup' or '-e_mainCRTStartup'. # 3. Some versions of '*-w64-mingw32-g++' ignore '-pie' if '-static' is also specified: # Pass '-pie' directly to the linker with '-Wl,-pie'. # 4. Linkage of some versions of 'libstdc++.a' fail with "relocation overflow" if a high # '--image-base' is used: Do not use '--high-entropy-va' in these cases. case "$host:$with_mingw_aslr:$LDFLAGS_set" in x86_64-*-mingw*:auto:no) AC_MSG_CHECKING([whether $CXX supports --high-entropy-va]) save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -Wl,--dynamicbase,-pie,-emainCRTStartup,--high-entropy-va,--image-base,0x140000000" # Link libstdc++ to detect MinGW-w64 problems with high '--image-base' AC_LINK_IFELSE([AC_LANG_PROGRAM([[ #include std::string s(42, '.');]])], [with_mingw_aslr=yes], [with_mingw_aslr=no]) LDFLAGS=$save_LDFLAGS AC_MSG_RESULT([$with_mingw_aslr]) test "$with_mingw_aslr" = "yes" || with_mingw_aslr=low ;; *-*-mingw*:auto:no) with_mingw_aslr=yes ;; esac case "$host:$with_mingw_aslr" in x86_64-*-mingw*:yes) LDFLAGS="$LDFLAGS -Wl,--dynamicbase,-pie,-emainCRTStartup,--high-entropy-va,--image-base,0x140000000" ;; x86_64-*-mingw*:low) LDFLAGS="$LDFLAGS -Wl,--dynamicbase,-pie,-emainCRTStartup" ;; *-*-mingw*:yes|*-*-mingw*:low) LDFLAGS="$LDFLAGS -Wl,--dynamicbase,-pie,-e_mainCRTStartup" ;; esac os_win32_manifest= case "$host" in *-*-mingw*) # Newer MinGW may add a default manifest AC_MSG_CHECKING([whether $CXX adds an application manifest]) cc_adds_manifest=no AC_LINK_IFELSE([AC_LANG_PROGRAM()], [ if "$WINDRES" -O rc conftest.exe 2>/dev/null | grep '^1.*RT_MANIFEST' >/dev/null 2>&1; then cc_adds_manifest=incomplete # Manifest must provide a Win 10 compatibility ID if "$WINDRES" -O rc conftest.exe 2>/dev/null | grep '{8e0f7a12-bfb3-4fe8-b9a5-48fd50a15a9a}' >/dev/null 2>&1; then cc_adds_manifest=yes fi fi], [AC_MSG_ERROR([test compile failed])]) AC_MSG_RESULT([$cc_adds_manifest]) test "$cc_adds_manifest" = "yes" || os_win32_manifest='os_win32/default.manifest' ;; esac AC_ARG_WITH(cxx11-regex, [AS_HELP_STRING([--with-cxx11-regex@<:@=yes|no@:>@], [Use C++11 std::regex instead of POSIX regex(3) [no]])]) need_regex=no if test "$with_cxx11_regex" = "yes"; then AC_DEFINE(WITH_CXX11_REGEX, 1, [Define to 1 to use C++11 std::regex instead of POSIX regex(3)]) else AC_CHECK_FUNCS([regcomp], [], [need_regex=yes]) fi AM_CONDITIONAL(NEED_REGEX, [test "$need_regex" = "yes"]) # TODO: Remove after smartmontools 7.4 AC_ARG_WITH(solaris-sparc-ata, [AS_HELP_STRING([--with-solaris-sparc-ata], [(removed)])], [AC_MSG_ERROR([ The option '--with@<:@out@:>@-solaris-sparc-ata' is no longer supported. If you still need legacy ATA support on Solaris SPARC, please inform $PACKAGE_BUGREPORT.])]) # Set platform-specific modules and symbols os_libs= os_dltools='curl wget lynx svn' os_mailer=mail os_hostname="'hostname' 'uname -n'" os_dnsdomainname= os_nisdomainname="'domainname'" os_posix=yes os_darwin=no os_solaris=no os_win32=no os_win32_mingw=no os_win64=no os_man_filter= os_nvme_devicescan= os_nvme_devicescan_changed=no case "${host}" in *-*-linux*) os_deps='os_linux.o cciss.o dev_areca.o' os_dnsdomainname="'dnsdomainname' 'hostname -d'" os_nisdomainname="'nisdomainname' 'hostname -y' 'domainname'" os_man_filter=Linux os_nvme_devicescan=yes ;; *-*-freebsd*|*-*-dragonfly*|*-*-kfreebsd*-gnu*) os_deps='os_freebsd.o cciss.o dev_areca.o' os_libs='-lcam -lsbuf' os_dltools='fetch curl wget lynx svn' AC_CHECK_LIB(usb, libusb20_dev_get_device_desc) os_man_filter=FreeBSD os_nvme_devicescan=yes # TODO: Remove after smartmontools 7.4 os_nvme_devicescan_changed=yes ;; *-*-solaris*) os_deps='os_solaris.o' os_mailer='mailx' os_solaris=yes os_man_filter=Solaris ;; *-*-netbsd*) os_deps='os_netbsd.o' os_libs='-lutil' os_man_filter=NetBSD os_nvme_devicescan=no ;; *-*-openbsd*) os_deps='os_openbsd.o' os_libs='-lutil' os_dltools='curl wget lynx ftp svn' os_man_filter=OpenBSD ;; *-*-cygwin*) os_deps='os_win32.o dev_areca.o' os_mailer='email' os_hostname="'hostname' 'uname -n' 'echo "'"${HOSTNAME?unset}"'"'" os_dnsdomainname="'dnsdomainname' 'hostname -d' 'echo "'"${USERDNSDOMAIN?unset}"'"'" os_nisdomainname= os_win32=yes os_man_filter=Cygwin os_nvme_devicescan=yes ;; x86_64-*-mingw*) os_deps='os_win32.o dev_areca.o' os_posix=no os_win32=yes os_win32_mingw=yes os_win64=yes os_man_filter=Windows os_nvme_devicescan=yes ;; *-*-mingw*) os_deps='os_win32.o dev_areca.o' os_posix=no os_win32=yes os_win32_mingw=yes os_man_filter=Windows os_nvme_devicescan=yes ;; *-*-darwin*) os_deps='os_darwin.o' os_libs='-framework CoreFoundation -framework IOKit' os_darwin=yes os_man_filter=Darwin os_nvme_devicescan=yes # TODO: Remove after smartmontools 7.4 os_nvme_devicescan_changed=yes ;; *-*-nto-qnx*) os_deps='os_qnxnto.o' ;; *-*-os2-*) os_deps='os_os2.o' os_posix=no ;; *) os_deps='os_generic.o' ;; esac # Replace if '--with-os-deps' was specified test -z "$with_os_deps" || os_deps="$with_os_deps" AC_MSG_CHECKING([whether the OS provides a POSIX API]) if test "$os_posix" = "yes"; then AC_DEFINE(HAVE_POSIX_API, 1, [Define to 1 if the OS provides a POSIX API]) fi AC_MSG_RESULT([$os_posix]) # Check if we need adapter to old interface (dev_legacy.cpp) os_src=`echo "${os_deps}"|sed -n 's,^\([[^ .]]*\)\.o.*$,\1.cpp,p'` AC_MSG_CHECKING([whether ${os_src} uses new interface]) if grep "smart_interface" "${srcdir}/${os_src}" >/dev/null 2>&1; then os_new_interface=yes else os_new_interface=no os_deps="${os_deps} dev_legacy.o" AC_DEFINE(OLD_INTERFACE, 1, [Define to 1 if os_*.cpp still uses the old interface]) fi AC_MSG_RESULT([$os_new_interface]) # TODO: Remove when NVMe support is no longer EXPERIMENTAL case "$os_nvme_devicescan:${with_nvme_devicescan+set}" in no:|yes:) AC_MSG_CHECKING([whether NVMe device scanning could be safely enabled]) with_nvme_devicescan=$os_nvme_devicescan AC_MSG_RESULT([$os_nvme_devicescan]) os_nvme_devicescan=used ;; esac AC_SUBST(with_nvme_devicescan) if test "$with_nvme_devicescan" = "yes"; then AC_DEFINE(WITH_NVME_DEVICESCAN, 1, [Define to 1 to include NVMe devices in smartd DEVICESCAN.]) fi AC_SUBST([os_deps]) AC_SUBST([os_libs]) AC_SUBST([os_dltools]) AC_SUBST([os_mailer]) AC_SUBST([os_hostname]) AC_SUBST([os_dnsdomainname]) AC_SUBST([os_nisdomainname]) AC_SUBST([os_man_filter]) AC_SUBST([os_win32_manifest]) # Create drivedb.h update branch name from version: 5.41[.X] -> RELEASE_5_41_DRIVEDB DRIVEDB_BRANCH=`echo "$drivedb_version" | sed 's,^\([[0-9]]*\.[[0-9]]*\)\..*$,\1,' \ | sed -n 's,^\([[0-9]][[0-9]]*\)\.\([[0-9]][[0-9]]*\)$,RELEASE_\1_\2_DRIVEDB,p'` if test -z "$DRIVEDB_BRANCH"; then AC_MSG_ERROR([Unable to create DRIVEDB_BRANCH for version: $drivedb_version]) fi AC_SUBST([DRIVEDB_BRANCH]) # Enable platform-specific makefile sections AM_CONDITIONAL(OS_POSIX, [test "$os_posix" = "yes"]) AM_CONDITIONAL(OS_DARWIN, [test "$os_darwin" = "yes"]) AM_CONDITIONAL(OS_SOLARIS, [test "$os_solaris" = "yes"]) AM_CONDITIONAL(OS_WIN32, [test "$os_win32" = "yes"]) AM_CONDITIONAL(OS_WIN32_MINGW, [test "$os_win32_mingw" = "yes"]) AM_CONDITIONAL(OS_WIN64, [test "$os_win64" = "yes"]) if test "$GXX" = "yes"; then orig_CXXFLAGS=$CXXFLAGS # Add -Wall and -W[extra] if its not already specified case " $CXXFLAGS " in *\ -Wall\ *) ;; *) CXXFLAGS="$CXXFLAGS -Wall" ;; esac case " $CXXFLAGS " in *\ -W\ *|*\ -Wextra\ *) ;; *) CXXFLAGS="$CXXFLAGS -W" ;; esac # Add -Wformat=2 (GCC 3.0), # -Werror=return-type (G++ >= 8.0 assumes that control never reaches the end of a non-void function), # -fstack-protector[-strong] (GCC 4.1[4.9]) # if supported and no -W or -f option was set in configure cmdline (TODO: -Wformat-signedness) for option in "-Wformat=2" "-Werror=return-type" "-fstack-protector-strong" "-fstack-protector"; do case " $orig_CXXFLAGS:$option" in *\ -W*:-W*|*\ -f*:-f*) continue ;; esac case " $CXXFLAGS:$option" in *\ -fstack-p*:-fstack-p*) continue ;; esac AC_MSG_CHECKING([whether $CXX supports $option]) save_CXXFLAGS=$CXXFLAGS CXXFLAGS="$CXXFLAGS $option" # For -fstack-protector*, check that '__stack_chk_*()' functions are available. AC_LINK_IFELSE([AC_LANG_PROGRAM([[int i;]], [[volatile char buf[10]; buf[i] = 0;]])], [res=yes], [res=no; CXXFLAGS=$save_CXXFLAGS]) AC_MSG_RESULT([$res]) done else # We are NOT using gcc, so enable host-specific compiler flags case "${host}" in sparc*-*-solaris*) # Tell the Solaris/SPARC C++ compiler about packed ATA structures case " $CXXFLAGS" in *\ -xmemalign*) ;; *) CXXFLAGS="-xmemalign=1i $CXXFLAGS" ;; esac ;; esac case "${host}" in *-*-solaris*) # Turn on optimization if user has not explicitly set its value case " $CXXFLAGS" in *\ -xO*) ;; *) CXXFLAGS="-xO2 $CXXFLAGS" ;; esac # Suppress trivial warnings case " $CXXFLAGS" in *\ -erroff*) ;; *) CXXFLAGS="-erroff=%none,wbadinitl,wbadasgl,badargtypel2w,badargtype2w $CXXFLAGS" ;; esac ;; esac fi AC_MSG_CHECKING([whether _FORTIFY_SOURCE is predefined]) # Use COMPILE check to detect compiler presets and C*FLAGS. AC_COMPILE_IFELSE([AC_LANG_SOURCE([[ #ifndef _FORTIFY_SOURCE #error false #endif]])], [res=yes], [res=no]) AC_MSG_RESULT([$res]) if test "$res:$NM" = "no:"; then AC_MSG_NOTICE([Skipping _FORTIFY_SOURCE support check because 'nm' is missing.]) elif test "$res" = "no"; then # Heuristic to check for _FORTIFY_SOURCE=[23] support. # Done after check for -fstack-protector because this may add an additional lib. # Note: Even if _FORTIFY_SOURCE is present in the include files, it may not be # detected here for some reason (disabled for C++, compiler optimization disabled, # LDFLAGS include '-s', ...) save_CPPFLAGS=$CPPFLAGS for level in 3 2; do AC_MSG_CHECKING([whether $CXX supports _FORTIFY_SOURCE=$level]) CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }-D_FORTIFY_SOURCE=$level" # Use LINK instead of COMPILE to make sure that the required lib is also present. AC_LINK_IFELSE([AC_LANG_SOURCE([[ #include #include char buf[42], *p; int main(int argc, char **argv) { #if _FORTIFY_SOURCE > 2 p = (char *)malloc(argc * 24); #else p = buf; #endif if (argc >= 2) strcpy(p, argv[1]); return p[0]; }]])], [res=yes; $NM conftest$EXEEXT 2>/dev/null | grep '_strcpy_chk' >/dev/null 2>&1 || res=no], [res=unknown]) AC_MSG_RESULT([$res]) test "$res" != "yes" || break CPPFLAGS=$save_CPPFLAGS done fi AC_DEFINE_UNQUOTED(SMARTMONTOOLS_BUILD_HOST, "${host}", [smartmontools Build Host]) AC_SUBST(CXXFLAGS) AC_CONFIG_FILES(Makefile) AC_OUTPUT AC_PROG_MAKE_SET # Note: Use `...` here as some shells do not properly parse '$(... case $x in X) ...)' info=` echo "-----------------------------------------------------------------------------" echo "${PACKAGE}-${VERSION} configuration:" echo "host operating system: $host" echo "C++ compiler: $CXX" echo "C compiler: $CC" echo "preprocessor flags: $CPPFLAGS" echo "C++ compiler flags: $CXXFLAGS" echo "C compiler flags: $CFLAGS" echo "linker flags: $LDFLAGS" echo "OS specific modules: $os_deps $os_libs $LIBS" case "$host_os" in mingw*) echo "application manifest: ${os_win32_manifest:-[[built-in]]}" echo "resource compiler: $WINDRES" echo "message compiler: ${WINDMC:-[[missing]]}" echo "NSIS compiler: ${MAKENSIS:-[[missing]]}" if test -n "$drivedbdir"; then echo "drive database file: EXEDIR/drivedb.h" if test -n "$MAKENSIS"; then echo "database update script: EXEDIR/update-smart-drivedb.ps1" fi else echo "drive database file: [[disabled]]" fi if test -n "$savestates"; then echo "smartd save files: \`eval eval eval echo $savestates\`MODEL-SERIAL.TYPE.state" fi if test -n "$attributelog"; then echo "smartd attribute logs: \`eval eval eval echo $attributelog\`MODEL-SERIAL.TYPE.csv" fi echo "NVMe DEVICESCAN: ${with_nvme_devicescan-no}" ;; *) echo "binary install path: \`eval eval eval echo $sbindir\`" echo "man page install path: \`eval eval eval echo $mandir\`" echo "doc file install path: \`eval eval eval echo $docdir\`" echo "examples install path: \`eval eval eval echo $exampledir\`" if test -n "$drivedbdir"; then if test "$drivedbinstdir" != "$drivedbdir"; then echo "installed drivedb file: \`eval eval eval echo $drivedbinstdir\`/drivedb.h" fi echo "drive database file: \`eval eval eval echo $drivedbdir\`/drivedb.h" if test "$with_update_smart_drivedb" = "yes"; then echo "database update script: \`eval eval eval echo $sbindir\`/update-smart-drivedb" if test "$drivedb_version" = "$smartmontools_drivedb_version"; then echo "database update branch: branches/$DRIVEDB_BRANCH" else echo "... backported to: branches/$DRIVEDB_BRANCH" fi echo "download tools: \`eval eval eval echo $os_dltools\`" if test -n "$gnupg"; then echo "GnuPG for verification: \`eval eval eval echo $gnupg\`" else echo "GnuPG for verification: [[disabled]]" fi else echo "database update script: [[disabled]]" fi else echo "drive database file: [[disabled]]" fi echo "local drive database: \`eval eval eval echo $sysconfdir\`/smart_drivedb.h" echo "smartd config file: \`eval eval eval echo $sysconfdir\`/smartd.conf${smartd_suffix}" echo "smartd warning script: \`eval eval eval echo $smartdscriptdir\`/smartd_warning.sh" if test -n "$smartdplugindir"; then echo "smartd plugin path: \`eval eval eval echo $smartdplugindir\`" else echo "smartd plugin path: [[disabled]]" fi if test -n "$scriptpath"; then echo "PATH within scripts: \`eval eval eval echo $scriptpath\`" else echo "PATH within scripts: [[inherited]]" fi if test -n "$initddir"; then echo "smartd initd script: \`eval eval eval echo $initddir\`/smartd" elif test -z "$systemdsystemunitdir"; then echo "smartd initd script: [[disabled]]" fi if test -n "$systemdsystemunitdir"; then echo "smartd service file: \`eval eval eval echo $systemdsystemunitdir\`/smartd.service" if test -n "$systemdenvfile"; then echo "smartd environ file: \`eval eval eval echo $systemdenvfile\`" else echo "smartd environ file: [[disabled]]" fi fi if test -n "$savestates"; then echo "smartd save files: \`eval eval eval echo $savestates\`MODEL-SERIAL.TYPE.state" else echo "smartd save files: [[disabled]]" fi if test -n "$attributelog"; then echo "smartd attribute logs: \`eval eval eval echo $attributelog\`MODEL-SERIAL.TYPE.csv" else echo "smartd attribute logs: [[disabled]]" fi case "$host_os" in linux*) echo "SELinux support: ${with_selinux-no}" echo "libcap-ng support: $use_libcap_ng" echo "systemd notify support: $use_libsystemd" ;; esac echo "NVMe DEVICESCAN: ${with_nvme_devicescan-[[not implemented]]}" ;; esac echo "-----------------------------------------------------------------------------" ` AC_MSG_NOTICE([ $info ]) # TODO: Remove when NVMe support is no longer EXPERIMENTAL case "$os_nvme_devicescan:$with_nvme_devicescan:$os_nvme_devicescan_changed" in used:yes:yes) AC_MSG_WARN([ The default for the inclusion of NVME devices in smartd.conf 'DEVICESCAN' and 'smartctl --scan' has been changed to 'yes' on this platform. Use option '--with-nvme-devicescan' to suppress this warning. ]) ;; used:no:*) AC_MSG_WARN([ This version of smartmontools provides NVMe support which is still EXPERIMENTAL. NVMe devices are not yet included in smartd.conf 'DEVICESCAN' and 'smartctl --scan' unless '-d nvme' is specified. Use option '--with-nvme-devicescan' to include NVMe devices. Use option '--without-nvme-devicescan' to suppress this warning. ]) ;; yes:no:*) AC_MSG_WARN([ The default for the inclusion of NVME devices in smartd.conf 'DEVICESCAN' and 'smartctl --scan' is 'yes' on this platform. If option '--without-nvme-devicescan' is still needed, please inform $PACKAGE_BUGREPORT - Thanks! ]) ;; esac # TODO: Remove after smartmontools 7.4 case "$host:$with_signal_func" in *-*-mingw*:*|*:sigaction) ;; *) AC_MSG_WARN([ The option '--with-signal-func=$with_signal_func' is deprecated and will be removed in a future version of smartmontools. If this option is still needed, please inform $PACKAGE_BUGREPORT. ]) ;; esac case "$host_os:$with_libsystemd:$use_libsystemd:$PKG_CONFIG" in linux*:auto:no:?*) if $PKG_CONFIG systemd >/dev/null 2>&1; then AC_MSG_WARN([ systemd(1) is used on this system but smartd systemd notify support will not be available because a required library is missing. Use option '--without-libsystemd' to suppress this warning. ]) fi ;; esac case "$host_os:$WINDMC" in mingw*:) AC_MSG_WARN([ The Windows message compiler (windmc) is missing. The build will work, but smartd will not contain the MESSAGETABLE required for proper display of smartd log messages in the Windows event log. ]) ;; esac test -z "$cxx_missing" || AC_MSG_WARN([ This version of smartmontools does not use C++14 or C++17 enhancements, but future versions possibly will. This script was unable to determine a compiler option to enable C++$cxx_missing. Please send info about compiler and platform to $PACKAGE_BUGREPORT - Thanks!])