Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 214759
b: refs/heads/master
c: 543876c
h: refs/heads/master
i:
  214757: 019a767
  214755: aabdf5b
  214751: 5297b90
v: v3
  • Loading branch information
Giuseppe Cavallaro authored and David S. Miller committed Sep 25, 2010
1 parent 408145f commit 6c0d510
Show file tree
Hide file tree
Showing 7 changed files with 25 additions and 21 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 77555ee7228234257957fd54daa0b69178906320
refs/heads/master: 543876c92837a8b208b5c99ec225c1f5a581900e
1 change: 0 additions & 1 deletion trunk/drivers/net/stmmac/common.h
Original file line number Diff line number Diff line change
Expand Up @@ -238,7 +238,6 @@ struct mac_device_info {
struct stmmac_ops *mac;
struct stmmac_desc_ops *desc;
struct stmmac_dma_ops *dma;
unsigned int pmt; /* support Power-Down */
struct mii_regs mii; /* MII register Addresses */
struct mac_link link;
};
Expand Down
1 change: 0 additions & 1 deletion trunk/drivers/net/stmmac/dwmac1000_core.c
Original file line number Diff line number Diff line change
Expand Up @@ -239,7 +239,6 @@ struct mac_device_info *dwmac1000_setup(void __iomem *ioaddr)
mac->mac = &dwmac1000_ops;
mac->dma = &dwmac1000_dma_ops;

mac->pmt = PMT_SUPPORTED;
mac->link.port = GMAC_CONTROL_PS;
mac->link.duplex = GMAC_CONTROL_DM;
mac->link.speed = GMAC_CONTROL_FES;
Expand Down
1 change: 0 additions & 1 deletion trunk/drivers/net/stmmac/dwmac100_core.c
Original file line number Diff line number Diff line change
Expand Up @@ -193,7 +193,6 @@ struct mac_device_info *dwmac100_setup(void __iomem *ioaddr)
mac->mac = &dwmac100_ops;
mac->dma = &dwmac100_dma_ops;

mac->pmt = PMT_NOT_SUPPORTED;
mac->link.port = MAC_CONTROL_PS;
mac->link.duplex = MAC_CONTROL_F;
mac->link.speed = 0;
Expand Down
14 changes: 9 additions & 5 deletions trunk/drivers/net/stmmac/stmmac_ethtool.c
Original file line number Diff line number Diff line change
Expand Up @@ -322,7 +322,7 @@ static void stmmac_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol)
struct stmmac_priv *priv = netdev_priv(dev);

spin_lock_irq(&priv->lock);
if (priv->wolenabled == PMT_SUPPORTED) {
if (device_can_wakeup(priv->device)) {
wol->supported = WAKE_MAGIC;
wol->wolopts = priv->wolopts;
}
Expand All @@ -334,16 +334,20 @@ static int stmmac_set_wol(struct net_device *dev, struct ethtool_wolinfo *wol)
struct stmmac_priv *priv = netdev_priv(dev);
u32 support = WAKE_MAGIC;

if (priv->wolenabled == PMT_NOT_SUPPORTED)
if (!device_can_wakeup(priv->device))
return -EINVAL;

if (wol->wolopts & ~support)
return -EINVAL;

if (wol->wolopts == 0)
device_set_wakeup_enable(priv->device, 0);
else
if (wol->wolopts) {
pr_info("stmmac: wakeup enable\n");
device_set_wakeup_enable(priv->device, 1);
enable_irq_wake(dev->irq);
} else {
device_set_wakeup_enable(priv->device, 0);
disable_irq_wake(dev->irq);
}

spin_lock_irq(&priv->lock);
priv->wolopts = wol->wolopts;
Expand Down
26 changes: 14 additions & 12 deletions trunk/drivers/net/stmmac/stmmac_main.c
Original file line number Diff line number Diff line change
Expand Up @@ -1568,9 +1568,8 @@ static int stmmac_mac_device_setup(struct net_device *dev)

priv->hw = device;

priv->wolenabled = priv->hw->pmt; /* PMT supported */
if (priv->wolenabled == PMT_SUPPORTED)
priv->wolopts = WAKE_MAGIC; /* Magic Frame */
if (device_can_wakeup(priv->device))
priv->wolopts = WAKE_MAGIC; /* Magic Frame as default */

return 0;
}
Expand Down Expand Up @@ -1709,6 +1708,12 @@ static int stmmac_dvr_probe(struct platform_device *pdev)
priv->enh_desc = plat_dat->enh_desc;
priv->ioaddr = addr;

/* PMT module is not integrated in all the MAC devices. */
if (plat_dat->pmt) {
pr_info("\tPMT module supported\n");
device_set_wakeup_capable(&pdev->dev, 1);
}

platform_set_drvdata(pdev, ndev);

/* Set the I/O base addr */
Expand Down Expand Up @@ -1836,13 +1841,11 @@ static int stmmac_suspend(struct platform_device *pdev, pm_message_t state)

stmmac_mac_disable_tx(priv->ioaddr);

if (device_may_wakeup(&(pdev->dev))) {
/* Enable Power down mode by programming the PMT regs */
if (priv->wolenabled == PMT_SUPPORTED)
priv->hw->mac->pmt(priv->ioaddr, priv->wolopts);
} else {
/* Enable Power down mode by programming the PMT regs */
if (device_can_wakeup(priv->device))
priv->hw->mac->pmt(priv->ioaddr, priv->wolopts);
else
stmmac_mac_disable_rx(priv->ioaddr);
}
} else {
priv->shutdown = 1;
/* Although this can appear slightly redundant it actually
Expand Down Expand Up @@ -1877,9 +1880,8 @@ static int stmmac_resume(struct platform_device *pdev)
* is received. Anyway, it's better to manually clear
* this bit because it can generate problems while resuming
* from another devices (e.g. serial console). */
if (device_may_wakeup(&(pdev->dev)))
if (priv->wolenabled == PMT_SUPPORTED)
priv->hw->mac->pmt(priv->ioaddr, 0);
if (device_can_wakeup(priv->device))
priv->hw->mac->pmt(priv->ioaddr, 0);

netif_device_attach(dev);

Expand Down
1 change: 1 addition & 0 deletions trunk/include/linux/stmmac.h
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ struct plat_stmmacenet_data {
int enh_desc;
int tx_coe;
int bugged_jumbo;
int pmt;
void (*fix_mac_speed)(void *priv, unsigned int speed);
void (*bus_setup)(void __iomem *ioaddr);
#ifdef CONFIG_STM_DRIVERS
Expand Down

0 comments on commit 6c0d510

Please sign in to comment.