summaryrefslogtreecommitdiffstats
path: root/lib/find_bit.c
diff options
context:
space:
mode:
authorWill Deacon <will@kernel.org>2024-03-08 15:28:27 +0000
committerChristoph Hellwig <hch@lst.de>2024-03-13 11:39:27 -0700
commit51b30ecb73b481d5fac6ccf2ecb4a309c9ee3310 (patch)
tree3c327ed3c45e260a8012c83117cebca0a4757ef1 /lib/find_bit.c
parentcbf53074a528191df82b4dba1e3d21191102255e (diff)
downloadlinux-stable-51b30ecb73b481d5fac6ccf2ecb4a309c9ee3310.tar.gz
linux-stable-51b30ecb73b481d5fac6ccf2ecb4a309c9ee3310.tar.bz2
linux-stable-51b30ecb73b481d5fac6ccf2ecb4a309c9ee3310.zip
swiotlb: Fix alignment checks when both allocation and DMA masks are present
Nicolin reports that swiotlb buffer allocations fail for an NVME device behind an IOMMU using 64KiB pages. This is because we end up with a minimum allocation alignment of 64KiB (for the IOMMU to map the buffer safely) but a minimum DMA alignment mask corresponding to a 4KiB NVME page (i.e. preserving the 4KiB page offset from the original allocation). If the original address is not 4KiB-aligned, the allocation will fail because swiotlb_search_pool_area() erroneously compares these unmasked bits with the 64KiB-aligned candidate allocation. Tweak swiotlb_search_pool_area() so that the DMA alignment mask is reduced based on the required alignment of the allocation. Fixes: 82612d66d51d ("iommu: Allow the dma-iommu api to use bounce buffers") Link: https://lore.kernel.org/r/cover.1707851466.git.nicolinc@nvidia.com Reported-by: Nicolin Chen <nicolinc@nvidia.com> Signed-off-by: Will Deacon <will@kernel.org> Reviewed-by: Michael Kelley <mhklinux@outlook.com> Tested-by: Nicolin Chen <nicolinc@nvidia.com> Tested-by: Michael Kelley <mhklinux@outlook.com> Signed-off-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'lib/find_bit.c')
0 files changed, 0 insertions, 0 deletions