Loading fs/proc/task_nommu.c +22 −10 Original line number Diff line number Diff line Loading @@ -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; } } Loading Loading @@ -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; Loading @@ -87,6 +94,7 @@ 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); Loading @@ -94,7 +102,11 @@ int task_statm(struct mm_struct *mm, int *shared, int *text, 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); Loading Loading
fs/proc/task_nommu.c +22 −10 Original line number Diff line number Diff line Loading @@ -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; } } Loading Loading @@ -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; Loading @@ -87,6 +94,7 @@ 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); Loading @@ -94,7 +102,11 @@ int task_statm(struct mm_struct *mm, int *shared, int *text, 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); Loading