* [PATCH v2 0/3] hw/dma: Add error handling for loading descriptions failing @ 2024-06-04 7:15 Fea.Wang 2024-06-04 7:15 ` [PATCH v2 1/3] hw/dma: Enhance error handling in loading description Fea.Wang ` (2 more replies) 0 siblings, 3 replies; 7+ messages in thread From: Fea.Wang @ 2024-06-04 7:15 UTC (permalink / raw) To: qemu-devel 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. * 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 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] 7+ messages in thread
* [PATCH v2 1/3] hw/dma: Enhance error handling in loading description 2024-06-04 7:15 [PATCH v2 0/3] hw/dma: Add error handling for loading descriptions failing Fea.Wang @ 2024-06-04 7:15 ` Fea.Wang 2024-06-06 11:55 ` Edgar E. Iglesias 2024-06-04 7:15 ` [PATCH v2 2/3] hw/dma: Add a trace log for a description loading failure Fea.Wang 2024-06-04 7:15 ` [PATCH v2 3/3] hw/net: Fix the transmission return size Fea.Wang 2 siblings, 1 reply; 7+ messages in thread From: Fea.Wang @ 2024-06-04 7:15 UTC (permalink / raw) To: qemu-devel 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] 7+ messages in thread
* Re: [PATCH v2 1/3] hw/dma: Enhance error handling in loading description 2024-06-04 7:15 ` [PATCH v2 1/3] hw/dma: Enhance error handling in loading description Fea.Wang @ 2024-06-06 11:55 ` Edgar E. Iglesias 0 siblings, 0 replies; 7+ messages in thread From: Edgar E. Iglesias @ 2024-06-06 11:55 UTC (permalink / raw) To: Fea.Wang Cc: qemu-devel, Alistair Francis, Peter Maydell, Jason Wang, open list:Xilinx Zynq, Frank Chang [-- Attachment #1: Type: text/plain, Size: 3363 bytes --] On Tue, Jun 4, 2024 at 9:10 AM Fea.Wang <fea.wang@sifive.com> wrote: > 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> > Thanks! Reviewed-by: Edgar E. Iglesias <edgar.iglesias@amd.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 > > [-- Attachment #2: Type: text/html, Size: 4544 bytes --] ^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH v2 2/3] hw/dma: Add a trace log for a description loading failure 2024-06-04 7:15 [PATCH v2 0/3] hw/dma: Add error handling for loading descriptions failing Fea.Wang 2024-06-04 7:15 ` [PATCH v2 1/3] hw/dma: Enhance error handling in loading description Fea.Wang @ 2024-06-04 7:15 ` Fea.Wang 2024-06-10 11:48 ` Philippe Mathieu-Daudé 2024-06-04 7:15 ` [PATCH v2 3/3] hw/net: Fix the transmission return size Fea.Wang 2 siblings, 1 reply; 7+ messages in thread From: Fea.Wang @ 2024-06-04 7:15 UTC (permalink / raw) To: qemu-devel 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..95db083be4 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:%d" 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] 7+ messages in thread
* Re: [PATCH v2 2/3] hw/dma: Add a trace log for a description loading failure 2024-06-04 7:15 ` [PATCH v2 2/3] hw/dma: Add a trace log for a description loading failure Fea.Wang @ 2024-06-10 11:48 ` Philippe Mathieu-Daudé 2024-06-13 1:24 ` Fea Wang 0 siblings, 1 reply; 7+ messages in thread From: Philippe Mathieu-Daudé @ 2024-06-10 11:48 UTC (permalink / raw) To: Fea.Wang, qemu-devel Cc: Edgar E. Iglesias, Alistair Francis, Peter Maydell, Jason Wang, open list:Xilinx Zynq, Edgar E . Iglesias, Frank Chang Hi Fea, On 4/6/24 09:15, 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(+) > +# xilinx_axidma.c > +xilinx_axidma_loading_desc_fail(uint32_t res) "error:%d" Unsigned format is "%u". Regards, Phil. ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v2 2/3] hw/dma: Add a trace log for a description loading failure 2024-06-10 11:48 ` Philippe Mathieu-Daudé @ 2024-06-13 1:24 ` Fea Wang 0 siblings, 0 replies; 7+ messages in thread From: Fea Wang @ 2024-06-13 1:24 UTC (permalink / raw) To: Philippe Mathieu-Daudé Cc: qemu-devel, Edgar E. Iglesias, Alistair Francis, Peter Maydell, Jason Wang, open list:Xilinx Zynq, Edgar E . Iglesias, Frank Chang [-- Attachment #1: Type: text/plain, Size: 775 bytes --] Sure, I will fix it in the next patch series. Thank you Sincerely, Fea On Mon, Jun 10, 2024 at 7:49 PM Philippe Mathieu-Daudé <philmd@linaro.org> wrote: > Hi Fea, > > On 4/6/24 09:15, 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(+) > > > > +# xilinx_axidma.c > > +xilinx_axidma_loading_desc_fail(uint32_t res) "error:%d" > > Unsigned format is "%u". > > Regards, > > Phil. > [-- Attachment #2: Type: text/html, Size: 1407 bytes --] ^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH v2 3/3] hw/net: Fix the transmission return size 2024-06-04 7:15 [PATCH v2 0/3] hw/dma: Add error handling for loading descriptions failing Fea.Wang 2024-06-04 7:15 ` [PATCH v2 1/3] hw/dma: Enhance error handling in loading description Fea.Wang 2024-06-04 7:15 ` [PATCH v2 2/3] hw/dma: Add a trace log for a description loading failure Fea.Wang @ 2024-06-04 7:15 ` Fea.Wang 2 siblings, 0 replies; 7+ messages in thread From: Fea.Wang @ 2024-06-04 7:15 UTC (permalink / raw) To: qemu-devel 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] 7+ messages in thread
end of thread, other threads:[~2024-06-13 1:25 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2024-06-04 7:15 [PATCH v2 0/3] hw/dma: Add error handling for loading descriptions failing Fea.Wang 2024-06-04 7:15 ` [PATCH v2 1/3] hw/dma: Enhance error handling in loading description Fea.Wang 2024-06-06 11:55 ` Edgar E. Iglesias 2024-06-04 7:15 ` [PATCH v2 2/3] hw/dma: Add a trace log for a description loading failure Fea.Wang 2024-06-10 11:48 ` Philippe Mathieu-Daudé 2024-06-13 1:24 ` Fea Wang 2024-06-04 7:15 ` [PATCH v2 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).