arm汇编返C语言,arm架构下C语言反汇编分析(示例代码)

本文展示了如何将ARM架构下的C语言代码转换为汇编语言,并进行详细解释。通过分析ARM汇编代码,可以理解C语言在ARM平台上的执行过程,包括堆栈设置、寄存器保存、内存操作等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

led.elf:file format elf32-littlearm

Disassembly of section .text:

00000000<_start>:0: e3a0da01 mov sp, #4096 ;0x1000 //设置堆栈为4096

4: eb000000 bl c //跳到main函数执行00000008:8: eafffffe b 80000000c:c: e1a0c00d mov ip, sp //把sp的值赋值给ip=4096

10: e92dd800 stmdb sp!, {fp, ip, lr, pc} //pc是R15 lr是R14 ip是R12 fp是R11

//先把sp的值减4,sp=4092然后把pc的值放到4096到4093所指的内存中

//再把sp值减4为4088 ,然后把lr的值放到4092到4089所指的内存中

//再把sp值减4为4084 ,然后把ip的值放到4088到4085所指的内存中

//再把sp值减4为4080 ,然后把ip的值放到4083到4080所指的内存中

// 上面一条指令是在调用main之前需要保存寄存器的值14: e24cb004 sub fp, ip, #4 ;0x4 // fp =ip-4=4092

18: e24dd008 sub sp, sp, #8 ;0x8 // sp =sp-4=4072

1c: e3a03456 mov r3, #1442840576 ;0x56000000 //把0x56000000放到r3中

20: e2833050 add r3, r3, #80 ;0x50 //把r3的值加80 变成0x56000050

24: e50b3010 str r3, [fp, #-16] //把0x56000050放到[4076] 第一局部变量28: e3a03456 mov r3, #1442840576 ;0x56000000 //把0x56000000放到r3中

2c:

反汇编带符号表的32位/64位ELF目标文件,CPU类型:ARM PowerPC MIPS 操作菜单选择:文件解析 Alx+P ELF文件解析 Alt+E 另有文本比较等杂项功能。V1.25.05相对上一版本,增加内存数据按数据类型解析功能;V1.25.04相对上一版本,完善X86反汇编,修复小BUG;V1.25.02相对上一版本,COREDUMP统计、匹配目标文件等相关功能优化,修复小BUG;V1.25.00相对上一版本,相关功能支持动态库文件,查询代码支持无符号目标文件+有符号目标文件,COREDUMP统计、与问题单关联、目标文件/CORE文件/问题单同步;V1.24.02相对上一版本,针对进程主动捕捉异常的信息定制处理进一步完善COREDUMP文件解析与应用,增强软件管理;V1.24.01相对上一版本,进一步完善COREDUMP文件解析与应用,提供部分ARM Thumb指令反汇编;V1.24.00相对上一版本,进一步完善COREDUMP文件解析与应用,提供堆栈调用关系分析;V1.23.03相对上一版本,提供32位X86反汇编;V1.23.02相对上一版本,提供源代码行查询指令地址,OBJ/COREDUMP文件解析,sprintf函数参数特定检查,完善文件拖放操作,修复小BUG;V1.23.01相对上一版本,提供ELF文件指令修改,修复ARM MLS指令反汇编错误等BUG;V1.23.00相对上一版本,提供程序地址对应源代码行查询,修复MIPS调试信息错误;V1.22相对上一版本,修复MIPS小端字节序反汇编错误,网上最新版本提示;另部分增强功能的菜单操作设有密码,如有兴趣欢迎咨询。欢迎大家反馈相关软件使用过程中的问题!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值