mailbox/bcm2835: Fix mailbox full detection.
authorEric Anholt <eric@anholt.net>
Wed, 13 May 2015 20:10:32 +0000 (13:10 -0700)
committerJassi Brar <jaswinder.singh@linaro.org>
Sat, 13 Jun 2015 10:50:39 +0000 (16:20 +0530)
With the VC reader blocked and the ARM writing, MAIL0_STA reads empty
permanently while MAIL1_STA goes from empty (0x40000000) to non-empty
(0x00000001-0x00000007) to full (0x80000008).

This bug ended up having no effect on us, because all of our
transactions in the client driver were synchronous and under a mutex.

Suggested-by: Phil Elwell <phil@raspberrypi.org>
Signed-off-by: Eric Anholt <eric@anholt.net>
Acked-by: Stephen Warren <swarren@wwwdotorg.org>
Signed-off-by: Jassi Brar <jaswinder.singh@linaro.org>
drivers/mailbox/bcm2835-mailbox.c

index 4b13268529f94e6e9648f5b4919ab48b53280fa0..0b47dd42f3bdbd37fab111bc726e0de3464b31f3 100644 (file)
@@ -49,6 +49,7 @@
 #define MAIL0_STA      (ARM_0_MAIL0 + 0x18)
 #define MAIL0_CNF      (ARM_0_MAIL0 + 0x1C)
 #define MAIL1_WRT      (ARM_0_MAIL1 + 0x00)
+#define MAIL1_STA      (ARM_0_MAIL1 + 0x18)
 
 /* Status register: FIFO state. */
 #define ARM_MS_FULL            BIT(31)
@@ -117,7 +118,7 @@ static bool bcm2835_last_tx_done(struct mbox_chan *link)
        bool ret;
 
        spin_lock(&mbox->lock);
-       ret = !(readl(mbox->regs + MAIL0_STA) & ARM_MS_FULL);
+       ret = !(readl(mbox->regs + MAIL1_STA) & ARM_MS_FULL);
        spin_unlock(&mbox->lock);
        return ret;
 }