lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <yudkovtipwtnofr3o2qwqrmriwxlczrwploieh5i4ke3sx5zhk@5ktlrew7o6k2>
Date: Sun, 9 Feb 2025 05:27:01 +0200
From: Dmitry Baryshkov <dmitry.baryshkov@...aro.org>
To: Maxime Ripard <mripard@...nel.org>
Cc: Maarten Lankhorst <maarten.lankhorst@...ux.intel.com>, 
	Thomas Zimmermann <tzimmermann@...e.de>, David Airlie <airlied@...il.com>, 
	Simona Vetter <simona@...ll.ch>, Andrzej Hajda <andrzej.hajda@...el.com>, 
	Neil Armstrong <neil.armstrong@...aro.org>, Robert Foss <rfoss@...nel.org>, 
	Laurent Pinchart <Laurent.pinchart@...asonboard.com>, Jonas Karlman <jonas@...boo.se>, 
	Jernej Skrabec <jernej.skrabec@...il.com>, Douglas Anderson <dianders@...omium.org>, 
	dri-devel@...ts.freedesktop.org, linux-kernel@...r.kernel.org, 
	Simona Vetter <simona.vetter@...ll.ch>
Subject: Re: [PATCH v2 00/35] drm/bridge: Various quality of life improvements

On Tue, Feb 04, 2025 at 03:57:28PM +0100, Maxime Ripard wrote:
> Hi,
> 
> Here's a series of changes after to the KMS helpers and bridge API
> following a bunch of reviews I did.
> 
> It's mostly centered across providing an easier time to deal with bridge
> states, and a somewhat consistent with the other entities API.
> 
> It's build tested only, with arm64 allmodconfig.
> 
> Maxime
> 
> Signed-off-by: Maxime Ripard <mripard@...nel.org>
> ---
> Changes in v2:
> - Pass the full atomic state to bridge atomic hooks
> - Make attach take the encoder as a parameter
> - Mark bridge->encoder as deprecated
> - Rework the logic to detect if a bridge uses a state or not at
>   atomic_check time
> - Add lockdep assertion to drm_bridge_get_current_state()
> - Link to v1: https://lore.kernel.org/r/20250115-bridge-connector-v1-0-9a2fecd886a6@kernel.org
> 
> ---
> Maxime Ripard (35):
>       drm/atomic: Document history of drm_atomic_state
>       drm/bridge: Pass full state to atomic_pre_enable
>       drm/bridge: Pass full state to atomic_enable
>       drm/bridge: Pass full state to atomic_disable
>       drm/bridge: Pass full state to atomic_post_disable
>       drm/atomic-helper: Fix commit_tail state variable name
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_wait_for_dependencies()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_commit_tail()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_commit_tail_rpm()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_modeset_disables()
>       drm/atomic-helper: Change parameter name of disable_outputs()
>       drm/bridge: Change parameter name of drm_atomic_bridge_chain_disable()
>       drm/bridge: Change parameter name of drm_atomic_bridge_chain_post_disable()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_update_legacy_modeset_state()
>       drm/atomic-helper: Change parameter name of crtc_set_mode()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_commit_planes()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_commit_modeset_enables()
>       drm/bridge: Change parameter name of drm_atomic_bridge_chain_pre_enable()
>       drm/bridge: Change parameter name of drm_atomic_bridge_chain_enable()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_commit_writebacks()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_fake_vblank()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_commit_hw_done()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_wait_for_vblanks()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_cleanup_planes()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_commit_cleanup_done()
>       drm/atomic-helper: Change parameter name of drm_atomic_helper_wait_for_flip_done()

I agree that use of the old_state can be confusing (and it has been
confusing to me for some time). The main question is, do we loose useful
memo 'this is the state after swap'. Most likely it is useless now, just
wanted to give it a second thought.

>       drm/bridge: Add encoder parameter to drm_bridge_funcs.attach
>       drm/bridge: Provide a helper to retrieve current bridge state
>       drm/bridge: Assume that a bridge is atomic if it has atomic_reset
>       drm/bridge: Provide pointers to the connector and crtc in bridge state
>       drm/bridge: Make encoder pointer deprecated
>       drm/bridge: cdns-csi: Switch to atomic helpers
>       drm/bridge: tc358775: Switch to atomic commit
>       drm/bridge: tc358768: Convert to atomic helpers
>       drm/bridge: ti-sn65dsi86: Use bridge_state crtc pointer
> 
>  drivers/gpu/drm/bridge/adv7511/adv7511_drv.c       |   3 +-
>  drivers/gpu/drm/bridge/analogix/analogix-anx6345.c |   3 +-
>  drivers/gpu/drm/bridge/analogix/analogix-anx78xx.c |   3 +-
>  drivers/gpu/drm/bridge/analogix/analogix_dp_core.c |  26 +--
>  drivers/gpu/drm/bridge/analogix/anx7625.c          |  11 +-
>  drivers/gpu/drm/bridge/aux-bridge.c                |   3 +-
>  drivers/gpu/drm/bridge/aux-hpd-bridge.c            |   1 +
>  drivers/gpu/drm/bridge/cadence/cdns-dsi-core.c     |  30 ++-
>  .../gpu/drm/bridge/cadence/cdns-mhdp8546-core.c    |   6 +-
>  drivers/gpu/drm/bridge/chipone-icn6211.c           |  13 +-
>  drivers/gpu/drm/bridge/chrontel-ch7033.c           |   5 +-
>  drivers/gpu/drm/bridge/display-connector.c         |   1 +
>  drivers/gpu/drm/bridge/fsl-ldb.c                   |   8 +-
>  drivers/gpu/drm/bridge/imx/imx-ldb-helper.c        |   7 +-
>  drivers/gpu/drm/bridge/imx/imx-ldb-helper.h        |   2 +-
>  drivers/gpu/drm/bridge/imx/imx-legacy-bridge.c     |   3 +-
>  drivers/gpu/drm/bridge/imx/imx8mp-hdmi-pvi.c       |  10 +-
>  drivers/gpu/drm/bridge/imx/imx8qm-ldb.c            |  10 +-
>  drivers/gpu/drm/bridge/imx/imx8qxp-ldb.c           |  21 +-
>  .../gpu/drm/bridge/imx/imx8qxp-pixel-combiner.c    |   8 +-
>  drivers/gpu/drm/bridge/imx/imx8qxp-pixel-link.c    |  13 +-
>  drivers/gpu/drm/bridge/imx/imx8qxp-pxl2dpi.c       |  11 +-
>  drivers/gpu/drm/bridge/ite-it6263.c                |  18 +-
>  drivers/gpu/drm/bridge/ite-it6505.c                |  10 +-
>  drivers/gpu/drm/bridge/ite-it66121.c               |   8 +-
>  drivers/gpu/drm/bridge/lontium-lt8912b.c           |   3 +-
>  drivers/gpu/drm/bridge/lontium-lt9211.c            |   8 +-
>  drivers/gpu/drm/bridge/lontium-lt9611.c            |  21 +-
>  drivers/gpu/drm/bridge/lontium-lt9611uxc.c         |   3 +-
>  drivers/gpu/drm/bridge/lvds-codec.c                |   3 +-
>  .../drm/bridge/megachips-stdpxxxx-ge-b850v3-fw.c   |   1 +
>  drivers/gpu/drm/bridge/microchip-lvds.c            |   3 +-
>  drivers/gpu/drm/bridge/nwl-dsi.c                   |  13 +-
>  drivers/gpu/drm/bridge/nxp-ptn3460.c               |   5 +-
>  drivers/gpu/drm/bridge/panel.c                     |  15 +-
>  drivers/gpu/drm/bridge/parade-ps8622.c             |   1 +
>  drivers/gpu/drm/bridge/parade-ps8640.c             |   7 +-
>  drivers/gpu/drm/bridge/samsung-dsim.c              |  11 +-
>  drivers/gpu/drm/bridge/sii902x.c                   |   9 +-
>  drivers/gpu/drm/bridge/sil-sii8620.c               |   1 +
>  drivers/gpu/drm/bridge/simple-bridge.c             |   5 +-
>  drivers/gpu/drm/bridge/synopsys/dw-hdmi-qp.c       |   5 +-
>  drivers/gpu/drm/bridge/synopsys/dw-hdmi.c          |   8 +-
>  drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c      |  11 +-
>  drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi2.c     |  11 +-
>  drivers/gpu/drm/bridge/tc358762.c                  |  12 +-
>  drivers/gpu/drm/bridge/tc358764.c                  |   3 +-
>  drivers/gpu/drm/bridge/tc358767.c                  |  22 +-
>  drivers/gpu/drm/bridge/tc358768.c                  |  33 ++-
>  drivers/gpu/drm/bridge/tc358775.c                  |  39 ++--
>  drivers/gpu/drm/bridge/thc63lvd1024.c              |   3 +-
>  drivers/gpu/drm/bridge/ti-dlpc3433.c               |  10 +-
>  drivers/gpu/drm/bridge/ti-sn65dsi83.c              |  10 +-
>  drivers/gpu/drm/bridge/ti-sn65dsi86.c              |  63 ++++--
>  drivers/gpu/drm/bridge/ti-tdp158.c                 |  12 +-
>  drivers/gpu/drm/bridge/ti-tfp410.c                 |   5 +-
>  drivers/gpu/drm/bridge/ti-tpd12s015.c              |   3 +-
>  drivers/gpu/drm/drm_atomic_helper.c                | 242 ++++++++++-----------
>  drivers/gpu/drm/drm_atomic_state_helper.c          |   5 +
>  drivers/gpu/drm/drm_bridge.c                       |  98 +++------
>  drivers/gpu/drm/i2c/tda998x_drv.c                  |   1 +
>  drivers/gpu/drm/imx/ipuv3/parallel-display.c       |   3 +-
>  drivers/gpu/drm/ingenic/ingenic-drm-drv.c          |   9 +-
>  drivers/gpu/drm/mcde/mcde_dsi.c                    |   3 +-
>  drivers/gpu/drm/mediatek/mtk_dp.c                  |   9 +-
>  drivers/gpu/drm/mediatek/mtk_dpi.c                 |   3 +-
>  drivers/gpu/drm/mediatek/mtk_dsi.c                 |  11 +-
>  drivers/gpu/drm/mediatek/mtk_hdmi.c                |  12 +-
>  drivers/gpu/drm/meson/meson_encoder_cvbs.c         |   8 +-
>  drivers/gpu/drm/meson/meson_encoder_dsi.c          |   8 +-
>  drivers/gpu/drm/meson/meson_encoder_hdmi.c         |   8 +-
>  drivers/gpu/drm/msm/dp/dp_display.c                |  28 +--
>  drivers/gpu/drm/msm/dp/dp_drm.c                    |  19 +-
>  drivers/gpu/drm/msm/dp/dp_drm.h                    |   6 +-
>  drivers/gpu/drm/msm/dsi/dsi_manager.c              |   3 +-
>  drivers/gpu/drm/omapdrm/dss/dpi.c                  |   3 +-
>  drivers/gpu/drm/omapdrm/dss/dsi.c                  |   3 +-
>  drivers/gpu/drm/omapdrm/dss/hdmi4.c                |   8 +-
>  drivers/gpu/drm/omapdrm/dss/hdmi5.c                |   8 +-
>  drivers/gpu/drm/omapdrm/dss/sdi.c                  |   3 +-
>  drivers/gpu/drm/omapdrm/dss/venc.c                 |   3 +-
>  drivers/gpu/drm/renesas/rcar-du/rcar_lvds.c        |   8 +-
>  drivers/gpu/drm/renesas/rcar-du/rcar_mipi_dsi.c    |   7 +-
>  drivers/gpu/drm/renesas/rz-du/rzg2l_mipi_dsi.c     |   8 +-
>  drivers/gpu/drm/stm/lvds.c                         |  16 +-
>  drivers/gpu/drm/tidss/tidss_encoder.c              |   3 +-
>  drivers/gpu/drm/vc4/vc4_dsi.c                      |  12 +-
>  drivers/gpu/drm/xlnx/zynqmp_dp.c                   |  17 +-
>  drivers/platform/arm64/acer-aspire1-ec.c           |   3 +-
>  include/drm/drm_atomic.h                           |  45 ++++
>  include/drm/drm_bridge.h                           |  39 +++-
>  91 files changed, 681 insertions(+), 574 deletions(-)
> ---
> base-commit: 50d0a57d3a4193862a53fae0de7ed7749908cd8f
> change-id: 20250115-bridge-connector-f93194e267ff
> 
> Best regards,
> -- 
> Maxime Ripard <mripard@...nel.org>
> 

-- 
With best wishes
Dmitry

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ