Skip to content

Commit

Permalink
mv643xx_eth: switch ->phy_lock from a spinlock to a mutex
Browse files Browse the repository at this point in the history
Since commit 81600ee ("mv643xx_eth:
use auto phy polling for configuring (R)(G)MII interface"),
mv643xx_eth no longer does SMI accesses from interrupt context.  The
only other callers that do SMI accesses all do them from process
context, which means we can switch the PHY lock from a spinlock to a
mutex, and get rid of the extra locking in some ethtool methods.

Signed-off-by: Lennert Buytenhek <buytenh@marvell.com>
  • Loading branch information
Lennert Buytenhek authored and Lennert Buytenhek committed Sep 5, 2008
1 parent 9da7874 commit 2b3ba0e
Showing 1 changed file with 7 additions and 16 deletions.
23 changes: 7 additions & 16 deletions drivers/net/mv643xx_eth.c
Original file line number Diff line number Diff line change
Expand Up @@ -251,7 +251,7 @@ struct mv643xx_eth_shared_private {
/*
* Protects access to SMI_REG, which is shared between ports.
*/
spinlock_t phy_lock;
struct mutex phy_lock;

/*
* Per-port MBUS window access register value.
Expand Down Expand Up @@ -988,11 +988,10 @@ static void smi_reg_read(struct mv643xx_eth_private *mp, unsigned int addr,
unsigned int reg, unsigned int *value)
{
void __iomem *smi_reg = mp->shared_smi->base + SMI_REG;
unsigned long flags;
int i;

/* the SMI register is a shared resource */
spin_lock_irqsave(&mp->shared_smi->phy_lock, flags);
mutex_lock(&mp->shared_smi->phy_lock);

/* wait for the SMI register to become available */
for (i = 0; readl(smi_reg) & SMI_BUSY; i++) {
Expand All @@ -1016,19 +1015,18 @@ static void smi_reg_read(struct mv643xx_eth_private *mp, unsigned int addr,

*value = readl(smi_reg) & 0xffff;
out:
spin_unlock_irqrestore(&mp->shared_smi->phy_lock, flags);
mutex_unlock(&mp->shared_smi->phy_lock);
}

static void smi_reg_write(struct mv643xx_eth_private *mp,
unsigned int addr,
unsigned int reg, unsigned int value)
{
void __iomem *smi_reg = mp->shared_smi->base + SMI_REG;
unsigned long flags;
int i;

/* the SMI register is a shared resource */
spin_lock_irqsave(&mp->shared_smi->phy_lock, flags);
mutex_lock(&mp->shared_smi->phy_lock);

/* wait for the SMI register to become available */
for (i = 0; readl(smi_reg) & SMI_BUSY; i++) {
Expand All @@ -1042,7 +1040,7 @@ static void smi_reg_write(struct mv643xx_eth_private *mp,
writel(SMI_OPCODE_WRITE | (reg << 21) |
(addr << 16) | (value & 0xffff), smi_reg);
out:
spin_unlock_irqrestore(&mp->shared_smi->phy_lock, flags);
mutex_unlock(&mp->shared_smi->phy_lock);
}


Expand Down Expand Up @@ -1161,9 +1159,7 @@ static int mv643xx_eth_get_settings(struct net_device *dev, struct ethtool_cmd *
struct mv643xx_eth_private *mp = netdev_priv(dev);
int err;

spin_lock_irq(&mp->lock);
err = mii_ethtool_gset(&mp->mii, cmd);
spin_unlock_irq(&mp->lock);

/*
* The MAC does not support 1000baseT_Half.
Expand Down Expand Up @@ -1211,18 +1207,13 @@ static int mv643xx_eth_get_settings_phyless(struct net_device *dev, struct ethto
static int mv643xx_eth_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
{
struct mv643xx_eth_private *mp = netdev_priv(dev);
int err;

/*
* The MAC does not support 1000baseT_Half.
*/
cmd->advertising &= ~ADVERTISED_1000baseT_Half;

spin_lock_irq(&mp->lock);
err = mii_ethtool_sset(&mp->mii, cmd);
spin_unlock_irq(&mp->lock);

return err;
return mii_ethtool_sset(&mp->mii, cmd);
}

static int mv643xx_eth_set_settings_phyless(struct net_device *dev, struct ethtool_cmd *cmd)
Expand Down Expand Up @@ -2324,7 +2315,7 @@ static int mv643xx_eth_shared_probe(struct platform_device *pdev)
if (msp->base == NULL)
goto out_free;

spin_lock_init(&msp->phy_lock);
mutex_init(&msp->phy_lock);

/*
* (Re-)program MBUS remapping windows if we are asked to.
Expand Down

0 comments on commit 2b3ba0e

Please sign in to comment.