免费注册 查看新帖 |

Chinaunix

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

Kernel thread访问用户空间的地址会怎样? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-04-21 17:46 |只看该作者 |倒序浏览
kernel thread没有地址空间,如果我在kernel thread中,访问小于0xc0000000以下的地址,会怎样?

问题是这样来的,user process通过系统调用给kernel一个user space的地址,kernel通过kernel 里的几个线程做了一系列操作后,需要往这个地址里写东西,
这样的思路可行吗?

论坛徽章:
0
2 [报告]
发表于 2012-04-21 17:52 |只看该作者
copy_to/from_user就是内核读写用户地址空间的,
前提是在同一个线程/进程。

只是在你的例子中拔地址给了其他的内核线程,应该不行了。

论坛徽章:
0
3 [报告]
发表于 2012-04-21 17:57 |只看该作者
回复 2# sanbiangongzi


    我也觉得不行,那就是说,那copy_to_user函数必须是use context下,也就是在系统调用里面使用而已??
   那像我帖子里提到的这种需求,是不是就没法做到了?

论坛徽章:
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
4 [报告]
发表于 2012-04-21 18:51 |只看该作者
本帖最后由 embeddedlwp 于 2012-04-21 18:52 编辑

回复 3# twoon

copy_to_user会调用access_ok,从access_ok的源码来看它只做了简单的检查会轻易绕过的,不会有什么错误。
但是当kernel thread向这个地址写数据的时候会发生缺页异常:

mm = tsk->mm;
if(in_atomic() || !mm)
    goto bad_area_nosemaphore

执行到这里表明是对用户空间的访问,而且是kernel thread造成的缺页异常。





   

论坛徽章:
0
5 [报告]
发表于 2012-04-21 21:38 |只看该作者
回复 4# embeddedlwp


    缺页之后呢?我的问题是在缺页之后,按理说要查页表了,但这时没有页表可查了。

论坛徽章:
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
6 [报告]
发表于 2012-04-21 21:40 |只看该作者
回复 5# twoon


缺页之后查页表?????你哪里看的!


   

论坛徽章:
0
7 [报告]
发表于 2012-04-21 23:05 |只看该作者
回复 6# embeddedlwp


    我的理解有误,你的意思是如果使用copy_to_user,就会缺页异常,我的意思是,如果不使用copy_to_user,直接往这个地址中写数据时,最终mmu会怎样解释这个地址?mmu解释这个地址的话,是需要页表的吧?

论坛徽章:
0
8 [报告]
发表于 2012-04-21 23:08 |只看该作者
得找个时间试试。

论坛徽章:
0
9 [报告]
发表于 2012-04-22 19:02 |只看该作者
本帖最后由 twoon 于 2012-04-22 19:02 编辑

回复 1# twoon


    看来是问题过于简单,牛牛们都不屑来回答了。
   好吧,我的实验结果也出来了,oops了。

论坛徽章:
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
10 [报告]
发表于 2012-04-22 19:20 |只看该作者
本帖最后由 embeddedlwp 于 2012-04-22 19:21 编辑
twoon 发表于 2012-04-22 19:02
回复 1# twoon




我不是已经回答很清楚了吗???你为什么不去看看代码,看看page fault到底是怎么回事,看看bad_area_nosemaphore的代码是什么样子的!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP