[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH V3 9/29] tools/libxc: Add viommu operations in libxc
On Thu, Sep 21, 2017 at 11:01:50PM -0400, Lan Tianyu wrote: > From: Chao Gao <chao.gao@xxxxxxxxx> > > This patch adds XEN_DOMCTL_viommu_op hypercall. This hypercall > comprises two sub-commands: Patch description doesn't match actual code. This patch doesn't add any new hypercalls, it just adds libxc helpers for XEN_DOMCTL_viommu_op. > - create(): create a vIOMMU in Xen, given viommu type, register-set > location and capabilities > - destroy(): destroy a vIOMMU specified by viommu_id > > Signed-off-by: Chao Gao <chao.gao@xxxxxxxxx> > Signed-off-by: Lan Tianyu <tianyu.lan@xxxxxxxxx> > --- > v3: > - Remove API for querying viommu capabilities > - Remove pointless cast > - Polish commit message > - Coding style > --- > tools/libxc/Makefile | 1 + > tools/libxc/include/xenctrl.h | 4 +++ > tools/libxc/xc_viommu.c | 64 > +++++++++++++++++++++++++++++++++++++++++++ > 3 files changed, 69 insertions(+) > create mode 100644 tools/libxc/xc_viommu.c > > diff --git a/tools/libxc/Makefile b/tools/libxc/Makefile > index 9a019e8..7d8c4b4 100644 > --- a/tools/libxc/Makefile > +++ b/tools/libxc/Makefile > @@ -51,6 +51,7 @@ CTRL_SRCS-$(CONFIG_MiniOS) += xc_minios.c > CTRL_SRCS-y += xc_evtchn_compat.c > CTRL_SRCS-y += xc_gnttab_compat.c > CTRL_SRCS-y += xc_devicemodel_compat.c > +CTRL_SRCS-y += xc_viommu.c > > GUEST_SRCS-y := > GUEST_SRCS-y += xg_private.c xc_suspend.c > diff --git a/tools/libxc/include/xenctrl.h b/tools/libxc/include/xenctrl.h > index 43151cb..bedca1f 100644 > --- a/tools/libxc/include/xenctrl.h > +++ b/tools/libxc/include/xenctrl.h > @@ -2501,6 +2501,10 @@ enum xc_static_cpu_featuremask { > const uint32_t *xc_get_static_cpu_featuremask(enum > xc_static_cpu_featuremask); > const uint32_t *xc_get_feature_deep_deps(uint32_t feature); > > +int xc_viommu_create(xc_interface *xch, domid_t dom, uint64_t type, > + uint64_t base_addr, uint64_t cap, uint32_t *viommu_id); > +int xc_viommu_destroy(xc_interface *xch, domid_t dom, uint32_t viommu_id); > + > #endif > > int xc_livepatch_upload(xc_interface *xch, > diff --git a/tools/libxc/xc_viommu.c b/tools/libxc/xc_viommu.c > new file mode 100644 > index 0000000..17507c5 > --- /dev/null > +++ b/tools/libxc/xc_viommu.c > @@ -0,0 +1,64 @@ > +/* > + * xc_viommu.c > + * > + * viommu related API functions. > + * > + * Copyright (C) 2017 Intel Corporation > + * > + * This library is free software; you can redistribute it and/or > + * modify it under the terms of the GNU Lesser General Public > + * License, version 2.1, as published by the Free Software Foundation. > + * > + * This library is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU > + * Lesser General Public License for more details. > + * > + * You should have received a copy of the GNU Lesser General Public > + * License along with this library; If not, see > <http://www.gnu.org/licenses/>. > + */ > + > +#include "xc_private.h" > + > +int xc_viommu_create(xc_interface *xch, domid_t dom, uint64_t type, > + uint64_t base_addr, uint64_t cap, uint32_t *viommu_id) > +{ > + int rc; > + Extra newline. > + DECLARE_DOMCTL; > + > + domctl.cmd = XEN_DOMCTL_viommu_op; > + domctl.domain = dom; > + domctl.u.viommu_op.cmd = XEN_DOMCTL_create_viommu; > + domctl.u.viommu_op.u.create.viommu_type = type; Please remove the "viommu_" prefix from the field, it's not needed and just using "type" is already clear. Thanks, Roger. _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx https://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |