On 2018-02-16 20:48, Guillaume Nault wrote:
On Fri, Feb 16, 2018 at 01:13:18PM +0200, Denys Fedoryshchenko wrote:
On 2018-02-15 21:42, Guillaume Nault wrote:
> On Thu, Feb 15, 2018 at 09:34:42PM +0200, Denys Fedoryshchenko wrote:
> > On 2018-02-15 21:31, Guillaume Nault wrote:
> > > On Thu, Feb 15, 2018 at 06:01:16PM +0200, Denys Fedoryshchenko wrote:
> > > > On 2018-02-15 17:55, Guillaume Nault wrote:
> > > > > On Thu, Feb 15, 2018 at 12:19:52PM +0200, Denys Fedoryshchenko wrote:
> > > > > > Here we go:
> > > > > >
> > > > > > <srv> [24558.921549]
> > > > > > ==================================================================
> > > > > > <srv> [24558.922167] BUG: KASAN: use-after-free in
> > > > > > ppp_ioctl+0xa6a/0x1522
> > > > > > [ppp_generic]
> > > > > > <srv> [24558.922776] Write of size 8 at addr ffff8803d35bf3f8 by
task
> > > > > > accel-pppd/12622
> > > > > > <srv> [24558.923113]
> > > > > > <srv> [24558.923451] CPU: 0 PID: 12622 Comm: accel-pppd Tainted: G
> > > > > > W
> > > > > > 4.15.3-build-0134 #1
> > > > > > <srv> [24558.924058] Hardware name: HP ProLiant DL320e Gen8 v2,
> > > > > > BIOS P80
> > > > > > 04/02/2015
> > > > > > <srv> [24558.924406] Call Trace:
> > > > > > <srv> [24558.924753] dump_stack+0x46/0x59
> > > > > > <srv> [24558.925103] print_address_description+0x6b/0x23b
> > > > > > <srv> [24558.925451] ? ppp_ioctl+0xa6a/0x1522 [ppp_generic]
> > > > > > <srv> [24558.925797] kasan_report+0x21b/0x241
> > > > > > <srv> [24558.926136] ppp_ioctl+0xa6a/0x1522 [ppp_generic]
> > > > > > <srv> [24558.926479] ? ppp_nl_newlink+0x1da/0x1da [ppp_generic]
> > > > > > <srv> [24558.926829] ? sock_sendmsg+0x89/0x99
> > > > > > <srv> [24558.927176] ? __vfs_write+0xd9/0x4ad
> > > > > > <srv> [24558.927523] ? kernel_read+0xed/0xed
> > > > > > <srv> [24558.927872] ? SyS_getpeername+0x18c/0x18c
> > > > > > <srv> [24558.928213] ? bit_waitqueue+0x2a/0x2a
> > > > > > <srv> [24558.928561] ? wake_atomic_t_function+0x115/0x115
> > > > > > <srv> [24558.928898] vfs_ioctl+0x6e/0x81
> > > > > > <srv> [24558.929228] do_vfs_ioctl+0xa00/0xb10
> > > > > > <srv> [24558.929571] ? sigprocmask+0x1a6/0x1d0
> > > > > > <srv> [24558.929907] ? sigsuspend+0x13e/0x13e
> > > > > > <srv> [24558.930239] ? ioctl_preallocate+0x14e/0x14e
> > > > > > <srv> [24558.930568] ? SyS_rt_sigprocmask+0xf1/0x142
> > > > > > <srv> [24558.930904] ? sigprocmask+0x1d0/0x1d0
> > > > > > <srv> [24558.931252] SyS_ioctl+0x39/0x55
> > > > > > <srv> [24558.931595] ? do_vfs_ioctl+0xb10/0xb10
> > > > > > <srv> [24558.931942] do_syscall_64+0x1b1/0x31f
> > > > > > <srv> [24558.932288] entry_SYSCALL_64_after_hwframe+0x21/0x86
> > > > > > <srv> [24558.932627] RIP: 0033:0x7f302849d8a7
> > > > > > <srv> [24558.932965] RSP: 002b:00007f3029a52af8 EFLAGS: 00000206
> > > > > > ORIG_RAX:
> > > > > > 0000000000000010
> > > > > > <srv> [24558.933578] RAX: ffffffffffffffda RBX: 00007f3027d861e3
RCX:
> > > > > > 00007f302849d8a7
> > > > > > <srv> [24558.933927] RDX: 00007f3023f49468 RSI: 000000004004743a
RDI:
> > > > > > 0000000000003a67
> > > > > > <srv> [24558.934266] RBP: 00007f3029a52b20 R08: 0000000000000000
R09:
> > > > > > 000055c8308d8e40
> > > > > > <srv> [24558.934607] R10: 0000000000000008 R11: 0000000000000206
R12:
> > > > > > 00007f3023f49358
> > > > > > <srv> [24558.934947] R13: 00007ffe86e5723f R14: 0000000000000000
R15:
> > > > > > 00007f3029a53700
> > > > > > <srv> [24558.935288]
> > > > > > <srv> [24558.935626] Allocated by task 12622:
> > > > > > <srv> [24558.935972] ppp_register_net_channel+0x5f/0x5c6
> > > > > > [ppp_generic]
> > > > > > <srv> [24558.936306] pppoe_connect+0xab7/0xc71 [pppoe]
> > > > > > <srv> [24558.936640] SyS_connect+0x14b/0x1b7
> > > > > > <srv> [24558.936975] do_syscall_64+0x1b1/0x31f
> > > > > > <srv> [24558.937319] entry_SYSCALL_64_after_hwframe+0x21/0x86
> > > > > > <srv> [24558.937655]
> > > > > > <srv> [24558.937993] Freed by task 12622:
> > > > > > <srv> [24558.938321] kfree+0xb0/0x11d
> > > > > > <srv> [24558.938658] ppp_release+0x111/0x120 [ppp_generic]
> > > > > > <srv> [24558.938994] __fput+0x2ba/0x51a
> > > > > > <srv> [24558.939332] task_work_run+0x11c/0x13d
> > > > > > <srv> [24558.939676] exit_to_usermode_loop+0x7c/0xaf
> > > > > > <srv> [24558.940022] do_syscall_64+0x2ea/0x31f
> > > > > > <srv> [24558.940368] entry_SYSCALL_64_after_hwframe+0x21/0x86
> > > > > > <srv> [24558.947099]
> > > > >
> > > > > Your first guess was right. It looks like we have an issue with
> > > > > reference counting on the channels. Can you send me your
ppp_generic.o?
> > > > http://nuclearcat.com/ppp_generic.o
> > > > Compiled with gcc version 6.4.0 (Gentoo 6.4.0-r1 p1.3)
> > > >
> > > From what I can see, ppp_release() and ioctl(PPPIOCCONNECT) are called
> > > concurrently on the same ppp_file. Even if this ppp_file was pointed at
> > > by two different file descriptors, I can't see how this could defeat
> > > the reference counting mechanism. I'm going to think more about it.
> > >
> > > Can you test with CONFIG_REFCOUNT_FULL? (and keep
> > > d780cd44e3ce ("drivers, net, ppp: convert ppp_file.refcnt from
> > > atomic_t to refcount_t")).
> > Ok, i will try that tonight. On vanilla kernel or reversing
> > mentioned in
> > previous email patch?
> On vanilla kernel. The other is really a shot in the dark.
As far as i can see there is only KASAN triggered again(and server
rebooted
shortly after that), but nothing else:
Ok, so no refcount failure detected. Not what I expected... but that's
still an information. It's getting even harder to find a ppp scenario
that could lead to such symptoms.
If that's acceptable for you, you can try reverting the few commits
that entered after 4.14.
02612bb05e51df8489db5e94d0cf8d1c81f87b0c pppoe: take ->needed_headroom
of lower device into account on xmit
0171c41835591e9aa2e384b703ef9a6ae367c610 ppp: unlock all_ppp_mutex
before registering device
e6675000f9a404f7651724c0b2e2e71f7247d3a1 ppp: exit_net cleanup checks
added
f02b2320b27c16b644691267ee3b5c110846f49e ppp: Destroy the mutex when
cleanup
90e229ef61fad240554f5899eb122fbe44990f78 ppp: allow usage in namespaces
709c89b45b874b2f81a074b8802a736009873f48 drivers, net, ppp: convert
syncppp.refcnt from atomic_t to refcount_t
d780cd44e3cea119a3346e6d7c04d35b9c50d54b drivers, net, ppp: convert
ppp_file.refcnt from atomic_t to refcount_t
313a912155c78ed87ad6fca175dc56b75fd00a58 drivers, net, ppp: convert
asyncppp.refcnt from atomic_t to refcount_t
Sorry, but I have nothing better to propose for now. At least that
should help narrowing the problem space.
I'm going to stress test ppp_generic and pppoe on my side.
Quick update.
Testing 5 first patches didn't changed anything.
But revering more, with last 4 patches also (i did all together) is
changing things, probably i need to repeat one night more reverting just
all refcount_t patches.
[25222.173840] ------------[ cut here ]------------
[25222.174259] NETDEV WATCHDOG: eth1 (ixgbe): transmit queue 3 timed
out
[25222.174618] WARNING: CPU: 3 PID: 0 at net/sched/sch_generic.c:323
dev_watchdog+0x44a/0x555
[25222.175212] Modules linked in: pppoe pppox ppp_generic slhc
netconsole configfs coretemp nf_nat_pptp nf_nat_proto_gre
nf_conntrack_pptp nf_conntrack_proto_gre tun xt_TEE nf_dup_ipv4 x
t_REDIRECT nf_nat_redirect xt_nat xt_TCPMSS ipt_REJECT nf_reject_ipv4
xt_set xt_string xt_connmark xt_DSCP xt_mark xt_tcpudp ip_set_hash_net
ip_set_hash_ip ip_set nfnetlink iptable_mangle iptable_filter iptable_na
t nf_conntrack_ipv4 nf_defrag_ipv4 nf_nat_ipv4 nf_nat nf_conntrack
ip_tables x_tables 8021q garp mrp stp llc ixgbe dca
[25222.177133] CPU: 3 PID: 0 Comm: swapper/3 Tainted: G B W
4.15.3-build-0134 #6
[25222.184121] Hardware name: HP ProLiant DL320e Gen8 v2, BIOS P80
04/02/2015
[25222.184457] RIP: 0010:dev_watchdog+0x44a/0x555
[25222.184791] RSP: 0018:ffff8803f22c7d98 EFLAGS: 00010292
[25222.185127] RAX: 0000000000000000 RBX: ffff8803ded00438 RCX:
0000000000000000
[25222.185463] RDX: 0000000000000001 RSI: 0000000000000002 RDI:
ffffed007e458fa8
[25222.185797] RBP: ffff8803ded00000 R08: 0000000000000001 R09:
0000000000000000
[25222.186133] R10: ffff8803f22c7e30 R11: 0000000000000001 R12:
ffff8803ded28450
[25222.186471] R13: 0000000000000003 R14: dffffc0000000000 R15:
ffff8803ded283c0
[25222.186804] FS: 0000000000000000(0000) GS:ffff8803f22c0000(0000)
knlGS:0000000000000000
[25222.187401] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
[25222.187739] CR2: 0000561f5bffc128 CR3: 0000000445a0d003 CR4:
00000000001606e0
[25222.188077] Call Trace:
[25222.188410] <IRQ>
[25222.188740] ? dev_graft_qdisc+0xfa/0xfa
[25222.189072] call_timer_fn+0x15/0x72
[25222.189407] ? dev_graft_qdisc+0xfa/0xfa
[25222.189741] expire_timers+0x1b9/0x1d5
[25222.190072] run_timer_softirq+0x184/0x361
[25222.190400] ? expire_timers+0x1d5/0x1d5
[25222.190723] ? enqueue_hrtimer+0xce/0xd8
[25222.191048] ? __hrtimer_run_queues+0x1ec/0x24d
[25222.191373] __do_softirq+0x17f/0x34a
[25222.191702] irq_exit+0x8f/0xf9
[25222.192034] smp_apic_timer_interrupt+0xcb/0xd6
[25222.192365] apic_timer_interrupt+0x92/0xa0
[25222.192695] </IRQ>
[25222.193023] RIP: 0010:mwait_idle+0x99/0xac
[25222.193355] RSP: 0018:ffff8803f030fef8 EFLAGS: 00000246 ORIG_RAX:
ffffffffffffff11
[25222.193956] RAX: 0000000000000000 RBX: ffff8803f02e3500 RCX:
0000000000000000
[25222.194290] RDX: 1ffff1007e05c6a0 RSI: 0000000000000000 RDI:
0000000000000000
[25222.194626] RBP: ffff8803f02e3500 R08: ffffed007ccc8eef R09:
ffff8803e6647728
[25222.194958] R10: ffff8803f030fdd0 R11: 0000000000000001 R12:
0000000000000000
[25222.195292] R13: dffffc0000000000 R14: ffffed007e05c6a0 R15:
ffff8803f02e3500
[25222.195627] do_idle+0xe6/0x19a
[25222.195963] cpu_startup_entry+0x18/0x1a
[25222.196295] secondary_startup_64+0xa5/0xb0
[25222.196625] Code: 68 87 40 01 00 75 3f 48 89 ef c6 05 5c 87 40 01 01
e8 64 93 fa ff 44 89 e9 48 89 c2 48 89 ee 48 c7 c7 80 28 68 83 e8 25 69
6d fe <0f> ff eb 17 41 ff c5 49 81 c4 40 0
1 00 00 44 3b 6c 24 04 0f 85
[25222.197511] ---[ end trace 4b04e9c6754a1cd5 ]---
and then
[25222.197853] ixgbe 0000:04:00.1 eth1: initiating reset due to tx
timeout
[25222.198194] ixgbe 0000:04:00.1 eth1: Reset adapter
[25227.805896] ixgbe 0000:04:00.1 eth1: initiating reset due to tx
timeout
[25232.925944] ixgbe 0000:04:00.1 eth1: initiating reset due to tx
timeout
[25236.084968] watchdog: BUG: soft lockup - CPU#0 stuck for 22s!
[accel-pppd:12627]
[25236.085562] Modules linked in: pppoe pppox ppp_generic slhc
netconsole configfs coretemp nf_nat_pptp nf_nat_proto_gre
nf_conntrack_pptp nf_conntrack_proto_gre tun xt_TEE nf_dup_ipv4 x
t_REDIRECT nf_nat_redirect xt_nat xt_TCPMSS ipt_REJECT nf_reject_ipv4
xt_set xt_string xt_connmark xt_DSCP xt_mark xt_tcpudp ip_set_hash_net
ip_set_hash_ip ip_set nfnetlink iptable_mangle iptable_filter iptable_na
t nf_conntrack_ipv4 nf_defrag_ipv4 nf_nat_ipv4 nf_nat nf_conntrack
ip_tables x_tables 8021q garp mrp stp llc ixgbe dca
[25236.087496] CPU: 0 PID: 12627 Comm: accel-pppd Tainted: G B W
4.15.3-build-0134 #6
[25236.088095] Hardware name: HP ProLiant DL320e Gen8 v2, BIOS P80
04/02/2015
[25236.088430] RIP: 0010:queued_spin_lock_slowpath+0xb1/0x418
[25236.088759] RSP: 0018:ffff8803e6457a98 EFLAGS: 00000213 ORIG_RAX:
ffffffffffffff11
[25236.089353] RAX: 00000000000001fb RBX: ffff880345e75fe0 RCX:
ffffffff811aeca3
[25236.089685] RDX: 0000000000000000 RSI: 0000000000000004 RDI:
ffff880345e75fe0
[25236.090026] RBP: ffffed0068bcebfc R08: 06030a0001012180 R09:
ffffed006cc9beb2
[25236.090369] R10: ffffed006cc9beb3 R11: 0000000000000001 R12:
0000000000000003
[25236.090705] R13: 0000000000008021 R14: 0000000000008021 R15:
00000000034e4b06
[25236.091043] FS: 00007f94bd26c700(0000) GS:ffff8803f2200000(0000)
knlGS:0000000000000000
[25236.091636] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
[25236.091966] CR2: 00007ffc0935eff8 CR3: 00000003d709b003 CR4:
00000000001606f0
[25236.092304] Call Trace:
[25236.092638] ppp_push+0x112/0xdda [ppp_generic]
[25236.092975] ? enqueue_hrtimer+0xce/0xd8
[25236.093304] ? hrtimer_start_range_ns+0x827/0x854
[25236.093635] __ppp_xmit_process+0xc6a/0xdd5 [ppp_generic]
[25236.093969] ? __kmalloc_reserve.isra.5+0x29/0x96
[25236.094302] ? memset+0x1f/0x31
[25236.094631] ? ppp_receive_nonmp_frame+0x138c/0x138c [ppp_generic]
[25236.094962] ? __alloc_skb+0x2ec/0x431
[25236.095292] ? __kmalloc_reserve.isra.5+0x96/0x96
[25236.095620] ? timerfd_release+0x1d3/0x1d3
[25236.095950] ppp_xmit_process+0xc3/0x194 [ppp_generic]
[25236.096284] ppp_write+0x1b7/0x1c3 [ppp_generic]
[25236.096617] __vfs_write+0xd9/0x4ad
[25236.096953] ? kernel_read+0xed/0xed
[25236.097283] ? vfs_copy_file_range+0x6a8/0x6a8
[25236.097614] ? bit_waitqueue+0x2a/0x2a
[25236.097946] ? __fsnotify_inode_delete+0xc/0xc
[25236.098276] ? __fsnotify_inode_delete+0xc/0xc
[25236.098610] ? SyS_sendmmsg+0x13/0x13
[25236.098936] vfs_write+0x18c/0x378
[25236.099258] SyS_write+0xc4/0x13b
[25236.099579] ? SyS_read+0x13b/0x13b
[25236.099902] ? exit_to_usermode_loop+0x7c/0xaf
[25236.100225] ? SyS_read+0x13b/0x13b
[25236.100550] do_syscall_64+0x1b1/0x31f
[25236.100879] entry_SYSCALL_64_after_hwframe+0x21/0x86
[25236.101210] RIP: 0033:0x7f94bca53b2d
[25236.101536] RSP: 002b:00007f94bd26bb80 EFLAGS: 00000293 ORIG_RAX:
0000000000000001
[25236.102127] RAX: ffffffffffffffda RBX: 00007f94bb59f1e3 RCX:
00007f94bca53b2d
[25236.102461] RDX: 000000000000000c RSI: 00007f94b78895d0 RDI:
0000000000002f92
[25236.102793] RBP: 00007f94bd26bbb0 R08: 0000000000000030 R09:
0000000000000027
[25236.103127] R10: 0000000000000000 R11: 0000000000000293 R12:
00007f94b6450eb8
[25236.103460] R13: 00007ffc8c047a6f R14: 0000000000000000 R15:
00007f94bd26c700
[25236.103790] Code: 83 03 00 00 48 89 dd 49 89 dc 48 b8 00 00 00 00 00
fc ff df 48 c1 ed 03 41 83 e4 07 48 01 c5 41 83 c4 03 8a 45 00 41 38 c4
7c 0c <84> c0 74 08 48 89 df e8 31 54 17 0
0 8b 03 84 c0 74 04 f3 90 eb
Then system autorebooted.
Maybe i am hitting some qdisc bug now...