[AMD Official Use Only] 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. -----Original Message----- From: VURDIGERENATARAJ, CHANDAN <chandan.vurdigerenata...@amd.com> Sent: Wednesday, March 30, 2022 12:30 PM To: Lin, Tsung-hua (Ryan) <tsung-hua....@amd.com> Cc: David (ChunMing) Zhou <david1.z...@amd.com>; Drew Davenport <ddavenp...@chromium.org>; Li, Sun peng (Leo) <sunpeng...@amd.com>; Li, Leon <leon...@amd.com>; dri-devel@lists.freedesktop.org; Siqueira, Rodrigo <rodrigo.sique...@amd.com>; linux-ker...@vger.kernel.org; amd-...@lists.freedesktop.org; Koenig, Christian <christian.koe...@amd.com>; David Airlie <airl...@linux.ie>; Sean Paul <seanp...@chromium.org>; Louis Li <ching-shih...@amd.corp-partner.google.com>; Daniel Vetter <dan...@ffwll.ch>; Bas Nieuwenhuizen <b...@basnieuwenhuizen.nl>; Deucher, Alexander <alexander.deuc...@amd.com>; Stéphane Marchesin <marc...@chromium.org>; Kazlauskas, Nicholas <nicholas.kazlaus...@amd.com>; Wentland, Harry <harry.wentl...@amd.com>; Lin, Tsung-hua (Ryan) <tsung-hua....@amd.com>; Mark Yacoub <markyac...@google.com> Subject: RE: [PATCH v2] drm/amdgpu: fix that issue that the number of the crtc of the 3250c is not correct 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....@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