summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_vce.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_vce.c')
-rw-r--r--drivers/gpu/drm/amd/amdgpu/amdgpu_vce.c21
1 files changed, 15 insertions, 6 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vce.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vce.c
index e933cb785..0a08cf930 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vce.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vce.c
@@ -41,15 +41,17 @@
/* Firmware Names */
#ifdef CONFIG_DRM_AMDGPU_CIK
#define FIRMWARE_BONAIRE "/*(DEBLOBBED)*/"
-#define FIRMWARE_KABINI "/*(DEBLOBBED)*/"
-#define FIRMWARE_KAVERI "/*(DEBLOBBED)*/"
-#define FIRMWARE_HAWAII "/*(DEBLOBBED)*/"
+#define FIRMWARE_KABINI "/*(DEBLOBBED)*/"
+#define FIRMWARE_KAVERI "/*(DEBLOBBED)*/"
+#define FIRMWARE_HAWAII "/*(DEBLOBBED)*/"
#define FIRMWARE_MULLINS "/*(DEBLOBBED)*/"
#endif
#define FIRMWARE_TONGA "/*(DEBLOBBED)*/"
#define FIRMWARE_CARRIZO "/*(DEBLOBBED)*/"
#define FIRMWARE_FIJI "/*(DEBLOBBED)*/"
#define FIRMWARE_STONEY "/*(DEBLOBBED)*/"
+#define FIRMWARE_POLARIS10 "/*(DEBLOBBED)*/"
+#define FIRMWARE_POLARIS11 "/*(DEBLOBBED)*/"
#ifdef CONFIG_DRM_AMDGPU_CIK
/*(DEBLOBBED)*/
@@ -106,6 +108,12 @@ int amdgpu_vce_sw_init(struct amdgpu_device *adev, unsigned long size)
case CHIP_STONEY:
fw_name = FIRMWARE_STONEY;
break;
+ case CHIP_POLARIS10:
+ fw_name = FIRMWARE_POLARIS10;
+ break;
+ case CHIP_POLARIS11:
+ fw_name = FIRMWARE_POLARIS11;
+ break;
default:
return -EINVAL;
@@ -419,7 +427,7 @@ int amdgpu_vce_get_create_msg(struct amdgpu_ring *ring, uint32_t handle,
for (i = ib->length_dw; i < ib_size_dw; ++i)
ib->ptr[i] = 0x0;
- r = amdgpu_ib_schedule(ring, 1, ib, NULL, &f);
+ r = amdgpu_ib_schedule(ring, 1, ib, NULL, NULL, &f);
job->fence = f;
if (r)
goto err;
@@ -481,7 +489,7 @@ int amdgpu_vce_get_destroy_msg(struct amdgpu_ring *ring, uint32_t handle,
ib->ptr[i] = 0x0;
if (direct) {
- r = amdgpu_ib_schedule(ring, 1, ib, NULL, &f);
+ r = amdgpu_ib_schedule(ring, 1, ib, NULL, NULL, &f);
job->fence = f;
if (r)
goto err;
@@ -745,7 +753,8 @@ out:
* @ib: the IB to execute
*
*/
-void amdgpu_vce_ring_emit_ib(struct amdgpu_ring *ring, struct amdgpu_ib *ib)
+void amdgpu_vce_ring_emit_ib(struct amdgpu_ring *ring, struct amdgpu_ib *ib,
+ unsigned vm_id, bool ctx_switch)
{
amdgpu_ring_write(ring, VCE_CMD_IB);
amdgpu_ring_write(ring, lower_32_bits(ib->gpu_addr));