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/