diff options
Diffstat (limited to 'common/recipes-kernel/linux/files/0909-drm-amdgpu-handle-error-case-for-ctx.patch')
-rw-r--r-- | common/recipes-kernel/linux/files/0909-drm-amdgpu-handle-error-case-for-ctx.patch | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/common/recipes-kernel/linux/files/0909-drm-amdgpu-handle-error-case-for-ctx.patch b/common/recipes-kernel/linux/files/0909-drm-amdgpu-handle-error-case-for-ctx.patch new file mode 100644 index 00000000..dcfa3fbe --- /dev/null +++ b/common/recipes-kernel/linux/files/0909-drm-amdgpu-handle-error-case-for-ctx.patch @@ -0,0 +1,44 @@ +From c8c52827acb7bc6bfa9bfc3861b7f08d570f7ed3 Mon Sep 17 00:00:00 2001 +From: Chunming Zhou <David1.Zhou@amd.com> +Date: Thu, 10 Dec 2015 15:50:02 +0800 +Subject: [PATCH 0909/1050] drm/amdgpu: handle error case for ctx +MIME-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit + +Change-Id: I3f3e972ad841888f8d6148033211e7a0369e6ca5 +Signed-off-by: Chunming Zhou <David1.Zhou@amd.com> +Reviewed-by: Christian König <christian.koenig@amd.com> +--- + drivers/gpu/drm/amd/amdgpu/amdgpu_ctx.c | 7 +++++-- + 1 file changed, 5 insertions(+), 2 deletions(-) + +diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ctx.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ctx.c +index c1f2308..15e3416 100644 +--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ctx.c ++++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ctx.c +@@ -56,7 +56,6 @@ int amdgpu_ctx_init(struct amdgpu_device *adev, enum amd_sched_priority pri, + for (j = 0; j < i; j++) + amd_sched_entity_fini(&adev->rings[j]->sched, + &ctx->rings[j].entity); +- kfree(ctx); + return r; + } + } +@@ -103,8 +102,12 @@ static int amdgpu_ctx_alloc(struct amdgpu_device *adev, + } + *id = (uint32_t)r; + r = amdgpu_ctx_init(adev, AMD_SCHED_PRIORITY_NORMAL, ctx); ++ if (r) { ++ idr_remove(&mgr->ctx_handles, *id); ++ *id = 0; ++ kfree(ctx); ++ } + mutex_unlock(&mgr->lock); +- + return r; + } + +-- +1.9.1 + |