diff options
-rw-r--r-- | drivers/net/myri10ge/myri10ge.c | 46 |
1 files changed, 39 insertions, 7 deletions
diff --git a/drivers/net/myri10ge/myri10ge.c b/drivers/net/myri10ge/myri10ge.c index c0c41ca688ef..a79afe2134ba 100644 --- a/drivers/net/myri10ge/myri10ge.c +++ b/drivers/net/myri10ge/myri10ge.c | |||
@@ -192,6 +192,8 @@ struct myri10ge_priv { | |||
192 | u32 read_dma; | 192 | u32 read_dma; |
193 | u32 write_dma; | 193 | u32 write_dma; |
194 | u32 read_write_dma; | 194 | u32 read_write_dma; |
195 | u32 link_changes; | ||
196 | u32 msg_enable; | ||
195 | }; | 197 | }; |
196 | 198 | ||
197 | static char *myri10ge_fw_unaligned = "myri10ge_ethp_z8e.dat"; | 199 | static char *myri10ge_fw_unaligned = "myri10ge_ethp_z8e.dat"; |
@@ -257,6 +259,12 @@ module_param(myri10ge_max_irq_loops, int, S_IRUGO); | |||
257 | MODULE_PARM_DESC(myri10ge_max_irq_loops, | 259 | MODULE_PARM_DESC(myri10ge_max_irq_loops, |
258 | "Set stuck legacy IRQ detection threshold\n"); | 260 | "Set stuck legacy IRQ detection threshold\n"); |
259 | 261 | ||
262 | #define MYRI10GE_MSG_DEFAULT NETIF_MSG_LINK | ||
263 | |||
264 | static int myri10ge_debug = -1; /* defaults above */ | ||
265 | module_param(myri10ge_debug, int, 0); | ||
266 | MODULE_PARM_DESC(myri10ge_debug, "Debug level (0=none,...,16=all)"); | ||
267 | |||
260 | #define MYRI10GE_FW_OFFSET 1024*1024 | 268 | #define MYRI10GE_FW_OFFSET 1024*1024 |
261 | #define MYRI10GE_HIGHPART_TO_U32(X) \ | 269 | #define MYRI10GE_HIGHPART_TO_U32(X) \ |
262 | (sizeof (X) == 8) ? ((u32)((u64)(X) >> 32)) : (0) | 270 | (sizeof (X) == 8) ? ((u32)((u64)(X) >> 32)) : (0) |
@@ -764,6 +772,7 @@ static int myri10ge_reset(struct myri10ge_priv *mgp) | |||
764 | mgp->rx_small.cnt = 0; | 772 | mgp->rx_small.cnt = 0; |
765 | mgp->rx_done.idx = 0; | 773 | mgp->rx_done.idx = 0; |
766 | mgp->rx_done.cnt = 0; | 774 | mgp->rx_done.cnt = 0; |
775 | mgp->link_changes = 0; | ||
767 | status = myri10ge_update_mac_address(mgp, mgp->dev->dev_addr); | 776 | status = myri10ge_update_mac_address(mgp, mgp->dev->dev_addr); |
768 | myri10ge_change_promisc(mgp, 0, 0); | 777 | myri10ge_change_promisc(mgp, 0, 0); |
769 | myri10ge_change_pause(mgp, mgp->pause); | 778 | myri10ge_change_pause(mgp, mgp->pause); |
@@ -1085,13 +1094,19 @@ static inline void myri10ge_check_statblock(struct myri10ge_priv *mgp) | |||
1085 | if (mgp->link_state != stats->link_up) { | 1094 | if (mgp->link_state != stats->link_up) { |
1086 | mgp->link_state = stats->link_up; | 1095 | mgp->link_state = stats->link_up; |
1087 | if (mgp->link_state) { | 1096 | if (mgp->link_state) { |
1088 | printk(KERN_INFO "myri10ge: %s: link up\n", | 1097 | if (netif_msg_link(mgp)) |
1089 | mgp->dev->name); | 1098 | printk(KERN_INFO |
1099 | "myri10ge: %s: link up\n", | ||
1100 | mgp->dev->name); | ||
1090 | netif_carrier_on(mgp->dev); | 1101 | netif_carrier_on(mgp->dev); |
1102 | mgp->link_changes++; | ||
1091 | } else { | 1103 | } else { |
1092 | printk(KERN_INFO "myri10ge: %s: link down\n", | 1104 | if (netif_msg_link(mgp)) |
1093 | mgp->dev->name); | 1105 | printk(KERN_INFO |
1106 | "myri10ge: %s: link down\n", | ||
1107 | mgp->dev->name); | ||
1094 | netif_carrier_off(mgp->dev); | 1108 | netif_carrier_off(mgp->dev); |
1109 | mgp->link_changes++; | ||
1095 | } | 1110 | } |
1096 | } | 1111 | } |
1097 | if (mgp->rdma_tags_available != | 1112 | if (mgp->rdma_tags_available != |
@@ -1293,8 +1308,9 @@ static const char myri10ge_gstrings_stats[][ETH_GSTRING_LEN] = { | |||
1293 | "serial_number", "tx_pkt_start", "tx_pkt_done", | 1308 | "serial_number", "tx_pkt_start", "tx_pkt_done", |
1294 | "tx_req", "tx_done", "rx_small_cnt", "rx_big_cnt", | 1309 | "tx_req", "tx_done", "rx_small_cnt", "rx_big_cnt", |
1295 | "wake_queue", "stop_queue", "watchdog_resets", "tx_linearized", | 1310 | "wake_queue", "stop_queue", "watchdog_resets", "tx_linearized", |
1296 | "link_up", "dropped_link_overflow", "dropped_link_error_or_filtered", | 1311 | "link_changes", "link_up", "dropped_link_overflow", |
1297 | "dropped_runt", "dropped_overrun", "dropped_no_small_buffer", | 1312 | "dropped_link_error_or_filtered", "dropped_runt", |
1313 | "dropped_overrun", "dropped_no_small_buffer", | ||
1298 | "dropped_no_big_buffer" | 1314 | "dropped_no_big_buffer" |
1299 | }; | 1315 | }; |
1300 | 1316 | ||
@@ -1345,6 +1361,7 @@ myri10ge_get_ethtool_stats(struct net_device *netdev, | |||
1345 | data[i++] = (unsigned int)mgp->stop_queue; | 1361 | data[i++] = (unsigned int)mgp->stop_queue; |
1346 | data[i++] = (unsigned int)mgp->watchdog_resets; | 1362 | data[i++] = (unsigned int)mgp->watchdog_resets; |
1347 | data[i++] = (unsigned int)mgp->tx_linearized; | 1363 | data[i++] = (unsigned int)mgp->tx_linearized; |
1364 | data[i++] = (unsigned int)mgp->link_changes; | ||
1348 | data[i++] = (unsigned int)ntohl(mgp->fw_stats->link_up); | 1365 | data[i++] = (unsigned int)ntohl(mgp->fw_stats->link_up); |
1349 | data[i++] = (unsigned int)ntohl(mgp->fw_stats->dropped_link_overflow); | 1366 | data[i++] = (unsigned int)ntohl(mgp->fw_stats->dropped_link_overflow); |
1350 | data[i++] = | 1367 | data[i++] = |
@@ -1355,6 +1372,18 @@ myri10ge_get_ethtool_stats(struct net_device *netdev, | |||
1355 | data[i++] = (unsigned int)ntohl(mgp->fw_stats->dropped_no_big_buffer); | 1372 | data[i++] = (unsigned int)ntohl(mgp->fw_stats->dropped_no_big_buffer); |
1356 | } | 1373 | } |
1357 | 1374 | ||
1375 | static void myri10ge_set_msglevel(struct net_device *netdev, u32 value) | ||
1376 | { | ||
1377 | struct myri10ge_priv *mgp = netdev_priv(netdev); | ||
1378 | mgp->msg_enable = value; | ||
1379 | } | ||
1380 | |||
1381 | static u32 myri10ge_get_msglevel(struct net_device *netdev) | ||
1382 | { | ||
1383 | struct myri10ge_priv *mgp = netdev_priv(netdev); | ||
1384 | return mgp->msg_enable; | ||
1385 | } | ||
1386 | |||
1358 | static struct ethtool_ops myri10ge_ethtool_ops = { | 1387 | static struct ethtool_ops myri10ge_ethtool_ops = { |
1359 | .get_settings = myri10ge_get_settings, | 1388 | .get_settings = myri10ge_get_settings, |
1360 | .get_drvinfo = myri10ge_get_drvinfo, | 1389 | .get_drvinfo = myri10ge_get_drvinfo, |
@@ -1375,7 +1404,9 @@ static struct ethtool_ops myri10ge_ethtool_ops = { | |||
1375 | #endif | 1404 | #endif |
1376 | .get_strings = myri10ge_get_strings, | 1405 | .get_strings = myri10ge_get_strings, |
1377 | .get_stats_count = myri10ge_get_stats_count, | 1406 | .get_stats_count = myri10ge_get_stats_count, |
1378 | .get_ethtool_stats = myri10ge_get_ethtool_stats | 1407 | .get_ethtool_stats = myri10ge_get_ethtool_stats, |
1408 | .set_msglevel = myri10ge_set_msglevel, | ||
1409 | .get_msglevel = myri10ge_get_msglevel | ||
1379 | }; | 1410 | }; |
1380 | 1411 | ||
1381 | static int myri10ge_allocate_rings(struct net_device *dev) | 1412 | static int myri10ge_allocate_rings(struct net_device *dev) |
@@ -2587,6 +2618,7 @@ static int myri10ge_probe(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
2587 | mgp->csum_flag = MXGEFW_FLAGS_CKSUM; | 2618 | mgp->csum_flag = MXGEFW_FLAGS_CKSUM; |
2588 | mgp->pause = myri10ge_flow_control; | 2619 | mgp->pause = myri10ge_flow_control; |
2589 | mgp->intr_coal_delay = myri10ge_intr_coal_delay; | 2620 | mgp->intr_coal_delay = myri10ge_intr_coal_delay; |
2621 | mgp->msg_enable = netif_msg_init(myri10ge_debug, MYRI10GE_MSG_DEFAULT); | ||
2590 | init_waitqueue_head(&mgp->down_wq); | 2622 | init_waitqueue_head(&mgp->down_wq); |
2591 | 2623 | ||
2592 | if (pci_enable_device(pdev)) { | 2624 | if (pci_enable_device(pdev)) { |