免费注册 查看新帖 |

Chinaunix

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

[内核入门] 开始研究4.4.30内核了 [复制链接]

论坛徽章:
2
2016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之广夏
日期:2016-12-07 08:32:11
跳转到指定楼层
[收藏(0)] [报告]
发表于 2016-11-10 16:57 |只看该作者 |正序浏览
终于决定开干现代内核了,内核代码太大了,在国内clone更是跟蜗牛一样,遂决定在我的VPS上clone下来,然后根据需要将某些源码下载到我的本地电脑上。结果git毫不留情的吃掉了我VPS所有的内存,最后被内核OOM机制干掉了。把git的内存配置修改了个遍也不能解决,于是只好动用shallow clone了:
  1. git clone --depth 1  --no-single-branch git://xxx
复制代码
clone完后挑选了几个目录下载下来,压缩后一共16M,解压后100多M。打开Source Insight建立工程,今晚就开始阅读一下内存管理的代码,试试感觉如何。目测4.4和2.4的代码已经是天差地别。

评分

参与人数 1可用积分 +2 收起 理由
Godbach + 2 赞一个!

查看全部评分

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
21 [报告]
发表于 2016-11-29 11:16 |只看该作者
回复 21# mrpre

更奇怪的是,执行了*((u32*)ptr) = 1;

之后,进程对应的页目录还是空。。。我cpu是mips,难道检测到地址是vmalloc的地址,就直接查询了init_mm页表?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
20 [报告]
发表于 2016-11-29 11:02 |只看该作者
回复 15# mordorwww

哥们你找到在哪里更新进程页目录了吗,我也有这个疑问。
我一个进程在系统调用中调用了vmalloc, vmalloc只更新了init_mm的页目录、页表;并没有更新进程的页目录和页表。

    g_v_pk = 1;
    ptr = vmalloc(PAGE_SIZE);
    if(ptr)
    {
        *((u32*)ptr) = 1;
        vfree(ptr);
    }
    g_v_pk = 0;


我在 do_page_fault 时加入
    if(g_v_pk)
    {
        printk("do_page_fault address:%lx\n",address);
    }


神奇的是,我在给ptr赋值时,没有产生缺页中断。

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
19 [报告]
发表于 2016-11-15 10:28 |只看该作者
回复 19# 剑魂箫心

那直接去 kernel.org 下载就可以了。一个压缩包大概70MB的样子

论坛徽章:
2
2016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之广夏
日期:2016-12-07 08:32:11
18 [报告]
发表于 2016-11-14 17:16 |只看该作者
回复 17# amarant

我有FQ用的VPS,我主要就就是嫌内核代码的文件小而多,解压之后用source insight搜索起来也很慢,所以就想去掉暂时不用的代码,于是采用shallow clone将代码放到VPS上再选择需要的源码进行打包下载。而且把历史commit下载下来暂时也没什么用处~

论坛徽章:
0
17 [报告]
发表于 2016-11-14 16:43 |只看该作者
回复 2# mordorwww

vmalloc 也表直接更新到 主内核页表的 (就是c0007000的那个)

如果某个进程访问vmalloc地址,会产生异常,然后在异常里面吧主内核页表项拷贝过来的。

具体代码在哪不清楚了,要看。

论坛徽章:
2
2016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之广夏
日期:2016-12-07 08:32:11
16 [报告]
发表于 2016-11-11 15:16 |只看该作者
本帖最后由 剑魂箫心 于 2016-11-11 15:17 编辑

回复 15# mordorwww

有点意思,就拿这个两个函数当做学习最新内核的起点好了。我现在被4.4.30内核搞蒙了,和2.4差异太大,完全不认识了,正在寻找一个合适的切入点去学习最新代码。

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
15 [报告]
发表于 2016-11-11 15:00 |只看该作者
剑魂箫心 发表于 2016-11-11 13:41
回复 13# mordorwww

假设32位系统,我猜想是不是这256个内核页目录项(除掉高端内存那几项)内容是不变 ...

kmalloc和其它静态映射不变
vmalloc映射表是动态映射的,会变的

论坛徽章:
2
2016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之广夏
日期:2016-12-07 08:32:11
14 [报告]
发表于 2016-11-11 13:41 |只看该作者
回复 13# mordorwww

假设32位系统,我猜想是不是这256个内核页目录项(除掉高端内存那几项)内容是不变的,也就是说256个页表永远在指向固定的页表,以后如果映射有变化的话,只需要改动页表即可,而所有进程这256项的目录项值是不变的。

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
13 [报告]
发表于 2016-11-11 13:17 |只看该作者
剑魂箫心 发表于 2016-11-11 11:55
回复 10# mordorwww

每个进程都有自己独立的页目录,虽然前768项各自独立,但是页目录后256项的值都是 ...

问题 是 这256项会变
如果每个进程一份,那么一个进程改了,一旦切换到其它进程的话,其它的进程也要改

论坛徽章:
2
综合交流区版块每日发帖之星
日期:2016-07-06 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:00
12 [报告]
发表于 2016-11-11 12:47 |只看该作者
回复 2# mordorwww
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP