# **OKI** semiconductor

# MSM80C88A-10RS/GS/JS

# 8-BIT CMOS MICROPROCESSOR

# GENERAL DESCRIPTION

The MSM80C88A-10 are internal 16-bit CPUs with 8-bit interface implemented in Silicon Gate CMOS technology. They are designed with the same processing speed as the NMOS8088-1, but with considerably less power consumption.

The processor has attributes of both 8 and 16-bit microprocessor. It is directly compatible with MSM80C86A-10 software and MSM80C85A/MSM80C85A-2 hardware and peripherals.

# **FEATURES**

- 8-Bit Data Bus Interface
- 16-Bit Internal Architecture
- 1 Mbyte Direct Addressable Memory Space
- Software Compatible with MSM80C86A
- Internal 14 Word by 16-bit Register Set
- 24 Operand Addressing Modes

- Bit, Byte, Word and String Operations
- 8 and 16-bit Signed and Unsigned Arithmetic Operation
- From DC to 10 MHz Clock Rate
- Low Power Dissipation (10 mA/MHz)
- Bus Hold Circuitry Eliminates Pull-Up Resistors

# FUNCTIONAL BLOCK DIAGRAM



Preliminary

# PIN CONFIGURATION



# **ABSOLUTE MAXIMUM RATINGS**

|                      |        | Limits             |                             |                    |      |                        |
|----------------------|--------|--------------------|-----------------------------|--------------------|------|------------------------|
| Parameter            | Symbol | MSM80C88A-<br>10RS | MSM80C88A-<br>10GS          | MSM80C88A-<br>10JS | Unit | Conditions             |
| Power Supply Voltage | Vcc    | -0.5 ~ +7          |                             |                    |      |                        |
| Input Voltage        | VIN    |                    | -0.5 ~ V <sub>CC</sub> +0.5 |                    |      | With respect<br>to GND |
| Output Voltage       | VOUT   |                    | -0.5 ~ V <sub>CC</sub> +0.5 |                    |      | 7.0 0.10               |
| Storage Temperature  | Tstg   | -65 ~ +150         |                             |                    | °C   | -                      |
| Power Dissipation    | PD     | 1.0                | 1.0 0.7                     |                    |      | Ta = 25°C              |

# **OPERATING RANGE**

| Parameter             | Symbol          | Limits       | l lais |
|-----------------------|-----------------|--------------|--------|
| r al allietei         | Symbol          | MSM80C88A-10 | Unit   |
| Power Supply Voltage  | v <sub>CC</sub> | 4.75 ~ 5.25  | ٧      |
| Operating Temperature | TOP             | 0 ~ +70      | °c     |

# **RECOMMENDED OPERATING CONDITIONS**

|                       | 0        | MS                   |     |                      |      |
|-----------------------|----------|----------------------|-----|----------------------|------|
| Parameter             | Symbol   | MIN                  | TYP | MAX                  | Unit |
| Power Supply Voltage  | Vcc      | 4.75                 | 5.0 | 5.25                 | V    |
| Operating Temperature | TOP      | 0                    | +25 | +70                  | °c   |
| "L" Input Voltage     | VIL      | -0.5                 |     | +0.8                 | V    |
| "H" Input Voltage     | VIH (*1) | V <sub>CC</sub> -0.8 |     | V <sub>CC</sub> +0.5 | ٧    |
| ri input voitage      | (*2)     | 2.0                  |     | V <sub>CC</sub> +0.5 | V    |

<sup>\*1</sup> Only CLK, \*2 Except CLK

# DC CHARACTERISTICS

(MSM80C88A-10:  $V_{CC} = 4.75$  to 5.25V,  $T_a = 0^{\circ}C$  to  $+70^{\circ}C$ )

| Parameter                                | Symbol            | MIN     | TYP | MAX  | Unit   | Conditions                                              |
|------------------------------------------|-------------------|---------|-----|------|--------|---------------------------------------------------------|
| "L" Output Voltage                       | VOL               | 8       |     | 0.4  | V      | IOL = 2.5 mA                                            |
| "H" Output Voltage                       | Val               | 3.0     |     |      | V      | IOH = -2.5 mA                                           |
| n Output Voltage                         | Voн               | VCC-0.4 |     |      |        | IOH = -100μA                                            |
| Input Leak Current                       | 1LI               | -1.0    |     | +1.0 | μА     | 0 < V1 < VCC                                            |
| Output Leak Current                      | ILO               | -10     |     | +10  | μА     | VO = VCC or GND                                         |
| Input Leakage Current<br>(Bus Hold Low)  | IBHL              | 50      |     | 400  | μΑ     | V <sub>IN</sub> = 0.8V                                  |
| Input Leakage Current<br>(Bus Hold High) | Івнн              | -50     |     | -400 | μА     | VIN = 3.0V                                              |
| Bus Hold Low Overdrive                   | <sup>I</sup> BHLO |         |     | 600  | μΑ     | *5                                                      |
| Bus Hold High Overdrive                  | Івнно             |         |     | -600 | μΑ     | *6                                                      |
| Operating Power Supply Current           | lcc               |         |     | 10   | mA/MHz | V <sub>IL</sub> =GND<br>V <sub>IH</sub> =VCC            |
| StandbySupply<br>Current                 | Iccs              |         |     | 500  | μА     | VIN=VCC or GND<br>Outputs Unloaded<br>CLK=GND or<br>VCC |
| Input Capacitance                        | C <sub>in</sub>   |         |     | 5    | pF     | *7                                                      |
| Output Capacitance                       | Cout              |         |     | _15  | pF     | *7                                                      |
| I/O Capacitance                          | CI/O              |         |     | 20   | pF     | *7                                                      |

<sup>\*3.</sup> Test conditions is to lower VIN to GND and then raise VIN to 0.8V on pins 2-16 and 35-39.

<sup>\*4.</sup> Test condition is to raise V<sub>IN</sub> to V<sub>CC</sub> and then lower V<sub>IN</sub> to 3.0V on pins 2–16, 26–32, and 34–39.

<sup>\*5.</sup> An external driver must source at least IBHLO to switch this node from LOW to HIGH.

<sup>\*6.</sup> An external driver must sink at least IBHHO to switch this node from HIGH to LOW.

<sup>\*7.</sup> Test Conditions: a) Freq = 1 MHz.

b) Ummeasured Pins at GND.

c) VIN at 5.0V or GND.

# A.C. CHARACTERISTICS

(MSM80C88A-10:  $V_{CC} = 4.75V$  to 5.25V,  $Ta = 0^{\circ}C$  to  $70^{\circ}C$ )

# Minimum Mode System

**Timing Requirements** 

| 8                                                   | Sumb at | MSM800 | C88A-10 | 11-11 |
|-----------------------------------------------------|---------|--------|---------|-------|
| Parameter                                           | Symbol  | Min.   | Max.    | Unit  |
| CLK Cycle Period                                    | TCLCL   | 100    | DC      | ns    |
| CLK Low Time                                        | TCLCH   | 46     |         | ns    |
| CLK High Time                                       | TCHCL   | 44     |         | ns    |
| CLK Rise Time (From 1.0V to 3.5V)                   | TCH1CH2 |        | 10      | ns    |
| CLK Fall Time (From 3.5V to 1.0V)                   | TCL2CL1 | •      | 10      | ns    |
| Data in Setup Time                                  | TDVCL   | 20     |         | ns    |
| Data in Hold Time                                   | TCLDX   | 10     |         | ns    |
| RDY Setup Time into MSM 82C84A<br>(See Notes 1, 2)  | TR1VCL  | 35     |         | ns    |
| RDY Hold Time into MSM 82C84A<br>(See Notes 1, 2)   | TCLR1X  | o      |         | ns    |
| READY Setup Time into MSM 80C88A                    | TRYHCH  | 46     |         | ns    |
| READY Hold Time into MSM 80C88A                     | TCHRYX  | 20     |         | ns    |
| READY inactive to CLK (See Note 3)                  | TRYLCL  | -8     |         | ns    |
| HOLD Setup Time                                     | тн∨сн   | 20     |         | ns    |
| INTR, NMI, TEST Setup Time<br>(See Note 2)          | TINVCH  | 15     |         | ns    |
| Input Rise Time (Except CLK)<br>(From 0.8V to 2.0V) | TILIH   |        | 15      | ns    |
| Input Fall Time (Except CLK)<br>(From 2.0V to 0.8V) | TIHIL   |        | 15      | ns    |

# **Timing Responses**

| Parameter                         | Sumbal | MSM800   | MSM80C88A-10 |      |  |
|-----------------------------------|--------|----------|--------------|------|--|
| Parameter                         | Symbol | Min.     | Max.         | Unit |  |
| Address Valid Delay               | TCLAV  | 10       | 60           | ns   |  |
| Address Hold Time                 | TCLAX  | 10       |              | ns   |  |
| Address Float Delay               | TCLAZ  | TCLAX    | 50           | ns   |  |
| ALE Width                         | TLHLL  | TCLCH-10 |              | ns   |  |
| ALE Active Delay                  | TCLLH  |          | 40           | ns   |  |
| ALE Inactive Delay                | TCHLL  |          | 45           | ns   |  |
| Address Hold Time to ALE Inactive | TLLAX  | TCHCL-10 |              | ns   |  |
| Data Valid Delay                  | TCLDV  | 10       | 60           | ns   |  |
| Data Hold Time                    | TCHDX  | 10       |              | ns   |  |
| Data Hold Time after WR           | TWHDX  | TCLCH-25 |              | ns   |  |
| Control Active Delay 1            | TCVCTV | 10       | 55           | ns   |  |
| Control Active Delay 2            | TCHCTV | 10       | 50           | ns   |  |
| Control Inactive Delay            | TCVCTX | 10       | 55           | ns   |  |
| Address Float to RD Active        | TAZRL  | 0        |              | ns   |  |
| RD Acrive Delay                   | TCLRL  | 10       | 70           | ns   |  |

| D                                    | S t    | MSM80C    | Unit |      |
|--------------------------------------|--------|-----------|------|------|
| Parameter                            | Symbol | Min.      | Max. | Unit |
| RD Inactive Delay                    | TCLRH  | 10        | 60   | ns   |
| RD Inactive to Next Address Active   | TRHAV  | TCLCL-35  |      | ns   |
| HLDA Valid Delay                     | TCLHAV | 10        | 60   | ns   |
| RD Width                             | TRLRH  | 2TCLCL-40 |      | ns   |
| WR Width                             | ŢWLWH  | 2TCLCL-35 |      | ns   |
| Address Valid to ALE Low             | TAVAL  | TCLCH-35  |      | ns   |
| Output Rise Time (From 0.8V to 2.0)  | TOLOH  |           | 15   | ns   |
| Output Fall Time (From 2.0V to 0.8V) | TOHOL  |           | 15   | ns   |

Notes: 1. Signals at MSM82C84A shown for reference only.

2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.

3. Applies only to T2 state. (8 ns into T3)

# **Maximum Mode System (Using MSM 82C88 Bus Controller) Timing Requirements**

|                                                            |         | MSM800 | 88A-10 |      |  |
|------------------------------------------------------------|---------|--------|--------|------|--|
| Parameter                                                  | Symbol  | Min.   | Max.   | Unit |  |
| CLK Cycle Period                                           | TCLCL   | 100    | DC     | ns   |  |
| CLK Low Time                                               | TCLCH   | 46     |        | ns   |  |
| CLK High Time                                              | TCHCL   | 44     |        | ns   |  |
| CLK Rise Time (From 1.0V to 3.5V)                          | TCH1CH2 |        | 10     | ns   |  |
| CLK Fall Time (From 3.5V to 1.0V)                          | TCL2CL1 |        | 10     | ns   |  |
| Data in Setup Time                                         | TDVCL   | 15     |        | ns   |  |
| Data in Hold Time                                          | TCLDX   | 10     |        | ns   |  |
| RDY Setup Time into MSM 82C84A<br>(See Notes 1, 2)         | TRIVCL  | 35     |        | ns   |  |
| RDY Hold Time into MSM 82C84A<br>(See Notes 1, 2)          | TCLR1X  | О      |        | ns   |  |
| READY Setup Time into MSM 80C88A                           | TRYHCH  | 46     |        | ns   |  |
| READY Hold Time into MSM 80C88A                            | TCHRYX  | 20     |        | ns   |  |
| READY inactive to CLK (See Note 3)                         | TRYLCL  | -8     |        | ns   |  |
| Set up Time for Recognition (NMI, INTR, TEST) (See Note 2) | TINVCH  | 15     |        | ns   |  |
| RQ/GT Setup Time                                           | TGVCH   | 15     |        | ns   |  |
| RQ Hold Time into MSM 80C88A                               | TCHGX   | 20     |        | ns   |  |
| Input Rise Time (Except CLK) (From 0.8V to 2.0V)           | TILIH   |        | 15     | ns   |  |
| Input Fall Time (Except CLK)<br>(From 2.0V to 0.8V)        | TIHIL   |        | 15     | ns   |  |

# Timing Responses

| Parameter                                     | 0      | MSM800    | 88A-10 | 1      |
|-----------------------------------------------|--------|-----------|--------|--------|
| rarameter                                     | Symbol | Min.      | Max.   | Unit # |
| Command Active Delay (See Note 1)             | TCLML  | 5         | 35     | ns     |
| Command Inactive Delay (See Note 1)           | TCLMH  | 5         | 45     | ns     |
| READY Active to Status Passive (See Note 4)   | TRYHSH |           | 45     | ns     |
| Status Active Delay                           | TCHSV  | 10        | 45     | ns     |
| Status Inactive Delay                         | TCLSH  | 10        | 60     | ns     |
| Address Valid Delay                           | TCLAV  | 10        | 60     | ns     |
| Address Hold Time                             | TCLAX  | 10        |        | ns     |
| Address Float Delay                           | TCLAZ  | TCLAX     | 50     | ns     |
| Status Valid to ALE High (See Note 1)         | TSVLH  |           | 25     | ns     |
| Status Valid to MCE High (See Note 1)         | TSVMCH |           | 30     | ns     |
| CLK low to ALE Valid (See Note 1)             | TCLLH  |           | 25     | ns     |
| CLK Low to MCE High (See Note 1)              | TCLMCH |           | 25     | ns     |
| ALE Inactive Delay (See Note 1)               | TCHLL  | 4         | 25     | ns     |
| Data Valid Delay                              | TCLDV  | 10        | 60     | ns     |
| Data Hold Time                                | TCHDX  | 10        |        | ns     |
| Control Active Delay (See Note 1)             | TCVNV  | 5         | 45     | ns     |
| Control Inactive Delay (See Note 1)           | TCVNX  | 5         | 45     | ns     |
| Address Float to RD Active                    | TAZRL  | 0         |        | ns     |
| RD Active Delay                               | TCLRL  | 10        | 70     | ns     |
| RD Inactive Delay                             | TCLRH  | 10        | 60     | ns     |
| RD Inactive to Next Address Active            | TRHAV  | TCLCL-35  |        | ns     |
| Direction Control Active Delay (See Note 1)   | TCHDTL |           | 50     | ns     |
| Direction Control Inactive Delay (See Note 1) | тснотн |           | 30     | ns     |
| GT Active Delay                               | TCLGL  | 0         | 45     | ns     |
| GT Inactive Delay                             | TCLGH  | 0         | 45     | ns     |
| RD Width                                      | TRLRH  | 2TCLCL-40 |        | ns     |
| Output Rise Time (From 0.8V to 2.0V)          | TOLOH  |           | 15     | ns     |
| Output Fall Time (From 2.0V to 0.8V)          | TOHOL  |           | 15     | ns     |

Notes: 1. Signals at MSM 82C84A or MSM 82C88 are shown for reference only.

2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.

<sup>3.</sup> Applies only to T2 state (8 ns into T3)

<sup>4.</sup> Applies only to T3 and wait states.

# A.C. TESTING INPUT, OUTPUT WAVEFORM

# 2.4 A.C. TESTING: INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC "I" AND 0.4SV FOR A LOGIC "O" TIMING MEASUREMENTS ARE 1.5V FOR BOTH A LOGIC "I" AND "O"

# A.C. TESTING LOAD CIRCUIT



# TIMING CHART

# Minimum Mode



# Minimum Mode (Continued)



# NOTES:

- 1. All signals switch between  $V_{\mbox{OH}}$  and  $V_{\mbox{OL}}$  unless otherwise specified.
- 2. RDY is sampled near the end of T2, T3, TW to determine if TW machines states are to be inserted.
- 3 Two INTA cycles run back-to-back. The MSM80C88A LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control signals shown for second INTA cycle.
- 4. Signals at MSM 82C84A shown for reference only.
- 5. All timing measurements are made at 1.5V unless otherwise noted.

# Maximum Mode



# Maximum Mode (Continued)



# NOTES:

- 1. All signals switch between  $V_{\mbox{OH}}$  and  $V_{\mbox{OL}}$  unless otherwise specified
- 2 RDY is sampled near the end of T2, T3, TW to determine if TW machines states are to be inserted.
- 3 Cascade address is valid between first and second INTA cycle
- 4 Two INTA cycles run back to back The MSM 80C88A LOCAL ADDR/DATA BUS is floating during both INTA cycles Control for pointer address is shown for second INTA cycle
- 5 Signal at MSM 82C84A and MSM82C88 shown for reference only
- 6 The issuance of the MSM 82C88 command and control signals IMRDC, MWTC, AMWC, IORC, IOWC, AIOWC, INTA and DEN) lags the active high MSM 82C88 CEN
- 7. All timing measurements are made at 1.5V unless otherwise noted
- 8 Status inactive in state just prior to T4

# **Asynchronous Signal Recognition**



# **Bus Lock Signal Timing (Maximum Mode Only)**



**Reset Timing** 



# Request/Grant Sequence Timing (Maximum Mode Only)



# Hold/Hold Acknowledge Timing (Minimum Mode Only)



# PIN DESCRIPTION

# AD0-AD7

ADDRESS DATA BUS: Input/Output

These lines are the multiplexed address and data

bus.

These are the address bus at T1 cycle and the data bus at T2. T3. TW and T4 cycle.

T2, T3, TW and T4 cycle.

These lines are high impedance during interrupt acknowledge and hold acknowledge.

### A8-A15

ADDRESS BUS: Output

These lines are the address bus bits 8 thru 15 at all cycles.

These lines do not have to be latched by an ALE signal

These lines are high impedance during interrupt acknowledge and hold acknowledge.

# A16/S3, A17/S4, A18/S5, A19/S6

ADDRESS/STATUS: Output

These are the four most significant address as at the T1, cycle.

Accessing I/O port address, these are low at T1 Cycles.

These lines are Status lines at the T2, T3, TW and T4 Cycle.

S5 indicate interrupt enable Flag.

S3 and S4 are encoded as shown.

| S3 | S4 | Characteristics |  |
|----|----|-----------------|--|
| 0  | 0  | Alternate Data  |  |
| 1  | 0  | Stack           |  |
| 0  | 1  | Code or None    |  |
| 1  | 1  | Data            |  |

These lines are high impedance during hold acknowledge.

# RD

**READ: Output** 

This lines indicates that the CPU is in a memory or I/O read cycle.

This line is the read strobe signal when the CPU reads data from a memory or I/O device.

This line is active low.

This line is high impedance during hold acknowledge.

# READY

READY: Input

This line indicates to the CPU that an addressed memory or I/O device is ready to read or write.

This line is active high.

IF the setup and hold time are outof specification, an illegal operation will occur.

# INTR

INTERRUPT REQUEST: Input

This line is a level triggered interrupt request signal which is sampled during the last clock cycle of instruction and string manipulations.

It can be internally masked by software.

This signal is active high and internally synchronized.

# TEST

TEST: Input

This line is examined by a "WAIT" instruction.
When TEST is high, the CPU enters an idle cycle.
When TEST is low, the CPU exits an idle cycle.

### NM

NON MASKABLE INTERRUPT: Input

This line causes a type 2 interrupt.

NMI is not maskable.

This signal is internally synchronized and needs a 2 clock cycle pulse width.

### RESET

RESET: Input

This signal causes the CPU to initialize immediately. This signal is active high and must be at least four clock cycles.

# CLK

CLOCK: Input

This signal provide the basic timing for an internal circuit.

# MN/MX

MINIMUM/MAXIMUM: Input

This signal selects the CPU's operate mode.

When  $V_{CC}$  is connected, the CPU operates in minimum mode.

When GND is connected, the CPU operates in maximum mode.

# V<sub>C</sub>C

V<sub>CC</sub> +5V supplied.

# GND

GROUND

The following pin function descriptions are for maximum mode only.

Other pin functions are already described.

# SO. S1. S2

STATUS: Output

These lines indicate bus status and they are used by the MSM82C88 Bus Controller to generate all memory and I/O access control signals.

These lines are high impedance during hold acknowledge.

These status lines are encoded as shown.

| <u>\$2</u> | <del>S</del> 1 | SO | Characteristics       |
|------------|----------------|----|-----------------------|
| 0 (LOW)    | 0              | 0  | Interrupt acknowledge |
| 0          | 0              | 1  | Read I/O Port         |
| 0          | 1              | 0  | Write I/O Port        |
| 0          | 1              | 1  | Halt                  |
| 1. (HIGH)  | 0              | 0  | Code Access           |
| 1          | 0              | 1  | Read Memory           |
| 1          | 1              | 0  | Write Memory          |
| 1          | 1              | 1  | Passive               |

# RO/GTO

REQUEST/GRANT: Input/Output

These lines are used for Bus Request from other devices and Bus GRANT to other devices.

These lines are bidirectional and active low.

# LOCK

LOCK: Output

This line is active low.

When this line is low, other devices can not gain control of the bus.

This line is high impedance during hold acknowledge.

# QS0/QS1

QUEUE STATUS: Output

These are Queue Status Lines that indicate internal instruction queue status.

| QS1      | QS0 | Characteristics                  |
|----------|-----|----------------------------------|
| 0 (LOW)  | 0   | No Operation                     |
| 0        | 1   | First Byte of Op Code from Queue |
| 1 (HIGH) | 0   | Empty the Queue                  |
| 1        | 1   | Subsequent Byte from Queue       |

The following pin function descriptions are minimum mode only. Other pin functions are already described.

# IO/M

STATUS: Output

This line selects memory address space or I/O address space.

When this line is low, the CPU selects memory address space and when it is high, the CPU selects I/O address space.

This line is high impedance during hold acknowledge.

# WR

WRITE: Output

This line indicates that the CPU is in a memory or I/O write cycle.

This line is a write strobe signal when the CPU writes data to memory or an I/O device.

This line is active low.

This line is high impedance during hold acknowledge.

# INTA

INTERRUPT ACKNOWLEDGE: Output

This line is a read strobe signal for the interrupt accknowledge cycle.

This line is active low

## ALE

ADDRESS LATCH ENABLE: Output

This line is used for latching an address into the MSM82C12 address latch it is a positive pulse and the trailing edge is used to strobe the address. This line in never floated.

# DT/R

DATA TRANSMIT/RECEIVE: Output

This line is used to control the direction of the bus transceiver.

When this line is high, the CPU transmits data, and when it is low, the CPU receive data.

This line is high impedance during hold acknowledge.

# DEN

DATA ENABLE: Output

This line is used to control the output enable of the bus transceiver

This line is active low. This line is high impedance during hold acknowledge.

# HOLD

HOLD REQUEST: Input

This line is used for a Bus Request from an other device.

This line is active high.

# HLDA

HOLD ACKNOWLEDGE: Output

This line is used for a Bus Grant to an other device.

This line is active high,

# 022

STATUS: Output

This line is logically equivalent to \$\overline{50}\$ in the maximum mode.

# STATIC OPERATION

All MSM80C88A circuitry is of static design. Internal registers, counters and latches are static and require no refresh as with dynamic circuit design. This eliminates the minimum operating frequency restriction placed on other microprocessors. The MSM80C88A can operate from DC to the appropriate upper frequency limit. The processor clock may be stopped in either state (high/low) and held there indefinitely. This type of operation is especially useful for system debug or power critical applications.

The MSM80C88A can be signal stepped using only the CPU clock. This state can be maintained as long as is necessary. Single step clock operation allows simple interface circuitry to provide critical information for bringing up your system.

Static design also allows very low frequency operation (down to DC). In a power critical situation, this can provide extremely low power operation since 80C8BA power dissipation is directly related to operating frequency. As the system frequency is reduced, so is the operating power until, ultimately, at a DC input frequency, the MSM80C8BA power requirement is the standby current (500 µA maximum).

# **FUNCTIONAL DESCRIPTION**

# **GENERAL OPERATION**

The internal function of the MSM80C88A consist of a Bus Interface Unit (BIU) and an Execution Unit (EU). These units operate mutually but perform as separate processors.

The BIU performs instruction fetch and queueing, operand fetch, DATA read and write address relocation and basic bus control. By performing instruction prefetch while waiting for decoding and execution of instruction, the CPU's performance is increased. Up to 4-bytes fo instruction stream can be queued.

EU receives pre-fetched instructions from the BIU queue, decodes and executes instructions and provides an un-relocated operand address to the BIU.

# MEMORY ORGANIZATION

The MSM80C88A has a 20-bit address to memory. Each address has 8-bit data width. Memory is organized 00000H to FFFFFH and is logically divided into four segments: code, data, extra data and stack segment. Each segment contains up to 64 Kbytes and locates on a 16-byte boundary. (Fig. 3a)

All memory references are made relative to a segment register according to a select rule. Memory location FFFF0H is the start address after reset, and 00000H through 003FFH are reserved as an interrupt pointer. There are 256 types of interrupt pointer;

Each interrupt type has a 4-byte pointer element consisting of a 16-bit segment address and a 16-bit offset address,

# Memory Organization



# Reserved Memory Locations



| Memory Reference Need  | Segment Register Used | Segment Selection Rule                                                                             |
|------------------------|-----------------------|----------------------------------------------------------------------------------------------------|
| Instructions           | CODE (CS)             | Automatic with all instruction prefetch.                                                           |
| Stack                  | STACK (SS)            | All stack pushes and pops. Memory references relative to BP base register except data references.  |
| Local Data             | DATA (DS)             | Data references when relative to stack, destination of string operation, or explicitly overridden. |
| External (Global) Data | EXTRA (ES)            | Destination of string operations: Explicitly selected using a segment override.                    |

# MINIMUM AND MAXIMUM MODES

The MSM80C88A has two system modes: minimum and maximum. When using the maximum mode, it is easy to organize a multiple-CPU system with the MSM 82C88 Bus Controller which generates the bus control signal.

When using the minimum mode, it is easy to organize a simple system by generating the bus control signal itself. MN/MX is the mode select pin. Definition of 24–31, 34 pin changes depends on the MN/MX pin.

# **BUS OPERATION**

The MSM80C88A has a time multiplexed address and data bus. If a non-multiplexed bus is desired for the system, it is only needed to add the address latch.

A CPU bus cycle consists of at least four clock cycles: T1, T2, T3 and T4. (Fig. 4)

The address output occurs during T1, and data transfer occurs during T3 and T4. T2 is used for changing the direction of the bus during read operation. When the device which is accessed by the CPU is not ready to data transfer and send to the CPU "NOT READY" is indicated TW cycles are inserted between T3 and T4.

When a bus cycle is not needed, T1 cycles are inserted between the bus cycles for internal execution. At the T1 cycle an ALE signal is output from the CPU or the MSM82C88 depending in MN/MX, at the trailing edge of an ALE, a valid address may be latched. Status bits S0, S1 and S2 are uased, in maximum mode, by the bus controller to recognize the type of bus operation according to the following table.

| <u>\$2</u> | <u>\$1</u> | SO. | Characteristics        |  |
|------------|------------|-----|------------------------|--|
| 0 (LOW)    | 0          | 0   | Interrupt acknowledge  |  |
| 0          | 0          | 1   | Read I/O               |  |
| 0          | 1          | 0   | Write I/O              |  |
| 0          | 1          | -   | Halt                   |  |
| 1 (HIGH)   | 0          | 0   | Instruction Fetch      |  |
| 1          | 0          | 1   | Read Data from Memory  |  |
| 1          | 1          | 0   | Write Data to Memory   |  |
| 1          | 1          | 1   | Passive (no bus cycle) |  |

Status bit S3 through S6 are multiplexed with A16-A19, and therefore they are valid during T2 through T4. S3 and S4 indicate which segment register was selected on the bus cycle, according to the following table.

| S4       | S3 | Characteristics                |
|----------|----|--------------------------------|
| 0 (LOW)  | 0  | Alternate Data (Extra Segment) |
| 0        | 1  | Stack                          |
| 1 (HIGH) | 0  | Code or None                   |
| 1        | 1  | Data                           |

S5 indicates interrupt enable Flag.

# I/O ADDRESSING

The MSM80C88A has a 64 Kbyte I/O. When the CPU accesses an I/O device, address A0-A15 are in same format as a memory access, and A16-A19 are low.

I/O ports address are same as four memory.

# **Basic System Timing**



# **EXTERNAL INTERFACE**

# RESET

CPU initialization is executed by the RESET pin. The MSM80C88A's RESET High signal is required for greater than 4 clock cycles.

The rising edge of RESET terminates the present operation immediately. The falling edge of RESET triggers an internal reset requence for approximately 10 clock cycles. After internal reset sequence is finished, normal operation begins from absolute location FFFF0H.

# INTERRUPT OPERATIONS

The interrupt operation is classified as software or hardware, and hardware interrupt is classified as non-markable or maskable.

An interrupt causes a new program location which is defined by the interrupt pointer table, according to the interrupt type. Absolute location 00000H through 003FFH is reserved for the interrupt pointer table. The interrupt pointer table consists of 256-elements. Each element is 4 bytes in size and corresponds to an 8-bit type number which is sent from an interrupt request device during the interrupt acknowledge cycle.

# NON-MASKABLE INTERRUPT (NMI)

The MSM80C88A has a non-maskable Interrupt (NM1) which is of higher priority than a maskable interrupt request (INTR).

An NM1 request pulse width needs minimum of 2 clock cycles. The NM1 will be serviced at the end of the current instruction or between string manipulations.

# MASKABLE INTERRUPT (INTR)

The MSM80C88A provides another interrupt request (INTR) which can be masked by software. INTR is level triggered, so it must be held until interrupt request is acknowledged.

The INTR will be serviced at the end of the current instruction or between string manipulations.

# INTERRUPT ACKNOWLEDGE

During the interrupt acknowledge sequence, further interrupts are disabled. The interrupt enable bit is reset by any interrupt, after which the Flag register is automatically pushed onto the stack. During an acknowledge sequence, the CPU emits the lock signal from T2 of first bus cycle to T2 of second bus cycle. At the second bus cycle, a byte is fetched from the external device as a vector which identifies the type of interrupt. This vector is multiplied by four and used as an interrupt pointer address (INTR only).

The Interrupt Return (IRET) instruction includes a Flag pop operation which returns the original interrupt enable bit when it restores the Flag.

## HAIT

When a Halt instruction is executed, the CPU enter Halt state. An interrupt request or RESET will force the MSMROCRRA out of the Halt state

# SYSTEM TIMING-MINIMUM MODE

A bus cycle begins at T1 with an ALE signal. The trailing edge of ALE is used to latch the address. From T1 to T4 the  $IO/\overline{M}$  signal indicates a memory or I/O operation. From T2 to T4, the address data bus changes the address bus to the data bus.

The read (RD), write (WR), and interrupt acknowledge (INTA) signals caused the addressed device to enable the data bus. These signals become active at the beginning of T2 and inactive at the beginning of T4.

# SYSTEM TIMING-MAXIMUM MODE

In maximum mode, the MSM82C88 Bus Controller is added to system. The CPU sends status information to the Bus Controller. Bus timing signals are generated by the Bus Controller. Bus timing is almost the same as in minimum mode.





# **BUS HOLD CIRCUITRY**

To avoid high current conditions caused by floating inputs to CMOS devices, and to eliminate the need for pull-up/down resistors, "bus-hold" circuitry has been used on 80C86 pins 2–16, 26–32, and 34–39 (Figures 6a, 6b). These circuits will maintain the last valid logic state if no driving source is present (i.e. an unconnected pin or a driving source which goes to a high impedance state). To overdrive the "bus

hold" circuits, an external driver must be capable of supplying approximately 400  $\mu$ A minimum sink or source current at valid input voltage levels. Since this "bus hold" circuitry is active and not a "resistive" type element, the associated power supply current is negligible and power dissipation is significantly reduced when compared to the use of passive pull-up resistors.



Figure 6a. Bus hold circuitry pin 2-16, 35-39.



Figure 6b. Bus hold circuitry pin 26-32, 34

# DATA TRANSFER

| MOV = Move:                         | 4 3 2 1 0 7 6 5 4 3 2 1       | 0 7 6 5 4 3 2 1 0 7 6 | 6 5 4 3 2 1 |
|-------------------------------------|-------------------------------|-----------------------|-------------|
| Register/memory to/from register    | pom w p 0                     |                       |             |
| Immediate to register/memory        | 1 1 0 0 0 1 1 w mod 0 0 0 r/m | data                  | data if w = |
| Immediate to register               | 1 1 w reg                     | data if w = 1         |             |
| Memory to accumulator               | 1 0 0 0 0 w                   | addr-high             |             |
| Accumulator to memory               | 1 0 0 0 1 w addr-low          | addr-high             |             |
| Register/memory to segment register | 0 1 1 1 0 mod 0 reg           |                       |             |
| Segment register to register/memory | 1 0 0 0 1 1 0 0 mod 0 reg r/m |                       |             |
| PUSH = Push:                        |                               |                       |             |
| Register/memory                     | 1 1 1 1 1 1 1 1 mod 1 1 0 r/m |                       |             |
| Register                            | 0 1 0 1 0 reg                 |                       |             |
| Segment register                    | 0 0 0 reg 1 1 0               | -                     |             |
| POP = Pop:                          |                               |                       |             |
| Register/memory                     | 1 0 0 0 1 1 1 1 mod 0 0 0 r/m |                       |             |
| Register                            | 0 1 0 1 1 reg                 |                       |             |
| Segment register                    | 0 0 0 reg 1 1 1               |                       |             |
| XCHG = Exchange:                    |                               |                       |             |
| Register/memory with register       | 1 0 0 0 0 1 1 w mod reg r/m   |                       | 5           |
| Hegister with accumulator           | -                             |                       |             |
| IN = Input from:                    |                               |                       |             |
| Fixed port                          | 0 1 0                         |                       |             |
| Variable port                       | 1 1 0 1 1 0 %                 |                       |             |
| OUT = Output to:                    |                               |                       |             |
| Fixed port                          | 1 1 1 0 0 1 1 w port          |                       |             |
| Variable port                       | 1 1 1 0 1 1 1 w               |                       |             |
| XLAT = Translate byte to AL         |                               |                       |             |
| LEA = Load EA to register           | reg                           | -                     |             |
| LDS = Load pointer to DS            | reg                           |                       |             |
| LES = Load pointer to ES            | 1 1 0 0 0 1 0 0 mod reg r/m   |                       |             |
| LAHF = Load AH with flags           | 1001                          |                       |             |
| SAHF = Store AH into flags          | 1001110                       |                       |             |
| PUSHF = Push flags                  | 000                           |                       |             |
| POPF = Pop flags                    |                               |                       |             |

# ARITHMETIC

| ADD = Add:                                                                                |                                                                                        |                       |                  |
|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------|------------------|
| Reg./memory with register to either Immediate to register/memory Immediate to accumulator | 0 0 0 0 0 0 d w mod reg r/m<br>1 0 0 0 0 s w mod 0 0 0 r/m<br>0 0 0 0 0 1 0 w data     | data<br>data if w = 1 | data if s:w = 01 |
| ADC = Add with carry:                                                                     |                                                                                        |                       |                  |
| Reg./memory with register to either Immediate to register/memory Immediate to accumulator | 0 0 0 1 0 0 d w mod reg r/m<br>1 0 0 0 0 0 s w mod 0 1 0 r/m<br>0 0 0 1 0 1 0 w        | data<br>data          | data if s:w = 01 |
| INC = Increment:                                                                          | :                                                                                      |                       |                  |
| Register/memory<br>Register<br>AAA = ASCII adjust for add<br>DAA = Decimal adjust for add | 1 1 1 1 1 1 1 1 w mod 0 0 0 r/m<br>0 1 0 0 0 reg<br>0 0 1 1 0 1 1 1<br>0 0 1 0 0 1 1 1 |                       |                  |
| SUB = subtract:                                                                           |                                                                                        |                       |                  |
| Reg./memory and register to either Immediate from register/memory                         | 1 0 0 1 0 1 0 d w mod reg r/m                                                          | i d                   | i e sep          |
| Immediate from accumulator                                                                | 0 w data                                                                               | data if w = 1         |                  |
| SBB = Subtract with borrow:                                                               |                                                                                        |                       |                  |
| Reg./memory and register to either immediate from register/memory                         | 0 0 0 0 1 1 0 d w mod reg r/m                                                          | ă<br>T                | data if s.w = 01 |
| Immediate from accumulator                                                                | 1 1 1 0 w data                                                                         | data if w = 1         |                  |
| DEC = Decrement:                                                                          |                                                                                        |                       |                  |
| Register/memory                                                                           | 1 1 1 1 1 1 1 w mod 0 0 1 r/m                                                          |                       |                  |
| Register<br>NEG = Change sign                                                             | 0 1 0 0 1 reg                                                                          |                       |                  |
| CMP = Compare:                                                                            |                                                                                        |                       |                  |
| Register/memory and register                                                              | 0 0 1 1 1 0 d w mod reg r/m                                                            |                       |                  |
| Immediate with register/memory                                                            | 0 0 0 0 0                                                                              | data                  | data if s:w = 01 |
| Immediate with accumulator                                                                | 0 0 1 1 1 1 0 w data                                                                   | data if w = 1         |                  |
| יאס - אסרון פחוחפון וכן פחסונפני                                                          |                                                                                        |                       |                  |

| DAS = Decimal adjust for subtract | 0 0 1 0 1 1 1 1               |
|-----------------------------------|-------------------------------|
| MUL = Multiply (unsigned)         | 100                           |
| IMUL = Integer multiply (signed)  | 1 1 1 1 0 1 1 w mod 1 0 1 r/m |
| AAM = ASCII adjust for multiply   | 0 0 1                         |
| DIV = Divide (unsigned)           | 1 1 1 1 0 1 1 w mod 1 1 0 r/m |
| IDIV = Integer divide (signed)    |                               |
| AAD = ASCII adjust for divide     | 11010101000010                |
| CBW = Convert byte to word        | 10011000                      |
| CWD = Convert word to double word | 10011001                      |
| × .                               |                               |

# COGIC

| NOT = Invert SHL/SAL = Shift logical/arithmetic left SHR = Shift logical right SAR = Shift arithmetic right ROL = Rotate left ROR = Rotate left RCL = Rotate left through carry RCL = Rotate right through carry |       | -0000000 |        | 0000000 | ->>>>>> | 3333333     | POE E E E E | 00000 | 000-0-             | £ £ £ £ £ £ £ £ |                       |               |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------|--------|---------|---------|-------------|-------------|-------|--------------------|-----------------|-----------------------|---------------|
| AND = And: Reg./memory and register to either Immediate to register/memory Immediate to accumulator                                                                                                              | 0 - 0 | -0+      | 000    | 000     | 0 O G   | 3 3 3       | рош         | -     | reg<br>0 0<br>data | E /2            | data<br>data if w = 1 | data if w = 1 |
| TEST = And function to flags, no result: Register/memory and register Immediate data and register/memory Immediate data and accumulator OR = Or:                                                                 | 0-0   | 0        | 0-0    | 00-     | 0 - 0   | 3 3 3       | pou<br>pou  | 0     | reg<br>0 0<br>data | £ /, 2          | data<br>data if w = 1 | data if w = 1 |
| Reg./memory and register to either Immediate to register/memory Immediate to accumulator XOR = Exclusive or:                                                                                                     | 0 - 0 | 000      | 000    | -0-     | 000     | 3 3 3       | pou E       | 0     | reg<br>0 1<br>data | r/n<br>r/m      | data<br>data if w = 1 | data if w = 1 |
| Reg./memory and register to either Immediate to register/memory Immediate to accumulator STRING MANIPUL ATION                                                                                                    | 0 - 0 | -0-      | -0-    | 000     | 000     | 3 3 3       | рош         | -     | reg<br>1 0<br>data | E /L            | data<br>data if w ≈ 1 | data if w = 1 |
| HEP = Repeat MOVS = Move byte/word CMPS = Compare byte/word SCAS = Scan byte/word LODS = Load byte/word to AL/AX STOS = Store byte/word from AL/AX                                                               |       |          | -00000 | 000     | -00-    | N 3 3 3 3 3 |             |       |                    |                 |                       |               |

| JE/JZ = Jump on equal/zero<br>JZ/JNGE = Jump on less/not greater or equal | -             | 1          | 0   | 0     | _        | die  |     |   |   |     |  |
|---------------------------------------------------------------------------|---------------|------------|-----|-------|----------|------|-----|---|---|-----|--|
| JZ/JNGE = Jump on less/not greater or equal                               | =             |            | ,   | ,     |          |      | 0   | _ |   | -   |  |
| JZ/JNGE = Jump on less/not greater or equal                               |               |            |     |       |          | 1    |     | - |   |     |  |
|                                                                           | <b>5 6</b>    |            |     | o •   |          | dsip |     |   |   |     |  |
| JLE/JNG = Jump on less or equal/not greater                               | <b>O</b>      |            | - ( |       | - ·      | disp |     |   |   |     |  |
| JB/JNAE = Jump on below/not above or equal                                | 0 0           | - ,<br>- , | 0 0 |       | 0 0      | disb |     |   |   |     |  |
| JBE/JNA = Jump on below or equal/not above                                | <b>-</b>      |            | · · |       | <b>-</b> | dsip |     |   |   |     |  |
| JP/JPE = Jump on parity/parity even                                       | <b>&gt;</b> C |            | - 0 | - 0   |          | dsip |     |   |   |     |  |
| JUMP on over 110w                                                         | 0             |            | 5   | ) (   |          | dsip |     |   |   |     |  |
| JS = Jump on sign                                                         | 0             | -          | -   | 0     |          | disp |     |   |   |     |  |
| JNE/JNZ = Jump on not equal/not zero                                      | 0             | -          | 0   | 0     |          | disp |     |   |   |     |  |
| JNL/JGE = Jump on not less/greater or equal                               | 0             | -          | -   | 0 1   |          | disp |     |   |   |     |  |
| JNLE/JG = Jump on not less or equal/greater                               | 0             | -          | -   |       |          | disp |     |   |   |     |  |
| JNB/JAE = Jump on not below/above or equal                                | 0             | -          | 0   | 1 1   |          | disp |     |   |   |     |  |
| JNBE/JA = Jump on not below or equal/above                                | 0             | -          | 0   | -     |          | disp |     |   |   |     |  |
| JNP/JPO = Jump on not parity/parity odd                                   | 0             | -          | -   | 1 1   |          | disp |     | - |   |     |  |
| JNO = Jump on not overflow                                                | 0             | -          | 0   | 0 0   |          | disp |     |   |   | -   |  |
| JNS = Jump on not sign                                                    | 0             | -          | -   | 0 0   |          | disp |     |   |   |     |  |
| LOOP = Loop CX times                                                      | -             | -          | 0   | 0 1 0 | _        | disp |     |   |   |     |  |
| LOOPZ/LOOPE = Loop while zero/equal                                       | -             | -          | 0   | 0 0   |          | disp |     | - | , |     |  |
| LOOPNZ/LOOPNE = Loop while not zero/equal                                 | -             | -          | 0   | 0 0   |          | disp |     |   |   |     |  |
| JCXZ = Jump on CX zero                                                    | -             | -          | 0   | 1     |          | disp |     | · |   |     |  |
|                                                                           |               |            |     |       |          |      |     |   |   |     |  |
| INT = Interrupt:                                                          |               |            |     |       |          |      |     |   |   |     |  |
| Type specified                                                            | -             | 0          | -   | 0 1   |          | type |     |   |   |     |  |
| Type 3                                                                    | -             | 0          | -   | 0 0 1 |          | -    |     | - |   |     |  |
| INTO = Interrupt on overflow                                              | -             | 0          | _   | 1 0   |          |      |     |   |   | .6. |  |
| IRET = Interrupt return                                                   | -             | 0          | -   | -     |          |      |     |   |   |     |  |
| PROCESSOR CONTROL                                                         |               |            |     |       |          |      |     |   |   |     |  |
| CLC = Clear carry                                                         | -1            | -          | 1   | 0     | _        |      |     |   |   | _   |  |
| CMC = Complement carry                                                    | -             | -          | 0   | 0     |          |      |     |   |   |     |  |
| STC = Set carry                                                           | -             | -          | -   | 0 0   |          |      |     |   |   |     |  |
| CLD = Clear direction                                                     | -             |            | _   | 0     | _        |      |     |   |   |     |  |
| STD = Set direction                                                       | -             | -          | -   | - 0   |          |      |     |   |   |     |  |
| CLI = Clear interrupt                                                     | -             | -          | -   | 1 0   |          |      |     |   |   |     |  |
| STI = Set interrupt                                                       | -             | -          | =   | - 1   |          |      |     | - |   |     |  |
| HLT = Halt                                                                | -             | -          | 0   | 0     | _        |      |     |   |   |     |  |
| WAIT = Wait                                                               | -             | 0 0        | -   | 1 1   |          |      |     |   |   |     |  |
| ESC = Escape (to external device)                                         | -             | 0          | -   |       | pom      | ×××  | r/m |   |   |     |  |
| LOCK = Bus lock prefix                                                    | -             | -          | 0   | 0 0   |          |      |     |   |   |     |  |

# CONTROL TRANSFER

| CALL = Call:                        | 7654321076543210              | 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 |
|-------------------------------------|-------------------------------|---------------------------------|
| Direct within segment               | 1 1 1 0 1 0 0 0 disp-low      | 0 disp-low disp-high            |
| Indirect within segment             | 1 1 1 1 1 1 1 1 mod 0 1 0 r/m |                                 |
| Direct intersegment                 | 1 0 0 1 1 0 1 0 offset-low    | offset-high                     |
|                                     | wol-ges                       | seg-high                        |
| Indirect intersegment               | 1 1 1 1 1 1 1 1 mod 0 1 1 r/m |                                 |
| JMP = Unconditional Jump:           |                               |                                 |
| Direct within segment               | 1 1 1 0 1 0 0 1 disp-low      | disp-high                       |
| Direct within segment-short         | 1 1 1 0 1 0 1 1 disp          |                                 |
| Indirect within segment             | 1 1 1 1 1 1 1 mod 1 0 0 r/m   |                                 |
| Direct intersegment                 |                               | offset-high                     |
|                                     | wol-gas                       | seg-high                        |
| Indirect intersegment               | 1 1 1 1 1 1 1 1 mod 1 0 1 r/m |                                 |
| RET = Return from CALL:             |                               |                                 |
| Within segment                      | 1 1 0 0 0 0 1 1               |                                 |
| Within seg. adding immediate to SP  | 1 1 0 0 0 0 1 0 data-low      | data-high                       |
| Intersegment                        | 1 1 0 0 1 0 1 1               |                                 |
| Intersegment adding immediate to SP | 1 1 0 0 1 0 1 0 data-low      | data-high                       |
|                                     |                               |                                 |
|                                     |                               |                                 |

## Footnotes:

```
AL = 8-bit accumulator
```

AX = 18-bit accumulator

CX = Count register

DS = Data segment

ES = Extra segment

Above/below refers to unsigned value

Greater = more positive

Less = less positive (more negative) signed value

If d = 1 then "to" reg: If d = 0 then "from" reg.

If w = 1 then word instruction: If w = 0 then byte instruction

If mod = 11 then r/m is treated as a REG field

If mod = 00 then DISP = 0\*, disp-low and disp-high are absent

If mod = 01 then DISP = disp-low sign-extended to 16-bits, disp-high is absent

If mod = 10 then DISP = disp-high: disp-low

If r/m = 000 then EA = (BX) + (SI) + DISP

If r/m = 001 then EA = (BX) + (DI) + DISP

If r/m = 010 then EA = (BP) + (SI) + DISP

If r/m = 011 then EA = (BP) + (DI) + DISP

If r/m = 100 then EA = (SI) + DISP

If r/m = 101 then EA = (DI) + DISP

If r/m = 110 then EA = (BP) + DISP\*

If r/m = 111 then EA = (BX) + DISP

DISP follows 2nd byte of instruction (before data if required)

\* except if mod = 00 and r/m = 110 then EA-disp-high: disp-low

If s:w = 01 then 16 bits of immediate data form the operand

If s:w = 11 then an immediate data byte is sign extended to form the 16-bit operand

If v = 0 then "count" = 1: If v = 1 then "count" in (CL)

x = don't care

z is used for string primitives for comparison with ZF FLAG

# SEGMENT OVERRIDE PREFIX

001 reg 110

REG is assigned according to the following table:

| 16-Bit | (w = 1) | 8-Bit | (w = 0) | Segment |
|--------|---------|-------|---------|---------|
| 000    | AX      | 000   | AL      | 00 ES   |
| 001    | CX      | 001   | CL      | 01 CS   |
| 010    | DX      | 010   | DL      | 10 SS   |
| 011    | BX      | 011   | BL      | 11 DS   |
| 100    | SP      | 100   | AH      |         |
| 101    | BP      | 101   | СН      |         |
| 110    | SI      | 110   | DH      |         |
| 111    | DI      | 111   | вн      |         |
|        |         |       |         |         |

Instructions which reference the flag register file as a 16-bit object use the symbol FLAGS to represent the file:

FLAGS = x:x:x:x:(OF):(DF):(IF):(IF):(SF):(ZF):X:(AF):X:(PF):X:(CF)