[PATCH] mm: rss = file_rss + anon_rss
I was lazy when we added anon_rss, and chose to change as few places as possible. So currently each anonymous page has to be counted twice, in rss and in anon_rss. Which won't be so good if those are atomic counts in some configurations. Change that around: keep file_rss and anon_rss separately, and add them together (with get_mm_rss macro) when the total is needed - reading two atomics is much cheaper than updating two atomics. And update anon_rss upfront, typically in memory.c, not tucked away in page_add_anon_rmap. Signed-off-by:Hugh Dickins <hugh@veritas.com> Signed-off-by:
Andrew Morton <akpm@osdl.org> Signed-off-by:
Linus Torvalds <torvalds@osdl.org>
Showing
- fs/exec.c 1 addition, 1 deletionfs/exec.c
- fs/proc/array.c 1 addition, 1 deletionfs/proc/array.c
- fs/proc/task_mmu.c 3 additions, 5 deletionsfs/proc/task_mmu.c
- include/linux/sched.h 3 additions, 1 deletioninclude/linux/sched.h
- kernel/acct.c 1 addition, 1 deletionkernel/acct.c
- kernel/fork.c 2 additions, 2 deletionskernel/fork.c
- mm/fremap.c 2 additions, 2 deletionsmm/fremap.c
- mm/hugetlb.c 3 additions, 3 deletionsmm/hugetlb.c
- mm/memory.c 17 additions, 14 deletionsmm/memory.c
- mm/nommu.c 1 addition, 1 deletionmm/nommu.c
- mm/rmap.c 3 additions, 5 deletionsmm/rmap.c
- mm/swapfile.c 1 addition, 1 deletionmm/swapfile.c
Loading
Please register or sign in to comment