39 lines
1.3 KiB
Plaintext
39 lines
1.3 KiB
Plaintext
|
Qemu supports the NBD protocol, and has an internal NBD client (see
|
||
|
block/nbd.c), an internal NBD server (see blockdev-nbd.c), and an
|
||
|
external NBD server tool (see qemu-nbd.c). The common code is placed
|
||
|
in nbd/*.
|
||
|
|
||
|
The NBD protocol is specified here:
|
||
|
https://github.com/NetworkBlockDevice/nbd/blob/master/doc/proto.md
|
||
|
|
||
|
The following paragraphs describe some specific properties of NBD
|
||
|
protocol realization in Qemu.
|
||
|
|
||
|
= Metadata namespaces =
|
||
|
|
||
|
Qemu supports the "base:allocation" metadata context as defined in the
|
||
|
NBD protocol specification, and also defines an additional metadata
|
||
|
namespace "qemu".
|
||
|
|
||
|
|
||
|
== "qemu" namespace ==
|
||
|
|
||
|
The "qemu" namespace currently contains only one type of context,
|
||
|
related to exposing the contents of a dirty bitmap alongside the
|
||
|
associated disk contents. That context has the following form:
|
||
|
|
||
|
qemu:dirty-bitmap:<dirty-bitmap-export-name>
|
||
|
|
||
|
Each dirty-bitmap metadata context defines only one flag for extents
|
||
|
in reply for NBD_CMD_BLOCK_STATUS:
|
||
|
|
||
|
bit 0: NBD_STATE_DIRTY, means that the extent is "dirty"
|
||
|
|
||
|
For NBD_OPT_LIST_META_CONTEXT the following queries are supported
|
||
|
in addition to "qemu:dirty-bitmap:<dirty-bitmap-export-name>":
|
||
|
|
||
|
* "qemu:" - returns list of all available metadata contexts in the
|
||
|
namespace.
|
||
|
* "qemu:dirty-bitmap:" - returns list of all available dirty-bitmap
|
||
|
metadata contexts.
|