summary refs log tree commit diff stats
path: root/results/classifier/zero-shot/118/none/1459
blob: 9cd5d3bd40cc4d783d60bb87b2f6701687718389 (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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
device: 0.792
graphic: 0.690
performance: 0.687
PID: 0.635
vnc: 0.594
ppc: 0.583
mistranslation: 0.539
kernel: 0.501
network: 0.489
arm: 0.459
architecture: 0.456
socket: 0.439
semantic: 0.433
risc-v: 0.389
files: 0.378
permissions: 0.364
VMM: 0.347
x86: 0.336
register: 0.332
TCG: 0.331
i386: 0.283
debug: 0.266
user-level: 0.245
peripherals: 0.231
boot: 0.227
hypervisor: 0.207
KVM: 0.156
virtual: 0.133
assembly: 0.083

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 
```