diff options
| author | Sergei Trofimovich <[email protected]> | 2021-04-29 22:55:08 -0700 | 
|---|---|---|
| committer | Linus Torvalds <[email protected]> | 2021-04-30 11:20:36 -0700 | 
| commit | 8e9b16c47680f6e7d6e5864a37f313f905a91cf5 (patch) | |
| tree | 808c4e3b1e920e4a0c570f2eab9deec1ff14bb83 /tools/perf/scripts/python/bin/stackcollapse-record | |
| parent | 608b5d668c8ea6734594a401c9adab4093ad9847 (diff) | |
mm: page_owner: detect page_owner recursion via task_struct
Before the change page_owner recursion was detected via fetching
backtrace and inspecting it for current instruction pointer.
It has a few problems:
 - it is slightly slow as it requires extra backtrace and a linear stack
   scan of the result
 - it is too late to check if backtrace fetching required memory
   allocation itself (ia64's unwinder requires it).
To simplify recursion tracking let's use page_owner recursion flag in
'struct task_struct'.
The change make page_owner=on work on ia64 by avoiding infinite
recursion in:
  kmalloc()
  -> __set_page_owner()
  -> save_stack()
  -> unwind() [ia64-specific]
  -> build_script()
  -> kmalloc()
  -> __set_page_owner() [we short-circuit here]
  -> save_stack()
  -> unwind() [recursion]
Link: https://lkml.kernel.org/r/[email protected]
Signed-off-by: Sergei Trofimovich <[email protected]>
Reviewed-by: Andrew Morton <[email protected]>
Acked-by: Vlastimil Babka <[email protected]>
Cc: Ingo Molnar <[email protected]>
Cc: Peter Zijlstra <[email protected]>
Cc: Juri Lelli <[email protected]>
Cc: Vincent Guittot <[email protected]>
Cc: Dietmar Eggemann <[email protected]>
Cc: Steven Rostedt <[email protected]>
Cc: Ben Segall <[email protected]>
Cc: Mel Gorman <[email protected]>
Cc: Daniel Bristot de Oliveira <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/bin/stackcollapse-record')
0 files changed, 0 insertions, 0 deletions