提交 df0d6f7a 编写于 作者: J John Efstathiades 提交者: David S. Miller

lan78xx: Limit number of driver warning messages

Device removal can result in a large burst of driver warning messages
(20 - 30) sent to the kernel log. Most of these are register read/write
failures.

This change limits the rate at which these messages are emitted.
Signed-off-by: NJohn Efstathiades <john.efstathiades@pebblebay.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 77dfff5b
...@@ -462,7 +462,7 @@ static int lan78xx_read_reg(struct lan78xx_net *dev, u32 index, u32 *data) ...@@ -462,7 +462,7 @@ static int lan78xx_read_reg(struct lan78xx_net *dev, u32 index, u32 *data)
if (likely(ret >= 0)) { if (likely(ret >= 0)) {
le32_to_cpus(buf); le32_to_cpus(buf);
*data = *buf; *data = *buf;
} else { } else if (net_ratelimit()) {
netdev_warn(dev->net, netdev_warn(dev->net,
"Failed to read register index 0x%08x. ret = %d", "Failed to read register index 0x%08x. ret = %d",
index, ret); index, ret);
...@@ -492,7 +492,8 @@ static int lan78xx_write_reg(struct lan78xx_net *dev, u32 index, u32 data) ...@@ -492,7 +492,8 @@ static int lan78xx_write_reg(struct lan78xx_net *dev, u32 index, u32 data)
USB_VENDOR_REQUEST_WRITE_REGISTER, USB_VENDOR_REQUEST_WRITE_REGISTER,
USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE, USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
0, index, buf, 4, USB_CTRL_SET_TIMEOUT); 0, index, buf, 4, USB_CTRL_SET_TIMEOUT);
if (unlikely(ret < 0)) { if (unlikely(ret < 0) &&
net_ratelimit()) {
netdev_warn(dev->net, netdev_warn(dev->net,
"Failed to write register index 0x%08x. ret = %d", "Failed to write register index 0x%08x. ret = %d",
index, ret); index, ret);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册