http://blog.csdn.net/lingfong_cool/article/details/7832896

(一) ELF 文件的格式

      ELF 文件类型 (1) 可重定位文件( .o 目标文件) : 用于链接创建可执行文件或 so 文件

(2) 可执行文件                     : 用于执行

(3)so( 共享对象 ) 文件            : 用于链接

注 :   一个 Program Header 对应一个 Segment

一个 Section Header 对应一个 Section

Segment 由 Section 构成

Segment 类型 :#define PT_NULL         0                   unused

#define PT_LOAD         1                   可加载段 ( 代码节和数据节 )

#define PT_DYNAMIC 2                   动态链接段 ( 动态链接信息 )

#define PT_INTERP       3                   解释器段 ( 动态链接器路径 )

#define PT_NOTE         4                   auxiliary information

#define PT_SHLIB 5                          reserved - purpose undefined

#define PT_PHDR         6                   program header

#define PT_NUM          7                   Number of segment types

#define PT_LOOS         0x60000000    reserved range for OS

#define PT_HIOS          0x6fffffff              specific segment types

#define PT_LOPROC    0x70000000    reserved range for processor

#define PT_HIPROC     0x7fffffff              specific segment types

Section 类型 :   #define ELF_BSS           ".bss"             uninitialized data

#define ELF_DATA          ".data "           数据节 initialized data

#define ELF_DEBUG        ".debug"         debug

#define ELF_DYNAMIC     ".dynamic "  动态链接节 dynamic linking information

#define ELF_DYNSTR ".dynstr"         dynamic string table

#define ELF_DYNSYM        ".dynsym"      dynamic symbol table

#define ELF_FINI             ".fini"             termination code

#define ELF_GOT          ".got"             global offset table

#define ELF_HASH         ".hash"           symbol hash table

#define ELF_INIT          ".init"             initialization code

#define ELF_REL_DATA     ".rel.data"       relocation data

#define ELF_REL_FINI    ".rel.fini"         relocation termination code

#define ELF_REL_INIT    ".rel.init"         relocation initialization code

#define ELF_REL_DYN      ".rel.dyn"        relocaltion dynamic link info

#define ELF_REL_RODATA  ".rel.rodata"    relocation read-only data

#define ELF_REL_TEXT   ".rel.text"        relocation code

#define ELF_RODATA     ".rodata"         read-only data

#define ELF_SHSTRTAB   ".shstrtab"       section header string table

#define ELF_STRTAB       ".strtab"          string table

#define ELF_SYMTAB       ".symtab"              symbol table

#define ELF_TEXT         ".text "            代码节 code

(二) ELF 文件的加载过程

源文件 Trunk/System/ElfLoader/dll/elfloader.c

LoadElfExec() 函数

加载的具体过程

1. 打开文件 open_library(char* filename)

系统调用 open(): 创建 File 结构体 , 放入进程打开文件表 , 返回 ( 打开文件表 ) 下标

2. 读出文件头和程序头表 IsElfFormat(FILE)

读出 ELF 文件头 ( 同时读出了程序头表 Program Header Table), 判断 ELF 格式根据文件头中的e_ident 来比较判断 .

3. 加载文件 load_library(char * filename,int fd)

(1) 计算所有 segment 占用内存大小 get_lib_extents()

通过遍历程序头表 (Program Header Table), 算出所有 segment 将占用的内存大小extents_size

(2) 分配内存 alloc_mem_region(extents_size)

匿名映射一块非共享的私有内存 ( 不涉及文件 )

(3) 分配 soinfo 结构体 alloc_info(char *filename)

从全局静态 soinfo 结构体数组中分配 soinfo 结构体 ( 描述整个 ELF 文件 )

(4) 加载 segment

load_segment(int fd,void* header,soinfo*si)

(1) 可加载段 (PT_LOAD): 映射到内存

mmap(void * start,size_t len, int prot,int flags,int fd,off_t offsize)

把 ELF 文件 offsize 处的 segment 映射到已分配内存的 start 处

(2) 动态链接段

由动态链接节设置 soinfo 中的动态链接信息

(5) 设置 soinfo 结构体

4. 加载依赖的动态链接库

5.重定位(自身符号)

重定位表项:   Elf32_Addr     r_offset   (重定位)内存地址(offset of relocation)

Elf32_Word    r_info      符号表下标和类型(symbol table index and type)

符号表项:      Elf32_Word    st_name  符号名(name - index into string table)

Elf32_Addr     st_value   符号值(symbol value)

Elf32_Word    st_size                 symbol size

unsigned char st_info                  type and binding

unsigned char st_other               0 - no defined meaning

Elf32_Half      st_shndx;                     section header index

根据重定位表(表项)查符号表,得到符号内存地址,修改(重定位)内存值

最后得到soinfo结构体数组描述了所有加载的文件

6.如果入口地址不为零,调用入口函数

ELF文件的格式和加载过程的更多相关文章

  1. tensorflow保存数据为.pb格式和加载pb文件

    转自:https://blog.csdn.net/u014264373/article/details/79943389 https://blog.csdn.net/fu6543210/article ...

  2. 整理ViewController的生命周期和加载过程

    按照执行顺序排列 - initWithCoder:通过nib文件初始化时触发 - awakeFromNib:nib文件被加载的时候,会发送一个awakeFromNib的消息到nib文件中的每个对象 p ...

  3. 浏览器打开URL的方式和加载过程

    不同浏览器的工作方式不完全一样,大体上,浏览器的核心是浏览器引擎,目前市场占有率最高的几种浏览器几乎都使用了不同的浏览器引擎:IE使用的是Trident.Firefox使用的是Gecko.Safari ...

  4. SpringMVC DispatcherServlet 启动和加载过程(源码调试)

    在阅读本文前,最好先阅读以下内容(当然,如果对 Servlet 已经有所了解,则可跳过): http://www.cnblogs.com/cyhbyw/p/8682078.html http://ww ...

  5. [NumPy]文件的保存和加载

    如果想看.ipynb文件,那就借一步说话!

  6. 重温.NET下Assembly的加载过程

    最近在工作中牵涉到了.NET下的一个古老的问题:Assembly的加载过程.虽然网上有很多文章介绍这部分内容,很多文章也是很久以前就已经出现了,但阅读之后发现,并没能解决我的问题,有些点写的不是特别详 ...

  7. 重温.NET下Assembly的加载过程 ASP.NET Core Web API下事件驱动型架构的实现(三):基于RabbitMQ的事件总线

    重温.NET下Assembly的加载过程   最近在工作中牵涉到了.NET下的一个古老的问题:Assembly的加载过程.虽然网上有很多文章介绍这部分内容,很多文章也是很久以前就已经出现了,但阅读之后 ...

  8. NET下Assembly的加载过程

    NET下Assembly的加载过程 最近在工作中牵涉到了.NET下的一个古老的问题:Assembly的加载过程.虽然网上有很多文章介绍这部分内容,很多文章也是很久以前就已经出现了,但阅读之后发现,并没 ...

  9. linux 编译,链接和加载

    1.   序 最近在折腾各种.so,碰到了一些问题,一开始对于很多错误也没有头绪,茫然不知所措.索性化了一天多时间将<<程序员的自我修养—链接.装载与库>>中部分内容略读了一遍 ...

随机推荐

  1. 萌新在线模板--keyboarder_zsq

    好像马上就要出去打铁了QAQ,所以是不是要做个模板带过去也玩一玩? 那就做吧... 标题就设为萌新模板吧...各种萌新讲解对吧.... 图论 拓扑排序 最短路 最小生成树 二分匹配 强连通Tarjan ...

  2. 洛谷P4707 重返现世(扩展MinMax容斥+dp)

    传送门 我永远讨厌\(dp.jpg\) 前置姿势 扩展\(Min-Max\)容斥 题解 看纳尔博客去→_→ 咱现在还没搞懂为啥初值要设为\(-1\)-- //minamoto #include< ...

  3. C语言经典算法100例(三)

    1.河内之塔 说明河内之塔(Towers of Hanoi)是法国人M.Claus(Lucas)于1883年从泰国带至法国的,河内为越战时北越的首都,即现在的胡志明市:1883年法国数学家 Edoua ...

  4. 消息队列RabbitMQ、缓存数据库Redis

    1.RabbitMQ消息队列 1.1 RabbitMQ简介 AMQP,即Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中 ...

  5. mac安装scrapy

    Mac自带python2.7,所以直接安装scrapy.默认安装了Xcode总共分以下几步:1.安装 homebrew.wget2.安装pip3.安装scrapy 安装homebrew在termina ...

  6. Mediator模式(仲裁者设计模式)

    Mediator ? Mediator的意思是"仲裁者""中介者".一方面,当发生麻烦事情的时候,通知仲裁者:当发生涉及全体组员的事情时,也通知仲裁者.当仲裁者 ...

  7. Unity Gizmos绘制指定长宽的网格

    using UnityEngine; using System.Collections; public class GridMap : MonoBehaviour { ; //宽度 ; //长度 vo ...

  8. QT源码解析笔记

    1. QT如何绘制控件的 QT的绘制控件在QStyleSheetStyle::DrawControl里面,这里会调用默认的QSS来绘制效果 2. 在设置一次QSS以后,将会触发polish事件,里面将 ...

  9. Java获取系统信息(用户目录,临时目录等)

    java.version Java运行时环境版本 java.vendor Java运行时环境供应商 java.vendor.url Java供应商的 URL java.home Java安装目录 ja ...

  10. SpringBoot | 第二十二章:定时任务的使用

    前言 上两章节,我们简单的讲解了关于异步调用和异步请求相关知识点.这一章节,我们来讲讲开发过程也是经常会碰见的定时任务.比如每天定时清理无效数据.定时发送短信.定时发送邮件.支付系统中的定时对账等等, ...