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 的指令。

示例

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

 /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  starti 的第一条指令

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

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

参考

链接与装载 interrupter 解释器

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