Replace bdrv_drain_all(), bdrv_commmit_all(), bdrv_flush_all(), bdrv_invalidate_cache_all(), bdrv_next() and occurrences of bdrv_states by their BlockBackend equivalents.
Signed-off-by: Max Reitz <mre...@redhat.com> --- block.c | 10 ++++---- block/block-backend.c | 8 +++---- block/qapi.c | 13 ++++++++-- blockdev.c | 12 ++++++---- cpus.c | 7 +++--- migration/block.c | 7 ++++-- migration/migration.c | 3 ++- migration/savevm.c | 66 ++++++++++++++++++++++++++++++--------------------- monitor.c | 15 +++++++----- qemu-char.c | 3 ++- qemu-io.c | 2 +- qmp.c | 9 ++++--- xen-mapcache.c | 3 ++- 13 files changed, 95 insertions(+), 63 deletions(-) diff --git a/block.c b/block.c index faad9fb..f8c1e99 100644 --- a/block.c +++ b/block.c @@ -1717,7 +1717,7 @@ int bdrv_reopen_multiple(BlockReopenQueue *bs_queue, Error **errp) assert(bs_queue != NULL); - bdrv_drain_all(); + blk_drain_all(); QSIMPLEQ_FOREACH(bs_entry, bs_queue, entry) { if (bdrv_reopen_prepare(&bs_entry->state, bs_queue, &local_err)) { @@ -1974,7 +1974,7 @@ void bdrv_close_all(void) /* Drop references from requests still in flight, such as canceled block * jobs whose AIO context has not been polled yet */ - bdrv_drain_all(); + blk_drain_all(); blockdev_close_all_bdrv_states(); blk_remove_all_bs(); @@ -3908,14 +3908,14 @@ bool bdrv_recurse_is_first_non_filter(BlockDriverState *bs, */ bool bdrv_is_first_non_filter(BlockDriverState *candidate) { - BlockDriverState *bs; + BlockBackend *blk = NULL; /* walk down the bs forest recursively */ - QTAILQ_FOREACH(bs, &bdrv_states, device_list) { + while ((blk = blk_next_inserted(blk)) != NULL) { bool perm; /* try to recurse in this top level bs */ - perm = bdrv_recurse_is_first_non_filter(bs, candidate); + perm = bdrv_recurse_is_first_non_filter(blk_bs(blk), candidate); /* candidate is the first non filter */ if (perm) { diff --git a/block/block-backend.c b/block/block-backend.c index b3d086d..c89340e 100644 --- a/block/block-backend.c +++ b/block/block-backend.c @@ -282,10 +282,10 @@ const char *blk_name(BlockBackend *blk) */ BlockBackend *blk_by_name(const char *name) { - BlockBackend *blk; + BlockBackend *blk = NULL; assert(name); - QTAILQ_FOREACH(blk, &blk_backends, link) { + while ((blk = blk_next(blk)) != NULL) { if (!strcmp(name, blk->name)) { return blk; } @@ -360,9 +360,9 @@ DriveInfo *blk_set_legacy_dinfo(BlockBackend *blk, DriveInfo *dinfo) */ BlockBackend *blk_by_legacy_dinfo(DriveInfo *dinfo) { - BlockBackend *blk; + BlockBackend *blk = NULL; - QTAILQ_FOREACH(blk, &blk_backends, link) { + while ((blk = blk_next(blk)) != NULL) { if (blk->legacy_dinfo == dinfo) { return blk; } diff --git a/block/qapi.c b/block/qapi.c index 89d4274..82727fb 100644 --- a/block/qapi.c +++ b/block/qapi.c @@ -405,15 +405,24 @@ BlockStatsList *qmp_query_blockstats(bool has_query_nodes, { BlockStatsList *head = NULL, **p_next = &head; BlockDriverState *bs = NULL; + BlockBackend *blk = NULL; /* Just to be safe if query_nodes is not always initialized */ query_nodes = has_query_nodes && query_nodes; - while ((bs = query_nodes ? bdrv_next_node(bs) : bdrv_next(bs))) { + while (query_nodes ? (bs = bdrv_next_node(bs)) != NULL + : (blk = blk_next_inserted(blk)) != NULL) + { BlockStatsList *info = g_malloc0(sizeof(*info)); - AioContext *ctx = bdrv_get_aio_context(bs); + AioContext *ctx = blk ? blk_get_aio_context(blk) + : bdrv_get_aio_context(bs); aio_context_acquire(ctx); + + if (blk) { + bs = blk_bs(blk); + } + info->value = bdrv_query_stats(bs, !query_nodes); aio_context_release(ctx); diff --git a/blockdev.c b/blockdev.c index 93a70b4..97e6897 100644 --- a/blockdev.c +++ b/blockdev.c @@ -1134,7 +1134,7 @@ void hmp_commit(Monitor *mon, const QDict *qdict) int ret; if (!strcmp(device, "all")) { - ret = bdrv_commit_all(); + ret = blk_commit_all(); } else { BlockDriverState *bs; AioContext *aio_context; @@ -1953,7 +1953,7 @@ void qmp_transaction(TransactionActionList *dev_list, Error **errp) QSIMPLEQ_INIT(&snap_bdrv_states); /* drain all i/o before any operations */ - bdrv_drain_all(); + blk_drain_all(); /* We don't do anything in this loop that commits us to the operations */ while (NULL != dev_entry) { @@ -2581,7 +2581,7 @@ void qmp_block_resize(bool has_device, const char *device, } /* complete all in-flight operations before resizing the device */ - bdrv_drain_all(); + blk_drain_all(); ret = bdrv_truncate(bs, size); switch (ret) { @@ -3576,12 +3576,14 @@ BlockJobInfoList *qmp_query_block_jobs(Error **errp) { BlockJobInfoList *head = NULL, **p_next = &head; BlockDriverState *bs; + BlockBackend *blk = NULL; - for (bs = bdrv_next(NULL); bs; bs = bdrv_next(bs)) { - AioContext *aio_context = bdrv_get_aio_context(bs); + while ((blk = blk_next_inserted(blk)) != NULL) { + AioContext *aio_context = blk_get_aio_context(blk); aio_context_acquire(aio_context); + bs = blk_bs(blk); if (bs->job) { BlockJobInfoList *elem = g_new0(BlockJobInfoList, 1); elem->value = block_job_query(bs->job); diff --git a/cpus.c b/cpus.c index 877bd70..46ef045 100644 --- a/cpus.c +++ b/cpus.c @@ -29,6 +29,7 @@ #include "qapi/qmp/qerror.h" #include "qemu/error-report.h" #include "sysemu/sysemu.h" +#include "sysemu/block-backend.h" #include "exec/gdbstub.h" #include "sysemu/dma.h" #include "sysemu/kvm.h" @@ -725,8 +726,8 @@ static int do_vm_stop(RunState state) qapi_event_send_stop(&error_abort); } - bdrv_drain_all(); - ret = bdrv_flush_all(); + blk_drain_all(); + ret = blk_flush_all(); return ret; } @@ -1417,7 +1418,7 @@ int vm_stop_force_state(RunState state) runstate_set(state); /* Make sure to return an error if the flush in a previous vm_stop() * failed. */ - return bdrv_flush_all(); + return blk_flush_all(); } } diff --git a/migration/block.c b/migration/block.c index cf9d9f8..9b28f46 100644 --- a/migration/block.c +++ b/migration/block.c @@ -349,6 +349,7 @@ static void unset_dirty_tracking(void) static void init_blk_migration(QEMUFile *f) { BlockDriverState *bs; + BlockBackend *blk = NULL; BlkMigDevState *bmds; int64_t sectors; @@ -360,7 +361,9 @@ static void init_blk_migration(QEMUFile *f) block_mig_state.bulk_completed = 0; block_mig_state.zero_blocks = migrate_zero_blocks(); - for (bs = bdrv_next(NULL); bs; bs = bdrv_next(bs)) { + while ((blk = blk_next_inserted(blk)) != NULL) { + bs = blk_bs(blk); + if (bdrv_is_read_only(bs)) { continue; } @@ -596,7 +599,7 @@ static void block_migration_cleanup(void *opaque) BlkMigDevState *bmds; BlkMigBlock *blk; - bdrv_drain_all(); + blk_drain_all(); unset_dirty_tracking(); diff --git a/migration/migration.c b/migration/migration.c index f99d3ea..74ea067 100644 --- a/migration/migration.c +++ b/migration/migration.c @@ -19,6 +19,7 @@ #include "migration/migration.h" #include "migration/qemu-file.h" #include "sysemu/sysemu.h" +#include "sysemu/block-backend.h" #include "block/block.h" #include "qapi/qmp/qerror.h" #include "qemu/sockets.h" @@ -296,7 +297,7 @@ static void process_incoming_migration_co(void *opaque) } /* Make sure all file formats flush their mutable metadata */ - bdrv_invalidate_cache_all(&local_err); + blk_invalidate_cache_all(&local_err); if (local_err) { migrate_generate_event(MIGRATION_STATUS_FAILED); error_report_err(local_err); diff --git a/migration/savevm.c b/migration/savevm.c index e05158d..02690ec 100644 --- a/migration/savevm.c +++ b/migration/savevm.c @@ -34,6 +34,7 @@ #include "net/net.h" #include "monitor/monitor.h" #include "sysemu/sysemu.h" +#include "sysemu/block-backend.h" #include "qemu/timer.h" #include "audio/audio.h" #include "migration/migration.h" @@ -1239,10 +1240,10 @@ out: static BlockDriverState *find_vmstate_bs(void) { - BlockDriverState *bs = NULL; - while ((bs = bdrv_next(bs))) { - if (bdrv_can_snapshot(bs)) { - return bs; + BlockBackend *blk = NULL; + while ((blk = blk_next_inserted(blk)) != NULL) { + if (bdrv_can_snapshot(blk_bs(blk))) { + return blk_bs(blk); } } return NULL; @@ -1254,11 +1255,13 @@ static BlockDriverState *find_vmstate_bs(void) static int del_existing_snapshots(Monitor *mon, const char *name) { BlockDriverState *bs; + BlockBackend *blk = NULL; QEMUSnapshotInfo sn1, *snapshot = &sn1; Error *err = NULL; - bs = NULL; - while ((bs = bdrv_next(bs))) { + while ((blk = blk_next_inserted(blk)) != NULL) { + bs = blk_bs(blk); + if (bdrv_can_snapshot(bs) && bdrv_snapshot_find(bs, snapshot, name) >= 0) { bdrv_snapshot_delete_by_id_or_name(bs, name, &err); @@ -1280,6 +1283,7 @@ static int del_existing_snapshots(Monitor *mon, const char *name) void hmp_savevm(Monitor *mon, const QDict *qdict) { BlockDriverState *bs, *bs1; + BlockBackend *blk = NULL; QEMUSnapshotInfo sn1, *sn = &sn1, old_sn1, *old_sn = &old_sn1; int ret; QEMUFile *f; @@ -1291,16 +1295,14 @@ void hmp_savevm(Monitor *mon, const QDict *qdict) Error *local_err = NULL; /* Verify if there is a device that doesn't support snapshots and is writable */ - bs = NULL; - while ((bs = bdrv_next(bs))) { - - if (!bdrv_is_inserted(bs) || bdrv_is_read_only(bs)) { + while ((blk = blk_next_inserted(blk)) != NULL) { + if (blk_is_read_only(blk)) { continue; } - if (!bdrv_can_snapshot(bs)) { + if (!bdrv_can_snapshot(blk_bs(blk))) { monitor_printf(mon, "Device '%s' is writable but does not support snapshots.\n", - bdrv_get_device_name(bs)); + blk_name(blk)); return; } } @@ -1364,15 +1366,17 @@ void hmp_savevm(Monitor *mon, const QDict *qdict) /* create the snapshots */ - bs1 = NULL; - while ((bs1 = bdrv_next(bs1))) { + blk = NULL; + while ((blk = blk_next_inserted(blk)) != NULL) { + bs1 = blk_bs(blk); + if (bdrv_can_snapshot(bs1)) { /* Write VM state size only to the image that contains the state */ sn->vm_state_size = (bs == bs1 ? vm_state_size : 0); ret = bdrv_snapshot_create(bs1, sn); if (ret < 0) { monitor_printf(mon, "Error while creating snapshot on '%s'\n", - bdrv_get_device_name(bs1)); + blk_name(blk)); } } } @@ -1412,6 +1416,7 @@ void qmp_xen_save_devices_state(const char *filename, Error **errp) int load_vmstate(const char *name) { + BlockBackend *blk; BlockDriverState *bs, *bs_vm_state; QEMUSnapshotInfo sn; QEMUFile *f; @@ -1435,12 +1440,12 @@ int load_vmstate(const char *name) /* Verify if there is any device that doesn't support snapshots and is writable and check if the requested snapshot is available too. */ - bs = NULL; - while ((bs = bdrv_next(bs))) { - - if (!bdrv_is_inserted(bs) || bdrv_is_read_only(bs)) { + blk = NULL; + while ((blk = blk_next_inserted(blk)) != NULL) { + if (blk_is_read_only(blk)) { continue; } + bs = blk_bs(blk); if (!bdrv_can_snapshot(bs)) { error_report("Device '%s' is writable but does not support snapshots.", @@ -1457,10 +1462,12 @@ int load_vmstate(const char *name) } /* Flush all IO requests so they don't interfere with the new state. */ - bdrv_drain_all(); + blk_drain_all(); + + blk = NULL; + while ((blk = blk_next_inserted(blk)) != NULL) { + bs = blk_bs(blk); - bs = NULL; - while ((bs = bdrv_next(bs))) { if (bdrv_can_snapshot(bs)) { ret = bdrv_snapshot_goto(bs, name); if (ret < 0) { @@ -1495,6 +1502,7 @@ int load_vmstate(const char *name) void hmp_delvm(Monitor *mon, const QDict *qdict) { BlockDriverState *bs; + BlockBackend *blk = NULL; Error *err; const char *name = qdict_get_str(qdict, "name"); @@ -1503,8 +1511,9 @@ void hmp_delvm(Monitor *mon, const QDict *qdict) return; } - bs = NULL; - while ((bs = bdrv_next(bs))) { + while ((blk = blk_next_inserted(blk)) != NULL) { + bs = blk_bs(blk); + if (bdrv_can_snapshot(bs)) { err = NULL; bdrv_snapshot_delete_by_id_or_name(bs, name, &err); @@ -1512,7 +1521,7 @@ void hmp_delvm(Monitor *mon, const QDict *qdict) monitor_printf(mon, "Error while deleting snapshot on device '%s':" " %s\n", - bdrv_get_device_name(bs), + blk_name(blk), error_get_pretty(err)); error_free(err); } @@ -1523,6 +1532,7 @@ void hmp_delvm(Monitor *mon, const QDict *qdict) void hmp_info_snapshots(Monitor *mon, const QDict *qdict) { BlockDriverState *bs, *bs1; + BlockBackend *blk; QEMUSnapshotInfo *sn_tab, *sn, s, *sn_info = &s; int nb_sns, i, ret, available; int total; @@ -1550,9 +1560,11 @@ void hmp_info_snapshots(Monitor *mon, const QDict *qdict) for (i = 0; i < nb_sns; i++) { sn = &sn_tab[i]; available = 1; - bs1 = NULL; + blk = NULL; + + while ((blk = blk_next_inserted(blk)) != NULL) { + bs1 = blk_bs(blk); - while ((bs1 = bdrv_next(bs1))) { if (bdrv_can_snapshot(bs1) && bs1 != bs) { ret = bdrv_snapshot_find(bs1, sn_info, sn->id_str); if (ret < 0) { diff --git a/monitor.c b/monitor.c index 3295840..4600f2d 100644 --- a/monitor.c +++ b/monitor.c @@ -41,6 +41,7 @@ #include "ui/console.h" #include "ui/input.h" #include "sysemu/blockdev.h" +#include "sysemu/block-backend.h" #include "audio/audio.h" #include "disas/disas.h" #include "sysemu/balloon.h" @@ -3402,16 +3403,18 @@ void host_net_remove_completion(ReadLineState *rs, int nb_args, const char *str) static void vm_completion(ReadLineState *rs, const char *str) { size_t len; - BlockDriverState *bs = NULL; + BlockDriverState *bs; + BlockBackend *blk = NULL; len = strlen(str); readline_set_completion_index(rs, len); - while ((bs = bdrv_next(bs))) { + while ((blk = blk_next_inserted(blk)) != NULL) { SnapshotInfoList *snapshots, *snapshot; - AioContext *ctx = bdrv_get_aio_context(bs); + AioContext *ctx = blk_get_aio_context(blk); bool ok = false; aio_context_acquire(ctx); + bs = blk_bs(blk); if (bdrv_can_snapshot(bs)) { ok = bdrv_query_snapshot_info_list(bs, &snapshots, NULL) == 0; } @@ -3460,7 +3463,7 @@ static void monitor_find_completion_by_table(Monitor *mon, int i; const char *ptype, *str, *name; const mon_cmd_t *cmd; - BlockDriverState *bs; + BlockBackend *blk = NULL; if (nb_args <= 1) { /* command completion */ @@ -3515,8 +3518,8 @@ static void monitor_find_completion_by_table(Monitor *mon, case 'B': /* block device name completion */ readline_set_completion_index(mon->rs, strlen(str)); - for (bs = bdrv_next(NULL); bs; bs = bdrv_next(bs)) { - name = bdrv_get_device_name(bs); + while ((blk = blk_next(blk)) != NULL) { + name = blk_name(blk); if (str[0] == '\0' || !strncmp(name, str, strlen(str))) { readline_add_completion(mon->rs, name); diff --git a/qemu-char.c b/qemu-char.c index 5448b0f..28ea364 100644 --- a/qemu-char.c +++ b/qemu-char.c @@ -24,6 +24,7 @@ #include "qemu-common.h" #include "monitor/monitor.h" #include "sysemu/sysemu.h" +#include "sysemu/block-backend.h" #include "qemu/error-report.h" #include "qemu/timer.h" #include "sysemu/char.h" @@ -501,7 +502,7 @@ static int mux_proc_byte(CharDriverState *chr, MuxDriver *d, int ch) break; } case 's': - bdrv_commit_all(); + blk_commit_all(); break; case 'b': qemu_chr_be_event(chr, CHR_EVENT_BREAK); diff --git a/qemu-io.c b/qemu-io.c index 269f17c..3a9707e 100644 --- a/qemu-io.c +++ b/qemu-io.c @@ -493,7 +493,7 @@ int main(int argc, char **argv) /* * Make sure all outstanding requests complete before the program exits. */ - bdrv_drain_all(); + blk_drain_all(); blk_unref(qemuio_blk); g_free(readline_state); diff --git a/qmp.c b/qmp.c index ddc63ea..4ca295d 100644 --- a/qmp.c +++ b/qmp.c @@ -171,8 +171,7 @@ SpiceInfo *qmp_query_spice(Error **errp) void qmp_cont(Error **errp) { Error *local_err = NULL; - BlockBackend *blk; - BlockDriverState *bs; + BlockBackend *blk = NULL; if (runstate_needs_reset()) { error_setg(errp, "Resetting the Virtual Machine is required"); @@ -181,11 +180,11 @@ void qmp_cont(Error **errp) return; } - for (blk = blk_next(NULL); blk; blk = blk_next(blk)) { + while ((blk = blk_next(blk)) != NULL) { blk_iostatus_reset(blk); } - for (bs = bdrv_next(NULL); bs; bs = bdrv_next(bs)) { - bdrv_add_key(bs, NULL, &local_err); + while ((blk = blk_next_inserted(blk)) != NULL) { + bdrv_add_key(blk_bs(blk), NULL, &local_err); if (local_err) { error_propagate(errp, local_err); return; diff --git a/xen-mapcache.c b/xen-mapcache.c index 97fece2..66634bc 100644 --- a/xen-mapcache.c +++ b/xen-mapcache.c @@ -14,6 +14,7 @@ #include "hw/xen/xen_backend.h" #include "sysemu/blockdev.h" +#include "sysemu/block-backend.h" #include "qemu/bitmap.h" #include <xen/hvm/params.h> @@ -419,7 +420,7 @@ void xen_invalidate_map_cache(void) MapCacheRev *reventry; /* Flush pending AIO before destroying the mapcache */ - bdrv_drain_all(); + blk_drain_all(); mapcache_lock(); -- 2.6.2