Commit d1d5e6b1 authored by Daniele Venzano's avatar Daniele Venzano Committed by David S. Miller

sis900: generate fake MAC address if the hardware doesn't have one

The attached patch modifies the sis900 driver when the MAC address
read from the hardware is invalid. As suggested, the patch now
generates a random address so that the user can go on and use
the hardware. In any case a message is also shown to warn on the
unexpected condition.
This seems to happen with newer HW implementation of the sis900
chipset, since this never came up before.

Patch is against vanilla 2.6.28 (but the driver doesn't change so often,
so it will probably apply to older/newer versions too).

See bugzilla ID 10201 and 11649 and ignore the previous patch.
Signed-off-by: default avatarDaniele Venzano <venza@brownhat.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent d7e094d4
...@@ -509,10 +509,10 @@ static int __devinit sis900_probe(struct pci_dev *pci_dev, ...@@ -509,10 +509,10 @@ static int __devinit sis900_probe(struct pci_dev *pci_dev,
else else
ret = sis900_get_mac_addr(pci_dev, net_dev); ret = sis900_get_mac_addr(pci_dev, net_dev);
if (ret == 0) { if (!ret || !is_valid_ether_addr(net_dev->dev_addr)) {
printk(KERN_WARNING "%s: Cannot read MAC address.\n", dev_name); random_ether_addr(net_dev->dev_addr);
ret = -ENODEV; printk(KERN_WARNING "%s: Unreadable or invalid MAC address,"
goto err_unmap_rx; "using random generated one\n", dev_name);
} }
/* 630ET : set the mii access mode as software-mode */ /* 630ET : set the mii access mode as software-mode */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment