LinuxKernel keep track of own volumes

This is squashed woju/qubes-core-admin#8 by @kalkin

- LinuxKernel.volumes() lists all available kernels
- LinuxKernel use kernel version as vid
- LinuxKernel add docstrings
- Linux.kernel use os.listdir instead of os.walk
- LinuxKernel dynamically list available kernels
This commit is contained in:
Bahtiar `kalkin-` Gadimov 2016-04-27 22:39:11 +02:00 committed by Wojtek Porczyk
parent 7200e6153b
commit 1d5b89f0d5

View File

@ -21,24 +21,27 @@
# with this program; if not, write to the Free Software Foundation, Inc., # with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
# #
''' This module contains pool implementations for different OS kernels. '''
import os import os
from qubes.storage import Pool, StoragePoolException, Volume from qubes.storage import Pool, StoragePoolException, Volume
class LinuxModules(Volume): class LinuxModules(Volume):
''' A volume representing a ro linux kernel '''
rw = False rw = False
def __init__(self, target_dir, kernel_version, **kwargs): def __init__(self, target_dir, kernel_version, **kwargs):
kwargs['vid'] = kernel_version
super(LinuxModules, self).__init__(**kwargs) super(LinuxModules, self).__init__(**kwargs)
self.kernels_dir = os.path.join(target_dir, kernel_version) self.kernels_dir = os.path.join(target_dir, kernel_version)
self.path = os.path.join(self.kernels_dir, 'modules.img') self.path = os.path.join(self.kernels_dir, 'modules.img')
self.vid = self.path
self.vmlinuz = os.path.join(self.kernels_dir, 'vmlinuz') self.vmlinuz = os.path.join(self.kernels_dir, 'vmlinuz')
self.initramfs = os.path.join(self.kernels_dir, 'initramfs') self.initramfs = os.path.join(self.kernels_dir, 'initramfs')
class LinuxKernel(Pool): class LinuxKernel(Pool):
''' Provides linux kernels '''
driver = 'linux-kernel' driver = 'linux-kernel'
def __init__(self, name=None, dir_path=None): def __init__(self, name=None, dir_path=None):
@ -100,6 +103,16 @@ class LinuxKernel(Pool):
def stop(self, volume): def stop(self, volume):
pass pass
@property
def volumes(self):
''' Return all known kernel volumes '''
return [LinuxModules(self.dir_path,
kernel_version,
pool=self.name,
name=kernel_version,
volume_type='read-only')
for kernel_version in os.listdir(self.dir_path)]
def _check_path(path): def _check_path(path):
''' Raise an :py:class:`qubes.storage.StoragePoolException` if ``path`` does ''' Raise an :py:class:`qubes.storage.StoragePoolException` if ``path`` does