diff options
-rw-r--r-- | drivers/net/ethernet/broadcom/genet/bcmgenet.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/drivers/net/ethernet/broadcom/genet/bcmgenet.c b/drivers/net/ethernet/broadcom/genet/bcmgenet.c index 1925ae1dc1e6..62ef49c85980 100644 --- a/drivers/net/ethernet/broadcom/genet/bcmgenet.c +++ b/drivers/net/ethernet/broadcom/genet/bcmgenet.c | |||
@@ -2635,6 +2635,12 @@ static int bcmgenet_suspend(struct device *d) | |||
2635 | bcmgenet_tx_reclaim_all(dev); | 2635 | bcmgenet_tx_reclaim_all(dev); |
2636 | bcmgenet_fini_dma(priv); | 2636 | bcmgenet_fini_dma(priv); |
2637 | 2637 | ||
2638 | /* Prepare the device for Wake-on-LAN and switch to the slow clock */ | ||
2639 | if (device_may_wakeup(d) && priv->wolopts) { | ||
2640 | bcmgenet_power_down(priv, GENET_POWER_WOL_MAGIC); | ||
2641 | clk_prepare_enable(priv->clk_wol); | ||
2642 | } | ||
2643 | |||
2638 | /* Turn off the clocks */ | 2644 | /* Turn off the clocks */ |
2639 | clk_disable_unprepare(priv->clk); | 2645 | clk_disable_unprepare(priv->clk); |
2640 | 2646 | ||
@@ -2663,6 +2669,12 @@ static int bcmgenet_resume(struct device *d) | |||
2663 | if (ret) | 2669 | if (ret) |
2664 | goto out_clk_disable; | 2670 | goto out_clk_disable; |
2665 | 2671 | ||
2672 | if (priv->wolopts) | ||
2673 | ret = bcmgenet_wol_resume(priv); | ||
2674 | |||
2675 | if (ret) | ||
2676 | goto out_clk_disable; | ||
2677 | |||
2666 | /* disable ethernet MAC while updating its registers */ | 2678 | /* disable ethernet MAC while updating its registers */ |
2667 | umac_enable_set(priv, CMD_TX_EN | CMD_RX_EN, false); | 2679 | umac_enable_set(priv, CMD_TX_EN | CMD_RX_EN, false); |
2668 | 2680 | ||