From 46bfa14d0841fb6a1e71fac83ae8771eb1ee784f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Sat, 29 Jul 2017 04:42:19 +0200 Subject: [PATCH] storage/lvm: make sure that volumes have /dev entries when export() is called In some cases (even manual manipulation) those files may not be present - especially because thin snapshots do not have nodes in /dev by default. --- qubes/storage/lvm.py | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/qubes/storage/lvm.py b/qubes/storage/lvm.py index ce11c012..5aff6d35 100644 --- a/qubes/storage/lvm.py +++ b/qubes/storage/lvm.py @@ -121,7 +121,7 @@ class ThinPool(qubes.storage.Pool): return volumes -def init_cache(log=logging.getLogger('qube.storage.lvm')): +def init_cache(log=logging.getLogger('qubes.storage.lvm')): cmd = ['lvs', '--noheadings', '-o', 'vg_name,pool_lv,name,lv_size,data_percent,lv_attr,origin', '--units', 'b', '--separator', ','] @@ -291,6 +291,8 @@ class ThinVolume(qubes.storage.Volume): def export(self): ''' Returns an object that can be `open()`. ''' + # make sure the device node is available + qubes_lvm(['activate', self.vid], self.log) devpath = '/dev/' + self.vid return devpath @@ -464,6 +466,8 @@ def qubes_lvm(cmd, log=logging.getLogger('qubes.storage.lvm')): elif action == 'extend': size = int(cmd[2]) / (1000 * 1000) lvm_cmd = ["lvextend", "-L%s" % size, cmd[1]] + elif action == 'activate': + lvm_cmd = ['lvchange', '-ay', cmd[1]] else: raise NotImplementedError('unsupported action: ' + action) if lvm_is_very_old: