xen/biomerge: Don't allow biovec's to be merged when Linux is not using 4KB pages
authorJulien Grall <julien.grall@citrix.com>
Mon, 11 May 2015 12:44:21 +0000 (13:44 +0100)
committerDavid Vrabel <david.vrabel@citrix.com>
Fri, 23 Oct 2015 13:20:36 +0000 (14:20 +0100)
commit36f8abd36febf1c6f67dae26ec7a87be44629138
tree50f578064856cd9ee400e57f8704c42af5c50044
parent4f503fbdf319e4411aa48852b8922c93a9cc0c5d
xen/biomerge: Don't allow biovec's to be merged when Linux is not using 4KB pages

On ARM all dma-capable devices on a same platform may not be protected
by an IOMMU. The DMA requests have to use the BFN (i.e MFN on ARM) in
order to use correctly the device.

While the DOM0 memory is allocated in a 1:1 fashion (PFN == MFN), grant
mapping will screw this contiguous mapping.

When Linux is using 64KB page granularitary, the page may be split
accross multiple non-contiguous MFN (Xen is using 4KB page
granularity). Therefore a DMA request will likely fail.

Checking that a 64KB page is using contiguous MFN is tedious. For
now, always says that biovec are not mergeable.

Signed-off-by: Julien Grall <julien.grall@citrix.com>
Reviewed-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
drivers/xen/biomerge.c