[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250108-async-disable-fix-v1-1-3f93eb600a3a@quicinc.com>
Date: Wed, 8 Jan 2025 14:57:51 -0800
From: Jessica Zhang <quic_jesszhan@...cinc.com>
To: Rob Clark <robdclark@...il.com>,
Dmitry Baryshkov
<dmitry.baryshkov@...aro.org>,
Sean Paul <sean@...rly.run>,
Marijn Suijten
<marijn.suijten@...ainline.org>,
David Airlie <airlied@...il.com>, "Simona
Vetter" <simona@...ll.ch>
CC: <quic_abhinavk@...cinc.com>, Rob Clark <robdclark@...omium.org>,
<linux-arm-msm@...r.kernel.org>, <dri-devel@...ts.freedesktop.org>,
<freedreno@...ts.freedesktop.org>, <linux-kernel@...r.kernel.org>,
"Jessica
Zhang" <quic_jesszhan@...cinc.com>
Subject: [PATCH] drm/msm/dpu: Force disabling commits to take non-async
path
Force commit that are disabling a plane in the async_crtc to take the
non-async commit tail path.
In cases where there are two consecutive async cursor updates (one
regular non-NULL update followed by a disabling NULL FB update), it is
possible for the second NULL update to not be queued (due to the
pending_crtc_mask check) or otherwise not be run before the cursor FB is
deallocated by drm_atomic_helper_cleanup_planes(). This would cause a
context fault since the hardware would try to fetch the old plane state
with the stale FB address.
Avoid this issue by forcing cursor updates that will disable the cursor
plane to be blocking commits. This will ensure that hardware clears and
stops fetching the FB source address before the driver deallocates the FB
Fixes: 2d99ced787e3 ("drm/msm: async commit support")
Signed-off-by: Jessica Zhang <quic_jesszhan@...cinc.com>
---
drivers/gpu/drm/msm/msm_atomic.c | 13 +++++++++++++
1 file changed, 13 insertions(+)
diff --git a/drivers/gpu/drm/msm/msm_atomic.c b/drivers/gpu/drm/msm/msm_atomic.c
index 9c45d641b5212c11078ab38c13a519663d85e10a..ddc74c68148c643d34ca631dd28d4cdc2b8c7dc0 100644
--- a/drivers/gpu/drm/msm/msm_atomic.c
+++ b/drivers/gpu/drm/msm/msm_atomic.c
@@ -142,6 +142,7 @@ static bool can_do_async(struct drm_atomic_state *state,
struct drm_connector_state *connector_state;
struct drm_connector *connector;
struct drm_crtc_state *crtc_state;
+ struct drm_plane_state *plane_state;
struct drm_crtc *crtc;
int i, num_crtcs = 0;
@@ -162,6 +163,18 @@ static bool can_do_async(struct drm_atomic_state *state,
*async_crtc = crtc;
}
+ /*
+ * Force a blocking commit if the cursor is being disabled. This is to
+ * ensure that the registers are cleared and hardware doesn't try to
+ * fetch from a stale address.
+ */
+ if (*async_crtc) {
+ plane_state = drm_atomic_get_new_plane_state(state,
+ (*async_crtc)->cursor);
+ if (plane_state && !plane_state->fb)
+ return false;
+ }
+
return true;
}
---
base-commit: 866e43b945bf98f8e807dfa45eca92f931f3a032
change-id: 20250108-async-disable-fix-cc1b9a1d5b19
Best regards,
--
Jessica Zhang <quic_jesszhan@...cinc.com>
Powered by blists - more mailing lists