aboutsummaryrefslogtreecommitdiff
path: root/kernel/trace/trace_workqueue.c
diff options
context:
space:
mode:
authorMel Gorman <[email protected]>2011-01-13 15:46:23 -0800
committerLinus Torvalds <[email protected]>2011-01-13 17:32:37 -0800
commit4d40502ea580c35414a1466d86f96484910ebaec (patch)
treeed03d2b5a100be1c3371d304421af221fa893129 /kernel/trace/trace_workqueue.c
parent0abdee2bd4118366c62349a304f81537be69af33 (diff)
mm: kswapd: reset kswapd_max_order and classzone_idx after reading
When kswapd wakes up, it reads its order and classzone from pgdat and calls balance_pgdat. While its awake, it potentially reclaimes at a high order and a low classzone index. This might have been a once-off that was not required by subsequent callers. However, because the pgdat values were not reset, they remain artifically high while balance_pgdat() is running and potentially kswapd enters a second unnecessary reclaim cycle. Reset the pgdat order and classzone index after reading. Signed-off-by: Mel Gorman <[email protected]> Reviewed-by: Minchan Kim <[email protected]> Reviewed-by: KAMEZAWA Hiroyuki <[email protected]> Reviewed-by: Eric B Munson <[email protected]> Cc: Simon Kirby <[email protected]> Cc: KOSAKI Motohiro <[email protected]> Cc: Shaohua Li <[email protected]> Cc: Dave Hansen <[email protected]> Cc: Johannes Weiner <[email protected]> Cc: Rik van Riel <[email protected]> Signed-off-by: Andrew Morton <[email protected]> Signed-off-by: Linus Torvalds <[email protected]>
Diffstat (limited to 'kernel/trace/trace_workqueue.c')
0 files changed, 0 insertions, 0 deletions