blob: 3f5312c05d23f086cfd39cacc227c03e7ef6d14f (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
analyze-migration.py doesn't account for saved blocks
Description of problem:
Steps to reproduce:
1. Make a migration snapshot that includes incremental block device (from HMP: `migrate -i "exec: cat > snap"`)
2. Load the snapshot: `scripts/analyze-migration.py -f snap`
```
Traceback (most recent call last):
File "scripts/analyze-migration.py", line 605, in <module>
dump.read(dump_memory = args.memory)
File "scripts/analyze-migration.py", line 539, in read
classdesc = self.section_classes[section_key]
KeyError: ('block', 0)
```
Additional information:
Here's pseudocode derived from `block_load` in `migration/block.c`:
```
N blocks of the following:
read 64 bits: sector number and flags
(blk->sector << BDRV_SECTOR_BITS) | flags
if flags & BLK_MIG_FLAG_EOS:
break
if flags & BLK_MIG_FLAG_PROGRESS
continue
if flags & BLK_MIG_FLAG_DEVICE_BLOCK
byte: name length
length bytes: device name string
if not flags & BLK_MIG_FLAG_ZERO_BLOCK:
read (1 << 20) bytes
```
|