SILICON GATE MOS
8080.A
INSTRUCTION SET
Summary
of
Processor Instructions
Instruction
Code
[1
J
Clock
[2]
Instruction
Code
(1)
Clock[2J
Mnemonic
Description
D7
D6
Os
D4
D3
02
0,
Do
Cycles
Mnemonic
Description
D7
06
Os
04
Da
~
0,
Do
Cycles
MOV
r1
.r2
Move
register
to
register
0
1
0 0 0
S S
S 5
RZ
Return
on
zero
1
1
0 0
,
0 0
0
5/11
MOVM,r
Move
register
to
memory
0 1
1
1 0
S
S
S
7
RNZ
Return
on
no
zero
1 1 0 0
0
0
C
0
5/11
MOVr,M
Move
memory
to
register
0 1
0
0 0
1
1
0
7
RP
Return
on
positive
1 1 1
1
0
0 0
0
5/11
.HLT
Halt
0 1
1 1
0 1
1
0
7
RM
Return
on
minus
1 1 1 1 1 0
0
0
5/11
MVI
r
Movi
immediate
register
0 0
0 0 0 1 1
0
7
RPE
Return
on
parity
even
1 1
1
0
1 0
0
0
5/11
MVIM
Move
immediate
memory
0
0
1 1
0
1 1
0
10
RPO
Return
on
parity
odd
1 1
1
0 0
0
0 0
5/11
lNR
r I
ncrement
register
0 0
0
0 0
1
0 0
5
RST
Restart
1 1
A A A
1
1 1
11
OCRr
Decrement
register
0 0
0
0 0
1
0 1 5
IN
Input
1 1
0
1
1 0
1 1
10
INR
M
I
ncrement
memory
0 0
1 1
0
1
0 0
10
OUT
Output
1
1 0
1
0
0
1
1
10
OCR
M
Decrement
memory
0 0
1
1
0 1 0
1
10
LXIB
Load
immediate
register
0
0 0 0 0
0
0
1
10
ADD
r
Add
register
to
A 1
0'
0
0
0
S S S
4
Pair
B& C
ADCr
Add
register
to
A
with
carry
1
0 0
0
1
S S S 4
LXIO
Load
immediate
register
0 0 0
0
0
0
10
SUB
r
Subtract
register
from
A 1
0
0
1 0
S S S
4-
Pair
D& E
SaB
r
Subtract
register
from
A
1
0
0
1 1
S S S
4
LXIH
Load
immediate
register
0 0
0 0
0 0
10
with
borrow
Pair
H& L
ANAr
And
register
with
A
0
1 0 0
S S S
,4
LXISP
Load
immediate
stack
pointer
0 0
1
1
0
0 0
10
XRAr
Exclusive
Or
register
with
A 0
1 0 1
S S
S
4
PUSH
a
Push
register
Pair
B& C
on
1 1
0
0 0
1 0
11
ORAr
.0
r
register
with
A 0
1
1
0
S S
S
4
stack
CMPr
Compare
register
with
A
0
1
1
1
S
S'
S 4
PUSH
0
Push
register
Pair
0 & E
on
0
0
0
11
ADOM
Add
memory
to
A
0 0
0
0 1
1
0
7
stack
ADCM
Add
memory
to
A
with
carry
0
0
0 1
1 1
0
7
PUSH
H
Push
register
Pair
H& Lon
0 0
0
11
SUB
M
Subtract
memory
from
A 0
0
'1
0
1
1
0
7
stack
SBB
M
Subtract
memory
from
A 0 0
1
1 1 1
0
7
PUSH
PSW
Push
A
and
Flags
0
0
11
with
borrow
on
stack
ANAM
And
memory
with
A
0
1 0 0
0
7
POP
B
Pop
register
pair
B& C
off
0 0 0
0 0
10
XRAM
Exclusive
0r
memory
with
A
0
1
O.
1 0
7
stack
ORAM
Or
memory
with
A
0
1
1
0
0
7
POPD
Pop
register
pair
0 & E
off
0 0
0
O'
10
CMPM
Compare
memory
with
A
0
1
1 1
0
7
stack
ADI
Add
immediate
to
A 1
0
0 0
0
7
POP
H
Po.p
register
pair
H& L
off
0 0
0 0
10
ACI
Add
immediate
to
A
with
1
0 0
1
0
7
stack
carry
POP
PSW
Pop
A
and
Flags
0 0 0
10
SUI
Subtract
immediate
from
A
0
0 0
off
stack
SBI
Subtract
immediate
from
A
0
1
0
STA
Store
Ad
trect
0
0
1
0
0
0
13
with
borrow
LOA
Load
A
direct
0
0
1
1 0
0
13
ANI
And
immediate
with
A
0 0 0
XCHG
Exchange
0 &
E,
H& L
1 1
0 1
0
1
4
XRI
Exclusive
Or
immediate
with
0 1
0
Registers
A
XTHL
Exchang~
top
of
stack,
H&L 1
1
1
0 0 0
1
1
18
ORI
Or
immediate
with
A
1
1 1
1
0 0
7
SPHL
H& L
to
stack
pointer
1 1 1 1 1
0
0 1 5
CPI
Compare
immediate
with
A
1 1 1
1 1
0
7
PCHL
H& L
to
program
counter
1
1
1
0 1 0
0
1
5
RLC
Rotate
A
left
0
0,
0
0
0
1 4
DAD
B
Add
B&C
to
H& L 0
0
0 0 1 0 0 1
10
RRC
Rotate
A
right
0 0 0 0
1 1
4
DAD
0
Add
0 & E
to
H& L
0 0 0
1
1 0 0 1
10
RAL
Rotate
A
left
through
carry
0 0
0
1
0
1
4
DAD
H
Add
H& L
to
H& L
0
0
1
0
1 0
0
1
10
RAR
Rotate
A
right
through
0 0 0
1
l'
1 4
DAD
SP
Add
stack
pointer
to
H& L
0 0
1 1
1 0 0 1
10
carry
STAXB
Store
A
indirect
0 0 0
0 0 0 1 0 7
JMP
Jump
unconditional
1
0
0
0
0
1
1
10
STAX
0
Store
A
indirect
0
0
0 1
0
0
1
0
7
JC
Jump
on
carrY
1
0
1 1 0
1
0
10
LOAXB
Load
A
indirect
0
0 0 0 1 0 1
0
7
JNC
Jump
on
no
carry
1
0
1 0 0
1
0
10
LoAXO
Load
A
indirect
0 0 0 1
1 0 1
0
7
JZ
Jump
on
zero
1
0
0
1
0 1
0
10
INX
B
Increment
B& C
registers
0 0 0
0
0 0
1
1 5
JNZ
Jump
on
no
zero
1
0
0 0
0 1
0
10
INX
D
Increment
0 & E
registers
0
0
0 1
0
0
1 1 5
JP
Jump
on
positive
1 1
1
0
0
1
0
10
INX
H
Increment
H& L
registers
0
0
1
0
0
0
1
1
5
JM
Jump
on
minus
1
1
1 1
0
1
0
10
INXSP
Increment
stack
pointer
0
0
1 1
0 0
1
1
'5
JPE
Jump
on
parity
even
1
1 0
1
0
1
0
10
OCX
B
Decrement
B& C
0 0 0 0 1
0 1
1
5
JPO
Jump
on
parity
odd
1 1 0 0 0
1
0
.10
,OCX
0
Decrement
0 & E
0
0
0 1 1
0 1 1
5
CALL
Call
unconditional
1
0
0 1
1 0
1
17
OCX
H
Decrement
H& L
0 0
1
0 1
0
1
1 5
CC
Call
on
carry
1
0
1
1
1 0 0
11/17
OCXSP
Decrement
stack
pointer
0
O.
1 1
1 0 1
1
5
CNC
Call
on
no
carry
1
0
1
0
1
0 0
11/17
CMA
Complement
A
0
0 1 0 1 1
1
1
4
CZ
Call
on
zero
,1
0
0 1
1
0
0
11/17
STC
Set
carry
0 0 1
1
0
"
1
1 4
CNZ
Call
on
no
zero
1
0
0
0
1
0
0
11/17
CMC
Complement
carry
0
0
1 1
1
1
1
1
4
CP
Call
on
positive
1
1 1 0 1 0
0
11/17
DAA
Decimal
adjust
A
0
0
1
0 0
1
1
,1
4
CM
Call
on
minus
1
1 1
1
1 0
0
11/17
SHLD
Store
H& L
direct
0 0
1
(}
0 0
1
0
16
CPE
Call
on
parity
even
1
1
0
1 1
0
0
11/17
LHLD
Load
H& L
direct
0
0
1
0
1 0 1
0
16
CPO
Call
on
parity
odd
1 1
0
0
1
0 0
11/17
EI
Enable
Interrupts
1 1
1
1
1
0 1
1
4
RET
Return
1 0 0 1
0
0 1
10
01
Disable
interrupt
1 1 1
1
0 0 1 1
4
RC
Return
on
carry
1
0
1
1
0,
0
0
5/11
N.OP
No-operation
0 0 0
0
0
0 0
0 4
RNC
Return
on
no
carry
1
0
1
0
0 0
0
5/11
NOTES:. 1.
DDDorSSS-OOOB-001
C-010D-011'E-100H-101
L-110Memory....:.111
A.
2. Two possible cycle times, (5/11) indicate instruction cycles dependent on
condition
flags.
5-19