Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

net: lan743x: Add support to SGMII register dump for PCI11010/PCI11414 chips

Add support to SGMII register dump

Signed-off-by: Raju Lakkaraju <Raju.Lakkaraju@microchip.com>
Reviewed-by: Horatiu Vultur <horatiu.vultur@microchip.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>

authored by

Raju Lakkaraju and committed by
Jakub Kicinski
90452205 925638a2

+177 -4
+105 -2
drivers/net/ethernet/microchip/lan743x_ethtool.c
··· 1195 1195 struct lan743x_adapter *adapter = netdev_priv(dev); 1196 1196 u32 *rb = p; 1197 1197 1198 - memset(p, 0, (MAX_LAN743X_ETH_REGS * sizeof(u32))); 1198 + memset(p, 0, (MAX_LAN743X_ETH_COMMON_REGS * sizeof(u32))); 1199 1199 1200 1200 rb[ETH_PRIV_FLAGS] = adapter->flags; 1201 1201 rb[ETH_ID_REV] = lan743x_csr_read(adapter, ID_REV); ··· 1218 1218 rb[ETH_WK_SRC] = lan743x_csr_read(adapter, MAC_WK_SRC); 1219 1219 } 1220 1220 1221 + static void lan743x_sgmii_regs(struct net_device *dev, void *p) 1222 + { 1223 + struct lan743x_adapter *adp = netdev_priv(dev); 1224 + u32 *rb = p; 1225 + u16 idx; 1226 + int val; 1227 + struct { 1228 + u8 id; 1229 + u8 dev; 1230 + u16 addr; 1231 + } regs[] = { 1232 + { ETH_SR_VSMMD_DEV_ID1, MDIO_MMD_VEND1, 0x0002}, 1233 + { ETH_SR_VSMMD_DEV_ID2, MDIO_MMD_VEND1, 0x0003}, 1234 + { ETH_SR_VSMMD_PCS_ID1, MDIO_MMD_VEND1, 0x0004}, 1235 + { ETH_SR_VSMMD_PCS_ID2, MDIO_MMD_VEND1, 0x0005}, 1236 + { ETH_SR_VSMMD_STS, MDIO_MMD_VEND1, 0x0008}, 1237 + { ETH_SR_VSMMD_CTRL, MDIO_MMD_VEND1, 0x0009}, 1238 + { ETH_SR_MII_CTRL, MDIO_MMD_VEND2, 0x0000}, 1239 + { ETH_SR_MII_STS, MDIO_MMD_VEND2, 0x0001}, 1240 + { ETH_SR_MII_DEV_ID1, MDIO_MMD_VEND2, 0x0002}, 1241 + { ETH_SR_MII_DEV_ID2, MDIO_MMD_VEND2, 0x0003}, 1242 + { ETH_SR_MII_AN_ADV, MDIO_MMD_VEND2, 0x0004}, 1243 + { ETH_SR_MII_LP_BABL, MDIO_MMD_VEND2, 0x0005}, 1244 + { ETH_SR_MII_EXPN, MDIO_MMD_VEND2, 0x0006}, 1245 + { ETH_SR_MII_EXT_STS, MDIO_MMD_VEND2, 0x000F}, 1246 + { ETH_SR_MII_TIME_SYNC_ABL, MDIO_MMD_VEND2, 0x0708}, 1247 + { ETH_SR_MII_TIME_SYNC_TX_MAX_DLY_LWR, MDIO_MMD_VEND2, 0x0709}, 1248 + { ETH_SR_MII_TIME_SYNC_TX_MAX_DLY_UPR, MDIO_MMD_VEND2, 0x070A}, 1249 + { ETH_SR_MII_TIME_SYNC_TX_MIN_DLY_LWR, MDIO_MMD_VEND2, 0x070B}, 1250 + { ETH_SR_MII_TIME_SYNC_TX_MIN_DLY_UPR, MDIO_MMD_VEND2, 0x070C}, 1251 + { ETH_SR_MII_TIME_SYNC_RX_MAX_DLY_LWR, MDIO_MMD_VEND2, 0x070D}, 1252 + { ETH_SR_MII_TIME_SYNC_RX_MAX_DLY_UPR, MDIO_MMD_VEND2, 0x070E}, 1253 + { ETH_SR_MII_TIME_SYNC_RX_MIN_DLY_LWR, MDIO_MMD_VEND2, 0x070F}, 1254 + { ETH_SR_MII_TIME_SYNC_RX_MIN_DLY_UPR, MDIO_MMD_VEND2, 0x0710}, 1255 + { ETH_VR_MII_DIG_CTRL1, MDIO_MMD_VEND2, 0x8000}, 1256 + { ETH_VR_MII_AN_CTRL, MDIO_MMD_VEND2, 0x8001}, 1257 + { ETH_VR_MII_AN_INTR_STS, MDIO_MMD_VEND2, 0x8002}, 1258 + { ETH_VR_MII_TC, MDIO_MMD_VEND2, 0x8003}, 1259 + { ETH_VR_MII_DBG_CTRL, MDIO_MMD_VEND2, 0x8005}, 1260 + { ETH_VR_MII_EEE_MCTRL0, MDIO_MMD_VEND2, 0x8006}, 1261 + { ETH_VR_MII_EEE_TXTIMER, MDIO_MMD_VEND2, 0x8008}, 1262 + { ETH_VR_MII_EEE_RXTIMER, MDIO_MMD_VEND2, 0x8009}, 1263 + { ETH_VR_MII_LINK_TIMER_CTRL, MDIO_MMD_VEND2, 0x800A}, 1264 + { ETH_VR_MII_EEE_MCTRL1, MDIO_MMD_VEND2, 0x800B}, 1265 + { ETH_VR_MII_DIG_STS, MDIO_MMD_VEND2, 0x8010}, 1266 + { ETH_VR_MII_ICG_ERRCNT1, MDIO_MMD_VEND2, 0x8011}, 1267 + { ETH_VR_MII_GPIO, MDIO_MMD_VEND2, 0x8015}, 1268 + { ETH_VR_MII_EEE_LPI_STATUS, MDIO_MMD_VEND2, 0x8016}, 1269 + { ETH_VR_MII_EEE_WKERR, MDIO_MMD_VEND2, 0x8017}, 1270 + { ETH_VR_MII_MISC_STS, MDIO_MMD_VEND2, 0x8018}, 1271 + { ETH_VR_MII_RX_LSTS, MDIO_MMD_VEND2, 0x8020}, 1272 + { ETH_VR_MII_GEN2_GEN4_TX_BSTCTRL0, MDIO_MMD_VEND2, 0x8038}, 1273 + { ETH_VR_MII_GEN2_GEN4_TX_LVLCTRL0, MDIO_MMD_VEND2, 0x803A}, 1274 + { ETH_VR_MII_GEN2_GEN4_TXGENCTRL0, MDIO_MMD_VEND2, 0x803C}, 1275 + { ETH_VR_MII_GEN2_GEN4_TXGENCTRL1, MDIO_MMD_VEND2, 0x803D}, 1276 + { ETH_VR_MII_GEN4_TXGENCTRL2, MDIO_MMD_VEND2, 0x803E}, 1277 + { ETH_VR_MII_GEN2_GEN4_TX_STS, MDIO_MMD_VEND2, 0x8048}, 1278 + { ETH_VR_MII_GEN2_GEN4_RXGENCTRL0, MDIO_MMD_VEND2, 0x8058}, 1279 + { ETH_VR_MII_GEN2_GEN4_RXGENCTRL1, MDIO_MMD_VEND2, 0x8059}, 1280 + { ETH_VR_MII_GEN4_RXEQ_CTRL, MDIO_MMD_VEND2, 0x805B}, 1281 + { ETH_VR_MII_GEN4_RXLOS_CTRL0, MDIO_MMD_VEND2, 0x805D}, 1282 + { ETH_VR_MII_GEN2_GEN4_MPLL_CTRL0, MDIO_MMD_VEND2, 0x8078}, 1283 + { ETH_VR_MII_GEN2_GEN4_MPLL_CTRL1, MDIO_MMD_VEND2, 0x8079}, 1284 + { ETH_VR_MII_GEN2_GEN4_MPLL_STS, MDIO_MMD_VEND2, 0x8088}, 1285 + { ETH_VR_MII_GEN2_GEN4_LVL_CTRL, MDIO_MMD_VEND2, 0x8090}, 1286 + { ETH_VR_MII_GEN4_MISC_CTRL2, MDIO_MMD_VEND2, 0x8093}, 1287 + { ETH_VR_MII_GEN2_GEN4_MISC_CTRL0, MDIO_MMD_VEND2, 0x8099}, 1288 + { ETH_VR_MII_GEN2_GEN4_MISC_CTRL1, MDIO_MMD_VEND2, 0x809A}, 1289 + { ETH_VR_MII_SNPS_CR_CTRL, MDIO_MMD_VEND2, 0x80A0}, 1290 + { ETH_VR_MII_SNPS_CR_ADDR, MDIO_MMD_VEND2, 0x80A1}, 1291 + { ETH_VR_MII_SNPS_CR_DATA, MDIO_MMD_VEND2, 0x80A2}, 1292 + { ETH_VR_MII_DIG_CTRL2, MDIO_MMD_VEND2, 0x80E1}, 1293 + { ETH_VR_MII_DIG_ERRCNT, MDIO_MMD_VEND2, 0x80E2}, 1294 + }; 1295 + 1296 + for (idx = 0; idx < ARRAY_SIZE(regs); idx++) { 1297 + val = lan743x_sgmii_read(adp, regs[idx].dev, regs[idx].addr); 1298 + if (val < 0) 1299 + rb[regs[idx].id] = 0xFFFF; 1300 + else 1301 + rb[regs[idx].id] = val; 1302 + } 1303 + } 1304 + 1221 1305 static int lan743x_get_regs_len(struct net_device *dev) 1222 1306 { 1223 - return MAX_LAN743X_ETH_REGS * sizeof(u32); 1307 + struct lan743x_adapter *adapter = netdev_priv(dev); 1308 + u32 num_regs = MAX_LAN743X_ETH_COMMON_REGS; 1309 + 1310 + if (adapter->is_sgmii_en) 1311 + num_regs += MAX_LAN743X_ETH_SGMII_REGS; 1312 + 1313 + return num_regs * sizeof(u32); 1224 1314 } 1225 1315 1226 1316 static void lan743x_get_regs(struct net_device *dev, 1227 1317 struct ethtool_regs *regs, void *p) 1228 1318 { 1319 + struct lan743x_adapter *adapter = netdev_priv(dev); 1320 + int regs_len; 1321 + 1322 + regs_len = lan743x_get_regs_len(dev); 1323 + memset(p, 0, regs_len); 1324 + 1229 1325 regs->version = LAN743X_ETH_REG_VERSION; 1326 + regs->len = regs_len; 1230 1327 1231 1328 lan743x_common_regs(dev, p); 1329 + p = (u32 *)p + MAX_LAN743X_ETH_COMMON_REGS; 1330 + 1331 + if (adapter->is_sgmii_en) { 1332 + lan743x_sgmii_regs(dev, p); 1333 + p = (u32 *)p + MAX_LAN743X_ETH_SGMII_REGS; 1334 + } 1232 1335 } 1233 1336 1234 1337 static void lan743x_get_pauseparam(struct net_device *dev,
+70 -1
drivers/net/ethernet/microchip/lan743x_ethtool.h
··· 29 29 ETH_WK_SRC, 30 30 31 31 /* Add new registers above */ 32 - MAX_LAN743X_ETH_REGS 32 + MAX_LAN743X_ETH_COMMON_REGS 33 + }; 34 + 35 + enum { 36 + /* SGMII Register */ 37 + ETH_SR_VSMMD_DEV_ID1, 38 + ETH_SR_VSMMD_DEV_ID2, 39 + ETH_SR_VSMMD_PCS_ID1, 40 + ETH_SR_VSMMD_PCS_ID2, 41 + ETH_SR_VSMMD_STS, 42 + ETH_SR_VSMMD_CTRL, 43 + ETH_SR_MII_CTRL, 44 + ETH_SR_MII_STS, 45 + ETH_SR_MII_DEV_ID1, 46 + ETH_SR_MII_DEV_ID2, 47 + ETH_SR_MII_AN_ADV, 48 + ETH_SR_MII_LP_BABL, 49 + ETH_SR_MII_EXPN, 50 + ETH_SR_MII_EXT_STS, 51 + ETH_SR_MII_TIME_SYNC_ABL, 52 + ETH_SR_MII_TIME_SYNC_TX_MAX_DLY_LWR, 53 + ETH_SR_MII_TIME_SYNC_TX_MAX_DLY_UPR, 54 + ETH_SR_MII_TIME_SYNC_TX_MIN_DLY_LWR, 55 + ETH_SR_MII_TIME_SYNC_TX_MIN_DLY_UPR, 56 + ETH_SR_MII_TIME_SYNC_RX_MAX_DLY_LWR, 57 + ETH_SR_MII_TIME_SYNC_RX_MAX_DLY_UPR, 58 + ETH_SR_MII_TIME_SYNC_RX_MIN_DLY_LWR, 59 + ETH_SR_MII_TIME_SYNC_RX_MIN_DLY_UPR, 60 + ETH_VR_MII_DIG_CTRL1, 61 + ETH_VR_MII_AN_CTRL, 62 + ETH_VR_MII_AN_INTR_STS, 63 + ETH_VR_MII_TC, 64 + ETH_VR_MII_DBG_CTRL, 65 + ETH_VR_MII_EEE_MCTRL0, 66 + ETH_VR_MII_EEE_TXTIMER, 67 + ETH_VR_MII_EEE_RXTIMER, 68 + ETH_VR_MII_LINK_TIMER_CTRL, 69 + ETH_VR_MII_EEE_MCTRL1, 70 + ETH_VR_MII_DIG_STS, 71 + ETH_VR_MII_ICG_ERRCNT1, 72 + ETH_VR_MII_GPIO, 73 + ETH_VR_MII_EEE_LPI_STATUS, 74 + ETH_VR_MII_EEE_WKERR, 75 + ETH_VR_MII_MISC_STS, 76 + ETH_VR_MII_RX_LSTS, 77 + ETH_VR_MII_GEN2_GEN4_TX_BSTCTRL0, 78 + ETH_VR_MII_GEN2_GEN4_TX_LVLCTRL0, 79 + ETH_VR_MII_GEN2_GEN4_TXGENCTRL0, 80 + ETH_VR_MII_GEN2_GEN4_TXGENCTRL1, 81 + ETH_VR_MII_GEN4_TXGENCTRL2, 82 + ETH_VR_MII_GEN2_GEN4_TX_STS, 83 + ETH_VR_MII_GEN2_GEN4_RXGENCTRL0, 84 + ETH_VR_MII_GEN2_GEN4_RXGENCTRL1, 85 + ETH_VR_MII_GEN4_RXEQ_CTRL, 86 + ETH_VR_MII_GEN4_RXLOS_CTRL0, 87 + ETH_VR_MII_GEN2_GEN4_MPLL_CTRL0, 88 + ETH_VR_MII_GEN2_GEN4_MPLL_CTRL1, 89 + ETH_VR_MII_GEN2_GEN4_MPLL_STS, 90 + ETH_VR_MII_GEN2_GEN4_LVL_CTRL, 91 + ETH_VR_MII_GEN4_MISC_CTRL2, 92 + ETH_VR_MII_GEN2_GEN4_MISC_CTRL0, 93 + ETH_VR_MII_GEN2_GEN4_MISC_CTRL1, 94 + ETH_VR_MII_SNPS_CR_CTRL, 95 + ETH_VR_MII_SNPS_CR_ADDR, 96 + ETH_VR_MII_SNPS_CR_DATA, 97 + ETH_VR_MII_DIG_CTRL2, 98 + ETH_VR_MII_DIG_ERRCNT, 99 + 100 + /* Add new registers above */ 101 + MAX_LAN743X_ETH_SGMII_REGS 33 102 }; 34 103 35 104 extern const struct ethtool_ops lan743x_ethtool_ops;
+1 -1
drivers/net/ethernet/microchip/lan743x_main.c
··· 939 939 return ret; 940 940 } 941 941 942 - static int lan743x_sgmii_read(struct lan743x_adapter *adapter, u8 mmd, u16 addr) 942 + int lan743x_sgmii_read(struct lan743x_adapter *adapter, u8 mmd, u16 addr) 943 943 { 944 944 u32 mmd_access; 945 945 int ret;
+1
drivers/net/ethernet/microchip/lan743x_main.h
··· 1161 1161 void lan743x_hs_syslock_release(struct lan743x_adapter *adapter); 1162 1162 void lan743x_mac_flow_ctrl_set_enables(struct lan743x_adapter *adapter, 1163 1163 bool tx_enable, bool rx_enable); 1164 + int lan743x_sgmii_read(struct lan743x_adapter *adapter, u8 mmd, u16 addr); 1164 1165 1165 1166 #endif /* _LAN743X_H */