Linux内核内存泄露,分析方法

Way1:打桩

 

只适合自己开发的驱动或者内核代码

 

from

http://www.powerpcdev.net/blog/index.php/archives/77.html

 

meng zhao <zhaomeng2009*gmail*com>
你可以使用打桩的方法,具体如下:
例如你写的程序调用到了kmalloc函数,那你可以自己实现另外一个内存分配函数,比如叫stub_kmalloc,
然后用 #define kmalloc(x) stub_kmalloc((x), __FILE__, __LINE__)
这个宏替换掉程序中所有的kmallock,stub_kmalloc大致流程如下:

struct unit {
struct list_head list;
int line_no;
char file[NAME];
void *p;
}
stuct list_head mem_alloc_list;
stub_kmalloc(size_t size, char *fname, int lineno)
{
struct unit *unit = kmalloc(*unit);

unit->p = kmalloc(size);
unit->line_no = lineno;
strncpy(unit->fname, fname, NAME);
list_add(&unit->list, mem_alloc_list);
return unit->p;
}

再实现相应的kfree函数。
当你的程序退出的时候,你可以查看该链表上的内容,它可以精确的告诉你某文件的某一行分配的内存有没有释放。

 

 

way 2: 使用 KFT(kernel function trace)

具体以后有空再谈

你可能感兴趣的:(struct,function,list,File,Gmail,linux内核)