汇编和反汇编

文章目录

一、程序处理的步骤

下面是编写 LED 程序时,它的 main.c 和 start.S的处理图:

.S 文件经过汇编之后得到机器码,机器看得懂的代码,链接之后再反汇编得到含汇编的代码,通过阅读反汇编得到最终可执行的代码,了解更深层次的内容。

二、汇编和反汇编

汇编:汇编文件转换为目标文件(里面是机器码);反汇编:可执行文件(目标文件,里面是机器码),转换成汇编文件。在上一次的点灯实验里,点击魔术棒,选择 USER 选项卡,在编译之后的空白行里输入下面代码,生成反汇编代码:

c 复制代码
fromelf  --bin  --output=led.bin  Objects\led_c.axf
fromelf  --text  -a -c  --output=led.dis  Objects\led_c.axf

然后在工程文件下找到 led.dis,用 keil 打开即可查看反汇编代码:

在 Start.S 文件里,申请栈空间的指令是一个伪指令,经过汇编之后转变成真实的指令:

在 led.dis 文件中找到 Reset_Handler,第一列的地址是链接地址,第二列是机器码,后面就是汇编代码,上面的伪指令也转变成真实的指令,将 [pc, #4] 地址所存的值,读到 sp 里如下图所示:

F103 板子是 Thumb-2 指令,LDR sp,[pc,#4]的机器码是 f8dfd004,里面的机器码与下图中的 Thumb-2 指令格式一一对应:

c 复制代码
f8dfd004 = 1111 1000 1101 1111 1101 0000 0000 0100

其中 sp 是 R13 寄存器,对应 Rt 的 12 ~ 15 位是 13,因此 12 ~ 15 位是 1101;0 ~ 11 位是表示一个立即数,pc + 4,正好对应 0 ~ 11 位全部加起来等于 4。

相关推荐
浩浩测试一下17 小时前
汇编 call与ret 函数与堆栈 (逆向分析)
汇编·push·函数·pop·call·ret·堆栈逆向
山屿落星辰20 小时前
昇腾NPU算子开发:从“手写汇编“到“搭积木“
汇编
浩浩测试一下1 天前
汇编 汇编寻址 (逆向分析)
汇编·寻址·windows编程·二进制逆向·机器码
浩浩测试一下2 天前
汇编 位运算 (逆向分析)
汇编·逆向·位运算·asm·windows编程·二进制逆向
浩浩测试一下2 天前
汇编 高低八位寄存器数据存储方式(逆向分析)
汇编·网络安全·逆向·二进制·免杀·寄存器·windows编程
a83331962 天前
C语言嵌入汇编详解
汇编·单片机·语言
yoyo_zzm3 天前
汇编到PHP:五大编程语言核心特性全解析
开发语言·汇编·php
ComputerInBook5 天前
X64 汇编 MOVSD 的两种用法
汇编·汇编指令·movsd
YangWeiminPHD6 天前
金水32051编译器下的AI8051U单片机入门:从点亮LED到“你好,世界,我来了!”
c语言·汇编·51单片机·编译器
九思十安8 天前
HNU2026-计算机系统-笔记 5 汇编进阶
汇编·笔记