Commit 709ef39f authored by Lang Yu's avatar Lang Yu Committed by Alex Deucher

drm/amdgpu/vpe: add multi instance VPE support

Add support for multi instance VPE processing.
Signed-off-by: default avatarLang Yu <Lang.Yu@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 79698b14
...@@ -1320,6 +1320,15 @@ static int amdgpu_discovery_reg_base_init(struct amdgpu_device *adev) ...@@ -1320,6 +1320,15 @@ static int amdgpu_discovery_reg_base_init(struct amdgpu_device *adev)
} }
} }
if (le16_to_cpu(ip->hw_id) == VPE_HWID) {
if (adev->vpe.num_instances < AMDGPU_MAX_VPE_INSTANCES)
adev->vpe.num_instances++;
else
dev_err(adev->dev, "Too many VPE instances: %d vs %d\n",
adev->vpe.num_instances + 1,
AMDGPU_MAX_VPE_INSTANCES);
}
if (le16_to_cpu(ip->hw_id) == UMC_HWID) { if (le16_to_cpu(ip->hw_id) == UMC_HWID) {
adev->gmc.num_umc++; adev->gmc.num_umc++;
adev->umc.node_inst_num++; adev->umc.node_inst_num++;
......
...@@ -27,6 +27,8 @@ ...@@ -27,6 +27,8 @@
#include "amdgpu_irq.h" #include "amdgpu_irq.h"
#include "vpe_6_1_fw_if.h" #include "vpe_6_1_fw_if.h"
#define AMDGPU_MAX_VPE_INSTANCES 2
struct amdgpu_vpe; struct amdgpu_vpe;
struct vpe_funcs { struct vpe_funcs {
...@@ -74,6 +76,8 @@ struct amdgpu_vpe { ...@@ -74,6 +76,8 @@ struct amdgpu_vpe {
uint32_t *cmdbuf_cpu_addr; uint32_t *cmdbuf_cpu_addr;
struct delayed_work idle_work; struct delayed_work idle_work;
bool context_started; bool context_started;
uint32_t num_instances;
}; };
int amdgpu_vpe_psp_update_sram(struct amdgpu_device *adev); int amdgpu_vpe_psp_update_sram(struct amdgpu_device *adev);
......
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