鱼C论坛

 找回密码
 立即注册

汇编指令集 (破解常用)

热度 2已有 914 次阅读2011-5-24 09:56 |个人分类:汇编语言

汇编语言指令集
一、数据传输指令
    1.
通用数据传送指令.
MOV    (MOVe)
传送字或字节.
MOVS    (MOVe String)   
串传送指令
MOVSX   
先符号扩展,再传送.
MOVZX   
先零扩展,再传送.
PUSH   
把字压入堆栈.
POP     
把字弹出堆栈.
PUSHA   
AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈.
POPA   
DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈.
PUSHAD
EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次压入堆栈.
POPAD   
EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次弹出堆栈.
BSWAP   
交换32位寄存器里字节的顺序
XCHG    (eXCHanG)
交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数)
CMPXCHG
比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX )
XADD   
先交换再累加.( 结果在第一个操作数里 )
XLAT    (TRANSLATE)
字节查表转换.
── BX 指向一张 256 字节的表的起点, AL 为表的索引值 (0-255,0-FFH); 返回 AL 为查表结果. ( [BX+AL]->AL )
      2.
输入输出端口传送指令.
IN      I/O
端口输入. ( 语法: IN 累加器, {端口号│DX} )
OUT      I/O
端口输出. ( 语法: OUT {端口号│DX},累加器 )
     
输入输出端口由立即方式指定时, 其范围是 0-255; 由寄存器 DX 指定时,其范围是 0-65535.
      3.
目的地址传送指令.
LEA    (Load Effective Address)
装入有效地址.
   
: LEA DX,string ;把偏移地址存到DX.
LDS    (Load DS with pointer)
传送目标指针,把指针内容装入DS.
   
: LDS SI,string ;把段地址:偏移地址存到DS:SI.
LES    (Load ES with pointer)
传送目标指针,把指针内容装入ES.
   
: LES DI,string ;把段地址:偏移地址存到ES:DI.
LFS
传送目标指针,把指针内容装入FS.
   
: LFS DI,string ;把段地址:偏移地址存到FS:DI.
LGS
传送目标指针,把指针内容装入GS.
   
: LGS DI,string ;把段地址:偏移地址存到GS:DI.
LSS
传送目标指针,把指针内容装入SS.
   
: LSS DI,string ;把段地址:偏移地址存到SS:DI.
      4.
标志传送指令.
LAHF    (Load AH with Flags)
标志寄存器传送,把标志装入AH.
SAHF    (Store AH into Flgs)
标志寄存器传送,AH内容装入标志寄存器.
PUSHF (PUSH the Flags)
标志入栈.
POPF    (POP the Flags)
标志出栈.
PUSHD    32
位标志入栈.
POPD    32
位标志出栈. 二、算术运算指令
───────────────────────────────────────
  ADD 加法.
ADC   
带进位加法.
INC   
1.
AAA   
加法的ASCII码调整.非压缩的BCD码加法十进制调整指令
DAA   
加法的十进制调整.压缩的BCD码加法十进制调整指令
SUB    (SUBtract)
减法.
SBB    (SuVtrach with borrow
)带借位减法.
DEC    (DECrement)
1.
NEC    (NEGate)
求反( 0 减之).
CMP    (CoMPare)
比较.(两操作数作减法,仅修改标志位,不回送结果).
AAS   
减法的ASCII码调整.非压缩的BCD码加法十进制调整指令
DAS   
减法的十进制调整.压缩的BCD码减法十进制调整指令
MUL    (unsinged MULtiple)
无符号乘法.
IMUL (sIgned MUL tiple)
整数乘法.
   
以上两条,结果回送AHAL(字节运算),DXAX(字运算),
AAM   
乘法的ASCII码调整.
DIV    (unsigned DIVide)
无符号除法.
IDIV (sIgned DIVide)
整数除法.
   
以上两条,结果回送:商回送AL,余数回送AH, (字节运算); 商回送AX,余数回送DX, (字运算).
AAD   
除法的ASCII码调整.
CBW    (Count Byte to Word)
字节转换为字. (AL中字节的符号扩展到AH中去)
CWD    (Count Word to Doble word)
字转换为双字. (AX中的字的符号扩展到DX中去)
CWDE
字转换为双字. (AX中的字符号扩展到EAX中去)
CDQ   
双字扩展. (EAX中的字的符号扩展到EDX中去)
三、逻辑运算指令
───────────────────────────────────────
  AND 与运算.
or   
或运算.
XOR   
异或运算.
NOT   
取反.
TEST
测试.(两操作数作与运算,仅修改标志位,不回送结果).
SHL    (SHift logical Letf)
逻辑左移.
SAL   
算术左移.(=SHL)
SHR    (SHift logical Right)
逻辑右移.
SAR   
算术右移.(=SHR)
ROL    (Rotate Left )
循环左移.
ROR    (Rotate Right)
循环右移.
RCL    (Rotate Left through Carry)
通过进位的循环左移.
RCR    (Rotate Right through Carry)
通过进位的循环右移.
   
以上八种移位指令,其移位次数可达255.
   
移位一次时, 可直接用操作码. SHL AX,1.
   
移位>1次时, 则由寄存器CL给出移位次数.
   
MOV CL,04
        SHL AX,CL

四、串指令
───────────────────────────────────────
DS:SI   
源串段寄存器 :源串变址.
ES:DI   
目标串段寄存器:目标串变址.
CX     
重复次数计数器.
AL/AX   
扫描值.
D
标志    0表示重复操作中SIDI应自动增量; 1表示应自动减量.
Z
标志    用来控制扫描或比较操作的结束.
MOVS   
串传送.
( MOVSB
传送字符. MOVSW 传送字. MOVSD 传送双字. )
CMPS    (CoMPare String)
串比较.
( CMPSB
比较字符. CMPSW 比较字. )
SCAS    (SCAn String)
串扫描指令.
ALAX的内容与目标串作比较,比较结果反映在标志位.
LODS
装入串.
把源串中的元素(字或字节)逐一装入ALAX.
( LODSB
传送字符. LODSW 传送字. LODSD 传送双字. )
STOS    (STOre into String)
保存串.
LODS的逆过程.
REP (REPeat)
CX/ECX<>0时重复.
REPE/REPZ (REPeat while Equal/Zero)
ZF=1或比较结果相等,CX/ECX<>0时重复.
REPNE/REPNZ (REPeat while Not Equal/Zero)
ZF=0或比较结果不相等,CX/ECX<>0时重复.
REPC   
CF=1CX/ECX<>0时重复.
REPNC   
CF=0CX/ECX<>0时重复.
五、程序转移指令
───────────────────────────────────────
 1>无条件转移指令 (长转移)
JMP   
无条件转移指令
CALL
过程调用
RET/RETF
过程返回.
    2>
条件转移指令 (短转移,-128+127的距离内)
(
当且仅当(SF XOR OF)=1,OP1<OP2 )
JA/JNBE
不小于或不等于时转移.
JAE/JNB
大于或等于转移.
JB/JNAE
小于转移.
JBE/JNA
小于或等于转移.
以上四条,测试无符号整数运算的结果(标志CZ).
JG/JNLE
大于转移.
JGE/JNL
大于或等于转移.
JL/JNGE
小于转移.
JLE/JNG
小于或等于转移.
以上四条,测试带符号整数运算的结果(标志S,OZ).
JE/JZ   
等于转移.
JNE/JNZ
不等于时转移.
JC   
有进位时转移.
JNC
无进位时转移.
JNO
不溢出时转移.
JNP/JPO
奇偶性为奇数时转移.
JNS
符号位为 "0" 时转移.
JO   
溢出转移.
JP/JPE
奇偶性为偶数时转移.
JS   
符号位为 "1" 时转移.
    3>
循环控制指令(短转移)
LOOP CX
不为零时循环.
LOOPE/LOOPZ CX
不为零且标志Z=1时循环.
LOOPNE/LOOPNZ CX
不为零且标志Z=0时循环.
JCXZ CX
为零时转移.
JECXZ ECX
为零时转移.
    4>
中断指令
INT   
中断指令
INTO
溢出中断
IRET
中断返回
    5>
处理器控制指令
HLT   
处理器暂停, 直到出现中断或复位信号才继续.
WAIT
当芯片引线TEST为高电平时使CPU进入等待状态.
ESC   
转换到外处理器.
LOCK
封锁总线.
NOP   
空操作.
STC   
置进位标志位.
CLC   
清进位标志位.
CMC   
进位标志取反.
STD    (SeT Direction flag)
置方向标志位.
CLD    (CLear Direction flag)
清方向标志位.
STI   
置中断允许位.
CLI   
清中断允许位.
六、伪指令
───────────────────────────────────────
  DW 定义字(2字节).
PROC   
定义过程.
ENDP   
过程结束.
SEGMENT
定义段.
ASSUME
建立段寄存器寻址.
ENDS
段结束.
END   
程序结束.
8088 汇编跳转
cmp a,b
比较ab
mov a,b
b的值送给a
ret
返回主程序
nop
无作用,英文“no operation”的简写,意思是“do nothing
call
调用子程序
je
jz 若相等则跳
jne
jnz 若不相等则跳
jmp
无条件跳
jb
若小于则跳
ja
若大于则跳
jg
若大于则跳
jge
若大于等于则跳
jl
若小于则跳
jle
若小于等于则跳
pop
出栈
push
压栈
MOV
功能: 把源操作数送给目的操作数
语法: MOV 目的操作数,源操作数
格式: MOV r1,r2
MOV r,m
MOV m,r
MOV r,data

XCHG
功能: 交换两个操作数的数据
语法: XCHG
格式: XCHG r1,r2 XCHG m,r XCHG r,m
PUSH,POP
功能: 把操作数压入或取出堆栈
语法: PUSH 操作数 POP 操作数
格式: PUSH r PUSH M PUSH data POP r POP m
PUSHF,POPF,PUSHA,POPA
功能: 堆栈指令群
格式: PUSHF POPF PUSHA POPA
LEA,LDS,LES
功能: 取地址至寄存器
语法: LEA r,m LDS r,m LES r,m
XLAT(XLATB)
功能: 查表指令
语法: XLAT XLAT m
算数运算指令
ADD,ADC
功能: 加法指令
语法: ADD OP1,OP2 ADC OP1,OP2
格式: ADD r1,r2 ADD r,m ADD m,r ADD r,data
影响标志: C,P,A,Z,S,O
SUB,SBB
功能:减法指令
语法: SUB OP1,OP2 SBB OP1,OP2
格式: SUB r1,r2 SUB r,m SUB m,r SUB r,data SUB m,data
影响标志: C,P,A,Z,S,O
INC,DEC
功能: OP的值加一或减一
语法: INC OP DEC OP
格式: INC r/m DEC r/m
影响标志: P,A,Z,S,O
NEG
功能: OP的符号反相(取二进制补码)
语法: NEG OP
格式: NEG r/m
影响标志: C,P,A,Z,S,O
MUL,IMUL
功能: 乘法指令
语法: MUL OP IMUL OP
格式: MUL r/m IMUL r/m
影响标志: C,P,A,Z,S,O(IMUL会影响S标志)
DIV,IDIV
功能:除法指令
语法: DIV OP IDIV OP
格式: DIV r/m IDIV r/m
CBW,CWD
功能: 有符号数扩展指令
语法: CBW CWD
AAA,AAS,AAM,AAD
功能: 非压BCD码运算调整指令
语法: AAA AAS AAM AAD
影响标志: A,C(AAA,AAS) S,Z,P(AAM,AAD)
DAA,DAS
功能: 压缩BCD码调整指令
语法: DAA DAS
影响标志: C,P,A,Z,S
位运算指令集
AND,OR,XOR,NOT,TEST
功能: 执行BITBIT之间的逻辑运算
语法: AND r/m,r/m/data OR r/m,r/m/data XOR r/m,r/m/data TEST r/m,r/m/data NOT r/m
影响标志: C,O,P,Z,S(其中CO两个标志会被设为0) NOT指令不影响任何标志位
SHR,SHL,SAR,SAL
功能: 移位指令
语法: SHR r/m,data/CL SHL r/m,data/CL SAR r/m,data/CL SAL r/m,data/CL
影响标志: C,P,Z,S,O
ROR,ROL,RCR,RCL
功能: 循环移位指令
语法: ROR r/m,data/CL ROL r/m,data/CL RCR r/m,data/CL RCL r/m,data/CL
影响标志: C,P,Z,S,O
程序流程控制指令集
CLC,STC,CMC
功能: 设定进位标志
语法: CLC STC CMC
标志位: C
CLD,STD
功能: 设定方向标志
语法: CLD STD
标志位: D
CLI,STI
功能: 设定中断标志
语法: CLI STI
标志位: I
CMP
功能: 比较OP1OP2的值
语法: CMP r/m,r/m/data
标志位: C,P,A,Z,O
JMP
功能: 跳往指定地址执行
语法: JMP 地址
JXX
功能: 当特定条件成立则跳往指定地址执行
语法: JXX 地址
:
   A: ABOVE,C=0,Z=0时成立
   B: BELOW,C=1时成立
   C: CARRY,当弁时成立 CXZ: CX寄存器的值为0(ZERO)时成立
   E: EQUAL,Z=1时成立
   G: GREATER(大于),Z=0S=0时成立
   L: LESS(小于),S不为零时成立
   N: NOT(相反条件),需和其它符号配合使用
   O: OVERFLOW,O=1时成立
   P: PARITY,P=1时成立
   PE: PARITY EVEN,P=1时成立
   PO: PARITY ODD,P=0时成立
   S: SIGN,S=1时成立
   Z: ZERO,Z=1时成立
LOOP
功能: 循环指令集
语法: LOOP 地址
LOOPE(Z)
地址 LOOPNE(Z) 地址
标志位:
CALL,RET
功能: 子程序调用,返回指令
语法: CALL 地址 RET RET n
标志位:
INT,IRET
功能: 中断调用及返回指令
语法: INT n IRET
标志位: 在执行INT,CPU会自动将标志寄存器的值入栈,在执行IRET时则会将堆栈中的标志值弹回寄存器
字符串操作指令集
MOVSB,MOVSW,MOVSD
功能: 字符串传送指令
语法: MOVSB MOVSW MOVSD
标志位:
CMPSB,CMPSW,CMPSD
功能: 字符串比较指令
语法: CMPSB CMPSW CMPSD
标志位: C,P,Z,S,O
SCASB,SCASW
功能: 字符串搜索指令
语法: SCASB SCASW
标志位: C,P,Z,S,O
LODSB,LODSW,STOSB,STOSW
功能: 字符串载入或存贮指令
语法: LODSB LODSW STOSB STOSW
标志位:
REP,REPE,REPNE
功能: 重复前缀指令集
语法: REP 指令S REPE 指令S REPNE 指令S
标志位: 依指令S而定


路过

鸡蛋

鲜花
2

握手

雷人

刚表态过的朋友 (2 人)

评论 (0 个评论)

facelist

您需要登录后才可以评论 登录 | 立即注册

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-13 02:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

返回顶部