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

可执行程序是怎么得来的

以C语言为例,c代码经过编译器的预处理,编译成汇编代码,由汇编器编译成目标代码,再链接成可执行文件,由操作系统加载到cpu里来执行。
(截图)

.c----.asm(.s)-----.o(二进制文件)-----A.out(可执行文件)

预处理负责把include的文件包含进来及宏替换等工作
可执行文件是使用共享库的。

静态编译
-static

把库里的东西都放在里面了所以比较大
可执行文件的内部是怎样的?

目标文件的格式ELF

(截图)
文件格式:

  • PE是windows下
  • ELF是linux下(executable linkable format)

目标文件格式和ABI应用程序二进制接口适应到某一种cpu格式

ELF标准下三种可执行文件:

    • 一个可重定位文件(代码和数据)
    • 一个可执行文件(用来执行的程序)
    • 一个共享文件(代码和数据,连接编译器和动态连接器)

      Obeject文件参与程序联接(创建一个程序)和程序执行(运行一个程序)

      (截图)

      查看ELF文件的头部

      gccs readelf -h main

      可执行程序加载的主要工作:

      映射代码中各种数据对应到进程空间的地址。例如:在文件中的代码段,拷贝到进程的空间时;数据段拷贝到进程空间。

      静态链接的ELF可执行文件和进程的地址空间

      文件映射进程地址空间
      0xc000000开始是用户态可以使用的
      0x8048000默认的加载地址
      0x8048X00程序的真实入口,可执行文件加载到内存中开始执行的第一行代码

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

    • 动态链接的进程会有多个代码段

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

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

      可执行程序的的执行环境

    • 命令行参数和shell环境

      • ls -l/usr/bin列出/usr/bin下的目录信息//ls是一个可执行程序
      • shell本身不限制命令行参数的个数,命令行参数的个数受限于命令自身//也就是main函数
      • 例如,int main(int argc,char argv[]);//愿意接受命令行参数,用户输入的
        -又例如,int main(int argc,char
        argv[],charenvp[])//envp:shell的环境变量
      • shell会调用execve将命令行参数传递给可执行程序的main()函数
      • int execve(int char filename,char argv[],char *const envp[]);//函数原型,先函数调用参数传递,再系统调用参数传递

        execve的封装教程

        (截图不能用)

        命令行参数和环境变量时如何保存和传递的?

        (截图不能用)命令行参数和环境变量,fork一个子进程时完全复制父进程的,然后调用execv时,把当前的可执行程序把原来的环境(子进程)给覆盖掉,子进程的用户态堆栈也被清空了,因为新的进程要执行。

        那么命令行参数和环境变量时如何进入新程序的堆栈的?
    • 命令行参数(char argv[])、环境变量(char const envp[])压栈
    • 创建一个新的用户态堆栈,通过指针将命令行参数,环境变量传递给系统调用execve的内核处理函数
    • 内核处理函数创建一个新的可执行程序用户态堆栈的同时,将命令行参数和环境变量拷贝进去
      shell程序--execve--对应的系统调用sys_execv--然后在初始化时拷贝

      装载时动态链接和运行时动态链接的应用举例

    • 可执行程序装载时动态链接
    • 可执行程序运行时动态链接
      #### 可执行装载时、运行动态链接
      1. 准备.so文件
        共享库文件shlibexample.h和shlibexample.c编译成.so文件
        (共享库的代码展示图)

      gcc -shared shlibexample.c -o libshlibexample.so -m32

      1. 分别以共享库和动态加载共享库的方式使用libshlibexample.so文件和libdllibexample.so文件
        (展示main函数)
        编译main注意这里只提供shlibexample的-L(库对应接口文件所在目录)和-l(库名)并没有提供dllibexample的信息
    • gcc mian.c -o main -l/path/to/your/dir -lshlibexample -ldl -m32
      //分别指定头文件的路径和库文件的路径,动态加载

    • export LD_LIBRARY_PATH=$PWD

      //将当前目录加入默认路径

    • ./main

Linux内核第七节 20135332武西垚的更多相关文章

  1. Linux内核第四节 20135332武西垚

    实验目的: 使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用 实验过程: 查看系统调用列表 get pid 函数 #include <stdio.h> #include & ...

  2. Linux内核第五节 20135332武西垚

    20135332武西垚 在MenuOS中通过添加代码增加自定义的系统调用命令 使用gdb跟踪调试内核 简单分析system_call代码了解系统调用在内核代码中的处理过程 由于本周实验是在Kali虚拟 ...

  3. Linux内核第六节 20135332武西垚

    如何描述一个进程:进程描述符的数据结构: 如何创建一个进程:内核是如何执行的,以及新创建的进程从哪里开始执行: 使用gdb跟踪新进程的创建过程. 进程的描述 操作系统三大功能: 进程管理(最核心最基础 ...

  4. Linux内核总结博客 20135332武西垚

    http://www.cnblogs.com/wuxiyao/p/5220677.htmlhttp://www.cnblogs.com/wuxiyao/p/5247571.htmlhttp://www ...

  5. Linux内核第三节 20135332武西垚

    总结部分: Linux内核源代码: Arch 支持不同cpu的源代码:主要关注x86 Init   内核启动的相关代码:主要关注main.c,整个Linux内核启动代码start_kernel函数 K ...

  6. Linux内核第八节 20135332武西垚

    第一种分类: I/O-bound:频繁进行I/O,并且需要花费很多时间等待I/O完成 CPU-bound:计算密集,需要大量的CPU时间进行运算 第二种分类: 批处理进程:不必与用户交互,常在后台进行 ...

  7. (笔记)Linux内核学习(七)之内核同步机制和实现方式

    一 原子操作 指令以原子的方式执行——执行过程不被打断. 1 原子整数操作 原子操作函数接收的操作数类型——atomic_t //定义 atomic_t v;//初始化 atomic_t u = AT ...

  8. Linux内核第二节

    作者:武西垚 深入理解函数调用堆栈 堆栈是C语言程序运行时必须的一个记录调用路径和参数的空间 堆栈的作用 函数调用框架 传递参数 保存返回地址 提供局部变量空间 堆栈相关的寄存器 esp,堆栈指针,指 ...

  9. Linux内核分析(一)---linux体系简介|内核源码简介|内核配置编译安装

    原文:Linux内核分析(一)---linux体系简介|内核源码简介|内核配置编译安装 Linux内核分析(一) 从本篇博文开始我将对linux内核进行学习和分析,整个过程必将十分艰辛,但我会坚持到底 ...

随机推荐

  1. 阿里八八β阶段Scrum(1/5)

    今日进度 叶文滔: 修改了α阶段遗留的部分界面BUG,比如状态栏白底等 张岳: 修复用户模块信息修改返回失败的BUG 林炜鸿: 重构了添加事件的代码,增加可修改的特性 黄梅玲: 绘制了新的日程显示格界 ...

  2. MySql/Oracle和SQL Server的分页查

    假设当前是第PageNo页,每页有PageSize条记录,现在分别用Mysql.Oracle和SQL Server分页查询student表. 1.Mysql的分页查询: 1 SELECT 2 * 3 ...

  3. 「PKUSC2018」神仙的游戏

    题目链接 比如说上面\(|S|\)为12的字符串,我们欲求出\(f(9)\)的值,那么上面相同颜色的字符必须两两能够匹配.也就是说,同种颜色的字符集里不能同时出现0和1.如果只考虑同种颜色集里相邻的两 ...

  4. C#用默认浏览器打开特定网址的几种方法

    方法一:从注册表中读取默认浏览器可执行文件路径 private void button1_Click(object sender, EventArgs e) { //从注册表中读取默认浏览器可执行文件 ...

  5. Hunter -- 批量文件管理工具

    一个简单工具, 用来进行批量文件的重命名, 更改后缀, 搜索特定后缀, 等 下载地址:http://download.csdn.net/download/kuangsun/7545179

  6. centos7下安装docker(12.3容器之间的连通性)

    我们接着盗图,如下: 在这张图上,可以看到,如果两个容器使用同一个bridge,那么两个容器之间是互相能通的 可以看到两个容器在同一个bridge下是可以互相ping通的 当两个容器在不同的bridg ...

  7. 理解 JavaScript 中的 for…of 循环

    什么是 for…of 循环 for...of 语句创建一个循环来迭代可迭代的对象.在 ES6 中引入的 for...of 循环,以替代 for...in 和 forEach() ,并支持新的迭代协议. ...

  8. usb-cam (2)摄像机标定

    http://blog.csdn.net/heyijia0327/article/details/43538695 官方也给出了单目的标定教程和双目视觉的标定教程.本教程基于usb_cam  pack ...

  9. CentOS6.9 安装Oracle 11G 版本11.2.0.1.0

    安装实例与数据库 CentOS6.9 安装Oracle 11G 版本11.2.0.1.0 一.检查系统类别. 查看 系统的类别,这里是 64位系统:[root@localhost ~]# uname ...

  10. iOS更新惹怒高通:苹果太可耻!

    之前高通同时在德国.中国发起对苹果的专利诉讼,而他们都赢得了最终的胜利,其中包含iPhone 7.8以及X系列机型,统统在禁售机型当中. 从法院公布的细节看,高通对iPhone禁售的理由是,iOS系统 ...