summaryrefslogtreecommitdiffstats
path: root/include/rdma
diff options
context:
space:
mode:
authorJason Gunthorpe <jgg@nvidia.com>2020-09-05 00:41:43 +0200
committerJason Gunthorpe <jgg@nvidia.com>2020-09-09 20:33:17 +0200
commit10c75ccb54e4fe548cb16d7ed426d7d709e6ae76 (patch)
tree042542dadee49a4ebe9ec7e96ebadbd57bfb83ad /include/rdma
parentRDMA/umem: Fix ib_umem_find_best_pgsz() for mappings that cross a page boundary (diff)
downloadlinux-10c75ccb54e4fe548cb16d7ed426d7d709e6ae76.tar.xz
linux-10c75ccb54e4fe548cb16d7ed426d7d709e6ae76.zip
RDMA/umem: Prevent small pages from being returned by ib_umem_find_best_pgsz()
rdma_for_each_block() makes assumptions about how the SGL is constructed that don't work if the block size is below the page size used to to build the SGL. The rules for umem SGL construction require that the SG's all be PAGE_SIZE aligned and we don't encode the actual byte offset of the VA range inside the SGL using offset and length. So rdma_for_each_block() has no idea where the actual starting/ending point is to compute the first/last block boundary if the starting address should be within a SGL. Fixing the SGL construction turns out to be really hard, and will be the subject of other patches. For now block smaller pages. Fixes: 4a35339958f1 ("RDMA/umem: Add API to find best driver supported page size in an MR") Link: https://lore.kernel.org/r/2-v2-270386b7e60b+28f4-umem_1_jgg@nvidia.com Reviewed-by: Leon Romanovsky <leonro@nvidia.com> Reviewed-by: Shiraz Saleem <shiraz.saleem@intel.com> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Diffstat (limited to 'include/rdma')
0 files changed, 0 insertions, 0 deletions