Re: [PATCH] new device support for forcedeth.c second try

From: Francois Romieu
Date: Sat Jun 19 2004 - 09:04:51 EST


Carl-Daniel Hailfinger <c-d.hailfinger.kernel.2004@xxxxxxx> :
[...]
> +static int phy_reset(struct net_device *dev)
> +{
> + struct fe_priv *np = get_nvpriv(dev);
> + u32 miicontrol;
> + u32 microseconds = 0;
> + u32 milliseconds = 0;
> +
> + miicontrol = mii_rw(dev, np->phyaddr, MII_BMCR, MII_READ);
> + miicontrol |= BMCR_RESET;
> + if (mii_rw(dev, np->phyaddr, MII_BMCR, miicontrol)) {
> + return -1;
> + }
> +
> + //wait for 500ms
> + mdelay(500);
> +
> + //must wait till reset is deasserted
> + while (miicontrol & BMCR_RESET) {
> + udelay(NV_MIIBUSY_DELAY);
> + miicontrol = mii_rw(dev, np->phyaddr, MII_BMCR, MII_READ);
> + microseconds++;
> + if (microseconds == 20) {
> + microseconds = 0;
> + milliseconds++;
> + }
> + if (milliseconds > 50)
> + return -1;
> + }
> + return 0;
> +}

Afaiks this function is not called from a spinlocked nor is it time-critical.
You should make it use schedule_timeout().

--
Ueimor
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/