aboutsummaryrefslogtreecommitdiffstats
path: root/tools/libxc/xc_flask.c
diff options
context:
space:
mode:
authorIan Campbell <ian.campbell@citrix.com>2010-10-22 15:14:51 +0100
committerIan Campbell <ian.campbell@citrix.com>2010-10-22 15:14:51 +0100
commit6209471c3cd925fd33eeb15e7df70bf031a61229 (patch)
treea7235a219fb562c6a56cda9d354110c6345f2381 /tools/libxc/xc_flask.c
parenta1549a5312c76bef403254bf5d3578e24297ef32 (diff)
downloadxen-6209471c3cd925fd33eeb15e7df70bf031a61229.tar.gz
xen-6209471c3cd925fd33eeb15e7df70bf031a61229.tar.bz2
xen-6209471c3cd925fd33eeb15e7df70bf031a61229.zip
libxc: convert flask interfaces over to hypercall buffers
Signed-off-by: Ian Campbell <ian.campbell@citrix.com> Signed-off-by: Ian Jackson <ian.jackson.citrix.com>
Diffstat (limited to 'tools/libxc/xc_flask.c')
-rw-r--r--tools/libxc/xc_flask.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/tools/libxc/xc_flask.c b/tools/libxc/xc_flask.c
index 621967f496..27794a82d5 100644
--- a/tools/libxc/xc_flask.c
+++ b/tools/libxc/xc_flask.c
@@ -40,23 +40,24 @@ int xc_flask_op(xc_interface *xch, flask_op_t *op)
{
int ret = -1;
DECLARE_HYPERCALL;
+ DECLARE_HYPERCALL_BOUNCE(op, sizeof(*op), XC_HYPERCALL_BUFFER_BOUNCE_BOTH);
- hypercall.op = __HYPERVISOR_xsm_op;
- hypercall.arg[0] = (unsigned long)op;
-
- if ( lock_pages(xch, op, sizeof(*op)) != 0 )
+ if ( xc_hypercall_bounce_pre(xch, op) )
{
- PERROR("Could not lock memory for Xen hypercall");
+ PERROR("Could not bounce memory for flask op hypercall");
goto out;
}
+ hypercall.op = __HYPERVISOR_xsm_op;
+ hypercall.arg[0] = HYPERCALL_BUFFER_AS_ARG(op);
+
if ( (ret = do_xen_hypercall(xch, &hypercall)) < 0 )
{
if ( errno == EACCES )
fprintf(stderr, "XSM operation failed!\n");
}
- unlock_pages(xch, op, sizeof(*op));
+ xc_hypercall_bounce_post(xch, op);
out:
return ret;