汇编知识点汇总

汇编的组成

  • 汇编指令
    • 数据处理指令
      • 数据搬移指令
      • 数据位移指令
      • 位运算指令
      • 算术运算指令
      • 比较指令
    • 跳转指令
    • 内存读写指令
    • 状态寄存器传送指令
    • 异常产生指令
    • 协处理器指令
  • 伪操作
    • 在程序编译过程中起到编译引导作用的内容
    • .text .global .if .else .endif
  • 伪指令
    • 不是汇编指令,但是可以起到指令的作用,会占用一定内存空间
  • 注释
    • 单行注释:@ ;
    • 多行注释:/* */
    • 条件注释:.if .else .endif

立即数

循环左移偶数位,取反(或不取)能得到0-255之间的数(8位以内)就是立即数

数据搬移指令

mov{条件码} 目标寄存器 操作数

功能:将操作数搬移到目标寄存器中,相当于赋值

mvn{条件码} 目标寄存器 操作数

功能:将操作数按位取反后结果搬移到目标寄存器中

注意:操作数可以是一个寄存器,也可以是一个立即数

数据移位指令

逻辑左移

lsl{条件码} 目标寄存器,第一操作寄存器,第二操作数

功能:将第一操作寄存器中的数左移第二操作数位数,将结果保存到目标寄存器中

逻辑右移

lsr{条件码} 目标寄存器,第一操作寄存器,第二操作数

功能:将第一操作寄存器中的数右移第二操作数位数,将结果保存到目标寄存器中

循环右移

ror{条件码} 目标寄存器,第一操作寄存器,第二操作数

功能:将第一操作寄存器中的数循环右移第二操作数位数,将结果保存到目标寄存器中

补充:汇编中对操作数书写的形式可以写成c语言风格的移位运算形式

ex:LSL R1,R0,#(0X1<<2)

位运算指令

与运算(and),与0清零,与1不变

and{条件码} 目标寄存器,第一操作寄存器,第二操作数

功能: 将第一操作寄存器中的数和第二操作数进行与运算,将结果保存到目标寄存器中

或运算(orr),有1位1,全0为0

orr{条件码} 目标寄存器,第一操作寄存器,第二操作数

功能: 将第一操作寄存器中的数和第二操作数进行或运算,将结果保存到目标寄存器中

异或运算(eor),相同为0,不同为1

eor{条件码} 目标寄存器,第一操作寄存器,第二操作数

功能: 将第一操作寄存器中的数和第二操作数进行异或运算,将结果保存到目标寄存器中

按位取反(mvn),0为1,1为0

mvn{条件码} 目标寄存器,第一操作寄存器,第二操作数

功能: 将第一操作寄存器中的数和第二操作数进行按位取反运算,将结果保存到目标寄存器中

按位清零(bic),指定位和1运算零

算术运算指令

加法指令

add{条件码}{s} 目标寄存器,第一操作寄存器,第二操作数

功能: 目标寄存器=第一操作寄存器+第二操作数

包含cpsr条件位的加法指令

adc{条件码}{s} 目标寄存器,第一操作寄存器,第二操作数

功能: 目标寄存器=第一操作寄存器+第二操作数+cpsr寄存器c位的值

减法指令

sub{条件码}{s} 目标寄存器,第一操作寄存器,第二操作数

功能: 目标寄存器=第一操作寄存器-第二操作数

包含cpsr条件位的减法指令

sbc{条件码}{s} 目标寄存器,第一操作寄存器,第二操作数

功能: 目标寄存器=第一操作寄存器+-第二操作数-cpsr寄存器c位的取反值

乘法指令

mul{条件码}{s} 目标寄存器,第一操作寄存器,第二操作数

功能: 目标寄存器=第一操作寄存器*第二操作数

模拟32位处理器进行64位数据运算

32位处理器一条指令最大能进行32位数据运算,想要进行64位运算,需要多条指令

第一个64位数据:

0x00000003 FFFFFFFE

第二个64位数据

0X00000005 00000006

运算原则:

低32位先运算,结果会影响cpsr条件位

高32位后运算,运算过程包含cpsr条件位

相关推荐
九思十安15 小时前
HNU2026-计算机系统-笔记 5 汇编进阶
汇编·笔记
九思十安18 小时前
HNU2026-计算机系统-笔记 4 汇编初步
汇编·笔记
这猪好帅2 天前
协程原理与实现
汇编
Byron Loong5 天前
【逆向】AT Hook 与 Inline Hook 对比
c语言·汇编·c++
iCxhust6 天前
微机原理课程设计大综合---计数器
汇编·单片机·嵌入式硬件·课程设计·微机原理
xxjj998a8 天前
PHP与汇编:从Web到硬件的编程差异
开发语言·汇编·php
陈eaten8 天前
汇编使用AES指令集实现AES解密
汇编·python·aes解密·aes指令集
顾鉴行思9 天前
10 字符串常量到底存在哪里?
c语言·汇编·经验分享
iCxhust9 天前
在 emu8086 中可以直接编译运行的完整汇编程序,演示数组的定义、遍历、求和、求最大值。
开发语言·前端·javascript·汇编·单片机·嵌入式硬件·算法
浩浩测试一下9 天前
堆栈中的 参数与局部变量 (逆向分析)
汇编·逆向·免杀·堆栈·windows编程·pe壳