From 3b320878acf9163e62d09a035e6f4895fffe4445 Mon Sep 17 00:00:00 2001 From: Marek Marczykowski Date: Sun, 26 Aug 2012 14:41:35 +0200 Subject: [PATCH] dom0/qvm-block: rework device name parsing to better support c0p1 name style --- dom0/qvm-core/qubesutils.py | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/dom0/qvm-core/qubesutils.py b/dom0/qvm-core/qubesutils.py index c054f182..6a3a0313 100644 --- a/dom0/qvm-core/qubesutils.py +++ b/dom0/qvm-core/qubesutils.py @@ -122,21 +122,14 @@ def block_name_to_majorminor(name): major = 0 minor = 0 dXpY_style = False - - name_match = re.match(r"([a-z]+)([a-z])([0-9]*)", name) - if not name_match: - name_match = re.match(r"([a-z]+)([0-9]*)(?:p([0-9]+)?", name) - if not name_match: - raise QubesException("Invalid device name: %s" % name) - else: - dXpY_style = True - disk = True - if name_match.group(1) == "xvd": + + if name.startswith("xvd"): major = 202 - elif name_match.group(1) == "sd": + elif name.startswith("sd"): major = 8 - elif name_match.group(1) == "mmcblk": + elif name.startswith("mmcblk"): + dXpY_style = True major = 179 elif name.startswith("scd"): disk = False @@ -154,6 +147,13 @@ def block_name_to_majorminor(name): # Unknown device return (0, 0) + if not dXpY_style: + name_match = re.match(r"^([a-z]+)([a-z])([0-9]*)$", name) + else: + name_match = re.match(r"^([a-z]+)([0-9]*)(?:p([0-9]+))?$", name) + if not name_match: + raise QubesException("Invalid device name: %s" % name) + if disk: if dXpY_style: minor = int(name_match.group(2))*8 @@ -191,7 +191,7 @@ def block_find_unused_frontend(vm = None): return None def block_list(vm = None, system_disks = False): - device_re = re.compile(r"^[a-z0-9]{1,8}$") + device_re = re.compile(r"^[a-z0-9]{1,12}$") # FIXME: any better idea of desc_re? desc_re = re.compile(r"^.{1,255}$") mode_re = re.compile(r"^[rw]$")