New version 3.0.1
This commit is contained in:
parent
16293e5a70
commit
0a37033dee
1
.gitignore
vendored
1
.gitignore
vendored
@ -50,3 +50,4 @@
|
|||||||
/libblockdev-2.27.tar.gz
|
/libblockdev-2.27.tar.gz
|
||||||
/libblockdev-2.28.tar.gz
|
/libblockdev-2.28.tar.gz
|
||||||
/libblockdev-3.0.tar.gz
|
/libblockdev-3.0.tar.gz
|
||||||
|
/libblockdev-3.0.1.tar.gz
|
||||||
|
@ -1,171 +0,0 @@
|
|||||||
From 1536c3fcc0e887a2116ff035bda187a4eab4ef47 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Vojtech Trefny <vtrefny@redhat.com>
|
|
||||||
Date: Wed, 17 May 2023 15:49:14 +0200
|
|
||||||
Subject: [PATCH] Allow resizing of inactive LVs with latest LVM
|
|
||||||
|
|
||||||
Latest LVM doesn't allow resizing of inactive LVs without the
|
|
||||||
"--fs ignore" option to protect users from corrupting their
|
|
||||||
filesystems. As a low level API we don't really want to offer this
|
|
||||||
kind of protection and we should allow to resize an inactive LV.
|
|
||||||
---
|
|
||||||
src/plugins/lvm-dbus.c | 28 +++++++++++++++++++++++++++-
|
|
||||||
src/plugins/lvm.c | 30 +++++++++++++++++++++++++++---
|
|
||||||
tests/lvm_dbus_tests.py | 4 ++++
|
|
||||||
tests/lvm_test.py | 4 ++++
|
|
||||||
tests/skip.yml | 6 ++++++
|
|
||||||
5 files changed, 68 insertions(+), 4 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/plugins/lvm-dbus.c b/src/plugins/lvm-dbus.c
|
|
||||||
index 51572c9a..1408236a 100644
|
|
||||||
--- a/src/plugins/lvm-dbus.c
|
|
||||||
+++ b/src/plugins/lvm-dbus.c
|
|
||||||
@@ -63,6 +63,8 @@ static gchar *global_config_str = NULL;
|
|
||||||
#define METHOD_CALL_TIMEOUT 5000
|
|
||||||
#define PROGRESS_WAIT 500 * 1000 /* microseconds */
|
|
||||||
|
|
||||||
+#define LVM_VERSION_FSRESIZE "2.03.19"
|
|
||||||
+
|
|
||||||
#define UNUSED __attribute__((unused))
|
|
||||||
|
|
||||||
static GDBusConnection *bus = NULL;
|
|
||||||
@@ -2102,6 +2104,15 @@ gboolean bd_lvm_lvresize (const gchar *vg_name, const gchar *lv_name, guint64 si
|
|
||||||
GVariantBuilder builder;
|
|
||||||
GVariantType *type = NULL;
|
|
||||||
GVariant *params = NULL;
|
|
||||||
+ GVariant *extra_params = NULL;
|
|
||||||
+ gboolean success = FALSE;
|
|
||||||
+ BDLVMLVdata *lvinfo = NULL;
|
|
||||||
+ GError *l_error = NULL;
|
|
||||||
+
|
|
||||||
+ lvinfo = bd_lvm_lvinfo (vg_name, lv_name, error);
|
|
||||||
+ if (!lvinfo)
|
|
||||||
+ /* error is already populated */
|
|
||||||
+ return FALSE;
|
|
||||||
|
|
||||||
g_variant_builder_init (&builder, G_VARIANT_TYPE_TUPLE);
|
|
||||||
g_variant_builder_add_value (&builder, g_variant_new ("t", size));
|
|
||||||
@@ -2111,7 +2122,22 @@ gboolean bd_lvm_lvresize (const gchar *vg_name, const gchar *lv_name, guint64 si
|
|
||||||
params = g_variant_builder_end (&builder);
|
|
||||||
g_variant_builder_clear (&builder);
|
|
||||||
|
|
||||||
- call_lv_method_sync (vg_name, lv_name, "Resize", params, NULL, extra, TRUE, error);
|
|
||||||
+ if (lvinfo->attr[4] != 'a') {
|
|
||||||
+ /* starting with 2.03.19 we need to add extra option to allow resizing of inactive LVs */
|
|
||||||
+ success = bd_utils_check_util_version ("lvm", LVM_VERSION_FSRESIZE,
|
|
||||||
+ "version", "LVM version:\\s+([\\d\\.]+)", &l_error);
|
|
||||||
+ if (success) {
|
|
||||||
+ g_variant_builder_init (&builder, G_VARIANT_TYPE_DICTIONARY);
|
|
||||||
+ g_variant_builder_add (&builder, "{sv}", "--fs", g_variant_new ("s", "ignore"));
|
|
||||||
+ extra_params = g_variant_builder_end (&builder);
|
|
||||||
+ g_variant_builder_clear (&builder);
|
|
||||||
+ }
|
|
||||||
+ g_clear_error (&l_error);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ bd_lvm_lvdata_free (lvinfo);
|
|
||||||
+
|
|
||||||
+ call_lv_method_sync (vg_name, lv_name, "Resize", params, extra_params, extra, TRUE, error);
|
|
||||||
return (*error == NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
diff --git a/src/plugins/lvm.c b/src/plugins/lvm.c
|
|
||||||
index 26af0d19..a07db65b 100644
|
|
||||||
--- a/src/plugins/lvm.c
|
|
||||||
+++ b/src/plugins/lvm.c
|
|
||||||
@@ -31,6 +31,8 @@
|
|
||||||
#define SECTOR_SIZE 512
|
|
||||||
#define VDO_POOL_SUFFIX "vpool"
|
|
||||||
|
|
||||||
+#define LVM_VERSION_FSRESIZE "2.03.19"
|
|
||||||
+
|
|
||||||
static GMutex global_config_lock;
|
|
||||||
static gchar *global_config_str = NULL;
|
|
||||||
|
|
||||||
@@ -1583,15 +1585,37 @@ gboolean bd_lvm_lvrename (const gchar *vg_name, const gchar *lv_name, const gcha
|
|
||||||
* Tech category: %BD_LVM_TECH_BASIC-%BD_LVM_TECH_MODE_MODIFY
|
|
||||||
*/
|
|
||||||
gboolean bd_lvm_lvresize (const gchar *vg_name, const gchar *lv_name, guint64 size, const BDExtraArg **extra, GError **error) {
|
|
||||||
- const gchar *args[6] = {"lvresize", "--force", "-L", NULL, NULL, NULL};
|
|
||||||
+ const gchar *args[8] = {"lvresize", "--force", "-L", NULL, NULL, NULL, NULL, NULL};
|
|
||||||
gboolean success = FALSE;
|
|
||||||
+ guint8 next_arg = 4;
|
|
||||||
+ g_autofree gchar *lvspec = NULL;
|
|
||||||
+ BDLVMLVdata *lvinfo = NULL;
|
|
||||||
+ GError *l_error = NULL;
|
|
||||||
+
|
|
||||||
+ lvinfo = bd_lvm_lvinfo (vg_name, lv_name, error);
|
|
||||||
+ if (!lvinfo)
|
|
||||||
+ /* error is already populated */
|
|
||||||
+ return FALSE;
|
|
||||||
|
|
||||||
args[3] = g_strdup_printf ("%"G_GUINT64_FORMAT"K", size/1024);
|
|
||||||
- args[4] = g_strdup_printf ("%s/%s", vg_name, lv_name);
|
|
||||||
+ if (lvinfo->attr[4] != 'a') {
|
|
||||||
+ /* starting with 2.03.19 we need to add extra option to allow resizing of inactive LVs */
|
|
||||||
+ success = bd_utils_check_util_version (deps[DEPS_LVM].name, LVM_VERSION_FSRESIZE,
|
|
||||||
+ deps[DEPS_LVM].ver_arg, deps[DEPS_LVM].ver_regexp, &l_error);
|
|
||||||
+ if (success) {
|
|
||||||
+ args[next_arg++] = "--fs";
|
|
||||||
+ args[next_arg++] = "ignore";
|
|
||||||
+ }
|
|
||||||
+ g_clear_error (&l_error);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ bd_lvm_lvdata_free (lvinfo);
|
|
||||||
+
|
|
||||||
+ lvspec = g_strdup_printf ("%s/%s", vg_name, lv_name);
|
|
||||||
+ args[next_arg++] = lvspec;
|
|
||||||
|
|
||||||
success = call_lvm_and_report_error (args, extra, TRUE, error);
|
|
||||||
g_free ((gchar *) args[3]);
|
|
||||||
- g_free ((gchar *) args[4]);
|
|
||||||
|
|
||||||
return success;
|
|
||||||
}
|
|
||||||
diff --git a/tests/lvm_dbus_tests.py b/tests/lvm_dbus_tests.py
|
|
||||||
index 3fb7946a..b9493642 100644
|
|
||||||
--- a/tests/lvm_dbus_tests.py
|
|
||||||
+++ b/tests/lvm_dbus_tests.py
|
|
||||||
@@ -901,6 +901,10 @@ class LvmTestLVresize(LvmPVVGLVTestCase):
|
|
||||||
succ = BlockDev.lvm_lvdeactivate("testVG", "testLV", None)
|
|
||||||
self.assertTrue(succ)
|
|
||||||
|
|
||||||
+ # try to shrink when deactivated
|
|
||||||
+ succ = BlockDev.lvm_lvresize("testVG", "testLV", 400 * 1024**2, None)
|
|
||||||
+ self.assertTrue(succ)
|
|
||||||
+
|
|
||||||
@unittest.skipUnless(lvm_dbus_running, "LVM DBus not running")
|
|
||||||
class LvmTestLVrename(LvmPVVGLVTestCase):
|
|
||||||
def test_lvrename(self):
|
|
||||||
diff --git a/tests/lvm_test.py b/tests/lvm_test.py
|
|
||||||
index 7be8f1ab..8baae513 100644
|
|
||||||
--- a/tests/lvm_test.py
|
|
||||||
+++ b/tests/lvm_test.py
|
|
||||||
@@ -830,6 +830,10 @@ class LvmTestLVresize(LvmPVVGLVTestCase):
|
|
||||||
succ = BlockDev.lvm_lvdeactivate("testVG", "testLV", None)
|
|
||||||
self.assertTrue(succ)
|
|
||||||
|
|
||||||
+ # try to shrink when deactivated
|
|
||||||
+ succ = BlockDev.lvm_lvresize("testVG", "testLV", 400 * 1024**2, None)
|
|
||||||
+ self.assertTrue(succ)
|
|
||||||
+
|
|
||||||
class LvmTestLVrename(LvmPVVGLVTestCase):
|
|
||||||
def test_lvrename(self):
|
|
||||||
"""Verify that it's possible to rename an LV"""
|
|
||||||
diff --git a/tests/skip.yml b/tests/skip.yml
|
|
||||||
index b06d05da..543d1396 100644
|
|
||||||
--- a/tests/skip.yml
|
|
||||||
+++ b/tests/skip.yml
|
|
||||||
@@ -143,3 +143,9 @@
|
|
||||||
- distro: "centos"
|
|
||||||
version: "9"
|
|
||||||
reason: "Creating RAID 1 LV on CentOS/RHEL 9 causes a system deadlock"
|
|
||||||
+
|
|
||||||
+- test: (lvm_test|lvm_dbus_tests).LvmTestLVresize.test_lvresize
|
|
||||||
+ skip_on:
|
|
||||||
+ - distro: "centos"
|
|
||||||
+ version: "9"
|
|
||||||
+ reason: "LVM >= 2.03.19 is not yet available breaking our check for LVM resize on CentOS 9 Stream"
|
|
||||||
--
|
|
||||||
2.40.1
|
|
||||||
|
|
@ -1,24 +0,0 @@
|
|||||||
From c06dd957335053595e50f705c6a4d4e1caf15a9c Mon Sep 17 00:00:00 2001
|
|
||||||
From: Vojtech Trefny <vtrefny@redhat.com>
|
|
||||||
Date: Wed, 26 Jan 2022 08:33:19 +0100
|
|
||||||
Subject: [PATCH] s390: Remove double fclose in bd_s390_dasd_online (#2045784)
|
|
||||||
|
|
||||||
---
|
|
||||||
src/plugins/s390.c | 1 -
|
|
||||||
1 file changed, 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/src/plugins/s390.c b/src/plugins/s390.c
|
|
||||||
index ac12b049..fb0dc982 100644
|
|
||||||
--- a/src/plugins/s390.c
|
|
||||||
+++ b/src/plugins/s390.c
|
|
||||||
@@ -290,7 +290,6 @@ gboolean bd_s390_dasd_online (const gchar *dasd, GError **error) {
|
|
||||||
if (wrc == EOF) {
|
|
||||||
g_set_error (error, BD_S390_ERROR, BD_S390_ERROR_DEVICE,
|
|
||||||
"Could not set DASD device %s online", dasd);
|
|
||||||
- fclose(fd);
|
|
||||||
bd_utils_report_finished (progress_id, (*error)->message);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
--
|
|
||||||
2.33.1
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
|||||||
From b870898b014f44a97fe996278210f59c57c1196b Mon Sep 17 00:00:00 2001
|
|
||||||
From: Vojtech Trefny <vtrefny@redhat.com>
|
|
||||||
Date: Thu, 29 Jun 2023 08:36:48 +0200
|
|
||||||
Subject: [PATCH] vdo_stats: Remove unused libparted include
|
|
||||||
|
|
||||||
I have no idea where this came from, but we don't need (and never
|
|
||||||
did) libparted in vdo_stats.
|
|
||||||
|
|
||||||
Fixes: #916
|
|
||||||
---
|
|
||||||
src/plugins/vdo_stats.c | 1 -
|
|
||||||
1 file changed, 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/src/plugins/vdo_stats.c b/src/plugins/vdo_stats.c
|
|
||||||
index 7c8b8a45..620e972f 100644
|
|
||||||
--- a/src/plugins/vdo_stats.c
|
|
||||||
+++ b/src/plugins/vdo_stats.c
|
|
||||||
@@ -18,7 +18,6 @@
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <glib.h>
|
|
||||||
-#include <parted/parted.h>
|
|
||||||
#include <blockdev/utils.h>
|
|
||||||
|
|
||||||
#include "vdo_stats.h"
|
|
||||||
--
|
|
||||||
2.41.0
|
|
||||||
|
|
@ -1,25 +0,0 @@
|
|||||||
From ea1c7363b88d804e41a7ba0844a0e558f521eb03 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Vojtech Trefny <vtrefny@redhat.com>
|
|
||||||
Date: Mon, 19 Jun 2023 11:09:10 +0200
|
|
||||||
Subject: [PATCH] s390: Do not try to close an unopened stream
|
|
||||||
|
|
||||||
Our Fedora builds are failing on this on s390x.
|
|
||||||
---
|
|
||||||
src/plugins/s390.c | 1 -
|
|
||||||
1 file changed, 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/src/plugins/s390.c b/src/plugins/s390.c
|
|
||||||
index fb0dc982..705a9ae7 100644
|
|
||||||
--- a/src/plugins/s390.c
|
|
||||||
+++ b/src/plugins/s390.c
|
|
||||||
@@ -601,7 +601,6 @@ gboolean bd_s390_zfcp_online (const gchar *devno, const gchar *wwpn, const gchar
|
|
||||||
boolrc = bd_utils_exec_and_report_error_no_progress (zfcp_cio_free, NULL, error);
|
|
||||||
|
|
||||||
if (!boolrc) {
|
|
||||||
- fclose (fd);
|
|
||||||
g_free (online);
|
|
||||||
g_set_error (error, BD_S390_ERROR, BD_S390_ERROR_DEVICE,
|
|
||||||
"Could not remove device %s from device ignore list.", devno);
|
|
||||||
--
|
|
||||||
2.40.1
|
|
||||||
|
|
@ -77,13 +77,12 @@
|
|||||||
%define configure_opts %{?python3_copts} %{?lvm_dbus_copts} %{?btrfs_copts} %{?crypto_copts} %{?dm_copts} %{?loop_copts} %{?lvm_copts} %{?lvm_dbus_copts} %{?mdraid_copts} %{?mpath_copts} %{?swap_copts} %{?part_copts} %{?fs_copts} %{?nvdimm_copts} %{?tools_copts} %{?gi_copts} %{?nvme_copts}
|
%define configure_opts %{?python3_copts} %{?lvm_dbus_copts} %{?btrfs_copts} %{?crypto_copts} %{?dm_copts} %{?loop_copts} %{?lvm_copts} %{?lvm_dbus_copts} %{?mdraid_copts} %{?mpath_copts} %{?swap_copts} %{?part_copts} %{?fs_copts} %{?nvdimm_copts} %{?tools_copts} %{?gi_copts} %{?nvme_copts}
|
||||||
|
|
||||||
Name: libblockdev
|
Name: libblockdev
|
||||||
Version: 3.0
|
Version: 3.0.1
|
||||||
Release: 2%{?dist}
|
Release: 1%{?dist}
|
||||||
Summary: A library for low-level manipulation with block devices
|
Summary: A library for low-level manipulation with block devices
|
||||||
License: LGPL-2.1-or-later
|
License: LGPL-2.1-or-later
|
||||||
URL: https://github.com/storaged-project/libblockdev
|
URL: https://github.com/storaged-project/libblockdev
|
||||||
Source0: https://github.com/storaged-project/libblockdev/releases/download/%{version}-%{release}/%{name}-%{version}.tar.gz
|
Source0: https://github.com/storaged-project/libblockdev/releases/download/%{version}-%{release}/%{name}-%{version}.tar.gz
|
||||||
Patch0: 0001-vdo_stats-Remove-unused-libparted-include.patch
|
|
||||||
|
|
||||||
BuildRequires: make
|
BuildRequires: make
|
||||||
BuildRequires: glib2-devel
|
BuildRequires: glib2-devel
|
||||||
@ -483,6 +482,7 @@ Various nice storage-related tools based on libblockdev.
|
|||||||
%ifarch s390 s390x
|
%ifarch s390 s390x
|
||||||
%package s390
|
%package s390
|
||||||
Summary: The s390 plugin for the libblockdev library
|
Summary: The s390 plugin for the libblockdev library
|
||||||
|
Requires: %{name}-utils%{?_isa} = %{version}-%{release}
|
||||||
Requires: s390utils
|
Requires: s390utils
|
||||||
|
|
||||||
%description s390
|
%description s390
|
||||||
@ -641,8 +641,8 @@ find %{buildroot} -type f -name "*.la" | xargs %{__rm}
|
|||||||
%{_libdir}/girepository*/BlockDev*.typelib
|
%{_libdir}/girepository*/BlockDev*.typelib
|
||||||
%endif
|
%endif
|
||||||
%dir %{_sysconfdir}/libblockdev
|
%dir %{_sysconfdir}/libblockdev
|
||||||
%dir %{_sysconfdir}/libblockdev/conf.d
|
%dir %{_sysconfdir}/libblockdev/3/conf.d
|
||||||
%config %{_sysconfdir}/libblockdev/conf.d/00-default.cfg
|
%config %{_sysconfdir}/libblockdev/3/conf.d/00-default.cfg
|
||||||
|
|
||||||
%files devel
|
%files devel
|
||||||
%{_libdir}/libblockdev.so
|
%{_libdir}/libblockdev.so
|
||||||
@ -751,7 +751,7 @@ find %{buildroot} -type f -name "*.la" | xargs %{__rm}
|
|||||||
%if %{with_lvm_dbus}
|
%if %{with_lvm_dbus}
|
||||||
%files lvm-dbus
|
%files lvm-dbus
|
||||||
%{_libdir}/libbd_lvm-dbus.so.*
|
%{_libdir}/libbd_lvm-dbus.so.*
|
||||||
%config %{_sysconfdir}/libblockdev/conf.d/10-lvm-dbus.cfg
|
%config %{_sysconfdir}/libblockdev/3/conf.d/10-lvm-dbus.cfg
|
||||||
|
|
||||||
%files lvm-dbus-devel
|
%files lvm-dbus-devel
|
||||||
%{_libdir}/libbd_lvm-dbus.so
|
%{_libdir}/libbd_lvm-dbus.so
|
||||||
@ -845,6 +845,26 @@ find %{buildroot} -type f -name "*.la" | xargs %{__rm}
|
|||||||
%files plugins-all
|
%files plugins-all
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Tue Jul 04 2023 Vojtech Trefny <vtrefny@redhat.com> - 3.0.1-1
|
||||||
|
- fs: Simplify struct BDFSInfo (tbzatek)
|
||||||
|
- boilerplate_generator: Annotate stub func args as G_GNUC_UNUSED (tbzatek)
|
||||||
|
- crypto: Remove stray struct redefinition (tbzatek)
|
||||||
|
- loop: Remove unused variable (tbzatek)
|
||||||
|
- build: Exit before AC_OUTPUT on error (tbzatek)
|
||||||
|
- loop: define LOOP_SET_BLOCK_SIZE is not defined (giulio.benetti)
|
||||||
|
- Make the conf.d directory versioned (vtrefny)
|
||||||
|
- configure: Fix MAJOR_VER macro (vtrefny)
|
||||||
|
- spec: Add dependency on libblockdev-utils to the s390 plugin (vtrefny)
|
||||||
|
- nvme: Mark private symbols as hidden (tbzatek)
|
||||||
|
- dist: Sync spec with downstream (vtrefny)
|
||||||
|
- misc: Update steps and Dockerfile for Python documentation (vtrefny)
|
||||||
|
- fs: Add missing copy and free functions to the header file (vtrefny)
|
||||||
|
- lvm: Add bd_lvm_segdata_copy/free to the header file (vtrefny)
|
||||||
|
- loop: Remove bd_loop_get_autoclear definition (vtrefny)
|
||||||
|
- lvm: Fix declaration for bd_lvm_vdolvpoolname (vtrefny)
|
||||||
|
- lvm: Make _vglock_start_stop static (vtrefny)
|
||||||
|
- vdo_stats: Remove unused libparted include (vtrefny)
|
||||||
|
|
||||||
* Thu Jun 29 2023 Python Maint <python-maint@redhat.com> - 3.0-2
|
* Thu Jun 29 2023 Python Maint <python-maint@redhat.com> - 3.0-2
|
||||||
- Rebuilt for Python 3.12
|
- Rebuilt for Python 3.12
|
||||||
|
|
||||||
|
2
sources
2
sources
@ -1 +1 @@
|
|||||||
SHA512 (libblockdev-3.0.tar.gz) = b2f801b93832343934f81dc9b2440805a9ef72ac7cde80f5b2d6581eb2585f6a05c52c5791b52fabee4278593e6bfffb0cd46175708b8f9bcc03f64bf40f620f
|
SHA512 (libblockdev-3.0.1.tar.gz) = b45e2f26691fe4016c8a161e1300f1edfca7a810e7535dd1eb787ad88a0d3110f75e0da289027eaed16bad275bfbb709b29b946e5fc3750a56e86c6453aa3a6d
|
||||||
|
Loading…
Reference in New Issue
Block a user