1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

cache: support clear-needs-check

Support newer cache tool which support new option
--clear-needs-check-flag.

Code does same as for thin_check.
This commit is contained in:
Zdenek Kabelac 2015-07-07 09:51:40 +02:00
parent d16332be72
commit 0ac20a8fdb
7 changed files with 84 additions and 4 deletions

View File

@ -1,5 +1,6 @@
Version 2.02.125 - Version 2.02.125 -
================================ ================================
Add support --clear-needs-check-flag for cache_check of cache pool metadata.
Replace --enable-lvmlockd by --enable-lockd-sanlock and --enable-lockd-dlm. Replace --enable-lvmlockd by --enable-lockd-sanlock and --enable-lockd-dlm.
Version 2.02.124 - 3rd July 2015 Version 2.02.124 - 3rd July 2015

38
configure vendored
View File

@ -902,6 +902,7 @@ with_cache_check
with_cache_dump with_cache_dump
with_cache_repair with_cache_repair
with_cache_restore with_cache_restore
enable_cache_check_needs_check
enable_readline enable_readline
enable_realtime enable_realtime
enable_ocf enable_ocf
@ -1635,6 +1636,8 @@ Optional Features:
device-mapper is missing from the kernel device-mapper is missing from the kernel
--disable-thin_check_needs_check --disable-thin_check_needs_check
required if thin_check version is < 0.3.0 required if thin_check version is < 0.3.0
--disable-cache_check_needs_check
required if cache_check version is < 0.5
--disable-readline disable readline support --disable-readline disable readline support
--enable-realtime enable realtime clock support --enable-realtime enable realtime clock support
--enable-ocf enable Open Cluster Framework (OCF) compliant --enable-ocf enable Open Cluster Framework (OCF) compliant
@ -8313,6 +8316,14 @@ $as_echo "#define CACHE_INTERNAL 1" >>confdefs.h
*) as_fn_error $? "--with-cache parameter invalid" "$LINENO" 5 ;; *) as_fn_error $? "--with-cache parameter invalid" "$LINENO" 5 ;;
esac esac
# Check whether --enable-cache_check_needs_check was given.
if test "${enable_cache_check_needs_check+set}" = set; then :
enableval=$enable_cache_check_needs_check; CACHE_CHECK_NEEDS_CHECK=$enableval
else
CACHE_CHECK_NEEDS_CHECK=yes
fi
# Test if necessary cache tools are available # Test if necessary cache tools are available
# if not - use plain defaults and warn user # if not - use plain defaults and warn user
case "$CACHE" in case "$CACHE" in
@ -8424,6 +8435,23 @@ $as_echo "$as_me: WARNING: cache_check not found in path $PATH" >&2;}
CACHE_CONFIGURE_WARN=y CACHE_CONFIGURE_WARN=y
fi fi
fi fi
if test "$CACHE_CHECK_NEEDS_CHECK" = yes; then
CACHE_CHECK_VSN=`"$CACHE_CHECK_CMD" -V 2>/dev/null`
CACHE_CHECK_VSN_MAJOR=`echo "$CACHE_CHECK_VSN" | $AWK -F '.' '{print $1}'`
CACHE_CHECK_VSN_MINOR=`echo "$CACHE_CHECK_VSN" | $AWK -F '.' '{print $2}'`
if test -z "$CACHE_CHECK_VSN_MAJOR" -o -z "$CACHE_CHECK_VSN_MINOR"; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $CACHE_CHECK_CMD: Bad version \"$CACHE_CHECK_VSN\" found" >&5
$as_echo "$as_me: WARNING: $CACHE_CHECK_CMD: Bad version \"$CACHE_CHECK_VSN\" found" >&2;}
CACHE_CHECK_VERSION_WARN=y
CACHE_CHECK_NEEDS_CHECK=no
elif test "$CACHE_CHECK_VSN_MAJOR" -eq 0 -a "$CACHE_CHECK_VSN_MINOR" -lt 5; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $CACHE_CHECK_CMD: Old version \"$CACHE_CHECK_VSN\" found" >&5
$as_echo "$as_me: WARNING: $CACHE_CHECK_CMD: Old version \"$CACHE_CHECK_VSN\" found" >&2;}
CACHE_CHECK_VERSION_WARN=y
CACHE_CHECK_NEEDS_CHECK=no
fi
fi
# Empty means a config way to ignore cache dumping # Empty means a config way to ignore cache dumping
if test "$CACHE_DUMP_CMD" = "autodetect"; then if test "$CACHE_DUMP_CMD" = "autodetect"; then
if test -n "$ac_tool_prefix"; then if test -n "$ac_tool_prefix"; then
@ -8745,6 +8773,16 @@ $as_echo "$as_me: WARNING: cache_restore not found in path $PATH" >&2;}
CACHE_CONFIGURE_WARN=y CACHE_CONFIGURE_WARN=y
} }
fi fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether cache_check supports the needs-check flag" >&5
$as_echo_n "checking whether cache_check supports the needs-check flag... " >&6; }
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $CACHE_CHECK_NEEDS_CHECK" >&5
$as_echo "$CACHE_CHECK_NEEDS_CHECK" >&6; }
if test "$CACHE_CHECK_NEEDS_CHECK" = yes; then
$as_echo "#define CACHE_CHECK_NEEDS_CHECK 1" >>confdefs.h
fi
;; ;;
esac esac

View File

@ -560,6 +560,12 @@ case "$CACHE" in
*) AC_MSG_ERROR([--with-cache parameter invalid]) ;; *) AC_MSG_ERROR([--with-cache parameter invalid]) ;;
esac esac
dnl -- cache_check needs-check flag
AC_ARG_ENABLE(cache_check_needs_check,
AC_HELP_STRING([--disable-cache_check_needs_check],
[required if cache_check version is < 0.5]),
CACHE_CHECK_NEEDS_CHECK=$enableval, CACHE_CHECK_NEEDS_CHECK=yes)
# Test if necessary cache tools are available # Test if necessary cache tools are available
# if not - use plain defaults and warn user # if not - use plain defaults and warn user
case "$CACHE" in case "$CACHE" in
@ -573,6 +579,21 @@ case "$CACHE" in
CACHE_CONFIGURE_WARN=y CACHE_CONFIGURE_WARN=y
fi fi
fi fi
if test "$CACHE_CHECK_NEEDS_CHECK" = yes; then
CACHE_CHECK_VSN=`"$CACHE_CHECK_CMD" -V 2>/dev/null`
CACHE_CHECK_VSN_MAJOR=`echo "$CACHE_CHECK_VSN" | $AWK -F '.' '{print $1}'`
CACHE_CHECK_VSN_MINOR=`echo "$CACHE_CHECK_VSN" | $AWK -F '.' '{print $2}'`
if test -z "$CACHE_CHECK_VSN_MAJOR" -o -z "$CACHE_CHECK_VSN_MINOR"; then
AC_MSG_WARN([$CACHE_CHECK_CMD: Bad version "$CACHE_CHECK_VSN" found])
CACHE_CHECK_VERSION_WARN=y
CACHE_CHECK_NEEDS_CHECK=no
elif test "$CACHE_CHECK_VSN_MAJOR" -eq 0 -a "$CACHE_CHECK_VSN_MINOR" -lt 5; then
AC_MSG_WARN([$CACHE_CHECK_CMD: Old version "$CACHE_CHECK_VSN" found])
CACHE_CHECK_VERSION_WARN=y
CACHE_CHECK_NEEDS_CHECK=no
fi
fi
# Empty means a config way to ignore cache dumping # Empty means a config way to ignore cache dumping
if test "$CACHE_DUMP_CMD" = "autodetect"; then if test "$CACHE_DUMP_CMD" = "autodetect"; then
AC_PATH_TOOL(CACHE_DUMP_CMD, cache_dump) AC_PATH_TOOL(CACHE_DUMP_CMD, cache_dump)
@ -600,6 +621,12 @@ case "$CACHE" in
CACHE_CONFIGURE_WARN=y CACHE_CONFIGURE_WARN=y
} }
fi fi
AC_MSG_CHECKING([whether cache_check supports the needs-check flag])
AC_MSG_RESULT([$CACHE_CHECK_NEEDS_CHECK])
if test "$CACHE_CHECK_NEEDS_CHECK" = yes; then
AC_DEFINE([CACHE_CHECK_NEEDS_CHECK], 1, [Define to 1 if the external 'cache_check' tool requires the --clear-needs-check-flag option])
fi
;; ;;
esac esac

View File

@ -2055,7 +2055,7 @@ static int _pool_register_callback(struct dev_manager *dm,
data->skip_zero = dm->activation; data->skip_zero = dm->activation;
data->exec = global_cache_check_executable_CFG; data->exec = global_cache_check_executable_CFG;
data->opts = global_cache_check_options_CFG; data->opts = global_cache_check_options_CFG;
data->defaults = DEFAULT_CACHE_CHECK_OPTION1; data->defaults = DEFAULT_CACHE_CHECK_OPTION1 " " DEFAULT_CACHE_CHECK_OPTION2;
data->global = "cache"; data->global = "cache";
} else { } else {
log_error(INTERNAL_ERROR "Registering unsupported pool callback."); log_error(INTERNAL_ERROR "Registering unsupported pool callback.");

View File

@ -900,7 +900,9 @@ cfg(global_cache_check_executable_CFG, "cache_check_executable", global_CFG_SECT
"Set to \"\" to skip this check. (Not recommended.)\n" "Set to \"\" to skip this check. (Not recommended.)\n"
"Also see cache_check_options.\n" "Also see cache_check_options.\n"
"The cache tools are available from the package\n" "The cache tools are available from the package\n"
"device-mapper-persistent-data.\n") "device-mapper-persistent-data.\n"
"With cache_check version 5.0 or newer you should add\n"
"--clear-needs-check-flag.\n")
cfg(global_cache_dump_executable_CFG, "cache_dump_executable", global_CFG_SECTION, CFG_ALLOW_EMPTY | CFG_DEFAULT_COMMENTED, CFG_TYPE_STRING, CACHE_DUMP_CMD, vsn(2, 2, 108), "@CACHE_DUMP_CMD@", 0, NULL, cfg(global_cache_dump_executable_CFG, "cache_dump_executable", global_CFG_SECTION, CFG_ALLOW_EMPTY | CFG_DEFAULT_COMMENTED, CFG_TYPE_STRING, CACHE_DUMP_CMD, vsn(2, 2, 108), "@CACHE_DUMP_CMD@", 0, NULL,
"The full path to the cache_dump command.\n" "The full path to the cache_dump command.\n"

View File

@ -101,8 +101,16 @@
#define DEFAULT_THIN_POOL_ZERO 1 #define DEFAULT_THIN_POOL_ZERO 1
#define DEFAULT_POOL_METADATA_SPARE 1 /* thin + cache */ #define DEFAULT_POOL_METADATA_SPARE 1 /* thin + cache */
#define DEFAULT_CACHE_CHECK_OPTION1 "-q" #ifdef CACHE_CHECK_NEEDS_CHECK
#define DEFAULT_CACHE_CHECK_OPTIONS_CONFIG "#S" DEFAULT_CACHE_CHECK_OPTION1 # define DEFAULT_CACHE_CHECK_OPTION1 "-q"
# define DEFAULT_CACHE_CHECK_OPTION2 "--clear-needs-check-flag"
# define DEFAULT_CACHE_CHECK_OPTIONS_CONFIG "#S" DEFAULT_CACHE_CHECK_OPTION1 "#S" DEFAULT_CACHE_CHECK_OPTION2
#else
# define DEFAULT_CACHE_CHECK_OPTION1 "-q"
# define DEFAULT_CACHE_CHECK_OPTION2 ""
# define DEFAULT_CACHE_CHECK_OPTIONS_CONFIG "#S" DEFAULT_CACHE_CHECK_OPTION1
#endif
#define DEFAULT_CACHE_REPAIR_OPTIONS "" #define DEFAULT_CACHE_REPAIR_OPTIONS ""
#define DEFAULT_CACHE_REPAIR_OPTIONS_CONFIG NULL #define DEFAULT_CACHE_REPAIR_OPTIONS_CONFIG NULL
#define DEFAULT_CACHE_POOL_METADATA_REQUIRE_SEPARATE_PVS 0 #define DEFAULT_CACHE_POOL_METADATA_REQUIRE_SEPARATE_PVS 0

View File

@ -6,6 +6,10 @@
/* The path to 'cache_check', if available. */ /* The path to 'cache_check', if available. */
#undef CACHE_CHECK_CMD #undef CACHE_CHECK_CMD
/* Define to 1 if the external 'cache_check' tool requires the
--clear-needs-check-flag option */
#undef CACHE_CHECK_NEEDS_CHECK
/* The path to 'cache_dump', if available. */ /* The path to 'cache_dump', if available. */
#undef CACHE_DUMP_CMD #undef CACHE_DUMP_CMD