From 4090fdf758e3b0f7299ac4b8cbf887dd7448768c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Tue, 19 Nov 2013 18:35:10 +0100 Subject: [PATCH] QubesHVm: restore private.img support --- core-modules/01QubesHVm.py | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/core-modules/01QubesHVm.py b/core-modules/01QubesHVm.py index 80b09379..8ac2c0e4 100644 --- a/core-modules/01QubesHVm.py +++ b/core-modules/01QubesHVm.py @@ -137,13 +137,23 @@ class QubesHVm(QubesVm): hook(self, verbose, source_template=source_template) def get_disk_utilization_private_img(self): - return 0 + return self.get_disk_usage(self.private_img) def get_private_img_sz(self): - return 0 + if not os.path.exists(self.private_img): + return 0 + + return os.path.getsize(self.private_img) def resize_private_img(self, size): - raise NotImplementedError("HVM has no private.img") + assert size >= self.get_private_img_sz(), "Cannot shrink private.img" + + if self.is_running(): + raise NotImplementedError("Online resize of HVM's private.img not implemented, shutdown the VM first") + + f_private = open (self.private_img, "a+b") + f_private.truncate (size) + f_private.close () def get_config_params(self, source_template=None): @@ -179,9 +189,6 @@ class QubesHVm(QubesVm): else: params['otherdevs'] = '' - # Disable currently unused private.img - to be enabled when TemplateHVm done - params['privatedev'] = '' - if self.timezone.lower() == 'localtime': params['localtime'] = '1' params['timeoffset'] = '0'