Blame SOURCES/0003-LVM-thin-metadata-calculation-fix.patch

4f8f2a
From 2bb371937c7ef73f26717e57a5eb78cafe90a9f7 Mon Sep 17 00:00:00 2001
4f8f2a
From: Vojtech Trefny <vtrefny@redhat.com>
4f8f2a
Date: Fri, 20 Sep 2019 09:58:01 +0200
4f8f2a
Subject: [PATCH 1/5] Mark all GIR file constants as guint64
4f8f2a
4f8f2a
See 9676585e65f69ec1c309f45ba139035408d59b8e for more information.
4f8f2a
---
4f8f2a
 src/lib/plugin_apis/btrfs.api  |  2 +-
4f8f2a
 src/lib/plugin_apis/crypto.api |  2 +-
4f8f2a
 src/lib/plugin_apis/lvm.api    | 20 ++++++++++----------
4f8f2a
 src/lib/plugin_apis/mdraid.api |  4 ++--
4f8f2a
 4 files changed, 14 insertions(+), 14 deletions(-)
4f8f2a
4f8f2a
diff --git a/src/lib/plugin_apis/btrfs.api b/src/lib/plugin_apis/btrfs.api
4f8f2a
index b52fb4ce..ef0f6c28 100644
4f8f2a
--- a/src/lib/plugin_apis/btrfs.api
4f8f2a
+++ b/src/lib/plugin_apis/btrfs.api
4f8f2a
@@ -3,7 +3,7 @@
4f8f2a
 #include <blockdev/utils.h>
4f8f2a
 
4f8f2a
 #define BD_BTRFS_MAIN_VOLUME_ID 5
4f8f2a
-#define BD_BTRFS_MIN_MEMBER_SIZE (128 MiB)
4f8f2a
+#define BD_BTRFS_MIN_MEMBER_SIZE G_GUINT64_CONSTANT (134217728ULL) // 128 MiB
4f8f2a
 
4f8f2a
 GQuark bd_btrfs_error_quark (void) {
4f8f2a
     return g_quark_from_static_string ("g-bd-btrfs-error-quark");
4f8f2a
diff --git a/src/lib/plugin_apis/crypto.api b/src/lib/plugin_apis/crypto.api
4f8f2a
index e3d69986..ef0217fe 100644
4f8f2a
--- a/src/lib/plugin_apis/crypto.api
4f8f2a
+++ b/src/lib/plugin_apis/crypto.api
4f8f2a
@@ -1,7 +1,7 @@
4f8f2a
 #include <glib.h>
4f8f2a
 #include <blockdev/utils.h>
4f8f2a
 
4f8f2a
-#define BD_CRYPTO_LUKS_METADATA_SIZE (2 MiB)
4f8f2a
+#define BD_CRYPTO_LUKS_METADATA_SIZE G_GUINT64_CONSTANT (2097152ULL) // 2 MiB
4f8f2a
 
4f8f2a
 GQuark bd_crypto_error_quark (void) {
4f8f2a
     return g_quark_from_static_string ("g-bd-crypto-error-quark");
4f8f2a
diff --git a/src/lib/plugin_apis/lvm.api b/src/lib/plugin_apis/lvm.api
4f8f2a
index 21c8f74d..ea52263b 100644
4f8f2a
--- a/src/lib/plugin_apis/lvm.api
4f8f2a
+++ b/src/lib/plugin_apis/lvm.api
4f8f2a
@@ -15,18 +15,18 @@
4f8f2a
 #define BD_LVM_MAX_LV_SIZE G_GUINT64_CONSTANT (9223372036854775808ULL)
4f8f2a
 
4f8f2a
 
4f8f2a
-#define BD_LVM_DEFAULT_PE_START (1 MiB)
4f8f2a
-#define BD_LVM_DEFAULT_PE_SIZE (4 MiB)
4f8f2a
-#define BD_LVM_MIN_PE_SIZE (1 KiB)
4f8f2a
-#define BD_LVM_MAX_PE_SIZE (16 GiB)
4f8f2a
-#define BD_LVM_MIN_THPOOL_MD_SIZE (2 MiB)
4f8f2a
-#define BD_LVM_MAX_THPOOL_MD_SIZE (16 GiB)
4f8f2a
-#define BD_LVM_MIN_THPOOL_CHUNK_SIZE (64 KiB)
4f8f2a
-#define BD_LVM_MAX_THPOOL_CHUNK_SIZE (1 GiB)
4f8f2a
-#define BD_LVM_DEFAULT_CHUNK_SIZE (64 KiB)
4f8f2a
+#define BD_LVM_DEFAULT_PE_START G_GUINT64_CONSTANT (1048576ULL) // 1 MiB
4f8f2a
+#define BD_LVM_DEFAULT_PE_SIZE G_GUINT64_CONSTANT (4194304ULL) // 4 MiB
4f8f2a
+#define BD_LVM_MIN_PE_SIZE G_GUINT64_CONSTANT (1024ULL) // 1 KiB
4f8f2a
+#define BD_LVM_MAX_PE_SIZE G_GUINT64_CONSTANT (17179869184ULL) // 16 GiB
4f8f2a
+#define BD_LVM_MIN_THPOOL_MD_SIZE G_GUINT64_CONSTANT (2097152ULL) // 2 MiB
4f8f2a
+#define BD_LVM_MAX_THPOOL_MD_SIZE G_GUINT64_CONSTANT (17179869184ULL) // 16 GiB
4f8f2a
+#define BD_LVM_MIN_THPOOL_CHUNK_SIZE G_GUINT64_CONSTANT (65536ULL) // 64 KiB
4f8f2a
+#define BD_LVM_MAX_THPOOL_CHUNK_SIZE G_GUINT64_CONSTANT (1073741824ULL) // 1 GiB
4f8f2a
+#define BD_LVM_DEFAULT_CHUNK_SIZE G_GUINT64_CONSTANT (65536ULL) // 64 KiB
4f8f2a
 
4f8f2a
 /* according to lvmcache (7) */
4f8f2a
-#define BD_LVM_MIN_CACHE_MD_SIZE (8 MiB)
4f8f2a
+#define BD_LVM_MIN_CACHE_MD_SIZE (8388608ULL) // 8 MiB
4f8f2a
 
4f8f2a
 GQuark bd_lvm_error_quark (void) {
4f8f2a
     return g_quark_from_static_string ("g-bd-lvm-error-quark");
4f8f2a
diff --git a/src/lib/plugin_apis/mdraid.api b/src/lib/plugin_apis/mdraid.api
4f8f2a
index 3bd9eaf2..02ca9530 100644
4f8f2a
--- a/src/lib/plugin_apis/mdraid.api
4f8f2a
+++ b/src/lib/plugin_apis/mdraid.api
4f8f2a
@@ -7,8 +7,8 @@
4f8f2a
 
4f8f2a
 /* taken from blivet */
4f8f2a
 // these defaults were determined empirically
4f8f2a
-#define BD_MD_SUPERBLOCK_SIZE (2 MiB)
4f8f2a
-#define BD_MD_CHUNK_SIZE (512 KiB)
4f8f2a
+#define BD_MD_SUPERBLOCK_SIZE G_GUINT64_CONSTANT (2097152ULL) // 2 MiB
4f8f2a
+#define BD_MD_CHUNK_SIZE G_GUINT64_CONSTANT (524288ULL) // 512 KiB
4f8f2a
 
4f8f2a
 GQuark bd_md_error_quark (void) {
4f8f2a
     return g_quark_from_static_string ("g-bd-md-error-quark");
4f8f2a
4f8f2a
From aeedce3bcaa8182c9878cc51d3f85a6c6eb6a01f Mon Sep 17 00:00:00 2001
4f8f2a
From: Vojtech Trefny <vtrefny@redhat.com>
4f8f2a
Date: Thu, 3 Dec 2020 14:41:25 +0100
4f8f2a
Subject: [PATCH 2/5] lvm: Set thin metadata limits to match limits LVM uses in
4f8f2a
 lvcreate
4f8f2a
4f8f2a
---
4f8f2a
 src/lib/plugin_apis/lvm.api | 4 ++--
4f8f2a
 src/plugins/lvm.h           | 9 +++++++--
4f8f2a
 tests/lvm_dbus_tests.py     | 7 ++++---
4f8f2a
 tests/lvm_test.py           | 7 ++++---
4f8f2a
 4 files changed, 17 insertions(+), 10 deletions(-)
4f8f2a
4f8f2a
diff --git a/src/lib/plugin_apis/lvm.api b/src/lib/plugin_apis/lvm.api
4f8f2a
index ea52263b..e843c916 100644
4f8f2a
--- a/src/lib/plugin_apis/lvm.api
4f8f2a
+++ b/src/lib/plugin_apis/lvm.api
4f8f2a
@@ -19,8 +19,8 @@
4f8f2a
 #define BD_LVM_DEFAULT_PE_SIZE G_GUINT64_CONSTANT (4194304ULL) // 4 MiB
4f8f2a
 #define BD_LVM_MIN_PE_SIZE G_GUINT64_CONSTANT (1024ULL) // 1 KiB
4f8f2a
 #define BD_LVM_MAX_PE_SIZE G_GUINT64_CONSTANT (17179869184ULL) // 16 GiB
4f8f2a
-#define BD_LVM_MIN_THPOOL_MD_SIZE G_GUINT64_CONSTANT (2097152ULL) // 2 MiB
4f8f2a
-#define BD_LVM_MAX_THPOOL_MD_SIZE G_GUINT64_CONSTANT (17179869184ULL) // 16 GiB
4f8f2a
+#define BD_LVM_MIN_THPOOL_MD_SIZE G_GUINT64_CONSTANT (4194304ULL) // 4 MiB
4f8f2a
+#define BD_LVM_MAX_THPOOL_MD_SIZE G_GUINT64_CONSTANT (33957085184ULL) // 31.62 GiB
4f8f2a
 #define BD_LVM_MIN_THPOOL_CHUNK_SIZE G_GUINT64_CONSTANT (65536ULL) // 64 KiB
4f8f2a
 #define BD_LVM_MAX_THPOOL_CHUNK_SIZE G_GUINT64_CONSTANT (1073741824ULL) // 1 GiB
4f8f2a
 #define BD_LVM_DEFAULT_CHUNK_SIZE G_GUINT64_CONSTANT (65536ULL) // 64 KiB
4f8f2a
diff --git a/src/plugins/lvm.h b/src/plugins/lvm.h
4f8f2a
index 4b970f2e..01c06ca4 100644
4f8f2a
--- a/src/plugins/lvm.h
4f8f2a
+++ b/src/plugins/lvm.h
4f8f2a
@@ -1,5 +1,6 @@
4f8f2a
 #include <glib.h>
4f8f2a
 #include <blockdev/utils.h>
4f8f2a
+#include <libdevmapper.h>
4f8f2a
 
4f8f2a
 #ifndef BD_LVM
4f8f2a
 #define BD_LVM
4f8f2a
@@ -21,8 +22,12 @@
4f8f2a
 #define USE_DEFAULT_PE_SIZE 0
4f8f2a
 #define RESOLVE_PE_SIZE(size) ((size) == USE_DEFAULT_PE_SIZE ? BD_LVM_DEFAULT_PE_SIZE : (size))
4f8f2a
 
4f8f2a
-#define BD_LVM_MIN_THPOOL_MD_SIZE (2 MiB)
4f8f2a
-#define BD_LVM_MAX_THPOOL_MD_SIZE (16 GiB)
4f8f2a
+/* lvm constants for thin pool metadata size are actually half of these
4f8f2a
+   but when they calculate the actual metadata size they double the limits
4f8f2a
+   so lets just double the limits here too */
4f8f2a
+#define BD_LVM_MIN_THPOOL_MD_SIZE (4 MiB)
4f8f2a
+#define BD_LVM_MAX_THPOOL_MD_SIZE (DM_THIN_MAX_METADATA_SIZE KiB)
4f8f2a
+
4f8f2a
 #define BD_LVM_MIN_THPOOL_CHUNK_SIZE (64 KiB)
4f8f2a
 #define BD_LVM_MAX_THPOOL_CHUNK_SIZE (1 GiB)
4f8f2a
 #define BD_LVM_DEFAULT_CHUNK_SIZE (64 KiB)
4f8f2a
diff --git a/tests/lvm_dbus_tests.py b/tests/lvm_dbus_tests.py
4f8f2a
index 47402fc3..b517aae9 100644
4f8f2a
--- a/tests/lvm_dbus_tests.py
4f8f2a
+++ b/tests/lvm_dbus_tests.py
4f8f2a
@@ -160,12 +160,13 @@ def test_get_thpool_meta_size(self):
4f8f2a
     def test_is_valid_thpool_md_size(self):
4f8f2a
         """Verify that is_valid_thpool_md_size works as expected"""
4f8f2a
 
4f8f2a
-        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(2 * 1024**2))
4f8f2a
-        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(3 * 1024**2))
4f8f2a
+        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(4 * 1024**2))
4f8f2a
+        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(5 * 1024**2))
4f8f2a
         self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(16 * 1024**3))
4f8f2a
 
4f8f2a
         self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(1 * 1024**2))
4f8f2a
-        self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(17 * 1024**3))
4f8f2a
+        self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(3 * 1024**2))
4f8f2a
+        self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(32 * 1024**3))
4f8f2a
 
4f8f2a
     @tag_test(TestTags.NOSTORAGE)
4f8f2a
     def test_is_valid_thpool_chunk_size(self):
4f8f2a
diff --git a/tests/lvm_test.py b/tests/lvm_test.py
4f8f2a
index 149cf54a..d0085651 100644
4f8f2a
--- a/tests/lvm_test.py
4f8f2a
+++ b/tests/lvm_test.py
4f8f2a
@@ -153,12 +153,13 @@ def test_get_thpool_meta_size(self):
4f8f2a
     def test_is_valid_thpool_md_size(self):
4f8f2a
         """Verify that is_valid_thpool_md_size works as expected"""
4f8f2a
 
4f8f2a
-        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(2 * 1024**2))
4f8f2a
-        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(3 * 1024**2))
4f8f2a
+        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(4 * 1024**2))
4f8f2a
+        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(5 * 1024**2))
4f8f2a
         self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(16 * 1024**3))
4f8f2a
 
4f8f2a
         self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(1 * 1024**2))
4f8f2a
-        self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(17 * 1024**3))
4f8f2a
+        self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(3 * 1024**2))
4f8f2a
+        self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(32 * 1024**3))
4f8f2a
 
4f8f2a
     @tag_test(TestTags.NOSTORAGE)
4f8f2a
     def test_is_valid_thpool_chunk_size(self):
4f8f2a
4f8f2a
From 15fcf1bb62865083a3483fc51f45e11cdc2d7386 Mon Sep 17 00:00:00 2001
4f8f2a
From: Vojtech Trefny <vtrefny@redhat.com>
4f8f2a
Date: Thu, 3 Dec 2020 14:46:00 +0100
4f8f2a
Subject: [PATCH 3/5] lvm: Do not use thin_metadata_size to recommend thin
4f8f2a
 metadata size
4f8f2a
4f8f2a
thin_metadata_size calculates the metadata size differently and
4f8f2a
recommends smaller metadata than lvcreate so we should use the
4f8f2a
lvcreate formula instead.
4f8f2a
4f8f2a
Resolves: rhbz#1898668
4f8f2a
---
4f8f2a
 dist/libblockdev.spec.in            |  4 --
4f8f2a
 src/lib/plugin_apis/lvm.api         |  8 +--
4f8f2a
 src/plugins/lvm-dbus.c              | 78 ++++++-----------------------
4f8f2a
 src/plugins/lvm.c                   | 66 +++++++-----------------
4f8f2a
 src/python/gi/overrides/BlockDev.py |  6 +++
4f8f2a
 tests/library_test.py               |  6 +--
4f8f2a
 tests/lvm_dbus_tests.py             | 20 ++++----
4f8f2a
 tests/lvm_test.py                   | 15 ++----
4f8f2a
 tests/utils.py                      |  2 +-
4f8f2a
 9 files changed, 61 insertions(+), 144 deletions(-)
4f8f2a
4f8f2a
diff --git a/dist/libblockdev.spec.in b/dist/libblockdev.spec.in
4f8f2a
index 7c775174..3e0a53c6 100644
4f8f2a
--- a/dist/libblockdev.spec.in
4f8f2a
+++ b/dist/libblockdev.spec.in
4f8f2a
@@ -387,8 +387,6 @@ BuildRequires: device-mapper-devel
4f8f2a
 Summary:     The LVM plugin for the libblockdev library
4f8f2a
 Requires: %{name}-utils%{?_isa} >= 0.11
4f8f2a
 Requires: lvm2
4f8f2a
-# for thin_metadata_size
4f8f2a
-Requires: device-mapper-persistent-data
4f8f2a
 
4f8f2a
 %description lvm
4f8f2a
 The libblockdev library plugin (and in the same time a standalone library)
4f8f2a
@@ -411,8 +409,6 @@ BuildRequires: device-mapper-devel
4f8f2a
 Summary:     The LVM plugin for the libblockdev library
4f8f2a
 Requires: %{name}-utils%{?_isa} >= 1.4
4f8f2a
 Requires: lvm2-dbusd >= 2.02.156
4f8f2a
-# for thin_metadata_size
4f8f2a
-Requires: device-mapper-persistent-data
4f8f2a
 
4f8f2a
 %description lvm-dbus
4f8f2a
 The libblockdev library plugin (and in the same time a standalone library)
4f8f2a
diff --git a/src/lib/plugin_apis/lvm.api b/src/lib/plugin_apis/lvm.api
4f8f2a
index e843c916..9f25c1ed 100644
4f8f2a
--- a/src/lib/plugin_apis/lvm.api
4f8f2a
+++ b/src/lib/plugin_apis/lvm.api
4f8f2a
@@ -704,11 +704,13 @@ guint64 bd_lvm_get_thpool_padding (guint64 size, guint64 pe_size, gboolean inclu
4f8f2a
  * bd_lvm_get_thpool_meta_size:
4f8f2a
  * @size: size of the thin pool
4f8f2a
  * @chunk_size: chunk size of the thin pool or 0 to use the default (%BD_LVM_DEFAULT_CHUNK_SIZE)
4f8f2a
- * @n_snapshots: number of snapshots that will be created in the pool
4f8f2a
+ * @n_snapshots: ignored
4f8f2a
  * @error: (out): place to store error (if any)
4f8f2a
  *
4f8f2a
- * Returns: recommended size of the metadata space for the specified pool or 0
4f8f2a
- *          in case of error
4f8f2a
+ * Note: This function will be changed in 3.0: the @n_snapshots parameter
4f8f2a
+ *       is currently not used and will be removed.
4f8f2a
+ *
4f8f2a
+ * Returns: recommended size of the metadata space for the specified pool
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_THIN_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
diff --git a/src/plugins/lvm-dbus.c b/src/plugins/lvm-dbus.c
4f8f2a
index 9f821a99..24d54426 100644
4f8f2a
--- a/src/plugins/lvm-dbus.c
4f8f2a
+++ b/src/plugins/lvm-dbus.c
4f8f2a
@@ -20,7 +20,6 @@
4f8f2a
 #include <glib.h>
4f8f2a
 #include <math.h>
4f8f2a
 #include <string.h>
4f8f2a
-#include <libdevmapper.h>
4f8f2a
 #include <unistd.h>
4f8f2a
 #include <blockdev/utils.h>
4f8f2a
 #include <gio/gio.h>
4f8f2a
@@ -248,14 +247,6 @@ static volatile guint avail_features = 0;
4f8f2a
 static volatile guint avail_module_deps = 0;
4f8f2a
 static GMutex deps_check_lock;
4f8f2a
 
4f8f2a
-#define DEPS_THMS 0
4f8f2a
-#define DEPS_THMS_MASK (1 << DEPS_THMS)
4f8f2a
-#define DEPS_LAST 1
4f8f2a
-
4f8f2a
-static const UtilDep deps[DEPS_LAST] = {
4f8f2a
-    {"thin_metadata_size", NULL, NULL, NULL},
4f8f2a
-};
4f8f2a
-
4f8f2a
 #define DBUS_DEPS_LVMDBUSD 0
4f8f2a
 #define DBUS_DEPS_LVMDBUSD_MASK (1 << DBUS_DEPS_LVMDBUSD)
4f8f2a
 #define DBUS_DEPS_LAST 1
4f8f2a
@@ -301,17 +292,6 @@ gboolean bd_lvm_check_deps (void) {
4f8f2a
         check_ret = check_ret && success;
4f8f2a
     }
4f8f2a
 
4f8f2a
-    for (i=0; i < DEPS_LAST; i++) {
4f8f2a
-        success = bd_utils_check_util_version (deps[i].name, deps[i].version,
4f8f2a
-                                               deps[i].ver_arg, deps[i].ver_regexp, &error);
4f8f2a
-        if (!success)
4f8f2a
-            g_warning ("%s", error->message);
4f8f2a
-        else
4f8f2a
-            g_atomic_int_or (&avail_deps, 1 << i);
4f8f2a
-        g_clear_error (&error);
4f8f2a
-        check_ret = check_ret && success;
4f8f2a
-    }
4f8f2a
-
4f8f2a
     if (!check_ret)
4f8f2a
         g_warning("Cannot load the LVM plugin");
4f8f2a
 
4f8f2a
@@ -386,10 +366,7 @@ gboolean bd_lvm_is_tech_avail (BDLVMTech tech, guint64 mode, GError **error) {
4f8f2a
             g_set_error (error, BD_LVM_ERROR, BD_LVM_ERROR_TECH_UNAVAIL,
4f8f2a
                          "Only 'query' supported for thin calculations");
4f8f2a
             return FALSE;
4f8f2a
-        } else if ((mode & BD_LVM_TECH_MODE_QUERY) &&
4f8f2a
-            !check_deps (&avail_deps, DEPS_THMS_MASK, deps, DEPS_LAST, &deps_check_lock, error))
4f8f2a
-            return FALSE;
4f8f2a
-        else
4f8f2a
+        } else
4f8f2a
             return TRUE;
4f8f2a
     case BD_LVM_TECH_CALCS:
4f8f2a
         if (mode & ~BD_LVM_TECH_MODE_QUERY) {
4f8f2a
@@ -1303,53 +1280,28 @@ guint64 bd_lvm_get_thpool_padding (guint64 size, guint64 pe_size, gboolean inclu
4f8f2a
  * bd_lvm_get_thpool_meta_size:
4f8f2a
  * @size: size of the thin pool
4f8f2a
  * @chunk_size: chunk size of the thin pool or 0 to use the default (%BD_LVM_DEFAULT_CHUNK_SIZE)
4f8f2a
- * @n_snapshots: number of snapshots that will be created in the pool
4f8f2a
+ * @n_snapshots: ignored
4f8f2a
  * @error: (out): place to store error (if any)
4f8f2a
  *
4f8f2a
- * Returns: recommended size of the metadata space for the specified pool or 0
4f8f2a
- *          in case of error
4f8f2a
+ * Note: This function will be changed in 3.0: the @n_snapshots parameter
4f8f2a
+ *       is currently not used and will be removed.
4f8f2a
+ *
4f8f2a
+ * Returns: recommended size of the metadata space for the specified pool
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_THIN_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-guint64 bd_lvm_get_thpool_meta_size (guint64 size, guint64 chunk_size, guint64 n_snapshots, GError **error) {
4f8f2a
-    /* ub - output in bytes, n - output just the number */
4f8f2a
-    const gchar* args[7] = {"thin_metadata_size", "-ub", "-n", NULL, NULL, NULL, NULL};
4f8f2a
-    gchar *output = NULL;
4f8f2a
-    gboolean success = FALSE;
4f8f2a
-    guint64 ret = 0;
4f8f2a
-
4f8f2a
-    if (!check_deps (&avail_deps, DEPS_THMS_MASK, deps, DEPS_LAST, &deps_check_lock, error))
4f8f2a
-        return 0;
4f8f2a
+guint64 bd_lvm_get_thpool_meta_size (guint64 size, guint64 chunk_size, guint64 n_snapshots UNUSED, GError **error UNUSED) {
4f8f2a
+    guint64 md_size = 0;
4f8f2a
 
4f8f2a
-    /* s - total size, b - chunk size, m - number of snapshots */
4f8f2a
-    args[3] = g_strdup_printf ("-s%"G_GUINT64_FORMAT, size);
4f8f2a
-    args[4] = g_strdup_printf ("-b%"G_GUINT64_FORMAT,
4f8f2a
-                               chunk_size != 0 ? chunk_size : (guint64) BD_LVM_DEFAULT_CHUNK_SIZE);
4f8f2a
-    args[5] = g_strdup_printf ("-m%"G_GUINT64_FORMAT, n_snapshots);
4f8f2a
-
4f8f2a
-    success = bd_utils_exec_and_capture_output (args, NULL, &output, error);
4f8f2a
-    g_free ((gchar*) args[3]);
4f8f2a
-    g_free ((gchar*) args[4]);
4f8f2a
-    g_free ((gchar*) args[5]);
4f8f2a
-
4f8f2a
-    if (!success) {
4f8f2a
-        /* error is already set */
4f8f2a
-        g_free (output);
4f8f2a
-        return 0;
4f8f2a
-    }
4f8f2a
-
4f8f2a
-    ret = g_ascii_strtoull (output, NULL, 0);
4f8f2a
-    if (ret == 0) {
4f8f2a
-        g_set_error (error, BD_LVM_ERROR, BD_LVM_ERROR_PARSE,
4f8f2a
-                     "Failed to parse number from thin_metadata_size's output: '%s'",
4f8f2a
-                     output);
4f8f2a
-        g_free (output);
4f8f2a
-        return 0;
4f8f2a
-    }
4f8f2a
+    /* based on lvcreate metadata size calculation */
4f8f2a
+    md_size = UINT64_C(64) * size / (chunk_size ? chunk_size : BD_LVM_DEFAULT_CHUNK_SIZE);
4f8f2a
 
4f8f2a
-    g_free (output);
4f8f2a
+    if (md_size > BD_LVM_MAX_THPOOL_MD_SIZE)
4f8f2a
+        md_size = BD_LVM_MAX_THPOOL_MD_SIZE;
4f8f2a
+    else if (md_size < BD_LVM_MIN_THPOOL_MD_SIZE)
4f8f2a
+        md_size = BD_LVM_MIN_THPOOL_MD_SIZE;
4f8f2a
 
4f8f2a
-    return MAX (ret, BD_LVM_MIN_THPOOL_MD_SIZE);
4f8f2a
+    return md_size;
4f8f2a
 }
4f8f2a
 
4f8f2a
 /**
4f8f2a
diff --git a/src/plugins/lvm.c b/src/plugins/lvm.c
4f8f2a
index 6bfaa338..74493feb 100644
4f8f2a
--- a/src/plugins/lvm.c
4f8f2a
+++ b/src/plugins/lvm.c
4f8f2a
@@ -20,7 +20,6 @@
4f8f2a
 #include <glib.h>
4f8f2a
 #include <math.h>
4f8f2a
 #include <string.h>
4f8f2a
-#include <libdevmapper.h>
4f8f2a
 #include <unistd.h>
4f8f2a
 #include <blockdev/utils.h>
4f8f2a
 
4f8f2a
@@ -213,13 +212,10 @@ static GMutex deps_check_lock;
4f8f2a
 
4f8f2a
 #define DEPS_LVM 0
4f8f2a
 #define DEPS_LVM_MASK (1 << DEPS_LVM)
4f8f2a
-#define DEPS_THMS 1
4f8f2a
-#define DEPS_THMS_MASK (1 << DEPS_THMS)
4f8f2a
-#define DEPS_LAST 2
4f8f2a
+#define DEPS_LAST 1
4f8f2a
 
4f8f2a
 static const UtilDep deps[DEPS_LAST] = {
4f8f2a
     {"lvm", LVM_MIN_VERSION, "version", "LVM version:\\s+([\\d\\.]+)"},
4f8f2a
-    {"thin_metadata_size", NULL, NULL, NULL},
4f8f2a
 };
4f8f2a
 
4f8f2a
 #define FEATURES_VDO 0
4f8f2a
@@ -236,6 +232,8 @@ static const UtilFeatureDep features[FEATURES_LAST] = {
4f8f2a
 
4f8f2a
 static const gchar*const module_deps[MODULE_DEPS_LAST] = { "kvdo" };
4f8f2a
 
4f8f2a
+#define UNUSED __attribute__((unused))
4f8f2a
+
4f8f2a
 /**
4f8f2a
  * bd_lvm_check_deps:
4f8f2a
  *
4f8f2a
@@ -317,10 +315,7 @@ gboolean bd_lvm_is_tech_avail (BDLVMTech tech, guint64 mode, GError **error) {
4f8f2a
             g_set_error (error, BD_LVM_ERROR, BD_LVM_ERROR_TECH_UNAVAIL,
4f8f2a
                          "Only 'query' supported for thin calculations");
4f8f2a
             return FALSE;
4f8f2a
-        } else if ((mode & BD_LVM_TECH_MODE_QUERY) &&
4f8f2a
-            !check_deps (&avail_deps, DEPS_THMS_MASK, deps, DEPS_LAST, &deps_check_lock, error))
4f8f2a
-            return FALSE;
4f8f2a
-        else
4f8f2a
+        } else
4f8f2a
             return TRUE;
4f8f2a
     case BD_LVM_TECH_CALCS:
4f8f2a
         if (mode & ~BD_LVM_TECH_MODE_QUERY) {
4f8f2a
@@ -820,53 +815,28 @@ guint64 bd_lvm_get_thpool_padding (guint64 size, guint64 pe_size, gboolean inclu
4f8f2a
  * bd_lvm_get_thpool_meta_size:
4f8f2a
  * @size: size of the thin pool
4f8f2a
  * @chunk_size: chunk size of the thin pool or 0 to use the default (%BD_LVM_DEFAULT_CHUNK_SIZE)
4f8f2a
- * @n_snapshots: number of snapshots that will be created in the pool
4f8f2a
+ * @n_snapshots: ignored
4f8f2a
  * @error: (out): place to store error (if any)
4f8f2a
  *
4f8f2a
- * Returns: recommended size of the metadata space for the specified pool or 0
4f8f2a
- *          in case of error
4f8f2a
+ * Note: This function will be changed in 3.0: the @n_snapshots parameter
4f8f2a
+ *       is currently not used and will be removed.
4f8f2a
+ *
4f8f2a
+ * Returns: recommended size of the metadata space for the specified pool
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_THIN_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-guint64 bd_lvm_get_thpool_meta_size (guint64 size, guint64 chunk_size, guint64 n_snapshots, GError **error) {
4f8f2a
-    /* ub - output in bytes, n - output just the number */
4f8f2a
-    const gchar* args[7] = {"thin_metadata_size", "-ub", "-n", NULL, NULL, NULL, NULL};
4f8f2a
-    gchar *output = NULL;
4f8f2a
-    gboolean success = FALSE;
4f8f2a
-    guint64 ret = 0;
4f8f2a
-
4f8f2a
-    if (!check_deps (&avail_deps, DEPS_THMS_MASK, deps, DEPS_LAST, &deps_check_lock, error))
4f8f2a
-        return 0;
4f8f2a
+guint64 bd_lvm_get_thpool_meta_size (guint64 size, guint64 chunk_size, guint64 n_snapshots UNUSED, GError **error UNUSED) {
4f8f2a
+    guint64 md_size = 0;
4f8f2a
 
4f8f2a
-    /* s - total size, b - chunk size, m - number of snapshots */
4f8f2a
-    args[3] = g_strdup_printf ("-s%"G_GUINT64_FORMAT, size);
4f8f2a
-    args[4] = g_strdup_printf ("-b%"G_GUINT64_FORMAT,
4f8f2a
-                               chunk_size != 0 ? chunk_size : (guint64) BD_LVM_DEFAULT_CHUNK_SIZE);
4f8f2a
-    args[5] = g_strdup_printf ("-m%"G_GUINT64_FORMAT, n_snapshots);
4f8f2a
+    /* based on lvcreate metadata size calculation */
4f8f2a
+    md_size = UINT64_C(64) * size / (chunk_size ? chunk_size : BD_LVM_DEFAULT_CHUNK_SIZE);
4f8f2a
 
4f8f2a
-    success = bd_utils_exec_and_capture_output (args, NULL, &output, error);
4f8f2a
-    g_free ((gchar*) args[3]);
4f8f2a
-    g_free ((gchar*) args[4]);
4f8f2a
-    g_free ((gchar*) args[5]);
4f8f2a
-
4f8f2a
-    if (!success) {
4f8f2a
-        /* error is already set */
4f8f2a
-        g_free (output);
4f8f2a
-        return 0;
4f8f2a
-    }
4f8f2a
-
4f8f2a
-    ret = g_ascii_strtoull (output, NULL, 0);
4f8f2a
-    if (ret == 0) {
4f8f2a
-        g_set_error (error, BD_LVM_ERROR, BD_LVM_ERROR_PARSE,
4f8f2a
-                     "Failed to parse number from thin_metadata_size's output: '%s'",
4f8f2a
-                     output);
4f8f2a
-        g_free (output);
4f8f2a
-        return 0;
4f8f2a
-    }
4f8f2a
-
4f8f2a
-    g_free (output);
4f8f2a
+    if (md_size > BD_LVM_MAX_THPOOL_MD_SIZE)
4f8f2a
+        md_size = BD_LVM_MAX_THPOOL_MD_SIZE;
4f8f2a
+    else if (md_size < BD_LVM_MIN_THPOOL_MD_SIZE)
4f8f2a
+        md_size = BD_LVM_MIN_THPOOL_MD_SIZE;
4f8f2a
 
4f8f2a
-    return MAX (ret, BD_LVM_MIN_THPOOL_MD_SIZE);
4f8f2a
+    return md_size;
4f8f2a
 }
4f8f2a
 
4f8f2a
 /**
4f8f2a
diff --git a/src/python/gi/overrides/BlockDev.py b/src/python/gi/overrides/BlockDev.py
4f8f2a
index d78bfaab..f768c8bd 100644
4f8f2a
--- a/src/python/gi/overrides/BlockDev.py
4f8f2a
+++ b/src/python/gi/overrides/BlockDev.py
4f8f2a
@@ -462,6 +462,12 @@ def lvm_get_thpool_padding(size, pe_size=0, included=False):
4f8f2a
     return _lvm_get_thpool_padding(size, pe_size, included)
4f8f2a
 __all__.append("lvm_get_thpool_padding")
4f8f2a
 
4f8f2a
+_lvm_get_thpool_meta_size = BlockDev.lvm_get_thpool_meta_size
4f8f2a
+@override(BlockDev.lvm_get_thpool_meta_size)
4f8f2a
+def lvm_get_thpool_meta_size(size, chunk_size=0, n_snapshots=0):
4f8f2a
+    return _lvm_get_thpool_meta_size(size, chunk_size, n_snapshots)
4f8f2a
+__all__.append("lvm_get_thpool_meta_size")
4f8f2a
+
4f8f2a
 _lvm_pvcreate = BlockDev.lvm_pvcreate
4f8f2a
 @override(BlockDev.lvm_pvcreate)
4f8f2a
 def lvm_pvcreate(device, data_alignment=0, metadata_size=0, extra=None, **kwargs):
4f8f2a
diff --git a/tests/library_test.py b/tests/library_test.py
4f8f2a
index e8bb175a..08e44fdc 100644
4f8f2a
--- a/tests/library_test.py
4f8f2a
+++ b/tests/library_test.py
4f8f2a
@@ -349,8 +349,7 @@ def test_try_reinit(self):
4f8f2a
 
4f8f2a
         # try reinitializing with only some utilities being available and thus
4f8f2a
         # only some plugins able to load
4f8f2a
-        with fake_path("tests/lib_missing_utils", keep_utils=["swapon", "swapoff", "mkswap", "lvm",
4f8f2a
-                                                              "thin_metadata_size", "swaplabel"]):
4f8f2a
+        with fake_path("tests/lib_missing_utils", keep_utils=["swapon", "swapoff", "mkswap", "lvm", "swaplabel"]):
4f8f2a
             succ, loaded = BlockDev.try_reinit(self.requested_plugins, True, None)
4f8f2a
             self.assertFalse(succ)
4f8f2a
             for plug_name in ("swap", "lvm", "crypto"):
4f8f2a
@@ -361,8 +360,7 @@ def test_try_reinit(self):
4f8f2a
 
4f8f2a
         # now the same with a subset of plugins requested
4f8f2a
         plugins = BlockDev.plugin_specs_from_names(["lvm", "swap", "crypto"])
4f8f2a
-        with fake_path("tests/lib_missing_utils", keep_utils=["swapon", "swapoff", "mkswap", "lvm",
4f8f2a
-                                                              "thin_metadata_size", "swaplabel"]):
4f8f2a
+        with fake_path("tests/lib_missing_utils", keep_utils=["swapon", "swapoff", "mkswap", "lvm","swaplabel"]):
4f8f2a
             succ, loaded = BlockDev.try_reinit(plugins, True, None)
4f8f2a
             self.assertTrue(succ)
4f8f2a
             self.assertEqual(set(loaded), set(["swap", "lvm", "crypto"]))
4f8f2a
diff --git a/tests/lvm_dbus_tests.py b/tests/lvm_dbus_tests.py
4f8f2a
index b517aae9..c06a480c 100644
4f8f2a
--- a/tests/lvm_dbus_tests.py
4f8f2a
+++ b/tests/lvm_dbus_tests.py
4f8f2a
@@ -141,21 +141,19 @@ def test_get_thpool_padding(self):
4f8f2a
     def test_get_thpool_meta_size(self):
4f8f2a
         """Verify that getting recommended thin pool metadata size works as expected"""
4f8f2a
 
4f8f2a
-        # no idea how thin_metadata_size works, but let's at least check that
4f8f2a
-        # the function works and returns what thin_metadata_size says
4f8f2a
-        out1 = subprocess.check_output(["thin_metadata_size", "-ub", "-n", "-b64k", "-s1t", "-m100"])
4f8f2a
-        self.assertEqual(int(out1), BlockDev.lvm_get_thpool_meta_size (1 * 1024**4, 64 * 1024, 100))
4f8f2a
+        # metadata size is calculated as 64 * pool_size / chunk_size
4f8f2a
+        self.assertEqual(BlockDev.lvm_get_thpool_meta_size(1 * 1024**4, 64 * 1024), 1 * 1024**3)
4f8f2a
 
4f8f2a
-        out2 = subprocess.check_output(["thin_metadata_size", "-ub", "-n", "-b128k", "-s1t", "-m100"])
4f8f2a
-        self.assertEqual(int(out2), BlockDev.lvm_get_thpool_meta_size (1 * 1024**4, 128 * 1024, 100))
4f8f2a
+        self.assertEqual(BlockDev.lvm_get_thpool_meta_size(1 * 1024**4, 128 * 1024),  512 * 1024**2)
4f8f2a
 
4f8f2a
-        # twice the chunk_size -> roughly half the metadata needed
4f8f2a
-        self.assertAlmostEqual(float(out1) / float(out2), 2, places=2)
4f8f2a
-
4f8f2a
-        # unless thin_metadata_size gives a value that is not valid (too small)
4f8f2a
-        self.assertEqual(BlockDev.lvm_get_thpool_meta_size (100 * 1024**2, 128 * 1024, 100),
4f8f2a
+        # lower limit is 4 MiB
4f8f2a
+        self.assertEqual(BlockDev.lvm_get_thpool_meta_size(100 * 1024**2, 128 * 1024),
4f8f2a
                          BlockDev.LVM_MIN_THPOOL_MD_SIZE)
4f8f2a
 
4f8f2a
+        # upper limit is 31.62 GiB
4f8f2a
+        self.assertEqual(BlockDev.lvm_get_thpool_meta_size(100 * 1024**4, 64 * 1024),
4f8f2a
+                         BlockDev.LVM_MAX_THPOOL_MD_SIZE)
4f8f2a
+
4f8f2a
     @tag_test(TestTags.NOSTORAGE)
4f8f2a
     def test_is_valid_thpool_md_size(self):
4f8f2a
         """Verify that is_valid_thpool_md_size works as expected"""
4f8f2a
diff --git a/tests/lvm_test.py b/tests/lvm_test.py
4f8f2a
index d0085651..b84adece 100644
4f8f2a
--- a/tests/lvm_test.py
4f8f2a
+++ b/tests/lvm_test.py
4f8f2a
@@ -134,19 +134,14 @@ def test_get_thpool_padding(self):
4f8f2a
     def test_get_thpool_meta_size(self):
4f8f2a
         """Verify that getting recommended thin pool metadata size works as expected"""
4f8f2a
 
4f8f2a
-        # no idea how thin_metadata_size works, but let's at least check that
4f8f2a
-        # the function works and returns what thin_metadata_size says
4f8f2a
-        out1 = subprocess.check_output(["thin_metadata_size", "-ub", "-n", "-b64k", "-s1t", "-m100"])
4f8f2a
-        self.assertEqual(int(out1), BlockDev.lvm_get_thpool_meta_size (1 * 1024**4, 64 * 1024, 100))
4f8f2a
 
4f8f2a
-        out2 = subprocess.check_output(["thin_metadata_size", "-ub", "-n", "-b128k", "-s1t", "-m100"])
4f8f2a
-        self.assertEqual(int(out2), BlockDev.lvm_get_thpool_meta_size (1 * 1024**4, 128 * 1024, 100))
4f8f2a
+        self.assertEqual(BlockDev.lvm_get_thpool_meta_size(1 * 1024**4, 64 * 1024),
4f8f2a
+                         1 * 1024**3)
4f8f2a
 
4f8f2a
-        # twice the chunk_size -> roughly half the metadata needed
4f8f2a
-        self.assertAlmostEqual(float(out1) / float(out2), 2, places=2)
4f8f2a
+        self.assertEqual(BlockDev.lvm_get_thpool_meta_size(1 * 1024**4, 128 * 1024),
4f8f2a
+                         512 * 1024**2)
4f8f2a
 
4f8f2a
-        # unless thin_metadata_size gives a value that is not valid (too small)
4f8f2a
-        self.assertEqual(BlockDev.lvm_get_thpool_meta_size (100 * 1024**2, 128 * 1024, 100),
4f8f2a
+        self.assertEqual(BlockDev.lvm_get_thpool_meta_size(100 * 1024**2, 128 * 1024),
4f8f2a
                          BlockDev.LVM_MIN_THPOOL_MD_SIZE)
4f8f2a
 
4f8f2a
     @tag_test(TestTags.NOSTORAGE)
4f8f2a
diff --git a/tests/utils.py b/tests/utils.py
4f8f2a
index 182eda6a..584fde5c 100644
4f8f2a
--- a/tests/utils.py
4f8f2a
+++ b/tests/utils.py
4f8f2a
@@ -70,7 +70,7 @@ def fake_utils(path="."):
4f8f2a
     finally:
4f8f2a
         os.environ["PATH"] = old_path
4f8f2a
 
4f8f2a
-ALL_UTILS = {"lvm", "thin_metadata_size", "btrfs", "mkswap", "swaplabel", "multipath", "mpathconf", "dmsetup", "mdadm", "make-bcache", "sgdisk", "sfdisk"}
4f8f2a
+ALL_UTILS = {"lvm", "btrfs", "mkswap", "swaplabel", "multipath", "mpathconf", "dmsetup", "mdadm", "make-bcache", "sgdisk", "sfdisk"}
4f8f2a
 
4f8f2a
 @contextmanager
4f8f2a
 def fake_path(path=None, keep_utils=None, all_but=None):
4f8f2a
4f8f2a
From 27961a3fcb205ea51f40668d68765dd8d388777b Mon Sep 17 00:00:00 2001
4f8f2a
From: Vojtech Trefny <vtrefny@redhat.com>
4f8f2a
Date: Thu, 3 Dec 2020 14:48:08 +0100
4f8f2a
Subject: [PATCH 4/5] lvm: Use the UNUSED macro instead of
4f8f2a
 __attribute__((unused))
4f8f2a
4f8f2a
for unused attributes. It makes the function definition a little
4f8f2a
bit more readable.
4f8f2a
---
4f8f2a
 src/plugins/lvm-dbus.c | 24 ++++++++++++------------
4f8f2a
 src/plugins/lvm.c      | 20 ++++++++++----------
4f8f2a
 2 files changed, 22 insertions(+), 22 deletions(-)
4f8f2a
4f8f2a
diff --git a/src/plugins/lvm-dbus.c b/src/plugins/lvm-dbus.c
4f8f2a
index 24d54426..b7b4480e 100644
4f8f2a
--- a/src/plugins/lvm-dbus.c
4f8f2a
+++ b/src/plugins/lvm-dbus.c
4f8f2a
@@ -959,7 +959,7 @@ static BDLVMPVdata* get_pv_data_from_props (GVariant *props, GError **error) {
4f8f2a
     return data;
4f8f2a
 }
4f8f2a
 
4f8f2a
-static BDLVMVGdata* get_vg_data_from_props (GVariant *props, GError **error __attribute__((unused))) {
4f8f2a
+static BDLVMVGdata* get_vg_data_from_props (GVariant *props, GError **error UNUSED) {
4f8f2a
     BDLVMVGdata *data = g_new0 (BDLVMVGdata, 1);
4f8f2a
     GVariantDict dict;
4f8f2a
 
4f8f2a
@@ -1061,7 +1061,7 @@ static BDLVMLVdata* get_lv_data_from_props (GVariant *props, GError **error) {
4f8f2a
     return data;
4f8f2a
 }
4f8f2a
 
4f8f2a
-static BDLVMVDOPooldata* get_vdo_data_from_props (GVariant *props, GError **error __attribute__((unused))) {
4f8f2a
+static BDLVMVDOPooldata* get_vdo_data_from_props (GVariant *props, GError **error UNUSED) {
4f8f2a
     BDLVMVDOPooldata *data = g_new0 (BDLVMVDOPooldata, 1);
4f8f2a
     GVariantDict dict;
4f8f2a
     gchar *value = NULL;
4f8f2a
@@ -1165,7 +1165,7 @@ static GVariant* create_size_str_param (guint64 size, const gchar *unit) {
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-gboolean bd_lvm_is_supported_pe_size (guint64 size, GError **error __attribute__((unused))) {
4f8f2a
+gboolean bd_lvm_is_supported_pe_size (guint64 size, GError **error UNUSED) {
4f8f2a
     return (((size % 2) == 0) && (size >= (BD_LVM_MIN_PE_SIZE)) && (size <= (BD_LVM_MAX_PE_SIZE)));
4f8f2a
 }
4f8f2a
 
4f8f2a
@@ -1177,7 +1177,7 @@ gboolean bd_lvm_is_supported_pe_size (guint64 size, GError **error __attribute__
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-guint64 *bd_lvm_get_supported_pe_sizes (GError **error __attribute__((unused))) {
4f8f2a
+guint64 *bd_lvm_get_supported_pe_sizes (GError **error UNUSED) {
4f8f2a
     guint8 i;
4f8f2a
     guint64 val = BD_LVM_MIN_PE_SIZE;
4f8f2a
     guint8 num_items = ((guint8) round (log2 ((double) BD_LVM_MAX_PE_SIZE))) - ((guint8) round (log2 ((double) BD_LVM_MIN_PE_SIZE))) + 2;
4f8f2a
@@ -1199,7 +1199,7 @@ guint64 *bd_lvm_get_supported_pe_sizes (GError **error __attribute__((unused)))
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-guint64 bd_lvm_get_max_lv_size (GError **error __attribute__((unused))) {
4f8f2a
+guint64 bd_lvm_get_max_lv_size (GError **error UNUSED) {
4f8f2a
     return BD_LVM_MAX_LV_SIZE;
4f8f2a
 }
4f8f2a
 
4f8f2a
@@ -1219,7 +1219,7 @@ guint64 bd_lvm_get_max_lv_size (GError **error __attribute__((unused))) {
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-guint64 bd_lvm_round_size_to_pe (guint64 size, guint64 pe_size, gboolean roundup, GError **error __attribute__((unused))) {
4f8f2a
+guint64 bd_lvm_round_size_to_pe (guint64 size, guint64 pe_size, gboolean roundup, GError **error UNUSED) {
4f8f2a
     pe_size = RESOLVE_PE_SIZE(pe_size);
4f8f2a
     guint64 delta = size % pe_size;
4f8f2a
     if (delta == 0)
4f8f2a
@@ -1313,7 +1313,7 @@ guint64 bd_lvm_get_thpool_meta_size (guint64 size, guint64 chunk_size, guint64 n
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_THIN_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-gboolean bd_lvm_is_valid_thpool_md_size (guint64 size, GError **error __attribute__((unused))) {
4f8f2a
+gboolean bd_lvm_is_valid_thpool_md_size (guint64 size, GError **error UNUSED) {
4f8f2a
     return ((BD_LVM_MIN_THPOOL_MD_SIZE <= size) && (size <= BD_LVM_MAX_THPOOL_MD_SIZE));
4f8f2a
 }
4f8f2a
 
4f8f2a
@@ -1327,7 +1327,7 @@ gboolean bd_lvm_is_valid_thpool_md_size (guint64 size, GError **error __attribut
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_THIN_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-gboolean bd_lvm_is_valid_thpool_chunk_size (guint64 size, gboolean discard, GError **error __attribute__((unused))) {
4f8f2a
+gboolean bd_lvm_is_valid_thpool_chunk_size (guint64 size, gboolean discard, GError **error UNUSED) {
4f8f2a
     gdouble size_log2 = 0.0;
4f8f2a
 
4f8f2a
     if ((size < BD_LVM_MIN_THPOOL_CHUNK_SIZE) || (size > BD_LVM_MAX_THPOOL_CHUNK_SIZE))
4f8f2a
@@ -2616,7 +2616,7 @@ gboolean bd_lvm_thsnapshotcreate (const gchar *vg_name, const gchar *origin_name
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_GLOB_CONF no mode (it is ignored)
4f8f2a
  */
4f8f2a
-gboolean bd_lvm_set_global_config (const gchar *new_config, GError **error __attribute__((unused))) {
4f8f2a
+gboolean bd_lvm_set_global_config (const gchar *new_config, GError **error UNUSED) {
4f8f2a
     /* XXX: the error attribute will likely be used in the future when
4f8f2a
        some validation comes into the game */
4f8f2a
 
4f8f2a
@@ -2641,7 +2641,7 @@ gboolean bd_lvm_set_global_config (const gchar *new_config, GError **error __att
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_GLOB_CONF no mode (it is ignored)
4f8f2a
  */
4f8f2a
-gchar* bd_lvm_get_global_config (GError **error __attribute__((unused))) {
4f8f2a
+gchar* bd_lvm_get_global_config (GError **error UNUSED) {
4f8f2a
     gchar *ret = NULL;
4f8f2a
 
4f8f2a
     g_mutex_lock (&global_config_lock);
4f8f2a
@@ -2660,7 +2660,7 @@ gchar* bd_lvm_get_global_config (GError **error __attribute__((unused))) {
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_CACHE_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-guint64 bd_lvm_cache_get_default_md_size (guint64 cache_size, GError **error __attribute__((unused))) {
4f8f2a
+guint64 bd_lvm_cache_get_default_md_size (guint64 cache_size, GError **error UNUSED) {
4f8f2a
     return MAX ((guint64) cache_size / 1000, BD_LVM_MIN_CACHE_MD_SIZE);
4f8f2a
 }
4f8f2a
 
4f8f2a
@@ -2670,7 +2670,7 @@ guint64 bd_lvm_cache_get_default_md_size (guint64 cache_size, GError **error __a
4f8f2a
  *
4f8f2a
  * Get LV type string from flags.
4f8f2a
  */
4f8f2a
-static const gchar* get_lv_type_from_flags (BDLVMCachePoolFlags flags, gboolean meta, GError **error __attribute__((unused))) {
4f8f2a
+static const gchar* get_lv_type_from_flags (BDLVMCachePoolFlags flags, gboolean meta, GError **error UNUSED) {
4f8f2a
     if (!meta) {
4f8f2a
         if (flags & BD_LVM_CACHE_POOL_STRIPED)
4f8f2a
             return "striped";
4f8f2a
diff --git a/src/plugins/lvm.c b/src/plugins/lvm.c
4f8f2a
index 74493feb..2be1dbdb 100644
4f8f2a
--- a/src/plugins/lvm.c
4f8f2a
+++ b/src/plugins/lvm.c
4f8f2a
@@ -700,7 +700,7 @@ static BDLVMVDOPooldata* get_vdo_data_from_table (GHashTable *table, gboolean fr
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-gboolean bd_lvm_is_supported_pe_size (guint64 size, GError **error __attribute__((unused))) {
4f8f2a
+gboolean bd_lvm_is_supported_pe_size (guint64 size, GError **error UNUSED) {
4f8f2a
     return (((size % 2) == 0) && (size >= (BD_LVM_MIN_PE_SIZE)) && (size <= (BD_LVM_MAX_PE_SIZE)));
4f8f2a
 }
4f8f2a
 
4f8f2a
@@ -712,7 +712,7 @@ gboolean bd_lvm_is_supported_pe_size (guint64 size, GError **error __attribute__
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-guint64 *bd_lvm_get_supported_pe_sizes (GError **error __attribute__((unused))) {
4f8f2a
+guint64 *bd_lvm_get_supported_pe_sizes (GError **error UNUSED) {
4f8f2a
     guint8 i;
4f8f2a
     guint64 val = BD_LVM_MIN_PE_SIZE;
4f8f2a
     guint8 num_items = ((guint8) round (log2 ((double) BD_LVM_MAX_PE_SIZE))) - ((guint8) round (log2 ((double) BD_LVM_MIN_PE_SIZE))) + 2;
4f8f2a
@@ -734,7 +734,7 @@ guint64 *bd_lvm_get_supported_pe_sizes (GError **error __attribute__((unused)))
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-guint64 bd_lvm_get_max_lv_size (GError **error __attribute__((unused))) {
4f8f2a
+guint64 bd_lvm_get_max_lv_size (GError **error UNUSED) {
4f8f2a
     return BD_LVM_MAX_LV_SIZE;
4f8f2a
 }
4f8f2a
 
4f8f2a
@@ -754,7 +754,7 @@ guint64 bd_lvm_get_max_lv_size (GError **error __attribute__((unused))) {
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-guint64 bd_lvm_round_size_to_pe (guint64 size, guint64 pe_size, gboolean roundup, GError **error __attribute__((unused))) {
4f8f2a
+guint64 bd_lvm_round_size_to_pe (guint64 size, guint64 pe_size, gboolean roundup, GError **error UNUSED) {
4f8f2a
     pe_size = RESOLVE_PE_SIZE(pe_size);
4f8f2a
     guint64 delta = size % pe_size;
4f8f2a
     if (delta == 0)
4f8f2a
@@ -848,7 +848,7 @@ guint64 bd_lvm_get_thpool_meta_size (guint64 size, guint64 chunk_size, guint64 n
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_THIN_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-gboolean bd_lvm_is_valid_thpool_md_size (guint64 size, GError **error __attribute__((unused))) {
4f8f2a
+gboolean bd_lvm_is_valid_thpool_md_size (guint64 size, GError **error UNUSED) {
4f8f2a
     return ((BD_LVM_MIN_THPOOL_MD_SIZE <= size) && (size <= BD_LVM_MAX_THPOOL_MD_SIZE));
4f8f2a
 }
4f8f2a
 
4f8f2a
@@ -862,7 +862,7 @@ gboolean bd_lvm_is_valid_thpool_md_size (guint64 size, GError **error __attribut
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_THIN_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-gboolean bd_lvm_is_valid_thpool_chunk_size (guint64 size, gboolean discard, GError **error __attribute__((unused))) {
4f8f2a
+gboolean bd_lvm_is_valid_thpool_chunk_size (guint64 size, gboolean discard, GError **error UNUSED) {
4f8f2a
     gdouble size_log2 = 0.0;
4f8f2a
 
4f8f2a
     if ((size < BD_LVM_MIN_THPOOL_CHUNK_SIZE) || (size > BD_LVM_MAX_THPOOL_CHUNK_SIZE))
4f8f2a
@@ -1983,7 +1983,7 @@ gboolean bd_lvm_thsnapshotcreate (const gchar *vg_name, const gchar *origin_name
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_GLOB_CONF no mode (it is ignored)
4f8f2a
  */
4f8f2a
-gboolean bd_lvm_set_global_config (const gchar *new_config, GError **error __attribute__((unused))) {
4f8f2a
+gboolean bd_lvm_set_global_config (const gchar *new_config, GError **error UNUSED) {
4f8f2a
     /* XXX: the error attribute will likely be used in the future when
4f8f2a
        some validation comes into the game */
4f8f2a
 
4f8f2a
@@ -2008,7 +2008,7 @@ gboolean bd_lvm_set_global_config (const gchar *new_config, GError **error __att
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_GLOB_CONF no mode (it is ignored)
4f8f2a
  */
4f8f2a
-gchar* bd_lvm_get_global_config (GError **error __attribute__((unused))) {
4f8f2a
+gchar* bd_lvm_get_global_config (GError **error UNUSED) {
4f8f2a
     gchar *ret = NULL;
4f8f2a
 
4f8f2a
     g_mutex_lock (&global_config_lock);
4f8f2a
@@ -2027,7 +2027,7 @@ gchar* bd_lvm_get_global_config (GError **error __attribute__((unused))) {
4f8f2a
  *
4f8f2a
  * Tech category: %BD_LVM_TECH_CACHE_CALCS no mode (it is ignored)
4f8f2a
  */
4f8f2a
-guint64 bd_lvm_cache_get_default_md_size (guint64 cache_size, GError **error __attribute__((unused))) {
4f8f2a
+guint64 bd_lvm_cache_get_default_md_size (guint64 cache_size, GError **error UNUSED) {
4f8f2a
     return MAX ((guint64) cache_size / 1000, BD_LVM_MIN_CACHE_MD_SIZE);
4f8f2a
 }
4f8f2a
 
4f8f2a
@@ -2037,7 +2037,7 @@ guint64 bd_lvm_cache_get_default_md_size (guint64 cache_size, GError **error __a
4f8f2a
  *
4f8f2a
  * Get LV type string from flags.
4f8f2a
  */
4f8f2a
-static const gchar* get_lv_type_from_flags (BDLVMCachePoolFlags flags, gboolean meta, GError **error __attribute__((unused))) {
4f8f2a
+static const gchar* get_lv_type_from_flags (BDLVMCachePoolFlags flags, gboolean meta, GError **error UNUSED) {
4f8f2a
     if (!meta) {
4f8f2a
         if (flags & BD_LVM_CACHE_POOL_STRIPED)
4f8f2a
             return "striped";
4f8f2a
4f8f2a
From f106e775d3c73e5f97512dd109627e00539b703a Mon Sep 17 00:00:00 2001
4f8f2a
From: Vojtech Trefny <vtrefny@redhat.com>
4f8f2a
Date: Tue, 15 Dec 2020 14:53:13 +0100
4f8f2a
Subject: [PATCH 5/5] Fix max size limit for LVM thinpool metadata
4f8f2a
4f8f2a
DM_THIN_MAX_METADATA_SIZE is in 512 sectors, not in KiB so the
4f8f2a
upper limit is 15.81 GiB not 31.62 GiB
4f8f2a
---
4f8f2a
 src/lib/plugin_apis/lvm.api |  2 +-
4f8f2a
 src/plugins/lvm.h           | 10 ++++++----
4f8f2a
 tests/lvm_dbus_tests.py     |  3 ++-
4f8f2a
 tests/lvm_test.py           |  3 ++-
4f8f2a
 4 files changed, 11 insertions(+), 7 deletions(-)
4f8f2a
4f8f2a
diff --git a/src/lib/plugin_apis/lvm.api b/src/lib/plugin_apis/lvm.api
4f8f2a
index 9f25c1ed..563c1041 100644
4f8f2a
--- a/src/lib/plugin_apis/lvm.api
4f8f2a
+++ b/src/lib/plugin_apis/lvm.api
4f8f2a
@@ -20,7 +20,7 @@
4f8f2a
 #define BD_LVM_MIN_PE_SIZE G_GUINT64_CONSTANT (1024ULL) // 1 KiB
4f8f2a
 #define BD_LVM_MAX_PE_SIZE G_GUINT64_CONSTANT (17179869184ULL) // 16 GiB
4f8f2a
 #define BD_LVM_MIN_THPOOL_MD_SIZE G_GUINT64_CONSTANT (4194304ULL) // 4 MiB
4f8f2a
-#define BD_LVM_MAX_THPOOL_MD_SIZE G_GUINT64_CONSTANT (33957085184ULL) // 31.62 GiB
4f8f2a
+#define BD_LVM_MAX_THPOOL_MD_SIZE G_GUINT64_CONSTANT (16978542592ULL) // 15.81 GiB
4f8f2a
 #define BD_LVM_MIN_THPOOL_CHUNK_SIZE G_GUINT64_CONSTANT (65536ULL) // 64 KiB
4f8f2a
 #define BD_LVM_MAX_THPOOL_CHUNK_SIZE G_GUINT64_CONSTANT (1073741824ULL) // 1 GiB
4f8f2a
 #define BD_LVM_DEFAULT_CHUNK_SIZE G_GUINT64_CONSTANT (65536ULL) // 64 KiB
4f8f2a
diff --git a/src/plugins/lvm.h b/src/plugins/lvm.h
4f8f2a
index 01c06ca4..2162d769 100644
4f8f2a
--- a/src/plugins/lvm.h
4f8f2a
+++ b/src/plugins/lvm.h
4f8f2a
@@ -22,11 +22,13 @@
4f8f2a
 #define USE_DEFAULT_PE_SIZE 0
4f8f2a
 #define RESOLVE_PE_SIZE(size) ((size) == USE_DEFAULT_PE_SIZE ? BD_LVM_DEFAULT_PE_SIZE : (size))
4f8f2a
 
4f8f2a
-/* lvm constants for thin pool metadata size are actually half of these
4f8f2a
-   but when they calculate the actual metadata size they double the limits
4f8f2a
-   so lets just double the limits here too */
4f8f2a
+/* lvm constant for thin pool metadata size is actually half of this
4f8f2a
+   but when they calculate the actual metadata size they double the limit
4f8f2a
+   so lets just double the limit here too */
4f8f2a
 #define BD_LVM_MIN_THPOOL_MD_SIZE (4 MiB)
4f8f2a
-#define BD_LVM_MAX_THPOOL_MD_SIZE (DM_THIN_MAX_METADATA_SIZE KiB)
4f8f2a
+
4f8f2a
+/* DM_THIN_MAX_METADATA_SIZE is in 512 sectors */
4f8f2a
+#define BD_LVM_MAX_THPOOL_MD_SIZE (DM_THIN_MAX_METADATA_SIZE * 512)
4f8f2a
 
4f8f2a
 #define BD_LVM_MIN_THPOOL_CHUNK_SIZE (64 KiB)
4f8f2a
 #define BD_LVM_MAX_THPOOL_CHUNK_SIZE (1 GiB)
4f8f2a
diff --git a/tests/lvm_dbus_tests.py b/tests/lvm_dbus_tests.py
4f8f2a
index c06a480c..8f2bb95d 100644
4f8f2a
--- a/tests/lvm_dbus_tests.py
4f8f2a
+++ b/tests/lvm_dbus_tests.py
4f8f2a
@@ -160,10 +160,11 @@ def test_is_valid_thpool_md_size(self):
4f8f2a
 
4f8f2a
         self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(4 * 1024**2))
4f8f2a
         self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(5 * 1024**2))
4f8f2a
-        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(16 * 1024**3))
4f8f2a
+        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(15 * 1024**3))
4f8f2a
 
4f8f2a
         self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(1 * 1024**2))
4f8f2a
         self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(3 * 1024**2))
4f8f2a
+        self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(16 * 1024**3))
4f8f2a
         self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(32 * 1024**3))
4f8f2a
 
4f8f2a
     @tag_test(TestTags.NOSTORAGE)
4f8f2a
diff --git a/tests/lvm_test.py b/tests/lvm_test.py
4f8f2a
index b84adece..6f80a3ba 100644
4f8f2a
--- a/tests/lvm_test.py
4f8f2a
+++ b/tests/lvm_test.py
4f8f2a
@@ -150,10 +150,11 @@ def test_is_valid_thpool_md_size(self):
4f8f2a
 
4f8f2a
         self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(4 * 1024**2))
4f8f2a
         self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(5 * 1024**2))
4f8f2a
-        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(16 * 1024**3))
4f8f2a
+        self.assertTrue(BlockDev.lvm_is_valid_thpool_md_size(15 * 1024**3))
4f8f2a
 
4f8f2a
         self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(1 * 1024**2))
4f8f2a
         self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(3 * 1024**2))
4f8f2a
+        self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(16 * 1024**3))
4f8f2a
         self.assertFalse(BlockDev.lvm_is_valid_thpool_md_size(32 * 1024**3))
4f8f2a
 
4f8f2a
     @tag_test(TestTags.NOSTORAGE)