|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen master] libxl: Provide libxl__backendpath_parse_domid
commit 481dddb63b1fac2368c8e8be109babee0b1ca171
Author: Ian Jackson <ian.jackson@xxxxxxxxxxxxx>
AuthorDate: Wed Apr 27 16:34:19 2016 +0100
Commit: Ian Jackson <Ian.Jackson@xxxxxxxxxxxxx>
CommitDate: Thu Jun 2 15:53:28 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 b4bd005..9f115c6 100644
--- a/tools/libxl/libxl_device.c
+++ b/tools/libxl/libxl_device.c
@@ -298,6 +298,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_disk_backend ok;
disk_try_backend_args a;
diff --git a/tools/libxl/libxl_internal.h b/tools/libxl/libxl_internal.h
index a4a4613..d8b877b 100644
--- a/tools/libxl/libxl_internal.h
+++ b/tools/libxl/libxl_internal.h
@@ -702,6 +702,8 @@ _hidden char **libxl__xs_directory(libxl__gc *gc,
xs_transaction_t t,
/* On error: returns NULL, sets errno (no logging) */
_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#master
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |