Linux通过一个叫做 task_statm 的函数来返回进程的内存使用状况
int task_statm(struct mm_struct *mm, int *shared, int *text,
int *data, int *resident)
{
*shared = get_mm_counter(mm, file_rss);
*text = (PAGE_ALIGN(mm->end_code) - (mm->start_code & PAGE_MASK))
>> PAGE_SHIFT;
*data = mm->total_vm - mm->shared_vm;
*resident = *shared + get_mm_counter(mm, anon_rss);
return mm->total_vm;
}
上面的代码中shared就是page cache里面实际使用了的物理内存的页数,text是代码所占用的页数,data是总虚拟内存页数减去共享的虚拟内存页数,resident是所有在使用的物理内存的页数。最后返回的mm->total_vm是进程虚拟内存的寻址空间大小。
函数get_mm_counter并不会做什么计算,它的功能是保证数值读取的原子性。
上面的数值最后会通过 procfs输出 到/proc/$pid/statm中去。他们与top显示的数值对应关系如下。
SHR: shared
RES: resident
VIRT: mm->total_vm
CODE: code
DATA: data
原文: