pl011: fix incorrect logic to set the RXFF flag
authorRob Herring <rob.herring@linaro.org>
Tue, 18 Mar 2014 18:18:41 +0000 (13:18 -0500)
committerPeter Maydell <peter.maydell@linaro.org>
Tue, 18 Mar 2014 19:38:56 +0000 (19:38 +0000)
The receive fifo full bit should be set when 1 character is received and
the fifo is disabled or when 16 characters are in the fifo.

Signed-off-by: Rob Herring <rob.herring@linaro.org>
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Message-id: 1395166721-15716-4-git-send-email-robherring2@gmail.com
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
hw/char/pl011.c

index 11c3a75..644aad7 100644 (file)
@@ -221,7 +221,7 @@ static void pl011_put_fifo(void *opaque, uint32_t value)
     s->read_fifo[slot] = value;
     s->read_count++;
     s->flags &= ~PL011_FLAG_RXFE;
-    if (s->cr & 0x10 || s->read_count == 16) {
+    if (!(s->lcr & 0x10) || s->read_count == 16) {
         s->flags |= PL011_FLAG_RXFF;
     }
     if (s->read_count == s->read_trigger) {