mbox series

[RFC,0/5] Add persistence to NVMe ZNS emulation

Message ID 20230816064617.3310-1-faithilikerun@gmail.com (mailing list archive)
Headers show
Series Add persistence to NVMe ZNS emulation | expand

Message

Sam Li Aug. 16, 2023, 6:46 a.m. UTC
ZNS emulation follows NVMe ZNS spec but the state of namespace
zones does not persist accross restarts of QEMU. This patch makes the
metadata of ZNS emulation persistent by using new block layer APIs and
the qcow2 img as backing file. It is the second part after the patches
- adding full zoned storage emulation to qcow2 driver.

The metadata of ZNS emulation divides into two parts, zone metadata and
zone descriptor extension data. The zone metadata is composed of zone
states, zone type, wp and zone attributes. The zone information can be
stored at an uint64_t wp to save space and easy access. The structure of
wp of each zone is as follows:
|| zone state (4)| zone type (1)| zone attr (8)| wp (51) ||

The zone descriptor extension data is relatively small comparing to the
overall size therefore we adopt the option that store zded of all zones
in an array regardless of the valid bit set.

To create a zns format qcow2 image file, use:
$ ./build/qemu-img create -f qcow2 zns.qcow2 -o size=768M
-o zone_size=64M -o zone_capacity=64M -o zone_nr_conv=0
-o max_append_sectors=512 -o max_open_zones=0 -o
max_active_zones=0 -o zoned_profile=zns

To attach this file as emulated zns drive in the command line of QEMU, use:
  -drive file=${znsimg},id=nvmezns0,format=qcow2,if=none \
  -device nvme-ns,drive=nvmezns0,bus=nvme0,nsid=1,uuid=xxx \

Sam Li (5):
  hw/nvme: use blk_get_*() to access zone info in the block layer
  qcow2: add zone device metadata with zd_extension
  hw/nvme: make the metadata of ZNS emulation persistent
  hw/nvme: refactor zone append writes using block layer APIs
  hw/nvme: make ZDED persistent

 block/block-backend.c             |   94 +++
 block/qcow2.c                     |  160 +++-
 block/qcow2.h                     |    3 +
 docs/interop/qcow2.txt            |    2 +
 hw/nvme/ctrl.c                    | 1256 ++++++++---------------------
 hw/nvme/ns.c                      |  163 +---
 hw/nvme/nvme.h                    |   95 +--
 include/block/block-common.h      |    9 +
 include/block/block_int-common.h  |    8 +
 include/sysemu/block-backend-io.h |   12 +
 include/sysemu/dma.h              |    3 +
 qapi/block-core.json              |    3 +
 softmmu/dma-helpers.c             |   17 +
 13 files changed, 686 insertions(+), 1139 deletions(-)