Professional Documents
Culture Documents
AH
BH
CH
DH
AL
BL
CL
DL
EU
Receive codes and data from BIU
Not connected to system buses
Execute instructions
Save results in registers, or pass to BIU to memory and IO
8086:
status x 6 [C, P, A, Z, S, O]
control x 3 [TF, IF, DF]
ZF
AF
PF
CF
OF
DF
IF
TF
TF: Trap flag (single-step after next instruction; clear by single-step interrupt)
IF: Interrupt-Enable: enable maskable interrupts
DF: Direction flag: auto-decrement (1) or increment(0) index on
string (block move) operations
OF: Overflow: signed result cannot be expressed within #bits in destination operand
9
10
0 = offset to begin-of-DS
11
FIGURE 3-9 The 8086 divides its 1 MB of memory address space into four segments, the
data, code, stack, and extra segments. The four segment registers DS, CS, SS, and ES point to
location 0 of the current segment. In this example, the stack and extra segments are partially
overlapped. (From J. Uffenbeck, Microcomputers and Microprocessors: The 8080, 8085, and
Z-80, Prentice Hall, Englewood Cliffs, NJ, 1985.)
John Uffenbeck
The 80x86 Family: Design, Programming, and
Interfacing, 3e
12
Address Translation:
Phys-address = Base*16+Index (or offset)
E.g., CS:IP, DS:2345H,
13
Alternative segment:
Default segment can be changed using segment override operator (for some
memory reference types)
14
Instruction fetch
CS
IP
Stack operations
SS
SP
General data
DS
CS,ES,SS
Effective address
String source
DS
CS,ES,SS
SI
String destination
ES
DI
BX used as pointer
DS
CS,ES,SS
Effective address
BP used as pointer
SS
CS,ES,DS
Effective address
15
;PA = DS (sl) + SI + 5
;PA = DS (sl) + DI + 20
;PA=DS(sl)+BX+DI +8
;PA=SS(sl)+BP+SI +29
8086 Microprocessor
Common signals
AD0-AD15 (Bidirectional)
Address/Data bus
Low order address bus;
multiplexed with data.
these
are
are
24
8086 Microprocessor
Common signals
MN/ MX
MINIMUM / MAXIMUM
This pin signal indicates what mode the
processor is to operate in.
8086 Microprocessor
Common signals
TEST
input is
instruction.
tested
by
the
WAIT
READY
This is the acknowledgement from the
slow device or memory that they have
completed the data transfer.
The signal made available by the devices
is synchronized by the 8284A clock
generator to provide ready input to the
8086.
The signal is active high.
26
8086 Microprocessor
Common signals
RESET (Input)
Causes the processor to immediately
terminate its present activity.
The signal must be active HIGH for at
least four clock cycles.
CLK
The clock input provides the basic timing
for processor operation and bus control
activity. Its an asymmetric square wave
with 33% duty cycle.
27
8086 Microprocessor
28
8086 Microprocessor
ALE
M/
8086 Microprocessor
HLDA
30
8086 Microprocessor
, ,
31
8086 Microprocessor
32
8086 Microprocessor
/ ,
/
of
the
33
8086 Microprocessor
Instruction Set
8086 supports 6 types of instructions.
1. Data Transfer Instructions
2. Arithmetic Instructions
3. Logical Instructions
4. String manipulation Instructions
5. Process Control Instructions
34
8086 Microprocessor
35
8086 Microprocessor
(reg2) (reg1)
(mem) (reg1)
(reg2) (mem)
(reg) data
(mem) data
(reg2) (reg1)
(mem) (reg1)
36
8086 Microprocessor
(SP) (SP) 2
MA S = (SS) x 1610 + SP
(MA S ; MA S + 1) (reg16)
PUSH mem
(SP) (SP) 2
MA S = (SS) x 1610 + SP
(MA S ; MA S + 1) (mem)
MA S = (SS) x 1610 + SP
(reg16) (MA S ; MA S + 1)
(SP) (SP) + 2
POP mem
MA S = (SS) x 1610 + SP
(mem) (MA S ; MA S + 1)
(SP) (SP) + 2
37
8086 Microprocessor
OUT [DX], A
IN A, [DX]
IN AL, [DX]
PORTaddr = (DX)
(AL) (PORT)
OUT [DX], AL
PORTaddr = (DX)
(PORT) (AL)
IN AX, [DX]
PORTaddr = (DX)
(AX) (PORT)
OUT [DX], AX
PORTaddr = (DX)
(PORT) (AX)
IN A, addr8
OUT addr8, A
IN AL, addr8
(AL) (addr8)
OUT addr8, AL
(addr8) (AL)
IN AX, addr8
(AX) (addr8)
OUT addr8, AX
(addr8) (AX)
38
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
ADD A, data
ADD AL, data8
ADD AX, data16
39
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
ADDC A, data
ADD AL, data8
ADD AX, data16
40
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
SUB A, data
SUB AL, data8
SUB AX, data16
41
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
SBB A, data
SBB AL, data8
SBB AX, data16
42
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
(reg8) (reg8) + 1
INC reg16
(reg16) (reg16) + 1
INC mem
(mem) (mem) + 1
(reg8) (reg8) - 1
DEC reg16
(reg16) (reg16) - 1
DEC mem
(mem) (mem) - 1
43
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
MUL mem
IMUL mem
44
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
DIV mem
45
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
IDIV mem
46
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
47
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
48
8086 Microprocessor
Instruction Set
2. Arithmetic Instructions
Mnemonics: ADD,
CMP A, data
CMP AL, data8
49
8086 Microprocessor
Instruction Set
Mnemonics:
3. Logical Instructions
AND, OR, XOR, TEST, SHR, SHL, RCR, RCL
50
8086 Microprocessor
Instruction Set
Mnemonics:
3. Logical Instructions
AND, OR, XOR, TEST, SHR, SHL, RCR, RCL
51
8086 Microprocessor
Instruction Set
Mnemonics:
3. Logical Instructions
AND, OR, XOR, TEST, SHR, SHL, RCR, RCL
52
8086 Microprocessor
Instruction Set
Mnemonics:
3. Logical Instructions
AND, OR, XOR, TEST, SHR, SHL, RCR, RCL
53
8086 Microprocessor
Instruction Set
Mnemonics:
3. Logical Instructions
AND, OR, XOR, TEST, SHR, SHL, RCR, RCL
54
8086 Microprocessor
Instruction Set
Mnemonics:
3. Logical Instructions
AND, OR, XOR, TEST, SHR, SHL, RCR, RCL
55
8086 Microprocessor
Instruction Set
Mnemonics:
3. Logical Instructions
AND, OR, XOR, TEST, SHR, SHL, RCR, RCL
56
8086 Microprocessor
Instruction Set
Mnemonics:
3. Logical Instructions
AND, OR, XOR, TEST, SHR, SHL, RCR, RCL
57