从ARM的汇编代码到二进制文件
来源:互联网 发布:freertos 软件定时器 编辑:程序博客网 时间:2024/06/14 01:41
首先声明,本文仅包括了ARM从汇编代码到二进制文件的转化过程,用于对二进制码的模拟分析,不可做执行文件使用。
写好汇编源文件1.s
$vi 1.s
.global add @ give the symbol add external linkage
add:
ADD r0, r0, r1 @ add input arguments
MOV pc, lr @ return from subroutine
@ end of program
其中这只是表示生成一个可供C语言调用的函数接口,本身不带main入口,只能生成.o文件
$arm-linux-gcc -c -o 1.o 1.s
得到1.o这个文件
$arm-linux-objdump -x -d -S 1.o 反汇编
1.o: file format elf32-littlearm
1.o
architecture: arm, flags 0x00000010:
HAS_SYMS
start address 0x00000000
private flags = 0: [APCS-32] [FPA float format]
Sections:
Idx Name Size VMA LMA File off Algn
0 .text 00000008 00000000 00000000 00000034 2**0
CONTENTS, ALLOC, LOAD, READONLY, CODE
1 .data 00000000 00000000 00000000 0000003c 2**0
CONTENTS, ALLOC, LOAD, DATA
2 .bss 00000000 00000000 00000000 0000003c 2**0
ALLOC
SYMBOL TABLE:
00000000 l d .text 00000000 .text
00000000 l d .data 00000000 .data
00000000 l d .bss 00000000 .bss
00000000 g .text 00000000 add
Disassembly of section .text:
00000000 <add>:
0: e0800001 add r0, r0, r1
4: e1a0f00e mov pc, lr
然后把提取1.o这个文件的.text段,
$arm-linux-objcopy -O binary -j .text 1.o 1.bin
$ls -la
-rw-r--r-- 1 wyc wyc 8 2010-07-02 15:00 1.bin
-rw-r--r-- 1 wyc wyc 488 2010-07-02 14:54 1.o
-rw-r--r-- 1 wyc wyc 146 2010-07-02 14:49 1.s
最后提出来的1.bin只有8个字节,是由于text段中仅包含了两条指令。
$od -x 1.bin
0000000 0001 e080 f00e e1a0
0000010
0: e0800001 add r0, r0, r1
4: e1a0f00e mov pc, lr
- 从ARM的汇编代码到二进制文件
- 从arm 到 gnu 的汇编转换
- 从ARMASM汇编到GNU ARM ASM汇编
- 从C的伪代码到汇编,动手实现objc_msgSend
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- arm linux kernel 从入口到start_kernel 的代码分析
- 从VC的反汇编复制代码到自己的汇编
- C代码从初始化到汇编执行
- VC中实现哈希Hash算法
- RDLC 报表系列(三) 参数、常量及常用表达式的使用
- Android和iPhone要做统一设计还是差异设计?
- LINQ to SQL与ADO.NET
- C++成员函数的重载、覆盖、隐藏
- 从ARM的汇编代码到二进制文件
- 深入理解.net服务器控件
- VS2005中SetUnhandledExceptionFilter函数应用
- using 和 foreach
- SQL语句导入导出大全
- 今天有人问s:if问题
- Oracle计算时间差表达式(转载)
- ASP.NET 2.0 DataGrid Custom Paging[by Ted Heng]
- parentElement 和 offsetParent 之间的区别