2013-09-18 16:47:41 +02:00
|
|
|
QA output created by 067
|
2014-12-09 08:38:03 +01:00
|
|
|
Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=134217728
|
2013-09-18 16:47:41 +02:00
|
|
|
|
|
|
|
=== -drive/-device and device_del ===
|
|
|
|
|
|
|
|
Testing: -drive file=TEST_DIR/t.qcow2,format=qcow2,if=none,id=disk -device virtio-blk-pci,drive=disk,id=virtio0
|
2014-11-17 13:31:06 +01:00
|
|
|
{
|
|
|
|
QMP_VERSION
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": [
|
|
|
|
{
|
|
|
|
"io-status": "ok",
|
|
|
|
"device": "disk",
|
|
|
|
"locked": false,
|
|
|
|
"removable": false,
|
|
|
|
"inserted": {
|
|
|
|
"iops_rd": 0,
|
|
|
|
"detect_zeroes": "off",
|
|
|
|
"image": {
|
|
|
|
"virtual-size": 134217728,
|
|
|
|
"filename": "TEST_DIR/t.qcow2",
|
|
|
|
"cluster-size": 65536,
|
|
|
|
"format": "qcow2",
|
|
|
|
"actual-size": SIZE,
|
|
|
|
"format-specific": {
|
|
|
|
"type": "qcow2",
|
|
|
|
"data": {
|
|
|
|
"compat": "1.1",
|
|
|
|
"lazy-refcounts": false,
|
|
|
|
"corrupt": false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"dirty-flag": false
|
|
|
|
},
|
|
|
|
"iops_wr": 0,
|
|
|
|
"ro": false,
|
|
|
|
"backing_file_depth": 0,
|
|
|
|
"drv": "qcow2",
|
|
|
|
"iops": 0,
|
|
|
|
"bps_wr": 0,
|
block: add event when disk usage exceeds threshold
Managing applications, like oVirt (http://www.ovirt.org), make extensive
use of thin-provisioned disk images.
To let the guest run smoothly and be not unnecessarily paused, oVirt sets
a disk usage threshold (so called 'high water mark') based on the occupation
of the device, and automatically extends the image once the threshold
is reached or exceeded.
In order to detect the crossing of the threshold, oVirt has no choice but
aggressively polling the QEMU monitor using the query-blockstats command.
This lead to unnecessary system load, and is made even worse under scale:
deployments with hundreds of VMs are no longer rare.
To fix this, this patch adds:
* A new monitor command `block-set-write-threshold', to set a mark for
a given block device.
* A new event `BLOCK_WRITE_THRESHOLD', to report if a block device
usage exceeds the threshold.
* A new `write_threshold' field into the `BlockDeviceInfo' structure,
to report the configured threshold.
This will allow the managing application to use smarter and more
efficient monitoring, greatly reducing the need of polling.
[Updated qemu-iotests 067 output to add the new 'write_threshold'
property. --Stefan]
[Changed g_assert_false() to !g_assert() to fix the build on older glib
versions. --Kevin]
Signed-off-by: Francesco Romani <fromani@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Message-id: 1421068273-692-1-git-send-email-fromani@redhat.com
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
2015-01-12 14:11:13 +01:00
|
|
|
"write_threshold": 0,
|
2014-11-17 13:31:06 +01:00
|
|
|
"encrypted": false,
|
|
|
|
"bps": 0,
|
|
|
|
"bps_rd": 0,
|
2014-05-22 13:28:45 +02:00
|
|
|
"cache": {
|
|
|
|
"no-flush": false,
|
|
|
|
"direct": false,
|
|
|
|
"writeback": true
|
|
|
|
},
|
2014-11-17 13:31:06 +01:00
|
|
|
"file": "TEST_DIR/t.qcow2",
|
|
|
|
"encryption_key_missing": false
|
|
|
|
},
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"io-status": "ok",
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "floppy0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "sd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_DELETED",
|
|
|
|
"data": {
|
|
|
|
"path": "/machine/peripheral/virtio0/virtio-backend"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_DELETED",
|
|
|
|
"data": {
|
|
|
|
"device": "virtio0",
|
|
|
|
"path": "/machine/peripheral/virtio0"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "RESET"
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": [
|
|
|
|
{
|
|
|
|
"io-status": "ok",
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "floppy0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "sd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "SHUTDOWN"
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_TRAY_MOVED",
|
|
|
|
"data": {
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"tray-open": true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_TRAY_MOVED",
|
|
|
|
"data": {
|
|
|
|
"device": "floppy0",
|
|
|
|
"tray-open": true
|
|
|
|
}
|
|
|
|
}
|
2013-09-18 16:47:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
=== -drive/device_add and device_del ===
|
|
|
|
|
|
|
|
Testing: -drive file=TEST_DIR/t.qcow2,format=qcow2,if=none,id=disk
|
2014-11-17 13:31:06 +01:00
|
|
|
{
|
|
|
|
QMP_VERSION
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": [
|
|
|
|
{
|
|
|
|
"device": "disk",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"inserted": {
|
|
|
|
"iops_rd": 0,
|
|
|
|
"detect_zeroes": "off",
|
|
|
|
"image": {
|
|
|
|
"virtual-size": 134217728,
|
|
|
|
"filename": "TEST_DIR/t.qcow2",
|
|
|
|
"cluster-size": 65536,
|
|
|
|
"format": "qcow2",
|
|
|
|
"actual-size": SIZE,
|
|
|
|
"format-specific": {
|
|
|
|
"type": "qcow2",
|
|
|
|
"data": {
|
|
|
|
"compat": "1.1",
|
|
|
|
"lazy-refcounts": false,
|
|
|
|
"corrupt": false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"dirty-flag": false
|
|
|
|
},
|
|
|
|
"iops_wr": 0,
|
|
|
|
"ro": false,
|
|
|
|
"backing_file_depth": 0,
|
|
|
|
"drv": "qcow2",
|
|
|
|
"iops": 0,
|
|
|
|
"bps_wr": 0,
|
block: add event when disk usage exceeds threshold
Managing applications, like oVirt (http://www.ovirt.org), make extensive
use of thin-provisioned disk images.
To let the guest run smoothly and be not unnecessarily paused, oVirt sets
a disk usage threshold (so called 'high water mark') based on the occupation
of the device, and automatically extends the image once the threshold
is reached or exceeded.
In order to detect the crossing of the threshold, oVirt has no choice but
aggressively polling the QEMU monitor using the query-blockstats command.
This lead to unnecessary system load, and is made even worse under scale:
deployments with hundreds of VMs are no longer rare.
To fix this, this patch adds:
* A new monitor command `block-set-write-threshold', to set a mark for
a given block device.
* A new event `BLOCK_WRITE_THRESHOLD', to report if a block device
usage exceeds the threshold.
* A new `write_threshold' field into the `BlockDeviceInfo' structure,
to report the configured threshold.
This will allow the managing application to use smarter and more
efficient monitoring, greatly reducing the need of polling.
[Updated qemu-iotests 067 output to add the new 'write_threshold'
property. --Stefan]
[Changed g_assert_false() to !g_assert() to fix the build on older glib
versions. --Kevin]
Signed-off-by: Francesco Romani <fromani@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Message-id: 1421068273-692-1-git-send-email-fromani@redhat.com
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
2015-01-12 14:11:13 +01:00
|
|
|
"write_threshold": 0,
|
2014-11-17 13:31:06 +01:00
|
|
|
"encrypted": false,
|
|
|
|
"bps": 0,
|
|
|
|
"bps_rd": 0,
|
2014-05-22 13:28:45 +02:00
|
|
|
"cache": {
|
|
|
|
"no-flush": false,
|
|
|
|
"direct": false,
|
|
|
|
"writeback": true
|
|
|
|
},
|
2014-11-17 13:31:06 +01:00
|
|
|
"file": "TEST_DIR/t.qcow2",
|
|
|
|
"encryption_key_missing": false
|
|
|
|
},
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"io-status": "ok",
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "floppy0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "sd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_DELETED",
|
|
|
|
"data": {
|
|
|
|
"path": "/machine/peripheral/virtio0/virtio-backend"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_DELETED",
|
|
|
|
"data": {
|
|
|
|
"device": "virtio0",
|
|
|
|
"path": "/machine/peripheral/virtio0"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "RESET"
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": [
|
|
|
|
{
|
|
|
|
"io-status": "ok",
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "floppy0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "sd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "SHUTDOWN"
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_TRAY_MOVED",
|
|
|
|
"data": {
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"tray-open": true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_TRAY_MOVED",
|
|
|
|
"data": {
|
|
|
|
"device": "floppy0",
|
|
|
|
"tray-open": true
|
|
|
|
}
|
|
|
|
}
|
2013-09-18 16:47:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
=== drive_add/device_add and device_del ===
|
|
|
|
|
|
|
|
Testing:
|
2014-11-17 13:31:06 +01:00
|
|
|
{
|
|
|
|
QMP_VERSION
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": "OK\r\n"
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": [
|
|
|
|
{
|
|
|
|
"io-status": "ok",
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "floppy0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "sd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "disk",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"inserted": {
|
|
|
|
"iops_rd": 0,
|
|
|
|
"detect_zeroes": "off",
|
|
|
|
"image": {
|
|
|
|
"virtual-size": 134217728,
|
|
|
|
"filename": "TEST_DIR/t.qcow2",
|
|
|
|
"cluster-size": 65536,
|
|
|
|
"format": "qcow2",
|
|
|
|
"actual-size": SIZE,
|
|
|
|
"format-specific": {
|
|
|
|
"type": "qcow2",
|
|
|
|
"data": {
|
|
|
|
"compat": "1.1",
|
|
|
|
"lazy-refcounts": false,
|
|
|
|
"corrupt": false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"dirty-flag": false
|
|
|
|
},
|
|
|
|
"iops_wr": 0,
|
|
|
|
"ro": false,
|
|
|
|
"backing_file_depth": 0,
|
|
|
|
"drv": "qcow2",
|
|
|
|
"iops": 0,
|
|
|
|
"bps_wr": 0,
|
block: add event when disk usage exceeds threshold
Managing applications, like oVirt (http://www.ovirt.org), make extensive
use of thin-provisioned disk images.
To let the guest run smoothly and be not unnecessarily paused, oVirt sets
a disk usage threshold (so called 'high water mark') based on the occupation
of the device, and automatically extends the image once the threshold
is reached or exceeded.
In order to detect the crossing of the threshold, oVirt has no choice but
aggressively polling the QEMU monitor using the query-blockstats command.
This lead to unnecessary system load, and is made even worse under scale:
deployments with hundreds of VMs are no longer rare.
To fix this, this patch adds:
* A new monitor command `block-set-write-threshold', to set a mark for
a given block device.
* A new event `BLOCK_WRITE_THRESHOLD', to report if a block device
usage exceeds the threshold.
* A new `write_threshold' field into the `BlockDeviceInfo' structure,
to report the configured threshold.
This will allow the managing application to use smarter and more
efficient monitoring, greatly reducing the need of polling.
[Updated qemu-iotests 067 output to add the new 'write_threshold'
property. --Stefan]
[Changed g_assert_false() to !g_assert() to fix the build on older glib
versions. --Kevin]
Signed-off-by: Francesco Romani <fromani@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Message-id: 1421068273-692-1-git-send-email-fromani@redhat.com
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
2015-01-12 14:11:13 +01:00
|
|
|
"write_threshold": 0,
|
2014-11-17 13:31:06 +01:00
|
|
|
"encrypted": false,
|
|
|
|
"bps": 0,
|
|
|
|
"bps_rd": 0,
|
2014-05-22 13:28:45 +02:00
|
|
|
"cache": {
|
|
|
|
"no-flush": false,
|
|
|
|
"direct": false,
|
|
|
|
"writeback": true
|
|
|
|
},
|
2014-11-17 13:31:06 +01:00
|
|
|
"file": "TEST_DIR/t.qcow2",
|
|
|
|
"encryption_key_missing": false
|
|
|
|
},
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_DELETED",
|
|
|
|
"data": {
|
|
|
|
"path": "/machine/peripheral/virtio0/virtio-backend"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_DELETED",
|
|
|
|
"data": {
|
|
|
|
"device": "virtio0",
|
|
|
|
"path": "/machine/peripheral/virtio0"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "RESET"
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": [
|
|
|
|
{
|
|
|
|
"io-status": "ok",
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "floppy0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "sd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "SHUTDOWN"
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_TRAY_MOVED",
|
|
|
|
"data": {
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"tray-open": true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_TRAY_MOVED",
|
|
|
|
"data": {
|
|
|
|
"device": "floppy0",
|
|
|
|
"tray-open": true
|
|
|
|
}
|
|
|
|
}
|
2013-09-18 16:47:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
=== blockdev_add/device_add and device_del ===
|
|
|
|
|
|
|
|
Testing:
|
2014-11-17 13:31:06 +01:00
|
|
|
{
|
|
|
|
QMP_VERSION
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": [
|
|
|
|
{
|
|
|
|
"io-status": "ok",
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "floppy0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "sd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "disk",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"inserted": {
|
|
|
|
"iops_rd": 0,
|
|
|
|
"detect_zeroes": "off",
|
|
|
|
"image": {
|
|
|
|
"virtual-size": 134217728,
|
|
|
|
"filename": "TEST_DIR/t.qcow2",
|
|
|
|
"cluster-size": 65536,
|
|
|
|
"format": "qcow2",
|
|
|
|
"actual-size": SIZE,
|
|
|
|
"format-specific": {
|
|
|
|
"type": "qcow2",
|
|
|
|
"data": {
|
|
|
|
"compat": "1.1",
|
|
|
|
"lazy-refcounts": false,
|
|
|
|
"corrupt": false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"dirty-flag": false
|
|
|
|
},
|
|
|
|
"iops_wr": 0,
|
|
|
|
"ro": false,
|
|
|
|
"backing_file_depth": 0,
|
|
|
|
"drv": "qcow2",
|
|
|
|
"iops": 0,
|
|
|
|
"bps_wr": 0,
|
block: add event when disk usage exceeds threshold
Managing applications, like oVirt (http://www.ovirt.org), make extensive
use of thin-provisioned disk images.
To let the guest run smoothly and be not unnecessarily paused, oVirt sets
a disk usage threshold (so called 'high water mark') based on the occupation
of the device, and automatically extends the image once the threshold
is reached or exceeded.
In order to detect the crossing of the threshold, oVirt has no choice but
aggressively polling the QEMU monitor using the query-blockstats command.
This lead to unnecessary system load, and is made even worse under scale:
deployments with hundreds of VMs are no longer rare.
To fix this, this patch adds:
* A new monitor command `block-set-write-threshold', to set a mark for
a given block device.
* A new event `BLOCK_WRITE_THRESHOLD', to report if a block device
usage exceeds the threshold.
* A new `write_threshold' field into the `BlockDeviceInfo' structure,
to report the configured threshold.
This will allow the managing application to use smarter and more
efficient monitoring, greatly reducing the need of polling.
[Updated qemu-iotests 067 output to add the new 'write_threshold'
property. --Stefan]
[Changed g_assert_false() to !g_assert() to fix the build on older glib
versions. --Kevin]
Signed-off-by: Francesco Romani <fromani@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Message-id: 1421068273-692-1-git-send-email-fromani@redhat.com
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
2015-01-12 14:11:13 +01:00
|
|
|
"write_threshold": 0,
|
2014-11-17 13:31:06 +01:00
|
|
|
"encrypted": false,
|
|
|
|
"bps": 0,
|
|
|
|
"bps_rd": 0,
|
2014-05-22 13:28:45 +02:00
|
|
|
"cache": {
|
|
|
|
"no-flush": false,
|
|
|
|
"direct": false,
|
|
|
|
"writeback": true
|
|
|
|
},
|
2014-11-17 13:31:06 +01:00
|
|
|
"file": "TEST_DIR/t.qcow2",
|
|
|
|
"encryption_key_missing": false
|
|
|
|
},
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_DELETED",
|
|
|
|
"data": {
|
|
|
|
"path": "/machine/peripheral/virtio0/virtio-backend"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_DELETED",
|
|
|
|
"data": {
|
|
|
|
"device": "virtio0",
|
|
|
|
"path": "/machine/peripheral/virtio0"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "RESET"
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": [
|
|
|
|
{
|
|
|
|
"io-status": "ok",
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "floppy0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"device": "sd0",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"io-status": "ok",
|
|
|
|
"device": "disk",
|
|
|
|
"locked": false,
|
|
|
|
"removable": true,
|
|
|
|
"inserted": {
|
|
|
|
"iops_rd": 0,
|
|
|
|
"detect_zeroes": "off",
|
|
|
|
"image": {
|
|
|
|
"virtual-size": 134217728,
|
|
|
|
"filename": "TEST_DIR/t.qcow2",
|
|
|
|
"cluster-size": 65536,
|
|
|
|
"format": "qcow2",
|
|
|
|
"actual-size": SIZE,
|
|
|
|
"format-specific": {
|
|
|
|
"type": "qcow2",
|
|
|
|
"data": {
|
|
|
|
"compat": "1.1",
|
|
|
|
"lazy-refcounts": false,
|
|
|
|
"corrupt": false
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"dirty-flag": false
|
|
|
|
},
|
|
|
|
"iops_wr": 0,
|
|
|
|
"ro": false,
|
|
|
|
"backing_file_depth": 0,
|
|
|
|
"drv": "qcow2",
|
|
|
|
"iops": 0,
|
|
|
|
"bps_wr": 0,
|
block: add event when disk usage exceeds threshold
Managing applications, like oVirt (http://www.ovirt.org), make extensive
use of thin-provisioned disk images.
To let the guest run smoothly and be not unnecessarily paused, oVirt sets
a disk usage threshold (so called 'high water mark') based on the occupation
of the device, and automatically extends the image once the threshold
is reached or exceeded.
In order to detect the crossing of the threshold, oVirt has no choice but
aggressively polling the QEMU monitor using the query-blockstats command.
This lead to unnecessary system load, and is made even worse under scale:
deployments with hundreds of VMs are no longer rare.
To fix this, this patch adds:
* A new monitor command `block-set-write-threshold', to set a mark for
a given block device.
* A new event `BLOCK_WRITE_THRESHOLD', to report if a block device
usage exceeds the threshold.
* A new `write_threshold' field into the `BlockDeviceInfo' structure,
to report the configured threshold.
This will allow the managing application to use smarter and more
efficient monitoring, greatly reducing the need of polling.
[Updated qemu-iotests 067 output to add the new 'write_threshold'
property. --Stefan]
[Changed g_assert_false() to !g_assert() to fix the build on older glib
versions. --Kevin]
Signed-off-by: Francesco Romani <fromani@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Message-id: 1421068273-692-1-git-send-email-fromani@redhat.com
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
2015-01-12 14:11:13 +01:00
|
|
|
"write_threshold": 0,
|
2014-11-17 13:31:06 +01:00
|
|
|
"encrypted": false,
|
|
|
|
"bps": 0,
|
|
|
|
"bps_rd": 0,
|
2014-05-22 13:28:45 +02:00
|
|
|
"cache": {
|
|
|
|
"no-flush": false,
|
|
|
|
"direct": false,
|
|
|
|
"writeback": true
|
|
|
|
},
|
2014-11-17 13:31:06 +01:00
|
|
|
"file": "TEST_DIR/t.qcow2",
|
|
|
|
"encryption_key_missing": false
|
|
|
|
},
|
|
|
|
"tray_open": false,
|
|
|
|
"type": "unknown"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"return": {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "SHUTDOWN"
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_TRAY_MOVED",
|
|
|
|
"data": {
|
|
|
|
"device": "ide1-cd0",
|
|
|
|
"tray-open": true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{
|
|
|
|
"timestamp": {
|
|
|
|
"seconds": TIMESTAMP,
|
|
|
|
"microseconds": TIMESTAMP
|
|
|
|
},
|
|
|
|
"event": "DEVICE_TRAY_MOVED",
|
|
|
|
"data": {
|
|
|
|
"device": "floppy0",
|
|
|
|
"tray-open": true
|
|
|
|
}
|
|
|
|
}
|
2013-09-18 16:47:41 +02:00
|
|
|
|
|
|
|
*** done
|