1 2=== Mode bitmap; Bitmap Sync never with simulated failure === 3 4--- Preparing image & VM --- 5 6{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 7{"return": {}} 8 9--- Write #0 --- 10 11write -P0x49 0x0000000 0x10000 12{"return": ""} 13write -P0x6c 0x0100000 0x10000 14{"return": ""} 15write -P0x6f 0x2000000 0x10000 16{"return": ""} 17write -P0x76 0x3ff0000 0x10000 18{"return": ""} 19{ 20 "bitmaps": {} 21} 22 23--- Reference Backup #0 --- 24 25{} 26{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 27{"return": {}} 28{} 29{} 30{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 31{"return": {}} 32{} 33{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 34{"return": {}} 35{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 36 37--- Add Bitmap --- 38 39{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 40{"return": {}} 41 42--- Write #1 --- 43 44write -P0x65 0x0000000 0x10000 45{"return": ""} 46write -P0x77 0x00f8000 0x10000 47{"return": ""} 48write -P0x72 0x2008000 0x10000 49{"return": ""} 50write -P0x69 0x3fe0000 0x10000 51{"return": ""} 52{ 53 "bitmaps": { 54 "drive0": [ 55 { 56 "busy": false, 57 "count": 393216, 58 "granularity": 65536, 59 "name": "bitmap0", 60 "persistent": false, 61 "recording": true 62 } 63 ] 64 } 65} 66 67= Checking Bitmap bitmap0 = 68expecting 6 dirty sectors; have 6. OK! 69 70--- Reference Backup #1 --- 71 72{} 73{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 74{"return": {}} 75{} 76{} 77{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 78{"return": {}} 79{} 80{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 81{"return": {}} 82{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 83 84--- Test Backup #1 --- 85 86{} 87{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 88{"return": {}} 89{} 90{} 91{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 92{"return": {}} 93{} 94{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "bitmap", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 95{"return": {}} 96 97--- Write #2 --- 98 99write -P0x74 0x0010000 0x10000 100{"return": ""} 101write -P0x69 0x00e8000 0x10000 102{"return": ""} 103write -P0x6e 0x2018000 0x10000 104{"return": ""} 105write -P0x67 0x3fe0000 0x20000 106{"return": ""} 107{ 108 "bitmaps": { 109 "backup-top": [ 110 { 111 "busy": false, 112 "count": 67108864, 113 "granularity": 65536, 114 "persistent": false, 115 "recording": false 116 }, 117 { 118 "busy": false, 119 "count": 458752, 120 "granularity": 65536, 121 "persistent": false, 122 "recording": false 123 }, 124 { 125 "busy": false, 126 "count": 0, 127 "granularity": 65536, 128 "persistent": false, 129 "recording": false 130 } 131 ], 132 "drive0": [ 133 { 134 "busy": false, 135 "count": 458752, 136 "granularity": 65536, 137 "persistent": false, 138 "recording": true 139 }, 140 { 141 "busy": true, 142 "count": 393216, 143 "granularity": 65536, 144 "name": "bitmap0", 145 "persistent": false, 146 "recording": true 147 } 148 ] 149 } 150} 151 152= Checking Bitmap bitmap0 = 153expecting 6 dirty sectors; have 6. OK! 154 155= Checking Bitmap (anonymous) = 156expecting 7 dirty sectors; have 7. OK! 157 158{"execute": "job-cancel", "arguments": {"id": "backup_1"}} 159{"return": {}} 160{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 161{"data": {"device": "backup_1", "len": 393216, "offset": 393216, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_CANCELLED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 162{ 163 "bitmaps": { 164 "drive0": [ 165 { 166 "busy": false, 167 "count": 655360, 168 "granularity": 65536, 169 "name": "bitmap0", 170 "persistent": false, 171 "recording": true 172 } 173 ] 174 } 175} 176 177= Checking Bitmap bitmap0 = 178expecting 10 dirty sectors; have 10. OK! 179 180--- Write #3 --- 181 182write -P0xaa 0x0010000 0x30000 183{"return": ""} 184write -P0xbb 0x00d8000 0x10000 185{"return": ""} 186write -P0xcc 0x2028000 0x10000 187{"return": ""} 188write -P0xdd 0x3fc0000 0x10000 189{"return": ""} 190{ 191 "bitmaps": { 192 "drive0": [ 193 { 194 "busy": false, 195 "count": 983040, 196 "granularity": 65536, 197 "name": "bitmap0", 198 "persistent": false, 199 "recording": true 200 } 201 ] 202 } 203} 204 205= Checking Bitmap bitmap0 = 206expecting 15 dirty sectors; have 15. OK! 207 208--- Reference Backup #2 --- 209 210{} 211{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 212{"return": {}} 213{} 214{} 215{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 216{"return": {}} 217{} 218{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 219{"return": {}} 220{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 221 222--- Test Backup #2 --- 223 224{} 225{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 226{"return": {}} 227{} 228{} 229{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 230{"return": {}} 231{} 232{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 233{"return": {}} 234{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 235{"return": {}} 236{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 237{"data": {"device": "backup_2", "len": 983040, "offset": 983040, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 238{ 239 "bitmaps": { 240 "drive0": [ 241 { 242 "busy": false, 243 "count": 983040, 244 "granularity": 65536, 245 "name": "bitmap0", 246 "persistent": false, 247 "recording": true 248 } 249 ] 250 } 251} 252 253= Checking Bitmap bitmap0 = 254expecting 15 dirty sectors; have 15. OK! 255 256--- Cleanup --- 257 258{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 259{"return": {}} 260{ 261 "bitmaps": {} 262} 263 264--- Verification --- 265 266qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 267qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 268qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 269 270 271=== Mode bitmap; Bitmap Sync never with intermediate failure === 272 273--- Preparing image & VM --- 274 275{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "blkdebug", "image": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "inject-error": [{"errno": 5, "event": "read_aio", "immediately": false, "once": true, "state": 3}], "set-state": [{"event": "flush_to_disk", "new-state": 2, "state": 1}, {"event": "read_aio", "new-state": 3, "state": 2}]}, "node-name": "drive0"}} 276{"return": {}} 277 278--- Write #0 --- 279 280write -P0x49 0x0000000 0x10000 281{"return": ""} 282write -P0x6c 0x0100000 0x10000 283{"return": ""} 284write -P0x6f 0x2000000 0x10000 285{"return": ""} 286write -P0x76 0x3ff0000 0x10000 287{"return": ""} 288{ 289 "bitmaps": {} 290} 291 292--- Reference Backup #0 --- 293 294{} 295{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 296{"return": {}} 297{} 298{} 299{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 300{"return": {}} 301{} 302{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 303{"return": {}} 304{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 305 306--- Add Bitmap --- 307 308{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 309{"return": {}} 310 311--- Write #1 --- 312 313write -P0x65 0x0000000 0x10000 314{"return": ""} 315write -P0x77 0x00f8000 0x10000 316{"return": ""} 317write -P0x72 0x2008000 0x10000 318{"return": ""} 319write -P0x69 0x3fe0000 0x10000 320{"return": ""} 321{ 322 "bitmaps": { 323 "drive0": [ 324 { 325 "busy": false, 326 "count": 393216, 327 "granularity": 65536, 328 "name": "bitmap0", 329 "persistent": false, 330 "recording": true 331 } 332 ] 333 } 334} 335 336= Checking Bitmap bitmap0 = 337expecting 6 dirty sectors; have 6. OK! 338 339--- Reference Backup #1 --- 340 341{} 342{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 343{"return": {}} 344{} 345{} 346{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 347{"return": {}} 348{} 349{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 350{"return": {}} 351{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 352 353{"return": ""} 354 355--- Test Backup #1 --- 356 357{} 358{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 359{"return": {}} 360{} 361{} 362{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 363{"return": {}} 364{} 365{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "bitmap", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 366{"return": {}} 367{"data": {"action": "report", "device": "backup_1", "operation": "read"}, "event": "BLOCK_JOB_ERROR", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 368{"data": {"device": "backup_1", "error": "Input/output error", "len": 393216, "offset": 65536, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 369{ 370 "bitmaps": { 371 "drive0": [ 372 { 373 "busy": false, 374 "count": 393216, 375 "granularity": 65536, 376 "name": "bitmap0", 377 "persistent": false, 378 "recording": true 379 } 380 ] 381 } 382} 383 384= Checking Bitmap bitmap0 = 385expecting 6 dirty sectors; have 6. OK! 386 387--- Write #3 --- 388 389write -P0xaa 0x0010000 0x30000 390{"return": ""} 391write -P0xbb 0x00d8000 0x10000 392{"return": ""} 393write -P0xcc 0x2028000 0x10000 394{"return": ""} 395write -P0xdd 0x3fc0000 0x10000 396{"return": ""} 397{ 398 "bitmaps": { 399 "drive0": [ 400 { 401 "busy": false, 402 "count": 917504, 403 "granularity": 65536, 404 "name": "bitmap0", 405 "persistent": false, 406 "recording": true 407 } 408 ] 409 } 410} 411 412= Checking Bitmap bitmap0 = 413expecting 14 dirty sectors; have 14. OK! 414 415--- Reference Backup #2 --- 416 417{} 418{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 419{"return": {}} 420{} 421{} 422{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 423{"return": {}} 424{} 425{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 426{"return": {}} 427{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 428 429--- Test Backup #2 --- 430 431{} 432{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 433{"return": {}} 434{} 435{} 436{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 437{"return": {}} 438{} 439{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 440{"return": {}} 441{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 442{"return": {}} 443{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 444{"data": {"device": "backup_2", "len": 917504, "offset": 917504, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 445{ 446 "bitmaps": { 447 "drive0": [ 448 { 449 "busy": false, 450 "count": 917504, 451 "granularity": 65536, 452 "name": "bitmap0", 453 "persistent": false, 454 "recording": true 455 } 456 ] 457 } 458} 459 460= Checking Bitmap bitmap0 = 461expecting 14 dirty sectors; have 14. OK! 462 463--- Cleanup --- 464 465{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 466{"return": {}} 467{ 468 "bitmaps": {} 469} 470 471--- Verification --- 472 473qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Mismatch, OK! 474qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 475qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 476 477 478=== Mode bitmap; Bitmap Sync never without failure === 479 480--- Preparing image & VM --- 481 482{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 483{"return": {}} 484 485--- Write #0 --- 486 487write -P0x49 0x0000000 0x10000 488{"return": ""} 489write -P0x6c 0x0100000 0x10000 490{"return": ""} 491write -P0x6f 0x2000000 0x10000 492{"return": ""} 493write -P0x76 0x3ff0000 0x10000 494{"return": ""} 495{ 496 "bitmaps": {} 497} 498 499--- Reference Backup #0 --- 500 501{} 502{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 503{"return": {}} 504{} 505{} 506{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 507{"return": {}} 508{} 509{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 510{"return": {}} 511{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 512 513--- Add Bitmap --- 514 515{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 516{"return": {}} 517 518--- Write #1 --- 519 520write -P0x65 0x0000000 0x10000 521{"return": ""} 522write -P0x77 0x00f8000 0x10000 523{"return": ""} 524write -P0x72 0x2008000 0x10000 525{"return": ""} 526write -P0x69 0x3fe0000 0x10000 527{"return": ""} 528{ 529 "bitmaps": { 530 "drive0": [ 531 { 532 "busy": false, 533 "count": 393216, 534 "granularity": 65536, 535 "name": "bitmap0", 536 "persistent": false, 537 "recording": true 538 } 539 ] 540 } 541} 542 543= Checking Bitmap bitmap0 = 544expecting 6 dirty sectors; have 6. OK! 545 546--- Reference Backup #1 --- 547 548{} 549{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 550{"return": {}} 551{} 552{} 553{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 554{"return": {}} 555{} 556{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 557{"return": {}} 558{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 559 560--- Test Backup #1 --- 561 562{} 563{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 564{"return": {}} 565{} 566{} 567{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 568{"return": {}} 569{} 570{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "bitmap", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 571{"return": {}} 572 573--- Write #2 --- 574 575write -P0x74 0x0010000 0x10000 576{"return": ""} 577write -P0x69 0x00e8000 0x10000 578{"return": ""} 579write -P0x6e 0x2018000 0x10000 580{"return": ""} 581write -P0x67 0x3fe0000 0x20000 582{"return": ""} 583{ 584 "bitmaps": { 585 "backup-top": [ 586 { 587 "busy": false, 588 "count": 67108864, 589 "granularity": 65536, 590 "persistent": false, 591 "recording": false 592 }, 593 { 594 "busy": false, 595 "count": 458752, 596 "granularity": 65536, 597 "persistent": false, 598 "recording": false 599 }, 600 { 601 "busy": false, 602 "count": 0, 603 "granularity": 65536, 604 "persistent": false, 605 "recording": false 606 } 607 ], 608 "drive0": [ 609 { 610 "busy": false, 611 "count": 458752, 612 "granularity": 65536, 613 "persistent": false, 614 "recording": true 615 }, 616 { 617 "busy": true, 618 "count": 393216, 619 "granularity": 65536, 620 "name": "bitmap0", 621 "persistent": false, 622 "recording": true 623 } 624 ] 625 } 626} 627 628= Checking Bitmap bitmap0 = 629expecting 6 dirty sectors; have 6. OK! 630 631= Checking Bitmap (anonymous) = 632expecting 7 dirty sectors; have 7. OK! 633 634{"execute": "job-finalize", "arguments": {"id": "backup_1"}} 635{"return": {}} 636{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 637{"data": {"device": "backup_1", "len": 393216, "offset": 393216, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 638{ 639 "bitmaps": { 640 "drive0": [ 641 { 642 "busy": false, 643 "count": 655360, 644 "granularity": 65536, 645 "name": "bitmap0", 646 "persistent": false, 647 "recording": true 648 } 649 ] 650 } 651} 652 653= Checking Bitmap bitmap0 = 654expecting 10 dirty sectors; have 10. OK! 655 656--- Write #3 --- 657 658write -P0xaa 0x0010000 0x30000 659{"return": ""} 660write -P0xbb 0x00d8000 0x10000 661{"return": ""} 662write -P0xcc 0x2028000 0x10000 663{"return": ""} 664write -P0xdd 0x3fc0000 0x10000 665{"return": ""} 666{ 667 "bitmaps": { 668 "drive0": [ 669 { 670 "busy": false, 671 "count": 983040, 672 "granularity": 65536, 673 "name": "bitmap0", 674 "persistent": false, 675 "recording": true 676 } 677 ] 678 } 679} 680 681= Checking Bitmap bitmap0 = 682expecting 15 dirty sectors; have 15. OK! 683 684--- Reference Backup #2 --- 685 686{} 687{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 688{"return": {}} 689{} 690{} 691{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 692{"return": {}} 693{} 694{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 695{"return": {}} 696{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 697 698--- Test Backup #2 --- 699 700{} 701{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 702{"return": {}} 703{} 704{} 705{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 706{"return": {}} 707{} 708{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 709{"return": {}} 710{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 711{"return": {}} 712{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 713{"data": {"device": "backup_2", "len": 983040, "offset": 983040, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 714{ 715 "bitmaps": { 716 "drive0": [ 717 { 718 "busy": false, 719 "count": 983040, 720 "granularity": 65536, 721 "name": "bitmap0", 722 "persistent": false, 723 "recording": true 724 } 725 ] 726 } 727} 728 729= Checking Bitmap bitmap0 = 730expecting 15 dirty sectors; have 15. OK! 731 732--- Cleanup --- 733 734{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 735{"return": {}} 736{ 737 "bitmaps": {} 738} 739 740--- Verification --- 741 742qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 743qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 744qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 745 746 747=== Mode bitmap; Bitmap Sync on-success with simulated failure === 748 749--- Preparing image & VM --- 750 751{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 752{"return": {}} 753 754--- Write #0 --- 755 756write -P0x49 0x0000000 0x10000 757{"return": ""} 758write -P0x6c 0x0100000 0x10000 759{"return": ""} 760write -P0x6f 0x2000000 0x10000 761{"return": ""} 762write -P0x76 0x3ff0000 0x10000 763{"return": ""} 764{ 765 "bitmaps": {} 766} 767 768--- Reference Backup #0 --- 769 770{} 771{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 772{"return": {}} 773{} 774{} 775{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 776{"return": {}} 777{} 778{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 779{"return": {}} 780{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 781 782--- Add Bitmap --- 783 784{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 785{"return": {}} 786 787--- Write #1 --- 788 789write -P0x65 0x0000000 0x10000 790{"return": ""} 791write -P0x77 0x00f8000 0x10000 792{"return": ""} 793write -P0x72 0x2008000 0x10000 794{"return": ""} 795write -P0x69 0x3fe0000 0x10000 796{"return": ""} 797{ 798 "bitmaps": { 799 "drive0": [ 800 { 801 "busy": false, 802 "count": 393216, 803 "granularity": 65536, 804 "name": "bitmap0", 805 "persistent": false, 806 "recording": true 807 } 808 ] 809 } 810} 811 812= Checking Bitmap bitmap0 = 813expecting 6 dirty sectors; have 6. OK! 814 815--- Reference Backup #1 --- 816 817{} 818{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 819{"return": {}} 820{} 821{} 822{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 823{"return": {}} 824{} 825{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 826{"return": {}} 827{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 828 829--- Test Backup #1 --- 830 831{} 832{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 833{"return": {}} 834{} 835{} 836{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 837{"return": {}} 838{} 839{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "bitmap", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 840{"return": {}} 841 842--- Write #2 --- 843 844write -P0x74 0x0010000 0x10000 845{"return": ""} 846write -P0x69 0x00e8000 0x10000 847{"return": ""} 848write -P0x6e 0x2018000 0x10000 849{"return": ""} 850write -P0x67 0x3fe0000 0x20000 851{"return": ""} 852{ 853 "bitmaps": { 854 "backup-top": [ 855 { 856 "busy": false, 857 "count": 67108864, 858 "granularity": 65536, 859 "persistent": false, 860 "recording": false 861 }, 862 { 863 "busy": false, 864 "count": 458752, 865 "granularity": 65536, 866 "persistent": false, 867 "recording": false 868 }, 869 { 870 "busy": false, 871 "count": 0, 872 "granularity": 65536, 873 "persistent": false, 874 "recording": false 875 } 876 ], 877 "drive0": [ 878 { 879 "busy": false, 880 "count": 458752, 881 "granularity": 65536, 882 "persistent": false, 883 "recording": true 884 }, 885 { 886 "busy": true, 887 "count": 393216, 888 "granularity": 65536, 889 "name": "bitmap0", 890 "persistent": false, 891 "recording": true 892 } 893 ] 894 } 895} 896 897= Checking Bitmap bitmap0 = 898expecting 6 dirty sectors; have 6. OK! 899 900= Checking Bitmap (anonymous) = 901expecting 7 dirty sectors; have 7. OK! 902 903{"execute": "job-cancel", "arguments": {"id": "backup_1"}} 904{"return": {}} 905{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 906{"data": {"device": "backup_1", "len": 393216, "offset": 393216, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_CANCELLED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 907{ 908 "bitmaps": { 909 "drive0": [ 910 { 911 "busy": false, 912 "count": 655360, 913 "granularity": 65536, 914 "name": "bitmap0", 915 "persistent": false, 916 "recording": true 917 } 918 ] 919 } 920} 921 922= Checking Bitmap bitmap0 = 923expecting 10 dirty sectors; have 10. OK! 924 925--- Write #3 --- 926 927write -P0xaa 0x0010000 0x30000 928{"return": ""} 929write -P0xbb 0x00d8000 0x10000 930{"return": ""} 931write -P0xcc 0x2028000 0x10000 932{"return": ""} 933write -P0xdd 0x3fc0000 0x10000 934{"return": ""} 935{ 936 "bitmaps": { 937 "drive0": [ 938 { 939 "busy": false, 940 "count": 983040, 941 "granularity": 65536, 942 "name": "bitmap0", 943 "persistent": false, 944 "recording": true 945 } 946 ] 947 } 948} 949 950= Checking Bitmap bitmap0 = 951expecting 15 dirty sectors; have 15. OK! 952 953--- Reference Backup #2 --- 954 955{} 956{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 957{"return": {}} 958{} 959{} 960{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 961{"return": {}} 962{} 963{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 964{"return": {}} 965{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 966 967--- Test Backup #2 --- 968 969{} 970{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 971{"return": {}} 972{} 973{} 974{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 975{"return": {}} 976{} 977{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 978{"return": {}} 979{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 980{"return": {}} 981{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 982{"data": {"device": "backup_2", "len": 983040, "offset": 983040, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 983{ 984 "bitmaps": { 985 "drive0": [ 986 { 987 "busy": false, 988 "count": 0, 989 "granularity": 65536, 990 "name": "bitmap0", 991 "persistent": false, 992 "recording": true 993 } 994 ] 995 } 996} 997 998= Checking Bitmap bitmap0 = 999expecting 0 dirty sectors; have 0. OK! 1000 1001--- Cleanup --- 1002 1003{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 1004{"return": {}} 1005{ 1006 "bitmaps": {} 1007} 1008 1009--- Verification --- 1010 1011qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 1012qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 1013qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 1014 1015 1016=== Mode bitmap; Bitmap Sync on-success with intermediate failure === 1017 1018--- Preparing image & VM --- 1019 1020{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "blkdebug", "image": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "inject-error": [{"errno": 5, "event": "read_aio", "immediately": false, "once": true, "state": 3}], "set-state": [{"event": "flush_to_disk", "new-state": 2, "state": 1}, {"event": "read_aio", "new-state": 3, "state": 2}]}, "node-name": "drive0"}} 1021{"return": {}} 1022 1023--- Write #0 --- 1024 1025write -P0x49 0x0000000 0x10000 1026{"return": ""} 1027write -P0x6c 0x0100000 0x10000 1028{"return": ""} 1029write -P0x6f 0x2000000 0x10000 1030{"return": ""} 1031write -P0x76 0x3ff0000 0x10000 1032{"return": ""} 1033{ 1034 "bitmaps": {} 1035} 1036 1037--- Reference Backup #0 --- 1038 1039{} 1040{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1041{"return": {}} 1042{} 1043{} 1044{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1045{"return": {}} 1046{} 1047{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 1048{"return": {}} 1049{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1050 1051--- Add Bitmap --- 1052 1053{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 1054{"return": {}} 1055 1056--- Write #1 --- 1057 1058write -P0x65 0x0000000 0x10000 1059{"return": ""} 1060write -P0x77 0x00f8000 0x10000 1061{"return": ""} 1062write -P0x72 0x2008000 0x10000 1063{"return": ""} 1064write -P0x69 0x3fe0000 0x10000 1065{"return": ""} 1066{ 1067 "bitmaps": { 1068 "drive0": [ 1069 { 1070 "busy": false, 1071 "count": 393216, 1072 "granularity": 65536, 1073 "name": "bitmap0", 1074 "persistent": false, 1075 "recording": true 1076 } 1077 ] 1078 } 1079} 1080 1081= Checking Bitmap bitmap0 = 1082expecting 6 dirty sectors; have 6. OK! 1083 1084--- Reference Backup #1 --- 1085 1086{} 1087{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1088{"return": {}} 1089{} 1090{} 1091{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1092{"return": {}} 1093{} 1094{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 1095{"return": {}} 1096{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1097 1098{"return": ""} 1099 1100--- Test Backup #1 --- 1101 1102{} 1103{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1104{"return": {}} 1105{} 1106{} 1107{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1108{"return": {}} 1109{} 1110{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "bitmap", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 1111{"return": {}} 1112{"data": {"action": "report", "device": "backup_1", "operation": "read"}, "event": "BLOCK_JOB_ERROR", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1113{"data": {"device": "backup_1", "error": "Input/output error", "len": 393216, "offset": 65536, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1114{ 1115 "bitmaps": { 1116 "drive0": [ 1117 { 1118 "busy": false, 1119 "count": 393216, 1120 "granularity": 65536, 1121 "name": "bitmap0", 1122 "persistent": false, 1123 "recording": true 1124 } 1125 ] 1126 } 1127} 1128 1129= Checking Bitmap bitmap0 = 1130expecting 6 dirty sectors; have 6. OK! 1131 1132--- Write #3 --- 1133 1134write -P0xaa 0x0010000 0x30000 1135{"return": ""} 1136write -P0xbb 0x00d8000 0x10000 1137{"return": ""} 1138write -P0xcc 0x2028000 0x10000 1139{"return": ""} 1140write -P0xdd 0x3fc0000 0x10000 1141{"return": ""} 1142{ 1143 "bitmaps": { 1144 "drive0": [ 1145 { 1146 "busy": false, 1147 "count": 917504, 1148 "granularity": 65536, 1149 "name": "bitmap0", 1150 "persistent": false, 1151 "recording": true 1152 } 1153 ] 1154 } 1155} 1156 1157= Checking Bitmap bitmap0 = 1158expecting 14 dirty sectors; have 14. OK! 1159 1160--- Reference Backup #2 --- 1161 1162{} 1163{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1164{"return": {}} 1165{} 1166{} 1167{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1168{"return": {}} 1169{} 1170{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 1171{"return": {}} 1172{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1173 1174--- Test Backup #2 --- 1175 1176{} 1177{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1178{"return": {}} 1179{} 1180{} 1181{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1182{"return": {}} 1183{} 1184{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 1185{"return": {}} 1186{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 1187{"return": {}} 1188{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1189{"data": {"device": "backup_2", "len": 917504, "offset": 917504, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1190{ 1191 "bitmaps": { 1192 "drive0": [ 1193 { 1194 "busy": false, 1195 "count": 0, 1196 "granularity": 65536, 1197 "name": "bitmap0", 1198 "persistent": false, 1199 "recording": true 1200 } 1201 ] 1202 } 1203} 1204 1205= Checking Bitmap bitmap0 = 1206expecting 0 dirty sectors; have 0. OK! 1207 1208--- Cleanup --- 1209 1210{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 1211{"return": {}} 1212{ 1213 "bitmaps": {} 1214} 1215 1216--- Verification --- 1217 1218qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Mismatch, OK! 1219qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 1220qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 1221 1222 1223=== Mode bitmap; Bitmap Sync on-success without failure === 1224 1225--- Preparing image & VM --- 1226 1227{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 1228{"return": {}} 1229 1230--- Write #0 --- 1231 1232write -P0x49 0x0000000 0x10000 1233{"return": ""} 1234write -P0x6c 0x0100000 0x10000 1235{"return": ""} 1236write -P0x6f 0x2000000 0x10000 1237{"return": ""} 1238write -P0x76 0x3ff0000 0x10000 1239{"return": ""} 1240{ 1241 "bitmaps": {} 1242} 1243 1244--- Reference Backup #0 --- 1245 1246{} 1247{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1248{"return": {}} 1249{} 1250{} 1251{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1252{"return": {}} 1253{} 1254{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 1255{"return": {}} 1256{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1257 1258--- Add Bitmap --- 1259 1260{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 1261{"return": {}} 1262 1263--- Write #1 --- 1264 1265write -P0x65 0x0000000 0x10000 1266{"return": ""} 1267write -P0x77 0x00f8000 0x10000 1268{"return": ""} 1269write -P0x72 0x2008000 0x10000 1270{"return": ""} 1271write -P0x69 0x3fe0000 0x10000 1272{"return": ""} 1273{ 1274 "bitmaps": { 1275 "drive0": [ 1276 { 1277 "busy": false, 1278 "count": 393216, 1279 "granularity": 65536, 1280 "name": "bitmap0", 1281 "persistent": false, 1282 "recording": true 1283 } 1284 ] 1285 } 1286} 1287 1288= Checking Bitmap bitmap0 = 1289expecting 6 dirty sectors; have 6. OK! 1290 1291--- Reference Backup #1 --- 1292 1293{} 1294{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1295{"return": {}} 1296{} 1297{} 1298{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1299{"return": {}} 1300{} 1301{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 1302{"return": {}} 1303{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1304 1305--- Test Backup #1 --- 1306 1307{} 1308{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1309{"return": {}} 1310{} 1311{} 1312{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1313{"return": {}} 1314{} 1315{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "bitmap", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 1316{"return": {}} 1317 1318--- Write #2 --- 1319 1320write -P0x74 0x0010000 0x10000 1321{"return": ""} 1322write -P0x69 0x00e8000 0x10000 1323{"return": ""} 1324write -P0x6e 0x2018000 0x10000 1325{"return": ""} 1326write -P0x67 0x3fe0000 0x20000 1327{"return": ""} 1328{ 1329 "bitmaps": { 1330 "backup-top": [ 1331 { 1332 "busy": false, 1333 "count": 67108864, 1334 "granularity": 65536, 1335 "persistent": false, 1336 "recording": false 1337 }, 1338 { 1339 "busy": false, 1340 "count": 458752, 1341 "granularity": 65536, 1342 "persistent": false, 1343 "recording": false 1344 }, 1345 { 1346 "busy": false, 1347 "count": 0, 1348 "granularity": 65536, 1349 "persistent": false, 1350 "recording": false 1351 } 1352 ], 1353 "drive0": [ 1354 { 1355 "busy": false, 1356 "count": 458752, 1357 "granularity": 65536, 1358 "persistent": false, 1359 "recording": true 1360 }, 1361 { 1362 "busy": true, 1363 "count": 393216, 1364 "granularity": 65536, 1365 "name": "bitmap0", 1366 "persistent": false, 1367 "recording": true 1368 } 1369 ] 1370 } 1371} 1372 1373= Checking Bitmap bitmap0 = 1374expecting 6 dirty sectors; have 6. OK! 1375 1376= Checking Bitmap (anonymous) = 1377expecting 7 dirty sectors; have 7. OK! 1378 1379{"execute": "job-finalize", "arguments": {"id": "backup_1"}} 1380{"return": {}} 1381{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1382{"data": {"device": "backup_1", "len": 393216, "offset": 393216, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1383{ 1384 "bitmaps": { 1385 "drive0": [ 1386 { 1387 "busy": false, 1388 "count": 458752, 1389 "granularity": 65536, 1390 "name": "bitmap0", 1391 "persistent": false, 1392 "recording": true 1393 } 1394 ] 1395 } 1396} 1397 1398= Checking Bitmap bitmap0 = 1399expecting 7 dirty sectors; have 7. OK! 1400 1401--- Write #3 --- 1402 1403write -P0xaa 0x0010000 0x30000 1404{"return": ""} 1405write -P0xbb 0x00d8000 0x10000 1406{"return": ""} 1407write -P0xcc 0x2028000 0x10000 1408{"return": ""} 1409write -P0xdd 0x3fc0000 0x10000 1410{"return": ""} 1411{ 1412 "bitmaps": { 1413 "drive0": [ 1414 { 1415 "busy": false, 1416 "count": 786432, 1417 "granularity": 65536, 1418 "name": "bitmap0", 1419 "persistent": false, 1420 "recording": true 1421 } 1422 ] 1423 } 1424} 1425 1426= Checking Bitmap bitmap0 = 1427expecting 12 dirty sectors; have 12. OK! 1428 1429--- Reference Backup #2 --- 1430 1431{} 1432{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1433{"return": {}} 1434{} 1435{} 1436{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1437{"return": {}} 1438{} 1439{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 1440{"return": {}} 1441{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1442 1443--- Test Backup #2 --- 1444 1445{} 1446{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1447{"return": {}} 1448{} 1449{} 1450{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1451{"return": {}} 1452{} 1453{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 1454{"return": {}} 1455{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 1456{"return": {}} 1457{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1458{"data": {"device": "backup_2", "len": 786432, "offset": 786432, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1459{ 1460 "bitmaps": { 1461 "drive0": [ 1462 { 1463 "busy": false, 1464 "count": 0, 1465 "granularity": 65536, 1466 "name": "bitmap0", 1467 "persistent": false, 1468 "recording": true 1469 } 1470 ] 1471 } 1472} 1473 1474= Checking Bitmap bitmap0 = 1475expecting 0 dirty sectors; have 0. OK! 1476 1477--- Cleanup --- 1478 1479{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 1480{"return": {}} 1481{ 1482 "bitmaps": {} 1483} 1484 1485--- Verification --- 1486 1487qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 1488qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 1489qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 1490 1491 1492=== Mode bitmap; Bitmap Sync always with simulated failure === 1493 1494--- Preparing image & VM --- 1495 1496{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 1497{"return": {}} 1498 1499--- Write #0 --- 1500 1501write -P0x49 0x0000000 0x10000 1502{"return": ""} 1503write -P0x6c 0x0100000 0x10000 1504{"return": ""} 1505write -P0x6f 0x2000000 0x10000 1506{"return": ""} 1507write -P0x76 0x3ff0000 0x10000 1508{"return": ""} 1509{ 1510 "bitmaps": {} 1511} 1512 1513--- Reference Backup #0 --- 1514 1515{} 1516{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1517{"return": {}} 1518{} 1519{} 1520{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1521{"return": {}} 1522{} 1523{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 1524{"return": {}} 1525{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1526 1527--- Add Bitmap --- 1528 1529{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 1530{"return": {}} 1531 1532--- Write #1 --- 1533 1534write -P0x65 0x0000000 0x10000 1535{"return": ""} 1536write -P0x77 0x00f8000 0x10000 1537{"return": ""} 1538write -P0x72 0x2008000 0x10000 1539{"return": ""} 1540write -P0x69 0x3fe0000 0x10000 1541{"return": ""} 1542{ 1543 "bitmaps": { 1544 "drive0": [ 1545 { 1546 "busy": false, 1547 "count": 393216, 1548 "granularity": 65536, 1549 "name": "bitmap0", 1550 "persistent": false, 1551 "recording": true 1552 } 1553 ] 1554 } 1555} 1556 1557= Checking Bitmap bitmap0 = 1558expecting 6 dirty sectors; have 6. OK! 1559 1560--- Reference Backup #1 --- 1561 1562{} 1563{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1564{"return": {}} 1565{} 1566{} 1567{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1568{"return": {}} 1569{} 1570{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 1571{"return": {}} 1572{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1573 1574--- Test Backup #1 --- 1575 1576{} 1577{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1578{"return": {}} 1579{} 1580{} 1581{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1582{"return": {}} 1583{} 1584{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "bitmap", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 1585{"return": {}} 1586 1587--- Write #2 --- 1588 1589write -P0x74 0x0010000 0x10000 1590{"return": ""} 1591write -P0x69 0x00e8000 0x10000 1592{"return": ""} 1593write -P0x6e 0x2018000 0x10000 1594{"return": ""} 1595write -P0x67 0x3fe0000 0x20000 1596{"return": ""} 1597{ 1598 "bitmaps": { 1599 "backup-top": [ 1600 { 1601 "busy": false, 1602 "count": 67108864, 1603 "granularity": 65536, 1604 "persistent": false, 1605 "recording": false 1606 }, 1607 { 1608 "busy": false, 1609 "count": 458752, 1610 "granularity": 65536, 1611 "persistent": false, 1612 "recording": false 1613 }, 1614 { 1615 "busy": false, 1616 "count": 0, 1617 "granularity": 65536, 1618 "persistent": false, 1619 "recording": false 1620 } 1621 ], 1622 "drive0": [ 1623 { 1624 "busy": false, 1625 "count": 458752, 1626 "granularity": 65536, 1627 "persistent": false, 1628 "recording": true 1629 }, 1630 { 1631 "busy": true, 1632 "count": 393216, 1633 "granularity": 65536, 1634 "name": "bitmap0", 1635 "persistent": false, 1636 "recording": true 1637 } 1638 ] 1639 } 1640} 1641 1642= Checking Bitmap bitmap0 = 1643expecting 6 dirty sectors; have 6. OK! 1644 1645= Checking Bitmap (anonymous) = 1646expecting 7 dirty sectors; have 7. OK! 1647 1648{"execute": "job-cancel", "arguments": {"id": "backup_1"}} 1649{"return": {}} 1650{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1651{"data": {"device": "backup_1", "len": 393216, "offset": 393216, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_CANCELLED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1652{ 1653 "bitmaps": { 1654 "drive0": [ 1655 { 1656 "busy": false, 1657 "count": 458752, 1658 "granularity": 65536, 1659 "name": "bitmap0", 1660 "persistent": false, 1661 "recording": true 1662 } 1663 ] 1664 } 1665} 1666 1667= Checking Bitmap bitmap0 = 1668expecting 7 dirty sectors; have 7. OK! 1669 1670--- Write #3 --- 1671 1672write -P0xaa 0x0010000 0x30000 1673{"return": ""} 1674write -P0xbb 0x00d8000 0x10000 1675{"return": ""} 1676write -P0xcc 0x2028000 0x10000 1677{"return": ""} 1678write -P0xdd 0x3fc0000 0x10000 1679{"return": ""} 1680{ 1681 "bitmaps": { 1682 "drive0": [ 1683 { 1684 "busy": false, 1685 "count": 786432, 1686 "granularity": 65536, 1687 "name": "bitmap0", 1688 "persistent": false, 1689 "recording": true 1690 } 1691 ] 1692 } 1693} 1694 1695= Checking Bitmap bitmap0 = 1696expecting 12 dirty sectors; have 12. OK! 1697 1698--- Reference Backup #2 --- 1699 1700{} 1701{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1702{"return": {}} 1703{} 1704{} 1705{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1706{"return": {}} 1707{} 1708{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 1709{"return": {}} 1710{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1711 1712--- Test Backup #2 --- 1713 1714{} 1715{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1716{"return": {}} 1717{} 1718{} 1719{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1720{"return": {}} 1721{} 1722{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 1723{"return": {}} 1724{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 1725{"return": {}} 1726{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1727{"data": {"device": "backup_2", "len": 786432, "offset": 786432, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1728{ 1729 "bitmaps": { 1730 "drive0": [ 1731 { 1732 "busy": false, 1733 "count": 0, 1734 "granularity": 65536, 1735 "name": "bitmap0", 1736 "persistent": false, 1737 "recording": true 1738 } 1739 ] 1740 } 1741} 1742 1743= Checking Bitmap bitmap0 = 1744expecting 0 dirty sectors; have 0. OK! 1745 1746--- Cleanup --- 1747 1748{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 1749{"return": {}} 1750{ 1751 "bitmaps": {} 1752} 1753 1754--- Verification --- 1755 1756qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 1757qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 1758qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 1759 1760 1761=== Mode bitmap; Bitmap Sync always with intermediate failure === 1762 1763--- Preparing image & VM --- 1764 1765{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "blkdebug", "image": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "inject-error": [{"errno": 5, "event": "read_aio", "immediately": false, "once": true, "state": 3}], "set-state": [{"event": "flush_to_disk", "new-state": 2, "state": 1}, {"event": "read_aio", "new-state": 3, "state": 2}]}, "node-name": "drive0"}} 1766{"return": {}} 1767 1768--- Write #0 --- 1769 1770write -P0x49 0x0000000 0x10000 1771{"return": ""} 1772write -P0x6c 0x0100000 0x10000 1773{"return": ""} 1774write -P0x6f 0x2000000 0x10000 1775{"return": ""} 1776write -P0x76 0x3ff0000 0x10000 1777{"return": ""} 1778{ 1779 "bitmaps": {} 1780} 1781 1782--- Reference Backup #0 --- 1783 1784{} 1785{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1786{"return": {}} 1787{} 1788{} 1789{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1790{"return": {}} 1791{} 1792{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 1793{"return": {}} 1794{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1795 1796--- Add Bitmap --- 1797 1798{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 1799{"return": {}} 1800 1801--- Write #1 --- 1802 1803write -P0x65 0x0000000 0x10000 1804{"return": ""} 1805write -P0x77 0x00f8000 0x10000 1806{"return": ""} 1807write -P0x72 0x2008000 0x10000 1808{"return": ""} 1809write -P0x69 0x3fe0000 0x10000 1810{"return": ""} 1811{ 1812 "bitmaps": { 1813 "drive0": [ 1814 { 1815 "busy": false, 1816 "count": 393216, 1817 "granularity": 65536, 1818 "name": "bitmap0", 1819 "persistent": false, 1820 "recording": true 1821 } 1822 ] 1823 } 1824} 1825 1826= Checking Bitmap bitmap0 = 1827expecting 6 dirty sectors; have 6. OK! 1828 1829--- Reference Backup #1 --- 1830 1831{} 1832{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1833{"return": {}} 1834{} 1835{} 1836{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1837{"return": {}} 1838{} 1839{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 1840{"return": {}} 1841{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1842 1843{"return": ""} 1844 1845--- Test Backup #1 --- 1846 1847{} 1848{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1849{"return": {}} 1850{} 1851{} 1852{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1853{"return": {}} 1854{} 1855{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "bitmap", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 1856{"return": {}} 1857{"data": {"action": "report", "device": "backup_1", "operation": "read"}, "event": "BLOCK_JOB_ERROR", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1858{"data": {"device": "backup_1", "error": "Input/output error", "len": 393216, "offset": 65536, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1859{ 1860 "bitmaps": { 1861 "drive0": [ 1862 { 1863 "busy": false, 1864 "count": 327680, 1865 "granularity": 65536, 1866 "name": "bitmap0", 1867 "persistent": false, 1868 "recording": true 1869 } 1870 ] 1871 } 1872} 1873 1874= Checking Bitmap bitmap0 = 1875expecting 5 dirty sectors; have 5. OK! 1876 1877--- Write #3 --- 1878 1879write -P0xaa 0x0010000 0x30000 1880{"return": ""} 1881write -P0xbb 0x00d8000 0x10000 1882{"return": ""} 1883write -P0xcc 0x2028000 0x10000 1884{"return": ""} 1885write -P0xdd 0x3fc0000 0x10000 1886{"return": ""} 1887{ 1888 "bitmaps": { 1889 "drive0": [ 1890 { 1891 "busy": false, 1892 "count": 851968, 1893 "granularity": 65536, 1894 "name": "bitmap0", 1895 "persistent": false, 1896 "recording": true 1897 } 1898 ] 1899 } 1900} 1901 1902= Checking Bitmap bitmap0 = 1903expecting 13 dirty sectors; have 13. OK! 1904 1905--- Reference Backup #2 --- 1906 1907{} 1908{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1909{"return": {}} 1910{} 1911{} 1912{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1913{"return": {}} 1914{} 1915{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 1916{"return": {}} 1917{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1918 1919--- Test Backup #2 --- 1920 1921{} 1922{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1923{"return": {}} 1924{} 1925{} 1926{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1927{"return": {}} 1928{} 1929{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 1930{"return": {}} 1931{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 1932{"return": {}} 1933{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1934{"data": {"device": "backup_2", "len": 851968, "offset": 851968, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 1935{ 1936 "bitmaps": { 1937 "drive0": [ 1938 { 1939 "busy": false, 1940 "count": 0, 1941 "granularity": 65536, 1942 "name": "bitmap0", 1943 "persistent": false, 1944 "recording": true 1945 } 1946 ] 1947 } 1948} 1949 1950= Checking Bitmap bitmap0 = 1951expecting 0 dirty sectors; have 0. OK! 1952 1953--- Cleanup --- 1954 1955{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 1956{"return": {}} 1957{ 1958 "bitmaps": {} 1959} 1960 1961--- Verification --- 1962 1963qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Mismatch, OK! 1964qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 1965qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 1966 1967 1968=== Mode bitmap; Bitmap Sync always without failure === 1969 1970--- Preparing image & VM --- 1971 1972{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 1973{"return": {}} 1974 1975--- Write #0 --- 1976 1977write -P0x49 0x0000000 0x10000 1978{"return": ""} 1979write -P0x6c 0x0100000 0x10000 1980{"return": ""} 1981write -P0x6f 0x2000000 0x10000 1982{"return": ""} 1983write -P0x76 0x3ff0000 0x10000 1984{"return": ""} 1985{ 1986 "bitmaps": {} 1987} 1988 1989--- Reference Backup #0 --- 1990 1991{} 1992{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 1993{"return": {}} 1994{} 1995{} 1996{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 1997{"return": {}} 1998{} 1999{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 2000{"return": {}} 2001{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2002 2003--- Add Bitmap --- 2004 2005{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 2006{"return": {}} 2007 2008--- Write #1 --- 2009 2010write -P0x65 0x0000000 0x10000 2011{"return": ""} 2012write -P0x77 0x00f8000 0x10000 2013{"return": ""} 2014write -P0x72 0x2008000 0x10000 2015{"return": ""} 2016write -P0x69 0x3fe0000 0x10000 2017{"return": ""} 2018{ 2019 "bitmaps": { 2020 "drive0": [ 2021 { 2022 "busy": false, 2023 "count": 393216, 2024 "granularity": 65536, 2025 "name": "bitmap0", 2026 "persistent": false, 2027 "recording": true 2028 } 2029 ] 2030 } 2031} 2032 2033= Checking Bitmap bitmap0 = 2034expecting 6 dirty sectors; have 6. OK! 2035 2036--- Reference Backup #1 --- 2037 2038{} 2039{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2040{"return": {}} 2041{} 2042{} 2043{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2044{"return": {}} 2045{} 2046{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 2047{"return": {}} 2048{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2049 2050--- Test Backup #1 --- 2051 2052{} 2053{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2054{"return": {}} 2055{} 2056{} 2057{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2058{"return": {}} 2059{} 2060{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "bitmap", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 2061{"return": {}} 2062 2063--- Write #2 --- 2064 2065write -P0x74 0x0010000 0x10000 2066{"return": ""} 2067write -P0x69 0x00e8000 0x10000 2068{"return": ""} 2069write -P0x6e 0x2018000 0x10000 2070{"return": ""} 2071write -P0x67 0x3fe0000 0x20000 2072{"return": ""} 2073{ 2074 "bitmaps": { 2075 "backup-top": [ 2076 { 2077 "busy": false, 2078 "count": 67108864, 2079 "granularity": 65536, 2080 "persistent": false, 2081 "recording": false 2082 }, 2083 { 2084 "busy": false, 2085 "count": 458752, 2086 "granularity": 65536, 2087 "persistent": false, 2088 "recording": false 2089 }, 2090 { 2091 "busy": false, 2092 "count": 0, 2093 "granularity": 65536, 2094 "persistent": false, 2095 "recording": false 2096 } 2097 ], 2098 "drive0": [ 2099 { 2100 "busy": false, 2101 "count": 458752, 2102 "granularity": 65536, 2103 "persistent": false, 2104 "recording": true 2105 }, 2106 { 2107 "busy": true, 2108 "count": 393216, 2109 "granularity": 65536, 2110 "name": "bitmap0", 2111 "persistent": false, 2112 "recording": true 2113 } 2114 ] 2115 } 2116} 2117 2118= Checking Bitmap bitmap0 = 2119expecting 6 dirty sectors; have 6. OK! 2120 2121= Checking Bitmap (anonymous) = 2122expecting 7 dirty sectors; have 7. OK! 2123 2124{"execute": "job-finalize", "arguments": {"id": "backup_1"}} 2125{"return": {}} 2126{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2127{"data": {"device": "backup_1", "len": 393216, "offset": 393216, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2128{ 2129 "bitmaps": { 2130 "drive0": [ 2131 { 2132 "busy": false, 2133 "count": 458752, 2134 "granularity": 65536, 2135 "name": "bitmap0", 2136 "persistent": false, 2137 "recording": true 2138 } 2139 ] 2140 } 2141} 2142 2143= Checking Bitmap bitmap0 = 2144expecting 7 dirty sectors; have 7. OK! 2145 2146--- Write #3 --- 2147 2148write -P0xaa 0x0010000 0x30000 2149{"return": ""} 2150write -P0xbb 0x00d8000 0x10000 2151{"return": ""} 2152write -P0xcc 0x2028000 0x10000 2153{"return": ""} 2154write -P0xdd 0x3fc0000 0x10000 2155{"return": ""} 2156{ 2157 "bitmaps": { 2158 "drive0": [ 2159 { 2160 "busy": false, 2161 "count": 786432, 2162 "granularity": 65536, 2163 "name": "bitmap0", 2164 "persistent": false, 2165 "recording": true 2166 } 2167 ] 2168 } 2169} 2170 2171= Checking Bitmap bitmap0 = 2172expecting 12 dirty sectors; have 12. OK! 2173 2174--- Reference Backup #2 --- 2175 2176{} 2177{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2178{"return": {}} 2179{} 2180{} 2181{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2182{"return": {}} 2183{} 2184{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 2185{"return": {}} 2186{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2187 2188--- Test Backup #2 --- 2189 2190{} 2191{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2192{"return": {}} 2193{} 2194{} 2195{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2196{"return": {}} 2197{} 2198{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 2199{"return": {}} 2200{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 2201{"return": {}} 2202{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2203{"data": {"device": "backup_2", "len": 786432, "offset": 786432, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2204{ 2205 "bitmaps": { 2206 "drive0": [ 2207 { 2208 "busy": false, 2209 "count": 0, 2210 "granularity": 65536, 2211 "name": "bitmap0", 2212 "persistent": false, 2213 "recording": true 2214 } 2215 ] 2216 } 2217} 2218 2219= Checking Bitmap bitmap0 = 2220expecting 0 dirty sectors; have 0. OK! 2221 2222--- Cleanup --- 2223 2224{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 2225{"return": {}} 2226{ 2227 "bitmaps": {} 2228} 2229 2230--- Verification --- 2231 2232qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 2233qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 2234qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 2235 2236 2237=== Mode full; Bitmap Sync on-success with simulated failure === 2238 2239--- Preparing image & VM --- 2240 2241{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 2242{"return": {}} 2243 2244--- Write #0 --- 2245 2246write -P0x49 0x0000000 0x10000 2247{"return": ""} 2248write -P0x6c 0x0100000 0x10000 2249{"return": ""} 2250write -P0x6f 0x2000000 0x10000 2251{"return": ""} 2252write -P0x76 0x3ff0000 0x10000 2253{"return": ""} 2254{ 2255 "bitmaps": {} 2256} 2257 2258--- Reference Backup #0 --- 2259 2260{} 2261{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2262{"return": {}} 2263{} 2264{} 2265{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2266{"return": {}} 2267{} 2268{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 2269{"return": {}} 2270{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2271 2272--- Add Bitmap --- 2273 2274{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 2275{"return": {}} 2276 2277--- Write #1 --- 2278 2279write -P0x65 0x0000000 0x10000 2280{"return": ""} 2281write -P0x77 0x00f8000 0x10000 2282{"return": ""} 2283write -P0x72 0x2008000 0x10000 2284{"return": ""} 2285write -P0x69 0x3fe0000 0x10000 2286{"return": ""} 2287{ 2288 "bitmaps": { 2289 "drive0": [ 2290 { 2291 "busy": false, 2292 "count": 393216, 2293 "granularity": 65536, 2294 "name": "bitmap0", 2295 "persistent": false, 2296 "recording": true 2297 } 2298 ] 2299 } 2300} 2301 2302= Checking Bitmap bitmap0 = 2303expecting 6 dirty sectors; have 6. OK! 2304 2305--- Reference Backup #1 --- 2306 2307{} 2308{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2309{"return": {}} 2310{} 2311{} 2312{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2313{"return": {}} 2314{} 2315{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 2316{"return": {}} 2317{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2318 2319--- Test Backup #1 --- 2320 2321{} 2322{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2323{"return": {}} 2324{} 2325{} 2326{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2327{"return": {}} 2328{} 2329{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "full", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 2330{"return": {}} 2331 2332--- Write #2 --- 2333 2334write -P0x74 0x0010000 0x10000 2335{"return": ""} 2336write -P0x69 0x00e8000 0x10000 2337{"return": ""} 2338write -P0x6e 0x2018000 0x10000 2339{"return": ""} 2340write -P0x67 0x3fe0000 0x20000 2341{"return": ""} 2342{ 2343 "bitmaps": { 2344 "backup-top": [ 2345 { 2346 "busy": false, 2347 "count": 67108864, 2348 "granularity": 65536, 2349 "persistent": false, 2350 "recording": false 2351 }, 2352 { 2353 "busy": false, 2354 "count": 458752, 2355 "granularity": 65536, 2356 "persistent": false, 2357 "recording": false 2358 }, 2359 { 2360 "busy": false, 2361 "count": 0, 2362 "granularity": 65536, 2363 "persistent": false, 2364 "recording": false 2365 } 2366 ], 2367 "drive0": [ 2368 { 2369 "busy": false, 2370 "count": 458752, 2371 "granularity": 65536, 2372 "persistent": false, 2373 "recording": true 2374 }, 2375 { 2376 "busy": true, 2377 "count": 393216, 2378 "granularity": 65536, 2379 "name": "bitmap0", 2380 "persistent": false, 2381 "recording": true 2382 } 2383 ] 2384 } 2385} 2386 2387= Checking Bitmap bitmap0 = 2388expecting 6 dirty sectors; have 6. OK! 2389 2390= Checking Bitmap (anonymous) = 2391expecting 7 dirty sectors; have 7. OK! 2392 2393{"execute": "job-cancel", "arguments": {"id": "backup_1"}} 2394{"return": {}} 2395{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2396{"data": {"device": "backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_CANCELLED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2397{ 2398 "bitmaps": { 2399 "drive0": [ 2400 { 2401 "busy": false, 2402 "count": 655360, 2403 "granularity": 65536, 2404 "name": "bitmap0", 2405 "persistent": false, 2406 "recording": true 2407 } 2408 ] 2409 } 2410} 2411 2412= Checking Bitmap bitmap0 = 2413expecting 10 dirty sectors; have 10. OK! 2414 2415--- Write #3 --- 2416 2417write -P0xaa 0x0010000 0x30000 2418{"return": ""} 2419write -P0xbb 0x00d8000 0x10000 2420{"return": ""} 2421write -P0xcc 0x2028000 0x10000 2422{"return": ""} 2423write -P0xdd 0x3fc0000 0x10000 2424{"return": ""} 2425{ 2426 "bitmaps": { 2427 "drive0": [ 2428 { 2429 "busy": false, 2430 "count": 983040, 2431 "granularity": 65536, 2432 "name": "bitmap0", 2433 "persistent": false, 2434 "recording": true 2435 } 2436 ] 2437 } 2438} 2439 2440= Checking Bitmap bitmap0 = 2441expecting 15 dirty sectors; have 15. OK! 2442 2443--- Reference Backup #2 --- 2444 2445{} 2446{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2447{"return": {}} 2448{} 2449{} 2450{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2451{"return": {}} 2452{} 2453{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 2454{"return": {}} 2455{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2456 2457--- Test Backup #2 --- 2458 2459{} 2460{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2461{"return": {}} 2462{} 2463{} 2464{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2465{"return": {}} 2466{} 2467{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 2468{"return": {}} 2469{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 2470{"return": {}} 2471{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2472{"data": {"device": "backup_2", "len": 983040, "offset": 983040, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2473{ 2474 "bitmaps": { 2475 "drive0": [ 2476 { 2477 "busy": false, 2478 "count": 0, 2479 "granularity": 65536, 2480 "name": "bitmap0", 2481 "persistent": false, 2482 "recording": true 2483 } 2484 ] 2485 } 2486} 2487 2488= Checking Bitmap bitmap0 = 2489expecting 0 dirty sectors; have 0. OK! 2490 2491--- Cleanup --- 2492 2493{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 2494{"return": {}} 2495{ 2496 "bitmaps": {} 2497} 2498 2499--- Verification --- 2500 2501qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 2502qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 2503qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 2504 2505 2506=== Mode full; Bitmap Sync on-success with intermediate failure === 2507 2508--- Preparing image & VM --- 2509 2510{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "blkdebug", "image": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "inject-error": [{"errno": 5, "event": "read_aio", "immediately": false, "once": true, "state": 3}], "set-state": [{"event": "flush_to_disk", "new-state": 2, "state": 1}, {"event": "read_aio", "new-state": 3, "state": 2}]}, "node-name": "drive0"}} 2511{"return": {}} 2512 2513--- Write #0 --- 2514 2515write -P0x49 0x0000000 0x10000 2516{"return": ""} 2517write -P0x6c 0x0100000 0x10000 2518{"return": ""} 2519write -P0x6f 0x2000000 0x10000 2520{"return": ""} 2521write -P0x76 0x3ff0000 0x10000 2522{"return": ""} 2523{ 2524 "bitmaps": {} 2525} 2526 2527--- Reference Backup #0 --- 2528 2529{} 2530{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2531{"return": {}} 2532{} 2533{} 2534{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2535{"return": {}} 2536{} 2537{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 2538{"return": {}} 2539{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2540 2541--- Add Bitmap --- 2542 2543{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 2544{"return": {}} 2545 2546--- Write #1 --- 2547 2548write -P0x65 0x0000000 0x10000 2549{"return": ""} 2550write -P0x77 0x00f8000 0x10000 2551{"return": ""} 2552write -P0x72 0x2008000 0x10000 2553{"return": ""} 2554write -P0x69 0x3fe0000 0x10000 2555{"return": ""} 2556{ 2557 "bitmaps": { 2558 "drive0": [ 2559 { 2560 "busy": false, 2561 "count": 393216, 2562 "granularity": 65536, 2563 "name": "bitmap0", 2564 "persistent": false, 2565 "recording": true 2566 } 2567 ] 2568 } 2569} 2570 2571= Checking Bitmap bitmap0 = 2572expecting 6 dirty sectors; have 6. OK! 2573 2574--- Reference Backup #1 --- 2575 2576{} 2577{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2578{"return": {}} 2579{} 2580{} 2581{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2582{"return": {}} 2583{} 2584{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 2585{"return": {}} 2586{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2587 2588{"return": ""} 2589 2590--- Test Backup #1 --- 2591 2592{} 2593{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2594{"return": {}} 2595{} 2596{} 2597{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2598{"return": {}} 2599{} 2600{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "full", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 2601{"return": {}} 2602{"data": {"action": "report", "device": "backup_1", "operation": "read"}, "event": "BLOCK_JOB_ERROR", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2603{"data": {"device": "backup_1", "error": "Input/output error", "len": 67108864, "offset": 983040, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2604{ 2605 "bitmaps": { 2606 "drive0": [ 2607 { 2608 "busy": false, 2609 "count": 393216, 2610 "granularity": 65536, 2611 "name": "bitmap0", 2612 "persistent": false, 2613 "recording": true 2614 } 2615 ] 2616 } 2617} 2618 2619= Checking Bitmap bitmap0 = 2620expecting 6 dirty sectors; have 6. OK! 2621 2622--- Write #3 --- 2623 2624write -P0xaa 0x0010000 0x30000 2625{"return": ""} 2626write -P0xbb 0x00d8000 0x10000 2627{"return": ""} 2628write -P0xcc 0x2028000 0x10000 2629{"return": ""} 2630write -P0xdd 0x3fc0000 0x10000 2631{"return": ""} 2632{ 2633 "bitmaps": { 2634 "drive0": [ 2635 { 2636 "busy": false, 2637 "count": 917504, 2638 "granularity": 65536, 2639 "name": "bitmap0", 2640 "persistent": false, 2641 "recording": true 2642 } 2643 ] 2644 } 2645} 2646 2647= Checking Bitmap bitmap0 = 2648expecting 14 dirty sectors; have 14. OK! 2649 2650--- Reference Backup #2 --- 2651 2652{} 2653{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2654{"return": {}} 2655{} 2656{} 2657{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2658{"return": {}} 2659{} 2660{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 2661{"return": {}} 2662{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2663 2664--- Test Backup #2 --- 2665 2666{} 2667{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2668{"return": {}} 2669{} 2670{} 2671{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2672{"return": {}} 2673{} 2674{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 2675{"return": {}} 2676{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 2677{"return": {}} 2678{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2679{"data": {"device": "backup_2", "len": 917504, "offset": 917504, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2680{ 2681 "bitmaps": { 2682 "drive0": [ 2683 { 2684 "busy": false, 2685 "count": 0, 2686 "granularity": 65536, 2687 "name": "bitmap0", 2688 "persistent": false, 2689 "recording": true 2690 } 2691 ] 2692 } 2693} 2694 2695= Checking Bitmap bitmap0 = 2696expecting 0 dirty sectors; have 0. OK! 2697 2698--- Cleanup --- 2699 2700{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 2701{"return": {}} 2702{ 2703 "bitmaps": {} 2704} 2705 2706--- Verification --- 2707 2708qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Mismatch, OK! 2709qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 2710qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 2711 2712 2713=== Mode full; Bitmap Sync on-success without failure === 2714 2715--- Preparing image & VM --- 2716 2717{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 2718{"return": {}} 2719 2720--- Write #0 --- 2721 2722write -P0x49 0x0000000 0x10000 2723{"return": ""} 2724write -P0x6c 0x0100000 0x10000 2725{"return": ""} 2726write -P0x6f 0x2000000 0x10000 2727{"return": ""} 2728write -P0x76 0x3ff0000 0x10000 2729{"return": ""} 2730{ 2731 "bitmaps": {} 2732} 2733 2734--- Reference Backup #0 --- 2735 2736{} 2737{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2738{"return": {}} 2739{} 2740{} 2741{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2742{"return": {}} 2743{} 2744{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 2745{"return": {}} 2746{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2747 2748--- Add Bitmap --- 2749 2750{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 2751{"return": {}} 2752 2753--- Write #1 --- 2754 2755write -P0x65 0x0000000 0x10000 2756{"return": ""} 2757write -P0x77 0x00f8000 0x10000 2758{"return": ""} 2759write -P0x72 0x2008000 0x10000 2760{"return": ""} 2761write -P0x69 0x3fe0000 0x10000 2762{"return": ""} 2763{ 2764 "bitmaps": { 2765 "drive0": [ 2766 { 2767 "busy": false, 2768 "count": 393216, 2769 "granularity": 65536, 2770 "name": "bitmap0", 2771 "persistent": false, 2772 "recording": true 2773 } 2774 ] 2775 } 2776} 2777 2778= Checking Bitmap bitmap0 = 2779expecting 6 dirty sectors; have 6. OK! 2780 2781--- Reference Backup #1 --- 2782 2783{} 2784{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2785{"return": {}} 2786{} 2787{} 2788{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2789{"return": {}} 2790{} 2791{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 2792{"return": {}} 2793{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2794 2795--- Test Backup #1 --- 2796 2797{} 2798{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2799{"return": {}} 2800{} 2801{} 2802{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2803{"return": {}} 2804{} 2805{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "full", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 2806{"return": {}} 2807 2808--- Write #2 --- 2809 2810write -P0x74 0x0010000 0x10000 2811{"return": ""} 2812write -P0x69 0x00e8000 0x10000 2813{"return": ""} 2814write -P0x6e 0x2018000 0x10000 2815{"return": ""} 2816write -P0x67 0x3fe0000 0x20000 2817{"return": ""} 2818{ 2819 "bitmaps": { 2820 "backup-top": [ 2821 { 2822 "busy": false, 2823 "count": 67108864, 2824 "granularity": 65536, 2825 "persistent": false, 2826 "recording": false 2827 }, 2828 { 2829 "busy": false, 2830 "count": 458752, 2831 "granularity": 65536, 2832 "persistent": false, 2833 "recording": false 2834 }, 2835 { 2836 "busy": false, 2837 "count": 0, 2838 "granularity": 65536, 2839 "persistent": false, 2840 "recording": false 2841 } 2842 ], 2843 "drive0": [ 2844 { 2845 "busy": false, 2846 "count": 458752, 2847 "granularity": 65536, 2848 "persistent": false, 2849 "recording": true 2850 }, 2851 { 2852 "busy": true, 2853 "count": 393216, 2854 "granularity": 65536, 2855 "name": "bitmap0", 2856 "persistent": false, 2857 "recording": true 2858 } 2859 ] 2860 } 2861} 2862 2863= Checking Bitmap bitmap0 = 2864expecting 6 dirty sectors; have 6. OK! 2865 2866= Checking Bitmap (anonymous) = 2867expecting 7 dirty sectors; have 7. OK! 2868 2869{"execute": "job-finalize", "arguments": {"id": "backup_1"}} 2870{"return": {}} 2871{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2872{"data": {"device": "backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2873{ 2874 "bitmaps": { 2875 "drive0": [ 2876 { 2877 "busy": false, 2878 "count": 458752, 2879 "granularity": 65536, 2880 "name": "bitmap0", 2881 "persistent": false, 2882 "recording": true 2883 } 2884 ] 2885 } 2886} 2887 2888= Checking Bitmap bitmap0 = 2889expecting 7 dirty sectors; have 7. OK! 2890 2891--- Write #3 --- 2892 2893write -P0xaa 0x0010000 0x30000 2894{"return": ""} 2895write -P0xbb 0x00d8000 0x10000 2896{"return": ""} 2897write -P0xcc 0x2028000 0x10000 2898{"return": ""} 2899write -P0xdd 0x3fc0000 0x10000 2900{"return": ""} 2901{ 2902 "bitmaps": { 2903 "drive0": [ 2904 { 2905 "busy": false, 2906 "count": 786432, 2907 "granularity": 65536, 2908 "name": "bitmap0", 2909 "persistent": false, 2910 "recording": true 2911 } 2912 ] 2913 } 2914} 2915 2916= Checking Bitmap bitmap0 = 2917expecting 12 dirty sectors; have 12. OK! 2918 2919--- Reference Backup #2 --- 2920 2921{} 2922{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2923{"return": {}} 2924{} 2925{} 2926{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2927{"return": {}} 2928{} 2929{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 2930{"return": {}} 2931{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2932 2933--- Test Backup #2 --- 2934 2935{} 2936{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 2937{"return": {}} 2938{} 2939{} 2940{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 2941{"return": {}} 2942{} 2943{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 2944{"return": {}} 2945{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 2946{"return": {}} 2947{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2948{"data": {"device": "backup_2", "len": 786432, "offset": 786432, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 2949{ 2950 "bitmaps": { 2951 "drive0": [ 2952 { 2953 "busy": false, 2954 "count": 0, 2955 "granularity": 65536, 2956 "name": "bitmap0", 2957 "persistent": false, 2958 "recording": true 2959 } 2960 ] 2961 } 2962} 2963 2964= Checking Bitmap bitmap0 = 2965expecting 0 dirty sectors; have 0. OK! 2966 2967--- Cleanup --- 2968 2969{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 2970{"return": {}} 2971{ 2972 "bitmaps": {} 2973} 2974 2975--- Verification --- 2976 2977qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 2978qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 2979qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 2980 2981 2982=== Mode full; Bitmap Sync always with simulated failure === 2983 2984--- Preparing image & VM --- 2985 2986{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 2987{"return": {}} 2988 2989--- Write #0 --- 2990 2991write -P0x49 0x0000000 0x10000 2992{"return": ""} 2993write -P0x6c 0x0100000 0x10000 2994{"return": ""} 2995write -P0x6f 0x2000000 0x10000 2996{"return": ""} 2997write -P0x76 0x3ff0000 0x10000 2998{"return": ""} 2999{ 3000 "bitmaps": {} 3001} 3002 3003--- Reference Backup #0 --- 3004 3005{} 3006{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3007{"return": {}} 3008{} 3009{} 3010{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3011{"return": {}} 3012{} 3013{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 3014{"return": {}} 3015{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3016 3017--- Add Bitmap --- 3018 3019{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 3020{"return": {}} 3021 3022--- Write #1 --- 3023 3024write -P0x65 0x0000000 0x10000 3025{"return": ""} 3026write -P0x77 0x00f8000 0x10000 3027{"return": ""} 3028write -P0x72 0x2008000 0x10000 3029{"return": ""} 3030write -P0x69 0x3fe0000 0x10000 3031{"return": ""} 3032{ 3033 "bitmaps": { 3034 "drive0": [ 3035 { 3036 "busy": false, 3037 "count": 393216, 3038 "granularity": 65536, 3039 "name": "bitmap0", 3040 "persistent": false, 3041 "recording": true 3042 } 3043 ] 3044 } 3045} 3046 3047= Checking Bitmap bitmap0 = 3048expecting 6 dirty sectors; have 6. OK! 3049 3050--- Reference Backup #1 --- 3051 3052{} 3053{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3054{"return": {}} 3055{} 3056{} 3057{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3058{"return": {}} 3059{} 3060{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 3061{"return": {}} 3062{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3063 3064--- Test Backup #1 --- 3065 3066{} 3067{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3068{"return": {}} 3069{} 3070{} 3071{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3072{"return": {}} 3073{} 3074{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "full", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 3075{"return": {}} 3076 3077--- Write #2 --- 3078 3079write -P0x74 0x0010000 0x10000 3080{"return": ""} 3081write -P0x69 0x00e8000 0x10000 3082{"return": ""} 3083write -P0x6e 0x2018000 0x10000 3084{"return": ""} 3085write -P0x67 0x3fe0000 0x20000 3086{"return": ""} 3087{ 3088 "bitmaps": { 3089 "backup-top": [ 3090 { 3091 "busy": false, 3092 "count": 67108864, 3093 "granularity": 65536, 3094 "persistent": false, 3095 "recording": false 3096 }, 3097 { 3098 "busy": false, 3099 "count": 458752, 3100 "granularity": 65536, 3101 "persistent": false, 3102 "recording": false 3103 }, 3104 { 3105 "busy": false, 3106 "count": 0, 3107 "granularity": 65536, 3108 "persistent": false, 3109 "recording": false 3110 } 3111 ], 3112 "drive0": [ 3113 { 3114 "busy": false, 3115 "count": 458752, 3116 "granularity": 65536, 3117 "persistent": false, 3118 "recording": true 3119 }, 3120 { 3121 "busy": true, 3122 "count": 393216, 3123 "granularity": 65536, 3124 "name": "bitmap0", 3125 "persistent": false, 3126 "recording": true 3127 } 3128 ] 3129 } 3130} 3131 3132= Checking Bitmap bitmap0 = 3133expecting 6 dirty sectors; have 6. OK! 3134 3135= Checking Bitmap (anonymous) = 3136expecting 7 dirty sectors; have 7. OK! 3137 3138{"execute": "job-cancel", "arguments": {"id": "backup_1"}} 3139{"return": {}} 3140{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3141{"data": {"device": "backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_CANCELLED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3142{ 3143 "bitmaps": { 3144 "drive0": [ 3145 { 3146 "busy": false, 3147 "count": 458752, 3148 "granularity": 65536, 3149 "name": "bitmap0", 3150 "persistent": false, 3151 "recording": true 3152 } 3153 ] 3154 } 3155} 3156 3157= Checking Bitmap bitmap0 = 3158expecting 7 dirty sectors; have 7. OK! 3159 3160--- Write #3 --- 3161 3162write -P0xaa 0x0010000 0x30000 3163{"return": ""} 3164write -P0xbb 0x00d8000 0x10000 3165{"return": ""} 3166write -P0xcc 0x2028000 0x10000 3167{"return": ""} 3168write -P0xdd 0x3fc0000 0x10000 3169{"return": ""} 3170{ 3171 "bitmaps": { 3172 "drive0": [ 3173 { 3174 "busy": false, 3175 "count": 786432, 3176 "granularity": 65536, 3177 "name": "bitmap0", 3178 "persistent": false, 3179 "recording": true 3180 } 3181 ] 3182 } 3183} 3184 3185= Checking Bitmap bitmap0 = 3186expecting 12 dirty sectors; have 12. OK! 3187 3188--- Reference Backup #2 --- 3189 3190{} 3191{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3192{"return": {}} 3193{} 3194{} 3195{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3196{"return": {}} 3197{} 3198{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 3199{"return": {}} 3200{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3201 3202--- Test Backup #2 --- 3203 3204{} 3205{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3206{"return": {}} 3207{} 3208{} 3209{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3210{"return": {}} 3211{} 3212{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 3213{"return": {}} 3214{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 3215{"return": {}} 3216{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3217{"data": {"device": "backup_2", "len": 786432, "offset": 786432, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3218{ 3219 "bitmaps": { 3220 "drive0": [ 3221 { 3222 "busy": false, 3223 "count": 0, 3224 "granularity": 65536, 3225 "name": "bitmap0", 3226 "persistent": false, 3227 "recording": true 3228 } 3229 ] 3230 } 3231} 3232 3233= Checking Bitmap bitmap0 = 3234expecting 0 dirty sectors; have 0. OK! 3235 3236--- Cleanup --- 3237 3238{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 3239{"return": {}} 3240{ 3241 "bitmaps": {} 3242} 3243 3244--- Verification --- 3245 3246qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 3247qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 3248qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 3249 3250 3251=== Mode full; Bitmap Sync always with intermediate failure === 3252 3253--- Preparing image & VM --- 3254 3255{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "blkdebug", "image": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "inject-error": [{"errno": 5, "event": "read_aio", "immediately": false, "once": true, "state": 3}], "set-state": [{"event": "flush_to_disk", "new-state": 2, "state": 1}, {"event": "read_aio", "new-state": 3, "state": 2}]}, "node-name": "drive0"}} 3256{"return": {}} 3257 3258--- Write #0 --- 3259 3260write -P0x49 0x0000000 0x10000 3261{"return": ""} 3262write -P0x6c 0x0100000 0x10000 3263{"return": ""} 3264write -P0x6f 0x2000000 0x10000 3265{"return": ""} 3266write -P0x76 0x3ff0000 0x10000 3267{"return": ""} 3268{ 3269 "bitmaps": {} 3270} 3271 3272--- Reference Backup #0 --- 3273 3274{} 3275{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3276{"return": {}} 3277{} 3278{} 3279{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3280{"return": {}} 3281{} 3282{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 3283{"return": {}} 3284{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3285 3286--- Add Bitmap --- 3287 3288{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 3289{"return": {}} 3290 3291--- Write #1 --- 3292 3293write -P0x65 0x0000000 0x10000 3294{"return": ""} 3295write -P0x77 0x00f8000 0x10000 3296{"return": ""} 3297write -P0x72 0x2008000 0x10000 3298{"return": ""} 3299write -P0x69 0x3fe0000 0x10000 3300{"return": ""} 3301{ 3302 "bitmaps": { 3303 "drive0": [ 3304 { 3305 "busy": false, 3306 "count": 393216, 3307 "granularity": 65536, 3308 "name": "bitmap0", 3309 "persistent": false, 3310 "recording": true 3311 } 3312 ] 3313 } 3314} 3315 3316= Checking Bitmap bitmap0 = 3317expecting 6 dirty sectors; have 6. OK! 3318 3319--- Reference Backup #1 --- 3320 3321{} 3322{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3323{"return": {}} 3324{} 3325{} 3326{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3327{"return": {}} 3328{} 3329{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 3330{"return": {}} 3331{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3332 3333{"return": ""} 3334 3335--- Test Backup #1 --- 3336 3337{} 3338{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3339{"return": {}} 3340{} 3341{} 3342{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3343{"return": {}} 3344{} 3345{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "full", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 3346{"return": {}} 3347{"data": {"action": "report", "device": "backup_1", "operation": "read"}, "event": "BLOCK_JOB_ERROR", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3348{"data": {"device": "backup_1", "error": "Input/output error", "len": 67108864, "offset": 983040, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3349{ 3350 "bitmaps": { 3351 "drive0": [ 3352 { 3353 "busy": false, 3354 "count": 66125824, 3355 "granularity": 65536, 3356 "name": "bitmap0", 3357 "persistent": false, 3358 "recording": true 3359 } 3360 ] 3361 } 3362} 3363 3364= Checking Bitmap bitmap0 = 3365expecting 1009 dirty sectors; have 1009. OK! 3366 3367--- Write #3 --- 3368 3369write -P0xaa 0x0010000 0x30000 3370{"return": ""} 3371write -P0xbb 0x00d8000 0x10000 3372{"return": ""} 3373write -P0xcc 0x2028000 0x10000 3374{"return": ""} 3375write -P0xdd 0x3fc0000 0x10000 3376{"return": ""} 3377{ 3378 "bitmaps": { 3379 "drive0": [ 3380 { 3381 "busy": false, 3382 "count": 66453504, 3383 "granularity": 65536, 3384 "name": "bitmap0", 3385 "persistent": false, 3386 "recording": true 3387 } 3388 ] 3389 } 3390} 3391 3392= Checking Bitmap bitmap0 = 3393expecting 1014 dirty sectors; have 1014. OK! 3394 3395--- Reference Backup #2 --- 3396 3397{} 3398{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3399{"return": {}} 3400{} 3401{} 3402{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3403{"return": {}} 3404{} 3405{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 3406{"return": {}} 3407{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3408 3409--- Test Backup #2 --- 3410 3411{} 3412{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3413{"return": {}} 3414{} 3415{} 3416{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3417{"return": {}} 3418{} 3419{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 3420{"return": {}} 3421{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 3422{"return": {}} 3423{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3424{"data": {"device": "backup_2", "len": 66453504, "offset": 66453504, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3425{ 3426 "bitmaps": { 3427 "drive0": [ 3428 { 3429 "busy": false, 3430 "count": 0, 3431 "granularity": 65536, 3432 "name": "bitmap0", 3433 "persistent": false, 3434 "recording": true 3435 } 3436 ] 3437 } 3438} 3439 3440= Checking Bitmap bitmap0 = 3441expecting 0 dirty sectors; have 0. OK! 3442 3443--- Cleanup --- 3444 3445{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 3446{"return": {}} 3447{ 3448 "bitmaps": {} 3449} 3450 3451--- Verification --- 3452 3453qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Mismatch, OK! 3454qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 3455qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 3456 3457 3458=== Mode full; Bitmap Sync always without failure === 3459 3460--- Preparing image & VM --- 3461 3462{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 3463{"return": {}} 3464 3465--- Write #0 --- 3466 3467write -P0x49 0x0000000 0x10000 3468{"return": ""} 3469write -P0x6c 0x0100000 0x10000 3470{"return": ""} 3471write -P0x6f 0x2000000 0x10000 3472{"return": ""} 3473write -P0x76 0x3ff0000 0x10000 3474{"return": ""} 3475{ 3476 "bitmaps": {} 3477} 3478 3479--- Reference Backup #0 --- 3480 3481{} 3482{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3483{"return": {}} 3484{} 3485{} 3486{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3487{"return": {}} 3488{} 3489{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 3490{"return": {}} 3491{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3492 3493--- Add Bitmap --- 3494 3495{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 3496{"return": {}} 3497 3498--- Write #1 --- 3499 3500write -P0x65 0x0000000 0x10000 3501{"return": ""} 3502write -P0x77 0x00f8000 0x10000 3503{"return": ""} 3504write -P0x72 0x2008000 0x10000 3505{"return": ""} 3506write -P0x69 0x3fe0000 0x10000 3507{"return": ""} 3508{ 3509 "bitmaps": { 3510 "drive0": [ 3511 { 3512 "busy": false, 3513 "count": 393216, 3514 "granularity": 65536, 3515 "name": "bitmap0", 3516 "persistent": false, 3517 "recording": true 3518 } 3519 ] 3520 } 3521} 3522 3523= Checking Bitmap bitmap0 = 3524expecting 6 dirty sectors; have 6. OK! 3525 3526--- Reference Backup #1 --- 3527 3528{} 3529{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3530{"return": {}} 3531{} 3532{} 3533{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3534{"return": {}} 3535{} 3536{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 3537{"return": {}} 3538{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3539 3540--- Test Backup #1 --- 3541 3542{} 3543{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3544{"return": {}} 3545{} 3546{} 3547{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3548{"return": {}} 3549{} 3550{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "full", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 3551{"return": {}} 3552 3553--- Write #2 --- 3554 3555write -P0x74 0x0010000 0x10000 3556{"return": ""} 3557write -P0x69 0x00e8000 0x10000 3558{"return": ""} 3559write -P0x6e 0x2018000 0x10000 3560{"return": ""} 3561write -P0x67 0x3fe0000 0x20000 3562{"return": ""} 3563{ 3564 "bitmaps": { 3565 "backup-top": [ 3566 { 3567 "busy": false, 3568 "count": 67108864, 3569 "granularity": 65536, 3570 "persistent": false, 3571 "recording": false 3572 }, 3573 { 3574 "busy": false, 3575 "count": 458752, 3576 "granularity": 65536, 3577 "persistent": false, 3578 "recording": false 3579 }, 3580 { 3581 "busy": false, 3582 "count": 0, 3583 "granularity": 65536, 3584 "persistent": false, 3585 "recording": false 3586 } 3587 ], 3588 "drive0": [ 3589 { 3590 "busy": false, 3591 "count": 458752, 3592 "granularity": 65536, 3593 "persistent": false, 3594 "recording": true 3595 }, 3596 { 3597 "busy": true, 3598 "count": 393216, 3599 "granularity": 65536, 3600 "name": "bitmap0", 3601 "persistent": false, 3602 "recording": true 3603 } 3604 ] 3605 } 3606} 3607 3608= Checking Bitmap bitmap0 = 3609expecting 6 dirty sectors; have 6. OK! 3610 3611= Checking Bitmap (anonymous) = 3612expecting 7 dirty sectors; have 7. OK! 3613 3614{"execute": "job-finalize", "arguments": {"id": "backup_1"}} 3615{"return": {}} 3616{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3617{"data": {"device": "backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3618{ 3619 "bitmaps": { 3620 "drive0": [ 3621 { 3622 "busy": false, 3623 "count": 458752, 3624 "granularity": 65536, 3625 "name": "bitmap0", 3626 "persistent": false, 3627 "recording": true 3628 } 3629 ] 3630 } 3631} 3632 3633= Checking Bitmap bitmap0 = 3634expecting 7 dirty sectors; have 7. OK! 3635 3636--- Write #3 --- 3637 3638write -P0xaa 0x0010000 0x30000 3639{"return": ""} 3640write -P0xbb 0x00d8000 0x10000 3641{"return": ""} 3642write -P0xcc 0x2028000 0x10000 3643{"return": ""} 3644write -P0xdd 0x3fc0000 0x10000 3645{"return": ""} 3646{ 3647 "bitmaps": { 3648 "drive0": [ 3649 { 3650 "busy": false, 3651 "count": 786432, 3652 "granularity": 65536, 3653 "name": "bitmap0", 3654 "persistent": false, 3655 "recording": true 3656 } 3657 ] 3658 } 3659} 3660 3661= Checking Bitmap bitmap0 = 3662expecting 12 dirty sectors; have 12. OK! 3663 3664--- Reference Backup #2 --- 3665 3666{} 3667{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3668{"return": {}} 3669{} 3670{} 3671{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3672{"return": {}} 3673{} 3674{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 3675{"return": {}} 3676{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3677 3678--- Test Backup #2 --- 3679 3680{} 3681{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3682{"return": {}} 3683{} 3684{} 3685{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3686{"return": {}} 3687{} 3688{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 3689{"return": {}} 3690{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 3691{"return": {}} 3692{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3693{"data": {"device": "backup_2", "len": 786432, "offset": 786432, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3694{ 3695 "bitmaps": { 3696 "drive0": [ 3697 { 3698 "busy": false, 3699 "count": 0, 3700 "granularity": 65536, 3701 "name": "bitmap0", 3702 "persistent": false, 3703 "recording": true 3704 } 3705 ] 3706 } 3707} 3708 3709= Checking Bitmap bitmap0 = 3710expecting 0 dirty sectors; have 0. OK! 3711 3712--- Cleanup --- 3713 3714{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 3715{"return": {}} 3716{ 3717 "bitmaps": {} 3718} 3719 3720--- Verification --- 3721 3722qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 3723qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 3724qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 3725 3726 3727=== Mode top; Bitmap Sync on-success with simulated failure === 3728 3729--- Preparing image & VM --- 3730 3731{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 3732{"return": {}} 3733 3734--- Write #0 --- 3735 3736write -P0x49 0x0000000 0x10000 3737{"return": ""} 3738write -P0x6c 0x0100000 0x10000 3739{"return": ""} 3740write -P0x6f 0x2000000 0x10000 3741{"return": ""} 3742write -P0x76 0x3ff0000 0x10000 3743{"return": ""} 3744{ 3745 "bitmaps": {} 3746} 3747 3748--- Reference Backup #0 --- 3749 3750{} 3751{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3752{"return": {}} 3753{} 3754{} 3755{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3756{"return": {}} 3757{} 3758{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 3759{"return": {}} 3760{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3761 3762--- Add Bitmap --- 3763 3764{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 3765{"return": {}} 3766 3767--- Write #1 --- 3768 3769write -P0x65 0x0000000 0x10000 3770{"return": ""} 3771write -P0x77 0x00f8000 0x10000 3772{"return": ""} 3773write -P0x72 0x2008000 0x10000 3774{"return": ""} 3775write -P0x69 0x3fe0000 0x10000 3776{"return": ""} 3777{ 3778 "bitmaps": { 3779 "drive0": [ 3780 { 3781 "busy": false, 3782 "count": 393216, 3783 "granularity": 65536, 3784 "name": "bitmap0", 3785 "persistent": false, 3786 "recording": true 3787 } 3788 ] 3789 } 3790} 3791 3792= Checking Bitmap bitmap0 = 3793expecting 6 dirty sectors; have 6. OK! 3794 3795--- Reference Backup #1 --- 3796 3797{} 3798{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3799{"return": {}} 3800{} 3801{} 3802{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3803{"return": {}} 3804{} 3805{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 3806{"return": {}} 3807{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3808 3809--- Test Backup #1 --- 3810 3811{} 3812{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3813{"return": {}} 3814{} 3815{} 3816{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3817{"return": {}} 3818{} 3819{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "top", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 3820{"return": {}} 3821 3822--- Write #2 --- 3823 3824write -P0x74 0x0010000 0x10000 3825{"return": ""} 3826write -P0x69 0x00e8000 0x10000 3827{"return": ""} 3828write -P0x6e 0x2018000 0x10000 3829{"return": ""} 3830write -P0x67 0x3fe0000 0x20000 3831{"return": ""} 3832{ 3833 "bitmaps": { 3834 "backup-top": [ 3835 { 3836 "busy": false, 3837 "count": 67108864, 3838 "granularity": 65536, 3839 "persistent": false, 3840 "recording": false 3841 }, 3842 { 3843 "busy": false, 3844 "count": 458752, 3845 "granularity": 65536, 3846 "persistent": false, 3847 "recording": false 3848 }, 3849 { 3850 "busy": false, 3851 "count": 0, 3852 "granularity": 65536, 3853 "persistent": false, 3854 "recording": false 3855 } 3856 ], 3857 "drive0": [ 3858 { 3859 "busy": false, 3860 "count": 458752, 3861 "granularity": 65536, 3862 "persistent": false, 3863 "recording": true 3864 }, 3865 { 3866 "busy": true, 3867 "count": 393216, 3868 "granularity": 65536, 3869 "name": "bitmap0", 3870 "persistent": false, 3871 "recording": true 3872 } 3873 ] 3874 } 3875} 3876 3877= Checking Bitmap bitmap0 = 3878expecting 6 dirty sectors; have 6. OK! 3879 3880= Checking Bitmap (anonymous) = 3881expecting 7 dirty sectors; have 7. OK! 3882 3883{"execute": "job-cancel", "arguments": {"id": "backup_1"}} 3884{"return": {}} 3885{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3886{"data": {"device": "backup_1", "len": 458752, "offset": 458752, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_CANCELLED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3887{ 3888 "bitmaps": { 3889 "drive0": [ 3890 { 3891 "busy": false, 3892 "count": 655360, 3893 "granularity": 65536, 3894 "name": "bitmap0", 3895 "persistent": false, 3896 "recording": true 3897 } 3898 ] 3899 } 3900} 3901 3902= Checking Bitmap bitmap0 = 3903expecting 10 dirty sectors; have 10. OK! 3904 3905--- Write #3 --- 3906 3907write -P0xaa 0x0010000 0x30000 3908{"return": ""} 3909write -P0xbb 0x00d8000 0x10000 3910{"return": ""} 3911write -P0xcc 0x2028000 0x10000 3912{"return": ""} 3913write -P0xdd 0x3fc0000 0x10000 3914{"return": ""} 3915{ 3916 "bitmaps": { 3917 "drive0": [ 3918 { 3919 "busy": false, 3920 "count": 983040, 3921 "granularity": 65536, 3922 "name": "bitmap0", 3923 "persistent": false, 3924 "recording": true 3925 } 3926 ] 3927 } 3928} 3929 3930= Checking Bitmap bitmap0 = 3931expecting 15 dirty sectors; have 15. OK! 3932 3933--- Reference Backup #2 --- 3934 3935{} 3936{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3937{"return": {}} 3938{} 3939{} 3940{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3941{"return": {}} 3942{} 3943{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 3944{"return": {}} 3945{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3946 3947--- Test Backup #2 --- 3948 3949{} 3950{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 3951{"return": {}} 3952{} 3953{} 3954{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 3955{"return": {}} 3956{} 3957{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 3958{"return": {}} 3959{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 3960{"return": {}} 3961{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3962{"data": {"device": "backup_2", "len": 983040, "offset": 983040, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 3963{ 3964 "bitmaps": { 3965 "drive0": [ 3966 { 3967 "busy": false, 3968 "count": 0, 3969 "granularity": 65536, 3970 "name": "bitmap0", 3971 "persistent": false, 3972 "recording": true 3973 } 3974 ] 3975 } 3976} 3977 3978= Checking Bitmap bitmap0 = 3979expecting 0 dirty sectors; have 0. OK! 3980 3981--- Cleanup --- 3982 3983{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 3984{"return": {}} 3985{ 3986 "bitmaps": {} 3987} 3988 3989--- Verification --- 3990 3991qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 3992qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 3993qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 3994 3995 3996=== Mode top; Bitmap Sync on-success with intermediate failure === 3997 3998--- Preparing image & VM --- 3999 4000{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "blkdebug", "image": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "inject-error": [{"errno": 5, "event": "read_aio", "immediately": false, "once": true, "state": 3}], "set-state": [{"event": "flush_to_disk", "new-state": 2, "state": 1}, {"event": "read_aio", "new-state": 3, "state": 2}]}, "node-name": "drive0"}} 4001{"return": {}} 4002 4003--- Write #0 --- 4004 4005write -P0x49 0x0000000 0x10000 4006{"return": ""} 4007write -P0x6c 0x0100000 0x10000 4008{"return": ""} 4009write -P0x6f 0x2000000 0x10000 4010{"return": ""} 4011write -P0x76 0x3ff0000 0x10000 4012{"return": ""} 4013{ 4014 "bitmaps": {} 4015} 4016 4017--- Reference Backup #0 --- 4018 4019{} 4020{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4021{"return": {}} 4022{} 4023{} 4024{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4025{"return": {}} 4026{} 4027{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 4028{"return": {}} 4029{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4030 4031--- Add Bitmap --- 4032 4033{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 4034{"return": {}} 4035 4036--- Write #1 --- 4037 4038write -P0x65 0x0000000 0x10000 4039{"return": ""} 4040write -P0x77 0x00f8000 0x10000 4041{"return": ""} 4042write -P0x72 0x2008000 0x10000 4043{"return": ""} 4044write -P0x69 0x3fe0000 0x10000 4045{"return": ""} 4046{ 4047 "bitmaps": { 4048 "drive0": [ 4049 { 4050 "busy": false, 4051 "count": 393216, 4052 "granularity": 65536, 4053 "name": "bitmap0", 4054 "persistent": false, 4055 "recording": true 4056 } 4057 ] 4058 } 4059} 4060 4061= Checking Bitmap bitmap0 = 4062expecting 6 dirty sectors; have 6. OK! 4063 4064--- Reference Backup #1 --- 4065 4066{} 4067{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4068{"return": {}} 4069{} 4070{} 4071{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4072{"return": {}} 4073{} 4074{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 4075{"return": {}} 4076{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4077 4078{"return": ""} 4079 4080--- Test Backup #1 --- 4081 4082{} 4083{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4084{"return": {}} 4085{} 4086{} 4087{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4088{"return": {}} 4089{} 4090{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "top", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 4091{"return": {}} 4092{"data": {"action": "report", "device": "backup_1", "operation": "read"}, "event": "BLOCK_JOB_ERROR", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4093{"data": {"device": "backup_1", "error": "Input/output error", "len": 458752, "offset": 65536, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4094{ 4095 "bitmaps": { 4096 "drive0": [ 4097 { 4098 "busy": false, 4099 "count": 393216, 4100 "granularity": 65536, 4101 "name": "bitmap0", 4102 "persistent": false, 4103 "recording": true 4104 } 4105 ] 4106 } 4107} 4108 4109= Checking Bitmap bitmap0 = 4110expecting 6 dirty sectors; have 6. OK! 4111 4112--- Write #3 --- 4113 4114write -P0xaa 0x0010000 0x30000 4115{"return": ""} 4116write -P0xbb 0x00d8000 0x10000 4117{"return": ""} 4118write -P0xcc 0x2028000 0x10000 4119{"return": ""} 4120write -P0xdd 0x3fc0000 0x10000 4121{"return": ""} 4122{ 4123 "bitmaps": { 4124 "drive0": [ 4125 { 4126 "busy": false, 4127 "count": 917504, 4128 "granularity": 65536, 4129 "name": "bitmap0", 4130 "persistent": false, 4131 "recording": true 4132 } 4133 ] 4134 } 4135} 4136 4137= Checking Bitmap bitmap0 = 4138expecting 14 dirty sectors; have 14. OK! 4139 4140--- Reference Backup #2 --- 4141 4142{} 4143{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4144{"return": {}} 4145{} 4146{} 4147{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4148{"return": {}} 4149{} 4150{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 4151{"return": {}} 4152{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4153 4154--- Test Backup #2 --- 4155 4156{} 4157{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4158{"return": {}} 4159{} 4160{} 4161{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4162{"return": {}} 4163{} 4164{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 4165{"return": {}} 4166{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 4167{"return": {}} 4168{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4169{"data": {"device": "backup_2", "len": 917504, "offset": 917504, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4170{ 4171 "bitmaps": { 4172 "drive0": [ 4173 { 4174 "busy": false, 4175 "count": 0, 4176 "granularity": 65536, 4177 "name": "bitmap0", 4178 "persistent": false, 4179 "recording": true 4180 } 4181 ] 4182 } 4183} 4184 4185= Checking Bitmap bitmap0 = 4186expecting 0 dirty sectors; have 0. OK! 4187 4188--- Cleanup --- 4189 4190{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 4191{"return": {}} 4192{ 4193 "bitmaps": {} 4194} 4195 4196--- Verification --- 4197 4198qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Mismatch, OK! 4199qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 4200qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 4201 4202 4203=== Mode top; Bitmap Sync on-success without failure === 4204 4205--- Preparing image & VM --- 4206 4207{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 4208{"return": {}} 4209 4210--- Write #0 --- 4211 4212write -P0x49 0x0000000 0x10000 4213{"return": ""} 4214write -P0x6c 0x0100000 0x10000 4215{"return": ""} 4216write -P0x6f 0x2000000 0x10000 4217{"return": ""} 4218write -P0x76 0x3ff0000 0x10000 4219{"return": ""} 4220{ 4221 "bitmaps": {} 4222} 4223 4224--- Reference Backup #0 --- 4225 4226{} 4227{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4228{"return": {}} 4229{} 4230{} 4231{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4232{"return": {}} 4233{} 4234{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 4235{"return": {}} 4236{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4237 4238--- Add Bitmap --- 4239 4240{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 4241{"return": {}} 4242 4243--- Write #1 --- 4244 4245write -P0x65 0x0000000 0x10000 4246{"return": ""} 4247write -P0x77 0x00f8000 0x10000 4248{"return": ""} 4249write -P0x72 0x2008000 0x10000 4250{"return": ""} 4251write -P0x69 0x3fe0000 0x10000 4252{"return": ""} 4253{ 4254 "bitmaps": { 4255 "drive0": [ 4256 { 4257 "busy": false, 4258 "count": 393216, 4259 "granularity": 65536, 4260 "name": "bitmap0", 4261 "persistent": false, 4262 "recording": true 4263 } 4264 ] 4265 } 4266} 4267 4268= Checking Bitmap bitmap0 = 4269expecting 6 dirty sectors; have 6. OK! 4270 4271--- Reference Backup #1 --- 4272 4273{} 4274{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4275{"return": {}} 4276{} 4277{} 4278{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4279{"return": {}} 4280{} 4281{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 4282{"return": {}} 4283{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4284 4285--- Test Backup #1 --- 4286 4287{} 4288{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4289{"return": {}} 4290{} 4291{} 4292{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4293{"return": {}} 4294{} 4295{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "top", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 4296{"return": {}} 4297 4298--- Write #2 --- 4299 4300write -P0x74 0x0010000 0x10000 4301{"return": ""} 4302write -P0x69 0x00e8000 0x10000 4303{"return": ""} 4304write -P0x6e 0x2018000 0x10000 4305{"return": ""} 4306write -P0x67 0x3fe0000 0x20000 4307{"return": ""} 4308{ 4309 "bitmaps": { 4310 "backup-top": [ 4311 { 4312 "busy": false, 4313 "count": 67108864, 4314 "granularity": 65536, 4315 "persistent": false, 4316 "recording": false 4317 }, 4318 { 4319 "busy": false, 4320 "count": 458752, 4321 "granularity": 65536, 4322 "persistent": false, 4323 "recording": false 4324 }, 4325 { 4326 "busy": false, 4327 "count": 0, 4328 "granularity": 65536, 4329 "persistent": false, 4330 "recording": false 4331 } 4332 ], 4333 "drive0": [ 4334 { 4335 "busy": false, 4336 "count": 458752, 4337 "granularity": 65536, 4338 "persistent": false, 4339 "recording": true 4340 }, 4341 { 4342 "busy": true, 4343 "count": 393216, 4344 "granularity": 65536, 4345 "name": "bitmap0", 4346 "persistent": false, 4347 "recording": true 4348 } 4349 ] 4350 } 4351} 4352 4353= Checking Bitmap bitmap0 = 4354expecting 6 dirty sectors; have 6. OK! 4355 4356= Checking Bitmap (anonymous) = 4357expecting 7 dirty sectors; have 7. OK! 4358 4359{"execute": "job-finalize", "arguments": {"id": "backup_1"}} 4360{"return": {}} 4361{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4362{"data": {"device": "backup_1", "len": 458752, "offset": 458752, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4363{ 4364 "bitmaps": { 4365 "drive0": [ 4366 { 4367 "busy": false, 4368 "count": 458752, 4369 "granularity": 65536, 4370 "name": "bitmap0", 4371 "persistent": false, 4372 "recording": true 4373 } 4374 ] 4375 } 4376} 4377 4378= Checking Bitmap bitmap0 = 4379expecting 7 dirty sectors; have 7. OK! 4380 4381--- Write #3 --- 4382 4383write -P0xaa 0x0010000 0x30000 4384{"return": ""} 4385write -P0xbb 0x00d8000 0x10000 4386{"return": ""} 4387write -P0xcc 0x2028000 0x10000 4388{"return": ""} 4389write -P0xdd 0x3fc0000 0x10000 4390{"return": ""} 4391{ 4392 "bitmaps": { 4393 "drive0": [ 4394 { 4395 "busy": false, 4396 "count": 786432, 4397 "granularity": 65536, 4398 "name": "bitmap0", 4399 "persistent": false, 4400 "recording": true 4401 } 4402 ] 4403 } 4404} 4405 4406= Checking Bitmap bitmap0 = 4407expecting 12 dirty sectors; have 12. OK! 4408 4409--- Reference Backup #2 --- 4410 4411{} 4412{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4413{"return": {}} 4414{} 4415{} 4416{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4417{"return": {}} 4418{} 4419{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 4420{"return": {}} 4421{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4422 4423--- Test Backup #2 --- 4424 4425{} 4426{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4427{"return": {}} 4428{} 4429{} 4430{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4431{"return": {}} 4432{} 4433{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 4434{"return": {}} 4435{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 4436{"return": {}} 4437{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4438{"data": {"device": "backup_2", "len": 786432, "offset": 786432, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4439{ 4440 "bitmaps": { 4441 "drive0": [ 4442 { 4443 "busy": false, 4444 "count": 0, 4445 "granularity": 65536, 4446 "name": "bitmap0", 4447 "persistent": false, 4448 "recording": true 4449 } 4450 ] 4451 } 4452} 4453 4454= Checking Bitmap bitmap0 = 4455expecting 0 dirty sectors; have 0. OK! 4456 4457--- Cleanup --- 4458 4459{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 4460{"return": {}} 4461{ 4462 "bitmaps": {} 4463} 4464 4465--- Verification --- 4466 4467qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 4468qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 4469qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 4470 4471 4472=== Mode top; Bitmap Sync always with simulated failure === 4473 4474--- Preparing image & VM --- 4475 4476{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 4477{"return": {}} 4478 4479--- Write #0 --- 4480 4481write -P0x49 0x0000000 0x10000 4482{"return": ""} 4483write -P0x6c 0x0100000 0x10000 4484{"return": ""} 4485write -P0x6f 0x2000000 0x10000 4486{"return": ""} 4487write -P0x76 0x3ff0000 0x10000 4488{"return": ""} 4489{ 4490 "bitmaps": {} 4491} 4492 4493--- Reference Backup #0 --- 4494 4495{} 4496{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4497{"return": {}} 4498{} 4499{} 4500{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4501{"return": {}} 4502{} 4503{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 4504{"return": {}} 4505{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4506 4507--- Add Bitmap --- 4508 4509{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 4510{"return": {}} 4511 4512--- Write #1 --- 4513 4514write -P0x65 0x0000000 0x10000 4515{"return": ""} 4516write -P0x77 0x00f8000 0x10000 4517{"return": ""} 4518write -P0x72 0x2008000 0x10000 4519{"return": ""} 4520write -P0x69 0x3fe0000 0x10000 4521{"return": ""} 4522{ 4523 "bitmaps": { 4524 "drive0": [ 4525 { 4526 "busy": false, 4527 "count": 393216, 4528 "granularity": 65536, 4529 "name": "bitmap0", 4530 "persistent": false, 4531 "recording": true 4532 } 4533 ] 4534 } 4535} 4536 4537= Checking Bitmap bitmap0 = 4538expecting 6 dirty sectors; have 6. OK! 4539 4540--- Reference Backup #1 --- 4541 4542{} 4543{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4544{"return": {}} 4545{} 4546{} 4547{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4548{"return": {}} 4549{} 4550{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 4551{"return": {}} 4552{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4553 4554--- Test Backup #1 --- 4555 4556{} 4557{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4558{"return": {}} 4559{} 4560{} 4561{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4562{"return": {}} 4563{} 4564{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "top", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 4565{"return": {}} 4566 4567--- Write #2 --- 4568 4569write -P0x74 0x0010000 0x10000 4570{"return": ""} 4571write -P0x69 0x00e8000 0x10000 4572{"return": ""} 4573write -P0x6e 0x2018000 0x10000 4574{"return": ""} 4575write -P0x67 0x3fe0000 0x20000 4576{"return": ""} 4577{ 4578 "bitmaps": { 4579 "backup-top": [ 4580 { 4581 "busy": false, 4582 "count": 67108864, 4583 "granularity": 65536, 4584 "persistent": false, 4585 "recording": false 4586 }, 4587 { 4588 "busy": false, 4589 "count": 458752, 4590 "granularity": 65536, 4591 "persistent": false, 4592 "recording": false 4593 }, 4594 { 4595 "busy": false, 4596 "count": 0, 4597 "granularity": 65536, 4598 "persistent": false, 4599 "recording": false 4600 } 4601 ], 4602 "drive0": [ 4603 { 4604 "busy": false, 4605 "count": 458752, 4606 "granularity": 65536, 4607 "persistent": false, 4608 "recording": true 4609 }, 4610 { 4611 "busy": true, 4612 "count": 393216, 4613 "granularity": 65536, 4614 "name": "bitmap0", 4615 "persistent": false, 4616 "recording": true 4617 } 4618 ] 4619 } 4620} 4621 4622= Checking Bitmap bitmap0 = 4623expecting 6 dirty sectors; have 6. OK! 4624 4625= Checking Bitmap (anonymous) = 4626expecting 7 dirty sectors; have 7. OK! 4627 4628{"execute": "job-cancel", "arguments": {"id": "backup_1"}} 4629{"return": {}} 4630{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4631{"data": {"device": "backup_1", "len": 458752, "offset": 458752, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_CANCELLED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4632{ 4633 "bitmaps": { 4634 "drive0": [ 4635 { 4636 "busy": false, 4637 "count": 458752, 4638 "granularity": 65536, 4639 "name": "bitmap0", 4640 "persistent": false, 4641 "recording": true 4642 } 4643 ] 4644 } 4645} 4646 4647= Checking Bitmap bitmap0 = 4648expecting 7 dirty sectors; have 7. OK! 4649 4650--- Write #3 --- 4651 4652write -P0xaa 0x0010000 0x30000 4653{"return": ""} 4654write -P0xbb 0x00d8000 0x10000 4655{"return": ""} 4656write -P0xcc 0x2028000 0x10000 4657{"return": ""} 4658write -P0xdd 0x3fc0000 0x10000 4659{"return": ""} 4660{ 4661 "bitmaps": { 4662 "drive0": [ 4663 { 4664 "busy": false, 4665 "count": 786432, 4666 "granularity": 65536, 4667 "name": "bitmap0", 4668 "persistent": false, 4669 "recording": true 4670 } 4671 ] 4672 } 4673} 4674 4675= Checking Bitmap bitmap0 = 4676expecting 12 dirty sectors; have 12. OK! 4677 4678--- Reference Backup #2 --- 4679 4680{} 4681{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4682{"return": {}} 4683{} 4684{} 4685{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4686{"return": {}} 4687{} 4688{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 4689{"return": {}} 4690{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4691 4692--- Test Backup #2 --- 4693 4694{} 4695{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4696{"return": {}} 4697{} 4698{} 4699{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4700{"return": {}} 4701{} 4702{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 4703{"return": {}} 4704{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 4705{"return": {}} 4706{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4707{"data": {"device": "backup_2", "len": 786432, "offset": 786432, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4708{ 4709 "bitmaps": { 4710 "drive0": [ 4711 { 4712 "busy": false, 4713 "count": 0, 4714 "granularity": 65536, 4715 "name": "bitmap0", 4716 "persistent": false, 4717 "recording": true 4718 } 4719 ] 4720 } 4721} 4722 4723= Checking Bitmap bitmap0 = 4724expecting 0 dirty sectors; have 0. OK! 4725 4726--- Cleanup --- 4727 4728{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 4729{"return": {}} 4730{ 4731 "bitmaps": {} 4732} 4733 4734--- Verification --- 4735 4736qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 4737qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 4738qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 4739 4740 4741=== Mode top; Bitmap Sync always with intermediate failure === 4742 4743--- Preparing image & VM --- 4744 4745{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "blkdebug", "image": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "inject-error": [{"errno": 5, "event": "read_aio", "immediately": false, "once": true, "state": 3}], "set-state": [{"event": "flush_to_disk", "new-state": 2, "state": 1}, {"event": "read_aio", "new-state": 3, "state": 2}]}, "node-name": "drive0"}} 4746{"return": {}} 4747 4748--- Write #0 --- 4749 4750write -P0x49 0x0000000 0x10000 4751{"return": ""} 4752write -P0x6c 0x0100000 0x10000 4753{"return": ""} 4754write -P0x6f 0x2000000 0x10000 4755{"return": ""} 4756write -P0x76 0x3ff0000 0x10000 4757{"return": ""} 4758{ 4759 "bitmaps": {} 4760} 4761 4762--- Reference Backup #0 --- 4763 4764{} 4765{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4766{"return": {}} 4767{} 4768{} 4769{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4770{"return": {}} 4771{} 4772{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 4773{"return": {}} 4774{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4775 4776--- Add Bitmap --- 4777 4778{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 4779{"return": {}} 4780 4781--- Write #1 --- 4782 4783write -P0x65 0x0000000 0x10000 4784{"return": ""} 4785write -P0x77 0x00f8000 0x10000 4786{"return": ""} 4787write -P0x72 0x2008000 0x10000 4788{"return": ""} 4789write -P0x69 0x3fe0000 0x10000 4790{"return": ""} 4791{ 4792 "bitmaps": { 4793 "drive0": [ 4794 { 4795 "busy": false, 4796 "count": 393216, 4797 "granularity": 65536, 4798 "name": "bitmap0", 4799 "persistent": false, 4800 "recording": true 4801 } 4802 ] 4803 } 4804} 4805 4806= Checking Bitmap bitmap0 = 4807expecting 6 dirty sectors; have 6. OK! 4808 4809--- Reference Backup #1 --- 4810 4811{} 4812{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4813{"return": {}} 4814{} 4815{} 4816{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4817{"return": {}} 4818{} 4819{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 4820{"return": {}} 4821{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4822 4823{"return": ""} 4824 4825--- Test Backup #1 --- 4826 4827{} 4828{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4829{"return": {}} 4830{} 4831{} 4832{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4833{"return": {}} 4834{} 4835{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "top", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 4836{"return": {}} 4837{"data": {"action": "report", "device": "backup_1", "operation": "read"}, "event": "BLOCK_JOB_ERROR", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4838{"data": {"device": "backup_1", "error": "Input/output error", "len": 458752, "offset": 65536, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4839{ 4840 "bitmaps": { 4841 "drive0": [ 4842 { 4843 "busy": false, 4844 "count": 393216, 4845 "granularity": 65536, 4846 "name": "bitmap0", 4847 "persistent": false, 4848 "recording": true 4849 } 4850 ] 4851 } 4852} 4853 4854= Checking Bitmap bitmap0 = 4855expecting 6 dirty sectors; have 6. OK! 4856 4857--- Write #3 --- 4858 4859write -P0xaa 0x0010000 0x30000 4860{"return": ""} 4861write -P0xbb 0x00d8000 0x10000 4862{"return": ""} 4863write -P0xcc 0x2028000 0x10000 4864{"return": ""} 4865write -P0xdd 0x3fc0000 0x10000 4866{"return": ""} 4867{ 4868 "bitmaps": { 4869 "drive0": [ 4870 { 4871 "busy": false, 4872 "count": 917504, 4873 "granularity": 65536, 4874 "name": "bitmap0", 4875 "persistent": false, 4876 "recording": true 4877 } 4878 ] 4879 } 4880} 4881 4882= Checking Bitmap bitmap0 = 4883expecting 14 dirty sectors; have 14. OK! 4884 4885--- Reference Backup #2 --- 4886 4887{} 4888{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4889{"return": {}} 4890{} 4891{} 4892{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4893{"return": {}} 4894{} 4895{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 4896{"return": {}} 4897{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4898 4899--- Test Backup #2 --- 4900 4901{} 4902{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4903{"return": {}} 4904{} 4905{} 4906{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4907{"return": {}} 4908{} 4909{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 4910{"return": {}} 4911{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 4912{"return": {}} 4913{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4914{"data": {"device": "backup_2", "len": 917504, "offset": 917504, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4915{ 4916 "bitmaps": { 4917 "drive0": [ 4918 { 4919 "busy": false, 4920 "count": 0, 4921 "granularity": 65536, 4922 "name": "bitmap0", 4923 "persistent": false, 4924 "recording": true 4925 } 4926 ] 4927 } 4928} 4929 4930= Checking Bitmap bitmap0 = 4931expecting 0 dirty sectors; have 0. OK! 4932 4933--- Cleanup --- 4934 4935{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 4936{"return": {}} 4937{ 4938 "bitmaps": {} 4939} 4940 4941--- Verification --- 4942 4943qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Mismatch, OK! 4944qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 4945qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 4946 4947 4948=== Mode top; Bitmap Sync always without failure === 4949 4950--- Preparing image & VM --- 4951 4952{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 4953{"return": {}} 4954 4955--- Write #0 --- 4956 4957write -P0x49 0x0000000 0x10000 4958{"return": ""} 4959write -P0x6c 0x0100000 0x10000 4960{"return": ""} 4961write -P0x6f 0x2000000 0x10000 4962{"return": ""} 4963write -P0x76 0x3ff0000 0x10000 4964{"return": ""} 4965{ 4966 "bitmaps": {} 4967} 4968 4969--- Reference Backup #0 --- 4970 4971{} 4972{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 4973{"return": {}} 4974{} 4975{} 4976{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 4977{"return": {}} 4978{} 4979{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_0", "sync": "full", "target": "ref_target_0", "x-perf": {"max-workers": 1}}} 4980{"return": {}} 4981{"data": {"device": "ref_backup_0", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 4982 4983--- Add Bitmap --- 4984 4985{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 4986{"return": {}} 4987 4988--- Write #1 --- 4989 4990write -P0x65 0x0000000 0x10000 4991{"return": ""} 4992write -P0x77 0x00f8000 0x10000 4993{"return": ""} 4994write -P0x72 0x2008000 0x10000 4995{"return": ""} 4996write -P0x69 0x3fe0000 0x10000 4997{"return": ""} 4998{ 4999 "bitmaps": { 5000 "drive0": [ 5001 { 5002 "busy": false, 5003 "count": 393216, 5004 "granularity": 65536, 5005 "name": "bitmap0", 5006 "persistent": false, 5007 "recording": true 5008 } 5009 ] 5010 } 5011} 5012 5013= Checking Bitmap bitmap0 = 5014expecting 6 dirty sectors; have 6. OK! 5015 5016--- Reference Backup #1 --- 5017 5018{} 5019{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 5020{"return": {}} 5021{} 5022{} 5023{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 5024{"return": {}} 5025{} 5026{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_1", "sync": "full", "target": "ref_target_1", "x-perf": {"max-workers": 1}}} 5027{"return": {}} 5028{"data": {"device": "ref_backup_1", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 5029 5030--- Test Backup #1 --- 5031 5032{} 5033{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 5034{"return": {}} 5035{} 5036{} 5037{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 5038{"return": {}} 5039{} 5040{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_1", "sync": "top", "target": "backup_target_1", "x-perf": {"max-workers": 1}}} 5041{"return": {}} 5042 5043--- Write #2 --- 5044 5045write -P0x74 0x0010000 0x10000 5046{"return": ""} 5047write -P0x69 0x00e8000 0x10000 5048{"return": ""} 5049write -P0x6e 0x2018000 0x10000 5050{"return": ""} 5051write -P0x67 0x3fe0000 0x20000 5052{"return": ""} 5053{ 5054 "bitmaps": { 5055 "backup-top": [ 5056 { 5057 "busy": false, 5058 "count": 67108864, 5059 "granularity": 65536, 5060 "persistent": false, 5061 "recording": false 5062 }, 5063 { 5064 "busy": false, 5065 "count": 458752, 5066 "granularity": 65536, 5067 "persistent": false, 5068 "recording": false 5069 }, 5070 { 5071 "busy": false, 5072 "count": 0, 5073 "granularity": 65536, 5074 "persistent": false, 5075 "recording": false 5076 } 5077 ], 5078 "drive0": [ 5079 { 5080 "busy": false, 5081 "count": 458752, 5082 "granularity": 65536, 5083 "persistent": false, 5084 "recording": true 5085 }, 5086 { 5087 "busy": true, 5088 "count": 393216, 5089 "granularity": 65536, 5090 "name": "bitmap0", 5091 "persistent": false, 5092 "recording": true 5093 } 5094 ] 5095 } 5096} 5097 5098= Checking Bitmap bitmap0 = 5099expecting 6 dirty sectors; have 6. OK! 5100 5101= Checking Bitmap (anonymous) = 5102expecting 7 dirty sectors; have 7. OK! 5103 5104{"execute": "job-finalize", "arguments": {"id": "backup_1"}} 5105{"return": {}} 5106{"data": {"id": "backup_1", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 5107{"data": {"device": "backup_1", "len": 458752, "offset": 458752, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 5108{ 5109 "bitmaps": { 5110 "drive0": [ 5111 { 5112 "busy": false, 5113 "count": 458752, 5114 "granularity": 65536, 5115 "name": "bitmap0", 5116 "persistent": false, 5117 "recording": true 5118 } 5119 ] 5120 } 5121} 5122 5123= Checking Bitmap bitmap0 = 5124expecting 7 dirty sectors; have 7. OK! 5125 5126--- Write #3 --- 5127 5128write -P0xaa 0x0010000 0x30000 5129{"return": ""} 5130write -P0xbb 0x00d8000 0x10000 5131{"return": ""} 5132write -P0xcc 0x2028000 0x10000 5133{"return": ""} 5134write -P0xdd 0x3fc0000 0x10000 5135{"return": ""} 5136{ 5137 "bitmaps": { 5138 "drive0": [ 5139 { 5140 "busy": false, 5141 "count": 786432, 5142 "granularity": 65536, 5143 "name": "bitmap0", 5144 "persistent": false, 5145 "recording": true 5146 } 5147 ] 5148 } 5149} 5150 5151= Checking Bitmap bitmap0 = 5152expecting 12 dirty sectors; have 12. OK! 5153 5154--- Reference Backup #2 --- 5155 5156{} 5157{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 5158{"return": {}} 5159{} 5160{} 5161{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 5162{"return": {}} 5163{} 5164{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "ref_backup_2", "sync": "full", "target": "ref_target_2", "x-perf": {"max-workers": 1}}} 5165{"return": {}} 5166{"data": {"device": "ref_backup_2", "len": 67108864, "offset": 67108864, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 5167 5168--- Test Backup #2 --- 5169 5170{} 5171{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 5172{"return": {}} 5173{} 5174{} 5175{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 5176{"return": {}} 5177{} 5178{"execute": "blockdev-backup", "arguments": {"auto-finalize": false, "bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "backup_2", "sync": "bitmap", "target": "backup_target_2", "x-perf": {"max-workers": 1}}} 5179{"return": {}} 5180{"execute": "job-finalize", "arguments": {"id": "backup_2"}} 5181{"return": {}} 5182{"data": {"id": "backup_2", "type": "backup"}, "event": "BLOCK_JOB_PENDING", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 5183{"data": {"device": "backup_2", "len": 786432, "offset": 786432, "speed": 0, "type": "backup"}, "event": "BLOCK_JOB_COMPLETED", "timestamp": {"microseconds": "USECS", "seconds": "SECS"}} 5184{ 5185 "bitmaps": { 5186 "drive0": [ 5187 { 5188 "busy": false, 5189 "count": 0, 5190 "granularity": 65536, 5191 "name": "bitmap0", 5192 "persistent": false, 5193 "recording": true 5194 } 5195 ] 5196 } 5197} 5198 5199= Checking Bitmap bitmap0 = 5200expecting 0 dirty sectors; have 0. OK! 5201 5202--- Cleanup --- 5203 5204{"execute": "block-dirty-bitmap-remove", "arguments": {"name": "bitmap0", "node": "drive0"}} 5205{"return": {}} 5206{ 5207 "bitmaps": {} 5208} 5209 5210--- Verification --- 5211 5212qemu_img compare "TEST_DIR/PID-bsync1" "TEST_DIR/PID-fbackup1" ==> Identical, OK! 5213qemu_img compare "TEST_DIR/PID-bsync2" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 5214qemu_img compare "TEST_DIR/PID-img" "TEST_DIR/PID-fbackup2" ==> Identical, OK! 5215 5216 5217=== API failure tests === 5218 5219--- Preparing image & VM --- 5220 5221{"execute": "blockdev-add", "arguments": {"driver": "qcow2", "file": {"driver": "file", "filename": "TEST_DIR/PID-img"}, "node-name": "drive0"}} 5222{"return": {}} 5223 5224{} 5225{"execute": "job-dismiss", "arguments": {"id": "bdc-file-job"}} 5226{"return": {}} 5227{} 5228{} 5229{"execute": "job-dismiss", "arguments": {"id": "bdc-fmt-job"}} 5230{"return": {}} 5231{} 5232 5233{"execute": "block-dirty-bitmap-add", "arguments": {"granularity": 65536, "name": "bitmap0", "node": "drive0"}} 5234{"return": {}} 5235 5236-- Testing invalid QMP commands -- 5237 5238-- Sync mode incremental tests -- 5239 5240{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "incremental", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5241{"error": {"class": "GenericError", "desc": "must provide a valid bitmap name for 'incremental' sync mode"}} 5242 5243{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "incremental", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5244{"error": {"class": "GenericError", "desc": "must provide a valid bitmap name for 'incremental' sync mode"}} 5245 5246{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "incremental", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5247{"error": {"class": "GenericError", "desc": "must provide a valid bitmap name for 'incremental' sync mode"}} 5248 5249{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "incremental", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5250{"error": {"class": "GenericError", "desc": "must provide a valid bitmap name for 'incremental' sync mode"}} 5251 5252{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "incremental", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5253{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5254 5255{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "incremental", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5256{"error": {"class": "GenericError", "desc": "Bitmap sync mode must be 'on-success' when using sync mode 'incremental'"}} 5257 5258{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "incremental", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5259{"error": {"class": "GenericError", "desc": "Bitmap sync mode must be 'on-success' when using sync mode 'incremental'"}} 5260 5261{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "incremental", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5262{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5263 5264{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "incremental", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5265{"error": {"class": "GenericError", "desc": "Bitmap sync mode must be 'on-success' when using sync mode 'incremental'"}} 5266 5267{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "incremental", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5268{"error": {"class": "GenericError", "desc": "Bitmap sync mode must be 'on-success' when using sync mode 'incremental'"}} 5269 5270-- Sync mode bitmap tests -- 5271 5272{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "bitmap", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5273{"error": {"class": "GenericError", "desc": "must provide a valid bitmap name for 'bitmap' sync mode"}} 5274 5275{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "bitmap", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5276{"error": {"class": "GenericError", "desc": "must provide a valid bitmap name for 'bitmap' sync mode"}} 5277 5278{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "bitmap", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5279{"error": {"class": "GenericError", "desc": "must provide a valid bitmap name for 'bitmap' sync mode"}} 5280 5281{"execute": "blockdev-backup", "arguments": {"device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "bitmap", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5282{"error": {"class": "GenericError", "desc": "must provide a valid bitmap name for 'bitmap' sync mode"}} 5283 5284{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "bitmap", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5285{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5286 5287{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "bitmap", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5288{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5289 5290{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "bitmap", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5291{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5292 5293{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "bitmap", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5294{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5295 5296{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "bitmap", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5297{"error": {"class": "GenericError", "desc": "Bitmap sync mode must be given when providing a bitmap"}} 5298 5299-- Sync mode full tests -- 5300 5301{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "full", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5302{"error": {"class": "GenericError", "desc": "Cannot specify bitmap sync mode without a bitmap"}} 5303 5304{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "full", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5305{"error": {"class": "GenericError", "desc": "Cannot specify bitmap sync mode without a bitmap"}} 5306 5307{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "full", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5308{"error": {"class": "GenericError", "desc": "Cannot specify bitmap sync mode without a bitmap"}} 5309 5310{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "full", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5311{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5312 5313{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "full", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5314{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5315 5316{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "full", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5317{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5318 5319{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "full", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5320{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5321 5322{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "full", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5323{"error": {"class": "GenericError", "desc": "Bitmap sync mode 'never' has no meaningful effect when combined with sync mode 'full'"}} 5324 5325{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "full", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5326{"error": {"class": "GenericError", "desc": "Bitmap sync mode must be given when providing a bitmap"}} 5327 5328-- Sync mode top tests -- 5329 5330{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "top", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5331{"error": {"class": "GenericError", "desc": "Cannot specify bitmap sync mode without a bitmap"}} 5332 5333{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "top", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5334{"error": {"class": "GenericError", "desc": "Cannot specify bitmap sync mode without a bitmap"}} 5335 5336{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "top", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5337{"error": {"class": "GenericError", "desc": "Cannot specify bitmap sync mode without a bitmap"}} 5338 5339{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "top", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5340{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5341 5342{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "top", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5343{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5344 5345{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "top", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5346{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5347 5348{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "top", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5349{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5350 5351{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "top", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5352{"error": {"class": "GenericError", "desc": "Bitmap sync mode 'never' has no meaningful effect when combined with sync mode 'top'"}} 5353 5354{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "top", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5355{"error": {"class": "GenericError", "desc": "Bitmap sync mode must be given when providing a bitmap"}} 5356 5357-- Sync mode none tests -- 5358 5359{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5360{"error": {"class": "GenericError", "desc": "Cannot specify bitmap sync mode without a bitmap"}} 5361 5362{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5363{"error": {"class": "GenericError", "desc": "Cannot specify bitmap sync mode without a bitmap"}} 5364 5365{"execute": "blockdev-backup", "arguments": {"bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5366{"error": {"class": "GenericError", "desc": "Cannot specify bitmap sync mode without a bitmap"}} 5367 5368{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5369{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5370 5371{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5372{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5373 5374{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5375{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5376 5377{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap404", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5378{"error": {"class": "GenericError", "desc": "Bitmap 'bitmap404' could not be found"}} 5379 5380{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "bitmap-mode": "on-success", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5381{"error": {"class": "GenericError", "desc": "sync mode 'none' does not produce meaningful bitmap outputs"}} 5382 5383{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "bitmap-mode": "always", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5384{"error": {"class": "GenericError", "desc": "sync mode 'none' does not produce meaningful bitmap outputs"}} 5385 5386{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "bitmap-mode": "never", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5387{"error": {"class": "GenericError", "desc": "sync mode 'none' does not produce meaningful bitmap outputs"}} 5388 5389{"execute": "blockdev-backup", "arguments": {"bitmap": "bitmap0", "device": "drive0", "filter-node-name": "backup-top", "job-id": "api_job", "sync": "none", "target": "backup_target", "x-perf": {"max-workers": 1}}} 5390{"error": {"class": "GenericError", "desc": "Bitmap sync mode must be given when providing a bitmap"}} 5391 5392