鱼C论坛

 找回密码
 立即注册

黑鹰破解——27课汇编

热度 3已有 1426 次阅读2011-5-24 10:08 |个人分类:汇编语言|

1.     指令系统总结:

[1]数据传送指令:movpushpoppushfpopfxchg等,这些指令实现寄存器和内存、寄存器和寄存器之间的单个数据传送。

[2]算术运算指令:addsubadcsbbIncdeccmpimulidivaaa等,这些指令实现寄存器和内存中的数据的算术运算,他们的执行结果影响标志寄存器的:sfzfofcfpfaf

[3]逻辑指令:andornotxortestshlshrsalsarrolrorrclrcr等,除了not指令外,其他的执行结果都影响标志寄存器的相关标志位。

[4]转移指令:可以修改IP,或同时修改CSIP的指令:无条件转移指令——jmp;条件转移指令------jcxzjejbjajnbjna;环指令:loop;过程:callretretf;中断:intiret

[5]处理机控制指令:这些指令对标志寄存器或其他处理机状态进行设置,如:cld std cli sti nop clc cmc stc hlt wait esc lock

[6]串处理指令:这些指令对内存中的批量数据进行处理,比如,movsb movsw cmps scas lods stos等,若要使用这些指令方便地进行批量数据的处理,则需要和repreperepne等前缀指令配合使用。

 

-------------------------------------------------------------

跳转命令

-------------------------------------------------------------根据条件作出是否跳转的决定,通常前面会有一个判断语句,例如:

 

    CMP AX,BX

    JZ XX //jump zero

 

上面两条命令意为用 AX BX,它的值如果为 0 则跳转到 XX 的标号行。

常用的跳转命令有:

 

    JZ/JE   相等或为零为则跳转

    JNZ/JNE  不相等或不为零则跳转

    JL/JLE  小于/小于或等于则跳转

    JG/JGE  大于/大于或等于则跳转

    JMP    无条件跳转

 

-------------------------------------------------------------

比较语句

-------------------------------------------------------------

    CMP AXBX  //AX 寄存器减去 BX 寄存器的内容

    AND AXBX  //AX BX 做“与运算”0则为0

    OR AXBX   //AX BX 做“或运算”有1则为1

    TEST AXBX AND AX,BX 命令有相同效果

    XOR AXAX 使 AX 的内容清零,每个寄存器与自己作异或运算等于清零动作

1. . and 逻辑与指令,按位进行与运算

        通过该指令可将操作对象的相应位设为0,其他位不变

         AL的第六位设为0and al,10111111B

    . Or 逻辑或指令,按位进行或运算

         通过该指令可将操作对象的相应位设为1,其他位不变

         AL的第六位设为1or al,01000000B

2.  A 41H01000001B   a : 61H01100001B.

     ASCII码的二进制形式来看,除第5位外,大写字母和小写字母的其他各位都一样。

     大写字母的ASCII码第五位为0,小写字母的第五位为1.

 

-------------------------------------------------------------

子程序

-------------------------------------------------------------

一个子程的模样长得像这个样子

 

    CALL 15F:334422

 

子程式是个很重要的概念,它是主程式的一个分支,用来做特定动作。

 

打个比方:你要上班,先你是走路到车站,然后上车,然后下车,然后走到自己的办公室。

 

这里如果要把上班编为一段程式的话,那么就可以把“走路”、“搭车”、“走到办公室”做为分支程式来处理。

 

说得再通俗一点就是:你要破解的程式不可能就是一条主程式到底,肯定会呼叫下面的子程式,由子程式来处理你发送的注册信息,然后比较,然后标记是否注册正确,这些都是靠它来完成的。

 

所以说,破解的关键在于,你找准程式在哪儿将会作注册判断,并进入那个注册子程式,仔细观察,你就成功了。(子程式的返回码是 RET

 

-------------------------------------------------------------

算术运算

-------------------------------------------------------------

    ADD AX,BX  加法运算   AX=AX+BX

    SUB AX,BX  减法运算   AX=AX-BX

    INC AX   寄存器加一  AX=AX+1

    DEC AX   寄存器减一  AX=AX-1

    MUL     乘法运算

    DIV/idiv     除法运算

-------------------------------------------------------------

数据操作

-------------------------------------------------------------

    MOV AX,BX 数据传送指令,将 BX 的值移送到 AX

    XCHG AX,BX AX BX 的值互换

 

8086/8088指令集
为了便于查询,这里分类列出8086/8088汇编指令:

数据传送指令
MOV

MOV    (MOVe) 传送字或字节.
MOVS    (MOVe String)   
串传送指令
MOVSX   
先符号扩展,再传送.
MOVZX   
先零扩展,再传送.


功能: 把源操作数送给目的操作数
语法: MOV 目的操作数,源操作数
格式: MOV r1,r2 MOV r,m MOV m,r MOV r,data

XCHG
功能: 交换两个操作数的数据

BSWAP    交换32位寄存器里字节的顺序
XCHG    (eXCHanG)
交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数)


语法: XCHG
格式: XCHG r1,r2 XCHG m,r XCHG r,m

PUSH,POP


功能: 把操作数压入或取出堆栈
语法: PUSH 操作数 POP 操作数
格式: PUSH r PUSH M PUSH data POP r POP m

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依次弹出堆栈.


PUSHF,POPF,PUSHA,POPA // PUSHFD POPFD PUSHAD POPAD
功能: 堆栈指令群
格式: 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  //change byte word // change word dword
功能: 有符号数扩展指令
格式: 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
字符串操作指令

MOVSB,MOVSW,MOVSD
功能: 字符串传送指令
格式: MOVSB MOVSW MOVSD
标志位:

CMPSB,CMPSW,CMPSD
功能: 字符串比较指令
格式: CMPSB CMPSW CMPSD
标志位: C,P,Z,S,O

SCASB,SCASW  //scansb
功能: 字符串搜索指令
格式: 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而定

位运算指令集
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 地址
XX
为下列值:
   A: ABOVE,
C=0,Z=0时成立
   B: BELOW,
C=1时成立
 
  C: CARRY,
CF=1时成立
   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时则会将堆栈中的标志值弹回寄存器

处理器状态控制指令
NOP
功能: 空操作指令。不执行任何操作,但要花费CPU一个机器周期
格式: NOP

HLT
功能: 暂停指令。CPU不执行任何操作,一直处于暂停状态,但IP指向HLT的下一条指令。
格式: HLT
脱离HLT状态的方式:1CPU复位;2CPU响应中断

ESC
WAITLOCK
功能: 用于多处理器系统。其中ESC是交权指令;WAIT是等待指令;LOCK是总线封锁指令


路过

鸡蛋

鲜花
1

握手

雷人

刚表态过的朋友 (1 人)

发表评论 评论 (3 个评论)

回复 小甲鱼 2011-5-24 10:54
  
回复 阿雪之季 2011-5-24 11:58
哇,好长,都要记住么
回复 lxbwyr 2011-5-24 13:43
引用小甲鱼老师的一话句,书是拿来查的,不要背。查多了自然就记住了 。

facelist

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

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

GMT+8, 2024-5-13 09:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

返回顶部