aboutsummaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_ioc32.c
diff options
context:
space:
mode:
authorKeqian Zhu <[email protected]>2021-05-07 19:03:22 +0800
committerMarc Zyngier <[email protected]>2021-06-01 12:01:47 +0100
commit2aa53d68cee6603931f73b28ef6b51ff3fde9397 (patch)
tree662ec20e1c78f7695a0bddea24f1c07520887e91 /drivers/gpu/drm/amd/amdgpu/amdgpu_ioc32.c
parentfd6f17bade2147b31198ad00b22d3acf5a398aec (diff)
KVM: arm64: Try stage2 block mapping for host device MMIO
The MMIO region of a device maybe huge (GB level), try to use block mapping in stage2 to speedup both map and unmap. Compared to normal memory mapping, we should consider two more points when try block mapping for MMIO region: 1. For normal memory mapping, the PA(host physical address) and HVA have same alignment within PUD_SIZE or PMD_SIZE when we use the HVA to request hugepage, so we don't need to consider PA alignment when verifing block mapping. But for device memory mapping, the PA and HVA may have different alignment. 2. For normal memory mapping, we are sure hugepage size properly fit into vma, so we don't check whether the mapping size exceeds the boundary of vma. But for device memory mapping, we should pay attention to this. This adds get_vma_page_shift() to get page shift for both normal memory and device MMIO region, and check these two points when selecting block mapping size for MMIO region. Signed-off-by: Keqian Zhu <[email protected]> Signed-off-by: Marc Zyngier <[email protected]> Link: https://lore.kernel.org/r/[email protected]
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_ioc32.c')
0 files changed, 0 insertions, 0 deletions