[PATCH] drm/amdgpu: Mask out clear/wipe operation if buffer function is unavailable
Christian König
christian.koenig at amd.com
Mon Jun 16 08:23:46 UTC 2025
On 6/16/25 10:21, Lang Yu wrote:
> It makes no sense to use clear/wipe operation if buffer function is
> unavailable. It's useful in bring up phase when SDMA is not ready
> and/or disabled intentionally by amdgpu_ip_block_mask. This avoids
> manually masking out clear/wipe operation repeatedly.
Clear NAK. SDMA can be temporary unavailable during suspend/resume, but that doesn't mean that we can skip that.
Especially ignoring AMDGPU_GEM_CREATE_VRAM_CLEARED will just crash userspace.
Regards,
Christian.
>
> Signed-off-by: Lang Yu <lang.yu at amd.com>
> ---
> drivers/gpu/drm/amd/amdgpu/amdgpu_object.c | 4 ++++
> 1 file changed, 4 insertions(+)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> index 3ac52d9b9d30..467c8a1911bc 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c
> @@ -689,6 +689,10 @@ int amdgpu_bo_create(struct amdgpu_device *adev,
> if (!amdgpu_bo_support_uswc(bo->flags))
> bo->flags &= ~AMDGPU_GEM_CREATE_CPU_GTT_USWC;
>
> + if (!adev->mman.buffer_funcs_enabled)
> + bo->flags &= ~(AMDGPU_GEM_CREATE_VRAM_CLEARED |
> + AMDGPU_GEM_CREATE_VRAM_WIPE_ON_RELEASE);
> +
> bo->tbo.bdev = &adev->mman.bdev;
> if (bp->domain & (AMDGPU_GEM_DOMAIN_GWS | AMDGPU_GEM_DOMAIN_OA |
> AMDGPU_GEM_DOMAIN_GDS))
More information about the amd-gfx
mailing list