Skip to content

Commit 96ecdcc

Browse files
kuba-moodavem330
authored andcommitted
bnxt: don't enable NAPI until rings are ready
Netpoll can try to poll napi as soon as napi_enable() is called. It crashes trying to access a doorbell which is still NULL: BUG: kernel NULL pointer dereference, address: 0000000000000000 CPU: 59 PID: 6039 Comm: ethtool Kdump: loaded Tainted: G S 5.9.0-rc1-00469-g5fd99b5d9950-dirty #26 RIP: 0010:bnxt_poll+0x121/0x1c0 Code: c4 20 44 89 e0 5b 5d 41 5c 41 5d 41 5e 41 5f c3 41 8b 86 a0 01 00 00 41 23 85 18 01 00 00 49 8b 96 a8 01 00 00 0d 00 00 00 24 <89> 02 41 f6 45 77 02 74 cb 49 8b ae d8 01 00 00 31 c0 c7 44 24 1a netpoll_poll_dev+0xbd/0x1a0 __netpoll_send_skb+0x1b2/0x210 netpoll_send_udp+0x2c9/0x406 write_ext_msg+0x1d7/0x1f0 console_unlock+0x23c/0x520 vprintk_emit+0xe0/0x1d0 printk+0x58/0x6f x86_vector_activate.cold+0xf/0x46 __irq_domain_activate_irq+0x50/0x80 __irq_domain_activate_irq+0x32/0x80 __irq_domain_activate_irq+0x32/0x80 irq_domain_activate_irq+0x25/0x40 __setup_irq+0x2d2/0x700 request_threaded_irq+0xfb/0x160 __bnxt_open_nic+0x3b1/0x750 bnxt_open_nic+0x19/0x30 ethtool_set_channels+0x1ac/0x220 dev_ethtool+0x11ba/0x2240 dev_ioctl+0x1cf/0x390 sock_do_ioctl+0x95/0x130 Reported-by: Rob Sherwood <[email protected]> Fixes: c0c050c ("bnxt_en: New Broadcom ethernet driver.") Signed-off-by: Jakub Kicinski <[email protected]> Reviewed-by: Michael Chan <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 96e97bc commit 96ecdcc

File tree

1 file changed

+4
-8
lines changed
  • drivers/net/ethernet/broadcom/bnxt

1 file changed

+4
-8
lines changed

drivers/net/ethernet/broadcom/bnxt/bnxt.c

+4-8
Original file line numberDiff line numberDiff line change
@@ -9504,15 +9504,15 @@ static int __bnxt_open_nic(struct bnxt *bp, bool irq_re_init, bool link_re_init)
95049504
}
95059505
}
95069506

9507-
bnxt_enable_napi(bp);
9508-
bnxt_debug_dev_init(bp);
9509-
95109507
rc = bnxt_init_nic(bp, irq_re_init);
95119508
if (rc) {
95129509
netdev_err(bp->dev, "bnxt_init_nic err: %x\n", rc);
9513-
goto open_err;
9510+
goto open_err_irq;
95149511
}
95159512

9513+
bnxt_enable_napi(bp);
9514+
bnxt_debug_dev_init(bp);
9515+
95169516
if (link_re_init) {
95179517
mutex_lock(&bp->link_lock);
95189518
rc = bnxt_update_phy_setting(bp);
@@ -9543,10 +9543,6 @@ static int __bnxt_open_nic(struct bnxt *bp, bool irq_re_init, bool link_re_init)
95439543
bnxt_vf_reps_open(bp);
95449544
return 0;
95459545

9546-
open_err:
9547-
bnxt_debug_dev_exit(bp);
9548-
bnxt_disable_napi(bp);
9549-
95509546
open_err_irq:
95519547
bnxt_del_napi(bp);
95529548

0 commit comments

Comments
 (0)