block/dirty-bitmap: add recording and busy properties
The current API allows us to report a single status, which we've defined as: Frozen: has a successor, treated as qmp_locked, may or may not be enabled. Locked: no successor, qmp_locked. may or may not be enabled. Disabled: Not frozen or locked, disabled. Active: Not frozen, locked, or disabled. The problem is that both "Frozen" and "Locked" mean nearly the same thing, and that both of them do not intuit whether they are recording guest writes or not. This patch deprecates that status field and introduces two orthogonal properties instead to replace it. Signed-off-by: John Snow <jsnow@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com> Message-id: 20190223000614.13894-2-jsnow@redhat.com Signed-off-by: John Snow <jsnow@redhat.com>
This commit is contained in:
parent
46316f1dff
commit
4db6ceb0b5
@ -226,6 +226,13 @@ DirtyBitmapStatus bdrv_dirty_bitmap_status(BdrvDirtyBitmap *bitmap)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Called with BQL taken. */
|
||||||
|
static bool bdrv_dirty_bitmap_recording(BdrvDirtyBitmap *bitmap)
|
||||||
|
{
|
||||||
|
return !bitmap->disabled || (bitmap->successor &&
|
||||||
|
!bitmap->successor->disabled);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a successor bitmap destined to replace this bitmap after an operation.
|
* Create a successor bitmap destined to replace this bitmap after an operation.
|
||||||
* Requires that the bitmap is not frozen and has no successor.
|
* Requires that the bitmap is not frozen and has no successor.
|
||||||
@ -448,6 +455,8 @@ BlockDirtyInfoList *bdrv_query_dirty_bitmaps(BlockDriverState *bs)
|
|||||||
info->has_name = !!bm->name;
|
info->has_name = !!bm->name;
|
||||||
info->name = g_strdup(bm->name);
|
info->name = g_strdup(bm->name);
|
||||||
info->status = bdrv_dirty_bitmap_status(bm);
|
info->status = bdrv_dirty_bitmap_status(bm);
|
||||||
|
info->recording = bdrv_dirty_bitmap_recording(bm);
|
||||||
|
info->busy = bdrv_dirty_bitmap_user_locked(bm);
|
||||||
info->persistent = bm->persistent;
|
info->persistent = bm->persistent;
|
||||||
entry->value = info;
|
entry->value = info;
|
||||||
*plist = entry;
|
*plist = entry;
|
||||||
|
@ -467,7 +467,14 @@
|
|||||||
#
|
#
|
||||||
# @granularity: granularity of the dirty bitmap in bytes (since 1.4)
|
# @granularity: granularity of the dirty bitmap in bytes (since 1.4)
|
||||||
#
|
#
|
||||||
# @status: current status of the dirty bitmap (since 2.4)
|
# @status: Deprecated in favor of @recording and @locked. (since 2.4)
|
||||||
|
#
|
||||||
|
# @recording: true if the bitmap is recording new writes from the guest.
|
||||||
|
# Replaces `active` and `disabled` statuses. (since 4.0)
|
||||||
|
#
|
||||||
|
# @busy: true if the bitmap is in-use by some operation (NBD or jobs)
|
||||||
|
# and cannot be modified via QMP or used by another operation.
|
||||||
|
# Replaces `locked` and `frozen` statuses. (since 4.0)
|
||||||
#
|
#
|
||||||
# @persistent: true if the bitmap will eventually be flushed to persistent
|
# @persistent: true if the bitmap will eventually be flushed to persistent
|
||||||
# storage (since 4.0)
|
# storage (since 4.0)
|
||||||
@ -476,6 +483,7 @@
|
|||||||
##
|
##
|
||||||
{ 'struct': 'BlockDirtyInfo',
|
{ 'struct': 'BlockDirtyInfo',
|
||||||
'data': {'*name': 'str', 'count': 'int', 'granularity': 'uint32',
|
'data': {'*name': 'str', 'count': 'int', 'granularity': 'uint32',
|
||||||
|
'recording': 'bool', 'busy': 'bool',
|
||||||
'status': 'DirtyBitmapStatus', 'persistent': 'bool' } }
|
'status': 'DirtyBitmapStatus', 'persistent': 'bool' } }
|
||||||
|
|
||||||
##
|
##
|
||||||
|
@ -72,6 +72,12 @@ by the @code{tls-authz} and @code{sasl-authz} options.
|
|||||||
"autoload" parameter is now ignored. All bitmaps are automatically loaded
|
"autoload" parameter is now ignored. All bitmaps are automatically loaded
|
||||||
from qcow2 images.
|
from qcow2 images.
|
||||||
|
|
||||||
|
@subsection query-block result field dirty-bitmaps[i].status (since 4.0)
|
||||||
|
|
||||||
|
The ``status'' field of the ``BlockDirtyInfo'' structure, returned by
|
||||||
|
the query-block command is deprecated. Two new boolean fields,
|
||||||
|
``recording'' and ``busy'' effectively replace it.
|
||||||
|
|
||||||
@subsection query-cpus (since 2.12.0)
|
@subsection query-cpus (since 2.12.0)
|
||||||
|
|
||||||
The ``query-cpus'' command is replaced by the ``query-cpus-fast'' command.
|
The ``query-cpus'' command is replaced by the ``query-cpus-fast'' command.
|
||||||
|
@ -22,17 +22,21 @@ write -P0xcd 0x3ff0000 64k
|
|||||||
"bitmaps": {
|
"bitmaps": {
|
||||||
"drive0": [
|
"drive0": [
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 262144,
|
"count": 262144,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapB",
|
"name": "bitmapB",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": true,
|
||||||
"status": "active"
|
"status": "active"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 262144,
|
"count": 262144,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapA",
|
"name": "bitmapA",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": true,
|
||||||
"status": "active"
|
"status": "active"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
@ -84,17 +88,21 @@ write -P0xcd 0x3ff0000 64k
|
|||||||
"bitmaps": {
|
"bitmaps": {
|
||||||
"drive0": [
|
"drive0": [
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 262144,
|
"count": 262144,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapB",
|
"name": "bitmapB",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": true,
|
||||||
"status": "active"
|
"status": "active"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 262144,
|
"count": 262144,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapA",
|
"name": "bitmapA",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": true,
|
||||||
"status": "active"
|
"status": "active"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
@ -184,24 +192,30 @@ write -P0xea 0x3fe0000 64k
|
|||||||
"bitmaps": {
|
"bitmaps": {
|
||||||
"drive0": [
|
"drive0": [
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 393216,
|
"count": 393216,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapC",
|
"name": "bitmapC",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": false,
|
||||||
"status": "disabled"
|
"status": "disabled"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 262144,
|
"count": 262144,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapB",
|
"name": "bitmapB",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": false,
|
||||||
"status": "disabled"
|
"status": "disabled"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 458752,
|
"count": 458752,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapA",
|
"name": "bitmapA",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": false,
|
||||||
"status": "disabled"
|
"status": "disabled"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
@ -251,24 +265,30 @@ write -P0xea 0x3fe0000 64k
|
|||||||
"bitmaps": {
|
"bitmaps": {
|
||||||
"drive0": [
|
"drive0": [
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 393216,
|
"count": 393216,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapC",
|
"name": "bitmapC",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": false,
|
||||||
"status": "disabled"
|
"status": "disabled"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 262144,
|
"count": 262144,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapB",
|
"name": "bitmapB",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": false,
|
||||||
"status": "disabled"
|
"status": "disabled"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 458752,
|
"count": 458752,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapA",
|
"name": "bitmapA",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": false,
|
||||||
"status": "disabled"
|
"status": "disabled"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
@ -311,31 +331,39 @@ write -P0xea 0x3fe0000 64k
|
|||||||
"bitmaps": {
|
"bitmaps": {
|
||||||
"drive0": [
|
"drive0": [
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 458752,
|
"count": 458752,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapD",
|
"name": "bitmapD",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": false,
|
||||||
"status": "disabled"
|
"status": "disabled"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 393216,
|
"count": 393216,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapC",
|
"name": "bitmapC",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": false,
|
||||||
"status": "disabled"
|
"status": "disabled"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 262144,
|
"count": 262144,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapB",
|
"name": "bitmapB",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": false,
|
||||||
"status": "disabled"
|
"status": "disabled"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
"busy": false,
|
||||||
"count": 458752,
|
"count": 458752,
|
||||||
"granularity": 65536,
|
"granularity": 65536,
|
||||||
"name": "bitmapA",
|
"name": "bitmapA",
|
||||||
"persistent": false,
|
"persistent": false,
|
||||||
|
"recording": false,
|
||||||
"status": "disabled"
|
"status": "disabled"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
Loading…
Reference in New Issue
Block a user