All of lore.kernel.org
 help / color / mirror / Atom feed
From: Maxime Ripard <maxime@cerno.tech>
To: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>,
	Thomas Zimmermann <tzimmermann@suse.de>,
	Maxime Ripard <maxime@cerno.tech>,
	Daniel Vetter <daniel.vetter@intel.com>,
	David Airlie <airlied@linux.ie>
Cc: dri-devel@lists.freedesktop.org
Subject: [PATCH v3 00/71] drm/vc4: Fix hotplug for vc4
Date: Wed, 29 Jun 2022 14:33:59 +0200	[thread overview]
Message-ID: <20220629123510.1915022-1-maxime@cerno.tech> (raw)

Hi,

Here is a series that address multiple issues when trying to unbind/rebind
vc4-related devices to their drivers.

Most of these issues involve either use-after-free, improper resource
liberation or similar.

It has been tested on the Pi3 and Pi4, with X and glxgears running and KASAN
enabled to properly validate our memory accesses.

Pi3 isn't functional after a rebind though, with vblank timeouts occuring. I'm
not quite sure why at this point, but at least the kernel doesn't completely
crash now.

Let me know what you think,
Maxime

---

Changes from v2:
  - Rebased on top of next-20220629
  - Fix va arguments on the crtc and encoder init
  - Removed drmm_connector_init_with_ddc and consolidated drm_connector_init*
  - Reworked the doc for drmm_of_get_bridge

Changes from v1:
  - Rebased on top on next-20220622
  - Consolidated the new drmm init helpers with their alloc counterparts
  - Dropped the drmm writeback and simple encoder helpers
  - Clarified the documentation of drm_connector_unregister
  - Removed the drm_connector_unregister usage
  - Fixed a vblank timeout when unbinding
  - Renamed the kref functions in vc4_dsi
  - Collected the tags

Maxime Ripard (71):
  drm/mipi-dsi: Detach devices when removing the host
  drm/crtc: Introduce drmm_crtc_init_with_planes
  drm/encoder: Introduce drmm_encoder_init
  drm/connector: Reorder headers
  drm/connector: Mention the cleanup after drm_connector_init
  drm/connector: Clarify when drm_connector_unregister is needed
  drm/connector: Consolidate Connector Initialization
  drm/connector: Check for destroy implementation
  drm/connector: Introduce drmm_connector_init
  drm/bridge: panel: Introduce drmm_panel_bridge_add
  drm/bridge: panel: Introduce drmm_of_get_bridge
  drm/vc4: drv: Call component_unbind_all()
  drm/vc4: drv: Use drm_dev_unplug
  drm/vc4: crtc: Create vblank reporting function
  drm/vc4: hvs: Protect device resources after removal
  drm/vc4: hvs: Remove planes currently allocated before taking down
  drm/vc4: plane: Take possible_crtcs as an argument
  drm/vc4: crtc: Remove manual plane removal on error
  drm/vc4: plane: Switch to drmm_universal_plane_alloc()
  drm/vc4: crtc: Move debugfs_name to crtc_data
  drm/vc4: crtc: Switch to drmm_kzalloc
  drm/vc4: crtc: Switch to DRM-managed CRTC initialization
  drm/vc4: dpi: Remove vc4_dev dpi pointer
  drm/vc4: dpi: Embed DRM structures into the private structure
  drm/vc4: dpi: Switch to drmm_kzalloc
  drm/vc4: dpi: Return an error if we can't enable our clock
  drm/vc4: dpi: Remove unnecessary drm_of_panel_bridge_remove call
  drm/vc4: dpi: Add action to disable the clock
  drm/vc4: dpi: Switch to DRM-managed encoder initialization
  drm/vc4: dpi: Switch to drmm_of_get_bridge
  drm/vc4: dpi: Protect device resources
  drm/vc4: dsi: Embed DRM structures into the private structure
  drm/vc4: dsi: Switch to DRM-managed encoder initialization
  drm/vc4: dsi: Switch to drmm_of_get_bridge
  drm/vc4: dsi: Fix the driver structure lifetime
  drm/vc4: dsi: Switch to devm_pm_runtime_enable
  drm/vc4: hdmi: Depends on CONFIG_PM
  drm/vc4: hdmi: Rework power up
  drm/vc4: hdmi: Switch to drmm_kzalloc
  drm/vc4: hdmi: Remove call to drm_connector_unregister()
  drm/vc4: hdmi: Switch to DRM-managed encoder initialization
  drm/vc4: hdmi: Switch to DRM-managed connector initialization
  drm/vc4: hdmi: Switch to device-managed ALSA initialization
  drm/vc4: hdmi: Switch to device-managed CEC initialization
  drm/vc4: hdmi: Use a device-managed action for DDC
  drm/vc4: hdmi: Switch to DRM-managed kfree to build regsets
  drm/vc4: hdmi: Use devm to register hotplug interrupts
  drm/vc4: hdmi: Move audio structure offset checks
  drm/vc4: hdmi: Protect device resources after removal
  drm/vc4: hdmi: Switch to devm_pm_runtime_enable
  drm/vc4: txp: Remove vc4_dev txp pointer
  drm/vc4: txp: Remove duplicate regset
  drm/vc4: txp: Switch to drmm_kzalloc
  drm/vc4: txp: Remove call to drm_connector_unregister()
  drm/vc4: txp: Protect device resources
  drm/vc4: vec: Remove vc4_dev vec pointer
  drm/vc4: vec: Embed DRM structures into the private structure
  drm/vc4: vec: Switch to drmm_kzalloc
  drm/vc4: vec: Remove call to drm_connector_unregister()
  drm/vc4: vec: Switch to DRM-managed encoder initialization
  drm/vc4: vec: Switch to DRM-managed connector initialization
  drm/vc4: vec: Protect device resources after removal
  drm/vc4: vec: Switch to devm_pm_runtime_enable
  drm/vc4: debugfs: Protect device resources
  drm/vc4: debugfs: Return an error on failure
  drm/vc4: debugfs: Simplify debugfs registration
  drm/vc4: Switch to drmm_mutex_init
  drm/vc4: perfmon: Add missing mutex_destroy
  drm/vc4: v3d: Stop disabling interrupts
  drm/vc4: v3d: Rework the runtime_pm setup
  drm/vc4: v3d: Switch to devm_pm_runtime_enable

 drivers/gpu/drm/bridge/panel.c    |  74 ++++
 drivers/gpu/drm/drm_connector.c   | 143 +++++--
 drivers/gpu/drm/drm_crtc.c        |  93 +++-
 drivers/gpu/drm/drm_encoder.c     |  76 +++-
 drivers/gpu/drm/drm_mipi_dsi.c    |   1 +
 drivers/gpu/drm/vc4/Kconfig       |   1 +
 drivers/gpu/drm/vc4/vc4_bo.c      |  33 +-
 drivers/gpu/drm/vc4/vc4_crtc.c    |  90 ++--
 drivers/gpu/drm/vc4/vc4_debugfs.c |  71 ++--
 drivers/gpu/drm/vc4/vc4_dpi.c     | 131 +++---
 drivers/gpu/drm/vc4/vc4_drv.c     |  21 +-
 drivers/gpu/drm/vc4/vc4_drv.h     |  47 +-
 drivers/gpu/drm/vc4/vc4_dsi.c     | 133 ++++--
 drivers/gpu/drm/vc4/vc4_gem.c     |  10 +-
 drivers/gpu/drm/vc4/vc4_hdmi.c    | 683 ++++++++++++++++++++++--------
 drivers/gpu/drm/vc4/vc4_hdmi.h    |   3 +-
 drivers/gpu/drm/vc4/vc4_hvs.c     | 145 ++++++-
 drivers/gpu/drm/vc4/vc4_irq.c     |   2 +-
 drivers/gpu/drm/vc4/vc4_perfmon.c |   1 +
 drivers/gpu/drm/vc4/vc4_plane.c   |  36 +-
 drivers/gpu/drm/vc4/vc4_txp.c     |  55 ++-
 drivers/gpu/drm/vc4/vc4_v3d.c     |  65 ++-
 drivers/gpu/drm/vc4/vc4_vec.c     | 216 +++++-----
 include/drm/drm_bridge.h          |   4 +
 include/drm/drm_connector.h       |   5 +
 include/drm/drm_crtc.h            |   9 +
 include/drm/drm_encoder.h         |   6 +
 27 files changed, 1514 insertions(+), 640 deletions(-)

-- 
2.36.1


             reply	other threads:[~2022-06-29 12:35 UTC|newest]

Thread overview: 78+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-06-29 12:33 Maxime Ripard [this message]
2022-06-29 12:34 ` [PATCH v3 01/71] drm/mipi-dsi: Detach devices when removing the host Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 02/71] drm/crtc: Introduce drmm_crtc_init_with_planes Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 03/71] drm/encoder: Introduce drmm_encoder_init Maxime Ripard
2022-06-29 13:32   ` Philipp Zabel
2022-06-29 14:41     ` Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 04/71] drm/connector: Reorder headers Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 05/71] drm/connector: Mention the cleanup after drm_connector_init Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 06/71] drm/connector: Clarify when drm_connector_unregister is needed Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 07/71] drm/connector: Consolidate Connector Initialization Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 08/71] drm/connector: Check for destroy implementation Maxime Ripard
2022-06-29 13:04   ` Jani Nikula
2022-06-29 12:34 ` [PATCH v3 09/71] drm/connector: Introduce drmm_connector_init Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 10/71] drm/bridge: panel: Introduce drmm_panel_bridge_add Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 11/71] drm/bridge: panel: Introduce drmm_of_get_bridge Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 12/71] drm/vc4: drv: Call component_unbind_all() Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 13/71] drm/vc4: drv: Use drm_dev_unplug Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 14/71] drm/vc4: crtc: Create vblank reporting function Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 15/71] drm/vc4: hvs: Protect device resources after removal Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 16/71] drm/vc4: hvs: Remove planes currently allocated before taking down Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 17/71] drm/vc4: plane: Take possible_crtcs as an argument Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 18/71] drm/vc4: crtc: Remove manual plane removal on error Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 19/71] drm/vc4: plane: Switch to drmm_universal_plane_alloc() Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 20/71] drm/vc4: crtc: Move debugfs_name to crtc_data Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 21/71] drm/vc4: crtc: Switch to drmm_kzalloc Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 22/71] drm/vc4: crtc: Switch to DRM-managed CRTC initialization Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 23/71] drm/vc4: dpi: Remove vc4_dev dpi pointer Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 24/71] drm/vc4: dpi: Embed DRM structures into the private structure Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 25/71] drm/vc4: dpi: Switch to drmm_kzalloc Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 26/71] drm/vc4: dpi: Return an error if we can't enable our clock Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 27/71] drm/vc4: dpi: Remove unnecessary drm_of_panel_bridge_remove call Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 28/71] drm/vc4: dpi: Add action to disable the clock Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 29/71] drm/vc4: dpi: Switch to DRM-managed encoder initialization Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 30/71] drm/vc4: dpi: Switch to drmm_of_get_bridge Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 31/71] drm/vc4: dpi: Protect device resources Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 32/71] drm/vc4: dsi: Embed DRM structures into the private structure Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 33/71] drm/vc4: dsi: Switch to DRM-managed encoder initialization Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 34/71] drm/vc4: dsi: Switch to drmm_of_get_bridge Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 35/71] drm/vc4: dsi: Fix the driver structure lifetime Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 36/71] drm/vc4: dsi: Switch to devm_pm_runtime_enable Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 37/71] drm/vc4: hdmi: Depends on CONFIG_PM Maxime Ripard
2022-07-08  9:42   ` (subset) " Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 38/71] drm/vc4: hdmi: Rework power up Maxime Ripard
2022-07-08  9:42   ` (subset) " Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 39/71] drm/vc4: hdmi: Switch to drmm_kzalloc Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 40/71] drm/vc4: hdmi: Remove call to drm_connector_unregister() Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 41/71] drm/vc4: hdmi: Switch to DRM-managed encoder initialization Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 42/71] drm/vc4: hdmi: Switch to DRM-managed connector initialization Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 43/71] drm/vc4: hdmi: Switch to device-managed ALSA initialization Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 44/71] drm/vc4: hdmi: Switch to device-managed CEC initialization Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 45/71] drm/vc4: hdmi: Use a device-managed action for DDC Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 46/71] drm/vc4: hdmi: Switch to DRM-managed kfree to build regsets Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 47/71] drm/vc4: hdmi: Use devm to register hotplug interrupts Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 48/71] drm/vc4: hdmi: Move audio structure offset checks Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 49/71] drm/vc4: hdmi: Protect device resources after removal Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 50/71] drm/vc4: hdmi: Switch to devm_pm_runtime_enable Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 51/71] drm/vc4: txp: Remove vc4_dev txp pointer Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 52/71] drm/vc4: txp: Remove duplicate regset Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 53/71] drm/vc4: txp: Switch to drmm_kzalloc Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 54/71] drm/vc4: txp: Remove call to drm_connector_unregister() Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 55/71] drm/vc4: txp: Protect device resources Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 56/71] drm/vc4: vec: Remove vc4_dev vec pointer Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 57/71] drm/vc4: vec: Embed DRM structures into the private structure Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 58/71] drm/vc4: vec: Switch to drmm_kzalloc Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 59/71] drm/vc4: vec: Remove call to drm_connector_unregister() Maxime Ripard
2022-06-29 12:34 ` [PATCH v3 60/71] drm/vc4: vec: Switch to DRM-managed encoder initialization Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 61/71] drm/vc4: vec: Switch to DRM-managed connector initialization Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 62/71] drm/vc4: vec: Protect device resources after removal Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 63/71] drm/vc4: vec: Switch to devm_pm_runtime_enable Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 64/71] drm/vc4: debugfs: Protect device resources Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 65/71] drm/vc4: debugfs: Return an error on failure Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 66/71] drm/vc4: debugfs: Simplify debugfs registration Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 67/71] drm/vc4: Switch to drmm_mutex_init Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 68/71] drm/vc4: perfmon: Add missing mutex_destroy Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 69/71] drm/vc4: v3d: Stop disabling interrupts Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 70/71] drm/vc4: v3d: Rework the runtime_pm setup Maxime Ripard
2022-06-29 12:35 ` [PATCH v3 71/71] drm/vc4: v3d: Switch to devm_pm_runtime_enable Maxime Ripard
2022-07-07  6:48 ` [PATCH v3 00/71] drm/vc4: Fix hotplug for vc4 Thomas Zimmermann

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20220629123510.1915022-1-maxime@cerno.tech \
    --to=maxime@cerno.tech \
    --cc=airlied@linux.ie \
    --cc=daniel.vetter@intel.com \
    --cc=dri-devel@lists.freedesktop.org \
    --cc=maarten.lankhorst@linux.intel.com \
    --cc=tzimmermann@suse.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.