diff options
| author | Luca Ceresoli <[email protected]> | 2025-05-09 13:53:47 +0000 |
|---|---|---|
| committer | Luca Ceresoli <[email protected]> | 2025-05-21 11:40:09 +0000 |
| commit | 6ad88bf9e74dae83c992d8a16683360117b7e2d8 (patch) | |
| tree | 9541f48a64903ad8d99c4e5cd71d9e67abb98baa /drivers/gpu/drm/meson/meson_encoder_cvbs.c | |
| parent | drm/bridge: add devm_drm_put_bridge() (diff) | |
| download | kernel-6ad88bf9e74dae83c992d8a16683360117b7e2d8.tar.gz kernel-6ad88bf9e74dae83c992d8a16683360117b7e2d8.zip | |
drm/bridge: panel: convert to devm_drm_bridge_alloc() API
This is the new API for allocating DRM bridges.
The devm lifetime management of this driver is peculiar. The underlying
device for the panel_bridge is the panel, and the devm lifetime is tied the
panel device (panel->dev). However the panel_bridge allocation is not
performed by the panel driver, but rather by a separate entity (typically
the previous bridge in the encoder chain).
Thus when that separate entity is destroyed, the panel_bridge is not
removed automatically by devm, so it is rather done explicitly by calling
drm_panel_bridge_remove(). This is the function that does devm_kfree() the
panel_bridge in current code, so update it as well to put the bridge
reference instead.
This is a temporary solution until the panel lifetime is reworked, which
should make this workaround unnecessary, so add a comment to clarify that.
Acked-by: Maxime Ripard <[email protected]>
Link: https://lore.kernel.org/r/20250509-drm-bridge-convert-to-alloc-api-v3-21-b8bc1f16d7aa@bootlin.com
Signed-off-by: Luca Ceresoli <[email protected]>
Diffstat (limited to 'drivers/gpu/drm/meson/meson_encoder_cvbs.c')
0 files changed, 0 insertions, 0 deletions
