]> git.proxmox.com Git - mirror_ubuntu-eoan-kernel.git/commitdiff
drm/msm/adreno: Load the firmware before bringing up the hardware
authorJordan Crouse <jcrouse@codeaurora.org>
Mon, 6 Aug 2018 17:33:22 +0000 (11:33 -0600)
committerRob Clark <robdclark@gmail.com>
Fri, 10 Aug 2018 22:49:18 +0000 (18:49 -0400)
Failure to load firmware is the primary reason to fail adreno_load_gpu().
Try to load it first before going into the hardware initialization code and
unwinding it. This is important for a6xx because the GMU gets loaded from
the runtime power code and it is more costly to fail in that path because
of missing firmware.

Signed-off-by: Jordan Crouse <jcrouse@codeaurora.org>
Signed-off-by: Rob Clark <robdclark@gmail.com>
drivers/gpu/drm/msm/adreno/adreno_device.c
drivers/gpu/drm/msm/adreno/adreno_gpu.c
drivers/gpu/drm/msm/adreno/adreno_gpu.h

index 44813624a28664b5b2359079a9c66cd91b6f56a8..37746f1d54cf5db10d968b1a9145ce256f24f04a 100644 (file)
@@ -155,6 +155,7 @@ struct msm_gpu *adreno_load_gpu(struct drm_device *dev)
        struct msm_drm_private *priv = dev->dev_private;
        struct platform_device *pdev = priv->gpu_pdev;
        struct msm_gpu *gpu = NULL;
+       struct adreno_gpu *adreno_gpu;
        int ret;
 
        if (pdev)
@@ -165,7 +166,27 @@ struct msm_gpu *adreno_load_gpu(struct drm_device *dev)
                return NULL;
        }
 
-       pm_runtime_get_sync(&pdev->dev);
+       adreno_gpu = to_adreno_gpu(gpu);
+
+       /*
+        * The number one reason for HW init to fail is if the firmware isn't
+        * loaded yet. Try that first and don't bother continuing on
+        * otherwise
+        */
+
+       ret = adreno_load_fw(adreno_gpu);
+       if (ret)
+               return NULL;
+
+       /* Make sure pm runtime is active and reset any previous errors */
+       pm_runtime_set_active(&pdev->dev);
+
+       ret = pm_runtime_get_sync(&pdev->dev);
+       if (ret < 0) {
+               dev_err(dev->dev, "Couldn't power up the GPU: %d\n", ret);
+               return NULL;
+       }
+
        mutex_lock(&dev->struct_mutex);
        ret = msm_gpu_hw_init(gpu);
        mutex_unlock(&dev->struct_mutex);
index 65c0ae7d8ad19bc3ee312b6a5f39d4ca16d29632..da1363a0c54d61b6d50fe77f5fa3993ee37668b4 100644 (file)
@@ -149,7 +149,7 @@ out:
        return fw;
 }
 
-static int adreno_load_fw(struct adreno_gpu *adreno_gpu)
+int adreno_load_fw(struct adreno_gpu *adreno_gpu)
 {
        int i;
 
index 4406776597fdb126ce161555c662cc2a7d9f0ad5..d391ff377612eedbcd7ed8a2aed844c972206205 100644 (file)
@@ -228,7 +228,7 @@ int adreno_gpu_init(struct drm_device *drm, struct platform_device *pdev,
                struct adreno_gpu *gpu, const struct adreno_gpu_funcs *funcs,
                int nr_rings);
 void adreno_gpu_cleanup(struct adreno_gpu *gpu);
-
+int adreno_load_fw(struct adreno_gpu *adreno_gpu);
 
 void adreno_gpu_state_destroy(struct msm_gpu_state *state);