码迷,mamicode.com
首页 > 系统相关 > 详细

Linux内核分析(第七周)

时间:2016-04-06 15:06:01      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:

可执行程序的装载

 

一、预处理、编译、链接和目标文件的格式

1.可执行程序怎么来的?

  预处理:

      gcc -E -o hello.cpp hello.c -m32

      *负责把include的文件包含进来及宏替换

  编译:

      gcc -x cpp-output -S -o hello.s hello.cpp -m32

      gcc -x assembler -c hello.s 0o hello.o -m32

      hello.s 汇编代码

      hello.o 二进制文件

  链接:

      gcc -o hello hello.o - -m32

2.目标文件的格式ELF

  A.out         COFF   (PE+ELF)

  三种类型:

      可重定位文件

      可执行文件

      共享文件

  Entry point address 程序的起点

3.静态链接的ELF

   静态链接会将所有代码放在一个代码段

   动态链接会有多个代码段

 

二、可执行程序,共享库,和动态链接

1.装载可执行程序程序之前的工作

  执行环境:命令行+参数

  *shell本身不限制命令行参数的个数

  *shell会调用execve将命令行参数和环境参数传递给main函数

  shell>execve>sys_exceve

  *初始化新程序堆栈时拷贝进去

  *先函数调用参数传递,再系统调用参数传递

2.装载时动态链接和示例

 

 

三、可执行程序的装载

1.相关关键问题分析

  fork先返回父进程一次;再返回ret_from_fork开始执行然后返回用户态

  sys_execve:

        do_exceve>do_execve_common>exec_binprm

  通过修改内核堆栈中EIP的值作为新程序的起点

2.sys_exceve的内部处理

  

  对于静态链接的文件elf_entry是新程序执行的起点

3.gdb跟踪

  new_ip是返回到用户态的第一条指令的地址

 

 

 

实验:

 

 

 

 

 

      

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  

 

Linux内核分析(第七周)

标签:

原文地址:http://www.cnblogs.com/java44/p/5359085.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!