[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen staging] tools: xencall, xengnttab, xengntshr: Provide access to internal fds
commit e1ed22be85703ff6010378183de3bd0d87c51ee4 Author: Ian Jackson <ian.jackson@xxxxxxxxxxxxx> AuthorDate: Fri May 4 16:29:17 2018 +0100 Commit: Ian Jackson <Ian.Jackson@xxxxxxxxxxxxx> CommitDate: Fri Jul 6 16:27:52 2018 +0100 tools: xencall, xengnttab, xengntshr: Provide access to internal fds I want this to support my qemu depriv descriptor audit tool. Signed-off-by: Ian Jackson <Ian.Jackson@xxxxxxxxxxxxx> CC: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> Reviewed-by: Roger Pau Monné <roger.pau@xxxxxxxxxx> Acked-by: Wei Liu <wei.liu2@xxxxxxxxxx> --- tools/libs/call/core.c | 5 +++++ tools/libs/call/include/xencall.h | 8 ++++++++ tools/libs/call/libxencall.map | 1 + tools/libs/gnttab/gntshr_core.c | 6 ++++++ tools/libs/gnttab/gnttab_core.c | 5 +++++ tools/libs/gnttab/include/xengnttab.h | 17 +++++++++++++++++ tools/libs/gnttab/libxengnttab.map | 6 ++++++ 7 files changed, 48 insertions(+) diff --git a/tools/libs/call/core.c b/tools/libs/call/core.c index 46ca61529e..57d3a33e6b 100644 --- a/tools/libs/call/core.c +++ b/tools/libs/call/core.c @@ -91,6 +91,11 @@ int xencall_close(xencall_handle *xcall) return rc; } +int xencall_fd(xencall_handle *xcall) +{ + return xcall->fd; +} + int xencall0(xencall_handle *xcall, unsigned int op) { privcmd_hypercall_t call = { diff --git a/tools/libs/call/include/xencall.h b/tools/libs/call/include/xencall.h index 0d09bc8eae..2d0c42ad5e 100644 --- a/tools/libs/call/include/xencall.h +++ b/tools/libs/call/include/xencall.h @@ -74,6 +74,14 @@ xencall_handle *xencall_open(struct xentoollog_logger *logger, int xencall_close(xencall_handle *xcall); /* + * Return the fd used internally by xencall. selecting on it is not + * useful. But it could be useful for unusual use cases; perhaps, + * passing to other programs, calling ioctls on directly, or maybe + * calling fcntl. + */ +int xencall_fd(xencall_handle *xcall); + +/* * Call hypercalls with varying numbers of arguments. * * On success the return value of the hypercall is the return value of diff --git a/tools/libs/call/libxencall.map b/tools/libs/call/libxencall.map index c482195b95..feacee3146 100644 --- a/tools/libs/call/libxencall.map +++ b/tools/libs/call/libxencall.map @@ -21,4 +21,5 @@ VERS_1.0 { VERS_1.1 { global: xencall_buffers_never_fault; + xencall_fd; } VERS_1.0; diff --git a/tools/libs/gnttab/gntshr_core.c b/tools/libs/gnttab/gntshr_core.c index 7f6bf9de6a..1117e29c91 100644 --- a/tools/libs/gnttab/gntshr_core.c +++ b/tools/libs/gnttab/gntshr_core.c @@ -64,6 +64,12 @@ int xengntshr_close(xengntshr_handle *xgs) free(xgs); return rc; } + +int xengntshr_fd(xengntshr_handle *xgs) +{ + return xgs->fd; +} + void *xengntshr_share_pages(xengntshr_handle *xcg, uint32_t domid, int count, uint32_t *refs, int writable) { diff --git a/tools/libs/gnttab/gnttab_core.c b/tools/libs/gnttab/gnttab_core.c index 98f1591e9d..bd075f818a 100644 --- a/tools/libs/gnttab/gnttab_core.c +++ b/tools/libs/gnttab/gnttab_core.c @@ -75,6 +75,11 @@ int xengnttab_close(xengnttab_handle *xgt) return rc; } +int xengnttab_fd(xengnttab_handle *xgt) +{ + return xgt->fd; +} + int xengnttab_set_max_grants(xengnttab_handle *xgt, uint32_t count) { return osdep_gnttab_set_max_grants(xgt, count); diff --git a/tools/libs/gnttab/include/xengnttab.h b/tools/libs/gnttab/include/xengnttab.h index 35be6c1567..91d4cd5bdd 100644 --- a/tools/libs/gnttab/include/xengnttab.h +++ b/tools/libs/gnttab/include/xengnttab.h @@ -149,6 +149,15 @@ xengnttab_handle *xengnttab_open(struct xentoollog_logger *logger, */ int xengnttab_close(xengnttab_handle *xgt); + +/* + * Return the fd used internally by xengnttab. selecting on it is not + * useful. But it could be useful for unusual use cases; perhaps, + * passing to other programs, calling ioctls on directly, or maybe + * calling fcntl. + */ +int xengnttab_fd(xengnttab_handle *xgt); + /** * Memory maps a grant reference from one domain to a local address range. * Mappings should be unmapped with xengnttab_unmap. Logs errors. @@ -334,6 +343,14 @@ xengntshr_handle *xengntshr_open(struct xentoollog_logger *logger, */ int xengntshr_close(xengntshr_handle *xgs); +/* + * Return the fd used internally by xengntshr. selecting on it is not + * useful. But it could be useful for unusual use cases; perhaps, + * passing to other programs, calling ioctls on directly, or maybe + * calling fcntl. + */ +int xengntshr_fd(xengntshr_handle *xgs); + /** * Allocates and shares pages with another domain. * diff --git a/tools/libs/gnttab/libxengnttab.map b/tools/libs/gnttab/libxengnttab.map index f78da229a5..d5da388a0d 100644 --- a/tools/libs/gnttab/libxengnttab.map +++ b/tools/libs/gnttab/libxengnttab.map @@ -26,3 +26,9 @@ VERS_1.1 { global: xengnttab_grant_copy; } VERS_1.0; + +VERS_1.2 { + global: + xengnttab_fd; + xengntshr_fd; +} VERS_1.1; -- generated by git-patchbot for /home/xen/git/xen.git#staging _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |