aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/spider_net.c20
-rw-r--r--drivers/net/spider_net.h1
2 files changed, 12 insertions, 9 deletions
diff --git a/drivers/net/spider_net.c b/drivers/net/spider_net.c
index f5ede5f6073c..0e79bacd7870 100644
--- a/drivers/net/spider_net.c
+++ b/drivers/net/spider_net.c
@@ -1172,7 +1172,7 @@ spider_net_decode_one_descr(struct spider_net_card *card)
1172 goto bad_desc; 1172 goto bad_desc;
1173 } 1173 }
1174 1174
1175 if (hwdescr->dmac_cmd_status & 0xfefe) { 1175 if (hwdescr->dmac_cmd_status & 0xfcf4) {
1176 pr_err("%s: bad status, cmd_status=x%08x\n", 1176 pr_err("%s: bad status, cmd_status=x%08x\n",
1177 card->netdev->name, 1177 card->netdev->name,
1178 hwdescr->dmac_cmd_status); 1178 hwdescr->dmac_cmd_status);
@@ -1251,6 +1251,7 @@ spider_net_poll(struct net_device *netdev, int *budget)
1251 if (no_more_packets) { 1251 if (no_more_packets) {
1252 netif_rx_complete(netdev); 1252 netif_rx_complete(netdev);
1253 spider_net_rx_irq_on(card); 1253 spider_net_rx_irq_on(card);
1254 card->ignore_rx_ramfull = 0;
1254 return 0; 1255 return 0;
1255 } 1256 }
1256 1257
@@ -1484,15 +1485,15 @@ spider_net_handle_error_irq(struct spider_net_card *card, u32 status_reg)
1484 case SPIDER_NET_GRFBFLLINT: /* fallthrough */ 1485 case SPIDER_NET_GRFBFLLINT: /* fallthrough */
1485 case SPIDER_NET_GRFAFLLINT: /* fallthrough */ 1486 case SPIDER_NET_GRFAFLLINT: /* fallthrough */
1486 case SPIDER_NET_GRMFLLINT: 1487 case SPIDER_NET_GRMFLLINT:
1487 if (netif_msg_intr(card) && net_ratelimit())
1488 pr_err("Spider RX RAM full, incoming packets "
1489 "might be discarded!\n");
1490 /* Could happen when rx chain is full */ 1488 /* Could happen when rx chain is full */
1491 spider_net_resync_head_ptr(card); 1489 if (card->ignore_rx_ramfull == 0) {
1492 spider_net_refill_rx_chain(card); 1490 card->ignore_rx_ramfull = 1;
1493 spider_net_enable_rxdmac(card); 1491 spider_net_resync_head_ptr(card);
1494 card->num_rx_ints ++; 1492 spider_net_refill_rx_chain(card);
1495 netif_rx_schedule(card->netdev); 1493 spider_net_enable_rxdmac(card);
1494 card->num_rx_ints ++;
1495 netif_rx_schedule(card->netdev);
1496 }
1496 show_error = 0; 1497 show_error = 0;
1497 break; 1498 break;
1498 1499
@@ -2265,6 +2266,7 @@ spider_net_setup_netdev(struct spider_net_card *card)
2265 2266
2266 netdev->irq = card->pdev->irq; 2267 netdev->irq = card->pdev->irq;
2267 card->num_rx_ints = 0; 2268 card->num_rx_ints = 0;
2269 card->ignore_rx_ramfull = 0;
2268 2270
2269 dn = pci_device_to_OF_node(card->pdev); 2271 dn = pci_device_to_OF_node(card->pdev);
2270 if (!dn) 2272 if (!dn)
diff --git a/drivers/net/spider_net.h b/drivers/net/spider_net.h
index b620f181227c..f457bce00e5c 100644
--- a/drivers/net/spider_net.h
+++ b/drivers/net/spider_net.h
@@ -462,6 +462,7 @@ struct spider_net_card {
462 atomic_t tx_timeout_task_counter; 462 atomic_t tx_timeout_task_counter;
463 wait_queue_head_t waitq; 463 wait_queue_head_t waitq;
464 int num_rx_ints; 464 int num_rx_ints;
465 int ignore_rx_ramfull;
465 466
466 /* for ethtool */ 467 /* for ethtool */
467 int msg_enable; 468 int msg_enable;