汇编速查手册

合集下载

汇编指令手册

汇编指令手册

计算机寄存器常用指令
一、常用指令
1. 通用数据传送指令.
MOV 传送字或字节.
MOVSX 先符号扩展,再传送.
MOVZX 先零扩展,再传送.
PUSH 把字压入堆栈.
POP 把字弹出堆栈.
PUSHA 把AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈.
POPA 把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈.
一、常用指令
二、算术运算指令
三、逻辑运算指令
四、串指令
五、程序跳转指令
------------------------------------------
计算机寄存器分类简介:
32位CPU所含有的寄存器有:
4个数据寄存器(EAX、EBX、ECX和EDX)
2个变址和指针寄存器(ESI和EDI) 2个指针寄存器(ESP和EBP)
6、溢出标志OF(Overflow Flag)
溢出标志OF用于反映有符号数加减运算所得结果是否溢出。如果运算结果超过当前运算位数所能表示的范围,则称为溢出,OF的值被置为1,否
则,OF的值被清为0。
“溢出”和“进位”是两个不同含义的概念,不要混淆。如果不太清楚的话,请查阅《计算机组成原理》课程中的有关章节。
二、状态控制标志位
状态控制标志位是用来控制CPU操作的,它们要通过专门的指令才能使之发生改变。
1、追踪标志TF(Trap Flag)
当追踪标志TF被置为1时,CPU进入单步执行方式,即每执行一条指令,产生一个单步中断请求。这种方式主要用于程序的调试。
指令系统中没有专门的指令来改变标志位TF的值,但程序员可用其它办法来改变其值。

8086汇编指令手册

8086汇编指令手册

8086汇编指令手册一、数据传输指令它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据.1. 通用数据传送指令.MOV 传送字或字节. 例: MOV 目的操作数源操作数(CX不能作目的)MOVSX 先符号扩展,再传送.MOVZX 先零扩展,再传送.PUSH 把字传送到以SS为段基址、SP为偏移地址的栈中(SP-1指示堆栈中可以存放数据的位置,存源操作数的高8位 SP-2源操作数的低8位,完成进栈操作)例:PUSH 源操作数POP 把字弹出堆栈. 与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 交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数,操作数不能为立即数) 例:XCHG 目的操作数,源操作数CMPXCHG 比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX )XADD 先交换再累加.( 结果在第一个操作数里 )XLAT 字节查表转换.例:MOV BX,2000H ;BX 指向一张 256 字节的表的偏移首地址MOV AL,5 ;AL 为表的被转换码 (0-255,即0-FFH)XLAT ;返回 AL 为查表结果. ( [BX+AL]->AL )2. 输入输出端口传送指令.输入输出端口由立即方式指定时, 其范围是 0-255; 由寄存器 DX 指定时,其范围是 0-65535.IN I/O端口输入. ( 语法: IN 累加器, {端口号│DX} ) 例:IN AL,n (00H-FFH) IN AX,DX(16位)OUT I/O端口输出. ( 语法: OUT {端口号│DX},累加器 ) 例:OUT n,AL OUT DX,AX3. 目的地址传送指令.LEA 装入有效地址. LEA 16位寄存器,源操作数偏移地址例: LEA SI,[2040H] ;(SI)=2040H注:MOV SI,[2040H] ;SI中为偏移地址为2040单元中的内容,而不是2040H这个值LDS 传送目标指针,把指针内容装入DS. 例: LDS SI,string ;把段地址:偏移地址存到DS:SI.LES 传送目标指针,把指针内容装入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 标志寄存器传送,把标志装入AH. FR寄存器的低8位->AH SAHF 标志寄存器传送,把AH内容装入标志寄存器. AH->FR寄存器的低8位PUSHF 标志入栈. FR寄存器推入堆栈中POPF 标志出栈.从栈顶中弹出的内容存入FR寄存器中(唯一可改变TF标志位的指令)PUSHD 32位标志入栈.POPD 32位标志出栈.二、算术运算指令ADD 加法.(进位影响CF标志位)例:ADD AL,12H; ADD WORD PTR[BX],5B28H ;WORD PTR 是伪指令,用以指明该存储器操作数是字型ADC 带进位加法. (低16用ADD,高16位用ADC)INC 加 1. 例:INC AX; INC BYTE PTR[BX];PTR为宏汇编中的运算符,BYTE用以指明该存储器操作数是字节型AAA 对非压缩BCD数加法操作的结果进行校正DAA 对压缩BCD数加法操作的结果进行校正SUB 减法.无符号操作数相减,若CF=1,则结果为补码。

汇编指令速查

汇编指令速查

汇编指令速查汇编指令速查GAS中每个操作都是有⼀个字符的后缀,表明操作数的⼤⼩。

C声明GAS后缀⼤⼩(字节)char b1short w2(unsigned) int / long / char*l4float s4double l8long double t10/12注意:GAL使⽤后缀“l”同时表⽰4字节整数和8字节双精度浮点数,这不会产⽣歧义因为浮点数使⽤的是完全不同的指令和寄存器。

操作数格式:格式操作数值名称样例(GAS = C语⾔)$Imm Imm⽴即数寻址$1 = 1Ea R[Ea]寄存器寻址%eax = eaxImm M[Imm]绝对寻址0x104 = *0x104(Ea)M[R[Ea]]间接寻址(%eax)= *eaxImm(Ea)M[Imm+R[Ea]](基址+偏移量)寻址4(%eax) = *(4+eax)(Ea,Eb)M[R[Ea]+R[Eb]]变址(%eax,%ebx) = *(eax+ebx)Imm(Ea,Eb)M[Imm+R[Ea]+R[Eb]]寻址9(%eax,%ebx)= *(9+eax+ebx)(,Ea,s)M[R[Ea]*s]伸缩化变址寻址(,%eax,4)= *(eax*4)Imm(,Ea,s)M[Imm+R[Ea]*s]伸缩化变址寻址0xfc(,%eax,4)= *(0xfc+eax*4)(Ea,Eb,s)M(R[Ea]+R[Eb]*s)伸缩化变址寻址(%eax,%ebx,4) = *(eax+ebx*4)Imm(Ea,Eb,s)M(Imm+R[Ea]+R[Eb]*s)伸缩化变址寻址8(%eax,%ebx,4) = *(8+eax+ebx*4)注:M[xx]表⽰在存储器中xx地址的值,R[xx]表⽰寄存器xx的值,这种表⽰⽅法将寄存器、内存都看出⼀个⼤数组的形式。

数据传送指令:指令效果描述movl S,D D <-- S传双字movw S,D D <-- S传字movb S,D D <-- S传字节movsbl S,D D <-- 符号扩展S符号位填充(字节->双字)movzbl S,D D <-- 零扩展S零填充(字节->双字)pushl S R[%esp] <-- R[%esp] – 4;压栈M[R[%esp]] <-- Spopl D D <-- M[R[%esp]];出栈R[%esp] <-- R[%esp] + 4;注:均假设栈往低地址扩展。

汇编指令手册(英文缩写原码)

汇编指令手册(英文缩写原码)

汇编指令手册(英文缩写原码)1.通用数据传送指令.MOV----> moveMOVSX---->extended move with sign dataMOVZX---->extended move with zero dataPUSH---->pushPOP---->popPUSHA---->push allPOPA---->pop allPUSHAD---->push all dataPOPAD---->pop all dataBSWAP---->byte swapXCHG---->exchangeCMPXCHG---->compare and changeXADD---->exchange and addXLAT---->translate2.输入输出端口传送指令.IN---->inputOUT---->output3.目的地址传送指令.LEA---->load effective addressLDS---->load DSLES---->load ESLFS---->load FSLGS---->load GSLSS---->load SS4.标志传送指令.LAHF---->load AH from flagSAHF---->save AH to flagPUSHF---->push flagPOPF---->pop flagPUSHD---->push dflagPOPD---->pop dflag二、算术运算指令ADD---->addADC---->add with carryINC---->increase 1AAA---->ascii add with adjustDAA---->decimal add with adjustSUB---->substractSBB---->substract with borrowDEC---->decrease 1NEC---->negativeCMP---->compareAAS---->ascii adjust on substractDAS---->decimal adjust on substractMUL---->multiplicationIMUL---->integer multiplicationAAM---->ascii adjust on multiplicationDIV---->divideIDIV---->integer divideAAD---->ascii adjust on divideCBW---->change byte to wordCWD---->change word to double wordCWDE---->change word to double word with sign to EAXCDQ---->change double word to quadrate word三、逻辑运算指令———————————————————————————————————————AND---->andOR---->orXOR---->xorNOT---->notTEST---->testSHL---->shift leftSAL---->arithmatic shift leftSHR---->shift rightSAR---->arithmatic shift rightROL---->rotate leftROR---->rotate rightRCL---->rotate left with carryRCR---->rotate right with carry四、串指令———————————————————————————————————————MOVS---->move stringCMPS---->compare stringSCAS---->scan stringLODS---->load stringSTOS---->store stringREP---->repeatREPE---->repeat when equalREPZ---->repeat when zero flagREPNE---->repeat when not equalREPNZ---->repeat when zero flagREPC---->repeat when carry flagREPNC---->repeat when not carry flag五、程序转移指令———————————————————————————————————————1>无条件转移指令(长转移)JMP---->jumpCALL---->callRET---->returnRETF---->return far2>条件转移指令(短转移,-128到+127的距离内)JAE---->jump when above or equalJNB---->jump when not belowJB---->jump when belowJNAE---->jump when not above or equalJBE---->jump when below or equalJNA---->jump when not aboveJG---->jump when greaterJNLE---->jump when not less or equalJGE---->jump when greater or equalJNL---->jump when not lessJL---->jump when lessJNGE---->jump when not greater or equalJLE---->jump when less or equalJNG---->jump when not greaterJE---->jump when equalJZ---->jump when has zero flagJNE---->jump when not equalJNZ---->jump when not has zero flagJC---->jump when has carry flagJNC---->jump when not has carry flagJNO---->jump when not has overflow flagJNP---->jump when not has parity flagJPO---->jump when parity flag is oddJNS---->jump when not has sign flagJO---->jump when has overflow flagJP---->jump when has parity flagJPE---->jump when parity flag is evenJS---->jump when has sign flag3>循环控制指令(短转移)LOOP---->loopLOOPE---->loop equalLOOPZ---->loop zeroLOOPNE---->loop not equalLOOPNZ---->loop not zeroJCXZ---->jump when CX is zeroJECXZ---->jump when ECX is zero4>中断指令INT---->interruptINTO---->overflow interruptIRET---->interrupt return5>处理器控制指令HLT---->haltWAIT---->waitESC---->escapeLOCK---->lockNOP---->no operationSTC---->set carryCLC---->clear carryCMC---->carry make changeSTD---->set directionCLD---->clear directionSTI---->set interruptCLI---->clear interrupt六、伪指令—————————————————————————————————————DW---->definw wordPROC---->procedureENDP---->end of procedureSEGMENT---->segmentASSUME---->assumeENDS---->end segmentEND---->end。

汇编语言标准手册

汇编语言标准手册

汇编语言标准手册《汇编语言标准手册》一、介绍汇编语言是一种低级的计算机程序设计语言,直接操作计算机硬件。

汇编语言标准手册是程序员在学习和开发汇编语言程序时的重要参考资料。

本手册将详细介绍汇编语言的基本语法和常见指令,帮助读者掌握汇编语言编程技巧。

二、汇编语言基础1. 汇编语言的特点汇编语言与高级语言相比具有直观、高效的特点。

程序员可以直接操作寄存器、内存和指令,实现对计算机硬件的精细控制。

2. 汇编语言的基本语法汇编语言的基本语法包括标号、指令、操作数和注释等部分。

标号用于标识程序中的跳转位置,指令用于执行具体的操作,操作数指明参与操作的数据,注释是对代码的解释说明。

3. 寄存器和内存汇编语言通过寄存器和内存来实现数据的存储和处理。

寄存器是位于CPU内部的一组高速存储单元,用于临时存储和操作数据,而内存则是用于长期存储数据的地方。

三、汇编语言指令集1. 数据传输指令数据传输指令用于将数据从一个位置复制到另一个位置,例如MOV指令可以将数据从一个寄存器复制到另一个寄存器或内存位置。

2. 算术和逻辑指令算术和逻辑指令用于进行各种数学和逻辑运算,例如ADD指令可以将两个数相加,AND指令可以进行按位与操作。

3. 跳转指令跳转指令用于控制程序的执行流程,例如JMP指令可以无条件跳转到目标位置,JZ指令可以在条件满足时跳转。

4. 推入和弹出指令推入和弹出指令用于栈的操作,例如PUSH指令可以将数据压入栈中,POP指令可以从栈中弹出数据。

四、实例演示1. 程序初始化程序初始化是编写汇编语言程序的第一步,包括设置栈帧、初始化寄存器和变量等操作。

2. 循环和条件判断循环和条件判断是控制程序流程的重要结构,通过判断条件并根据结果进行跳转和执行不同的指令,实现程序的灵活控制。

3. 数据处理和显示数据处理和显示是汇编语言程序中常见的操作,例如对输入的数据进行处理后输出显示,或者进行数据的排序和统计等操作。

五、汇编语言调试技巧1. 单步执行在调试汇编语言程序时,可以使用单步执行功能逐条执行并观察每条指令的结果,帮助定位错误。

ppc汇编速查

ppc汇编速查

Appendix J.PowerPC Instruction Set Sorted by OpcodeThis appendix lists all the instructions in the PowerPC Architecture,in order by opcode.A page number is shown for instructions that are defined in this Book (Book I,PowerPC User Instruction Set Architecture), and the Book number is shown for instructions that are defined in other Books(Book II,PowerPC Virtual Envi-ronment Architecture,and Book III,PowerPC Oper-ating Environment Architecture).If an instruction is defined in more than one of these Books,the lowest-numbered Book is used.FormOpcode ModeDep.1Page/BkMnemonic Instruction Primary ExtendD260tdi Trap Doubleword ImmediateD360twi Trap Word ImmediateD754mulli Multiply Low ImmediateD8SR51subfic Subtract From Immediate CarryingD1059cmpli Compare Logical ImmediateD1158cmpi Compare ImmediateD12SR50addic Add Immediate CarryingD13SR50addic.Add Immediate Carrying and RecordD1449addi Add ImmediateD1549addis Add Immediate ShiftedB16CT23bc[l][a]Branch ConditionalSC1725sc System CallI1823b[l][a]BranchXL19028mcrf Move Condition Register FieldXL1916CT24bclr[l]Branch Conditional to Link RegisterXL1918III rfid Return from Interrupt DoublewordXL193327crnor Condition Register NORXL1912927crandc Condition Register AND with ComplementXL19150II isync Instruction SynchronizeXL1919326crxor Condition Register XORXL1922526crnand Condition Register NANDXL1925726crand Condition Register ANDXL1928927creqv Condition Register EquivalentXL1941727crorc Condition Register OR with ComplementXL1944926cror Condition Register ORXL19528CT24bcctr[l]Branch Conditional to Count RegisterM20SR73rlwimi[.]Rotate Left Word Immediate then Mask InsertM21SR70rlwinm[.]Rotate Left Word Immediate then AND with MaskM23SR72rlwnm[.]Rotate Left Word then AND with MaskD2463ori OR ImmediateD2563oris OR Immediate ShiftedD2663xori XOR ImmediateD2763xoris XOR Immediate ShiftedD28SR62andi.AND ImmediateD29SR62andis.AND Immediate ShiftedMD300SR69rldicl[.]Rotate Left Doubleword Immediate then Clear LeftMD301SR69rldicr[.]Rotate Left Doubleword Immediate then Clear RightMD302SR70rldic[.]Rotate Left Doubleword Immediate then ClearMD303SR73rldimi[.]Rotate Left Doubleword Immediate then Mask InsertMDS308SR71rldcl[.]Rotate Left Doubleword then Clear LeftMDS309SR72rldcr[.]Rotate Left Doubleword then Clear RightAppendix J.PowerPC Instruction Set Sorted by Opcode193Dep.BkPrimary ExtendX31058cmp CompareX31461tw Trap WordXO318SR51subfc[o][.]Subtract From CarryingXO319SR55mulhdu[.]Multiply High Doubleword UnsignedXO3110SR51addc[o][.]Add CarryingXO3111SR55mulhwu[.]Multiply High Word UnsignedXFX311980mfcr Move From Condition RegisterXFX3119118mfocrf Move From One Condition Register FieldX3120II lwarx Load Word And Reserve IndexedX312137ldx Load Doubleword IndexedX312335lwzx Load Word and Zero IndexedX3124SR74slw[.]Shift Left WordX3126SR67cntlzw[.]Count Leading Zeros WordX3127SR74sld[.]Shift Left DoublewordX3128SR64and[.]ANDX313259cmpl Compare LogicalXO3140SR50subf[o][.]Subtract FromX315337ldux Load Doubleword with Update IndexedX3154II dcbst Data Cache Block StoreX315535lwzux Load Word and Zero with Update IndexedX3158SR67cntlzd[.]Count Leading Zeros DoublewordX3160SR65andc[.]AND with ComplementX316861td Trap DoublewordXO3173SR55mulhd[.]Multiply High DoublewordXO3175SR55mulhw[.]Multiply High WordX3183III mfmsr Move From Machine State RegisterX3184II ldarx Load Doubleword And Reserve IndexedX3186II dcbf Data Cache Block FlushX318732lbzx Load Byte and Zero IndexedXO31104SR53neg[o][.]NegateX3111932lbzux Load Byte and Zero with Update IndexedX31124SR65nor[.]NORXO31136SR52subfe[o][.]Subtract From ExtendedXO31138SR52adde[o][.]Add ExtendedXFX3114480mtcrf Move To Condition Register FieldsXFX31144118mtocrf Move To One Condition Register FieldX31146III mtmsr Move To Machine State RegisterX3114941stdx Store Doubleword IndexedX31150II stwcx.Store Word Conditional IndexedX3115140stwx Store Word IndexedX31178III mtmsrd Move To Machine State Register Doubleword X3118141stdux Store Doubleword with Update IndexedX3118340stwux Store Word with Update IndexedXO31200SR53subfze[o][.]Subtract From Zero ExtendedXO31202SR53addze[o][.]Add to Zero ExtendedX3121032III mtsr Move To Segment RegisterX31214II stdcx.Store Doubleword Conditional IndexedX3121538stbx Store Byte IndexedXO31232SR52subfme[o][.]Subtract From Minus One ExtendedXO31233SR54mulld[o][.]Multiply Low DoublewordXO31234SR52addme[o][.]Add to Minus One ExtendedXO31235SR54mullw[o][.]Multiply Low WordX3124232III mtsrin Move To Segment Register IndirectX31246II dcbtst Data Cache Block Touch for StoreX3124738stbux Store Byte with Update IndexedXO31266SR50add[o][.]AddX31278II dcbt Data Cache Block TouchX3127933lhzx Load Halfword and Zero Indexed194PowerPC User Instruction Set ArchitectureDep.BkPrimary ExtendX31284SR65eqv[.]EquivalentX3130664III tlbie TLB Invalidate EntryX31310II eciwx External Control In Word IndexedX3131133lhzux Load Halfword and Zero with Update IndexedX31316SR64xor[.]XORXFX3133979mfspr Move From Special Purpose RegisterX3134136lwax Load Word Algebraic IndexedX3134334lhax Load Halfword Algebraic IndexedX31370III tlbia TLB Invalidate AllXFX31371II mftb Move From Time BaseX3137336lwaux Load Word Algebraic with Update IndexedX3137534lhaux Load Halfword Algebraic with Update IndexedX31402III slbmte SLB Move To EntryX3140739sthx Store Halfword IndexedX31412SR65orc[.]OR with ComplementXS31413SR76sradi[.]Shift Right Algebraic Doubleword ImmediateX31434III slbie SLB Invalidate EntryX31438II ecowx External Control Out Word IndexedX3143939sthux Store Halfword with Update IndexedX31444SR64or[.]ORXO31457SR57divdu[o][.]Divide Doubleword UnsignedXO31459SR57divwu[o][.]Divide Word UnsignedXFX3146778mtspr Move To Special Purpose RegisterX31476SR64nand[.]NANDXO31489SR56divd[o][.]Divide DoublewordXO31491SR56divw[o][.]Divide WordX31498III slbia SLB Invalidate AllX31512131mcrxr Move to Condition Register from XERX3153346lswx Load String Word IndexedX3153442lwbrx Load Word Byte-Reverse IndexedX3153598lfsx Load Floating-Point Single IndexedX31536SR75srw[.]Shift Right WordX31539SR75srd[.]Shift Right DoublewordX31566III tlbsync TLB SynchronizeX3156798lfsux Load Floating-Point Single with Update IndexedX3159532III mfsr Move From Segment RegisterX3159746lswi Load String Word ImmediateX31598II sync SynchronizeX3159999lfdx Load Floating-Point Double IndexedX3163199lfdux Load Floating-Point Double with Update IndexedX3165932III mfsrin Move From Segment Register IndirectX3166147stswx Store String Word IndexedX3166243stwbrx Store Word Byte-Reverse IndexedX31663101stfsx Store Floating-Point Single IndexedX31695101stfsux Store Floating-Point Single with Update IndexedX3172547stswi Store String Word ImmediateX31727102stfdx Store Floating-Point Double IndexedX31759102stfdux Store Floating-Point Double with Update IndexedX3179042lhbrx Load Halfword Byte-Reverse IndexedX31792SR77sraw[.]Shift Right Algebraic WordX31794SR77srad[.]Shift Right Algebraic DoublewordX31824SR76srawi[.]Shift Right Algebraic Word ImmediateX31851III slbmfev SLB Move From Entry VSIDX31854II eieio Enforce In-order Execution of I/OX31915III slbmfee SLB Move From Entry ESIDX3191843sthbrx Store Halfword Byte-Reverse IndexedX31922SR66extsh[.]Extend Sign HalfwordX31954SR66extsb[.]Extend Sign ByteAppendix J.PowerPC Instruction Set Sorted by Opcode195Dep.BkPrimary ExtendX31982II icbi Instruction Cache Block InvalidateX31983103stfiwx Store Floating-Point as Integer Word IndexedX31986SR66extsw[.]Extend Sign WordX311014II dcbz Data Cache Block set to ZeroD3235lwz Load Word and ZeroD3335lwzu Load Word and Zero with UpdateD3432lbz Load Byte and ZeroD3532lbzu Load Byte and Zero with UpdateD3640stw Store WordD3740stwu Store Word with UpdateD3838stb Store ByteD3938stbu Store Byte with UpdateD4033lhz Load Halfword and ZeroD4133lhzu Load Halfword and Zero with UpdateD4234lha Load Halfword AlgebraicD4334lhau Load Halfword Algebraic with UpdateD4439sth Store HalfwordD4539sthu Store Halfword with UpdateD4644lmw Load Multiple WordD4744stmw Store Multiple WordD4898lfs Load Floating-Point SingleD4998lfsu Load Floating-Point Single with UpdateD5099lfd Load Floating-Point DoubleD5199lfdu Load Floating-Point Double with UpdateD52101stfs Store Floating-Point SingleD53101stfsu Store Floating-Point Single with UpdateD54102stfd Store Floating-Point DoubleD55102stfdu Store Floating-Point Double with UpdateDS58037ld Load DoublewordDS58137ldu Load Doubleword with UpdateDS58236lwa Load Word AlgebraicA5918106fdivs[.]Floating Divide SingleA5920105fsubs[.]Floating Subtract SingleA5921105fadds[.]Floating Add SingleA5922120fsqrts[.]Floating Square Root SingleA5924120fres[.]Floating Reciprocal Estimate SingleA5925106fmuls[.]Floating Multiply SingleA5928107fmsubs[.]Floating Multiply-Subtract SingleA5929107fmadds[.]Floating Multiply-Add SingleA5930108fnmsubs[.]Floating Negative Multiply-Subtract SingleA5931108fnmadds[.]Floating Negative Multiply-Add SingleDS62041std Store DoublewordDS62141stdu Store Doubleword with UpdateX630113fcmpu Floating Compare UnorderedX6312109frsp[.]Floating Round to Single-PrecisionX6314111fctiw[.]Floating Convert To Integer WordX6315111fctiwz[.]Floating Convert To Integer Word with round toward Zero A6318106fdiv[.]Floating DivideA6320105fsub[.]Floating SubtractA6321105fadd[.]Floating AddA6322120fsqrt[.]Floating Square RootA6323121fsel[.]Floating SelectA6325106fmul[.]Floating MultiplyA6326121frsqrte[.]Floating Reciprocal Square Root EstimateA6328107fmsub[.]Floating Multiply-SubtractA6329107fmadd[.]Floating Multiply-AddA6330108fnmsub[.]Floating Negative Multiply-SubtractA6331108fnmadd[.]Floating Negative Multiply-Add196PowerPC User Instruction Set ArchitectureDep.BkPrimary ExtendX6332113fcmpo Floating Compare OrderedX6338116mtfsb1[.]Move To FPSCR Bit1X6340104fneg[.]Floating NegateX6364114mcrfs Move to Condition Register from FPSCRX6370116mtfsb0[.]Move To FPSCR Bit0X6372104fmr[.]Floating Move RegisterX63134115mtfsfi[.]Move To FPSCR Field ImmediateX63136104fnabs[.]Floating Negative Absolute ValueX63264104fabs[.]Floating Absolute ValueX63583114mffs[.]Move From FPSCRXFL63711115mtfsf[.]Move To FPSCR FieldsX63814110fctid[.]Floating Convert To Integer DoublewordX63815110fctidz[.]Floating Convert To Integer Doubleword with round towardZeroX63846112fcfid[.]Floating Convert From Integer Doubleword1See key to mode dependency column,on page203.Appendix J.PowerPC Instruction Set Sorted by Opcode197198PowerPC User Instruction Set ArchitectureAppendix K.PowerPC Instruction Set Sorted by MnemonicThis appendix lists all the instructions in the PowerPC Architecture,in order by mnemonic.A page number is shown for instructions that are defined in this Book (Book I,PowerPC User Instruction Set Architecture), and the Book number is shown for instructions that are defined in other Books(Book II,PowerPC Virtual Environment Architecture,and Book III,PowerPC Operating Environment Architecture).If an instruction is defined in more than one of these Books,the lowest-numbered Book is used.FormOpcode ModeDep.1Page/BkMnemonic Instruction Primary ExtendXO31266SR50add[o][.]AddXO3110SR51addc[o][.]Add CarryingXO31138SR52adde[o][.]Add ExtendedD1449addi Add ImmediateD12SR50addic Add Immediate CarryingD13SR50addic.Add Immediate Carrying and RecordD1549addis Add Immediate ShiftedXO31234SR52addme[o][.]Add to Minus One ExtendedXO31202SR53addze[o][.]Add to Zero ExtendedX3128SR64and[.]ANDX3160SR65andc[.]AND with ComplementD28SR62andi.AND ImmediateD29SR62andis.AND Immediate ShiftedI1823b[l][a]BranchB16CT23bc[l][a]Branch ConditionalXL19528CT24bcctr[l]Branch Conditional to Count RegisterXL1916CT24bclr[l]Branch Conditional to Link RegisterX31058cmp CompareD1158cmpi Compare ImmediateX313259cmpl Compare LogicalD1059cmpli Compare Logical ImmediateX3158SR67cntlzd[.]Count Leading Zeros DoublewordX3126SR67cntlzw[.]Count Leading Zeros WordXL1925726crand Condition Register ANDXL1912927crandc Condition Register AND with ComplementXL1928927creqv Condition Register EquivalentXL1922526crnand Condition Register NANDXL193327crnor Condition Register NORXL1944926cror Condition Register ORXL1941727crorc Condition Register OR with ComplementXL1919326crxor Condition Register XORX3186II dcbf Data Cache Block FlushX3154II dcbst Data Cache Block StoreX31278II dcbt Data Cache Block TouchX31246II dcbtst Data Cache Block Touch for StoreX311014II dcbz Data Cache Block set to ZeroXO31489SR56divd[o][.]Divide DoublewordXO31457SR57divdu[o][.]Divide Doubleword UnsignedXO31491SR56divw[o][.]Divide WordXO31459SR57divwu[o][.]Divide Word UnsignedX31310II eciwx External Control In Word IndexedAppendix K.PowerPC Instruction Set Sorted by Mnemonic199Dep.BkPrimary ExtendX31438II ecowx External Control Out Word IndexedX31854II eieio Enforce In-order Execution of I/OX31284SR65eqv[.]EquivalentX31954SR66extsb[.]Extend Sign ByteX31922SR66extsh[.]Extend Sign HalfwordX31986SR66extsw[.]Extend Sign WordX63264104fabs[.]Floating Absolute ValueA6321105fadd[.]Floating AddA5921105fadds[.]Floating Add SingleX63846112fcfid[.]Floating Convert From Integer DoublewordX6332113fcmpo Floating Compare OrderedX630113fcmpu Floating Compare UnorderedX63814110fctid[.]Floating Convert To Integer DoublewordX63815110fctidz[.]Floating Convert To Integer Doubleword with roundtoward ZeroX6314111fctiw[.]Floating Convert To Integer WordX6315111fctiwz[.]Floating Convert To Integer Word with round toward Zero A6318106fdiv[.]Floating DivideA5918106fdivs[.]Floating Divide SingleA6329107fmadd[.]Floating Multiply-AddA5929107fmadds[.]Floating Multiply-Add SingleX6372104fmr[.]Floating Move RegisterA6328107fmsub[.]Floating Multiply-SubtractA5928107fmsubs[.]Floating Multiply-Subtract SingleA6325106fmul[.]Floating MultiplyA5925106fmuls[.]Floating Multiply SingleX63136104fnabs[.]Floating Negative Absolute ValueX6340104fneg[.]Floating NegateA6331108fnmadd[.]Floating Negative Multiply-AddA5931108fnmadds[.]Floating Negative Multiply-Add SingleA6330108fnmsub[.]Floating Negative Multiply-SubtractA5930108fnmsubs[.]Floating Negative Multiply-Subtract SingleA5924120fres[.]Floating Reciprocal Estimate SingleX6312109frsp[.]Floating Round to Single-PrecisionA6326121frsqrte[.]Floating Reciprocal Square Root EstimateA6323121fsel[.]Floating SelectA6322120fsqrt[.]Floating Square RootA5922120fsqrts[.]Floating Square Root SingleA6320105fsub[.]Floating SubtractA5920105fsubs[.]Floating Subtract SingleX31982II icbi Instruction Cache Block InvalidateXL19150II isync Instruction SynchronizeD3432lbz Load Byte and ZeroD3532lbzu Load Byte and Zero with UpdateX3111932lbzux Load Byte and Zero with Update IndexedX318732lbzx Load Byte and Zero IndexedDS58037ld Load DoublewordX3184II ldarx Load Doubleword And Reserve IndexedDS58137ldu Load Doubleword with UpdateX315337ldux Load Doubleword with Update IndexedX312137ldx Load Doubleword IndexedD5099lfd Load Floating-Point DoubleD5199lfdu Load Floating-Point Double with UpdateX3163199lfdux Load Floating-Point Double with Update IndexedX3159999lfdx Load Floating-Point Double IndexedD4898lfs Load Floating-Point SingleD4998lfsu Load Floating-Point Single with UpdateX3156798lfsux Load Floating-Point Single with Update Indexed200PowerPC User Instruction Set ArchitectureDep.BkPrimary ExtendX3153598lfsx Load Floating-Point Single IndexedD4234lha Load Halfword AlgebraicD4334lhau Load Halfword Algebraic with UpdateX3137534lhaux Load Halfword Algebraic with Update IndexedX3134334lhax Load Halfword Algebraic IndexedX3179042lhbrx Load Halfword Byte-Reverse IndexedD4033lhz Load Halfword and ZeroD4133lhzu Load Halfword and Zero with UpdateX3131133lhzux Load Halfword and Zero with Update IndexedX3127933lhzx Load Halfword and Zero IndexedD4644lmw Load Multiple WordX3159746lswi Load String Word ImmediateX3153346lswx Load String Word IndexedDS58236lwa Load Word AlgebraicX3120II lwarx Load Word And Reserve IndexedX3137336lwaux Load Word Algebraic with Update IndexedX3134136lwax Load Word Algebraic IndexedX3153442lwbrx Load Word Byte-Reverse IndexedD3235lwz Load Word and ZeroD3335lwzu Load Word and Zero with UpdateX315535lwzux Load Word and Zero with Update IndexedX312335lwzx Load Word and Zero IndexedXL19028mcrf Move Condition Register FieldX6364114mcrfs Move to Condition Register from FPSCRX31512131mcrxr Move to Condition Register from XERXFX311980mfcr Move From Condition RegisterXFX3119118mfocrf Move From One Condition Register FieldX63583114mffs[.]Move From FPSCRX3183III mfmsr Move From Machine State RegisterXFX3133979mfspr Move From Special Purpose RegisterX3159532III mfsr Move From Segment RegisterX3165932III mfsrin Move From Segment Register IndirectXFX31371II mftb Move From Time BaseXFX3114480mtcrf Move To Condition Register FieldsXFX31144118mtocrf Move To One Condition Register FieldX6370116mtfsb0[.]Move To FPSCR Bit0X6338116mtfsb1[.]Move To FPSCR Bit1XFL63711115mtfsf[.]Move To FPSCR FieldsX63134115mtfsfi[.]Move To FPSCR Field ImmediateX31146III mtmsr Move To Machine State RegisterX31178III mtmsrd Move To Machine State Register DoublewordXFX3146778mtspr Move To Special Purpose RegisterX3121032III mtsr Move To Segment RegisterX3124232III mtsrin Move To Segment Register IndirectXO3173SR55mulhd[.]Multiply High DoublewordXO319SR55mulhdu[.]Multiply High Doubleword UnsignedXO3175SR55mulhw[.]Multiply High WordXO3111SR55mulhwu[.]Multiply High Word UnsignedXO31233SR54mulld[o][.]Multiply Low DoublewordD754mulli Multiply Low ImmediateXO31235SR54mullw[o][.]Multiply Low WordX31476SR64nand[.]NANDXO31104SR53neg[o][.]NegateX31124SR65nor[.]NORX31444SR64or[.]ORX31412SR65orc[.]OR with ComplementD2463ori OR ImmediateD2563oris OR Immediate ShiftedAppendix K.PowerPC Instruction Set Sorted by Mnemonic201Dep.BkPrimary ExtendXL1918III rfid Return from Interrupt DoublewordMDS308SR71rldcl[.]Rotate Left Doubleword then Clear LeftMDS309SR72rldcr[.]Rotate Left Doubleword then Clear RightMD302SR70rldic[.]Rotate Left Doubleword Immediate then ClearMD300SR69rldicl[.]Rotate Left Doubleword Immediate then Clear Left MD301SR69rldicr[.]Rotate Left Doubleword Immediate then Clear Right MD303SR73rldimi[.]Rotate Left Doubleword Immediate then Mask Insert M20SR73rlwimi[.]Rotate Left Word Immediate then Mask InsertM21SR70rlwinm[.]Rotate Left Word Immediate then AND with MaskM23SR72rlwnm[.]Rotate Left Word then AND with MaskSC1725sc System CallX31498III slbia SLB Invalidate AllX31434III slbie SLB Invalidate EntryX31915III slbmfee SLB Move From Entry ESIDX31851III slbmfev SLB Move From Entry VSIDX31402III slbmte SLB Move To EntryX3127SR74sld[.]Shift Left DoublewordX3124SR74slw[.]Shift Left WordX31794SR77srad[.]Shift Right Algebraic DoublewordXS31413SR76sradi[.]Shift Right Algebraic Doubleword ImmediateX31792SR77sraw[.]Shift Right Algebraic WordX31824SR76srawi[.]Shift Right Algebraic Word ImmediateX31539SR75srd[.]Shift Right DoublewordX31536SR75srw[.]Shift Right WordD3838stb Store ByteD3938stbu Store Byte with UpdateX3124738stbux Store Byte with Update IndexedX3121538stbx Store Byte IndexedDS62041std Store DoublewordX31214II stdcx.Store Doubleword Conditional IndexedDS62141stdu Store Doubleword with UpdateX3118141stdux Store Doubleword with Update IndexedX3114941stdx Store Doubleword IndexedD54102stfd Store Floating-Point DoubleD55102stfdu Store Floating-Point Double with UpdateX31759102stfdux Store Floating-Point Double with Update IndexedX31727102stfdx Store Floating-Point Double IndexedX31983103stfiwx Store Floating-Point as Integer Word IndexedD52101stfs Store Floating-Point SingleD53101stfsu Store Floating-Point Single with UpdateX31695101stfsux Store Floating-Point Single with Update IndexedX31663101stfsx Store Floating-Point Single IndexedD4439sth Store HalfwordX3191843sthbrx Store Halfword Byte-Reverse IndexedD4539sthu Store Halfword with UpdateX3143939sthux Store Halfword with Update IndexedX3140739sthx Store Halfword IndexedD4744stmw Store Multiple WordX3172547stswi Store String Word ImmediateX3166147stswx Store String Word IndexedD3640stw Store WordX3166243stwbrx Store Word Byte-Reverse IndexedX31150II stwcx.Store Word Conditional IndexedD3740stwu Store Word with UpdateX3118340stwux Store Word with Update IndexedX3115140stwx Store Word IndexedXO3140SR50subf[o][.]Subtract FromXO318SR51subfc[o][.]Subtract From Carrying202PowerPC User Instruction Set ArchitectureVersion2.01FormOpcode ModeDep.1Page/BkMnemonic Instruction Primary ExtendXO31136SR52subfe[o][.]Subtract From ExtendedD8SR51subfic Subtract From Immediate Carrying XO31232SR52subfme[o][.]Subtract From Minus One Extended XO31200SR53subfze[o][.]Subtract From Zero ExtendedX31598II sync SynchronizeX316861td Trap DoublewordD260tdi Trap Doubleword ImmediateX31370III tlbia TLB Invalidate AllX3130664III tlbie TLB Invalidate EntryX31566III tlbsync TLB SynchronizeX31461tw Trap WordD360twi Trap Word ImmediateX31316SR64xor[.]XORD2663xori XOR ImmediateD2763xoris XOR Immediate Shifted1Key to Mode Dependency ColumnExcept as described below and in Section 1.12.2,“Effective Address Calculation”on page14,allinstructions are independent of whether the processoris in32-bit or64-bit mode.CT If the instruction tests the Count Register,it tests the low-order32bits in32-bit mode andall64bits in64-bit mode.SR The setting of status registers(such as XER and CR0)is mode-dependent.32The instruction must be executed only in 32-bit mode.64The instruction must be executed only in 64-bit mode.Appendix K.PowerPC Instruction Set Sorted by Mnemonic203Version2.01 204PowerPC User Instruction Set Architecture。

8051单片机汇编指令速查表

8051单片机汇编指令速查表

8051系列单片机汇编语言指令速查表说明:1)Ri, Rn指当前工作寄存器,i,n = 0 – 7,当前工作寄存器由程序状态字寄存器PSW的2个位RS1, RS0决定PLC汇编语言指令集一、数据传输指令它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据。

1. 通用数据传送指令MOV传送字或字节.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依次弹出堆栈.BSW AP交换32位寄存器里字节的顺序XCHG交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数)CMPXCHG比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX )XADD 先交换再累加.( 结果在第一个操作数里)XLAT字节查表转换.──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装入有效地址. 例: LEA DX,string ;把偏移地址存到DX.LDS传送目标指针,把指针内容装入DS. 例: LDS SI,string ;把段地址:偏移地址存到DS:SI.LES传送目标指针,把指针内容装入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标志寄存器传送,把标志装入AH.SAHF 标志寄存器传送,把AH内容装入标志寄存器.PUSHF标志入栈.POPF标志出栈.PUSHD 32位标志入栈.POPD 32位标志出栈.逻算术运算指令二、算术运算指令ADD加法.ADC带进位加法.INC加1.AAA 加法的ASCII码调整.DAA加法的十进制调整.SUB减法.SBB带借位减法.DEC减1.NEC求反(以0 减之).CMP比较.(两操作数作减法,仅修改标志位,不回送结果).AAS减法的ASCII码调整.DAS减法的十进制调整.MUL无符号乘法.IMUL整数乘法.以上两条,结果回送AH和AL(字节运算),或DX和AX(字运算), AAM乘法的ASCII码调整.DIV无符号除法.IDIV整数除法.以上两条,结果回送:商回送AL,余数回送AH, (字节运算);或商回送AX,余数回送DX, (字运算).AAD除法的ASCII码调整.CBW字节转换为字. (把AL中字节的符号扩展到AH中去)CWD字转换为双字. (把AX中的字的符号扩展到DX中去)CWDE 字转换为双字. (把AX中的字符号扩展到EAX中去)CDQ双字扩展. (把EAX中的字的符号扩展到EDX中去)逻辑运算指令三、逻辑运算指令AND与运算.OR 或运算.XOR异或运算.NOT取反.TEST测试.(两操作数作与运算,仅修改标志位,不回送结果).SHL逻辑左移.SAL算术左移.(=SHL)SHR逻辑右移.SAR算术右移.(=SHR)ROL循环左移.ROR循环右移.RCL通过进位的循环左移.RCR通过进位的循环右移.以上八种移位指令,其移位次数可达255次.移位一次时, 可直接用操作码. 如SHL AX,1.移位>1次时, 则由寄存器CL给出移位次数.如MOV CL,04SHL AX,CL串指令四、串指令DS:SI源串段寄存器:源串变址.ES:DI目标串段寄存器:目标串变址.CX重复次数计数器.AL/AX扫描值.D标志0表示重复操作中SI和DI应自动增量; 1表示应自动减量.Z标志用来控制扫描或比较操作的结束.MOVS串传送.( MOVSB 传送字符. MOVSW 传送字. MOVSD 传送双字. )CMPS串比较.( CMPSB 比较字符. CMPSW 比较字. )SCAS串扫描.把AL或AX的内容与目标串作比较,比较结果反映在标志位.LODS装入串.把源串中的元素(字或字节)逐一装入AL或AX中.( LODSB 传送字符. LODSW 传送字. LODSD 传送双字. )STOS 保存串.是LODS的逆过程.REP 当CX/ECX<>0时重复.REPE/REPZ 当ZF=1或比较结果相等,且CX/ECX<>0时重复.REPNE/REPNZ 当ZF=0或比较结果不相等,且CX/ECX<>0时重复.REPC 当CF=1且CX/ECX<>0时重复.REPNC 当CF=0且CX/ECX<>0时重复.五、程序转移指令1>无条件转移指令(长转移)JMP 无条件转移指令CALL过程调用RET/RETF过程返回.2>条件转移指令(短转移,-128到+127的距离内)( 当且仅当(SF XOR OF)=1时,OP1<OP2 )JA/JNBE不小于或不等于时转移.JAE/JNB大于或等于转移.JB/JNAE小于转移.JBE/JNA 小于或等于转移.以上四条,测试无符号整数运算的结果(标志C和Z).JG/JNLE大于转移.JGE/JNL大于或等于转移.JL/JNGE小于转移.JLE/JNG 小于或等于转移.以上四条,测试带符号整数运算的结果(标志S,O和Z).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处理器暂停, 直到出现中断或复位信号才继续.W AIT当芯片引线TEST为高电平时使CPU进入等待状态.ESC转换到外处理器.LOCK封锁总线.NOP 空操作.STC置进位标志位.CLC清进位标志位.CMC进位标志取反.STD置方向标志位.CLD清方向标志位.STI 置中断允许位.CLI清中断允许位.六、伪指令DW定义字(2字节).PROC定义过程.ENDP 过程结束.SEGMENT定义段.ASSUME建立段寄存器寻址.ENDS段结束.END程序结束.七、处理机控制指令:标志处理指令CLC(进位位置0指令)CMC(进位位求反指令)STC(进位位置为1指令)CLD(方向标志置1指令)STD(方向标志位置1指令)CLI(中断标志置0指令)STI(中断标志置1指令)NOP(无操作)HLT(停机)W AIT(等待)ESC(换码)LOCK(封锁)。

汇编语言程序设计常用资料速查手册

汇编语言程序设计常用资料速查手册

汇编程序设计常用资料速查手册1 常用DOS命令1.显示目录命令DIR该命令用来列出指定盘、指定目录或指定文件的目录。

命令格式有一下三种:DIR [<盘符>][/P][/W]DIR [<目录路径名>][/P][/W]DIR [<文件路径名>][/P][/W]其中/P表示分页显示;/W表示紧缩格式显示,即一行显示多个文件。

[ ]中内容为任选项;< >中内容必须输入。

文件路径名为:[<盘符>][<路径>]<文件名>目录路径名为:[<盘符>]<路径>文件名中可用通配符“*”和“?”,“*”代表任意一串字符,“?”代表任意一个字符。

例如:若要显示D盘MASM目录下的所有扩展名为ASM文件的DOS命令为:DIR D:\MASM\*.ASM2.文件改名命令REN该命令用来更改文件名,格式为:REN <旧文件路径名> <新文件名>旧文件路径名定义同第一点中的文件路径名,文件名中可用通配符“*”和“?”。

例如:若要将D盘MASM目录下的test.lst文件改名为test.asm,其DOS命令为:REN D:\MASM\TEST.LST TEST.ASM3.文件复制命令COPY该命令将一个或多个文件复制成副本,格式为:COPY <文件路径名> <文件路径名>文件路径名定义同第一点中的文件路径名,文件名中可用通配符“*”和“?”。

例如:若要将D盘MASM 目录下的所有扩展名为ASM的文件复制到C盘的EXAMPLE目录下,其DOS命令为:COPY D:\MASM\*.ASM C:\EXAMPLE若要将当前目录下的TEST.ASM文件复制成TEST1.ASM,其DOS命令为:COPY TEST.ASM TEST1.ASM4.文件删除命令DEL该命令将一个或多个文件删除,格式为:DEL <文件路径名>文件路径名定义同第一点中的文件路径名,文件名中可用通配符“*”和“?”。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

汇编速查手册汇编语言总结概要寄存器与存储器1. 寄存器功能. 寄存器的一般用途和专用用途. CS:IP 控制程序执行流程. SS:SP 提供堆栈栈顶单元地址. DS:BX(SI,DI) 提供数据段内单元地址. SS:BP 提供堆栈内单元地址. ES:BX(SI,DI) 提供附加段内单元地址. AX,CX,BX和CX寄存器多用于运算和暂存中间计算结果,但又专用于某些指令(查阅指令表)。

. PSW程序状态字寄存器只能通过专用指令(LAHF, SAHF)和堆栈(PUSHF,POPF)进行存取。

2. 存储器分段管理. 解决了16位寄存器构成20位地址的问题. 便于程序重定位. 20位物理地址=段地址* 16 + 偏移地址. 程序分段组织: 一般由代码段,堆栈段,数据段和附加段组成,不设置堆栈段时则使用系统内部的堆栈。

3. 堆栈. 堆栈是一种先进后出的数据结构, 数据的存取在栈顶进行, 数据入栈使堆栈向地址减小的方向扩展。

. 堆栈常用于保存子程序调用和中断响应时的断点以及暂存数据或中间计算结果。

. 堆栈总是以字为单位存取指令系统与寻址方式1. 指令系统. 计算机提供给用户使用的机器指令集称为指令系统,大多数指令为双操作数指令。

执行指令后,一般源操作数不变,目的操作数被计算结果替代。

. 机器指令由CPU执行,完成某种运算或操作,8086/8088指令系统中的指令分为6类: 数据传送,算术运算,逻辑运算,串操作,控制转移和处理机控制。

2. 寻址方式. 寻址方式确定执行指令时获得操作数地址的方法. 分为与数据有关的寻址方式(7种)和与转移地址有关的寻址方式(4)种。

. 与数据有关的寻址方式的一般用途:(1) 立即数寻址方式--将常量赋给寄存器或存储单元(2) 直接寻址方式--存取单个变量(3) 寄存器寻址方式--访问寄存器的速度快于访问存储单元的速度(4) 寄存器间接寻址方式--访问数组元素(5) 变址寻址方式(6) 基址变址寻址方式(7) 相对基址变址寻址方式(5),(6),(7)都便于处理数组元素. 与数据有关的寻址方式中,提供地址的寄存器只能是BX,SI,DI或BP. 与转移地址有关的寻址方式的一般用途:(1) 段内直接寻址--段内直接转移或子程序调用(2) 段内间接寻址--段内间接转移或子程序调用(3) 段间直接寻址--段间直接转移或子程序调用(4) 段间间接寻址--段间间接转移或子程序调用汇编程序和汇编语言1. 汇编程序. 汇编程序是将汇编语言源程序翻译成二进制代码程序的语言处理程序,翻译的过程称为汇编。

2. 汇编语言. 汇编语言是用指令助记符,各种标识变量,地址,过程等的标识符书写程序的语言, 汇编语言指令与机器指令一一对应。

. 伪指令,宏指令不是由CPU执行的指令,而是由汇编程序在汇编期间处理的指令。

. 伪指令指示汇编程序如何完成数据定义,存储空间分配,组织段等工作。

. 宏指令可简化程序并减少程序书写量。

. 条件汇编伪指令的功能是确定是否汇编某段源程序,而不是实现程序分支,对未汇编的程序将不产生相应的目标代码。

. 结构作为一种数据结构可将一组类型不同但有逻辑关联的数据组织在一起,便于整体处理数据。

. 记录可用于提高存储单元的利用率,将若干不足一个字节或字且有逻辑关联的信息压缩存放在一个字节或字中。

. 指令中的表达式在汇编期间计算,并且只能对常量或地址进行计算。

程序设计基础1. 分支程序设计. 程序分支由条件转移指令或无条件转移指令实现. 存放若干目的转移地址或跳转指令的跳转表常用于实现多路分支. 条件转移指令只能实现偏移量为-128至+127字节范围的转移. 无条件转移指令根据寻址方式可实现短转移(偏移量为-128至+127字节),段内转移,段间转移。

2. 循环程序设计. 可由循环控制指令或条件转移指令组织循环结构. 内层循环结构必须完全包含在外层循环结构内,并不能发生从循环结构外向循环结构内的转移。

3. 子程序设计. 子程序中应保护寄存器内容,并正确使用堆栈, 成对执行PUSH和POP指令,保证执行RET指令时堆栈栈顶为返回地址。

. 主程序可通过寄存器,参数表,或堆栈传递参数给子程序4. EXE文件和COM文件. 二者都是可执行文件. COM文件源程序的特点是: 第一条可执行指令的起始存放地址必须是100H,不能分段,不用定义堆栈,所有过程为NEAR类型,直接用INT 20H 指令返回DOS。

5. DOS功能调用与BIOS中断调用. 二者都是完成DOS系统提供给用户的输入/输出等常用功能,通过执行软中断指令完成一次软中断服务。

. DOS功能调用的中断服务程序是操作系统的一部分,存于RAM中; 而BIOS中断调用的中断服务程序存放在ROM中。

输入/输出与中断系统1. 输入/输出的方式. 程序直接I/O方式: 用IN和OUT指令直接在端口级上进行I/O操作,数据传送方式分为无条件传送方式和查询传送方式。

. 中断传送方式:由CPU响应中断请求完成中断服务。

. DMA传送方式: 直接在存储器与外设之间传送数据。

2. 有关中断的概念. 中断、中断源、中断请求、中断服务、中断向量、中断向量表、中断响应过程、中断指令、开中断、关中断、内部中断、外部中断、可屏蔽中断、非屏蔽中断。

3. 键盘I/O、显示器I/O操作. 键盘的输入操作用BIOS的16H中断调用控制,也可直接访问60H端口(数据端口), 61H 端口(状态端口)检测键盘的按键操作。

. 对于特殊键(如Shift , Ctrl , Alt , NumLock , ScrollLock等键)的按动情况,可以直接从来40:17H单元取得有关信息。

. 显示器的图形显示可以用BIOS的10H中断调用实现,另一种速度更快的方法是直接读写视频缓冲区。

4. 打印机I/O操作由INT 17H中断调用实现,串行通讯口操作由INT 14H中断调用实现。

CLD Clear the direction flag (set to forward direction)将方向标志置0,使si和di增量,串处理从低地址向高地址处理8088 汇编速查手册一、数据传输指令它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据.1. 通用数据传送指令.MOV传送字或字节.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交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数)CMPXCHG 比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX )XADD先交换再累加.( 结果在第一个操作数里)XLAT字节查表转换.── 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装入有效地址.例: LEA DX,string;把偏移地址存到DX.LDS传送目标指针,把指针内容装入DS.例: LDS SI,string;把段地址:偏移地址存到DS:SI.LES传送目标指针,把指针内容装入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标志寄存器传送,把标志装入AH.SAHF标志寄存器传送,把AH内容装入标志寄存器.PUSHF标志入栈.POPF标志出栈.PUSHD32位标志入栈.POPD32位标志出栈.二、算术运算指令ADD 加法.ADC带进位加法.INC加 1.AAA加法的ASCII码调整.DAA加法的十进制调整.SUB减法.SBB带借位减法.DEC减 1.NEC求反(以0 减之).CMP比较.(两操作数作减法,仅修改标志位,不回送结果).AAS减法的ASCII码调整.DAS减法的十进制调整.MUL无符号乘法.IMUL整数乘法.以上两条,结果回送AH和AL(字节运算),或DX和AX(字运算), AAM乘法的ASCII码调整.DIV无符号除法.IDIV整数除法.以上两条,结果回送:商回送AL,余数回送AH, (字节运算);或商回送AX,余数回送DX, (字运算).AAD除法的ASCII码调整.CBW字节转换为字. (把AL中字节的符号扩展到AH中去)CWD字转换为双字. (把AX中的字的符号扩展到DX中去)CWDE字转换为双字. (把AX中的字符号扩展到EAX中去)CDQ双字扩展.(把EAX中的字的符号扩展到EDX中去) 三、逻辑运算指令AND与运算.OR或运算.XOR异或运算.NOT取反.TEST测试.(两操作数作与运算,仅修改标志位,不回送结果).SHL逻辑左移.SAL算术左移.(=SHL)SHR逻辑右移.SAR算术右移.(=SHR)ROL循环左移.ROR循环右移.RCL通过进位的循环左移.RCR通过进位的循环右移.以上八种移位指令,其移位次数可达255次.移位一次时, 可直接用操作码.如SHL AX,1.移位>1次时, 则由寄存器CL给出移位次数.如MOV CL,04SHL AX,CL四、串指令DS:SI源串段寄存器:源串变址.ES:DI目标串段寄存器:目标串变址.CX重复次数计数器.AL/AX扫描值.D标志0表示重复操作中SI和DI应自动增量; 1表示应自动减量.Z标志用来控制扫描或比较操作的结束.MOVS串传送.( MOVSB传送字符.MOVSW传送字.MOVSD传送双字. ) CMPS串比较.( CMPSB比较字符.CMPSW比较字. )SCAS串扫描.把AL或AX的内容与目标串作比较,比较结果反映在标志位.LODS装入串.把源串中的元素(字或字节)逐一装入AL或AX中.( LODSB传送字符.LODSW传送字.LODSD传送双字. ) STOS保存串. 是LODS的逆过程.REP当CX/ECX<>0时重复.REPE/REPZ当ZF=1或比较结果相等,且CX/ECX<>0时重复.REPNE/REPNZ当ZF=0或比较结果不相等,且CX/ECX<>0时重复.REPC当CF=1且CX/ECX< >0时重复.REPNC当CF=0且CX/ECX<>0时重复.五、程序转移指令1>无条件转移指令(长转移)JMP无条件转移指令CALL过程调用RET/RETF过程返回.2>条件转移指令(短转移,-128到+127的距离内)( 当且仅当(SF XOR OF)=1时,OP1<OP2 )JA/JNBE 不小于或不等于时转移.JAE/JNB 大于或等于转移.JB/JNAE 小于转移.JBE/JNA 小于或等于转移.以上四条,测试无符号整数运算的结果(标志C和Z).JG/JNLE 大于转移.JGE/JNL 大于或等于转移.JL/JNGE 小于转移.JLE/JNG 小于或等于转移.以上四条,测试带符号整数运算的结果(标志S,O和Z).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置方向标志位.CLD清方向标志位.STI置中断允许位.CLI清中断允许位.六、伪指令DW定义字(2字节).PROC定义过程.ENDP过程结束.SEGMENT 定义段.ASSUME建立段寄存器寻址.ENDS段结束.END程序结束.。

相关文档
最新文档