[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 03/14] qcow2_format.py: change Qcow2BitmapExt initialization metho
From: |
Eric Blake |
Subject: |
[PULL 03/14] qcow2_format.py: change Qcow2BitmapExt initialization method |
Date: |
Fri, 21 Aug 2020 09:08:15 -0500 |
From: Andrey Shinkevich <andrey.shinkevich@virtuozzo.com>
There are two ways to initialize a class derived from Qcow2Struct:
1. Pass a block of binary data to the constructor.
2. Pass the file descriptor to allow reading the file from constructor.
Let's change the Qcow2BitmapExt initialization method from 1 to 2 to
support a scattered reading in the initialization chain.
The implementation comes with the patch that follows.
Suggested-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
Signed-off-by: Andrey Shinkevich <andrey.shinkevich@virtuozzo.com>
Reviewed-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
Message-Id: <1596742557-320265-4-git-send-email-andrey.shinkevich@virtuozzo.com>
Signed-off-by: Eric Blake <eblake@redhat.com>
---
tests/qemu-iotests/qcow2_format.py | 34 ++++++++++++++++++------------
1 file changed, 21 insertions(+), 13 deletions(-)
diff --git a/tests/qemu-iotests/qcow2_format.py
b/tests/qemu-iotests/qcow2_format.py
index 2f3681bb5f7c..d4a997453758 100644
--- a/tests/qemu-iotests/qcow2_format.py
+++ b/tests/qemu-iotests/qcow2_format.py
@@ -113,6 +113,11 @@ class Qcow2BitmapExt(Qcow2Struct):
('u64', '{:#x}', 'bitmap_directory_offset')
)
+ def __init__(self, fd):
+ super().__init__(fd=fd)
+ tail = struct.calcsize(self.fmt) % 8
+ if tail:
+ fd.seek(8 - tail, 1)
QCOW2_EXT_MAGIC_BITMAPS = 0x23852875
@@ -161,21 +166,24 @@ class QcowHeaderExtension(Qcow2Struct):
else:
assert all(v is None for v in (magic, length, data))
super().__init__(fd=fd)
- padded = (self.length + 7) & ~7
- self.data = fd.read(padded)
- assert self.data is not None
+ if self.magic == QCOW2_EXT_MAGIC_BITMAPS:
+ self.obj = Qcow2BitmapExt(fd=fd)
+ self.data = None
+ else:
+ padded = (self.length + 7) & ~7
+ self.data = fd.read(padded)
+ assert self.data is not None
+ self.obj = None
- data_str = self.data[:self.length]
- if all(c in string.printable.encode('ascii') for c in data_str):
- data_str = f"'{ data_str.decode('ascii') }'"
- else:
- data_str = '<binary>'
- self.data_str = data_str
+ if self.data is not None:
+ data_str = self.data[:self.length]
+ if all(c in string.printable.encode(
+ 'ascii') for c in data_str):
+ data_str = f"'{ data_str.decode('ascii') }'"
+ else:
+ data_str = '<binary>'
+ self.data_str = data_str
- if self.magic == QCOW2_EXT_MAGIC_BITMAPS:
- self.obj = Qcow2BitmapExt(data=self.data)
- else:
- self.obj = None
def dump(self):
super().dump()
--
2.28.0
- [PULL 00/14] bitmaps patches for 2020-08-21, Eric Blake, 2020/08/21
- [PULL 04/14] qcow2_format.py: dump bitmap flags in human readable way., Eric Blake, 2020/08/21
- [PULL 10/14] qcow2_format.py: support dumping metadata in JSON format, Eric Blake, 2020/08/21
- [PULL 12/14] migration: Add block-bitmap-mapping parameter, Eric Blake, 2020/08/21
- [PULL 01/14] iotests: add test for QCOW2 header dump, Eric Blake, 2020/08/21
- [PULL 02/14] qcow2_format.py: make printable data an extension class member, Eric Blake, 2020/08/21
- [PULL 03/14] qcow2_format.py: change Qcow2BitmapExt initialization method,
Eric Blake <=
- [PULL 06/14] qcow2_format.py: pass cluster size to substructures, Eric Blake, 2020/08/21
- [PULL 05/14] qcow2_format.py: Dump bitmap directory information, Eric Blake, 2020/08/21
- [PULL 07/14] qcow2_format.py: Dump bitmap table serialized entries, Eric Blake, 2020/08/21
- [PULL 09/14] qcow2_format.py: collect fields to dump in JSON format, Eric Blake, 2020/08/21
- [PULL 11/14] iotests: dump QCOW2 header in JSON in #303, Eric Blake, 2020/08/21
- [PULL 08/14] qcow2.py: Introduce '-j' key to dump in JSON format, Eric Blake, 2020/08/21
- [PULL 13/14] iotests.py: Let wait_migration() return on failure, Eric Blake, 2020/08/21
- [PULL 14/14] iotests: Test node/bitmap aliases during migration, Eric Blake, 2020/08/21
- Re: [PULL 00/14] bitmaps patches for 2020-08-21, Peter Maydell, 2020/08/22