gdb应用程序-用户层的第一条指令

 

参考:

starti 在第一条指令处停下来

https://www.cnblogs.com/zhangzhiwei122/p/15811300.html 

链接与装载 interrupter 解释器

https://blog.csdn.net/u011734326/article/details/101028881

 

问题:

linux环境下可执行文件 - 用户层代码的第一条指令从哪儿开始执行?

 

interpreter 解释器

第一条指令并不是 main 开始 的,

1、对于单独的一个elf格式的文件【可执行文件,或者动态链接库文件】,其入口通过readelf -h xxx 可以查看到

2、对于 有 interpreter 的可执行文件,由 interpreter 负责执行它。即 用户层的第一条执行指令是 interpreter 的指令。

示例

gdb应用程序-用户层的第一条指令

 

如上图,这是一个具有 interpreter 的程序,其由 /lib64/ld-linux-x86-64.so.2 负责装载执行。

gdb应用程序-用户层的第一条指令

 

 /lib64/ld-linux-x86-64.so.2  符号链接到 /lib/x86_64-linux-gnu/ld-2.31.so 上面

/lib/x86_64-linux-gnu/ld-2.31.so  再没有 interpreter 了。

通常 ld.so 被称作 动态装载器,就是因为它基本上是 所有 应用层程序的 interpreter 。 

 

入口

 

拷贝 /lib/x86_64-linux-gnu/ld-2.31.so 为 ld.so [备用】

cp /lib/x86_64-linux-gnu/ld-2.31.so   ./ld.so

readelf & objdump  ld.so  的入口

gdb应用程序-用户层的第一条指令

 

gdb应用程序-用户层的第一条指令

 

 gdb应用程序-用户层的第一条指令

 

 gdb  starti 的第一条指令

gdb应用程序-用户层的第一条指令

 

 

 

上图中,红色框 内的 机器码  和 ld.so 入口处的一致,表示其为 用户从程序的 第一条指令。

 

linux 内核 怎么到第一条用户层指令的?

参考

链接与装载 interrupter 解释器

https://blog.csdn.net/u011734326/article/details/101028881

gdb应用程序-用户层的第一条指令

 

上一篇:undefined symbol: _dl_sym, version GLIBC_PRIVATE


下一篇:通过maven插件推送docker镜像