diff mbox series

[V2,3/4] drm/v3d: Don't clear MMU control bits on exception

Message ID 1608755714-18233-4-git-send-email-stefan.wahren@i2se.com
State New
Headers show
Series drm/v3d: Minor improvements | expand

Commit Message

Stefan Wahren Dec. 23, 2020, 8:35 p.m. UTC
From: Phil Elwell <phil@raspberrypi.org>

MMU exception conditions are reported in the V3D_MMU_CTRL register as
write-1-to-clear (W1C) bits. The MMU interrupt handling code clears any
exceptions, but does so by masking out any other bits and writing the
result back. There are some important control bits in that register,
including MMU_ENABLE, so a safer approach is to simply write back the
value just read unaltered.

Signed-off-by: Phil Elwell <phil@raspberrypi.org>
Signed-off-by: Stefan Wahren <stefan.wahren@i2se.com>
---
 drivers/gpu/drm/v3d/v3d_irq.c | 5 +----
 1 file changed, 1 insertion(+), 4 deletions(-)

Comments

maxime@cerno.tech Jan. 6, 2021, 3:09 p.m. UTC | #1
On Wed, Dec 23, 2020 at 09:35:13PM +0100, Stefan Wahren wrote:
> From: Phil Elwell <phil@raspberrypi.org>

> 

> MMU exception conditions are reported in the V3D_MMU_CTRL register as

> write-1-to-clear (W1C) bits. The MMU interrupt handling code clears any

> exceptions, but does so by masking out any other bits and writing the

> result back. There are some important control bits in that register,

> including MMU_ENABLE, so a safer approach is to simply write back the

> value just read unaltered.

> 

> Signed-off-by: Phil Elwell <phil@raspberrypi.org>

> Signed-off-by: Stefan Wahren <stefan.wahren@i2se.com>


Applied, thanks!
Maxime
diff mbox series

Patch

diff --git a/drivers/gpu/drm/v3d/v3d_irq.c b/drivers/gpu/drm/v3d/v3d_irq.c
index 0be2eb7..e714d53 100644
--- a/drivers/gpu/drm/v3d/v3d_irq.c
+++ b/drivers/gpu/drm/v3d/v3d_irq.c
@@ -178,10 +178,7 @@  v3d_hub_irq(int irq, void *arg)
 		};
 		const char *client = "?";
 
-		V3D_WRITE(V3D_MMU_CTL,
-			  V3D_READ(V3D_MMU_CTL) & (V3D_MMU_CTL_CAP_EXCEEDED |
-						   V3D_MMU_CTL_PT_INVALID |
-						   V3D_MMU_CTL_WRITE_VIOLATION));
+		V3D_WRITE(V3D_MMU_CTL, V3D_READ(V3D_MMU_CTL));
 
 		if (v3d->ver >= 41) {
 			axi_id = axi_id >> 5;