qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v3 0/3] hw/dma: Add error handling for loading descriptions failing
@ 2024-06-13  1:34 Fea.Wang
  2024-06-13  1:34 ` [PATCH v3 1/3] hw/dma: Enhance error handling in loading description Fea.Wang
                   ` (2 more replies)
  0 siblings, 3 replies; 5+ messages in thread
From: Fea.Wang @ 2024-06-13  1:34 UTC (permalink / raw)
  To: qemu-devel, qemu-riscv
  Cc: Edgar E. Iglesias, Alistair Francis, Peter Maydell, Jason Wang,
	open list:Xilinx Zynq, Fea.Wang

The original code assumes that memory transmission is always successful,
but in some cases, it gets bus-error.

Add error handling for DMA reading description failures. Do some
reasonable settings, and return the corrected transmission size.
Finally, return the error status.

* Fix the trace format for an unsigned variable

base-commit: d82f37faf5643897b2e61abb229499d64a51aa26

[v2]
* Add DMASR_DECERR case
* Squash the two commits to one

base-commit: 915758c537b5fe09575291f4acd87e2d377a93de


[v1]
base-commit: 1806da76cb81088ea026ca3441551782b850e393

Fea.Wang (3):
  hw/dma: Enhance error handling in loading description
  hw/dma: Add a trace log for a description loading failure
  hw/net: Fix the transmission return size

Fea.Wang (3):
  hw/dma: Enhance error handling in loading description
  hw/dma: Add a trace log for a description loading failure
  hw/net: Fix the transmission return size

 hw/dma/trace-events     |  3 +++
 hw/dma/xilinx_axidma.c  | 33 +++++++++++++++++++++++++++++----
 hw/net/xilinx_axienet.c |  2 +-
 3 files changed, 33 insertions(+), 5 deletions(-)

-- 
2.34.1



^ permalink raw reply	[flat|nested] 5+ messages in thread

* [PATCH v3 1/3] hw/dma: Enhance error handling in loading description
  2024-06-13  1:34 [PATCH v3 0/3] hw/dma: Add error handling for loading descriptions failing Fea.Wang
@ 2024-06-13  1:34 ` Fea.Wang
  2024-06-13  1:35 ` [PATCH v3 2/3] hw/dma: Add a trace log for a description loading failure Fea.Wang
  2024-06-13  1:35 ` [PATCH v3 3/3] hw/net: Fix the transmission return size Fea.Wang
  2 siblings, 0 replies; 5+ messages in thread
From: Fea.Wang @ 2024-06-13  1:34 UTC (permalink / raw)
  To: qemu-devel, qemu-riscv
  Cc: Edgar E. Iglesias, Alistair Francis, Peter Maydell, Jason Wang,
	open list:Xilinx Zynq, Fea.Wang, Frank Chang

Loading a description from memory may cause a bus-error. In this
case, the DMA should stop working, set the error flag, and return
the failure value.

When calling the loading a description function, it should be noticed
that the function may return a failure value. Breaking the loop in this
case is one of the possible ways to handle it.

Signed-off-by: Fea.Wang <fea.wang@sifive.com>
Reviewed-by: Frank Chang <frank.chang@sifive.com>
---
 hw/dma/xilinx_axidma.c | 30 ++++++++++++++++++++++++++----
 1 file changed, 26 insertions(+), 4 deletions(-)

diff --git a/hw/dma/xilinx_axidma.c b/hw/dma/xilinx_axidma.c
index 0ae056ed06..ad307994c2 100644
--- a/hw/dma/xilinx_axidma.c
+++ b/hw/dma/xilinx_axidma.c
@@ -71,8 +71,11 @@ enum {
 enum {
     DMASR_HALTED = 1,
     DMASR_IDLE  = 2,
+    DMASR_SLVERR = 1 << 5,
+    DMASR_DECERR = 1 << 6,
     DMASR_IOC_IRQ  = 1 << 12,
     DMASR_DLY_IRQ  = 1 << 13,
+    DMASR_ERR_IRQ  = 1 << 14,
 
     DMASR_IRQ_MASK = 7 << 12
 };
@@ -190,17 +193,32 @@ static inline int streamid_from_addr(hwaddr addr)
     return sid;
 }
 
-static void stream_desc_load(struct Stream *s, hwaddr addr)
+static MemTxResult stream_desc_load(struct Stream *s, hwaddr addr)
 {
     struct SDesc *d = &s->desc;
 
-    address_space_read(&s->dma->as, addr, MEMTXATTRS_UNSPECIFIED, d, sizeof *d);
+    MemTxResult result = address_space_read(&s->dma->as,
+                                            addr, MEMTXATTRS_UNSPECIFIED,
+                                            d, sizeof *d);
+    if (result != MEMTX_OK) {
+        if (result == MEMTX_DECODE_ERROR) {
+            s->regs[R_DMASR] |= DMASR_DECERR;
+        } else {
+            s->regs[R_DMASR] |= DMASR_SLVERR;
+        }
+
+        s->regs[R_DMACR] &= ~DMACR_RUNSTOP;
+        s->regs[R_DMASR] |= DMASR_HALTED;
+        s->regs[R_DMASR] |= DMASR_ERR_IRQ;
+        return result;
+    }
 
     /* Convert from LE into host endianness.  */
     d->buffer_address = le64_to_cpu(d->buffer_address);
     d->nxtdesc = le64_to_cpu(d->nxtdesc);
     d->control = le32_to_cpu(d->control);
     d->status = le32_to_cpu(d->status);
+    return result;
 }
 
 static void stream_desc_store(struct Stream *s, hwaddr addr)
@@ -279,7 +297,9 @@ static void stream_process_mem2s(struct Stream *s, StreamSink *tx_data_dev,
     }
 
     while (1) {
-        stream_desc_load(s, s->regs[R_CURDESC]);
+        if (MEMTX_OK != stream_desc_load(s, s->regs[R_CURDESC])) {
+            break;
+        }
 
         if (s->desc.status & SDESC_STATUS_COMPLETE) {
             s->regs[R_DMASR] |= DMASR_HALTED;
@@ -336,7 +356,9 @@ static size_t stream_process_s2mem(struct Stream *s, unsigned char *buf,
     }
 
     while (len) {
-        stream_desc_load(s, s->regs[R_CURDESC]);
+        if (MEMTX_OK != stream_desc_load(s, s->regs[R_CURDESC])) {
+            break;
+        }
 
         if (s->desc.status & SDESC_STATUS_COMPLETE) {
             s->regs[R_DMASR] |= DMASR_HALTED;
-- 
2.34.1



^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [PATCH v3 2/3] hw/dma: Add a trace log for a description loading failure
  2024-06-13  1:34 [PATCH v3 0/3] hw/dma: Add error handling for loading descriptions failing Fea.Wang
  2024-06-13  1:34 ` [PATCH v3 1/3] hw/dma: Enhance error handling in loading description Fea.Wang
@ 2024-06-13  1:35 ` Fea.Wang
  2024-06-18 10:54   ` Philippe Mathieu-Daudé
  2024-06-13  1:35 ` [PATCH v3 3/3] hw/net: Fix the transmission return size Fea.Wang
  2 siblings, 1 reply; 5+ messages in thread
From: Fea.Wang @ 2024-06-13  1:35 UTC (permalink / raw)
  To: qemu-devel, qemu-riscv
  Cc: Edgar E. Iglesias, Alistair Francis, Peter Maydell, Jason Wang,
	open list:Xilinx Zynq, Fea.Wang, Edgar E . Iglesias, Frank Chang

Due to a description loading failure, adding a trace log makes observing
the DMA behavior easy.

Signed-off-by: Fea.Wang <fea.wang@sifive.com>
Reviewed-by: Edgar E. Iglesias <edgar.iglesias@amd.com>
Reviewed-by: Frank Chang <frank.chang@sifive.com>
---
 hw/dma/trace-events    | 3 +++
 hw/dma/xilinx_axidma.c | 3 +++
 2 files changed, 6 insertions(+)

diff --git a/hw/dma/trace-events b/hw/dma/trace-events
index 3c47df54e4..4c09790f9a 100644
--- a/hw/dma/trace-events
+++ b/hw/dma/trace-events
@@ -44,3 +44,6 @@ pl330_debug_exec_stall(void) "stall of debug instruction not implemented"
 pl330_iomem_write(uint32_t offset, uint32_t value) "addr: 0x%08"PRIx32" data: 0x%08"PRIx32
 pl330_iomem_write_clr(int i) "event interrupt lowered %d"
 pl330_iomem_read(uint32_t addr, uint32_t data) "addr: 0x%08"PRIx32" data: 0x%08"PRIx32
+
+# xilinx_axidma.c
+xilinx_axidma_loading_desc_fail(uint32_t res) "error:%u"
diff --git a/hw/dma/xilinx_axidma.c b/hw/dma/xilinx_axidma.c
index ad307994c2..c9cfc3169b 100644
--- a/hw/dma/xilinx_axidma.c
+++ b/hw/dma/xilinx_axidma.c
@@ -36,6 +36,7 @@
 #include "sysemu/dma.h"
 #include "hw/stream.h"
 #include "qom/object.h"
+#include "trace.h"
 
 #define D(x)
 
@@ -201,6 +202,8 @@ static MemTxResult stream_desc_load(struct Stream *s, hwaddr addr)
                                             addr, MEMTXATTRS_UNSPECIFIED,
                                             d, sizeof *d);
     if (result != MEMTX_OK) {
+        trace_xilinx_axidma_loading_desc_fail(result);
+
         if (result == MEMTX_DECODE_ERROR) {
             s->regs[R_DMASR] |= DMASR_DECERR;
         } else {
-- 
2.34.1



^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [PATCH v3 3/3] hw/net: Fix the transmission return size
  2024-06-13  1:34 [PATCH v3 0/3] hw/dma: Add error handling for loading descriptions failing Fea.Wang
  2024-06-13  1:34 ` [PATCH v3 1/3] hw/dma: Enhance error handling in loading description Fea.Wang
  2024-06-13  1:35 ` [PATCH v3 2/3] hw/dma: Add a trace log for a description loading failure Fea.Wang
@ 2024-06-13  1:35 ` Fea.Wang
  2 siblings, 0 replies; 5+ messages in thread
From: Fea.Wang @ 2024-06-13  1:35 UTC (permalink / raw)
  To: qemu-devel, qemu-riscv
  Cc: Edgar E. Iglesias, Alistair Francis, Peter Maydell, Jason Wang,
	open list:Xilinx Zynq, Fea.Wang, Edgar E . Iglesias, Frank Chang

Fix the transmission return size because not all bytes could be
transmitted successfully. So, return a successful length instead of a
constant value.

Signed-off-by: Fea.Wang <fea.wang@sifive.com>
Reviewed-by: Edgar E. Iglesias <edgar.iglesias@amd.com>
Reviewed-by: Frank Chang <frank.chang@sifive.com>
---
 hw/net/xilinx_axienet.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/hw/net/xilinx_axienet.c b/hw/net/xilinx_axienet.c
index 7d1fd37b4a..05d41bd548 100644
--- a/hw/net/xilinx_axienet.c
+++ b/hw/net/xilinx_axienet.c
@@ -847,7 +847,7 @@ static ssize_t eth_rx(NetClientState *nc, const uint8_t *buf, size_t size)
     axienet_eth_rx_notify(s);
 
     enet_update_irq(s);
-    return size;
+    return s->rxpos;
 }
 
 static size_t
-- 
2.34.1



^ permalink raw reply related	[flat|nested] 5+ messages in thread

* Re: [PATCH v3 2/3] hw/dma: Add a trace log for a description loading failure
  2024-06-13  1:35 ` [PATCH v3 2/3] hw/dma: Add a trace log for a description loading failure Fea.Wang
@ 2024-06-18 10:54   ` Philippe Mathieu-Daudé
  0 siblings, 0 replies; 5+ messages in thread
From: Philippe Mathieu-Daudé @ 2024-06-18 10:54 UTC (permalink / raw)
  To: Fea.Wang, qemu-devel, qemu-riscv
  Cc: Edgar E. Iglesias, Alistair Francis, Peter Maydell, Jason Wang,
	open list:Xilinx Zynq, Edgar E . Iglesias, Frank Chang

On 13/6/24 03:35, Fea.Wang wrote:
> Due to a description loading failure, adding a trace log makes observing
> the DMA behavior easy.
> 
> Signed-off-by: Fea.Wang <fea.wang@sifive.com>
> Reviewed-by: Edgar E. Iglesias <edgar.iglesias@amd.com>
> Reviewed-by: Frank Chang <frank.chang@sifive.com>
> ---
>   hw/dma/trace-events    | 3 +++
>   hw/dma/xilinx_axidma.c | 3 +++
>   2 files changed, 6 insertions(+)

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>



^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2024-06-18 10:55 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-06-13  1:34 [PATCH v3 0/3] hw/dma: Add error handling for loading descriptions failing Fea.Wang
2024-06-13  1:34 ` [PATCH v3 1/3] hw/dma: Enhance error handling in loading description Fea.Wang
2024-06-13  1:35 ` [PATCH v3 2/3] hw/dma: Add a trace log for a description loading failure Fea.Wang
2024-06-18 10:54   ` Philippe Mathieu-Daudé
2024-06-13  1:35 ` [PATCH v3 3/3] hw/net: Fix the transmission return size Fea.Wang

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).