]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
drm/msm/adreno: set cx_misc_mmio regardless of if platform has LLCC
authorAlexander Koskovich <akoskovich@pm.me>
Thu, 28 May 2026 09:48:57 +0000 (09:48 +0000)
committerRob Clark <robin.clark@oss.qualcomm.com>
Fri, 29 May 2026 14:07:30 +0000 (07:07 -0700)
Platforms without a LLCC (e.g. milos) still need to be able to read and
write to the cx_mem region. Previously if LLCC slices were unavailable
the cx_misc_mmio mapping was overwritten with ERR_PTR, causing a crash
when the GMU later accessed cx_mem.

Move the cx_misc_mmio mapping out of a6xx_llc_slices_init() into
a6xx_gpu_init() so that cx_mem mapping is independent of LLCC.

Reviewed-by: Konrad Dybcio <konrad.dybcio@oss.qualcomm.com>
Reviewed-by: Akhil P Oommen <akhilpo@oss.qualcomm.com>
Signed-off-by: Alexander Koskovich <akoskovich@pm.me>
Patchwork: https://patchwork.freedesktop.org/patch/728808/
Message-ID: <20260528-adreno-810-v7-4-7fe7fdd97fc2@pm.me>
Signed-off-by: Rob Clark <robin.clark@oss.qualcomm.com>
drivers/gpu/drm/msm/adreno/a6xx_gpu.c

index a65dc653ca732cf15c0fb40cff30c4a9da5734b7..8b3bb2fd433bab983a701823a46fb1553fa32825 100644 (file)
@@ -1961,7 +1961,7 @@ static void a6xx_llc_activate(struct a6xx_gpu *a6xx_gpu)
        struct msm_gpu *gpu = &adreno_gpu->base;
        u32 cntl1_regval = 0;
 
-       if (IS_ERR(a6xx_gpu->cx_misc_mmio))
+       if (IS_ERR_OR_NULL(a6xx_gpu->llc_slice) && IS_ERR_OR_NULL(a6xx_gpu->htw_llc_slice))
                return;
 
        if (!llcc_slice_activate(a6xx_gpu->llc_slice)) {
@@ -2020,7 +2020,7 @@ static void a7xx_llc_activate(struct a6xx_gpu *a6xx_gpu)
        struct adreno_gpu *adreno_gpu = &a6xx_gpu->base;
        struct msm_gpu *gpu = &adreno_gpu->base;
 
-       if (IS_ERR(a6xx_gpu->cx_misc_mmio))
+       if (IS_ERR_OR_NULL(a6xx_gpu->llc_slice) && IS_ERR_OR_NULL(a6xx_gpu->htw_llc_slice))
                return;
 
        if (!llcc_slice_activate(a6xx_gpu->llc_slice)) {
@@ -2057,31 +2057,12 @@ static void a6xx_llc_slices_destroy(struct a6xx_gpu *a6xx_gpu)
 static void a6xx_llc_slices_init(struct platform_device *pdev,
                struct a6xx_gpu *a6xx_gpu, bool is_a7xx)
 {
-       struct device_node *phandle;
-
        /* No LLCC on non-RPMh (and by extension, non-GMU) SoCs */
        if (adreno_has_gmu_wrapper(&a6xx_gpu->base))
                return;
 
-       /*
-        * There is a different programming path for A6xx targets with an
-        * mmu500 attached, so detect if that is the case
-        */
-       phandle = of_parse_phandle(pdev->dev.of_node, "iommus", 0);
-       a6xx_gpu->have_mmu500 = (phandle &&
-               of_device_is_compatible(phandle, "arm,mmu-500"));
-       of_node_put(phandle);
-
-       if (is_a7xx || !a6xx_gpu->have_mmu500)
-               a6xx_gpu->cx_misc_mmio = msm_ioremap(pdev, "cx_mem");
-       else
-               a6xx_gpu->cx_misc_mmio = NULL;
-
        a6xx_gpu->llc_slice = llcc_slice_getd(LLCC_GPU);
        a6xx_gpu->htw_llc_slice = llcc_slice_getd(LLCC_GPUHTW);
-
-       if (IS_ERR_OR_NULL(a6xx_gpu->llc_slice) && IS_ERR_OR_NULL(a6xx_gpu->htw_llc_slice))
-               a6xx_gpu->cx_misc_mmio = ERR_PTR(-EINVAL);
 }
 
 #define GBIF_CLIENT_HALT_MASK          BIT(0)
@@ -2679,6 +2660,7 @@ static struct msm_gpu *a6xx_gpu_init(struct drm_device *dev)
        struct platform_device *pdev = priv->gpu_pdev;
        struct adreno_platform_config *config = pdev->dev.platform_data;
        const struct adreno_info *info = config->info;
+       struct device_node *phandle;
        struct a6xx_gpu *a6xx_gpu;
        struct adreno_gpu *adreno_gpu;
        struct msm_gpu *gpu;
@@ -2729,6 +2711,20 @@ static struct msm_gpu *a6xx_gpu_init(struct drm_device *dev)
 
        a6xx_llc_slices_init(pdev, a6xx_gpu, is_a7xx);
 
+       /*
+        * There is a different programming path for A6xx targets with an
+        * mmu500 attached, so detect if that is the case
+        */
+       phandle = of_parse_phandle(pdev->dev.of_node, "iommus", 0);
+       a6xx_gpu->have_mmu500 = (phandle &&
+               of_device_is_compatible(phandle, "arm,mmu-500"));
+       of_node_put(phandle);
+
+       if (is_a7xx || !a6xx_gpu->have_mmu500)
+               a6xx_gpu->cx_misc_mmio = msm_ioremap(pdev, "cx_mem");
+       else
+               a6xx_gpu->cx_misc_mmio = NULL;
+
        ret = a6xx_set_supported_hw(&pdev->dev, a6xx_gpu, info);
        if (ret) {
                a6xx_llc_slices_destroy(a6xx_gpu);