Skip to content

Commit 12f3b92

Browse files
melissawenalexdeucher
authored andcommitted
drm/amd/display: restore edid reading from a given i2c adapter
When switching to drm_edid, we slightly changed how to get edid by removing the possibility of getting them from dc_link when in aux transaction mode. As MST doesn't initialize the connector with `drm_connector_init_with_ddc()`, restore the original behavior to avoid functional changes. v2: - Fix build warning of unchecked dereference (kernel test bot) CC: Alex Hung <[email protected]> CC: Mario Limonciello <[email protected]> CC: Roman Li <[email protected]> CC: Aurabindo Pillai <[email protected]> Fixes: 48edb2a ("drm/amd/display: switch amdgpu_dm_connector to use struct drm_edid") Reviewed-by: Alex Hung <[email protected]> Signed-off-by: Melissa Wen <[email protected]> Signed-off-by: Alex Deucher <[email protected]> (cherry picked from commit 81262b1)
1 parent 96989f3 commit 12f3b92

File tree

1 file changed

+15
-2
lines changed

1 file changed

+15
-2
lines changed

drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c

Lines changed: 15 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -7240,8 +7240,14 @@ static void amdgpu_dm_connector_funcs_force(struct drm_connector *connector)
72407240
struct dc_link *dc_link = aconnector->dc_link;
72417241
struct dc_sink *dc_em_sink = aconnector->dc_em_sink;
72427242
const struct drm_edid *drm_edid;
7243+
struct i2c_adapter *ddc;
72437244

7244-
drm_edid = drm_edid_read(connector);
7245+
if (dc_link && dc_link->aux_mode)
7246+
ddc = &aconnector->dm_dp_aux.aux.ddc;
7247+
else
7248+
ddc = &aconnector->i2c->base;
7249+
7250+
drm_edid = drm_edid_read_ddc(connector, ddc);
72457251
drm_edid_connector_update(connector, drm_edid);
72467252
if (!drm_edid) {
72477253
DRM_ERROR("No EDID found on connector: %s.\n", connector->name);
@@ -7286,14 +7292,21 @@ static int get_modes(struct drm_connector *connector)
72867292
static void create_eml_sink(struct amdgpu_dm_connector *aconnector)
72877293
{
72887294
struct drm_connector *connector = &aconnector->base;
7295+
struct dc_link *dc_link = aconnector->dc_link;
72897296
struct dc_sink_init_data init_params = {
72907297
.link = aconnector->dc_link,
72917298
.sink_signal = SIGNAL_TYPE_VIRTUAL
72927299
};
72937300
const struct drm_edid *drm_edid;
72947301
const struct edid *edid;
7302+
struct i2c_adapter *ddc;
7303+
7304+
if (dc_link && dc_link->aux_mode)
7305+
ddc = &aconnector->dm_dp_aux.aux.ddc;
7306+
else
7307+
ddc = &aconnector->i2c->base;
72957308

7296-
drm_edid = drm_edid_read(connector);
7309+
drm_edid = drm_edid_read_ddc(connector, ddc);
72977310
drm_edid_connector_update(connector, drm_edid);
72987311
if (!drm_edid) {
72997312
DRM_ERROR("No EDID found on connector: %s.\n", connector->name);

0 commit comments

Comments
 (0)