[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH RFCv3 5/8] libxl: add libxl__domain_soft_reset_destroy_old()
New libxl__domain_soft_reset_destroy_old() is an internal-only version of libxl_domain_destroy() which follows the same domain destroy path with the only difference: xc_domain_destroy() is being avoided so the domain is not actually being destroyed. Add soft_reset flag to libxl__domain_destroy_state structure to support the change. The original libxl_domain_destroy() function could be easily modified to support new flag but I'm trying to avoid that as it is part of public API. Signed-off-by: Vitaly Kuznetsov <vkuznets@xxxxxxxxxx> --- tools/libxl/libxl.c | 32 +++++++++++++++++++++++++++----- tools/libxl/libxl_internal.h | 4 ++++ 2 files changed, 31 insertions(+), 5 deletions(-) diff --git a/tools/libxl/libxl.c b/tools/libxl/libxl.c index 77672d0..a38019b 100644 --- a/tools/libxl/libxl.c +++ b/tools/libxl/libxl.c @@ -1351,6 +1351,23 @@ int libxl_domain_destroy(libxl_ctx *ctx, uint32_t domid, return AO_INPROGRESS; } +int libxl__domain_soft_reset_destroy_old(libxl_ctx *ctx, uint32_t domid, + const libxl_asyncop_how *ao_how) +{ + AO_CREATE(ctx, domid, ao_how); + libxl__domain_destroy_state *dds; + + GCNEW(dds); + dds->ao = ao; + dds->domid = domid; + dds->callback = domain_destroy_cb; + dds->soft_reset = 1; + libxl__domain_destroy(egc, dds); + + return AO_INPROGRESS; +} + + static void domain_destroy_cb(libxl__egc *egc, libxl__domain_destroy_state *dds, int rc) { @@ -1526,6 +1543,7 @@ static void devices_destroy_cb(libxl__egc *egc, { STATE_AO_GC(drs->ao); libxl__destroy_domid_state *dis = CONTAINER_OF(drs, *dis, drs); + libxl__domain_destroy_state *dds = CONTAINER_OF(dis, *dds, domain); libxl_ctx *ctx = CTX; uint32_t domid = dis->domid; char *dom_path; @@ -1564,11 +1582,15 @@ static void devices_destroy_cb(libxl__egc *egc, } libxl__userdata_destroyall(gc, domid); - rc = xc_domain_destroy(ctx->xch, domid); - if (rc < 0) { - LIBXL__LOG_ERRNOVAL(ctx, LIBXL__LOG_ERROR, rc, "xc_domain_destroy failed for %d", domid); - rc = ERROR_FAIL; - goto out; + if (!dds->soft_reset) + { + rc = xc_domain_destroy(ctx->xch, domid); + if (rc < 0) { + LIBXL__LOG_ERRNOVAL(ctx, LIBXL__LOG_ERROR, rc, + "xc_domain_destroy failed for %d", domid); + rc = ERROR_FAIL; + goto out; + } } rc = 0; diff --git a/tools/libxl/libxl_internal.h b/tools/libxl/libxl_internal.h index f61673c..b43f2e3 100644 --- a/tools/libxl/libxl_internal.h +++ b/tools/libxl/libxl_internal.h @@ -2762,6 +2762,7 @@ struct libxl__domain_destroy_state { int stubdom_finished; libxl__destroy_domid_state domain; int domain_finished; + int soft_reset; }; /* @@ -2925,6 +2926,9 @@ _hidden void libxl__domain_save_device_model(libxl__egc *egc, _hidden const char *libxl__device_model_savefile(libxl__gc *gc, uint32_t domid); +_hidden int libxl__domain_soft_reset_destroy_old(libxl_ctx *ctx, uint32_t domid, + const libxl_asyncop_how *ao_how); + /* * Convenience macros. -- 1.9.3 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx http://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |