[BPQ] lockdep: fix false positive
Bpqether is encapsulating AX.25 frames into ethernet frames. There is a virtual bpqether device paired with each ethernet devices, so it's normal to pass through dev_queue_xmit twice for each frame which triggers the locking detector. Signed-off-by: Ralf Baechle <ralf@linux-mips.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
7466d90f85
commit
1eeb7e4288
|
@ -122,6 +122,12 @@ struct bpqdev {
|
||||||
|
|
||||||
static LIST_HEAD(bpq_devices);
|
static LIST_HEAD(bpq_devices);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* bpqether network devices are paired with ethernet devices below them, so
|
||||||
|
* form a special "super class" of normal ethernet devices; split their locks
|
||||||
|
* off into a separate class since they always nest.
|
||||||
|
*/
|
||||||
|
static struct lock_class_key bpq_netdev_xmit_lock_key;
|
||||||
|
|
||||||
/* ------------------------------------------------------------------------ */
|
/* ------------------------------------------------------------------------ */
|
||||||
|
|
||||||
|
@ -528,6 +534,7 @@ static int bpq_new_device(struct net_device *edev)
|
||||||
err = register_netdevice(ndev);
|
err = register_netdevice(ndev);
|
||||||
if (err)
|
if (err)
|
||||||
goto error;
|
goto error;
|
||||||
|
lockdep_set_class(&ndev->_xmit_lock, &bpq_netdev_xmit_lock_key);
|
||||||
|
|
||||||
/* List protected by RTNL */
|
/* List protected by RTNL */
|
||||||
list_add_rcu(&bpq->bpq_list, &bpq_devices);
|
list_add_rcu(&bpq->bpq_list, &bpq_devices);
|
||||||
|
|
Loading…
Reference in New Issue