dmaengine: ioatdma: loop for number elements in array chanerr_str
authorColin Ian King <colin.king@canonical.com>
Sun, 16 Oct 2016 12:25:47 +0000 (13:25 +0100)
committerVinod Koul <vinod.koul@intel.com>
Wed, 19 Oct 2016 14:47:01 +0000 (20:17 +0530)
Just iterate over the number of elements in array chanerr_str rather
than for all 32 bits.  This removes the need for a NULL chanerr_str[i]
check which could possibly overrun if the upper bits (28..31) of
chanerr are set and 27th bit in chanerr is zero. This simplifies the
code by removing an if statement and a break.

Signed-off-by: Colin Ian King <colin.king@canonical.com>
Signed-off-by: Vinod Koul <vinod.koul@intel.com>
drivers/dma/ioat/dma.c

index 49386ce..42ff307 100644 (file)
@@ -66,7 +66,6 @@ static char *chanerr_str[] = {
        "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);
@@ -75,13 +74,10 @@ static void ioat_print_chanerrs(struct ioatdma_chan *ioat_chan, u32 chanerr)
 {
        int i;
 
-       for (i = 0; i < 32; i++) {
+       for (i = 0; i < ARRAY_SIZE(chanerr_str); 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;
+                       dev_err(to_dev(ioat_chan), "Err(%d): %s\n",
+                               i, chanerr_str[i]);
                }
        }
 }