summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLucas Stach <l.stach@pengutronix.de>2018-07-23 14:27:23 +0200
committerLucas Stach <l.stach@pengutronix.de>2018-08-06 15:24:33 +0200
commit5b147465532365dc4e2fee8499d6ca1f52dd0d16 (patch)
treebc81acaeaa17c14b39ef22f10704e62f5cb6ac27
parentcfad05a24dcb2bf09ba6438e0843c6a0ed90381c (diff)
downloadop-kernel-dev-5b147465532365dc4e2fee8499d6ca1f52dd0d16.zip
op-kernel-dev-5b147465532365dc4e2fee8499d6ca1f52dd0d16.tar.gz
drm/etnaviv: fix crash in GPU suspend when init failed due to buffer placement
When the suballocator was unable to provide a suitable buffer for the MMUv1 linear window, we roll back the GPU initialization. As the GPU is runtime resumed at that point we need to clear the kernel cmdbuf suballoc entry to properly skip any attempt to manipulate the cmdbuf when the GPU gets shut down in the runtime suspend later on. Signed-off-by: Lucas Stach <l.stach@pengutronix.de>
-rw-r--r--drivers/gpu/drm/etnaviv/etnaviv_gpu.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/gpu/drm/etnaviv/etnaviv_gpu.c b/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
index 18c2224..ab8dfe7 100644
--- a/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
+++ b/drivers/gpu/drm/etnaviv/etnaviv_gpu.c
@@ -799,6 +799,7 @@ int etnaviv_gpu_init(struct etnaviv_gpu *gpu)
free_buffer:
etnaviv_cmdbuf_free(&gpu->buffer);
+ gpu->buffer.suballoc = NULL;
destroy_iommu:
etnaviv_iommu_destroy(gpu->mmu);
gpu->mmu = NULL;
OpenPOWER on IntegriCloud