[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH 2/3] gnttab: bypass IOMMU (un)mapping when a domain is (un)mapping its own grant
On 17.02.2021 12:41, Julien Grall wrote: > Hi Jan, > > On 17/02/2021 11:38, Jan Beulich wrote: >> On 17.02.2021 12:03, Julien Grall wrote: >>> On 17/02/2021 10:46, Jan Beulich wrote: >>>> Mappings for a domain's own pages should already be present in the >>>> IOMMU. While installing the same mapping again is merely redundant (and >>>> inefficient), removing the mapping when the grant mapping gets removed >>>> is outright wrong in this case: The mapping was there before the map, so >>>> should remain in place after unmapping. >>>> >>>> This affects >>>> - Arm Dom0 in the direct mapped case, >>>> - x86 PV Dom0 in the "iommu=dom0-strict" / "dom0-iommu=strict" cases, >>>> - all x86 PV DomU-s, including driver domains. >>>> >>>> Reported-by: Rahul Singh <Rahul.Singh@xxxxxxx> >>>> Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx> >>>> >>>> --- a/xen/common/grant_table.c >>>> +++ b/xen/common/grant_table.c >>>> @@ -1243,7 +1243,7 @@ map_grant_ref( >>>> goto undo_out; >>>> } >>>> >>>> - need_iommu = gnttab_need_iommu_mapping(ld); >>>> + need_iommu = ld != rd && gnttab_need_iommu_mapping(ld); >>> >>> AFAICT, the owner of the page may not always be rd. So do we want to >>> check against the owner instead? >> >> For the DomIO case - specifically not. And the DomCOW case can't >> happen when an IOMMU is in use. Did I overlook any other cases >> where the page may not be owned by rd? > > For the current code, it looks like not. But it feels to me this code is > fragile as we are assuming that other cases should never happen. > > I think it would be worth explaining in a comment and the commit message > why check rd rather than the page owner is sufficient. Well, I've added /* * This is deliberately not checking the page's owner: get_paged_frame() * explicitly rejects foreign pages, and all success paths above yield * either owner == rd or owner == dom_io (the dom_cow case is irrelevant * as mem-sharing and IOMMU use are incompatible). The dom_io case would * need checking separately if we compared against owner here. */ to map_grant_ref(), and a reference to this comment to both unmap_common() and the commit message. Will this do? Jan
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |