summaryrefslogtreecommitdiff
path: root/include/linux/iova.h
diff options
context:
space:
mode:
authorRobin Murphy <robin.murphy@arm.com>2015-07-16 19:40:12 +0100
committerDavid Woodhouse <David.Woodhouse@intel.com>2015-07-28 15:47:56 +0100
commit8f6429c7cb59f28433253575cc8e3262eed63592 (patch)
treeb0ba92c894735701a01d289f92c42c221c6d3cf1 /include/linux/iova.h
parent52721d9d3334c1cb1f76219a161084094ec634dc (diff)
downloadlwn-8f6429c7cb59f28433253575cc8e3262eed63592.tar.gz
lwn-8f6429c7cb59f28433253575cc8e3262eed63592.zip
iommu/iova: Avoid over-allocating when size-aligned
Currently, allocating a size-aligned IOVA region quietly adjusts the actual allocation size in the process, returning a rounded-up power-of-two-sized allocation. This results in mismatched behaviour in the IOMMU driver if the original size was not a power of two, where the original size is mapped, but the rounded-up IOVA size is unmapped. Whilst some IOMMUs will happily unmap already-unmapped pages, others consider this an error, so fix it by computing the necessary alignment padding without altering the actual allocation size. Also clean up by making pad_size unsigned, since its callers always pass unsigned values and negative padding makes little sense here anyway. Signed-off-by: Robin Murphy <robin.murphy@arm.com> Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
Diffstat (limited to 'include/linux/iova.h')
0 files changed, 0 insertions, 0 deletions