Jiexun Wang
b2f557a21b
mm/madvise: add cond_resched() in madvise_cold_or_pageout_pte_range()
...
I conducted real-time testing and observed that
madvise_cold_or_pageout_pte_range() causes significant latency under
memory pressure, which can be effectively reduced by adding cond_resched()
within the loop.
I tested on the LicheePi 4A board using Cylictest for latency testing and
Ftrace for latency tracing. The board uses TH1520 processor and has a
memory size of 8GB. The kernel version is 6.5.0 with the PREEMPT_RT patch
applied.
The script I tested is as follows:
echo wakeup_rt > /sys/kernel/tracing/current_tracer
echo 1 > /sys/kernel/tracing/tracing_on
echo 0 > /sys/kernel/tracing/tracing_max_latency
stress-ng --vm 8 --vm-bytes 2G &
cyclictest --mlockall --smp --priority=99 --distance=0 --duration=30m
echo 0 > /sys/kernel/tracing/tracing_on
cat /sys/kernel/tracing/trace
The tracing results before modification are as follows:
# tracer: wakeup_rt
#
# wakeup_rt latency trace v1.1.5 on 6.5.0-rt6-r1208-00003-g999d221864bf
# --------------------------------------------------------------------
# latency: 2552 us, #6/6, CPU#3 | (M:preempt_rt VP:0, KP:0, SP:0 HP:0 #P:4)
# -----------------
# | task: cyclictest-196 (uid:0 nice:0 policy:1 rt_prio:99)
# -----------------
#
# _--------=> CPU#
# / _-------=> irqs-off/BH-disabled
# | / _------=> need-resched
# || / _-----=> need-resched-lazy
# ||| / _----=> hardirq/softirq
# |||| / _---=> preempt-depth
# ||||| / _--=> preempt-lazy-depth
# |||||| / _-=> migrate-disable
# ||||||| / delay
# cmd pid |||||||| time | caller
# \ / |||||||| \ | /
stress-n-206 3dn.h512 2us : 206:120:R + [003] 196: 0:R cyclictest
stress-n-206 3dn.h512 7us : <stack trace>
=> __ftrace_trace_stack
=> __trace_stack
=> probe_wakeup
=> ttwu_do_activate
=> try_to_wake_up
=> wake_up_process
=> hrtimer_wakeup
=> __hrtimer_run_queues
=> hrtimer_interrupt
=> riscv_timer_interrupt
=> handle_percpu_devid_irq
=> generic_handle_domain_irq
=> riscv_intc_irq
=> handle_riscv_irq
=> do_irq
stress-n-206 3dn.h512 9us#: 0
stress-n-206 3d...3.. 2544us : __schedule
stress-n-206 3d...3.. 2545us : 206:120:R ==> [003] 196: 0:R cyclictest
stress-n-206 3d...3.. 2551us : <stack trace>
=> __ftrace_trace_stack
=> __trace_stack
=> probe_wakeup_sched_switch
=> __schedule
=> preempt_schedule
=> migrate_enable
=> rt_spin_unlock
=> madvise_cold_or_pageout_pte_range
=> walk_pgd_range
=> __walk_page_range
=> walk_page_range
=> madvise_pageout
=> madvise_vma_behavior
=> do_madvise
=> sys_madvise
=> do_trap_ecall_u
=> ret_from_exception
The tracing results after modification are as follows:
# tracer: wakeup_rt
#
# wakeup_rt latency trace v1.1.5 on 6.5.0-rt6-r1208-00004-gca3876fc69a6-dirty
# --------------------------------------------------------------------
# latency: 1689 us, #6/6, CPU#0 | (M:preempt_rt VP:0, KP:0, SP:0 HP:0 #P:4)
# -----------------
# | task: cyclictest-217 (uid:0 nice:0 policy:1 rt_prio:99)
# -----------------
#
# _--------=> CPU#
# / _-------=> irqs-off/BH-disabled
# | / _------=> need-resched
# || / _-----=> need-resched-lazy
# ||| / _----=> hardirq/softirq
# |||| / _---=> preempt-depth
# ||||| / _--=> preempt-lazy-depth
# |||||| / _-=> migrate-disable
# ||||||| / delay
# cmd pid |||||||| time | caller
# \ / |||||||| \ | /
stress-n-232 0dn.h413 1us+: 232:120:R + [000] 217: 0:R cyclictest
stress-n-232 0dn.h413 12us : <stack trace>
=> __ftrace_trace_stack
=> __trace_stack
=> probe_wakeup
=> ttwu_do_activate
=> try_to_wake_up
=> wake_up_process
=> hrtimer_wakeup
=> __hrtimer_run_queues
=> hrtimer_interrupt
=> riscv_timer_interrupt
=> handle_percpu_devid_irq
=> generic_handle_domain_irq
=> riscv_intc_irq
=> handle_riscv_irq
=> do_irq
stress-n-232 0dn.h413 19us#: 0
stress-n-232 0d...3.. 1671us : __schedule
stress-n-232 0d...3.. 1676us+: 232:120:R ==> [000] 217: 0:R cyclictest
stress-n-232 0d...3.. 1687us : <stack trace>
=> __ftrace_trace_stack
=> __trace_stack
=> probe_wakeup_sched_switch
=> __schedule
=> preempt_schedule
=> migrate_enable
=> free_unref_page_list
=> release_pages
=> free_pages_and_swap_cache
=> tlb_batch_pages_flush
=> tlb_flush_mmu
=> unmap_page_range
=> unmap_vmas
=> unmap_region
=> do_vmi_align_munmap.constprop.0
=> do_vmi_munmap
=> __vm_munmap
=> sys_munmap
=> do_trap_ecall_u
=> ret_from_exception
After the modification, the cause of maximum latency is no longer
madvise_cold_or_pageout_pte_range(), so this modification can reduce the
latency caused by madvise_cold_or_pageout_pte_range().
Currently the madvise_cold_or_pageout_pte_range() function exhibits
significant latency under memory pressure, which can be effectively
reduced by adding cond_resched() within the loop.
When the batch_count reaches SWAP_CLUSTER_MAX, we reschedule
the task to ensure fairness and avoid long lock holding times.
Link: https://lkml.kernel.org/r/85363861af65fac66c7a98c251906afc0d9c8098.1695291046.git.wangjiexun@tinylab.org
Signed-off-by: Jiexun Wang <wangjiexun@tinylab.org>
Cc: Zhangjin Wu <falcon@tinylab.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
2023-12-06 16:12:50 -08:00
..
2023-12-06 16:12:48 -08:00
2023-11-02 19:38:47 -10:00
2023-09-08 12:16:52 -07:00
2023-10-25 16:47:10 -07:00
2023-08-21 13:37:48 -07:00
2023-10-25 16:47:13 -07:00
2023-03-28 16:20:06 -07:00
2023-10-04 10:32:29 -07:00
2023-10-04 10:32:19 -07:00
2023-06-09 16:25:23 -07:00
2023-10-25 16:47:14 -07:00
2023-06-09 16:25:31 -07:00
2023-04-05 19:42:38 -07:00
2023-06-09 16:25:17 -07:00
2023-06-09 16:25:56 -07:00
2023-06-23 16:59:31 -07:00
2023-06-09 16:25:23 -07:00
2022-11-22 18:50:44 -08:00
2023-12-06 16:12:45 -08:00
2023-07-24 18:04:30 -04:00
2023-06-23 16:58:19 -07:00
2022-11-08 17:37:15 -08:00
2023-10-18 14:34:15 -07:00
2023-06-19 16:19:25 -07:00
2023-08-21 13:07:20 -07:00
2023-11-15 15:30:09 -08:00
2023-10-18 14:34:17 -07:00
2023-10-25 16:47:08 -07:00
2023-10-25 16:47:14 -07:00
2023-12-06 16:12:43 -08:00
2022-10-03 14:03:05 -07:00
2023-08-21 13:37:46 -07:00
2023-10-25 16:47:16 -07:00
2023-08-18 10:12:36 -07:00
2023-12-06 16:12:47 -08:00
2023-05-29 16:14:28 +01:00
2023-11-02 20:53:31 -10:00
2023-12-06 16:12:44 -08:00
2023-11-15 15:30:09 -08:00
2023-04-12 17:36:23 -07:00
2023-12-06 16:12:50 -08:00
2023-10-04 10:32:23 -07:00
2023-08-24 16:20:30 -07:00
2023-11-08 09:40:13 -08:00
2023-12-06 16:12:44 -08:00
2023-10-04 10:32:22 -07:00
2023-12-06 16:12:46 -08:00
2023-10-04 10:32:20 -07:00
2023-10-16 15:44:39 -07:00
2023-12-06 16:12:43 -08:00
2023-11-02 19:38:47 -10:00
2022-11-30 15:58:41 -08:00
2023-02-09 16:51:46 -08:00
2023-08-21 13:37:47 -07:00
2023-08-31 12:20:12 -07:00
2023-10-25 16:47:14 -07:00
2023-08-21 13:07:20 -07:00
2023-10-25 16:47:14 -07:00
2023-10-04 10:32:30 -07:00
2022-10-03 14:02:43 -07:00
2023-11-02 19:38:47 -10:00
2023-08-24 16:20:30 -07:00
2023-08-18 10:12:41 -07:00
2023-10-25 16:47:13 -07:00
2023-10-25 16:47:12 -07:00
2023-10-18 14:34:18 -07:00
2023-11-02 19:38:47 -10:00
2023-10-25 16:47:10 -07:00
2023-10-25 16:47:16 -07:00
2023-08-18 10:12:31 -07:00
2023-01-18 17:12:52 -08:00
2023-10-04 10:32:27 -07:00
2023-08-18 10:12:39 -07:00
2023-10-18 14:34:19 -07:00
2023-08-21 13:37:30 -07:00
2023-04-05 19:42:46 -07:00
2023-08-24 16:20:18 -07:00
2023-08-18 10:12:13 -07:00
2023-11-20 15:05:18 +01:00
2023-09-02 08:39:21 -07:00
2023-06-19 16:19:29 -07:00
2023-11-02 19:38:47 -10:00
2023-08-18 10:12:25 -07:00
2023-06-09 16:25:25 -07:00
2023-06-19 16:19:24 -07:00
2023-10-19 11:02:49 +02:00
2023-10-18 14:34:14 -07:00
2022-10-03 14:03:05 -07:00
2023-08-21 13:38:02 -07:00
2023-08-09 09:15:40 +02:00
2023-11-02 20:53:31 -10:00
2023-10-04 10:32:19 -07:00
2023-10-04 10:32:26 -07:00
2023-10-04 10:32:26 -07:00
2022-10-03 14:03:07 -07:00
2023-04-05 19:42:46 -07:00
2023-10-30 18:01:41 -10:00
2023-07-18 10:07:47 +02:00
2023-10-25 16:47:11 -07:00
2023-10-02 11:55:47 +02:00
2023-08-18 10:12:53 -07:00
2023-08-18 10:12:14 -07:00
2022-10-03 14:03:36 -07:00
2022-10-03 14:02:46 -07:00
2023-10-25 16:47:16 -07:00
2023-06-23 16:59:30 -07:00
2023-10-25 16:47:16 -07:00
2023-10-28 13:29:19 +02:00
2023-08-29 14:25:26 -07:00
2023-04-12 17:36:23 -07:00
2023-11-15 15:30:09 -08:00
2023-11-15 15:30:09 -08:00
2023-11-01 12:38:35 -07:00
2023-08-16 12:21:32 +01:00
2023-10-18 14:34:14 -07:00
2023-10-25 16:47:10 -07:00
2023-10-04 10:32:24 -07:00
2023-08-21 13:37:51 -07:00
2023-06-19 16:19:27 -07:00
2023-06-19 16:19:27 -07:00
2023-10-18 14:34:16 -07:00
2023-11-01 12:38:35 -07:00