diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/vce_v3_0.c')
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/vce_v3_0.c | 37 |
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 | ||
801 | static void vce_v3_0_set_ring_funcs(struct amdgpu_device *adev) | 798 | static 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 | ||
807 | static const struct amdgpu_irq_src_funcs vce_v3_0_irq_funcs = { | 806 | static const struct amdgpu_irq_src_funcs vce_v3_0_irq_funcs = { |