免费注册 查看新帖 |

Chinaunix

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

[C] 进程通过系统调用陷入内核,那相应的内核函数是怎么访问进程的用户地址空间的? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-12-29 10:42 |只看该作者 |倒序浏览
是直接通过传进来的线性地址,先访问PGD取得页表后直接访问?还是通过什么内核页表的中高128空间的某种映射完成的,分不清楚了。。

论坛徽章:
0
2 [报告]
发表于 2012-12-29 16:56 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
3 [报告]
发表于 2012-12-29 17:32 |只看该作者
内核线程木有进程描述符?OMG。。。貌似没有回答我 的问题。。。
stephen_du 发表于 2012-12-29 16:56
你对用户进程的组成似乎有点不理解。

系统中存在两种进程:

论坛徽章:
0
4 [报告]
发表于 2012-12-29 20:14 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
5 [报告]
发表于 2012-12-29 22:41 来自手机 |只看该作者
什么乱七八糟的。
是直接走的pgd, 你第一种立即是正确的

论坛徽章:
0
6 [报告]
发表于 2012-12-30 19:07 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
7 [报告]
发表于 2012-12-30 19:33 |只看该作者
@stephen_du
好像只要是访问内存都是通过page table来访问的吧

X86中,ProtectedMode下,所有访存都通过PageTale,就是所谓的非分页内存也是如此,只有DMA例外

TO LZ:
内核没有自已的页表,它一直是以当前进程的身份活动的。
也就是说,它看起来是用户进程的一部分,使用当前用户的页表(不过,内核事实上并不知道这一点,所以它只能使用有限的空间,比较内核堆栈及用户程序给出的缓冲区地址)

论坛徽章:
0
8 [报告]
发表于 2012-12-30 21:13 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
4
天秤座
日期:2013-10-18 13:58:33金牛座
日期:2013-11-28 16:17:01辰龙
日期:2014-01-14 09:54:32戌狗
日期:2014-01-24 09:23:27
9 [报告]
发表于 2012-12-30 22:01 |只看该作者
7楼指得可能是进入内核态后,不发生页表切换。

论坛徽章:
3
15-16赛季CBA联赛之山东
日期:2016-10-30 08:47:3015-16赛季CBA联赛之佛山
日期:2016-12-17 00:06:31CU十四周年纪念徽章
日期:2017-12-03 01:04:02
10 [报告]
发表于 2012-12-31 05:13 |只看该作者

LS all 大侠.

一旦陷入内核, 内核想干啥都行.

所有的进程都放在运行队列中, 运行队列中每个数据元素为task_struct实例[Linux kernel]. 每个进程有无独立虚拟地址空间, 其映射如何, 均可由此结构追溯之.

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP