提交 f4e8ab7c 编写于 作者: B Bernard Blackham 提交者: David S. Miller

smsc95xx: generate random MAC address once, not every ifup

The smsc95xx driver currently generates a new random MAC address
every time the interface is brought up. This makes it impossible to
override using the standard `ifconfig hw ether` approach.

Past patches tried to make the MAC address a module parameter or
base it off the die ID, but it seems to me much simpler (and
hopefully less controversial) to stick with the current random
generation scheme, but allow the user to change the address.

This patch does exactly that - it moves the random address
generation from smsc95xx_reset() into smsc95xx_bind(), so that it is
done once on module load, not on every ifup. The user can then
override this using the standard mechanisms.

Applies against 2.6.35 and linux-2.6 head.
Signed-off-by: NBernard Blackham <b-omap@largestprime.net>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 fdb246f5
...@@ -805,8 +805,6 @@ static int smsc95xx_reset(struct usbnet *dev) ...@@ -805,8 +805,6 @@ static int smsc95xx_reset(struct usbnet *dev)
return ret; return ret;
} }
smsc95xx_init_mac_address(dev);
ret = smsc95xx_set_mac_address(dev); ret = smsc95xx_set_mac_address(dev);
if (ret < 0) if (ret < 0)
return ret; return ret;
...@@ -1047,6 +1045,8 @@ static int smsc95xx_bind(struct usbnet *dev, struct usb_interface *intf) ...@@ -1047,6 +1045,8 @@ static int smsc95xx_bind(struct usbnet *dev, struct usb_interface *intf)
pdata->use_tx_csum = DEFAULT_TX_CSUM_ENABLE; pdata->use_tx_csum = DEFAULT_TX_CSUM_ENABLE;
pdata->use_rx_csum = DEFAULT_RX_CSUM_ENABLE; pdata->use_rx_csum = DEFAULT_RX_CSUM_ENABLE;
smsc95xx_init_mac_address(dev);
/* Init all registers */ /* Init all registers */
ret = smsc95xx_reset(dev); ret = smsc95xx_reset(dev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册