[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen stable-4.3] libxl: Provide libxl__backendpath_parse_domid
commit 89c6672d012890894105d7f832ddf4cbf8d56a15 Author: Ian Jackson <ian.jackson@xxxxxxxxxxxxx> AuthorDate: Wed Apr 27 16:34:19 2016 +0100 Commit: Ian Jackson <Ian.Jackson@xxxxxxxxxxxxx> CommitDate: Mon Jun 6 17:05:30 2016 +0100 libxl: Provide libxl__backendpath_parse_domid Multiple places in libxl need to figure out the backend domid of a device. This can be discovered easily by looking at the backend path, which always starts /local/domain/$backend_domid/. There are no call sites yet. This is part of XSA-175. Signed-off-by: Ian Jackson <Ian.Jackson@xxxxxxxxxxxxx> Reviewed-by: Wei Liu <wei.liu2@xxxxxxxxxx> --- tools/libxl/libxl_device.c | 15 +++++++++++++++ tools/libxl/libxl_internal.h | 2 ++ 2 files changed, 17 insertions(+) diff --git a/tools/libxl/libxl_device.c b/tools/libxl/libxl_device.c index b9d9e62..fd46726 100644 --- a/tools/libxl/libxl_device.c +++ b/tools/libxl/libxl_device.c @@ -274,6 +274,21 @@ static int disk_try_backend(disk_try_backend_args *a, return 0; } +int libxl__backendpath_parse_domid(libxl__gc *gc, const char *be_path, + libxl_domid *domid_out) { + int r; + unsigned int domid_sc; + char delim_sc; + + r = sscanf(be_path, "/local/domain/%u%c", &domid_sc, &delim_sc); + if (!(r==2 && delim_sc=='/')) { + LOG(ERROR, "internal error: backend path %s unparseable!", be_path); + return ERROR_FAIL; + } + *domid_out = domid_sc; + return 0; +} + int libxl__device_disk_set_backend(libxl__gc *gc, libxl_device_disk *disk) { libxl_ctx *ctx = libxl__gc_owner(gc); libxl_disk_backend ok; diff --git a/tools/libxl/libxl_internal.h b/tools/libxl/libxl_internal.h index 7376394..84fa2cc 100644 --- a/tools/libxl/libxl_internal.h +++ b/tools/libxl/libxl_internal.h @@ -562,6 +562,8 @@ _hidden bool libxl__xs_mkdir(libxl__gc *gc, xs_transaction_t t, _hidden char *libxl__xs_libxl_path(libxl__gc *gc, uint32_t domid); +_hidden int libxl__backendpath_parse_domid(libxl__gc *gc, const char *be_path, + libxl_domid *domid_out); /*----- "checked" xenstore access functions -----*/ /* Each of these functions will check that it succeeded; if it -- generated by git-patchbot for /home/xen/git/xen.git#stable-4.3 _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |