From 9b722c3a2d0e04a51b9659762c86a9babeab19567e9e45cc9ac1e7a92468c34a Mon Sep 17 00:00:00 2001 From: Gang He Date: Tue, 21 Aug 2018 03:13:03 +0000 Subject: [PATCH] Accepting request 630677 from home:ganghe:branches:openSUSE:Factory - Update to LVM2.2.02.180 - Drop the upstream patches - fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch - lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch - lvm2-69-dm-lvm-metad.rules-set-systemd-vars-on-chang.patch - bug-1095960_dev_io-no-discard-in-testmode.patch - Refresh patches + bsc1080299-detect-clvm-properly.patch + bug-950089_test-fix-lvm2-testsuite-build-error.patch - Fix cmirrord LV creation/activation failure (bsc#1091863) - Fix that pvmove does not work (bsc#1080299) - Fix package name for modprobe during build (bsc#1102668) - Fix building error due to the script interpreter + tests-specify-python3-as-the-script-interpreter.patch - Update to LVM2.2.02.180 - Drop the upstream patches - fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch - lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch - lvm2-69-dm-lvm-metad.rules-set-systemd-vars-on-chang.patch - bug-1095960_dev_io-no-discard-in-testmode.patch - Refresh patches + bsc1080299-detect-clvm-properly.patch + bug-950089_test-fix-lvm2-testsuite-build-error.patch - Fix cmirrord LV creation/activation failure (bsc#1091863) - Fix that pvmove does not work (bsc#1080299) - Fix package name for modprobe during build (bsc#1102668) - Fix building error due to the script interpreter + tests-specify-python3-as-the-script-interpreter.patch - Update to LVM2.2.02.180 - Drop the upstream patches - fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch - lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch - lvm2-69-dm-lvm-metad.rules-set-systemd-vars-on-chang.patch - bug-1095960_dev_io-no-discard-in-testmode.patch - Refresh patches + bsc1080299-detect-clvm-properly.patch + bug-950089_test-fix-lvm2-testsuite-build-error.patch - Fix cmirrord LV creation/activation failure (bsc#1091863) - Fix that pvmove does not work (bsc#1080299) - Fix package name for modprobe during build (bsc#1102668) - Fix building error due to the script interpreter + tests-specify-python3-as-the-script-interpreter.patch OBS-URL: https://build.opensuse.org/request/show/630677 OBS-URL: https://build.opensuse.org/package/show/Base:System/lvm2?expand=0&rev=227 --- LVM2.2.02.177.tgz | 3 - LVM2.2.02.177.tgz.asc | 7 - LVM2.2.02.180.tgz | 3 + LVM2.2.02.180.tgz.asc | 17 ++ bsc1080299-detect-clvm-properly.patch | 12 +- ...095960_dev_io-no-discard-in-testmode.patch | 34 ---- ..._test-fix-lvm2-testsuite-build-error.patch | 4 +- device-mapper.changes | 18 +++ device-mapper.spec | 15 +- ...kopt-values-for-skipping-selected-lo.patch | 79 --------- ...lvm-metad.rules-explicit-pvscan-rule.patch | 83 ---------- ...etad.rules-set-systemd-vars-on-chang.patch | 153 ------------------ lvm2-clvm.changes | 18 +++ lvm2-clvm.spec | 15 +- lvm2.changes | 18 +++ lvm2.spec | 19 +-- ...fy-python3-as-the-script-interpreter.patch | 27 ++++ 17 files changed, 127 insertions(+), 398 deletions(-) delete mode 100644 LVM2.2.02.177.tgz delete mode 100644 LVM2.2.02.177.tgz.asc create mode 100644 LVM2.2.02.180.tgz create mode 100644 LVM2.2.02.180.tgz.asc delete mode 100644 bug-1095960_dev_io-no-discard-in-testmode.patch delete mode 100644 fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch delete mode 100644 lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch delete mode 100644 lvm2-69-dm-lvm-metad.rules-set-systemd-vars-on-chang.patch create mode 100644 tests-specify-python3-as-the-script-interpreter.patch diff --git a/LVM2.2.02.177.tgz b/LVM2.2.02.177.tgz deleted file mode 100644 index 5e5d20d..0000000 --- a/LVM2.2.02.177.tgz +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:4025a23ec9b15c2cb7486d151c29dc953b75efc4d452cfe9dbbc7c0fac8e80f2 -size 2378651 diff --git a/LVM2.2.02.177.tgz.asc b/LVM2.2.02.177.tgz.asc deleted file mode 100644 index 29e077c..0000000 --- a/LVM2.2.02.177.tgz.asc +++ /dev/null @@ -1,7 +0,0 @@ ------BEGIN PGP SIGNATURE----- -Version: GnuPG v2.0.14 (GNU/Linux) - -iEYEABECAAYFAlo4KccACgkQIoGRwVZ+LBcdSgCg3Dgs6+ItNryJV9GvCCDguOoj -gGQAoIfvtmvZc5eif/P941hGELtZQFZ6 -=0j1r ------END PGP SIGNATURE----- diff --git a/LVM2.2.02.180.tgz b/LVM2.2.02.180.tgz new file mode 100644 index 0000000..b9a0cc2 --- /dev/null +++ b/LVM2.2.02.180.tgz @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:24997e26dfc916151707c9da504d38d0473bec3481a8230b676bc079041bead6 +size 2373004 diff --git a/LVM2.2.02.180.tgz.asc b/LVM2.2.02.180.tgz.asc new file mode 100644 index 0000000..22a61dc --- /dev/null +++ b/LVM2.2.02.180.tgz.asc @@ -0,0 +1,17 @@ +-----BEGIN PGP SIGNATURE----- +Version: GnuPG v2.0.22 (GNU/Linux) + +iQIcBAABAgAGBQJbUMBzAAoJELkRJDHlCQOfksgQAKHvpM0f4Nt354cmY6N+ha7i +ikSv6aYsFHuHYOHFKJLPJBcNaMs3oZxBtVN69ZuV0cdJ7oiwrQzQzy94wvcaBOZy +tWRLVI+grVU7Fp4uyFwGe4kkxUSGK3/lQrhtI8j+drwGvKk7O0dg8k/ayb9N1do5 +hx86WsucXDl8EFxCSYGu6D8DaL+5zNhumIBXrjp5IbQunckw1/hRqstfMfs/q7dm +7dLlrCWXuEL6AwHYvSI8BorO2vRX2iUBvovNneooGUnfz+c06VawhgmwMVA3j/Lk +jOyT9ytVAgnI/yvMHKB7RUSbjCHqppvxg0K0Fs3ex2rca+GiSrtXoxsK83xVaqiS +8J3amb46ItLsE+5XUFzsSfFCxAdzEGqdW+/YmgQNRQ0OXHlsg98hTD9zNbhNMIqj +RtlPqzFKdIZfhgRAY3fw2TEAaKkuBG1+AeeJHLrPZFcDOXHyvJqoPYcMb3QeANCx +RhrMNLvs4MKlhXUkeimBJZTKXSCCIwaqtH8rOtYYM9Ei50AQYZddUObVLBoQB01Y +MxC87m1eZgIKipWTNfEXm41M4tLPebkaxT9+IBp38yVcZ1jeXxOk41EXtzcs3PII +/SlUw66qokTgSyXFH+mptqxfB3Xkk8li5wv31yOiVY9MZQzt8fvz/veY5uEGxU/a +1et7yfJMpeJYrMuhtCL4 +=kQvz +-----END PGP SIGNATURE----- diff --git a/bsc1080299-detect-clvm-properly.patch b/bsc1080299-detect-clvm-properly.patch index 8766381..a9c2fce 100644 --- a/bsc1080299-detect-clvm-properly.patch +++ b/bsc1080299-detect-clvm-properly.patch @@ -1,7 +1,7 @@ -Index: LVM2.2.02.177/configure +Index: LVM2.2.02.178/configure =================================================================== ---- LVM2.2.02.177.orig/configure -+++ LVM2.2.02.177/configure +--- LVM2.2.02.178.orig/configure ++++ LVM2.2.02.178/configure @@ -10888,8 +10888,6 @@ if [ `expr x"$CLVMD" : '.*corosync.*'` ! fi @@ -20,10 +20,10 @@ Index: LVM2.2.02.177/configure ################################################################################ { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build cluster mirror log daemon" >&5 $as_echo_n "checking whether to build cluster mirror log daemon... " >&6; } -Index: LVM2.2.02.177/configure.in +Index: LVM2.2.02.178/configure.ac =================================================================== ---- LVM2.2.02.177.orig/configure.in -+++ LVM2.2.02.177/configure.in +--- LVM2.2.02.178.orig/configure.ac ++++ LVM2.2.02.178/configure.ac @@ -959,7 +959,6 @@ fi ################################################################################ diff --git a/bug-1095960_dev_io-no-discard-in-testmode.patch b/bug-1095960_dev_io-no-discard-in-testmode.patch deleted file mode 100644 index cf39d35..0000000 --- a/bug-1095960_dev_io-no-discard-in-testmode.patch +++ /dev/null @@ -1,34 +0,0 @@ -From b8a7f6ba3de6aed38c2969693b6064a943ea8799 Mon Sep 17 00:00:00 2001 -From: Zdenek Kabelac -Date: Sun, 8 Jul 2018 21:11:01 +0200 -Subject: [PATCH] dev_io: no discard in testmode - -When lvm2 command is executed in test mode, discard ioctl is skipped. -This may cause even data-loose in case, issuing discard for released -areas was enabled and user 'tested' lvreduce. ---- - lib/device/dev-io.c | 8 +++++--- - 1 file changed, 5 insertions(+), 3 deletions(-) - -diff --git a/lib/device/dev-io.c b/lib/device/dev-io.c -index 145093f17..2a4967fc1 100644 ---- a/lib/device/dev-io.c -+++ b/lib/device/dev-io.c -@@ -411,9 +411,11 @@ static int _dev_discard_blocks(struct device *dev, uint64_t offset_bytes, uint64 - discard_range[0] = offset_bytes; - discard_range[1] = size_bytes; - -- log_debug_devs("Discarding %" PRIu64 " bytes offset %" PRIu64 " bytes on %s.", -- size_bytes, offset_bytes, dev_name(dev)); -- if (ioctl(dev->fd, BLKDISCARD, &discard_range) < 0) { -+ log_debug_devs("Discarding %" PRIu64 " bytes offset %" PRIu64 " bytes on %s. %s", -+ size_bytes, offset_bytes, dev_name(dev), -+ test_mode() ? " (test mode - suppressed)" : ""); -+ -+ if (!test_mode() && ioctl(dev->fd, BLKDISCARD, &discard_range) < 0) { - log_error("%s: BLKDISCARD ioctl at offset %" PRIu64 " size %" PRIu64 " failed: %s.", - dev_name(dev), offset_bytes, size_bytes, strerror(errno)); - if (!dev_close(dev)) --- -2.12.3 - diff --git a/bug-950089_test-fix-lvm2-testsuite-build-error.patch b/bug-950089_test-fix-lvm2-testsuite-build-error.patch index 9614869..1d74e66 100644 --- a/bug-950089_test-fix-lvm2-testsuite-build-error.patch +++ b/bug-950089_test-fix-lvm2-testsuite-build-error.patch @@ -26,14 +26,14 @@ index f152868..f0845d7 100644 --- a/test/Makefile.in +++ b/test/Makefile.in @@ -224,7 +224,7 @@ install: .tests-stamp lib/paths-installed - $(INSTALL_DATA) shell/*.sh $(DATADIR)/shell $(INSTALL_DATA) api/*.sh $(DATADIR)/api + $(INSTALL_DATA) unit/*.sh $(DATADIR)/unit $(INSTALL_DATA) lib/mke2fs.conf $(DATADIR)/lib - $(INSTALL_PROGRAM) api/*.{t,py} $(DATADIR)/api + $(INSTALL_PROGRAM) api/*.py $(DATADIR)/api/ + $(INSTALL_PROGRAM) unit/unit-test $(DATADIR)/unit $(INSTALL_PROGRAM) dbus/*.py $(DATADIR)/dbus/ $(INSTALL_DATA) lib/paths-installed $(DATADIR)/lib/paths - cd lib && $(INSTALL_DATA) \ @@ -244,6 +244,7 @@ install: .tests-stamp lib/paths-installed @cd $(EXECDIR) && for i in $(LIB_LINK_NOT); do \ echo "$(LN_S) -f not $$i"; \ diff --git a/device-mapper.changes b/device-mapper.changes index d8d0537..50cd6ea 100644 --- a/device-mapper.changes +++ b/device-mapper.changes @@ -1,3 +1,21 @@ +------------------------------------------------------------------- +Mon Jul 23 11:45:20 UTC 2018 - ghe@suse.com + +- Update to LVM2.2.02.180 +- Drop the upstream patches + - fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch + - lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch + - lvm2-69-dm-lvm-metad.rules-set-systemd-vars-on-chang.patch + - bug-1095960_dev_io-no-discard-in-testmode.patch +- Refresh patches + + bsc1080299-detect-clvm-properly.patch + + bug-950089_test-fix-lvm2-testsuite-build-error.patch +- Fix cmirrord LV creation/activation failure (bsc#1091863) +- Fix that pvmove does not work (bsc#1080299) +- Fix package name for modprobe during build (bsc#1102668) +- Fix building error due to the script interpreter + + tests-specify-python3-as-the-script-interpreter.patch + ------------------------------------------------------------------- Wed Jul 18 11:33:30 UTC 2018 - ghe@suse.com diff --git a/device-mapper.spec b/device-mapper.spec index 80cc4be..7ed7bfe 100644 --- a/device-mapper.spec +++ b/device-mapper.spec @@ -19,8 +19,8 @@ %define libname libdevmapper1_03 %define libname_event libdevmapper-event1_03 ### COMMON-DEF-BEGIN ### -%define lvm2_version 2.02.177 -%define device_mapper_version 1.02.146 +%define lvm2_version 2.02.180 +%define device_mapper_version 1.02.149 %define thin_provisioning_version 0.7.0 ### COMMON-DEF-END ### Name: device-mapper @@ -33,7 +33,10 @@ Url: http://www.sourceware.org/lvm2/ Source: ftp://sources.redhat.com/pub/lvm2/LVM2.%{lvm2_version}.tgz Source1: ftp://sources.redhat.com/pub/lvm2/LVM2.%{lvm2_version}.tgz.asc Source99: baselibs.conf +# To detect modprobe during build BuildRequires: gcc-c++ +BuildRequires: kmod-compat +BuildRequires: libaio-devel BuildRequires: pkgconfig BuildRequires: suse-module-tools BuildRequires: thin-provisioning-tools >= %{thin_provisioning_version} @@ -47,8 +50,6 @@ BuildRoot: %{_tmppath}/%{name}-%{version}-build %{?systemd_requires} ### COMMON-PATCH-BEGIN ### # Upstream patches -Patch0001: fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch -Patch0002: bug-1095960_dev_io-no-discard-in-testmode.patch # SUSE patches: 1000+ for LVM # Never upstream @@ -60,8 +61,6 @@ Patch1005: bsc1080299-detect-clvm-properly.patch #SUSE patches 2000+ for device mapper, udev rules Patch2001: bug-1012973_simplify-special-case-for-md-in-69-dm-lvm-metadata.patch -Patch2002: lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch -Patch2003: lvm2-69-dm-lvm-metad.rules-set-systemd-vars-on-chang.patch ### COMMON-PATCH-END ### %description @@ -71,15 +70,11 @@ Programs and man pages for configuring and using the device mapper. %setup -q -n LVM2.%{lvm2_version} ### COMMON-PREP-BEGIN ### %patch1001 -p1 -%patch0001 -p1 -%patch0002 -p1 %patch1002 -p1 %patch1003 -p1 %patch1004 -p1 %patch1005 -p1 %patch2001 -p1 -%patch2002 -p1 -%patch2003 -p1 ### COMMON-PREP-END ### %build diff --git a/fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch b/fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch deleted file mode 100644 index 2ced239..0000000 --- a/fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch +++ /dev/null @@ -1,79 +0,0 @@ -From 46cedb105bb7fdba0107794ca5801c2a0e8fd524 Mon Sep 17 00:00:00 2001 -From: David Teigland -Date: Tue, 9 Jan 2018 11:18:57 -0600 -Subject: [PATCH 1/2] lvmlockd: add lockopt values for skipping selected locks - -and add lockopt to common options. ---- - tools/command-lines.in | 9 ++++----- - tools/lvmcmdline.c | 10 ++++++++++ - 2 files changed, 14 insertions(+), 5 deletions(-) - -diff --git a/tools/command-lines.in b/tools/command-lines.in -index d0e5e060c..a1776ce8a 100644 ---- a/tools/command-lines.in -+++ b/tools/command-lines.in -@@ -187,7 +187,7 @@ - # OO_ALL is included in every command automatically. - # - OO_ALL: --commandprofile String, --config String, --debug, ----driverloaded Bool, --help, --longhelp, --profile String, --quiet, -+--driverloaded Bool, --help, --lockopt String, --longhelp, --profile String, --quiet, - --verbose, --version, --yes, --test - - # -@@ -1524,19 +1524,18 @@ ID: vgchange_systemid - DESC: Change the system ID of a VG. - - vgchange --lockstart --OO: --lockopt String, --select String -+OO: --select String - OP: VG|Tag|Select ... - ID: vgchange_lockstart - DESC: Start the lockspace of a shared VG in lvmlockd. - - vgchange --lockstop --OO: --lockopt String, --select String -+OO: --select String - OP: VG|Tag|Select ... - ID: vgchange_lockstop - DESC: Stop the lockspace of a shared VG in lvmlockd. - - vgchange --locktype LockType VG --OO: --lockopt String - ID: vgchange_locktype - DESC: Change the lock type for a shared VG. - -@@ -1563,7 +1562,7 @@ OO: --addtag Tag, --alloc Alloc, --autobackup Bool, --clustered Bool, --maxlogic - --physicalextentsize SizeMB, --force, --zero Bool, --labelsector Number, - --metadatasize SizeMB, --pvmetadatacopies MetadataCopiesPV, --vgmetadatacopies MetadataCopiesVG, - --reportformat ReportFmt, --dataalignment SizeKB, --dataalignmentoffset SizeKB, ----shared, --systemid String, --locktype LockType, --lockopt String -+--shared, --systemid String, --locktype LockType - ID: vgcreate_general - - --- -diff --git a/tools/lvmcmdline.c b/tools/lvmcmdline.c -index b693722c1..791e27206 100644 ---- a/tools/lvmcmdline.c -+++ b/tools/lvmcmdline.c -@@ -2682,6 +2682,16 @@ static int _init_lvmlockd(struct cmd_context *cmd) - return 1; - } - -+ if (use_lvmlockd && arg_is_set(cmd, lockopt_ARG)) { -+ const char *opts = arg_str_value(cmd, lockopt_ARG, ""); -+ if (strstr(opts, "skiplv")) -+ cmd->lockd_lv_disable = 1; -+ if (strstr(opts, "skipvg")) -+ cmd->lockd_vg_disable = 1; -+ if (strstr(opts, "skipgl")) -+ cmd->lockd_gl_disable = 1; -+ } -+ - if (use_lvmlockd && locking_is_clustered()) { - log_error("ERROR: configuration setting use_lvmlockd cannot be used with clustered locking_type 3."); - return 0; --- -2.13.6 - diff --git a/lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch b/lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch deleted file mode 100644 index 1b99706..0000000 --- a/lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch +++ /dev/null @@ -1,83 +0,0 @@ -From fe1af8d113e8b0f5a8aa9397b05eb00341aea332 Mon Sep 17 00:00:00 2001 -From: Martin Wilck -Date: Thu, 21 Dec 2017 09:30:16 +0100 -Subject: [PATCH 1/2] lvm2: 69-dm-lvm-metad.rules: explicit pvscan rule - -Make the distinction between the cases with and without systemd -background jobs explicit in 69-dm-lvm-metad.rules rather than -substituting the rule from the Makefile. At this stage, -this improves only readibility, at the cost of one GOTO statement. - -The next patch will add more differences between the two cases (mostly -comments), which are practically impossible to generate with the current -string subsitution approach. - -This patch introduces no functional change to the udev rules. - -Signed-off-by: Martin Wilck ---- - udev/69-dm-lvm-metad.rules.in | 19 ++++++++++++++++++- - udev/Makefile.in | 9 +++++---- - 2 files changed, 23 insertions(+), 5 deletions(-) - -diff --git a/udev/69-dm-lvm-metad.rules.in b/udev/69-dm-lvm-metad.rules.in -index fff063f6dafd..e8d9a64c29f5 100644 ---- a/udev/69-dm-lvm-metad.rules.in -+++ b/udev/69-dm-lvm-metad.rules.in -@@ -88,6 +88,23 @@ LABEL="lvm_scan" - # loop | | X | X* | | - # other | X | | X | | X - ENV{SYSTEMD_READY}="1" --(PVSCAN_RULE) -+ -+# The method for invoking pvscan is selected at build time with the option -+# --(enable|disable)-udev-systemd-background-jobs to "configure". -+# On modern distributions with recent systemd, it's "systemd_background"; -+# on others, "direct_pvscan". -+GOTO="(PVSCAN_RULE)" -+ -+LABEL="systemd_background" -+ -+ACTION!="remove", ENV{LVM_PV_GONE}=="1", RUN+="(BINDIR)/systemd-run (LVM_EXEC)/lvm pvscan --cache $major:$minor", GOTO="lvm_end" -+ENV{SYSTEMD_ALIAS}="/dev/block/$major:$minor" -+ENV{ID_MODEL}="LVM PV $env{ID_FS_UUID_ENC} on /dev/$name" -+ENV{SYSTEMD_WANTS}+="lvm2-pvscan@$major:$minor.service" -+GOTO="lvm_end" -+ -+LABEL="direct_pvscan" -+ -+RUN+="(LVM_EXEC)/lvm pvscan --background --cache --activate ay --major $major --minor $minor", ENV{LVM_SCANNED}="1" - - LABEL="lvm_end" -diff --git a/udev/Makefile.in b/udev/Makefile.in -index cd031aefa084..5797ee699b95 100644 ---- a/udev/Makefile.in -+++ b/udev/Makefile.in -@@ -26,6 +26,7 @@ endif - - DM_DIR=$(shell $(GREP) "\#define DM_DIR" $(top_srcdir)/libdm/misc/dm-ioctl.h | $(AWK) '{print $$3}') - -+BINDIR=@bindir@ - ifeq ("@UDEV_RULE_EXEC_DETECTION@", "yes") - SBIN=\$$env{DM_SBIN_PATH} - DM_EXEC_RULE=ENV{DM_SBIN_PATH}=\"\/sbin\"\\nTEST!=\"\$$env{DM_SBIN_PATH}\/dmsetup\", ENV{DM_SBIN_PATH}=\"\/usr\/sbin\" -@@ -47,13 +48,13 @@ BLKID_RULE=IMPORT{program}=\"${SBIN}\/blkid -o udev -p \$$tempnode\" - endif - - ifeq ("@UDEV_SYSTEMD_BACKGROUND_JOBS@", "yes") --PVSCAN_RULE=ACTION\!=\"remove\", ENV{LVM_PV_GONE}==\"1\", RUN\+=\"@bindir@/systemd-run $(LVM_EXEC)\/lvm pvscan --cache \$$major\:\$$minor\", GOTO=\"lvm_end\"\nENV{SYSTEMD_ALIAS}=\"\/dev\/block\/\$$major:\$$minor\"\nENV{ID_MODEL}=\"LVM PV \$$env{ID_FS_UUID_ENC} on \/dev\/\$$name\"\nENV{SYSTEMD_WANTS}\+=\"lvm2-pvscan@\$$major:\$$minor.service\" -+PVSCAN_RULE=systemd_background - else --PVSCAN_RULE=RUN\+\=\"$(LVM_EXEC)/lvm pvscan --background --cache --activate ay --major \$$major --minor \$$minor\", ENV{LVM_SCANNED}=\"1\" -+PVSCAN_RULE=direct_pvscan - endif - - %.rules: $(srcdir)/%.rules.in -- $(SED) -e "s+(DM_DIR)+$(DM_DIR)+;s+(BLKID_RULE)+$(BLKID_RULE)+;s+(PVSCAN_RULE)+$(PVSCAN_RULE)+;s+(DM_EXEC_RULE)+$(DM_EXEC_RULE)+;s+(DM_EXEC)+$(DM_EXEC)+;s+(LVM_EXEC_RULE)+$(LVM_EXEC_RULE)+;s+(LVM_EXEC)+$(LVM_EXEC)+;" $< >$@ -+ $(SED) -e "s+(DM_DIR)+$(DM_DIR)+;s+(BINDIR)+$(BINDIR)+;s+(BLKID_RULE)+$(BLKID_RULE)+;s+(PVSCAN_RULE)+$(PVSCAN_RULE)+;s+(DM_EXEC_RULE)+$(DM_EXEC_RULE)+;s+(DM_EXEC)+$(DM_EXEC)+;s+(LVM_EXEC_RULE)+$(LVM_EXEC_RULE)+;s+(LVM_EXEC)+$(LVM_EXEC)+;" $< >$@ - - %_install: %.rules - $(INSTALL_DATA) -D $< $(udevdir)/$( -Date: Thu, 21 Dec 2017 10:06:38 +0100 -Subject: [PATCH 2/2] lvm2: 69-dm-lvm-metad.rules: set systemd vars on "change" - -The current logic that avoids setting SYSTEMD_ALIAS and SYSTEMD_WANTS -on "change" events is flawed in the default "systemd background job" -configuration. For systemd, it's important that device properties don't -change spuriously. - -If an "add" event starts lvm2-pvscan@.service for a device, and a -"change" event follows, removing SYSTEMD_ALIAS and SYSTEMD_WANTS from the -udev db, information about unit dependencies between the device and the -pvscan service can be lost in systemd, in particular if the daemon -configuration is reloaded. - -Steps to reproduce problem: - -- create a device with an LVM PV -- remove device -- add device (generates "add" and "change" uevents for the device) - (at this point SYSTEMD_ALIAS and SYSTEMD_WANTS are clear in udev db) -- systemctl daemon-reload - (systemd reloads udev db) -- vgchange -a n -- remove device - -=> the lvm2-pvscan@.service for the device is still active although the -device is gone. - -- add device again - -=> the PV is not detected, because systemd sees the lvm2-pvscan@.service -as active and thus doesn't restart it. - -The original purpose of this logic was to avoid volumes being scanned -over and over again. With systemd background jobs, that isn't necessary, -because systemd will not restart the job as long as it's active. - -Signed-off-by: Martin Wilck ---- - udev/69-dm-lvm-metad.rules.in | 56 +++++++++++++++++++++++++++++++------------ - udev/Makefile.in | 4 +++- - 2 files changed, 44 insertions(+), 16 deletions(-) - -diff --git a/udev/69-dm-lvm-metad.rules.in b/udev/69-dm-lvm-metad.rules.in -index e8d9a64c29f5..203cb479f592 100644 ---- a/udev/69-dm-lvm-metad.rules.in -+++ b/udev/69-dm-lvm-metad.rules.in -@@ -68,25 +68,15 @@ ACTION=="change", ENV{LVM_LOOP_PV_ACTIVATED}!="1", TEST=="loop/backing_file", EN - ENV{LVM_LOOP_PV_ACTIVATED}!="1", ENV{SYSTEMD_READY}="0" - GOTO="lvm_end" - --# If the PV is not a special device listed above, scan only after device addition (ADD event) -+# If the PV is not a special device listed above, scan only if necessary. -+# For "direct_pvscan" mode (see below), this means run rules only an ADD events. -+# For "systemd_background" mode, systemd takes care of this by activating -+# the lvm2-pvscan@.service only once. - LABEL="next" --ACTION!="add", GOTO="lvm_end" -+ACTION!="(PVSCAN_ACTION)", GOTO="lvm_end" - - LABEL="lvm_scan" - --# The table below summarises the situations in which we reach the LABEL="lvm_scan". --# Marked by X, X* means only if the special dev is properly set up. --# The artificial ADD is supported for coldplugging. We avoid running the pvscan --# on artificial CHANGE so there's no unexpected autoactivation when WATCH rule fires. --# N.B. MD and loop never actually reaches lvm_scan on REMOVE as the PV label is gone --# within a CHANGE event (these are caught by the "LVM_PV_GONE" rule at the beginning). --# --# | real ADD | real CHANGE | artificial ADD | artificial CHANGE | REMOVE --# ============================================================================= --# DM | | X | X* | | X --# MD | | X | X* | | --# loop | | X | X* | | --# other | X | | X | | X - ENV{SYSTEMD_READY}="1" - - # The method for invoking pvscan is selected at build time with the option -@@ -97,6 +87,27 @@ GOTO="(PVSCAN_RULE)" - - LABEL="systemd_background" - -+# The table below summarises the situations in which we reach the LABEL="lvm_scan" -+# in the "systemd_background" case. -+# Marked by X, X* means only if the special dev is properly set up. -+# The artificial ADD is supported for coldplugging. We avoid running the pvscan -+# on artificial CHANGE so there's no unexpected autoactivation when WATCH rule fires. -+# N.B. MD and loop never actually reaches lvm_scan on REMOVE as the PV label is gone -+# within a CHANGE event (these are caught by the "LVM_PV_GONE" rule at the beginning). -+# -+# In this case, we simply set up the dependency between the device and the pvscan -+# job using SYSTEMD_ALIAS (which sets up a simplified device identifier that -+# allows using "BindsTo" in the sytemd unit file) and SYSTEMD_WANTS (which tells -+# systemd to start the pvscan job once the device is ready). -+# We need to set these variables for both "add" and "change" events, otherwise -+# systemd may loose information about the device/unit dependencies. -+# -+# | real ADD | real CHANGE | artificial ADD | artificial CHANGE | REMOVE -+# ============================================================================= -+# DM | | X | X* | | X -+# MD | | X | X* | | -+# loop | | X | X* | | -+# other | X | X | X | | X - ACTION!="remove", ENV{LVM_PV_GONE}=="1", RUN+="(BINDIR)/systemd-run (LVM_EXEC)/lvm pvscan --cache $major:$minor", GOTO="lvm_end" - ENV{SYSTEMD_ALIAS}="/dev/block/$major:$minor" - ENV{ID_MODEL}="LVM PV $env{ID_FS_UUID_ENC} on /dev/$name" -@@ -105,6 +116,21 @@ GOTO="lvm_end" - - LABEL="direct_pvscan" - -+# The table below summarises the situations in which we reach the LABEL="lvm_scan" -+# for the "direct_pvscan" case. -+# Marked by X, X* means only if the special dev is properly set up. -+# The artificial ADD is supported for coldplugging. We avoid running the pvscan -+# on artificial CHANGE so there's no unexpected autoactivation when WATCH rule fires. -+# -+# In this case, we need to make sure that pvscan is not invoked spuriously, therefore -+# we invoke it only for "add" events for "other" devices. -+# -+# | real ADD | real CHANGE | artificial ADD | artificial CHANGE | REMOVE -+# ============================================================================= -+# DM | | X | X* | | X -+# MD | | X | X* | | -+# loop | | X | X* | | -+# other | X | | X | | X - RUN+="(LVM_EXEC)/lvm pvscan --background --cache --activate ay --major $major --minor $minor", ENV{LVM_SCANNED}="1" - - LABEL="lvm_end" -diff --git a/udev/Makefile.in b/udev/Makefile.in -index 5797ee699b95..3e274736d145 100644 ---- a/udev/Makefile.in -+++ b/udev/Makefile.in -@@ -49,12 +49,14 @@ endif - - ifeq ("@UDEV_SYSTEMD_BACKGROUND_JOBS@", "yes") - PVSCAN_RULE=systemd_background -+PVSCAN_ACTION=add|change - else - PVSCAN_RULE=direct_pvscan -+PVSCAN_ACTION=add - endif - - %.rules: $(srcdir)/%.rules.in -- $(SED) -e "s+(DM_DIR)+$(DM_DIR)+;s+(BINDIR)+$(BINDIR)+;s+(BLKID_RULE)+$(BLKID_RULE)+;s+(PVSCAN_RULE)+$(PVSCAN_RULE)+;s+(DM_EXEC_RULE)+$(DM_EXEC_RULE)+;s+(DM_EXEC)+$(DM_EXEC)+;s+(LVM_EXEC_RULE)+$(LVM_EXEC_RULE)+;s+(LVM_EXEC)+$(LVM_EXEC)+;" $< >$@ -+ $(SED) -e "s+(DM_DIR)+$(DM_DIR)+;s+(BINDIR)+$(BINDIR)+;s+(BLKID_RULE)+$(BLKID_RULE)+;s+(PVSCAN_RULE)+$(PVSCAN_RULE)+;s+(PVSCAN_ACTION)+$(PVSCAN_ACTION)+;s+(DM_EXEC_RULE)+$(DM_EXEC_RULE)+;s+(DM_EXEC)+$(DM_EXEC)+;s+(LVM_EXEC_RULE)+$(LVM_EXEC_RULE)+;s+(LVM_EXEC)+$(LVM_EXEC)+;" $< >$@ - - %_install: %.rules - $(INSTALL_DATA) -D $< $(udevdir)/$(= %{dlm_version} BuildRequires: pkgconfig @@ -48,8 +51,6 @@ Obsoletes: cmirrord < %{version} Provides: cmirrord = %{version} ### COMMON-PATCH-BEGIN ### # Upstream patches -Patch0001: fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch -Patch0002: bug-1095960_dev_io-no-discard-in-testmode.patch # SUSE patches: 1000+ for LVM # Never upstream @@ -61,8 +62,6 @@ Patch1005: bsc1080299-detect-clvm-properly.patch #SUSE patches 2000+ for device mapper, udev rules Patch2001: bug-1012973_simplify-special-case-for-md-in-69-dm-lvm-metadata.patch -Patch2002: lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch -Patch2003: lvm2-69-dm-lvm-metad.rules-set-systemd-vars-on-chang.patch ### COMMON-PATCH-END ### # Patches for clvmd and cmirrord @@ -76,15 +75,11 @@ A daemon for using LVM2 Logival Volumes in a clustered environment. ### COMMON-PREP-BEGIN ### %patch1001 -p1 -%patch0001 -p1 -%patch0002 -p1 %patch1002 -p1 %patch1003 -p1 %patch1004 -p1 %patch1005 -p1 %patch2001 -p1 -%patch2002 -p1 -%patch2003 -p1 ### COMMON-PREP-END ### %patch3001 -p1 diff --git a/lvm2.changes b/lvm2.changes index d8d0537..50cd6ea 100644 --- a/lvm2.changes +++ b/lvm2.changes @@ -1,3 +1,21 @@ +------------------------------------------------------------------- +Mon Jul 23 11:45:20 UTC 2018 - ghe@suse.com + +- Update to LVM2.2.02.180 +- Drop the upstream patches + - fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch + - lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch + - lvm2-69-dm-lvm-metad.rules-set-systemd-vars-on-chang.patch + - bug-1095960_dev_io-no-discard-in-testmode.patch +- Refresh patches + + bsc1080299-detect-clvm-properly.patch + + bug-950089_test-fix-lvm2-testsuite-build-error.patch +- Fix cmirrord LV creation/activation failure (bsc#1091863) +- Fix that pvmove does not work (bsc#1080299) +- Fix package name for modprobe during build (bsc#1102668) +- Fix building error due to the script interpreter + + tests-specify-python3-as-the-script-interpreter.patch + ------------------------------------------------------------------- Wed Jul 18 11:33:30 UTC 2018 - ghe@suse.com diff --git a/lvm2.spec b/lvm2.spec index 0ce1317..c1d503f 100644 --- a/lvm2.spec +++ b/lvm2.spec @@ -16,13 +16,14 @@ # +%define _unpackaged_files_terminate_build 0 %define _udevdir %(pkg-config --variable=udevdir udev) %define applib liblvm2app2_2 %define cmdlib liblvm2cmd2_02 ### COMMON-DEF-BEGIN ### -%define lvm2_version 2.02.177 -%define device_mapper_version 1.02.146 +%define lvm2_version 2.02.180 +%define device_mapper_version 1.02.149 %define thin_provisioning_version 0.7.0 ### COMMON-DEF-END ### @@ -38,9 +39,10 @@ Source1: lvm.conf Source42: ftp://sources.redhat.com/pub/lvm2/LVM2.%{version}.tgz.asc BuildRequires: gcc-c++ BuildRequires: libaio-devel +BuildRequires: libcorosync-devel BuildRequires: libselinux-devel # To detect modprobe during build -BuildRequires: modutils +BuildRequires: kmod-compat BuildRequires: pkgconfig BuildRequires: readline-devel BuildRequires: thin-provisioning-tools >= %{thin_provisioning_version} @@ -58,8 +60,6 @@ BuildRoot: %{_tmppath}/%{name}-%{version}-build ### COMMON-PATCH-BEGIN ### # Upstream patches -Patch0001: fate-323203_lvmlockd-add-lockopt-values-for-skipping-selected-lo.patch -Patch0002: bug-1095960_dev_io-no-discard-in-testmode.patch # SUSE patches: 1000+ for LVM # Never upstream @@ -71,14 +71,13 @@ Patch1005: bsc1080299-detect-clvm-properly.patch #SUSE patches 2000+ for device mapper, udev rules Patch2001: bug-1012973_simplify-special-case-for-md-in-69-dm-lvm-metadata.patch -Patch2002: lvm2-69-dm-lvm-metad.rules-explicit-pvscan-rule.patch -Patch2003: lvm2-69-dm-lvm-metad.rules-set-systemd-vars-on-chang.patch ### COMMON-PATCH-END ### # 3000+ for test code Patch3001: bug-950089_test-fix-lvm2-testsuite-build-error.patch Patch3002: bug-1043040_test-fix-read-ahead-issues-in-test-scripts.patch Patch3003: bug-1072624_test-lvmetad_dump-always-timed-out-when-using-nc.patch +Patch3004: tests-specify-python3-as-the-script-interpreter.patch # patches specif for lvm2.spec Patch4001: bug-1037309_Makefile-skip-compliling-daemons-lvmlockd-directory.patch @@ -91,20 +90,17 @@ Volume Manager. %setup -q -n LVM2.%{version} ### COMMON-PREP-BEGIN ### %patch1001 -p1 -%patch0001 -p1 -%patch0002 -p1 %patch1002 -p1 %patch1003 -p1 %patch1004 -p1 %patch1005 -p1 %patch2001 -p1 -%patch2002 -p1 -%patch2003 -p1 ### COMMON-PREP-END ### %patch3001 -p1 %patch3002 -p1 %patch3003 -p1 +%patch3004 -p1 %patch4001 -p1 %build @@ -119,6 +115,7 @@ extra_opts=" --with-default-locking-dir=/run/lock/lvm --with-default-pid-dir=/run --with-default-run-dir=/run/lvm + --enable-cmirrord " ### COMMON-CONFIG-BEGIN ### diff --git a/tests-specify-python3-as-the-script-interpreter.patch b/tests-specify-python3-as-the-script-interpreter.patch new file mode 100644 index 0000000..6604149 --- /dev/null +++ b/tests-specify-python3-as-the-script-interpreter.patch @@ -0,0 +1,27 @@ +From 3f768d29ceb5427b6e8de4fe35e2c1001409d750 Mon Sep 17 00:00:00 2001 +From: Gang He +Date: Wed, 20 Jun 2018 14:04:52 +0800 +Subject: [PATCH] tests: specify python3 as the script interpreter + +specify /usr/bin/python3 as the script interpreter in +python_lvm_unit.py.in file, otherwise, there will be a building +error. + +Signed-off-by: Gang He +--- + test/api/python_lvm_unit.py.in | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/test/api/python_lvm_unit.py.in b/test/api/python_lvm_unit.py.in +index 78ced7e31..c6a7c9905 100755 +--- a/test/api/python_lvm_unit.py.in ++++ b/test/api/python_lvm_unit.py.in +@@ -1,4 +1,4 @@ +-#!@PYTHON@ ++#!/usr/bin/python3 + + # Copyright (C) 2012-2013 Red Hat, Inc. All rights reserved. + # +-- +2.12.3 +