Commit d1a6bfff authored by Ma Jun's avatar Ma Jun Committed by Alex Deucher

drm/amdgpu: Fix null pointer dereference to bo

Check bo before using it
Signed-off-by: default avatarMa Jun <Jun.Ma2@amd.com>
Reviewed-by: default avatarChristian König <christian.koenig@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent ff422eb7
...@@ -497,9 +497,8 @@ static void gmc_v12_0_get_vm_pte(struct amdgpu_device *adev, ...@@ -497,9 +497,8 @@ static void gmc_v12_0_get_vm_pte(struct amdgpu_device *adev,
uint64_t *flags) uint64_t *flags)
{ {
struct amdgpu_bo *bo = mapping->bo_va->base.bo; struct amdgpu_bo *bo = mapping->bo_va->base.bo;
struct amdgpu_device *bo_adev = amdgpu_ttm_adev(bo->tbo.bdev); struct amdgpu_device *bo_adev;
bool coherent = bo->flags & AMDGPU_GEM_CREATE_COHERENT; bool coherent, is_system;
bool is_system = bo->tbo.resource->mem_type == TTM_PL_SYSTEM;
*flags &= ~AMDGPU_PTE_EXECUTABLE; *flags &= ~AMDGPU_PTE_EXECUTABLE;
...@@ -515,13 +514,20 @@ static void gmc_v12_0_get_vm_pte(struct amdgpu_device *adev, ...@@ -515,13 +514,20 @@ static void gmc_v12_0_get_vm_pte(struct amdgpu_device *adev,
*flags &= ~AMDGPU_PTE_VALID; *flags &= ~AMDGPU_PTE_VALID;
} }
if (bo && bo->flags & (AMDGPU_GEM_CREATE_COHERENT | if (!bo)
return;
if (bo->flags & (AMDGPU_GEM_CREATE_COHERENT |
AMDGPU_GEM_CREATE_UNCACHED)) AMDGPU_GEM_CREATE_UNCACHED))
*flags = (*flags & ~AMDGPU_PTE_MTYPE_GFX12_MASK) | *flags = (*flags & ~AMDGPU_PTE_MTYPE_GFX12_MASK) |
AMDGPU_PTE_MTYPE_GFX12(MTYPE_UC); AMDGPU_PTE_MTYPE_GFX12(MTYPE_UC);
bo_adev = amdgpu_ttm_adev(bo->tbo.bdev);
coherent = bo->flags & AMDGPU_GEM_CREATE_COHERENT;
is_system = bo->tbo.resource->mem_type == TTM_PL_SYSTEM;
/* WA for HW bug */ /* WA for HW bug */
if ((bo && is_system) || ((bo_adev != adev) && coherent)) if (is_system || ((bo_adev != adev) && coherent))
*flags |= AMDGPU_PTE_MTYPE_GFX12(MTYPE_NC); *flags |= AMDGPU_PTE_MTYPE_GFX12(MTYPE_NC);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment