免费注册 查看新帖 |

Chinaunix

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

请教有关段式映射方面的内容 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-04-27 20:07 |只看该作者 |倒序浏览
各位,请教一下,有关《linux情景分析》里有关对 i386CPU 的内存管理方面的内容,具体如下:

1、里面提到了一个例子,如下:

========================================
greeting()
{
        printf("hello world\n");
}

main()
{
        greeting();
}

其中反编译后(objdump),发现 greeting()的入口地址为 0x8048368.

========================================

2、当执行 “call 0x8048368” 这条指令时,按上面所说的是,(由于是 i386CPU 的缘故)CPU分析 0x8048368 这个地址时,是先进行段式映射,再进行页式映射的。对于页式映射部分,没什么问题。但对于段式映射部分,还是不太清楚,想请教一下大家(换句话说,对于0x8048368这个地址,在linux中是如何进行段式映射的?第一步干什么、第二步干什么....),谢谢。

论坛徽章:
0
2 [报告]
发表于 2011-04-27 20:10 |只看该作者
回复 1# sherf

先顶一下

论坛徽章:
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
3 [报告]
发表于 2011-04-27 20:33 |只看该作者
呵呵  Linux中沒使用分段的這個特性,Linux中有四個主要的段,但是都是映射到同一個地方。具體可以看《深入理解Linux內核》

论坛徽章:
0
4 [报告]
发表于 2011-04-27 20:37 |只看该作者
呵呵  Linux中沒使用分段的這個特性,Linux中有四個主要的段,但是都是映射到同一個地方。具體可以看《深入 ...
amarant 发表于 2011-04-27 20:33


分段的特性是由 i386cpu 定的(其他CPU没有),因此linux要能在i386下正常运行,则必须先分段后分页........

论坛徽章:
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
5 [报告]
发表于 2011-04-27 21:53 |只看该作者
本帖最后由 amarant 于 2011-04-27 22:16 编辑

回复 4# sherf


    嗯,linux只象征性的分了下  你可以去看看head.S 看了就明白了

论坛徽章:
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
6 [报告]
发表于 2011-04-27 22:08 |只看该作者
这么说吧,因为在linux中,用户(内核)代码(数据)断 这四个断的base全部都是0x0000 0000,所以就跟没分段一样的。

在没开启保护模式的,地址的算法是 cs * 16 + ip
开启保护模式以后就是: cs 指定段  eip 指定线性地址

论坛徽章:
0
7 [报告]
发表于 2011-04-28 00:28 |只看该作者
各位,请教一下,有关《linux情景分析》里有关对 i386CPU 的内存管理方面的内容,具体如下:

1、里面提到 ...
sherf 发表于 2011-04-27 20:07



看下这个精华贴吧,写的应该比较清楚了:http://bbs.chinaunix.net/thread-2083672-1-1.html

论坛徽章:
0
8 [报告]
发表于 2011-04-28 00:29 |只看该作者
这么说吧,因为在linux中,用户(内核)代码(数据)断 这四个断的base全部都是0x0000 0000,所以就跟没分段一样的。
amarant 发表于 2011-04-27 22:08


我手头上现在没linux代码,但我记得至少权限是不一样的。

论坛徽章:
0
9 [报告]
发表于 2011-04-28 07:06 |只看该作者
确实用了分段,但从最后的效果上来说,几乎等于没用。

论坛徽章:
0
10 [报告]
发表于 2011-04-28 07:09 |只看该作者
回复 8# new_learner

他说的应该是segment descriptor里七零八落的base字段,几个段的其它属性肯定有别。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP