lsmod,/ proc / modules和slabinfo,/ proc / meminfo 不会给我的内核模块使用多少内存
有没有办法找到这个?
顺便说一句,我基本上写了一个小测试程序,一个设备驱动程序,它接受ioctl调用以分配1MB,我每秒从我的应用程序发送这个ioctl消息,所以我的驱动器每秒都会执行kmalloc。我无法看到“cat / proc / meminfo | grep Slab”的增加- 剪辑---
int device_ioctl(
struct file *file,
unsigned int ioctl_num,
unsigned long ioctl_param)
{
/*
* Switch according to the ioctl called
*/
printk ( "<l> inside ioctl %d IOCTL_ALLOC_MSG = %d\n", ioctl_num,IOCTL_ALLOC_MSG );
switch (ioctl_num) {
case IOCTL_ALLOC_MSG:
allocfunc(); // kmalloc 1MB // printk in this function is OK
break;
case IOCTL_DEALLOC_MSG:
deallocfunc();
break;
}
return 0;
}
申请/用户空间
while ( !stop )
{
ret_val = ioctl(memfile, IOCTL_ALLOC_MSG);
if (ret_val < 0) {
printf("ioctl failed. Return code: %d, meaning: %s\n", ret_val, strerror(errno));
return -1;
}
sleep ( 10 );
}
我看不到slabinfo中记忆的增长。我知道linux会执行cache-&gt; slabs-&gt; pages-&gt;对象,但在用户区中必须有一些方法来确定特定内核模块的内存大小。
谢谢,
答案 0 :(得分:3)
我不确定它是否适合您,但您可以获得模块使用'cat / proc / modules'获取的内存量,第二列是模块所在的大小(以字节为单位)第一列正在使用。
示例输出显示drm模块使用的内存:
cat / proc / modules | grep ^ drm | awk'{print $ 1“”$ 2}“
drm_kms_helper 49394 drm 286028
希望有所帮助。
答案 1 :(得分:0)
假设没有办法直接这样做(据我所知,可能存在这种情况)....
您可以使用LTTng来跟踪内核事件。如果那里没有任何方便的事件,即使每次模块分配内存,也应该创建一个新的跟踪。
然后,您可以分析跟踪并绘制内存使用量随时间增长和缩小的图表。