写在前面
前面我们梳理过,page owner用于跟踪每个页面的分配细节。如上图,当有内存被分配时,内存分配调用栈、进程ID、分配时间、掩码信息等都会被记录下来。
因此我们可以通过分析这些信息来了解运行时情况下的内存布局;
但是,page_owner信息很多,有些时候抓出来的信息有几百兆,如果我们每个调用栈都去看一遍,效率太低,因此需要借助一些工具对数据进行解析。
一、page_owner_sort
排序命令如下:
page_owner_sort page_owner.txt sorted_page_owner.txt
排序后的调用栈信息如下:
42051 times:表示相同的调用栈信息共分配了42051次。
order:表示当前所分配内存页的阶,0阶表示页大小4Kb;
GFP_HIGHUSER_MOVABLE:分配掩码
pid:任务ID(线程);
二、Pageowner解析终极武器
2.1 pageowner使用关键函数名解析工具
该工具通过关键函数对pageowner进行解析、统计,最终以进程级展示进程的cma内存使用情况,并通过占用size自动排序。
ParsePageOwnerByFunc.py
解析进程cma内存后的效果:
2.2 pageowner分拆工具
该工具用于分拆pageowner信息,并以进程和线程进行分别拆分,用于更细力度的pageowner拆分。
01_SplitPageOwnerByPid-SPid.py
解析效果如下如:
2.3 pageowner进程级解析工具
该工具用于解析整个pageowner中各个进程的内存使用情况
03_ParsePageOwnerALL.py
解析效果如下图:
解析工具下载地址如下: