dmaengine: ioatdma: add error strings to chanerr output
Provide a mechanism to translate CHANERR bits to English strings in order to allow user to report more concise errors. Signed-off-by: Dave Jiang <dave.jiang@intel.com> Reviewed-by: Lars-Peter Clausen <lars@metafoo.de> Signed-off-by: Vinod Koul <vinod.koul@intel.com>
This commit is contained in:
parent
9546d4cdc8
commit
aed681d1dc
@ -38,8 +38,54 @@
|
|||||||
|
|
||||||
#include "../dmaengine.h"
|
#include "../dmaengine.h"
|
||||||
|
|
||||||
|
static char *chanerr_str[] = {
|
||||||
|
"DMA Transfer Destination Address Error",
|
||||||
|
"Next Descriptor Address Error",
|
||||||
|
"Descriptor Error",
|
||||||
|
"Chan Address Value Error",
|
||||||
|
"CHANCMD Error",
|
||||||
|
"Chipset Uncorrectable Data Integrity Error",
|
||||||
|
"DMA Uncorrectable Data Integrity Error",
|
||||||
|
"Read Data Error",
|
||||||
|
"Write Data Error",
|
||||||
|
"Descriptor Control Error",
|
||||||
|
"Descriptor Transfer Size Error",
|
||||||
|
"Completion Address Error",
|
||||||
|
"Interrupt Configuration Error",
|
||||||
|
"Super extended descriptor Address Error",
|
||||||
|
"Unaffiliated Error",
|
||||||
|
"CRC or XOR P Error",
|
||||||
|
"XOR Q Error",
|
||||||
|
"Descriptor Count Error",
|
||||||
|
"DIF All F detect Error",
|
||||||
|
"Guard Tag verification Error",
|
||||||
|
"Application Tag verification Error",
|
||||||
|
"Reference Tag verification Error",
|
||||||
|
"Bundle Bit Error",
|
||||||
|
"Result DIF All F detect Error",
|
||||||
|
"Result Guard Tag verification Error",
|
||||||
|
"Result Application Tag verification Error",
|
||||||
|
"Result Reference Tag verification Error",
|
||||||
|
NULL
|
||||||
|
};
|
||||||
|
|
||||||
static void ioat_eh(struct ioatdma_chan *ioat_chan);
|
static void ioat_eh(struct ioatdma_chan *ioat_chan);
|
||||||
|
|
||||||
|
static void ioat_print_chanerrs(struct ioatdma_chan *ioat_chan, u32 chanerr)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < 32; i++) {
|
||||||
|
if ((chanerr >> i) & 1) {
|
||||||
|
if (chanerr_str[i]) {
|
||||||
|
dev_err(to_dev(ioat_chan), "Err(%d): %s\n",
|
||||||
|
i, chanerr_str[i]);
|
||||||
|
} else
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ioat_dma_do_interrupt - handler used for single vector interrupt mode
|
* ioat_dma_do_interrupt - handler used for single vector interrupt mode
|
||||||
* @irq: interrupt id
|
* @irq: interrupt id
|
||||||
@ -774,6 +820,11 @@ static void ioat_eh(struct ioatdma_chan *ioat_chan)
|
|||||||
if (chanerr ^ err_handled || chanerr == 0) {
|
if (chanerr ^ err_handled || chanerr == 0) {
|
||||||
dev_err(to_dev(ioat_chan), "%s: fatal error (%x:%x)\n",
|
dev_err(to_dev(ioat_chan), "%s: fatal error (%x:%x)\n",
|
||||||
__func__, chanerr, err_handled);
|
__func__, chanerr, err_handled);
|
||||||
|
dev_err(to_dev(ioat_chan), "Errors handled:\n");
|
||||||
|
ioat_print_chanerrs(ioat_chan, err_handled);
|
||||||
|
dev_err(to_dev(ioat_chan), "Errors not handled:\n");
|
||||||
|
ioat_print_chanerrs(ioat_chan, (chanerr & ~err_handled));
|
||||||
|
|
||||||
BUG();
|
BUG();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -833,6 +884,9 @@ void ioat_timer_event(unsigned long data)
|
|||||||
chanerr = readl(ioat_chan->reg_base + IOAT_CHANERR_OFFSET);
|
chanerr = readl(ioat_chan->reg_base + IOAT_CHANERR_OFFSET);
|
||||||
dev_err(to_dev(ioat_chan), "%s: Channel halted (%x)\n",
|
dev_err(to_dev(ioat_chan), "%s: Channel halted (%x)\n",
|
||||||
__func__, chanerr);
|
__func__, chanerr);
|
||||||
|
dev_err(to_dev(ioat_chan), "Errors:\n");
|
||||||
|
ioat_print_chanerrs(ioat_chan, chanerr);
|
||||||
|
|
||||||
if (test_bit(IOAT_RUN, &ioat_chan->state)) {
|
if (test_bit(IOAT_RUN, &ioat_chan->state)) {
|
||||||
spin_lock_bh(&ioat_chan->cleanup_lock);
|
spin_lock_bh(&ioat_chan->cleanup_lock);
|
||||||
spin_lock_bh(&ioat_chan->prep_lock);
|
spin_lock_bh(&ioat_chan->prep_lock);
|
||||||
@ -875,10 +929,13 @@ void ioat_timer_event(unsigned long data)
|
|||||||
u32 chanerr;
|
u32 chanerr;
|
||||||
|
|
||||||
chanerr = readl(ioat_chan->reg_base + IOAT_CHANERR_OFFSET);
|
chanerr = readl(ioat_chan->reg_base + IOAT_CHANERR_OFFSET);
|
||||||
dev_warn(to_dev(ioat_chan), "CHANSTS: %#Lx CHANERR: %#x\n",
|
dev_err(to_dev(ioat_chan), "CHANSTS: %#Lx CHANERR: %#x\n",
|
||||||
status, chanerr);
|
status, chanerr);
|
||||||
dev_warn(to_dev(ioat_chan), "Active descriptors: %d\n",
|
dev_err(to_dev(ioat_chan), "Errors:\n");
|
||||||
ioat_ring_active(ioat_chan));
|
ioat_print_chanerrs(ioat_chan, chanerr);
|
||||||
|
|
||||||
|
dev_dbg(to_dev(ioat_chan), "Active descriptors: %d\n",
|
||||||
|
ioat_ring_active(ioat_chan));
|
||||||
|
|
||||||
spin_lock_bh(&ioat_chan->prep_lock);
|
spin_lock_bh(&ioat_chan->prep_lock);
|
||||||
set_bit(IOAT_CHAN_DOWN, &ioat_chan->state);
|
set_bit(IOAT_CHAN_DOWN, &ioat_chan->state);
|
||||||
|
Loading…
Reference in New Issue
Block a user