drm/bridge: anx7625: Ensure bridge is suspended in disable()
authorHsin-Yi Wang <hsinyi@chromium.org>
Thu, 18 Jan 2024 01:58:14 +0000 (17:58 -0800)
committerDouglas Anderson <dianders@chromium.org>
Mon, 22 Jan 2024 16:53:42 +0000 (08:53 -0800)
commit4d5b7daa3c610af3f322ad1e91fc0c752ff32f0e
tree564af39151930ee281e2399a0b004629248632ab
parent4b5581f112075e46d73b34b9848be041e6c1e489
drm/bridge: anx7625: Ensure bridge is suspended in disable()

Similar to commit 26db46bc9c67 ("drm/bridge: parade-ps8640: Ensure bridge
is suspended in .post_disable()"). Add a mutex to ensure that aux transfer
won't race with atomic_disable by holding the PM reference and prevent
the bridge from suspend.

Also we need to use pm_runtime_put_sync_suspend() to suspend the bridge
instead of idle with pm_runtime_put_sync().

Fixes: 3203e497eb76 ("drm/bridge: anx7625: Synchronously run runtime suspend.")
Fixes: adca62ec370c ("drm/bridge: anx7625: Support reading edid through aux channel")
Signed-off-by: Hsin-Yi Wang <hsinyi@chromium.org>
Tested-by: Xuxin Xiong <xuxinxiong@huaqin.corp-partner.google.com>
Reviewed-by: Pin-yen Lin <treapking@chromium.org>
Reviewed-by: Douglas Anderson <dianders@chromium.org>
Signed-off-by: Douglas Anderson <dianders@chromium.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20240118015916.2296741-1-hsinyi@chromium.org
drivers/gpu/drm/bridge/analogix/anx7625.c
drivers/gpu/drm/bridge/analogix/anx7625.h