Hi, Static analysis with Coverity has found an issue with the sxgbe driver in drivers/net/ethernet/samsung/sxgbe/sxgbe_mtl.c from the following commit:
commit 1edb9ca69e8a7988900fc0283e10550b5592164d Author: Siva Reddy <siva.kal...@samsung.com> Date: Tue Mar 25 12:10:54 2014 -0700 net: sxgbe: add basic framework for Samsung 10Gb ethernet driver The analysis is as follows: 20 static void sxgbe_mtl_init(void __iomem *ioaddr, unsigned int etsalg, 21 unsigned int raa) 22 { 23 u32 reg_val; 24 25 reg_val = readl(ioaddr + SXGBE_MTL_OP_MODE_REG); 26 reg_val &= ETS_RST; 27 28 /* ETS Algorith */ 29 switch (etsalg & SXGBE_MTL_OPMODE_ESTMASK) { Logically dead code (DEADCODE) 30 case ETS_WRR: 31 reg_val &= ETS_WRR; 32 break; Logically dead code (DEADCODE) 33 case ETS_WFQ: 34 reg_val |= ETS_WFQ; 35 break; Logically dead code (DEADCODE) 36 case ETS_DWRR: 37 reg_val |= ETS_DWRR; 38 break; 39 } Above: SXGBE_MTL_OPMODE_ESTMASK is 0x3 ETS_WRR is 0xFFFFFFFB ETS_WFQ is 0x00000020 ETS_DWRR is 0x00000040 so none of the case statements are ever reachable because of the mask being used. 40 writel(reg_val, ioaddr + SXGBE_MTL_OP_MODE_REG); 41 42 switch (raa & SXGBE_MTL_OPMODE_RAAMASK) { Logically dead code (DEADCODE) 43 case RAA_SP: 44 reg_val &= RAA_SP; 45 break; Logically dead code (DEADCODE) 46 case RAA_WSP: 47 reg_val |= RAA_WSP; 48 break; 49 } 50 writel(reg_val, ioaddr + SXGBE_MTL_OP_MODE_REG); 51} And above, SXGBE_MTL_OPMODE_RAAMASK is 0x1 RAA_SP is 0xFFFFFFFB RAA_WSP is 0x00000004 again, none of the case statements are ever reachable because of the mask being used. Not sure of how this was meant to work, so I can't determine a fix, hence I'm reporting this issue. Colin