aboutsummaryrefslogtreecommitdiffstats
path: root/fs/proc/task_mmu.c
diff options
context:
space:
mode:
authorDavid Rientjes <rientjes@google.com>2007-05-06 17:49:22 -0400
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2007-05-07 15:12:52 -0400
commitf79f177c25016647cc92ffac8afa7cb96ce47011 (patch)
treeb613be041a467fd3ffaed7ad89d8694ede780dfa /fs/proc/task_mmu.c
parent826fad1b93fdb4ffacfd9cd860f06140e852e377 (diff)
smaps: add pages referenced count to smaps
Adds an additional unsigned long field to struct mem_size_stats called 'referenced'. For each pte walked in the smaps code, this field is incremented by PAGE_SIZE if it has pte-reference bits. An additional line was added to the /proc/pid/smaps output for each VMA to indicate how many pages within it are currently marked as referenced or accessed. Cc: Hugh Dickins <hugh@veritas.com> Cc: Paul Mundt <lethal@linux-sh.org> Cc: Christoph Lameter <clameter@sgi.com> Signed-off-by: David Rientjes <rientjes@google.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/proc/task_mmu.c')
-rw-r--r--fs/proc/task_mmu.c20
1 files changed, 13 insertions, 7 deletions
diff --git a/fs/proc/task_mmu.c b/fs/proc/task_mmu.c
index 9d22c1c1caa8..199088ee969b 100644
--- a/fs/proc/task_mmu.c
+++ b/fs/proc/task_mmu.c
@@ -120,6 +120,7 @@ struct mem_size_stats
120 unsigned long shared_dirty; 120 unsigned long shared_dirty;
121 unsigned long private_clean; 121 unsigned long private_clean;
122 unsigned long private_dirty; 122 unsigned long private_dirty;
123 unsigned long referenced;
123}; 124};
124 125
125struct pmd_walker { 126struct pmd_walker {
@@ -188,18 +189,20 @@ static int show_map_internal(struct seq_file *m, void *v, struct mem_size_stats
188 189
189 if (mss) 190 if (mss)
190 seq_printf(m, 191 seq_printf(m,
191 "Size: %8lu kB\n" 192 "Size: %8lu kB\n"
192 "Rss: %8lu kB\n" 193 "Rss: %8lu kB\n"
193 "Shared_Clean: %8lu kB\n" 194 "Shared_Clean: %8lu kB\n"
194 "Shared_Dirty: %8lu kB\n" 195 "Shared_Dirty: %8lu kB\n"
195 "Private_Clean: %8lu kB\n" 196 "Private_Clean: %8lu kB\n"
196 "Private_Dirty: %8lu kB\n", 197 "Private_Dirty: %8lu kB\n"
198 "Pgs_Referenced: %8lu kB\n",
197 (vma->vm_end - vma->vm_start) >> 10, 199 (vma->vm_end - vma->vm_start) >> 10,
198 mss->resident >> 10, 200 mss->resident >> 10,
199 mss->shared_clean >> 10, 201 mss->shared_clean >> 10,
200 mss->shared_dirty >> 10, 202 mss->shared_dirty >> 10,
201 mss->private_clean >> 10, 203 mss->private_clean >> 10,
202 mss->private_dirty >> 10); 204 mss->private_dirty >> 10,
205 mss->referenced >> 10);
203 206
204 if (m->count < m->size) /* vma is copied successfully */ 207 if (m->count < m->size) /* vma is copied successfully */
205 m->version = (vma != get_gate_vma(task))? vma->vm_start: 0; 208 m->version = (vma != get_gate_vma(task))? vma->vm_start: 0;
@@ -232,6 +235,9 @@ static void smaps_one_pmd(struct vm_area_struct *vma, pmd_t *pmd,
232 if (!page) 235 if (!page)
233 continue; 236 continue;
234 237
238 /* Accumulate the size in pages that have been accessed. */
239 if (pte_young(ptent) || PageReferenced(page))
240 mss->referenced += PAGE_SIZE;
235 if (page_mapcount(page) >= 2) { 241 if (page_mapcount(page) >= 2) {
236 if (pte_dirty(ptent)) 242 if (pte_dirty(ptent))
237 mss->shared_dirty += PAGE_SIZE; 243 mss->shared_dirty += PAGE_SIZE;