drm/panfrost: Fix the panfrost_mmu_map_fault_addr() error path
authorBoris Brezillon <boris.brezillon@collabora.com>
Fri, 21 May 2021 09:38:11 +0000 (11:38 +0200)
committerBoris Brezillon <boris.brezillon@collabora.com>
Mon, 3 Apr 2023 06:23:42 +0000 (08:23 +0200)
Make sure all bo->base.pages entries are either NULL or pointing to a
valid page before calling drm_gem_shmem_put_pages().

Reported-by: Tomeu Vizoso <tomeu.vizoso@collabora.com>
Cc: <stable@vger.kernel.org>
Fixes: 187d2929206e ("drm/panfrost: Add support for GPU heap allocations")
Signed-off-by: Boris Brezillon <boris.brezillon@collabora.com>
Reviewed-by: Steven Price <steven.price@arm.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20210521093811.1018992-1-boris.brezillon@collabora.com
drivers/gpu/drm/panfrost/panfrost_mmu.c

index 666a5e5..e961fa2 100644 (file)
@@ -504,6 +504,7 @@ static int panfrost_mmu_map_fault_addr(struct panfrost_device *pfdev, int as,
                if (IS_ERR(pages[i])) {
                        mutex_unlock(&bo->base.pages_lock);
                        ret = PTR_ERR(pages[i]);
+                       pages[i] = NULL;
                        goto err_pages;
                }
        }