Paul E. McKenney
261da4b2d3
mm/mmap.c: Add cond_resched() for exit_mmap() CPU stalls
...
[ Upstream commit 0a3b3c253a1eb2c7fe7f34086d46660c909abeb3 ]
A large process running on a heavily loaded system can encounter the
following RCU CPU stall warning:
rcu: INFO: rcu_sched self-detected stall on CPU
rcu: 3-....: (20998 ticks this GP) idle=4ea/1/0x4000000000000002 softirq=556558/556558 fqs=5190
(t=21013 jiffies g=1005461 q=132576)
NMI backtrace for cpu 3
CPU: 3 PID: 501900 Comm: aio-free-ring-w Kdump: loaded Not tainted 5.2.9-108_fbk12_rc3_3858_gb83b75af7909 #1
Hardware name: Wiwynn HoneyBadger/PantherPlus, BIOS HBM6.71 02/03/2016
Call Trace:
<IRQ>
dump_stack+0x46/0x60
nmi_cpu_backtrace.cold.3+0x13/0x50
? lapic_can_unplug_cpu.cold.27+0x34/0x34
nmi_trigger_cpumask_backtrace+0xba/0xca
rcu_dump_cpu_stacks+0x99/0xc7
rcu_sched_clock_irq.cold.87+0x1aa/0x397
? tick_sched_do_timer+0x60/0x60
update_process_times+0x28/0x60
tick_sched_timer+0x37/0x70
__hrtimer_run_queues+0xfe/0x270
hrtimer_interrupt+0xf4/0x210
smp_apic_timer_interrupt+0x5e/0x120
apic_timer_interrupt+0xf/0x20
</IRQ>
RIP: 0010:kmem_cache_free+0x223/0x300
Code: 88 00 00 00 0f 85 ca 00 00 00 41 8b 55 18 31 f6 f7 da 41 f6 45 0a 02 40 0f 94 c6 83 c6 05 9c 41 5e fa e8 a0 a7 01 00 41 56 9d <49> 8b 47 08 a8 03 0f 85 87 00 00 00 65 48 ff 08 e9 3d fe ff ff 65
RSP: 0018:ffffc9000e8e3da8 EFLAGS: 00000206 ORIG_RAX: ffffffffffffff13
RAX: 0000000000020000 RBX: ffff88861b9de960 RCX: 0000000000000030
RDX: fffffffffffe41e8 RSI: 000060777fe3a100 RDI: 000000000001be18
RBP: ffffea00186e7780 R08: ffffffffffffffff R09: ffffffffffffffff
R10: ffff88861b9dea28 R11: ffff88887ffde000 R12: ffffffff81230a1f
R13: ffff888854684dc0 R14: 0000000000000206 R15: ffff8888547dbc00
? remove_vma+0x4f/0x60
remove_vma+0x4f/0x60
exit_mmap+0xd6/0x160
mmput+0x4a/0x110
do_exit+0x278/0xae0
? syscall_trace_enter+0x1d3/0x2b0
? handle_mm_fault+0xaa/0x1c0
do_group_exit+0x3a/0xa0
__x64_sys_exit_group+0x14/0x20
do_syscall_64+0x42/0x100
entry_SYSCALL_64_after_hwframe+0x44/0xa9
And on a PREEMPT=n kernel, the "while (vma)" loop in exit_mmap() can run
for a very long time given a large process. This commit therefore adds
a cond_resched() to this loop, providing RCU any needed quiescent states.
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: <linux-mm@kvack.org>
Reviewed-by: Shakeel Butt <shakeelb@google.com>
Reviewed-by: Joel Fernandes (Google) <joel@joelfernandes.org>
Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2020-08-21 11:01:58 +02:00
..
2019-05-08 07:19:07 +02:00
2019-05-21 18:49:01 +02:00
2016-07-26 16:19:19 -07:00
2016-10-11 15:06:33 -07:00
2016-01-27 09:09:57 -05:00
2019-06-22 08:17:12 +02:00
2019-08-06 18:29:37 +02:00
2017-01-12 11:39:32 +01:00
2016-03-17 15:09:34 -07:00
2018-09-19 22:47:17 +02:00
2016-03-17 15:09:34 -07:00
2018-02-25 11:05:49 +01:00
2018-09-15 09:42:57 +02:00
2016-03-15 16:55:16 -07:00
2019-11-12 19:16:10 +01:00
2018-11-10 07:42:52 -08:00
2016-07-26 16:19:19 -07:00
2019-06-11 12:22:45 +02:00
2016-05-19 19:12:14 -07:00
2020-06-20 10:24:19 +02:00
2019-11-25 09:51:58 +01:00
2019-06-22 08:17:12 +02:00
2017-01-06 10:40:13 +01:00
2019-12-05 15:35:02 +01:00
2018-05-22 16:57:57 +02:00
2016-09-13 02:35:27 +02:00
2019-08-06 18:29:41 +02:00
2016-03-17 15:09:34 -07:00
2016-03-17 15:09:34 -07:00
2019-08-04 09:33:41 +02:00
2019-11-28 18:28:09 +01:00
2019-06-22 08:17:18 +02:00
2016-05-22 17:21:27 -07:00
2018-10-10 08:53:20 +02:00
2016-10-12 10:23:41 -07:00
2017-08-30 10:21:47 +02:00
2020-07-31 16:44:05 +02:00
2019-11-28 18:28:51 +01:00
2019-03-23 13:19:49 +01:00
2019-02-20 10:18:34 +01:00
2020-04-13 10:32:54 +02:00
2016-07-28 16:07:41 -07:00
2019-03-13 14:04:54 -07:00
2019-05-21 18:48:58 +02:00
2019-07-10 09:55:43 +02:00
2016-03-17 15:09:34 -07:00
2020-08-21 11:01:58 +02:00
2016-04-28 11:44:19 +02:00
2019-08-04 09:33:42 +02:00
2016-05-19 19:12:14 -07:00
2018-08-15 18:14:45 +02:00
2020-06-11 09:22:20 +02:00
2015-11-05 19:34:48 -08:00
2017-08-24 17:12:19 -07:00
2020-04-02 17:20:26 +02:00
2019-02-12 19:45:02 +01:00
2020-05-20 08:15:28 +02:00
2015-11-05 19:34:48 -08:00
2019-04-05 22:29:06 +02:00
2019-07-10 09:55:38 +02:00
2016-10-07 18:46:29 -07:00
2016-10-07 18:46:29 -07:00
2016-10-07 18:46:27 -07:00
2016-06-03 15:06:22 -07:00
2020-01-23 08:19:40 +01:00
2017-11-24 08:33:42 +01:00
2016-03-17 15:09:34 -07:00
2019-04-27 09:34:47 +02:00
2016-03-17 15:09:34 -07:00
2016-10-18 14:13:37 -07:00
2016-03-17 15:09:34 -07:00
2016-08-26 17:39:35 -07:00
2018-11-21 09:26:03 +01:00
2020-05-20 08:15:33 +02:00
2020-06-30 15:38:44 -04:00
2019-06-22 08:17:13 +02:00
2017-03-22 12:43:38 +01:00
2017-03-22 12:43:38 +01:00
2020-07-09 09:35:55 +02:00
2016-08-02 17:31:41 -04:00
2017-10-21 17:21:36 +02:00
2017-07-05 14:40:17 +02:00
2020-07-09 09:35:54 +02:00
2016-10-07 18:46:28 -07:00
2018-08-15 18:14:45 +02:00
2018-12-08 13:05:09 +01:00
2019-10-17 13:42:06 -07:00
2016-04-04 10:41:08 -07:00
2019-01-16 22:12:32 +01:00
2018-09-19 22:47:17 +02:00
2020-06-03 08:16:47 +02:00
2017-03-12 06:41:43 +01:00
2018-09-19 22:47:12 +02:00
2019-11-12 19:15:43 +01:00
2017-04-08 09:30:36 +02:00
2016-06-03 16:02:55 -07:00
2016-01-15 11:40:52 -08:00
2015-11-06 17:50:42 -08:00
2020-01-12 11:24:13 +01:00
2018-09-05 09:20:02 +02:00