linux二进制分析笔记-ELF头

我的博客:www.saoguang.top
[TOC]

ELF二进制格式

  1. ELF文件对应windows系统的PE文件

ELF头

#define EI_NIDENT        16
typedef struct {
    unsigned char  e_ident[EI_NIDENT];
    Elf32_Half     e_type;
    Elf32_Half     e_machine;
    Elf32_Word     e_version;
    Elf32_Addr     e_entry;
    Elf32_Off      e_phoff;
    Elf32_Off      e_shoff;
    Elf32_Word     e_flags;
    Elf32_Half     e_ehsize;
    Elf32_Half     e_phentsize;
    Elf32_Half     e_phnum;
    Elf32_Half     e_shentsize;
    Elf32_Half     e_shnum;
    Elf32_Half     e_shstrndx;
 } Elf32_Ehdr;

详细信息可以查询:http://refspecs.linuxbase.org/elf/elf.pdf

ELF文件类型

  1. 也就是ELF头中定义的e_type字段:
NameValueMeaning
ET_NONE0No file type(未知或者还未定义)
ET_REL1Relocatable file(重定位文件)
ET_EXEC2Executable file(可执行文件)
ET_DYN3Shared object file(共享目标文件,即共享库)
ET_CORE4Core file(核心文件)
ET_LOPROC0xff00Processor-specific
ET_HIPROC0xffffProcessor-specific

Core file: 在程序崩溃或者进程传递了一个SIGSEGV信号(分段违规)时,会在核心文件重记录整个进程的镜像信息。可以使用GDB读取这类文件来辅助调试并查找程序崩溃的原因。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值