The 'sg->offset' denotes the offset into a page in bytes, but under drm subsystem, there has NO drivers that etnaviv can contact that actually touch the 'offset' data member of SG anymore. This means that all DMA addresses that sg_dma_address() gives us will be PAGE_SIZE aligned, in other words, sg->offset will always equal to 0. But if 'sg->offset != 0' really could happens, then the current implement might be not correct. Previous commits[1] fix the 'sg->offset == 0' cases effectively, below is a simple illustration. One CPU page Another one CPU page +----+----+----+----+ +----+----+----+----+ |||||| | |||||| | +----+----+----+----+ +----+----+----+----+ ^ ^ ^ ^ | | | | | | .----------------' | | | | .----------------' | | | | +----+ +----+ +----+ |||||| |||||| | | GPU pages, each one is SZ_4K +----+ +----+ +----+ Correct implementation. -------------------------------------------------------------- One CPU page Another one CPU page +----+----+----+----+ +----+----+----+----+ |///////////////////| |||||| | +----+----+----+----+ +----+----+----+----+ ^ ^ ^ ^ | | | | | .------------|---' | | | .-------|--------' | | | | | +----+ | | |||||| | | +----+ | | IOVA | GPUVA range collision if use 'sg_dma_len(sg)' +----+ +----+-------+ directly to map. Because 'sg_dma_len(sg)' is |////|/|////////////| frequently larger than SZ_4K. +----+ +----+-------+ Wrong implementation. If we map the address range with respect to the size of the backing memory, it will occupy GPUVA ranges that doesn't belong to. Which results in GPUVA range collision for different buffers. Patch 0001 of this series give a fix, patch 0002 and 0003 do trivial cleanup which eliminates unnecessary overheads. v2 -> v3 * Reword and improve commit message v1 -> v2 * Reword and fix typos and mistakes v1 Link: https://patchwork.freedesktop.org/series/140589/ Sui Jingfeng (3): drm/etnaviv: Drop the offset in page manipulation drm/etnaviv: Fix the debug log of the etnaviv_iommu_map() drm/etnaviv: Improve VA, PA, SIZE alignment checking drivers/gpu/drm/etnaviv/etnaviv_mmu.c | 26 +++++++++++--------------- 1 file changed, 11 insertions(+), 15 deletions(-) -- 2.34.1