[PATCH v2] drm/amdgpu: fix that issue that the number of the crtc of the 3250c is not correct
VURDIGERENATARAJ, CHANDAN
CHANDAN.VURDIGERENATARAJ at amd.com
Wed Mar 30 08:15:17 UTC 2022
>Hi Chandan,
>
>This issue we found on the Zork project which uses the kernel 5.4 on. So I just implemented it on kernel 5.4.
>For finding out which is 3250c, I referenced the function which is implemented from another function.
>Below is the part where I found it.
>
>drivers/gpu/drm/amd/amdgpu/amdgpu_device.c-
> case CHIP_RAVEN:
> if (adev->rev_id >= 8)
> chip_name = "raven2";
> else if (adev->pdev->device == 0x15d8)
> chip_name = "picasso";
> else
> chip_name = "raven";
> break;
>
>BR,
>Ryan Lin.
Suggest you to rebase to amd-staging-drm-next tip and update your changes accordingly and re-submit.
>
>Hi Ryan,
>
>Is this change applicable on a specific kernel version?
>On latest I see IP DISCOVERY based impl for CHIP_RAVEN.
>
>>[Why]
>>External displays take priority over internal display when there are fewer display controllers than displays.
>>
>> [How]
>>The root cause is because of that number of the crtc is not correct.
>>The number of the crtc on the 3250c is 3, but on the 3500c is 4.
>>On the source code, we can see that number of the crtc has been fixed at 4.
>>Needs to set the num_crtc to 3 for 3250c platform.
>>
>>v2:
>> - remove unnecessary comments and Id
>>
>>Signed-off-by: Ryan Lin <tsung-hua.lin at amd.com>
>>
>>---
>> drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 12 +++++++++---
>> 1 file changed, 9 insertions(+), 3 deletions(-)
>>
>>diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
>>index 40c91b448f7da..455a2c45e8cda 100644
>>--- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
>>+++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
>>@@ -2738,9 +2738,15 @@ static int dm_early_init(void *handle)
>> break;
>> #if defined(CONFIG_DRM_AMD_DC_DCN1_0)
>> case CHIP_RAVEN:
>>- adev->mode_info.num_crtc = 4;
>>- adev->mode_info.num_hpd = 4;
>>- adev->mode_info.num_dig = 4;
>>+ if (adev->rev_id >= 8) {
>
>May I know what this ">=8" indicate? Also, should it be external_rev_id if its based on old version?
>
>>+ adev->mode_info.num_crtc = 3;
>>+ adev->mode_info.num_hpd = 3;
>>+ adev->mode_info.num_dig = 3;
>>+ } else {
>>+ adev->mode_info.num_crtc = 4;
>>+ adev->mode_info.num_hpd = 4;
>>+ adev->mode_info.num_dig = 4;
>>+ }
>> break;
>> #endif
>> #if defined(CONFIG_DRM_AMD_DC_DCN2_0)
>>--
>>2.25.1
>>
>
>BR,
>Chandan V N
More information about the dri-devel
mailing list