[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH v3 2/6] x86/hvm: Provide XEN_DMOP_add_to_physmap
> -----Original Message----- > From: Ross Lagerwall [mailto:ross.lagerwall@xxxxxxxxxx] > Sent: 12 January 2018 12:45 > To: xen-devel@xxxxxxxxxxxxx > Cc: Ross Lagerwall <ross.lagerwall@xxxxxxxxxx>; Paul Durrant > <Paul.Durrant@xxxxxxxxxx>; Jan Beulich <jbeulich@xxxxxxxx>; Andrew > Cooper <Andrew.Cooper3@xxxxxxxxxx>; George Dunlap > <George.Dunlap@xxxxxxxxxx>; Ian Jackson <Ian.Jackson@xxxxxxxxxx>; Konrad > Rzeszutek Wilk <konrad.wilk@xxxxxxxxxx>; Stefano Stabellini > <sstabellini@xxxxxxxxxx>; Tim (Xen.org) <tim@xxxxxxx>; Wei Liu > <wei.liu2@xxxxxxxxxx> > Subject: [PATCH v3 2/6] x86/hvm: Provide XEN_DMOP_add_to_physmap > > Provide XEN_DMOP_add_to_physmap, a limited version of > XENMEM_add_to_physmap to allow a deprivileged QEMU to move VRAM > when a > guest programs its BAR. It is equivalent to XENMEM_add_to_physmap with > space == XENMAPSPACE_gmfn_range. > > Signed-off-by: Ross Lagerwall <ross.lagerwall@xxxxxxxxxx> Reviewed-by: Paul Durrant <paul.durrant@xxxxxxxxxx> > --- > > Changed in v3: > * Renamed idx -> src_gfn and gpfn -> dst_gfn. > * Increase the width of size and add an overflow check. > * Rework some of the descriptions. > * Dropped Paul's reviewed-by due to the above changes. > > Changed in v2: > * Make it operate on a range. > > xen/arch/x86/hvm/dm.c | 37 > +++++++++++++++++++++++++++++++++++++ > xen/include/public/hvm/dm_op.h | 19 +++++++++++++++++++ > xen/include/xlat.lst | 1 + > 3 files changed, 57 insertions(+) > > diff --git a/xen/arch/x86/hvm/dm.c b/xen/arch/x86/hvm/dm.c > index a787f43..4a2033e 100644 > --- a/xen/arch/x86/hvm/dm.c > +++ b/xen/arch/x86/hvm/dm.c > @@ -640,6 +640,42 @@ static int dm_op(const struct dmop_args *op_args) > break; > } > > + case XEN_DMOP_add_to_physmap: > + { > + struct xen_dm_op_add_to_physmap *data = > + &op.u.add_to_physmap; > + struct xen_add_to_physmap xatp = { > + .domid = op_args->domid, > + .size = data->size, > + .space = XENMAPSPACE_gmfn_range, > + .idx = data->src_gfn, > + .gpfn = data->dst_gfn, > + }; > + > + if ( data->pad ) > + { > + rc = -EINVAL; > + break; > + } > + > + if ( xatp.size != data->size ) > + { > + rc = -EOVERFLOW; > + break; > + } > + > + rc = xenmem_add_to_physmap(d, &xatp, 0); > + if ( rc > 0 ) > + { > + data->size -= rc; > + data->src_gfn += rc; > + data->dst_gfn += rc; > + const_op = false; > + rc = -ERESTART; > + } > + break; > + } > + > default: > rc = -EOPNOTSUPP; > break; > @@ -669,6 +705,7 @@ CHECK_dm_op_set_mem_type; > CHECK_dm_op_inject_event; > CHECK_dm_op_inject_msi; > CHECK_dm_op_remote_shutdown; > +CHECK_dm_op_add_to_physmap; > > int compat_dm_op(domid_t domid, > unsigned int nr_bufs, > diff --git a/xen/include/public/hvm/dm_op.h > b/xen/include/public/hvm/dm_op.h > index e173085..0d7e22f 100644 > --- a/xen/include/public/hvm/dm_op.h > +++ b/xen/include/public/hvm/dm_op.h > @@ -368,6 +368,24 @@ struct xen_dm_op_remote_shutdown { > /* (Other reason values are not blocked) */ > }; > > +/* > + * XEN_DMOP_add_to_physmap : Sets the GFNs at which a page range > appears in > + * the specified guest's address space. Identical > to > + * XENMEM_add_to_physmap with > + * space == XENMAPSPACE_gmfn_range. > + */ > +#define XEN_DMOP_add_to_physmap 17 > + > +struct xen_dm_op_add_to_physmap { > + /* Number of GFNs to process. */ > + uint32_t size; > + uint32_t pad; > + /* Starting GFN of the source mapping page(s). */ > + uint64_aligned_t src_gfn; > + /* Starting GFN where the source mapping page(s) should appear. */ > + uint64_aligned_t dst_gfn; > +}; > + > struct xen_dm_op { > uint32_t op; > uint32_t pad; > @@ -389,6 +407,7 @@ struct xen_dm_op { > struct xen_dm_op_map_mem_type_to_ioreq_server > map_mem_type_to_ioreq_server; > struct xen_dm_op_remote_shutdown remote_shutdown; > + struct xen_dm_op_add_to_physmap add_to_physmap; > } u; > }; > > diff --git a/xen/include/xlat.lst b/xen/include/xlat.lst > index 4346cbe..d40bac6 100644 > --- a/xen/include/xlat.lst > +++ b/xen/include/xlat.lst > @@ -57,6 +57,7 @@ > ? grant_entry_v2 grant_table.h > ? gnttab_swap_grant_ref grant_table.h > ! dm_op_buf hvm/dm_op.h > +? dm_op_add_to_physmap hvm/dm_op.h > ? dm_op_create_ioreq_server hvm/dm_op.h > ? dm_op_destroy_ioreq_server hvm/dm_op.h > ? dm_op_get_ioreq_server_info hvm/dm_op.h > -- > 2.9.5 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |