当前位置:首页 > 未分类 > 正文内容

汇编指令

admin2天前未分类10

NOP

表示 No Operation(空操作),机器码为 0x90,无操作数。执行这条指令时,CPU 不进行任何实质性操作,仅消耗一个指令周期,常用于内存地址对齐、延时控制或填充溢出 payload 等场景。

PUSH

功能:将数据压入栈中(栈遵循 “先进后出” 原则)。

指令格式:push x

操作数范围

  • x 可取 imm8(8 位立即数)、imm16(16 位立即数)、imm32(32 位立即数)、r/m16(16 位寄存器 / 内存)、r/m32(32 位寄存器 / 内存)、r/m64(64 位寄存器 / 内存)。

执行逻辑:栈指针寄存器 ESP(32 位环境)或 RSP(64 位环境)自动递减(32 位环境递减 4 字节,64 位环境递减 8 字节),再将数据存入栈指针指向的内存地址。

POP

功能:从栈中弹出数据(取出栈顶元素)。

指令格式:pop x

操作数范围

  • x 可取 r/m16(16 位寄存器 / 内存)、r/m32(32 位寄存器 / 内存)、r/m64(64 位寄存器 / 内存)(不可为立即数)。

执行逻辑:先将栈指针 ESP/RSP 指向的栈顶数据存入目标操作数 x,再使 ESP/RSP 自动递增(32 位环境递增 4 字节,64 位环境递增 8 字节)。

MOV

功能:将数据从源操作数移动到目的操作数(仅数据拷贝,源操作数内容不变)。

指令格式:mov x1, x2(意为 “将 x2 的数据移动到 x1”,x1 为目的操作数,x2 为源操作数)。

操作数组合规则

  1. 寄存器到寄存器(如 mov eax, ebx);

  1. 内存到寄存器(如 mov eax, [0x12345678])、寄存器到内存(如 mov [0x12345678], eax);

  1. 立即数到寄存器(如 mov eax, 0x12)、立即数到内存(如 mov [0x12345678], 0x12)。

注意:不支持 “内存直接到内存” 的移动(如 mov [0x1234], [0x5678] 非法),需通过寄存器中转。

LEA

功能:Load Effective Address(载入有效地址),本质是计算内存操作数的地址并存入目标寄存器,而非读取内存中的数据。

指令格式:lea x1, x2

操作数范围

  • x1:r16(16 位寄存器)、r32(32 位寄存器)、r64(64 位寄存器);

  • x2:内存地址(常用 [] 语法表示 “引用内存地址”,如 [eax+4*ebx+0x12])。

典型用途

  1. 指针运算(如计算数组元素地址:lea eax, [ebx+4*ecx],假设数组元素占 4 字节);

  1. 简化数值计算(如 lea eax, [ebx+ecx+0x10],等效于 eax = ebx + ecx + 16,比 add 指令更高效)。

ADD

功能:实现两个操作数的加法运算,结果存入目的操作数。

指令格式:add x1, x2(意为 “x1 = x1 + x2”,x1 为目的操作数,x2 为源操作数)。

操作数范围

  • x1:r/m16、r/m32、r/m64;

  • x2:r/m16、r/m32、r/m64 或立即数(imm8/16/32)。

注意:x1 和 x2 不能同时为内存操作数。

标志位影响:执行结果会修改 eflags 寄存器中的标志位,包括:

  • OF(溢出标志)、SF(符号标志)、ZF(零标志)、AF(辅助进位标志)、PF(奇偶标志)、CF(进位标志)。

SUB

功能:实现两个操作数的减法运算,结果存入目的操作数(x1 = x1 - x2)。

指令格式:sub x1, x2(x1 为目的操作数,x2 为源操作数)。

操作数范围:与 ADD 指令一致:

  • x1:r/m16、r/m32、r/m64;

  • x2:r/m16、r/m32、r/m64 或立即数(imm8/16/32)。

注意:x1 和 x2 不能同时为内存操作数。

标志位影响:与 ADD 指令一致,会修改 eflags 寄存器的 OF、SF、ZF、AF、PF、CF 标志位。

IMUL/MUL

1. IMUL(有符号乘法指令)

功能:实现有符号整数的乘法运算,结果长度为操作数的 2 倍(需用两个寄存器存储)。

三种指令格式

  1. imul r/m32(单操作数):

    • 功能:edx:eax = eax * r/m32(32 位环境),edx 存储高位结果,eax 存储低位结果;

    • 示例:imul ebx(等效于 edx:eax = eax * ebx)。

  1. imul reg, r/m32(双操作数):

    • 功能:reg = reg * r/m32(结果存入目标寄存器 reg);

    • 示例:imul ecx, ebx(等效于 ecx = ecx * ebx)。

  1. imul reg, r/m32, imm(三操作数):

    • 功能:reg = r/m32 * imm(立即数 imm 与 r/m32 相乘,结果存入 reg);

    • 示例:imul ecx, ebx, 0x10(等效于 ecx = ebx * 16)。

2. MUL(无符号乘法指令)

功能:实现无符号整数的乘法运算,指令格式与 IMUL 的 “单操作数格式” 一致,但仅处理无符号数,结果存储规则相同(如 mul r/m32 对应 edx:eax = eax * r/m32)。

注意:IMUL 也可处理无符号数(结果与 MUL 一致),但 MUL 无法处理有符号数。

IDIV/DIV

1. DIV(无符号除法指令)

功能:实现无符号整数的除法运算,被除数长度为除数的 2 倍(需用两个寄存器存储)。

两种指令格式

  1. 16 位除法:div r/m8

    • 被除数:ax(16 位);

    • 除数:r/m8(8 位);

    • 结果:al 存储商,ah 存储余数。

    • 示例:div bl(ax / bl,商存 al,余数存 ah)。

  1. 32 位除法:div r/m32

    • 被除数:edx:eax(64 位,edx 为高位,eax 为低位);

    • 除数:r/m32(32 位);

    • 结果:eax 存储商,edx 存储余数。

    • 示例:div ebx(edx:eax / ebx,商存 eax,余数存 edx)。

注意

  • 若被除数为 32 位(eax),执行前需将 edx 置为 0(避免高位残留数据影响结果);

  • 若除数为 0 或商超过目标寄存器容量(如 16 位除法商超过 8 位),会抛出 “除零异常” 或 “溢出异常”。

2. IDIV(有符号除法指令)

功能:实现有符号整数的除法运算,指令格式与 DIV 一致,但处理有符号数,余数符号与被除数相同。

示例:idiv ebx(edx:eax 除以 ebx,有符号运算,商存 eax,余数存 edx)。

AND

功能:实现两个操作数的 “按位逻辑与” 运算,结果存入目的操作数(x1 = x1 & x2)。

指令格式:and x1, x2(x1 为目的操作数,x2 为源操作数)。

操作数范围

  • x1:r/m16、r/m32、r/m64;

  • x2:r/m16、r/m32、r/m64 或立即数(imm8/16/32)。

注意:x1 和 x2 不能同时为内存操作数。

典型用途:按位清零(如 and eax, 0x0000ffff,将 eax 高 16 位清零)。

OR

功能:实现两个操作数的 “按位逻辑或” 运算,结果存入目的操作数(x1 = x1 | x2)。

指令格式:or x1, x2(x1 为目的操作数,x2 为源操作数)。

操作数范围:与 AND 指令一致:

  • x1:r/m16、r/m32、r/m64;

  • x2:r/m16、r/m32、r/m64 或立即数(imm8/16/32)。

注意:x1 和 x2 不能同时为内存操作数。

典型用途:按位置 1(如 or eax, 0x00000001,将 eax 最低位置 1)。

XOR

功能:实现两个操作数的 “按位异或” 运算(相同为 0,不同为 1),结果存入目的操作数(x1 = x1 ^ x2)。

指令格式:xor x1, x2(x1 为目的操作数,x2 为源操作数)。

操作数范围:与 AND、OR 指令一致:

  • x1:r/m16、r/m32、r/m64;

  • x2:r/m16、r/m32、r/m64 或立即数(imm8/16/32)。

注意:x1 和 x2 不能同时为内存操作数。

典型用途:寄存器清零(如 xor eax, eax,等效于 mov eax, 0,但执行效率更高)。

NOT

功能:实现操作数的 “按位逻辑非” 运算(每一位取反,0 变 1,1 变 0),结果存入原操作数(x = ~x)。

指令格式:not x

操作数范围:r/m16(16 位寄存器 / 内存)、r/m32(32 位寄存器 / 内存)、r/m64(64 位寄存器 / 内存)(不可为立即数)。

注意:NOT 是单操作数指令,且不影响 eflags 寄存器的任何标志位。


扫描二维码推送至手机访问。

版权声明:本文由克拉玛依三十年社团发布,如需转载请注明出处。

本文链接:https://www.klmyssn.com/?id=73

分享给朋友:

“汇编指令” 的相关文章

(原创)看我用各种姿势在手机和PC查看到连接到的wifi密码

(原创)看我用各种姿势在手机和PC查看到连接到的wifi密码

今天一个女神来我家做客,她问我WiFi密码,然而我却奇迹般的忘记了(特么的当时心里一万个草泥马踏过去),让我在她面前尴尬求子的,所以为了防止你们也出现这种情况,我特地把各种方法整理了一下,那么感兴趣的朋友们继续往下看吧! 用电脑的cmd命令行查看密码 1.按住Windows键和R键,在跳出来的运...

(原创)记一次终端售货机的沙盒逃逸

(原创)记一次终端售货机的沙盒逃逸

楼主小白一枚,第一次发文章,希望各位大佬多多指教发 freebuf 未能通过,于是分享群友 hhh,还是很基础,直接复制过来所以多了 freebuf 的码。偶然发现学校里的终端机是 win7 的,就尝试一下逃逸机器大概长这个样子(下晚课开始兴风作浪)让我们来看一下操作界面(ps: 拍广告的妹子也不咋...

(原创)NOIP [全国青少年信息学奥林匹克联赛] 初赛之后的杂谈

(原创)NOIP [全国青少年信息学奥林匹克联赛] 初赛之后的杂谈

没人能比我更懂你。这次的 noip 初赛考的很砸,比数学还砸。深夜的情感就像熬过冬日的野草。我们都在寻找,寻找着一个能够和自己差不多的人,去对他倾诉自己的情感,去倾听他的情感。在一次一次的失败,一次又一次的成功后,留下的只是回忆;在一次次的交流中,一次次的倾听中,留下的是感情。就像我们总是在学习,却...

(原创)市教育局 web 渗透 — 市 OA 系统 [web 渗透实例][教育局网络安全][内网安全][内网渗透][oa 系统漏洞]

(原创)市教育局 web 渗透 — 市 OA 系统 [web 渗透实例][教育局网络安全][内网安全][内网渗透][oa 系统漏洞]

一、渗透前置说明(授权与免责)1. 授权声明本次渗透是在取得教育局网络第三方厂商(即时讯立维公司)授权许可之后进行的渗透测试。漏洞报告已第一时间交给教育局及第三方厂商,并协助厂商完成修补,至文章发布时,文中漏洞已修复。本文仅选取漏洞报告部分内容公开,完整漏洞报告模板存放于社团群内部。2. 免责申明请...

(原创)想学黑阔?这些书可以带你飞![web 安全书籍]

(原创)想学黑阔?这些书可以带你飞![web 安全书籍]

这些是我多年前收集的一些 web 安全相关书籍,虽当初未能坚持系统学习,但书籍本身质量较好,现分享给大家,希望能为想学 web 安全的朋友提供帮助!书籍资源获取百度云链接:http://pan.baidu.com/s/1jHVch9O提取密码:bauj...

(原创)微信跳一跳辅助跳跃教程,轻轻松松拿高分!

(原创)微信跳一跳辅助跳跃教程,轻轻松松拿高分!

一、前期准备:模拟器配置1. 核心工具与系统要求模拟器:逍遥模拟器(需安装多开器)系统版本:通过多开器创建 “安卓 5.1” 系统的模拟器实例设备型号设置:在模拟器中将设备型号改为 “小米 5S”(适配辅助工具兼容性)2. 微信与游戏准备在模拟器中下载并安装微信,登录账号后打开 “跳一跳” 游戏,确...