2
0
mirror of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git synced 2025-09-04 20:19:47 +08:00
linux/drivers/gpu/drm/msm/adreno
Rob Clark 167a668ab0 drm/msm/gpu: Wait for idle before suspending
System suspend uses pm_runtime_force_suspend(), which cheekily bypasses
the runpm reference counts.  This doesn't actually work so well when the
GPU is active.  So add a reasonable delay waiting for the GPU to become
idle.

Alternatively we could just return -EBUSY in this case, but that has the
disadvantage of causing system suspend to fail.

v2: s/ret/remaining [sboyd], and switch to using active_submits count
    to ensure we aren't racing with submit cleanup (and devfreq idle
    work getting scheduled, etc)
v3: fix inverted logic

Signed-off-by: Rob Clark <robdclark@chromium.org>
Reviewed-by: Bjorn Andersson <bjorn.andersson@linaro.org>
Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
Link: https://lore.kernel.org/r/20220108180913.814448-2-robdclark@gmail.com
Signed-off-by: Rob Clark <robdclark@chromium.org>
2022-01-25 08:54:41 -08:00
..
a2xx_gpu.c drm/msm: Drop priv->lastctx 2021-11-28 09:50:33 -08:00
a2xx_gpu.h drm/msm/adreno: add a2xx 2018-12-11 13:07:06 -05:00
a2xx.xml.h drm/msm: Generated register update 2021-06-23 07:33:54 -07:00
a3xx_gpu.c drm/msm: Drop priv->lastctx 2021-11-28 09:50:33 -08:00
a3xx_gpu.h drm/msm/gpu: add ocmem init/cleanup functions 2019-10-07 08:17:39 -07:00
a3xx.xml.h drm/msm: Generated register update 2021-06-23 07:33:54 -07:00
a4xx_gpu.c drm/msm: Drop priv->lastctx 2021-11-28 09:50:33 -08:00
a4xx_gpu.h drm/msm/gpu: add ocmem init/cleanup functions 2019-10-07 08:17:39 -07:00
a4xx.xml.h drm/msm: Generated register update 2021-06-23 07:33:54 -07:00
a5xx_debugfs.c drm/msm: Remove struct_mutex usage 2021-11-28 09:50:33 -08:00
a5xx_gpu.c drm/msm/a5xx: Fix missing CP_PROTECT for SMMU on A540 2021-12-17 15:09:46 -08:00
a5xx_gpu.h drm/msm: Allow a5xx to mark the RPTR shadow as privileged 2020-09-15 10:47:44 -07:00
a5xx_power.c drm/msm: drop drm_gem_object_put_locked() 2021-07-27 18:09:18 -07:00
a5xx_preempt.c drm/msm: drop drm_gem_object_put_locked() 2021-07-27 18:09:18 -07:00
a5xx.xml.h drm/msm: Generated register update 2021-06-23 07:33:54 -07:00
a6xx_gmu.c drm/msm/gpu: Name GMU bos 2021-11-29 16:19:58 -08:00
a6xx_gmu.h drm/msm/a6xx: Serialize GMU communication 2021-10-01 13:10:20 -07:00
a6xx_gmu.xml.h drm/msm: Generated register update 2021-06-23 07:33:54 -07:00
a6xx_gpu_state.c drm/msm/a6xx: Skip crashdumper state if GPU needs_hw_init 2021-12-13 13:46:18 -08:00
a6xx_gpu_state.h drm/msm/a6xx: fix crashdec section name typo 2020-08-22 10:36:30 -07:00
a6xx_gpu.c drm/msm/a6xx: Add missing suspend_count increment 2022-01-25 05:47:57 +03:00
a6xx_gpu.h drm/msm: Drop priv->lastctx 2021-11-28 09:50:33 -08:00
a6xx_hfi.c drm/msm/gpu: Also snapshot GMU HFI buffer 2021-11-29 16:19:58 -08:00
a6xx_hfi.h drm/msm/gpu: Also snapshot GMU HFI buffer 2021-11-29 16:19:58 -08:00
a6xx.xml.h drm/msm: Generated register update 2021-06-23 07:33:54 -07:00
adreno_common.xml.h drm/msm: Generated register update 2021-06-23 07:33:54 -07:00
adreno_device.c drm/msm/gpu: Wait for idle before suspending 2022-01-25 08:54:41 -08:00
adreno_gpu.c drm/msm/a6xx: Skip crashdumper state if GPU needs_hw_init 2021-12-13 13:46:18 -08:00
adreno_gpu.h drm/msm/a5xx: Add support for Adreno 506 GPU 2021-12-17 15:09:46 -08:00
adreno_pm4.xml.h drm/msm: Generated register update 2021-06-23 07:33:54 -07:00