1.ObjdumpObjdump 的使用
2.GNU 工具链开发入门(一):工具链介绍
3.目标代码目标文件格式
ObjdumpObjdump 的使用
objdump是一个命令行工具,用于分析和反汇编可执行文件、共享库和目标文件。它支持多种格式,如COFF、ELF、预约系统源码jspMS-DOS等。本文将详细介绍objdump的基本选项和用途。
首先,让我们了解一些基本选项:
- `-a`:显示档案库的成员信息,与ar tv类似。
- `-b bfdname`或`--target=bfdname`:指定目标码格式。虽然不是必需的,objdump能自动识别许多格式,但可以通过它明确指定文件的math库源码格式,例如`objdump -b oasys -m vax -h fu.o`。
- `-C`:将底层的符号名解码成用户级名字,去除所有开头的下划线,使C++函数名以可理解的方式显示出来。
- `-d`或`--disassemble`:反汇编那些应该还有指令机器码的section。
- `-D`:与 `-d` 类似,但反汇编所有section。
- `-h`或`--headers`:显示目标文件各个section的头部摘要信息。
- `-i`或`--info`:显示可用的架构和目标格式列表。
- `-j section`或`--section=section`:仅仅显示指定section的信息。
- `-l`:用文件名和行号标注相应的目标代码,适用于与 `-d`、`-D` 或 `-r` 一起使用。
- `-m machine`或`--architecture=machine`:指定反汇编目标文件时使用的wireshark源码分析架构。
- `-r`或`--reloc`:显示文件的重定位入口。
- `-S`或`--source`:尽可能反汇编出源代码,特别是当编译时指定了调试参数如`-g`时。
- `-x`或`--all-headers`:显示所有可用的头信息,包括符号表、重定位入口。等价于 `-a -f -h -r -t`。
- `--version`:显示版本信息。
通过这些选项,objdump提供了强大的功能,用于调试、分析和理解二进制文件。例如,使用`objdump -a libpcap.a`可以查看libpcap库中的oschina ios源码成员信息,与`ar -tv libpcap.a`的输出进行比较。
在实际应用中,`objdump`常被用来理解二进制文件的内部结构,查找特定指令或函数,或是在调试过程中分析代码行为。理解这些选项的用途和作用,将有助于更有效地使用`objdump`进行二进制分析工作。
GNU 工具链开发入门(一):工具链介绍
进入GNU工具链开发领域,首先需认识到GNU/Linux世界中,GNU工具链扮演着不可或缺的角色。尽管在代码耦合程度和可读性方面,GNU工具链可能不如使用Apache协议的LLVM广受欢迎,但只要GNU/Linux系统持续存在,GNU工具链的超级hook源码使用不会停止。作者自年开始深入探索GNU工具链开发,并通过系列文章整理知识体系,分享个人经验。
GNU工具链主要由三个部分构成:GCC、GAS和LD。GCC作为编译器集合,包含多种编译器,如用于C语言的GCC、用于C++的G++等,而GAS是汇编器,负责将汇编代码转换为机器代码。LD则是链接器,将生成的模块链接成可执行文件或共享库。
在GCC的使用中,编译过程可以被详细拆解。一个简单的示例为使用`gcc hello.c -o hello`命令编译hello.c文件并生成hello程序。这里实际涉及多个步骤:首先,GCC调用C语言编译器cc1将源代码编译为汇编代码;随后,GAS将汇编代码转换为对象文件;最后,LD链接库文件,生成最终的可执行文件。
在构建程序时,GCC通过调用AS和LD完成汇编和链接过程,具体参数的传递可能依据不同后端的设置。此外,BFD(Binary File Descriptor)是Binutils仓库中用于底层操作的工具集,包括as、ld等。
GLibc作为GNU C Library,在构建GNU/Linux和Linux内核时扮演关键角色。它包含几乎所有的UNIX标准,对构建过程至关重要。作者对GLibc的理解仍停留在浅层阶段,专注于RISC-V后端相关工作,对C库的具体实现不敢妄加评论。
构建GCC的过程通常基于上游最新代码进行,步骤包括配置、编译、链接和安装等。具体步骤可参考相关指南或教程。构建GCC时需要注意版本兼容性、依赖库以及构建环境的设置。
总结,GNU工具链作为GNU/Linux生态系统的核心组成部分,为用户提供强大的编译和链接功能。了解其构成、使用方法以及构建流程,对深入参与GNU/Linux生态系统的开发工作至关重要。
目标代码目标文件格式
目标文件格式是用于存放目标代码和编译或汇编过程中生成的相应数据的计算机文件格式。 随着Unix和其他可移植操作系统的问世,人们定义了如COFF和ELF等格式,这些格式在不同系统上被广泛使用。链接器的输入和输出通常使用相同的文件格式,库文件和可执行文件格式也采用相同的格式。设计或选择一种目标文件格式是计算系统整体设计的关键部分,它影响链接器的性能以及程序员在开发过程中的耗时。 目标文件格式的设计影响着程序的运行时间以及系统对用户请求的响应速度。大部分目标文件格式采用区块组织方式,每块包含相同类型的数据。当虚拟内存系统需要这些块时,它可以通过将块分页后调入内存,无需进一步处理即可使用。 最简单的目标文件格式是DOS的COM文件格式,它仅由原始数据组成,并始终被加载到固定位置。其他格式通常由一组复杂且精密的数据结构序列组成,规范说明书往往有数页之多。 调试信息可以作为目标文件格式的一部分,如COFF格式中那样,或作为可能被多个目标格式使用的独立格式,如stabs或DWARF。 GNU计划的BFD库提供了一套通用的应用程序编程接口,用于操纵各种目标文件格式。 典型的目标文件格式支持的数据类型包括符号起始区域(BSSBlockStartedbySymbol)、正文段(textsegment或译作代码段)和数据段(datasegment)。这些格式的设计和使用在计算系统中扮演着关键角色,影响着开发效率、程序运行时间和系统响应速度。扩展资料
指源代码经编译后,产生的能被 CPU直接识别的二进制代码。