mirror of
https://github.com/torvalds/linux.git
synced 2026-03-08 03:24:45 +01:00
net: usb: kaweth: remove TX queue manipulation in kaweth_set_rx_mode
kaweth_set_rx_mode(), the ndo_set_rx_mode callback, calls
netif_stop_queue() and netif_wake_queue(). These are TX queue flow
control functions unrelated to RX multicast configuration.
The premature netif_wake_queue() can re-enable TX while tx_urb is still
in-flight, leading to a double usb_submit_urb() on the same URB:
kaweth_start_xmit() {
netif_stop_queue();
usb_submit_urb(kaweth->tx_urb);
}
kaweth_set_rx_mode() {
netif_stop_queue();
netif_wake_queue(); // wakes TX queue before URB is done
}
kaweth_start_xmit() {
netif_stop_queue();
usb_submit_urb(kaweth->tx_urb); // URB submitted while active
}
This triggers the WARN in usb_submit_urb():
"URB submitted while active"
This is a similar class of bug fixed in rtl8150 by
- commit 958baf5eae ("net: usb: Remove disruptive netif_wake_queue in rtl8150_set_multicast").
Also kaweth_set_rx_mode() is already functionally broken, the
real set_rx_mode action is performed by kaweth_async_set_rx_mode(),
which in turn is not a no-op only at ndo_open() time.
Suggested-by: Paolo Abeni <pabeni@redhat.com>
Fixes: 1da177e4c3 ("Linux-2.6.12-rc2")
Signed-off-by: Ziyi Guo <n7l8m4@u.northwestern.edu>
Link: https://patch.msgid.link/20260217175012.1234494-1-n7l8m4@u.northwestern.edu
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
e1512c1db9
commit
64868f5eca
1 changed files with 0 additions and 2 deletions
|
|
@ -765,7 +765,6 @@ static void kaweth_set_rx_mode(struct net_device *net)
|
|||
|
||||
netdev_dbg(net, "Setting Rx mode to %d\n", packet_filter_bitmap);
|
||||
|
||||
netif_stop_queue(net);
|
||||
|
||||
if (net->flags & IFF_PROMISC) {
|
||||
packet_filter_bitmap |= KAWETH_PACKET_FILTER_PROMISCUOUS;
|
||||
|
|
@ -775,7 +774,6 @@ static void kaweth_set_rx_mode(struct net_device *net)
|
|||
}
|
||||
|
||||
kaweth->packet_filter_bitmap = packet_filter_bitmap;
|
||||
netif_wake_queue(net);
|
||||
}
|
||||
|
||||
/****************************************************************
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue