mirror of
https://github.com/torvalds/linux.git
synced 2026-05-12 16:18:45 +02:00
io_uring/zcrx: use dma_len for chunk size calculation
Buffers are now dma-mapped earlier and we can sg_dma_len(), otherwise,
since it's walking with for_each_sgtable_dma_sg(), it might wrongfully
reject some configurations. As a bonus, it'd now be able to use larger
chunks if dma addresses are coalesced e.g by iommu.
Fixes: 8c0cab0b7bf7 ("io_uring/zcrx: always dma map in advance")
Signed-off-by: Pavel Begunkov <asml.silence@gmail.com>
Link: https://patch.msgid.link/03b219af3f6cfdd1cf64679b8bab7461e47cc123.1774780198.git.asml.silence@gmail.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
52dcd1776b
commit
7120b87bed
|
|
@ -63,7 +63,7 @@ static int io_area_max_shift(struct io_zcrx_mem *mem)
|
|||
unsigned i;
|
||||
|
||||
for_each_sgtable_dma_sg(sgt, sg, i)
|
||||
shift = min(shift, __ffs(sg->length));
|
||||
shift = min(shift, __ffs(sg_dma_len(sg)));
|
||||
return shift;
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user