ELF文件加载时需要对其进行重定位吗?若需要,加载器是怎样处理的?
对于可执行程序而言,我记得是不需要重定位的。动态共享库是PIC,也不需要。至于可执行程序调用共享库的代码是通过plt表和got表做的,如果非要说有“重定位”,那么就是在第一次调用某个共享库的函数时,动态链接器需要添GOT表。
但是,对于目标文件(.o)文件,链接成可执行文件的过程中需要重定位,这个是链接器做的,和加载器没关系。
原帖由 bingfeng2hzy 于 2008-9-10 13:03 发表 ELF文件加载时需要对其进行重定位吗?若需要,加载器是怎样处理的?
[ 本帖最后由 freearth 于 2008-9-10 15:03 编辑 ]
谢谢!但不知道在代码段中有如下程序:mov ax,ds:[si]时,编译成ELF可执行文件后, DS的值应位多少?我的理解:在段页式存储管理系统中,DS的值应为选择子,但编译器并不能将其修改为选择子,这应由加载器修改.但在可执行文件加载时并不需要重定位,不知道此时DS的值应为多少?
你应该不是在为linux写程序吧
原帖由 cjaizss 于 2008-9-10 17:23 发表 你应该不是在为linux写程序吧
我的目的是做一个加载ELF可执行文件的加载器.我觉得如果应用程序中不调用系统功能的话,那么我想我的加载器应该能将ELF可执行文件加载到任何系统中执行.
[ 本帖最后由 bingfeng2hzy 于 2008-9-10 17:30 编辑 ]
内核启动也是以ELF格式启动的, 在X86下一般是做好内存布局的BIN文件ELF文件在加载前要进行内存的段布局, 然后将PC指针跳到入口处执行.
原帖由 smartham_whl 于 2008-9-10 20:28 发表 内核启动也是以ELF格式启动的, 在X86下一般是做好内存布局的BIN文件ELF文件在加载前要进行内存的段布局, 然后将PC指针跳到入口处执行.
在段页式存储管理系统中,ELF文件的加载中建立段描述符,是怎样做的?谢谢!
在ELF加载的过程中不去做这件事情。在Linux下,段描述符表在Kernel进入保护模式的时候就建好了,之后都不再更改,所有的用户程序都共享一个code段和一个data段,并且,linux并不是段页式存储管理,在Linux中,只有页式管理。
原帖由 bingfeng2hzy 于 2008-9-10 20:53 发表 在段页式存储管理系统中,ELF文件的加载中建立段描述符,是怎样做的?谢谢!
原帖由 bingfeng2hzy 于 2008-9-10 20:53 发表
X86启动内核建议看一下情景分析的下册667页.
如果内核已经启动了,则使用的都是任务私有的映射空间
原帖由 freearth 于 2008-9-11 13:29 发表 在ELF加载的过程中不去做这件事情。在Linux下,段描述符表在Kernel进入保护模式的时候就建好了,之后都不再更改,所有的用户程序都共享一个code段和一个data段,并且,linux并不是段页式存储管理,在Linux中, ...
谢谢!不过我不太明白.能具体解释一下这句"所有的用户程序都共享一个code段和一个data段"吗?
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
暂无简介
文章 0 评论 0
接受
发布评论
评论(9)
对于可执行程序而言,我记得是不需要重定位的。动态共享库是PIC,也不需要。至于可执行程序调用共享库的代码是通过plt表和got表做的,如果非要说有“重定位”,那么就是在第一次调用某个共享库的函数时,动态链接器需要添GOT表。
但是,对于目标文件(.o)文件,链接成可执行文件的过程中需要重定位,这个是链接器做的,和加载器没关系。
[ 本帖最后由 freearth 于 2008-9-10 15:03 编辑 ]
谢谢!但不知道在代码段中有如下程序:
mov ax,ds:[si]
时,编译成ELF可执行文件后, DS的值应位多少?
我的理解:在段页式存储管理系统中,DS的值应为选择子,但编译器并不能将其修改为选择子,这应由加载器修改.但在可执行文件加载时并不需要重定位,不知道此时DS的值应为多少?
你应该不是在为linux写程序吧
我的目的是做一个加载ELF可执行文件的加载器.我觉得如果应用程序中不调用系统功能的话,那么我想我的加载器应该能将ELF可执行文件加载到任何系统中执行.
[ 本帖最后由 bingfeng2hzy 于 2008-9-10 17:30 编辑 ]
内核启动也是以ELF格式启动的, 在X86下一般是做好内存布局的BIN文件
ELF文件在加载前要进行内存的段布局, 然后将PC指针跳到入口处执行.
在段页式存储管理系统中,ELF文件的加载中建立段描述符,是怎样做的?
谢谢!
在ELF加载的过程中不去做这件事情。
在Linux下,段描述符表在Kernel进入保护模式的时候就建好了,之后都不再更改,所有的用户程序都共享一个code段和一个data段,并且,linux并不是段页式存储管理,在Linux中,只有页式管理。
X86启动内核建议看一下情景分析的下册667页.
如果内核已经启动了,则使用的都是任务私有的映射空间
谢谢!不过我不太明白.能具体解释一下这句"所有的用户程序都共享一个code段和一个data段"吗?