drm/msm/gpu: Remove mutex from wait_event condition
authorRob Clark <robdclark@chromium.org>
Thu, 10 Mar 2022 23:46:06 +0000 (15:46 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 27 Apr 2022 12:41:06 +0000 (14:41 +0200)
[ Upstream commit 7242795d520d3fb48e005e3c96ba54bb59639d6e ]

The mutex wasn't really protecting anything before.  Before the previous
patch we could still be racing with the scheduler's kthread, as that is
not necessarily frozen yet.  Now that we've parked the sched threads,
the only race is with jobs retiring, and that is harmless, ie.

Signed-off-by: Rob Clark <robdclark@chromium.org>
Link: https://lore.kernel.org/r/20220310234611.424743-4-robdclark@gmail.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/gpu/drm/msm/adreno/adreno_device.c

index b93de79000e1b08684b384c3bf3a62749331b51d..e8a8240a68686055b9f0354c0aa4f807f98e1e37 100644 (file)
@@ -608,22 +608,13 @@ static int adreno_runtime_resume(struct device *dev)
        return gpu->funcs->pm_resume(gpu);
 }
 
-static int active_submits(struct msm_gpu *gpu)
-{
-       int active_submits;
-       mutex_lock(&gpu->active_lock);
-       active_submits = gpu->active_submits;
-       mutex_unlock(&gpu->active_lock);
-       return active_submits;
-}
-
 static int adreno_runtime_suspend(struct device *dev)
 {
        struct msm_gpu *gpu = dev_to_gpu(dev);
        int remaining;
 
        remaining = wait_event_timeout(gpu->retire_event,
-                                      active_submits(gpu) == 0,
+                                      gpu->active_submits == 0,
                                       msecs_to_jiffies(1000));
        if (remaining == 0) {
                dev_err(dev, "Timeout waiting for GPU to suspend\n");