vhost: add JSON config dump
Change-Id: If6c9ea6f9959b6c34ef90b8e382ceba9889040ee Signed-off-by: Pawel Wodkowski <pawelx.wodkowski@intel.com> Reviewed-on: https://review.gerrithub.io/404373 Tested-by: SPDK Automated Test System <sys_sgsw@intel.com> Reviewed-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com> Reviewed-by: Daniel Verkamp <daniel.verkamp@intel.com>
This commit is contained in:
parent
e3263286d3
commit
a3f8876777
@ -42,6 +42,7 @@
|
|||||||
#include "spdk/stdinc.h"
|
#include "spdk/stdinc.h"
|
||||||
|
|
||||||
#include "spdk/event.h"
|
#include "spdk/event.h"
|
||||||
|
#include "spdk/json.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@ -77,6 +78,15 @@ int spdk_vhost_init(void);
|
|||||||
*/
|
*/
|
||||||
void spdk_vhost_fini(spdk_vhost_fini_cb fini_cb);
|
void spdk_vhost_fini(spdk_vhost_fini_cb fini_cb);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Write vhost subsystem configuration into provided JSON context.
|
||||||
|
*
|
||||||
|
* \param w JSON write context
|
||||||
|
* \param done_ev call this event when done.
|
||||||
|
*/
|
||||||
|
void spdk_vhost_config_json(struct spdk_json_write_ctx *w, struct spdk_event *done_ev);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deinit vhost application. This is called once by SPDK app layer.
|
* Deinit vhost application. This is called once by SPDK app layer.
|
||||||
*/
|
*/
|
||||||
|
@ -64,6 +64,7 @@ static struct spdk_subsystem g_spdk_subsystem_vhost = {
|
|||||||
.init = spdk_vhost_subsystem_init,
|
.init = spdk_vhost_subsystem_init,
|
||||||
.fini = spdk_vhost_subsystem_fini,
|
.fini = spdk_vhost_subsystem_fini,
|
||||||
.config = NULL,
|
.config = NULL,
|
||||||
|
.write_config_json = spdk_vhost_config_json,
|
||||||
};
|
};
|
||||||
|
|
||||||
SPDK_SUBSYSTEM_REGISTER(g_spdk_subsystem_vhost);
|
SPDK_SUBSYSTEM_REGISTER(g_spdk_subsystem_vhost);
|
||||||
|
@ -1158,11 +1158,10 @@ session_shutdown(void *arg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
spdk_vhost_dump_config_json(struct spdk_vhost_dev *vdev,
|
spdk_vhost_dump_info_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w)
|
||||||
struct spdk_json_write_ctx *w)
|
|
||||||
{
|
{
|
||||||
assert(vdev->backend->dump_config_json != NULL);
|
assert(vdev->backend->dump_info_json != NULL);
|
||||||
vdev->backend->dump_config_json(vdev, w);
|
vdev->backend->dump_info_json(vdev, w);
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
@ -1368,5 +1367,39 @@ spdk_vhost_fini(spdk_vhost_fini_cb fini_cb)
|
|||||||
pthread_detach(tid);
|
pthread_detach(tid);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct spdk_vhost_write_config_json_ctx {
|
||||||
|
struct spdk_json_write_ctx *w;
|
||||||
|
struct spdk_event *done_ev;
|
||||||
|
};
|
||||||
|
|
||||||
|
static int
|
||||||
|
spdk_vhost_config_json_cb(struct spdk_vhost_dev *vdev, void *arg)
|
||||||
|
{
|
||||||
|
struct spdk_vhost_write_config_json_ctx *ctx = arg;
|
||||||
|
|
||||||
|
if (vdev == NULL) {
|
||||||
|
spdk_json_write_array_end(ctx->w);
|
||||||
|
spdk_event_call(ctx->done_ev);
|
||||||
|
free(ctx);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
vdev->backend->write_config_json(vdev, ctx->w);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
spdk_vhost_config_json(struct spdk_json_write_ctx *w, struct spdk_event *done_ev)
|
||||||
|
{
|
||||||
|
struct spdk_vhost_write_config_json_ctx *ctx = calloc(1, sizeof(*ctx));
|
||||||
|
|
||||||
|
ctx->w = w;
|
||||||
|
ctx->done_ev = done_ev;
|
||||||
|
|
||||||
|
spdk_json_write_array_begin(w);
|
||||||
|
|
||||||
|
spdk_vhost_call_external_event_foreach(spdk_vhost_config_json_cb, ctx);
|
||||||
|
}
|
||||||
|
|
||||||
SPDK_LOG_REGISTER_COMPONENT("vhost", SPDK_LOG_VHOST)
|
SPDK_LOG_REGISTER_COMPONENT("vhost", SPDK_LOG_VHOST)
|
||||||
SPDK_LOG_REGISTER_COMPONENT("vhost_ring", SPDK_LOG_VHOST_RING)
|
SPDK_LOG_REGISTER_COMPONENT("vhost_ring", SPDK_LOG_VHOST_RING)
|
||||||
|
@ -595,7 +595,7 @@ err:
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
spdk_vhost_blk_dump_config_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w)
|
spdk_vhost_blk_dump_info_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w)
|
||||||
{
|
{
|
||||||
struct spdk_bdev *bdev = spdk_vhost_blk_get_dev(vdev);
|
struct spdk_bdev *bdev = spdk_vhost_blk_get_dev(vdev);
|
||||||
struct spdk_vhost_blk_dev *bvdev = to_blk_dev(vdev);
|
struct spdk_vhost_blk_dev *bvdev = to_blk_dev(vdev);
|
||||||
@ -617,6 +617,28 @@ spdk_vhost_blk_dump_config_json(struct spdk_vhost_dev *vdev, struct spdk_json_wr
|
|||||||
spdk_json_write_object_end(w);
|
spdk_json_write_object_end(w);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
spdk_vhost_blk_write_config_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w)
|
||||||
|
{
|
||||||
|
struct spdk_vhost_blk_dev *bvdev = to_blk_dev(vdev);
|
||||||
|
|
||||||
|
if (!bvdev->bdev) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
spdk_json_write_object_begin(w);
|
||||||
|
spdk_json_write_named_string(w, "method", "construct_vhost_blk_controller");
|
||||||
|
|
||||||
|
spdk_json_write_named_object_begin(w, "params");
|
||||||
|
spdk_json_write_named_string(w, "ctrlr", vdev->name);
|
||||||
|
spdk_json_write_named_string(w, "dev_name", spdk_bdev_get_name(bvdev->bdev));
|
||||||
|
spdk_json_write_named_string(w, "cpumask", spdk_cpuset_fmt(vdev->cpumask));
|
||||||
|
spdk_json_write_named_bool(w, "readonly", bvdev->readonly);
|
||||||
|
spdk_json_write_object_end(w);
|
||||||
|
|
||||||
|
spdk_json_write_object_end(w);
|
||||||
|
}
|
||||||
|
|
||||||
static int spdk_vhost_blk_destroy(struct spdk_vhost_dev *dev);
|
static int spdk_vhost_blk_destroy(struct spdk_vhost_dev *dev);
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -672,7 +694,8 @@ static const struct spdk_vhost_dev_backend vhost_blk_device_backend = {
|
|||||||
.start_device = spdk_vhost_blk_start,
|
.start_device = spdk_vhost_blk_start,
|
||||||
.stop_device = spdk_vhost_blk_stop,
|
.stop_device = spdk_vhost_blk_stop,
|
||||||
.vhost_get_config = spdk_vhost_blk_get_config,
|
.vhost_get_config = spdk_vhost_blk_get_config,
|
||||||
.dump_config_json = spdk_vhost_blk_dump_config_json,
|
.dump_info_json = spdk_vhost_blk_dump_info_json,
|
||||||
|
.write_config_json = spdk_vhost_blk_write_config_json,
|
||||||
.remove_device = spdk_vhost_blk_destroy,
|
.remove_device = spdk_vhost_blk_destroy,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -128,7 +128,8 @@ struct spdk_vhost_dev_backend {
|
|||||||
int (*vhost_set_config)(struct spdk_vhost_dev *vdev, uint8_t *config,
|
int (*vhost_set_config)(struct spdk_vhost_dev *vdev, uint8_t *config,
|
||||||
uint32_t offset, uint32_t size, uint32_t flags);
|
uint32_t offset, uint32_t size, uint32_t flags);
|
||||||
|
|
||||||
void (*dump_config_json)(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w);
|
void (*dump_info_json)(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w);
|
||||||
|
void (*write_config_json)(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w);
|
||||||
int (*remove_device)(struct spdk_vhost_dev *vdev);
|
int (*remove_device)(struct spdk_vhost_dev *vdev);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -248,7 +249,7 @@ int spdk_vhost_dev_unregister(struct spdk_vhost_dev *vdev);
|
|||||||
|
|
||||||
int spdk_vhost_scsi_controller_construct(void);
|
int spdk_vhost_scsi_controller_construct(void);
|
||||||
int spdk_vhost_blk_controller_construct(void);
|
int spdk_vhost_blk_controller_construct(void);
|
||||||
void spdk_vhost_dump_config_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w);
|
void spdk_vhost_dump_info_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w);
|
||||||
void spdk_vhost_dev_backend_event_done(void *event_ctx, int response);
|
void spdk_vhost_dev_backend_event_done(void *event_ctx, int response);
|
||||||
void spdk_vhost_lock(void);
|
void spdk_vhost_lock(void);
|
||||||
void spdk_vhost_unlock(void);
|
void spdk_vhost_unlock(void);
|
||||||
|
@ -1005,7 +1005,7 @@ err:
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
spdk_vhost_nvme_dump_config_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w)
|
spdk_vhost_nvme_dump_info_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w)
|
||||||
{
|
{
|
||||||
struct spdk_vhost_nvme_dev *nvme = to_nvme_dev(vdev);
|
struct spdk_vhost_nvme_dev *nvme = to_nvme_dev(vdev);
|
||||||
struct spdk_vhost_nvme_ns *ns_dev;
|
struct spdk_vhost_nvme_ns *ns_dev;
|
||||||
@ -1043,7 +1043,7 @@ spdk_vhost_nvme_dump_config_json(struct spdk_vhost_dev *vdev, struct spdk_json_w
|
|||||||
static const struct spdk_vhost_dev_backend spdk_vhost_nvme_device_backend = {
|
static const struct spdk_vhost_dev_backend spdk_vhost_nvme_device_backend = {
|
||||||
.start_device = spdk_vhost_nvme_start_device,
|
.start_device = spdk_vhost_nvme_start_device,
|
||||||
.stop_device = spdk_vhost_nvme_stop_device,
|
.stop_device = spdk_vhost_nvme_stop_device,
|
||||||
.dump_config_json = spdk_vhost_nvme_dump_config_json,
|
.dump_info_json = spdk_vhost_nvme_dump_info_json,
|
||||||
.remove_device = spdk_vhost_nvme_dev_remove,
|
.remove_device = spdk_vhost_nvme_dev_remove,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -476,7 +476,7 @@ spdk_rpc_get_vhost_controllers_cb(struct spdk_vhost_dev *vdev, void *arg)
|
|||||||
spdk_json_write_name(ctx->w, "backend_specific");
|
spdk_json_write_name(ctx->w, "backend_specific");
|
||||||
|
|
||||||
spdk_json_write_object_begin(ctx->w);
|
spdk_json_write_object_begin(ctx->w);
|
||||||
spdk_vhost_dump_config_json(vdev, ctx->w);
|
spdk_vhost_dump_info_json(vdev, ctx->w);
|
||||||
spdk_json_write_object_end(ctx->w);
|
spdk_json_write_object_end(ctx->w);
|
||||||
|
|
||||||
spdk_json_write_object_end(ctx->w); // ctrl
|
spdk_json_write_object_end(ctx->w); // ctrl
|
||||||
|
@ -107,7 +107,10 @@ struct spdk_vhost_scsi_task {
|
|||||||
|
|
||||||
static int spdk_vhost_scsi_start(struct spdk_vhost_dev *, void *);
|
static int spdk_vhost_scsi_start(struct spdk_vhost_dev *, void *);
|
||||||
static int spdk_vhost_scsi_stop(struct spdk_vhost_dev *, void *);
|
static int spdk_vhost_scsi_stop(struct spdk_vhost_dev *, void *);
|
||||||
static void spdk_vhost_scsi_config_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w);
|
static void spdk_vhost_scsi_dump_info_json(struct spdk_vhost_dev *vdev,
|
||||||
|
struct spdk_json_write_ctx *w);
|
||||||
|
static void spdk_vhost_scsi_write_config_json(struct spdk_vhost_dev *vdev,
|
||||||
|
struct spdk_json_write_ctx *w);
|
||||||
static int spdk_vhost_scsi_dev_remove(struct spdk_vhost_dev *vdev);
|
static int spdk_vhost_scsi_dev_remove(struct spdk_vhost_dev *vdev);
|
||||||
|
|
||||||
const struct spdk_vhost_dev_backend spdk_vhost_scsi_device_backend = {
|
const struct spdk_vhost_dev_backend spdk_vhost_scsi_device_backend = {
|
||||||
@ -115,7 +118,8 @@ const struct spdk_vhost_dev_backend spdk_vhost_scsi_device_backend = {
|
|||||||
.disabled_features = SPDK_VHOST_SCSI_DISABLED_FEATURES,
|
.disabled_features = SPDK_VHOST_SCSI_DISABLED_FEATURES,
|
||||||
.start_device = spdk_vhost_scsi_start,
|
.start_device = spdk_vhost_scsi_start,
|
||||||
.stop_device = spdk_vhost_scsi_stop,
|
.stop_device = spdk_vhost_scsi_stop,
|
||||||
.dump_config_json = spdk_vhost_scsi_config_json,
|
.dump_info_json = spdk_vhost_scsi_dump_info_json,
|
||||||
|
.write_config_json = spdk_vhost_scsi_write_config_json,
|
||||||
.remove_device = spdk_vhost_scsi_dev_remove,
|
.remove_device = spdk_vhost_scsi_dev_remove,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1167,7 +1171,7 @@ err:
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
spdk_vhost_scsi_config_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w)
|
spdk_vhost_scsi_dump_info_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w)
|
||||||
{
|
{
|
||||||
struct spdk_scsi_dev *sdev;
|
struct spdk_scsi_dev *sdev;
|
||||||
struct spdk_scsi_lun *lun;
|
struct spdk_scsi_lun *lun;
|
||||||
@ -1221,6 +1225,44 @@ spdk_vhost_scsi_config_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_
|
|||||||
spdk_json_write_array_end(w);
|
spdk_json_write_array_end(w);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
spdk_vhost_scsi_write_config_json(struct spdk_vhost_dev *vdev, struct spdk_json_write_ctx *w)
|
||||||
|
{
|
||||||
|
struct spdk_vhost_scsi_dev *svdev = to_scsi_dev(vdev);
|
||||||
|
struct spdk_scsi_lun *lun;
|
||||||
|
uint32_t i;
|
||||||
|
|
||||||
|
spdk_json_write_object_begin(w);
|
||||||
|
spdk_json_write_named_string(w, "method", "construct_vhost_scsi_controller");
|
||||||
|
|
||||||
|
spdk_json_write_named_object_begin(w, "params");
|
||||||
|
spdk_json_write_named_string(w, "ctrlr", vdev->name);
|
||||||
|
spdk_json_write_named_string(w, "cpumask", spdk_cpuset_fmt(vdev->cpumask));
|
||||||
|
spdk_json_write_object_end(w);
|
||||||
|
|
||||||
|
spdk_json_write_object_end(w);
|
||||||
|
|
||||||
|
for (i = 0; i < SPDK_COUNTOF(svdev->scsi_dev); i++) {
|
||||||
|
if (svdev->scsi_dev[i] == NULL || svdev->scsi_dev_state[i].removed) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
lun = spdk_scsi_dev_get_lun(svdev->scsi_dev[i], 0);
|
||||||
|
|
||||||
|
spdk_json_write_object_begin(w);
|
||||||
|
spdk_json_write_named_string(w, "method", "add_vhost_scsi_lun");
|
||||||
|
|
||||||
|
spdk_json_write_named_object_begin(w, "params");
|
||||||
|
spdk_json_write_named_string(w, "ctrlr", vdev->name);
|
||||||
|
spdk_json_write_named_uint32(w, "scsi_target_num", i);
|
||||||
|
|
||||||
|
spdk_json_write_named_string(w, "bdev_name", spdk_scsi_lun_get_bdev_name(lun));
|
||||||
|
spdk_json_write_object_end(w);
|
||||||
|
|
||||||
|
spdk_json_write_object_end(w);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
SPDK_LOG_REGISTER_COMPONENT("vhost_scsi", SPDK_LOG_VHOST_SCSI)
|
SPDK_LOG_REGISTER_COMPONENT("vhost_scsi", SPDK_LOG_VHOST_SCSI)
|
||||||
SPDK_LOG_REGISTER_COMPONENT("vhost_scsi_queue", SPDK_LOG_VHOST_SCSI_QUEUE)
|
SPDK_LOG_REGISTER_COMPONENT("vhost_scsi_queue", SPDK_LOG_VHOST_SCSI_QUEUE)
|
||||||
SPDK_LOG_REGISTER_COMPONENT("vhost_scsi_data", SPDK_LOG_VHOST_SCSI_DATA)
|
SPDK_LOG_REGISTER_COMPONENT("vhost_scsi_data", SPDK_LOG_VHOST_SCSI_DATA)
|
||||||
|
@ -38,6 +38,8 @@
|
|||||||
#include "spdk_internal/mock.h"
|
#include "spdk_internal/mock.h"
|
||||||
#include "spdk/io_channel.h"
|
#include "spdk/io_channel.h"
|
||||||
|
|
||||||
|
#include "unit/lib/json_mock.c"
|
||||||
|
|
||||||
struct spdk_conf_section {
|
struct spdk_conf_section {
|
||||||
struct spdk_conf_section *next;
|
struct spdk_conf_section *next;
|
||||||
char *name;
|
char *name;
|
||||||
@ -87,16 +89,6 @@ DEFINE_STUB_V(spdk_vhost_call_external_event, (const char *ctrlr_name, spdk_vhos
|
|||||||
DEFINE_STUB(spdk_vhost_vring_desc_has_next, bool, (struct vring_desc *cur_desc), false);
|
DEFINE_STUB(spdk_vhost_vring_desc_has_next, bool, (struct vring_desc *cur_desc), false);
|
||||||
DEFINE_STUB_VP(spdk_vhost_gpa_to_vva, (struct spdk_vhost_dev *vdev, uint64_t addr), {0});
|
DEFINE_STUB_VP(spdk_vhost_gpa_to_vva, (struct spdk_vhost_dev *vdev, uint64_t addr), {0});
|
||||||
DEFINE_STUB(spdk_scsi_dev_get_id, int, (const struct spdk_scsi_dev *dev), {0});
|
DEFINE_STUB(spdk_scsi_dev_get_id, int, (const struct spdk_scsi_dev *dev), {0});
|
||||||
DEFINE_STUB(spdk_json_write_null, int, (struct spdk_json_write_ctx *w), 0);
|
|
||||||
DEFINE_STUB(spdk_json_write_bool, int, (struct spdk_json_write_ctx *w, bool val), 0);
|
|
||||||
DEFINE_STUB(spdk_json_write_name, int, (struct spdk_json_write_ctx *w, const char *name), 0);
|
|
||||||
DEFINE_STUB(spdk_json_write_object_begin, int, (struct spdk_json_write_ctx *w), 0);
|
|
||||||
DEFINE_STUB(spdk_json_write_uint32, int, (struct spdk_json_write_ctx *w, uint32_t val), 0);
|
|
||||||
DEFINE_STUB(spdk_json_write_int32, int, (struct spdk_json_write_ctx *w, int32_t val), 0);
|
|
||||||
DEFINE_STUB(spdk_json_write_string, int, (struct spdk_json_write_ctx *w, const char *val), 0);
|
|
||||||
DEFINE_STUB(spdk_json_write_array_begin, int, (struct spdk_json_write_ctx *w), 0);
|
|
||||||
DEFINE_STUB(spdk_json_write_object_end, int, (struct spdk_json_write_ctx *w), 0);
|
|
||||||
DEFINE_STUB(spdk_json_write_array_end, int, (struct spdk_json_write_ctx *w), 0);
|
|
||||||
|
|
||||||
/* This sets spdk_vhost_dev_unregister to either to fail or success */
|
/* This sets spdk_vhost_dev_unregister to either to fail or success */
|
||||||
DEFINE_STUB(spdk_vhost_dev_unregister_fail, bool, (void), false);
|
DEFINE_STUB(spdk_vhost_dev_unregister_fail, bool, (void), false);
|
||||||
|
@ -38,6 +38,7 @@
|
|||||||
#include "spdk/io_channel.h"
|
#include "spdk/io_channel.h"
|
||||||
#include "spdk_internal/mock.h"
|
#include "spdk_internal/mock.h"
|
||||||
#include "common/lib/test_env.c"
|
#include "common/lib/test_env.c"
|
||||||
|
#include "unit/lib/json_mock.c"
|
||||||
|
|
||||||
#include "vhost/vhost.c"
|
#include "vhost/vhost.c"
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user