免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1999 | 回复: 1
打印 上一主题 下一主题

请教内核中的内存分配? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-10-16 17:23 |只看该作者 |倒序浏览
我希望实现一个功能,就是在内核态遍历每个进程的信息,比方说对最近60秒内占用CPU最多的进程进行一个排序,然后每秒刷新一次。
初步打算用 for_each_task这个宏,但是现在在内存分配上遇到一点困惑。

我几乎没有内核编程的经验

我现在参考“top”的源代码,(top是一个应用层程序,可以显示每个进程的一些信息),top源代码在分配内存那部分有如下动作:
1. 在遍历进程时,给每个进程相关的数据结构,分配内存,用malloc
2. 休息一段时间
3. 再次遍历进程,如果进程数比以前多,继续malloc,如果进程数比以前少,将闲置的放到一个自定义的free列表,如果下次需要内存,先从free列表里面取得。


我想问的是,这套机制我能不能照搬到内核,只不过我把malloc换成vmalloc。

另外,
1. 内核中有无类似qsort那样的排序函数?
2. 在内核态遍历每个进程的信息,比方说对最近60秒内占用CPU最多的进程进行一个排序,然后每秒刷新一次。(这个大家有什么好的思路嘛)

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
2 [报告]
发表于 2011-10-17 08:33 |只看该作者
为啥不用/proc
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP