mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-04-14 16:26:38 -04:00
drm/amdgpu: add db size and offset range for VCN and VPE
VCN and VPE have different offset range, update the doorbell offset range repsectively. Doorbell size for VCN and VPE is 32bit. v1 : add gfx switch case and fix checkpatch warnings (Shashank) Signed-off-by: Saleemkhan Jamadar <saleemkhan.jamadar@amd.com> Reviewed-by: Shashank Sharma <shashank.sharma@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
committed by
Alex Deucher
parent
3e37fcb57b
commit
49cd3353db
@@ -221,7 +221,29 @@ amdgpu_userqueue_get_doorbell_index(struct amdgpu_userq_mgr *uq_mgr,
|
||||
goto unpin_bo;
|
||||
}
|
||||
|
||||
db_size = sizeof(u64);
|
||||
switch (db_info->queue_type) {
|
||||
case AMDGPU_HW_IP_GFX:
|
||||
case AMDGPU_HW_IP_COMPUTE:
|
||||
case AMDGPU_HW_IP_DMA:
|
||||
db_size = sizeof(u64);
|
||||
break;
|
||||
|
||||
case AMDGPU_HW_IP_VCN_ENC:
|
||||
db_size = sizeof(u32);
|
||||
db_info->doorbell_offset += AMDGPU_NAVI10_DOORBELL64_VCN0_1 << 1;
|
||||
break;
|
||||
|
||||
case AMDGPU_HW_IP_VPE:
|
||||
db_size = sizeof(u32);
|
||||
db_info->doorbell_offset += AMDGPU_NAVI10_DOORBELL64_VPE << 1;
|
||||
break;
|
||||
|
||||
default:
|
||||
DRM_ERROR("[Usermode queues] IP %d not support\n", db_info->queue_type);
|
||||
r = -EINVAL;
|
||||
goto unpin_bo;
|
||||
}
|
||||
|
||||
index = amdgpu_doorbell_index_on_bar(uq_mgr->adev, db_obj->obj,
|
||||
db_info->doorbell_offset, db_size);
|
||||
DRM_DEBUG_DRIVER("[Usermode queues] doorbell index=%lld\n", index);
|
||||
|
||||
Reference in New Issue
Block a user