dri-devel Archive on lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 00/13] drm/amd/display: more drm_edid to AMD display driver
@ 2025-04-11 20:08 Melissa Wen
  2025-04-11 20:08 ` [PATCH 01/13] drm/amd/display: make sure drm_edid stored in aconnector doesn't leak Melissa Wen
                   ` (12 more replies)
  0 siblings, 13 replies; 24+ messages in thread
From: Melissa Wen @ 2025-04-11 20:08 UTC (permalink / raw)
  To: Alex Hung, Mario Limonciello, Rodrigo Siqueira, airlied,
	alexander.deucher, christian.koenig, harry.wentland,
	maarten.lankhorst, mripard, mwen, simona, sunpeng.li, tzimmermann
  Cc: Jani Nikula, amd-gfx, dri-devel, kernel-dev

Hi,

Siqueira and I worked on a solution to reduce the usage of drm_edid_raw
in the AMD display driver, since the current guideline in the DRM
subsystem is to stop handling raw edid data in driver-specific
implementation and use opaque `drm_edid` object with common-code
helpers.

In short, this series approaches the issue of maintaining DC as an
OS-agnostic component by creating a mid layer to isolate `drm_edid`
helpers that need to be called in the DC code, while allowing other OSes
to implement their specific implementation. This is an extension of [1].

- Patch 1 addresses a possible leak added by previous migration to
  drm_edid.
- Patches 2-6 use common-code, drm_edid helpers to parse edid
  capabilities instead of driver-specific solutions.
- Patches 7-8 are groundwork to reduce the noise of Linux/DRM specific
  code in the DC shared code
- Patch 9 creates a mid layer to make DC embraces different ways of
  handling EDID by platforms.
- Patch 10-11 move open-coded management of raw EDID data to the mid
  layer created before.
- Patch 12 adds drm_edid to dc_sink struct and a mid-layer helper to
  free `drm_edid`.
- Patch 13 switch dc_edid to drm_edid across the driver in a way that
  the DC shared code is little affected by Linux specific stuff.

There are three specific points where we still use drm_edid_raw() in the
driver:
1. raw edid data for write EDID checksum in DP_TEST_EDID_CHECKSUM via
   drm_dp_dpcd_write(), that AFAIK there is no common code solution yet;
2. open-coded connectivity log for dc link detection, that maybe can be
   moved to drm (?);
3. open-coded parser that I suspect is a lot of duplicated code, but
   needs careful examining.

I suggest to address those points in a next phase for regression control.

[1] https://lore.kernel.org/amd-gfx/20250308142650.35920-1-mwen@igalia.com/

Let me know yours thoughts!

Melissa

Melissa Wen (11):
  drm/amd/display: make sure drm_edid stored in aconnector doesn't leak
  drm/amd/display: use drm_edid_product_id for parsing EDID product info
  drm/amd/display: parse display name from drm_eld
  drm/amd/display: get panel id with drm_edid helper
  drm/amd/display: get SAD from drm_eld when parsing EDID caps
  drm/amd/display: get SADB from drm_eld when parsing EDID caps
  drm/amd/display: simplify dm_helpers_parse_edid_caps signature
  drm/amd/display: change DC functions to accept private types for edid
  drm/edid: introduce a helper that compares edid data from two drm_edid
  drm/amd/display: add drm_edid to dc_sink
  drm/amd/display: move dc_sink from dc_edid to drm_edid

Rodrigo Siqueira (2):
  drm/amd/display: add a mid-layer file to handle EDID in DC
  drm/amd/display: create a function to fill dc_sink with edid data

 .../gpu/drm/amd/display/amdgpu_dm/Makefile    |   1 +
 .../gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c |  33 +++---
 .../amd/display/amdgpu_dm/amdgpu_dm_helpers.c | 104 ++++++++----------
 .../display/amdgpu_dm/amdgpu_dm_mst_types.c   |  21 ++--
 .../gpu/drm/amd/display/amdgpu_dm/dc_edid.c   |  34 ++++++
 .../gpu/drm/amd/display/amdgpu_dm/dc_edid.h   |  15 +++
 .../drm/amd/display/dc/core/dc_link_exports.c |   9 +-
 drivers/gpu/drm/amd/display/dc/core/dc_sink.c |   3 +
 drivers/gpu/drm/amd/display/dc/dc.h           |  12 +-
 drivers/gpu/drm/amd/display/dc/dm_helpers.h   |   7 +-
 drivers/gpu/drm/amd/display/dc/inc/link.h     |   9 +-
 .../drm/amd/display/dc/link/link_detection.c  |  30 ++---
 .../drm/amd/display/dc/link/link_detection.h  |   9 +-
 drivers/gpu/drm/drm_edid.c                    |  18 +++
 include/drm/drm_edid.h                        |   2 +
 15 files changed, 165 insertions(+), 142 deletions(-)
 create mode 100644 drivers/gpu/drm/amd/display/amdgpu_dm/dc_edid.c
 create mode 100644 drivers/gpu/drm/amd/display/amdgpu_dm/dc_edid.h

-- 
2.47.2


^ permalink raw reply	[flat|nested] 24+ messages in thread

end of thread, other threads:[~2025-04-17 13:57 UTC | newest]

Thread overview: 24+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-04-11 20:08 [PATCH 00/13] drm/amd/display: more drm_edid to AMD display driver Melissa Wen
2025-04-11 20:08 ` [PATCH 01/13] drm/amd/display: make sure drm_edid stored in aconnector doesn't leak Melissa Wen
2025-04-14 18:24   ` Mario Limonciello
2025-04-11 20:08 ` [PATCH 02/13] drm/amd/display: use drm_edid_product_id for parsing EDID product info Melissa Wen
2025-04-15  9:32   ` Michel Dänzer
2025-04-17 13:27     ` Melissa Wen
2025-04-17 13:57       ` Michel Dänzer
2025-04-11 20:08 ` [PATCH 03/13] drm/amd/display: parse display name from drm_eld Melissa Wen
2025-04-14 10:10   ` Jani Nikula
2025-04-17 13:46     ` Melissa Wen
2025-04-11 20:08 ` [PATCH 04/13] drm/amd/display: get panel id with drm_edid helper Melissa Wen
2025-04-11 20:08 ` [PATCH 05/13] drm/amd/display: get SAD from drm_eld when parsing EDID caps Melissa Wen
2025-04-11 20:08 ` [PATCH 06/13] drm/amd/display: get SADB " Melissa Wen
2025-04-11 20:08 ` [PATCH 07/13] drm/amd/display: simplify dm_helpers_parse_edid_caps signature Melissa Wen
2025-04-15 10:28   ` kernel test robot
2025-04-11 20:08 ` [PATCH 08/13] drm/amd/display: change DC functions to accept private types for edid Melissa Wen
2025-04-11 20:08 ` [PATCH 09/13] drm/amd/display: add a mid-layer file to handle EDID in DC Melissa Wen
2025-04-11 20:08 ` [PATCH 10/13] drm/amd/display: create a function to fill dc_sink with edid data Melissa Wen
2025-04-11 20:08 ` [PATCH 11/13] drm/edid: introduce a helper that compares edid data from two drm_edid Melissa Wen
2025-04-14 10:06   ` Jani Nikula
2025-04-17 13:44     ` Melissa Wen
2025-04-11 20:08 ` [PATCH 12/13] drm/amd/display: add drm_edid to dc_sink Melissa Wen
2025-04-11 20:08 ` [PATCH 13/13] drm/amd/display: move dc_sink from dc_edid to drm_edid Melissa Wen
2025-04-14 10:20   ` Jani Nikula

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox