diff options
author | Alex Waterman <alexw@nvidia.com> | 2017-08-16 18:53:55 -0400 |
---|---|---|
committer | mobile promotions <svcmobile_promotions@nvidia.com> | 2017-10-04 05:19:08 -0400 |
commit | 2559fa295d0c478466e47496174fa2108ab01c33 (patch) | |
tree | 94d1c9f12edb985b984e8599653c38a836be2adb /drivers/gpu/nvgpu/gk20a | |
parent | 84f2356b13fdad636c33d1d2908ff2e977a09bf0 (diff) |
gpu: nvgpu: Add common vaddr translate function
Add a function to do address translation for IOMMU capable GPUs.
When an iGPU is behind and IOMMU it can pick whether to use that
IOMMU for translation by adding a bit to physical addresses. This
function takes care of that.
However, this required an abstracted nvgpu_iommuable() API to
check whether a GPU is behind an IOMMU. This patch adds that API
for Linux.
JIRA NVGPU-68
Change-Id: I489d14475167c019c294407372395df78c8b5feb
Signed-off-by: Alex Waterman <alexw@nvidia.com>
Reviewed-on: https://git-master.nvidia.com/r/1542965
Reviewed-by: Automatic_Commit_Validation_User
Reviewed-by: svc-mobile-coverity <svc-mobile-coverity@nvidia.com>
Reviewed-by: svccoveritychecker <svccoveritychecker@nvidia.com>
GVS: Gerrit_Virtual_Submit
Reviewed-by: Sourab Gupta <sourabg@nvidia.com>
Reviewed-by: Konsta Holtta <kholtta@nvidia.com>
Reviewed-by: Vijayakumar Subbu <vsubbu@nvidia.com>
Diffstat (limited to 'drivers/gpu/nvgpu/gk20a')
-rw-r--r-- | drivers/gpu/nvgpu/gk20a/mm_gk20a.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/drivers/gpu/nvgpu/gk20a/mm_gk20a.c b/drivers/gpu/nvgpu/gk20a/mm_gk20a.c index dc1e9688..3d1f8d28 100644 --- a/drivers/gpu/nvgpu/gk20a/mm_gk20a.c +++ b/drivers/gpu/nvgpu/gk20a/mm_gk20a.c | |||
@@ -1276,8 +1276,7 @@ u64 gk20a_mm_smmu_vaddr_translate(struct gk20a *g, u64 iova) | |||
1276 | /* ensure it is not vidmem allocation */ | 1276 | /* ensure it is not vidmem allocation */ |
1277 | WARN_ON(is_vidmem_page_alloc(iova)); | 1277 | WARN_ON(is_vidmem_page_alloc(iova)); |
1278 | 1278 | ||
1279 | if (device_is_iommuable(dev_from_gk20a(g)) && | 1279 | if (nvgpu_iommuable(g) && g->ops.mm.get_physical_addr_bits) |
1280 | g->ops.mm.get_physical_addr_bits) | ||
1281 | return iova | 1ULL << g->ops.mm.get_physical_addr_bits(g); | 1280 | return iova | 1ULL << g->ops.mm.get_physical_addr_bits(g); |
1282 | 1281 | ||
1283 | return iova; | 1282 | return iova; |