Skip to content

Commit

Permalink
NOMMU: Improve procfs output using per-MM VMAs
Browse files Browse the repository at this point in the history
Improve procfs output using per-MM VMAs for process memory accounting.

Signed-off-by: David Howells <dhowells@redhat.com>
Tested-by: Mike Frysinger <vapier.adi@gmail.com>
Acked-by: Paul Mundt <lethal@linux-sh.org>
  • Loading branch information
David Howells committed Jan 8, 2009
1 parent dd8632a commit 38f7147
Showing 1 changed file with 22 additions and 10 deletions.
32 changes: 22 additions & 10 deletions fs/proc/task_nommu.c
Original file line number Diff line number Diff line change
Expand Up @@ -16,24 +16,31 @@
void task_mem(struct seq_file *m, struct mm_struct *mm)
{
struct vm_area_struct *vma;
struct vm_region *region;
struct rb_node *p;
unsigned long bytes = 0, sbytes = 0, slack = 0;
unsigned long bytes = 0, sbytes = 0, slack = 0, size;

down_read(&mm->mmap_sem);
for (p = rb_first(&mm->mm_rb); p; p = rb_next(p)) {
vma = rb_entry(p, struct vm_area_struct, vm_rb);

bytes += kobjsize(vma);

region = vma->vm_region;
if (region) {
size = kobjsize(region);
size += region->vm_end - region->vm_start;
} else {
size = vma->vm_end - vma->vm_start;
}

if (atomic_read(&mm->mm_count) > 1 ||
vma->vm_region ||
vma->vm_flags & VM_MAYSHARE) {
sbytes += kobjsize((void *) vma->vm_start);
if (vma->vm_region)
sbytes += kobjsize(vma->vm_region);
sbytes += size;
} else {
bytes += kobjsize((void *) vma->vm_start);
slack += kobjsize((void *) vma->vm_start) -
(vma->vm_end - vma->vm_start);
bytes += size;
if (region)
slack = region->vm_end - vma->vm_end;
}
}

Expand Down Expand Up @@ -77,7 +84,7 @@ unsigned long task_vsize(struct mm_struct *mm)
down_read(&mm->mmap_sem);
for (p = rb_first(&mm->mm_rb); p; p = rb_next(p)) {
vma = rb_entry(p, struct vm_area_struct, vm_rb);
vsize += vma->vm_region->vm_end - vma->vm_region->vm_start;
vsize += vma->vm_end - vma->vm_start;
}
up_read(&mm->mmap_sem);
return vsize;
Expand All @@ -87,14 +94,19 @@ int task_statm(struct mm_struct *mm, int *shared, int *text,
int *data, int *resident)
{
struct vm_area_struct *vma;
struct vm_region *region;
struct rb_node *p;
int size = kobjsize(mm);

down_read(&mm->mmap_sem);
for (p = rb_first(&mm->mm_rb); p; p = rb_next(p)) {
vma = rb_entry(p, struct vm_area_struct, vm_rb);
size += kobjsize(vma);
size += kobjsize((void *) vma->vm_start);
region = vma->vm_region;
if (region) {
size += kobjsize(region);
size += region->vm_end - region->vm_start;
}
}

size += (*text = mm->end_code - mm->start_code);
Expand Down

0 comments on commit 38f7147

Please sign in to comment.