qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH] hw/ssi: Fix Linux driver init issue with xilinx_spi


From: Edgar E. Iglesias
Subject: Re: [PATCH] hw/ssi: Fix Linux driver init issue with xilinx_spi
Date: Fri, 31 Mar 2023 12:09:41 +0200


On Thu, Mar 23, 2023 at 7:29 PM Chris Rauer <crauer@google.com> wrote:
The problem is that the Linux driver expects the master transaction inhibit
bit(R_SPICR_MTI) to be set during driver initialization so that it can
detect the fifo size but QEMU defaults it to zero out of reset.  The
datasheet indicates this bit is active on reset.

See page 25, SPI Control Register section:
https://www.xilinx.com/content/dam/xilinx/support/documents/ip_documentation/axi_quad_spi/v3_2/pg153-axi-quad-spi.pdf


Yes, MTI should be set when the device comes out of reset.

Reviewed-by: Edgar E. Iglesias <edgar@zeroasic.com>

 
Signed-off-by: Chris Rauer <crauer@google.com>
---
 hw/ssi/xilinx_spi.c | 1 +
 1 file changed, 1 insertion(+)

diff --git a/hw/ssi/xilinx_spi.c b/hw/ssi/xilinx_spi.c
index 552927622f..d4de2e7aab 100644
--- a/hw/ssi/xilinx_spi.c
+++ b/hw/ssi/xilinx_spi.c
@@ -156,6 +156,7 @@ static void xlx_spi_do_reset(XilinxSPI *s)
     txfifo_reset(s);

     s->regs[R_SPISSR] = ~0;
+    s->regs[R_SPICR] = R_SPICR_MTI;
     xlx_spi_update_irq(s);
     xlx_spi_update_cs(s);
 }
--
2.40.0.348.gf938b09366-goog



reply via email to

[Prev in Thread] Current Thread [Next in Thread]