----------------------------------------------------------------
| |
| |
| Zilog |
| |
| ZZZZZZZ 88888 000 000 000 |
| Z 8 8 0 0 0 0 0 0 |
| Z 8 8 0 0 0 0 0 0 0 0 0 |
| Z 88888 0 0 0 0 0 0 0 0 0 |
| Z 8 8 0 0 0 0 0 0 0 0 0 |
| Z 8 8 0 0 0 0 0 0 |
| ZZZZZZZ 88888 000 000 000 |
| |
| Z8001/Z8002 MICROPROCESSOR Instruction Set Summary |
| |
| |
| |
| |
| XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXX X |
| XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXX XX |
| XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXX XXXX |
| XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXX XXXXXX |
| XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXX XXXXXXXX |
| XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXX XXXXXXXXX |
| XXXXXXXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXX XXXXXXXXX |
| XXXXXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXX XXXXXXXXX |
| XXXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXX XXXXXXXXX |
| XXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXX XXXXXXXXX |
| XXXXXXXXXXXXXXXXXXXXX XXXXXXXXX XXXXXXXXX |
| XXXXXXXXXXXXXXXXXXX XXXXXXXXX XXXXXXXXX |
| XXXXXXXXXXXXXXXXX XXXXXXXXX XXXXXXXXX |
| XXXXXXXXXXXXXXX XXXXXXXXX XXXXXXXXX |
| XXXXXXXXX XXXXXXXXX XXXXXXXXXXXXXX |
| XXXXXXXXX XXXXXXXXX XXXXXXXXXXXXXXXX |
| XXXXXXXXX XXXXXXXXX XXXXXXXXXXXXXXXXXX |
| XXXXXXXXX XXXXXXXXX XXXXXXXXXXXXXXXXXXXX |
| XXXXXXXXX XXXXXXXXX XXXXXXXXXXXXXXXXXXXXXX |
| XXXXXXXXX XXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXX |
| XXXXXXXXX XXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXXXX |
| XXXXXXXXX XXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| XXXXXXXXX XXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| XXXXXXXXX XXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| XXXXXXX XXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| XXXXX XXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| XXX XXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| X XXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| |
| |
| |
| XXXXXXXXXXXXXXX XXX XXXXX |
| XXXXXXXXXXXXXXX XXX XXXXX |
| XXX XXXX XXX |
| XXXX XXXXXX XXX XXXXXXX XXXXXX XX |
| XXXX XXXXXX XXX XXXXXXXXXXX XXXXXXXXXXXXX |
| XXXX XXX XXX XXXX XXXX XXXX XXXX |
| XXXX XXX XXX XXX XXX XXX XXX |
| XXXX XXX XXX XXX XXXX XXXX XXXX XXXX |
| XXXXXXXXXXXXXXX XXXXXXXX XXXXXXX XXXXXXXXXXX XXXXXXXXXXXX |
| XXXXXXXXXXXXXXX XXXXXXXX XXXXXXX XXXXXXX XXXXXX XXX |
| XXX |
| XX XXXX |
| XXXXXXXXXXX |
| XXXXXXX |
| |
| |
| |
| |
|Written by Jonathan Bowen |
| Programming Research Group |
| Oxford University Computing Laboratory |
| 8-11 Keble Road |
| Oxford OX1 3QD |
| England |
| |
| Tel +44-865-273840 |
| |
|Created October 1981 |
|Updated April 1985 |
|Issue 1.2 Copyright (C) J.P.Bowen 1985|
----------------------------------------------------------------
----------------------------------------------------------------
|Mnemonic |CZSPDH|Description |Notes |
|------------+------+----------------------------+-------------|
|ADCb d,s |****bb|Add with Carry |d=d+s+C |
|ADDa d,s |****bb|Add |d=d+s |
|ANDb d,s |-**b--|Logical AND |d=d&s |
|BITb d,s |-*----|Bit Test |Z=~d<s> |
|CALL d |------|Call |-[SP]=PC,PC=d|
|CALR d |------|Call Relative |-[SP]=PC,PC=d|
|CLRb d |------|Clear |d=0 |
|COMb d |-**b--|Complement |d=~d |
|COMFLG f |++++--|Complement Flag |f=~f |
|CPa d,s |****--|Compare |d-s |
|CPDb d,s,c|?*?*--|Compare and Decrement |d-s,r=r-1 |
|CPDRb d,s,c|?*?*--|Compare, Decrement and Rept |CPD till r=0 |
|CPIb d,s,c|?*?*--|Compare and Increment |d-s,r=r+1 |
|CPIRb d,s,c|?*?*--|Compare, Increment and Rept |CPI till r=0 |
|CPSDb d,s,c|?*?*--|Compare String and Decrement|d-s,r=r-1 |
|CPSDRb d,s,c|?*?*--|Compare String, Dec. and Rep|CPSD till r=0|
|CPSIb d,s,c|?*?*--|Compare String and Increment|d-s,r=r+1 |
|CPSIRb d,s,c|?*?*--|Compare String, Inc. and Rep|CPSI till r=0|
|DAB d |***---|Decimal Adjust Byte |d=BCD format |
|DECb d,s |-***--|Decrement (s=1-16) |d=d-s |
|DI i |------|Disable Interrupts | #|
|DIVl d,s |****--|Divide |d=d/s |
|DbJNZ r,d |------|Decrement & Jump if Not Zero|r=r-1 |
|EI i |------|Enable Interrupts | #|
|EXb d,s |------|Exchange |d<->s |
|EXTSa d |------|Extend Signs | |
|HALT |------|Halt | #|
|pINb d,s |------|(Special) Input |d=s #|
|INCb d,s |-***--|Increment (s=1-16) |d=d+s |
|pINDb d,s,r|---*--|(Special) Input and Dec. |d=s,r=r-1 #|
|pINDRb d,s,r|---1--|(Special) Input, Dec. & Rept|IND till r-0#|
|pINIb d,s,r|---*--|(Special) Input and Inc. |d=s,r=r+1 #|
|pINIRb d,s,r|---1--|(Special) Input, Inc. & Rept|INI till r=0#|
|IRET |??????|Interrupt Return |PS=[SP]+ #|
|JP cc,d |------|Jump |PC=d |
|JR cc,d |------|Jump Relative |PC=d |
|LDa d,s |------|Load |d=s |
|LDA d,s |------|Load Address |d=EAs |
|LDAR d,s |------|Load Address Relative |d=EAs |
|LDCTL d,s |++++++|Load Control |d=s #|
|LDCTLB d,s |++++++|Load Control Byte |d=s |
|LDDb d,s,r|---*--|Load and Decrement |d=s,r=r-1 |
|LDDRb d,s,r|---1--|Load, Decrement and Repeat |LDD till r=0 |
|LDIb d,s,r|---*--|Load and Increment |d=s,r=r+1 |
|LDIRb d,s,r|---1--|Load, Increment and Repeat |LDI till r=0 |
|LDK d,s |------|Load Constant (s=0-15) |d=s |
|LDM d,s,n|------|Load Multiple (n=1-16) |d=s (n words)|
|LDPS s |??????|Load Program Status |PS=s #|
|LDRa d,s |------|Load Relative |d=s |
|MBIT |??*???|Multi-Micro Bit Test |S=~MI pin #|
|MREQ d |-**---|Multi-Micro Request |S=available #|
|MRES |------|Multi-Micro Reset |~MI=high #|
|MSET |------|Multi-Micro Set |~MO=low #|
|MULTl d,s |***0--|Multiply |d=d*s |
|NEGb d |****--|Negate |d=-d |
|NOP |------|No Operation | |
|ORb d,s |-**b--|Logical inclusive OR |d=dvs |
|pOTDRb d,s,r|---1--|(Special) Output, Dec. & Rep|OTD till r=0#|
|pOTIRb d,s,r|---1--|(Special) Output, Inc. & Rep|OTI till r=0#|
|pOUTb d,s |------|(Special) Output |d=s #|
|pOUTDb d,s,r|---*--|(Special) Output and Dec. |d=s,r=r=1 #|
|pOUTIb d,s,r|---*--|(Special) Output and Inc. |d=s,r=r+1 #|
|POPl d,s |------|Pop |d=s,[EAs]+ |
|PUSHl d,s |------|Push |-[EAs],d=s |
|RESb d,s |------|Reset Bit |d<s>=0 |
|RESFLG f |++++--|Reset Flag |f=0 |
|RET cc |------|Return |PC=[SP]+ |
|RLb d,s |****--|Rotate Left |d=d<-s |
|RLCb d,s |****--|Rotate Left through Carry |d={C,d}<-s |
|RLDB ll,s |-*?---|Rotate Left Digit Byte |s={ll,s}<-4 |
|RRb d,s |****--|Rotate Right |d=s->d |
|RRCb d,s |****--|Rotate Right through Carry |d=s->{C,d} |
|RRDB ll,s |-*?---|Rotate Right Digit Byte |s=4->{ll,s} |
|SBC d,s |****bb|Subtract with Carry |d=d-s-C |
|SC s |------|System Call (-[SP]={PS,ins})|PS=sys PS #|
|SDAa d,s |****--|Shift Dynamic Arithmetic |d={1,d,0}<-s |
----------------------------------------------------------------
----------------------------------------------------------------
|Mnemonic |CZSPDH|Description |Notes |
|------------+------+----------------------------+-------------|
|SDLa d,s |***?--|Shift Dynamic Logical |d={0,d,0}<-s |
|SETb d,s |------|Set Bit |d<s>=1 |
|SETFLG f |++++--|Set Flag |f=1 |
|SLAa d,s |****--|Shift Left Arithmetic |d={d,0}<-s |
|SLLa d,s |***?--|Shift Left Logical |d={d,0}<-s |
|SRAa d,s |***0--|Shift Right Arithmetic |d=s->{1,d} |
|SRLa d,s |***?--|Shift Right Logical |d=s->{0,d} |
|SUBa d,s |****bb|Subtract |d=d-s |
|TCCb cc,d |------|Test Condition Code |If cc d<0>=1 |
|TESTa d |-***--|Test |dv0 |
|TRDB d,s,r|-?-*--|Translate and Decrement |d=s[d],r=r-1 |
|TRDRB d,s,r|-?-1--|Translate, Dec. and Repeat |TRDB till r=0|
|TRIB d,s,r|-?-*--|Translate and Increment |d=s[d],r=r+1 |
|TRIRB d,s,r|-?-1--|Translate, Inc. and Repeat |TRIB till r=0|
|TRTDB s,s,r|-*-*--|Translate, Test and Dec. |RH1=s2[s1],..|
|TRTDRB s,s,r|-*-*--|Translate, Test, Dec. & Rept|TRTDB till...|
|TRTIB s,s,r|-*-*--|Translate, Test and Inc. |RH1=s2[s1],..|
|TRTIRB s,s,r|-*-*--|Translate, Test, Inc. & Rept|TRTIB till...|
|TSETb d |--*---|Test and Set |{S,d}=d<MSB> |
|XOR d,s |-**b--|Logical Exclusive OR |d=dxs |
|------------+------+----------------------------+-------------|
| FCW |-*01? |Unaffected/affected/reset/set/unknown |
| |+b |Optionally affected/affected for byte only|
| C |C |Carry flag (Bit 7) |
| Z | Z |Zero flag (Bit 6) |
| S | S |Sign flag (Bit 5) |
| D | D |Decimal adjust flag (Bit 4) |
| P/V | P |Parity/Overflow flag (Bit 3) |
| H | H|Half carry flag (Bit 2) |
|-------------------+------------------------------------------|
| #n #nn #nnnn |Immediate data mode (IM, 4/8/16/32-bit) |
| r |Register addressing mode (R) |
| @r |Indirect Register mode (IR) |
| <<n>>nn nn |nn| |Direct Addressing mode (DA) |
| <<n>>nn[Rn] nn[Rn]|Indexed Addressing mode (X, not R0) |
| $+nn nn |Relative Addressing mode (RA) |
| RRn[#nn] |Based Addressing mode (BA, not RR0) |
| RRn[Rn] |Based Indexed addressing mode (BX, not R0)|
|-------------------+------------------------------------------|
|AVAL nnnn(,...) |Define Address Value(s) |
|BVAL n(,...) |Define Byte Value(s) |
|EVEN |Set program counter to Even address |
|LVAL nnnn(,...) |Define Long word Value(s) |
|WVAL nn(,...) |Define Word Value(s) |
|-------------------+------------------------------------------|
| FCW |Flag Control Word (16-bit) |
| PC |Program Counter (32-bit) |
| PSAP |Program Status Area Pointer (32-bit) |
| REFRESH |Refresh control register (16-bit) |
| RLn |Low byte register (8-bit, n=0-7) |
| RHn |High byte register (8-bit, n=0-7) |
| Rn |Word register (16-bit, n=0-15) |
| RRn |Double word register (32-bit, n=0-14,even)|
| RQn |Quadruple word reg. (64-bit, n=0/4/8/12) |
| RR14 |Used as stack pointer (32-bit) |
|-------------------+------------------------------------------|
| a |Blank, B or L (Word/Byte/Long operation) |
| b |Blank or B (Word/Byte operation) |
| c |Condition (r,cc) |
| cc |Condition Code (F/Z/NZ/C/NC/PL/MI/NE/EQ/ |
| | OV/NOV/PE/PO/GE/LT/GT/LE/UGE/ULT/UGT/ULE)|
| d d<X> |Destination/Bit X of Destination |
| f |Flag(s) (C/Z/S/P/V) |
| i |Interrupt (VI/NVI) |
| l |Blank or L (Word/Long word operation) |
| ll |Link Location (bottom 4 bits of register) |
| n nn nnnn |Constant expression (8/16/32-bit) |
| p |Blank or S (Normal/Special operation) |
| r |Register (RLn/RHn/Rn/RRn/RQn) |
| s EAs |Source/Effective Address of Source |
| + - * / |Arithmetic add/subtract/multiply/divide |
| & ~ v x |Logical AND/NOT/inclusive OR/exclusive OR |
| <-X X-> |Rotate left/right by X bits |
| [ ] [ ]+ -[ ] |Indirect address/auto-increment/decrement |
| { } # |Combination of operands/privileged instr. |
| <<n>> |nn| |Segment/short offset (0-255) |
----------------------------------------------------------------
|