drm/panfrost: Fix the panfrost_mmu_map_fault_addr() error path
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: 187d292920
("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
This commit is contained in:
parent
7f67aa097e
commit
764a2ab9eb
@ -504,6 +504,7 @@ static int panfrost_mmu_map_fault_addr(struct panfrost_device *pfdev, int as,
|
|||||||
if (IS_ERR(pages[i])) {
|
if (IS_ERR(pages[i])) {
|
||||||
mutex_unlock(&bo->base.pages_lock);
|
mutex_unlock(&bo->base.pages_lock);
|
||||||
ret = PTR_ERR(pages[i]);
|
ret = PTR_ERR(pages[i]);
|
||||||
|
pages[i] = NULL;
|
||||||
goto err_pages;
|
goto err_pages;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user