aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/vce_v3_0.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/vce_v3_0.c')
-rw-r--r--drivers/gpu/drm/amd/amdgpu/vce_v3_0.c37
1 files changed, 18 insertions, 19 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/vce_v3_0.c b/drivers/gpu/drm/amd/amdgpu/vce_v3_0.c
index 615b8b16ad04..27acd2862d8a 100644
--- a/drivers/gpu/drm/amd/amdgpu/vce_v3_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/vce_v3_0.c
@@ -345,6 +345,8 @@ static int vce_v3_0_early_init(void *handle)
345 (AMDGPU_VCE_HARVEST_VCE0 | AMDGPU_VCE_HARVEST_VCE1)) 345 (AMDGPU_VCE_HARVEST_VCE0 | AMDGPU_VCE_HARVEST_VCE1))
346 return -ENOENT; 346 return -ENOENT;
347 347
348 adev->vce.num_rings = 2;
349
348 vce_v3_0_set_ring_funcs(adev); 350 vce_v3_0_set_ring_funcs(adev);
349 vce_v3_0_set_irq_funcs(adev); 351 vce_v3_0_set_irq_funcs(adev);
350 352
@@ -355,7 +357,7 @@ static int vce_v3_0_sw_init(void *handle)
355{ 357{
356 struct amdgpu_device *adev = (struct amdgpu_device *)handle; 358 struct amdgpu_device *adev = (struct amdgpu_device *)handle;
357 struct amdgpu_ring *ring; 359 struct amdgpu_ring *ring;
358 int r; 360 int r, i;
359 361
360 /* VCE */ 362 /* VCE */
361 r = amdgpu_irq_add_id(adev, 167, &adev->vce.irq); 363 r = amdgpu_irq_add_id(adev, 167, &adev->vce.irq);
@@ -371,19 +373,14 @@ static int vce_v3_0_sw_init(void *handle)
371 if (r) 373 if (r)
372 return r; 374 return r;
373 375
374 ring = &adev->vce.ring[0]; 376 for (i = 0; i < adev->vce.num_rings; i++) {
375 sprintf(ring->name, "vce0"); 377 ring = &adev->vce.ring[i];
376 r = amdgpu_ring_init(adev, ring, 512, VCE_CMD_NO_OP, 0xf, 378 sprintf(ring->name, "vce%d", i);
377 &adev->vce.irq, 0, AMDGPU_RING_TYPE_VCE); 379 r = amdgpu_ring_init(adev, ring, 512, VCE_CMD_NO_OP, 0xf,
378 if (r) 380 &adev->vce.irq, 0, AMDGPU_RING_TYPE_VCE);
379 return r; 381 if (r)
380 382 return r;
381 ring = &adev->vce.ring[1]; 383 }
382 sprintf(ring->name, "vce1");
383 r = amdgpu_ring_init(adev, ring, 512, VCE_CMD_NO_OP, 0xf,
384 &adev->vce.irq, 0, AMDGPU_RING_TYPE_VCE);
385 if (r)
386 return r;
387 384
388 return r; 385 return r;
389} 386}
@@ -413,10 +410,10 @@ static int vce_v3_0_hw_init(void *handle)
413 if (r) 410 if (r)
414 return r; 411 return r;
415 412
416 adev->vce.ring[0].ready = false; 413 for (i = 0; i < adev->vce.num_rings; i++)
417 adev->vce.ring[1].ready = false; 414 adev->vce.ring[i].ready = false;
418 415
419 for (i = 0; i < 2; i++) { 416 for (i = 0; i < adev->vce.num_rings; i++) {
420 r = amdgpu_ring_test_ring(&adev->vce.ring[i]); 417 r = amdgpu_ring_test_ring(&adev->vce.ring[i]);
421 if (r) 418 if (r)
422 return r; 419 return r;
@@ -800,8 +797,10 @@ static const struct amdgpu_ring_funcs vce_v3_0_ring_funcs = {
800 797
801static void vce_v3_0_set_ring_funcs(struct amdgpu_device *adev) 798static void vce_v3_0_set_ring_funcs(struct amdgpu_device *adev)
802{ 799{
803 adev->vce.ring[0].funcs = &vce_v3_0_ring_funcs; 800 int i;
804 adev->vce.ring[1].funcs = &vce_v3_0_ring_funcs; 801
802 for (i = 0; i < adev->vce.num_rings; i++)
803 adev->vce.ring[i].funcs = &vce_v3_0_ring_funcs;
805} 804}
806 805
807static const struct amdgpu_irq_src_funcs vce_v3_0_irq_funcs = { 806static const struct amdgpu_irq_src_funcs vce_v3_0_irq_funcs = {