aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/ethernet/wiznet/Kconfig8
-rw-r--r--drivers/net/ethernet/wiznet/w5100.c5
-rw-r--r--drivers/net/ethernet/wiznet/w5300.c9
3 files changed, 5 insertions, 17 deletions
diff --git a/drivers/net/ethernet/wiznet/Kconfig b/drivers/net/ethernet/wiznet/Kconfig
index c8291bf905a7..cb18043f5830 100644
--- a/drivers/net/ethernet/wiznet/Kconfig
+++ b/drivers/net/ethernet/wiznet/Kconfig
@@ -70,12 +70,4 @@ config WIZNET_BUS_ANY
70 Performance may decrease compared to explicitly selected bus mode. 70 Performance may decrease compared to explicitly selected bus mode.
71endchoice 71endchoice
72 72
73config WIZNET_TX_FLOW
74 bool "Use transmit flow control"
75 depends on WIZNET_W5100 || WIZNET_W5300
76 default y
77 help
78 This enables transmit flow control for WIZnet chips.
79 If unsure, say Y.
80
81endif # NET_VENDOR_WIZNET 73endif # NET_VENDOR_WIZNET
diff --git a/drivers/net/ethernet/wiznet/w5100.c b/drivers/net/ethernet/wiznet/w5100.c
index c28e1d57b02d..a4079d7d1af0 100644
--- a/drivers/net/ethernet/wiznet/w5100.c
+++ b/drivers/net/ethernet/wiznet/w5100.c
@@ -441,8 +441,7 @@ static int w5100_start_tx(struct sk_buff *skb, struct net_device *ndev)
441 struct w5100_priv *priv = netdev_priv(ndev); 441 struct w5100_priv *priv = netdev_priv(ndev);
442 u16 offset; 442 u16 offset;
443 443
444 if (IS_ENABLED(CONFIG_WIZNET_TX_FLOW)) 444 netif_stop_queue(ndev);
445 netif_stop_queue(ndev);
446 445
447 offset = w5100_read16(priv, W5100_S0_TX_WR); 446 offset = w5100_read16(priv, W5100_S0_TX_WR);
448 w5100_writebuf(priv, offset, skb->data, skb->len); 447 w5100_writebuf(priv, offset, skb->data, skb->len);
@@ -517,7 +516,7 @@ static irqreturn_t w5100_interrupt(int irq, void *ndev_instance)
517 w5100_write(priv, W5100_S0_IR, ir); 516 w5100_write(priv, W5100_S0_IR, ir);
518 mmiowb(); 517 mmiowb();
519 518
520 if (IS_ENABLED(CONFIG_WIZNET_TX_FLOW) && (ir & S0_IR_SENDOK)) { 519 if (ir & S0_IR_SENDOK) {
521 netif_dbg(priv, tx_done, ndev, "tx done\n"); 520 netif_dbg(priv, tx_done, ndev, "tx done\n");
522 netif_wake_queue(ndev); 521 netif_wake_queue(ndev);
523 } 522 }
diff --git a/drivers/net/ethernet/wiznet/w5300.c b/drivers/net/ethernet/wiznet/w5300.c
index 88afde99de8d..7bede7f5defa 100644
--- a/drivers/net/ethernet/wiznet/w5300.c
+++ b/drivers/net/ethernet/wiznet/w5300.c
@@ -273,9 +273,7 @@ static void w5300_hw_start(struct w5300_priv *priv)
273 S0_MR_MACRAW : S0_MR_MACRAW_MF); 273 S0_MR_MACRAW : S0_MR_MACRAW_MF);
274 mmiowb(); 274 mmiowb();
275 w5300_command(priv, S0_CR_OPEN); 275 w5300_command(priv, S0_CR_OPEN);
276 w5300_write(priv, W5300_S0_IMR, IS_ENABLED(CONFIG_WIZNET_TX_FLOW) ? 276 w5300_write(priv, W5300_S0_IMR, S0_IR_RECV | S0_IR_SENDOK);
277 S0_IR_RECV | S0_IR_SENDOK :
278 S0_IR_RECV);
279 w5300_write(priv, W5300_IMR, IR_S0); 277 w5300_write(priv, W5300_IMR, IR_S0);
280 mmiowb(); 278 mmiowb();
281} 279}
@@ -371,8 +369,7 @@ static int w5300_start_tx(struct sk_buff *skb, struct net_device *ndev)
371{ 369{
372 struct w5300_priv *priv = netdev_priv(ndev); 370 struct w5300_priv *priv = netdev_priv(ndev);
373 371
374 if (IS_ENABLED(CONFIG_WIZNET_TX_FLOW)) 372 netif_stop_queue(ndev);
375 netif_stop_queue(ndev);
376 373
377 w5300_write_frame(priv, skb->data, skb->len); 374 w5300_write_frame(priv, skb->data, skb->len);
378 mmiowb(); 375 mmiowb();
@@ -439,7 +436,7 @@ static irqreturn_t w5300_interrupt(int irq, void *ndev_instance)
439 w5300_write(priv, W5300_S0_IR, ir); 436 w5300_write(priv, W5300_S0_IR, ir);
440 mmiowb(); 437 mmiowb();
441 438
442 if (IS_ENABLED(CONFIG_WIZNET_TX_FLOW) && (ir & S0_IR_SENDOK)) { 439 if (ir & S0_IR_SENDOK) {
443 netif_dbg(priv, tx_done, ndev, "tx done\n"); 440 netif_dbg(priv, tx_done, ndev, "tx done\n");
444 netif_wake_queue(ndev); 441 netif_wake_queue(ndev);
445 } 442 }