Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 3410572d authored by Francois Romieu's avatar Francois Romieu
Browse files

b44: early return in dev->do_ioctl when the device is not up



The device has not gone through a whole reset/init sequence until the
device is up. Accessing the mii interface before this point is not
safe.

Signed-off-by: default avatarFrancois Romieu <romieu@fr.zoreil.com>
parent d9e2d185
Loading
Loading
Loading
Loading
+5 −2
Original line number Diff line number Diff line
@@ -1838,12 +1838,15 @@ static int b44_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
{
	struct mii_ioctl_data *data = if_mii(ifr);
	struct b44 *bp = netdev_priv(dev);
	int err;
	int err = -EINVAL;

	if (!netif_running(dev))
		goto out;

	spin_lock_irq(&bp->lock);
	err = generic_mii_ioctl(&bp->mii_if, data, cmd, NULL);
	spin_unlock_irq(&bp->lock);

out:
	return err;
}