Commit 037b98a2 authored by Alex Deucher's avatar Alex Deucher

drm/amdgpu: move UVD and VCE sched entity init after sched init

We need kernel scheduling entities to deal with handle clean up
if apps are not cleaned up properly.  With commit 56e44960
("drm/sched: Convert the GPU scheduler to variable number of run-queues")
the scheduler entities have to be created after scheduler init, so
change the ordering to fix this.

v2: Leave logic in UVD and VCE code

Fixes: 56e44960 ("drm/sched: Convert the GPU scheduler to variable number of run-queues")
Reviewed-by: default avatarChristian König <christian.koenig@amd.com>
Reviewed-by: default avatarLuben Tuikov <ltuikov89@gmail.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
Cc: ltuikov89@gmail.com
parent 8ed79c40
...@@ -2584,6 +2584,18 @@ static int amdgpu_device_init_schedulers(struct amdgpu_device *adev) ...@@ -2584,6 +2584,18 @@ static int amdgpu_device_init_schedulers(struct amdgpu_device *adev)
ring->name); ring->name);
return r; return r;
} }
r = amdgpu_uvd_entity_init(adev, ring);
if (r) {
DRM_ERROR("Failed to create UVD scheduling entity on ring %s.\n",
ring->name);
return r;
}
r = amdgpu_vce_entity_init(adev, ring);
if (r) {
DRM_ERROR("Failed to create VCE scheduling entity on ring %s.\n",
ring->name);
return r;
}
} }
amdgpu_xcp_update_partition_sched_list(adev); amdgpu_xcp_update_partition_sched_list(adev);
......
...@@ -399,20 +399,20 @@ int amdgpu_uvd_sw_fini(struct amdgpu_device *adev) ...@@ -399,20 +399,20 @@ int amdgpu_uvd_sw_fini(struct amdgpu_device *adev)
* *
* @adev: amdgpu_device pointer * @adev: amdgpu_device pointer
* *
* Initialize the entity used for handle management in the kernel driver.
*/ */
int amdgpu_uvd_entity_init(struct amdgpu_device *adev) int amdgpu_uvd_entity_init(struct amdgpu_device *adev, struct amdgpu_ring *ring)
{ {
struct amdgpu_ring *ring; if (ring == &adev->uvd.inst[0].ring) {
struct drm_gpu_scheduler *sched; struct drm_gpu_scheduler *sched = &ring->sched;
int r; int r;
ring = &adev->uvd.inst[0].ring; r = drm_sched_entity_init(&adev->uvd.entity, DRM_SCHED_PRIORITY_NORMAL,
sched = &ring->sched; &sched, 1, NULL);
r = drm_sched_entity_init(&adev->uvd.entity, DRM_SCHED_PRIORITY_NORMAL, if (r) {
&sched, 1, NULL); DRM_ERROR("Failed setting up UVD kernel entity.\n");
if (r) { return r;
DRM_ERROR("Failed setting up UVD kernel entity.\n"); }
return r;
} }
return 0; return 0;
......
...@@ -73,7 +73,7 @@ struct amdgpu_uvd { ...@@ -73,7 +73,7 @@ struct amdgpu_uvd {
int amdgpu_uvd_sw_init(struct amdgpu_device *adev); int amdgpu_uvd_sw_init(struct amdgpu_device *adev);
int amdgpu_uvd_sw_fini(struct amdgpu_device *adev); int amdgpu_uvd_sw_fini(struct amdgpu_device *adev);
int amdgpu_uvd_entity_init(struct amdgpu_device *adev); int amdgpu_uvd_entity_init(struct amdgpu_device *adev, struct amdgpu_ring *ring);
int amdgpu_uvd_prepare_suspend(struct amdgpu_device *adev); int amdgpu_uvd_prepare_suspend(struct amdgpu_device *adev);
int amdgpu_uvd_suspend(struct amdgpu_device *adev); int amdgpu_uvd_suspend(struct amdgpu_device *adev);
int amdgpu_uvd_resume(struct amdgpu_device *adev); int amdgpu_uvd_resume(struct amdgpu_device *adev);
......
...@@ -231,20 +231,20 @@ int amdgpu_vce_sw_fini(struct amdgpu_device *adev) ...@@ -231,20 +231,20 @@ int amdgpu_vce_sw_fini(struct amdgpu_device *adev)
* *
* @adev: amdgpu_device pointer * @adev: amdgpu_device pointer
* *
* Initialize the entity used for handle management in the kernel driver.
*/ */
int amdgpu_vce_entity_init(struct amdgpu_device *adev) int amdgpu_vce_entity_init(struct amdgpu_device *adev, struct amdgpu_ring *ring)
{ {
struct amdgpu_ring *ring; if (ring == &adev->vce.ring[0]) {
struct drm_gpu_scheduler *sched; struct drm_gpu_scheduler *sched = &ring->sched;
int r; int r;
ring = &adev->vce.ring[0]; r = drm_sched_entity_init(&adev->vce.entity, DRM_SCHED_PRIORITY_NORMAL,
sched = &ring->sched; &sched, 1, NULL);
r = drm_sched_entity_init(&adev->vce.entity, DRM_SCHED_PRIORITY_NORMAL, if (r != 0) {
&sched, 1, NULL); DRM_ERROR("Failed setting up VCE run queue.\n");
if (r != 0) { return r;
DRM_ERROR("Failed setting up VCE run queue.\n"); }
return r;
} }
return 0; return 0;
......
...@@ -55,7 +55,7 @@ struct amdgpu_vce { ...@@ -55,7 +55,7 @@ struct amdgpu_vce {
int amdgpu_vce_sw_init(struct amdgpu_device *adev, unsigned long size); int amdgpu_vce_sw_init(struct amdgpu_device *adev, unsigned long size);
int amdgpu_vce_sw_fini(struct amdgpu_device *adev); int amdgpu_vce_sw_fini(struct amdgpu_device *adev);
int amdgpu_vce_entity_init(struct amdgpu_device *adev); int amdgpu_vce_entity_init(struct amdgpu_device *adev, struct amdgpu_ring *ring);
int amdgpu_vce_suspend(struct amdgpu_device *adev); int amdgpu_vce_suspend(struct amdgpu_device *adev);
int amdgpu_vce_resume(struct amdgpu_device *adev); int amdgpu_vce_resume(struct amdgpu_device *adev);
void amdgpu_vce_free_handles(struct amdgpu_device *adev, struct drm_file *filp); void amdgpu_vce_free_handles(struct amdgpu_device *adev, struct drm_file *filp);
......
...@@ -577,8 +577,6 @@ static int uvd_v3_1_sw_init(void *handle) ...@@ -577,8 +577,6 @@ static int uvd_v3_1_sw_init(void *handle)
ptr += ucode_len; ptr += ucode_len;
memcpy(&adev->uvd.keyselect, ptr, 4); memcpy(&adev->uvd.keyselect, ptr, 4);
r = amdgpu_uvd_entity_init(adev);
return r; return r;
} }
......
...@@ -127,8 +127,6 @@ static int uvd_v4_2_sw_init(void *handle) ...@@ -127,8 +127,6 @@ static int uvd_v4_2_sw_init(void *handle)
if (r) if (r)
return r; return r;
r = amdgpu_uvd_entity_init(adev);
return r; return r;
} }
......
...@@ -125,8 +125,6 @@ static int uvd_v5_0_sw_init(void *handle) ...@@ -125,8 +125,6 @@ static int uvd_v5_0_sw_init(void *handle)
if (r) if (r)
return r; return r;
r = amdgpu_uvd_entity_init(adev);
return r; return r;
} }
......
...@@ -432,8 +432,6 @@ static int uvd_v6_0_sw_init(void *handle) ...@@ -432,8 +432,6 @@ static int uvd_v6_0_sw_init(void *handle)
} }
} }
r = amdgpu_uvd_entity_init(adev);
return r; return r;
} }
......
...@@ -480,10 +480,6 @@ static int uvd_v7_0_sw_init(void *handle) ...@@ -480,10 +480,6 @@ static int uvd_v7_0_sw_init(void *handle)
if (r) if (r)
return r; return r;
r = amdgpu_uvd_entity_init(adev);
if (r)
return r;
r = amdgpu_virt_alloc_mm_table(adev); r = amdgpu_virt_alloc_mm_table(adev);
if (r) if (r)
return r; return r;
......
...@@ -441,8 +441,6 @@ static int vce_v2_0_sw_init(void *handle) ...@@ -441,8 +441,6 @@ static int vce_v2_0_sw_init(void *handle)
return r; return r;
} }
r = amdgpu_vce_entity_init(adev);
return r; return r;
} }
......
...@@ -450,8 +450,6 @@ static int vce_v3_0_sw_init(void *handle) ...@@ -450,8 +450,6 @@ static int vce_v3_0_sw_init(void *handle)
return r; return r;
} }
r = amdgpu_vce_entity_init(adev);
return r; return r;
} }
......
...@@ -486,11 +486,6 @@ static int vce_v4_0_sw_init(void *handle) ...@@ -486,11 +486,6 @@ static int vce_v4_0_sw_init(void *handle)
return r; return r;
} }
r = amdgpu_vce_entity_init(adev);
if (r)
return r;
r = amdgpu_virt_alloc_mm_table(adev); r = amdgpu_virt_alloc_mm_table(adev);
if (r) if (r)
return r; return r;
......
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