disp: msm: sde: cancel delayed work items during TUI transition
Delayed work items may touch HW registers. If these work items run while HW is not owned by this VM it will lead to invalid access. This happens in video mode as HAL does not disable idle power-collapse in this mode. It can also happen with ESD status if lastclose or TUI transition failure occurs. Although there is a contract with user mode to turn off certain features, kernel cannot rely on it to always do the right thing. Prevent potential crashes from certain corner cases by cancelling all delayed work items when the HW ownership is transferred. Change-Id: I08da17f2ce72bf2fddf71924c3e8edd2e2715be8 Signed-off-by: Steve Cohen <cohens@codeaurora.org>
This commit is contained in:
@@ -1880,6 +1880,17 @@ static void _sde_encoder_rc_cancel_delayed(struct sde_encoder_virt *sde_enc,
|
||||
sw_event);
|
||||
}
|
||||
|
||||
void sde_encoder_cancel_delayed_work(struct drm_encoder *encoder)
|
||||
{
|
||||
struct sde_encoder_virt *sde_enc;
|
||||
|
||||
if (!encoder)
|
||||
return;
|
||||
|
||||
sde_enc = to_sde_encoder_virt(encoder);
|
||||
_sde_encoder_rc_cancel_delayed(sde_enc, 0);
|
||||
}
|
||||
|
||||
static void _sde_encoder_rc_kickoff_delayed(struct sde_encoder_virt *sde_enc,
|
||||
u32 sw_event)
|
||||
{
|
||||
|
Reference in New Issue
Block a user