# OKI semiconductor MSM80C88RS/GS

8-BIT CMOS MICROPROCESSOR

# **GENERAL DESCRIPTION**

The MSM80C88 is a internal 16-bit CPU with 8-bit interface implemented in Sillicon Gate CMOS technology. It is designed with same processing speed as the NMOS8088 but with considerably less power consumption.

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

# FEATURES

- 8-Bit Data Bus Interface
- 16-Bit Internal Architecture
- 1 Mbyte Direct Addressable Memory Space
- Software Compatible with MSM80C86
- 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
- 5 MHz Clock Rate
- Low Power Dissipation (MAX 55 mA)

# FUNCTIONAL BLOCK DIAGRAM



# PIN CONFIGURATION



# ABSOLUTE MAXIMUM RATINGS

| -                    |        | Limits                      |            |      |                     |  |  |
|----------------------|--------|-----------------------------|------------|------|---------------------|--|--|
| Parameter            | Symbol | MSM80C88RS                  | MSM80C88GS | Unit | Conditions          |  |  |
| Power Supply Voltage | Vcc    | -0.5 ~ +7                   |            | v    |                     |  |  |
| Input Voltage        | VIN    | -0.5 ~ V <sub>CC</sub> +0.5 |            | v    | With respect to GND |  |  |
| Output Voltage       | Vout   | -0.5 ~ V <sub>CC</sub> +0.5 |            | V    |                     |  |  |
| Storage Temperature  | Tstg   | <b>65</b> ~ 150             |            | °C   | -                   |  |  |
| Power Dissipation    | ۴D     | 1.0                         | 0.7        | w    | Ta = 25° C          |  |  |

# **OPERATING RANGE**

| Parameter             | Symbol          | Limits   | Unit |
|-----------------------|-----------------|----------|------|
| Power Supply Voltage  | ∨cc             | 3~6      | v    |
| Operating Temperature | т <sub>ОР</sub> | -40 ~ 85 | °C   |

# **RECOMMENDED OPERATING CONDITIONS**

| Parameter             | Symbol   | MIN                  | ТҮР | МАХ                  | Unit |
|-----------------------|----------|----------------------|-----|----------------------|------|
| Power Supply Voltage  | Vcc      | 4.5                  | 5.0 | 5.5                  | v    |
| Operating Temperature | TOP      | -40                  | +25 | +85                  | °C   |
| "L" Input Voltage     | VIL      | -0.5                 |     | +0.8                 | v    |
|                       | (*1)     | V <sub>CC</sub> -0.8 |     | V <sub>CC</sub> +0.5 | v    |
| "H" Input Voltage     | VIH (*2) | 3.0                  | _   | V <sub>CC</sub> +0.5 | v    |
|                       | (*3)     | 2.2                  |     | V <sub>CC</sub> +0.5 | v    |

\*1 Only CLK, \*2 Reset & Ready, \*3 Except CLK, Reset and Ready

# DC CHARACTERISTICS

 $(V_{CC} = 4.5V \text{ to } 5.5V, Ta = -40^{\circ}C \text{ to } +85^{\circ}C)$ 

| Parameter                | Symbol          | MIN                         | ΤΥΡ | MAX  | Unit | Conditions                                                   |
|--------------------------|-----------------|-----------------------------|-----|------|------|--------------------------------------------------------------|
| "L" Output Voltage       | VOL             |                             |     | 0.4  | v    | I <sub>OL</sub> = 2.5mA                                      |
| "H" Output Voltage       | VOH             | 3.0<br>V <sub>CC</sub> -0.4 |     |      | v    | $\frac{I_{OH} = -2.5 \text{ mA}}{I_{OH} = -100 \mu\text{A}}$ |
| Input Leak Current       | ILI.            | -1.0                        |     | +1.0 | μA   | $0 \le V_I \le V_{CC}$                                       |
| Output Leak Current      | ILO             | -10                         |     | +10  | μA   | $0 \le V_O \le V_{CC}$                                       |
| Operating Supply Current | 'cc             |                             |     | 55   | mA   | TCLCL=200NS, Ta≈25°C<br>C <sub>L</sub> = 0pF, at Reset       |
| Input Capacitance        | C <sub>in</sub> |                             |     | 5    | pF   | *4                                                           |
| Output Capacitance       | Cout            |                             |     | 15   | pF   | *4                                                           |
| I/O Capacitance          | CI/O            |                             |     | 20   | pF   | *4                                                           |

\*4.Test Conditions: a) Freq = 1 MHz.

b) Unmeasured Pins at GND.

c) V<sub>in</sub> at 5.0V or GND.

# A.C. CHARACTERISTICS

 $(V_{CC} = 4.5V \text{ to } 5.5V, \text{ Ta} = -40^{\circ}\text{C to } +85^{\circ}\text{C})$ 

## Minimum Mode System

# Timing Requirements

| Parameter                                        | Symbol  | MIN | MAX | Unit |
|--------------------------------------------------|---------|-----|-----|------|
| CLK Cycle Period                                 | TCLCL   | 200 | 500 | NS   |
| CLK Low Time                                     | TCLCH   | 118 |     | NS   |
| CLK High Time                                    | TCHCL   | 65  |     | 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   | 30  |     | NS   |
| Data in Hold Time                                | TCLDX   | 10  |     | NS   |
| RDY Setup Time into MSM 82C84A (See Notes 1, 2)  | TR1VCL  | 35  |     | NS   |
| RDY Hold Time into MSM 82C84A (See Notes 1, 2)   | TCLR1X  | 0   |     | NS   |
| READY Setup Time into MSM 80C88                  | TRYHCH  | 110 |     | NS   |
| READY Hold Time into MSM 80C88                   | TCHRYX  | 30  |     | NS   |
| READY Inactive to CLK (See Note 3)               | TRYLCL  | -8  |     | NS   |
| HOLD Setup Time                                  | тнусн   | 35  |     | NS   |
| INTR, NMI, TEST Setup Time (See Note 2)          | TINVCE  | 30  |     | NS   |
| Input Rise Time (Except CLK) (From 0.8V to 2.2V) | TILIH   |     | 15  | NS   |
| Input Fall Time (Except CLK) (From 2.2V to 0.8V) | TIHIL   |     | 15  | NS   |

## Timing Responses

| Parameter                            | Symbol | MIN       | MAX | Unit |
|--------------------------------------|--------|-----------|-----|------|
| Address Valid Delay                  | TCLAV  | 10        | 110 | NS   |
| Address Hold Time                    | TCLAX  | 10        |     | NS   |
| Address Float Delay                  | TCLAZ  | TCLAX     | 80  | NS   |
| ALE Width                            | TLHLL  | TCLCH-20  |     | NS   |
| ALE Active Delay                     | TCLLH  |           | 80  | NS   |
| ALE Inactive Delay                   | TCHLL  |           | 85  | NS   |
| Address Hold Time to ALE Inactive    | TLLAX  | TCHCL-10  |     | NS   |
| Data Valid Delay                     | TCLDV  | 10        | 110 | NS   |
| Data Hold Time                       | тснох  | 10        |     | NS   |
| Data Hold Time after WR              | TWHDX  | TCLCH-30  |     | NS   |
| Control Active Delay 1               | TCVCTV | 10        | 110 | NS   |
| Control Active Delay 2               | TCHCTV | 10        | 110 | NS   |
| Control Inactive Delay               | TCVCTX | 10        | 110 | NS   |
| Address Float to RD Active           | TAZRL  | 0         |     | NS   |
| RD Active Delay                      | TCLRL  | 10        | 165 | NS   |
| RD Inactive Delay                    | TCLRH  | 10        | 150 | NS   |
| RD Inactive to Next Address Active   | TRHAV  | TCLCL-45  |     | NS   |
| HLDA Valid Delay                     | TCLHAV | 10        | 160 | NS   |
| RD Width                             | TRLRH  | 2TCLCL-75 |     | NS   |
| WR Width                             | TWLWH  | 2TCLCL-60 | ļ   | NS   |
| Address Valid to ALE Low             | TAVAL  | TCLCH-60  |     | NS   |
| Output Rise Time (From 0.8V to 2.2V) | TOLOH  |           | 20  | NS   |
| Output Fall Time (From 2.2V to 0.8V) | TOHOL  |           | 15  | NS   |

NOTES: 1. Signals at MSM 82C84A shown for reference only.

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

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

## Max. mode system (Using MSM 82C88 Bus Controller) Timing Requirement

| Parameter                                                 | Symbol  | MIN | MAX | Unit |
|-----------------------------------------------------------|---------|-----|-----|------|
| CLK Cycle Period                                          | TCLCL   | 200 | 500 | NS   |
| CLK Low Time                                              | TCLCH   | 118 |     | NS   |
| CLK High Time                                             | TCHCL   | 65  |     | 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   | 30  |     | NS   |
| Data in Hold Time                                         | TCLDX   | 10  |     | NS   |
| RDY Setup Time into MSM 82C84A (See Notes 1, 2)           | TRIVCL  | 35  |     | NS   |
| RDY Hold Time into MSM 82C84A (See Notes 1, 2)            | TCLR1X  | 0   |     | NS   |
| READY Setup Time into MSM 80C88                           | TRYHCH  | 110 |     | NS   |
| READY Hold Time into MSM 80C88                            | TCHRYX  | 30  |     | NS   |
| READY Inactive to CLK (See Note 3)                        | TRYLCL  | -8  |     | NS   |
| Setup Time for Recognition (NM1, INTR, TEST) (See Note 2) | TINVCH  | 30  |     | NS   |
| RQ/GT Setup Time                                          | TGVCH   | 30  |     | NS   |
| RQ Hold Time into MSM 80C88                               | TCHGX   | 40  |     | NS   |
| Input Rise Time (Except CLK) (From 0.8V to 2.2V)          | TILIH   |     | 15  | NS   |
| Input Fall Time (Except CLK) (From 2.2V to 0.8V)          | TIHIL   |     | 15  | NS   |

## **Timing Responses**

| Parameter                                     | Symbol | MIN       | MAX | Unit |
|-----------------------------------------------|--------|-----------|-----|------|
| Command Active Delay (See Note 1)             | TCLML  | 5         | 45  | NS   |
| Command Inactive Delay (See Note 1)           | TCLMH  | 5         | 35  | NS   |
| READY Active to Status Passive (See Note 4)   | TRYHSH |           | 110 | NS   |
| Status Active Delay                           | TCHSV  | 10        | 110 | NS   |
| Status Inactive Delay                         | TCLSH  | 10        | 130 | NS   |
| Address Valid Delay                           | TCLAV  | 10        | 110 | NS   |
| Address Hold Time                             | TCLAX  | 10        |     | NS   |
| Address Float Delay                           | TCLAZ  | TCLAX     | 80  | NS   |
| Status Valid to ALE High (See Note 1)         | TSVLH  |           | 35  | - NS |
| Status Valid to MCE High (See Note 1)         | телисн |           | 35  | NS   |
| CLK Low to ALE Valid (See Note 1)             | TCLLH  |           | 35  | NS   |
| CLK Low to MCE High (See Note 1)              | TCLMCH |           | 35  | NS   |
| ALE Inactive Delay (See Note 1)               | TCHLL  | 4         | 35  | NS   |
| MCE Inactive Delay (See Note 1)               | TCLMCL |           | 35  | NS   |
| Data Valid Delay                              | TCLDV  | 10        | 110 | NS   |
| Data Hold Time                                | тснох  | 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        | 165 | NS   |
| RD Inactive Delay                             | TCLRH  | 10        | 150 | NS   |
| <b>RD</b> Inactive to Next Address Active     | TRHAV  | TCLCL-45  |     | NS   |
| Direction Control Active Delay (See Note 1)   | TCHDTL |           | 50  | NS   |
| Direction Control Inactive Delay (See Note 1) | TCHDTH |           | 35  | NS   |
| GT Active Delay                               | TCLGL  | 0         | 85  | NS   |
| GT Inactive Delay                             | TCLGH  | 0         | 85  | NS   |
| RD Width                                      | TRLRH  | 2TCLCL-75 |     | NS   |
| Output Rise Time (From 0.8V to 2.2V)          | TOLOH  |           | 20  | NS   |
| Output Fall Time (From 2.2V to 0.8V)          | TOHOL  | 1         | 15  | NS   |

NOTES: 1. Signal at MSM 82C84A and MSM82C88 shown for reference only.

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

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

4. Applies only to T3 and wait states.

# A.C. TESTING INPUT, OUTPUT WAVEFORM



# A.C. TESTING LOAD CIRCUIT



## TIMING CHART

## Minimum Mode



#### Minimum Mode (Continued)



#### NOTES:

- 1. All signals switch between VOH and VOL unless otherwise specified.
- 2. RDY is sampled near the end of T2, T3, TW to determine if TW machines states are to be inserted.
- Two INTA cycles run back-to-back. The MSM 80C88 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<sub>OH</sub> and V<sub>OL</sub> unless otherwise specified 2. RDY is sampled near the end of 12, 13, 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 80C88 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 (MRDC, MWTC, AMWC, IORC, IOWC, AIOWC, INTA and DENI 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**











#### 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 multiplexed address and data bus. These are address bus at T1 cycle and data bus at 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 address bus of bit 8 thru 15 at all cycles.

These lines do not have to be latch by 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 four most significant address at T1 cycle. Accessing I/O port address, these are low at T1 Cycle.

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

S5 indicate interrupt enable Flag.

S3 and S4 are encoded as shown.

| <b>S</b> 3 | 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 line indicates that CPU is memory or I/O read cycle.

This line is read strobe signal when CPU read data from memory or  $1/O\ device.$ 

This line is active low.

This line is high impedance during hold acknowledge.

## READY

**READY:** Input

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

This line is active high.

If the setup and hold time is out of specification illegal operation will occur.

## INTR

#### INTERRUPT REQUEST: Input

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

It can be internally masked by software.

This signal is active high and internally synchronized.

## TEST

## TEST: Input

This line is examined by "WAIT" instruction. When TEST is high, CPU enter idle cycle. When TEST is low, CPU exit idle cycle.

## NMI

NON MASKABLE INTERRUPT: Input

This line causes type 2 interrupt.

NMI is not maskable.

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

### RESET

RESET: Input

circuit.

This signal causes 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 internal

#### MN/MX

MINIMUM/MAXIMUM: Input

This signal selects CPU's operate mode.

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

When GND is connected. CPU operates maximum mode.

## Vcc

Vcc:

+ 3 - +6 V supplied.

## GND

GROUND:

The following pin function descriptions are 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>52</u> | <u>51</u> | 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               |

# RQ/GTO

# RQ/GT1

REQUEST/GRANT: Input/Output

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

These lines are bidirectional and active low.

## LOCK

LOCK: Output

This line is active low.

When this line is low, other device could not gain control of the bus.

This line is high impedance during hold acknowledge.

## QSO/QS1

QUEUE STATUS: Output

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

| Q\$1     | Q.S0 | Characteristics                     |  |
|----------|------|-------------------------------------|--|
| 0 (LOW)  | 0    | No Operation                        |  |
| 0        | 1    | First Byte of Op Code from<br>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. CPU select memory address space and when it is high. CPU select I/O address space.

This line is high impedance during hold acknowledge.

#### WR

WRITE: Output

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

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

This line is active low.

This line is high impedance during hold acknowledge,

## INTA

INTERRUPT ACKNOWLEDGE: Output

This line is read strobe signal for interrupt acknowledge cycle.

This line is active low.

## ALE

ADDRESS LATCH ENABLE: Output

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

#### DT/R

DATA TRANSMIT/RECEIVE: Output

This line is used for control a direction of bus transceiver.

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

This line is high impedance during hold acknowledge:

#### DEN

DATA ENABLE: Output

This line is used for control an output enable of bus transceiver.

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

## HOLD

HOLD REQUEST: Input

This line is used for Bus Request from other device.

This line is active high.

### HLDA

HOLD ACKNOWLEDGE: Output

This line is used for Bus Grant to other device. This line is active high.

## SSO

STATUS: Output

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

## FUNCTIONAL DESCRIPTION

#### GENERAL OPERATION

The internal function of MSM80C88 consist of Bus Interface Unit (BIU) and Execution Unit (EU). These units operate mutually but perform as separate processor.

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

EU receives pre-fetched instructions from BIU queue, decodes and executes instruction and provided un-relocated operand address to BIU.

#### Memory Organization

#### MEMORY ORGANIZATION

MSM80C88 has 20-bit address to memory. Each address has 8-bit data width. Memory is organized 00000H to FFFFH and is logically divided four segment, code, data, extra data and stack segment. Each segment contain up to 64 Kbytes and locate on 16-byte boundary. (Fig. 3a)

All memory references are made relative to segment register which is according to select rule. Memory location FFFFOH is start address after reset and 00000H through 003FFH are reserved for interrupt pointer, where 256 types interrupt pointer are there.

Each interrupt type has 4-byte pointer element consist of 16-bit segment address and 16-bit offset address.



| Memory Reference Need  | Segment Register Used | Segment Selection Rule Automatic with all instruction prefetch.                                    |  |  |  |  |
|------------------------|-----------------------|----------------------------------------------------------------------------------------------------|--|--|--|--|
| Instructions           | CODE (CS)             |                                                                                                    |  |  |  |  |
| 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<br>using a segment override.                 |  |  |  |  |

#### MINIMUM AND MAXIMUM MODES

MSM80C88 has two system mode: minimum and maximum mode. As using maximum ode, it is easy to organize multi-CPU system with MSM82C88 Bus Controller which general bus control signal generate.

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

## BUS OPERATION

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

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 at read operation. When the device which is accessed by CPU is not ready to data transfer and send to CPU "NOT READY". TW cycles are inserted between T3 and T4.

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

| <u>52</u> | <u>S1</u> | SO | Characteristics        |  |
|-----------|-----------|----|------------------------|--|
| O (LOW)   | 0         | 0  | Interrupt acknowledge  |  |
| 0         | 0         | 1  | Read I/O               |  |
| 0         | 1         | 0  | Write I/O              |  |
| 0         | 1         | 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 bits S3 through S6 are multiplexed with A16-A19, and therefore there 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       | <b>S</b> 3 | 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

MSM80C88 has 64 K byte I/O. When CPU accesses I/O device, address A0-A15 are same format as a memory access, and A16-A19 are low.

I/O ports address are same as memory.

■ CPU · MSM80C88RS/GS ■ -----

**Basic System Timing** 



# EXTERNAL INTERFACE

#### RESET

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

Rising edge of RESET terminate present operation immediately. Falling edge of RESET triggered internal reset sequence for approximately 10 clock cycles. After internal reset sequence is done, normal operation begin from absolute location FFFF0H.

#### INTERRUPT OPERATIONS

Interrupt operation is classified as software or hardware and hardware interrupt is classified as nonmaskable or maskable.

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

#### NON-MASKABLE INTERRUPT (NMI)

MSM80C88 has Non-maskable Interrupt (NM1) which is higher priority than maskable interrupt request (INTR).

NMI request pulse width need minimum 2 clock cycles.NMI will be serviced at the end of the current instruction or between string manipulation.

#### MASKABLE INTERRUPT (INTR)

Interrupt Acknowledge Sequence

MSM80C88 provides an another interrupt request (INTR) which can be masked by software. INTR is level triggered, so it must be hold until interrupt request is acknowledged.

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

#### INTERRUPT ACKNOWLEDGE

During the interrupt acknowledge sequence, further interrupts are disabled. Interrupt enable bit is reset by any interrupt, after Flag register is automatically pushed onto the stack. During acknowledge sequence. CPU emits the lock signal from T2 of first bus cycle to T2 of second bus cycle. At second bus cycle, byte is fetched from external device as a vector which identified the type of interrupt, and this vector is multiplied by four and used as a 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.

#### HALT

When Halt instruction is executed, CPU enter Halt state. Interrupt request or RESET will force the MSM80C88 out of the Halt state.

#### SYSTEM TIMING-MINIMUM MODE

Bus cycle begins T1 with ALE signal. The trailing edge of ALE is used to latch the address. From T1 to T4 the 10/M signal indicates a memory or 1/0 operation. From T2 to T4, the address data bus change address bus to data bus.

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

#### SYSTEM TIMING-MAXIMUM MODE

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



| MUV = Move:                         |   | 2 |     |     | e   | 2 1 | 0 |     | 6 5      | 4        | e  | 2 1 | 0 | 7 | 6 5 | 4         | m         | 2 | - | 0 | 7 6 | 6 5 | 4   | e       | 3 | 1 0 |
|-------------------------------------|---|---|-----|-----|-----|-----|---|-----|----------|----------|----|-----|---|---|-----|-----------|-----------|---|---|---|-----|-----|-----|---------|---|-----|
| Register/memory to/from register    |   | - |     |     | -   | 0   | 3 | mod |          | reg      |    | r/m |   |   |     |           |           |   |   | - |     |     |     |         |   |     |
| Immediate to register/memory        |   | - | 1 0 | 0   | 0   | 1 1 |   |     |          | 0 0      | 0  | r/m |   |   |     | data      | ~         |   |   |   |     |     | dat | data if | S | -   |
| Immediate to register               |   | - |     |     | 3   | rec | - |     |          | data     |    |     |   |   |     | da        | data if w | 3 | ī |   |     |     |     |         |   |     |
| Memory to accumulator               |   | - |     |     |     | 00  |   |     | 10       | addr-low | NO |     |   |   |     | addr-high | -higl     | - |   |   |     |     |     |         |   |     |
| Accumulator to memory               |   | - |     |     |     |     |   |     |          |          | NO |     | - |   |     | addr      | -higl     | 5 |   |   |     |     |     |         |   |     |
| Register/memory to segment register |   | - | 0   | 0   |     |     | 0 |     | о о<br>п |          |    | r/m |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| Segment register to register/memory |   | - | 0   | 0   | -   | -   | 0 | pou |          | reg      | -  | r/m |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| PUSH = Push:                        |   |   |     |     |     |     |   |     |          |          |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| Register/memory                     |   | - |     | -   | -   | 1   | - | pom | -        | -        | 0  | r/m |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| Register                            |   | 0 | 0   | -   | 0   | reg |   |     |          |          |    |     |   |   |     |           |           |   |   | - |     |     |     |         |   |     |
| Segment register                    |   |   | 0   | reg | -   |     | 0 |     |          |          |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| POP = Pop:                          |   |   |     |     |     |     |   |     |          |          |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| Register/memory                     |   | - | 0 ( | 0   | -   |     | - | pom | 0<br>P   | 0        | 0  | r/m |   |   |     |           |           |   |   |   |     |     |     |         | ÷ |     |
| Register                            |   | 0 |     | -   | -   | reg |   |     |          |          |    |     | _ |   |     |           |           |   |   |   |     |     |     |         |   |     |
| Segment register                    |   |   | 0   | reg |     | -   | - |     |          |          |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| XCHG = Exchange:                    |   |   |     |     |     |     |   |     |          |          |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| Register/memory with register       |   | - | 0   | 0   | 0   | 1 1 | 3 | pom | 7        | reg      |    | r/m |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| Register with accumulator           |   | - | 0 0 | -   | 0   | reg |   | -   |          | •        |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| IN = Input from:                    |   |   |     |     |     |     |   |     |          |          |    |     |   |   |     |           |           |   |   |   |     | ×2  |     |         |   |     |
| Fixed port                          |   |   | -   | 0   | 0   | -   | 3 |     |          | port     | ť  |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| Variable port                       |   | - | -   | 0   | -   | 1 0 |   |     |          |          |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| OUT = Output to:                    |   |   |     |     |     |     |   |     |          |          |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| Fixed port                          |   | - | -   | 0   | 0   | -   | 3 |     |          | port     | t  |     | _ |   |     |           |           |   |   |   |     |     |     |         |   |     |
| Variable port                       | _ | - |     | 0   | -   | , L | 3 |     |          |          |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| XLAT = Translate byte to AL         |   | - | 0   | -   | 0   | -   | - |     |          |          |    |     | - |   |     |           |           |   |   |   |     |     |     |         |   |     |
| LEA = Load EA to register           | 1 | - | 0   | 0   | -   | 1   |   |     | Ð        | reg      |    | r/m |   |   |     |           |           |   |   | • |     |     |     |         |   |     |
| LDS = Load pointer to DS            |   | - | 0   | 0   | 0   | 1   |   |     | J        | reg      |    | r/m | - |   |     |           |           |   |   |   |     |     |     |         |   |     |
| LES = Load pointer to ES            |   | - | •   | 0   | 0   |     |   | pom | Ð        | reg      |    | r/m |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| LAHF = Load AH with flags           |   |   | -   |     |     | - · |   |     |          |          |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| SAHF = Store AH into flags          | _ |   | 00  | - • | - , |     |   |     |          |          |    |     |   |   |     |           |           |   |   |   |     |     |     |         |   |     |
| PUSHF = Push flags                  |   | - |     | -   | -   | -   | 0 |     |          |          |    |     |   |   |     |           |           |   |   | - |     |     |     |         |   |     |

| ADD = Add:                                                                                                                                        |         |                                 |         |                |                      |            |                       |                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------------------------|---------|----------------|----------------------|------------|-----------------------|------------------|
| Reg./memory with register to either<br>Immediate to register/memory<br>Immediate to accumulator                                                   | 000     | 000                             | ονσ     | pom w          | reg<br>0 0 0<br>data | ш/л<br>/   | data<br>data if w = 1 | data if s:w = 01 |
| ADC = Add with carry:<br>Reg./memory with register to either<br>Immediate to register/memory<br>Immediate to accumulator                          | 0000    | 100                             | οασ     | pom v v        | reg<br>0 1 0<br>data | E/1        | data<br>data if w = 1 | data if s:w = 01 |
| INC = Increment:<br>Register/memory<br>Register<br>AAA = ASCII adjust for add<br>DAA = Decimal adjust for add                                     | - 0 0 0 | - 0 - 0<br>- 0 0 0<br>          | - 69    | mod<br>T T     | 0<br>0<br>0          | E/1        |                       |                  |
| SUB = subtract:<br>Reg./memory and register to either<br>Immediate from register/memory<br>Immediate from accumulator                             | 0 0 0 0 | - 0 0<br>- 0 0<br>- 0 0         | οασ     | pom v v        | reg<br>1 0 1<br>data | E E / 2    | data<br>data if w = 1 | data if s:w = 01 |
| SBB = Subtract with borrow:<br>Reg./memory and register to either<br>Immediate from register/memory<br>Immediate from accumulator                 | 000     | - 0 0<br>- 0 0<br>- 0 0         | ονα     |                | reg<br>0 1 1<br>data | r/m<br>//  | data<br>data if w = 1 | data if s:w = 01 |
| DEC = Decrement:<br>Register/memory<br>Register<br>NEG = Change sign                                                                              | - 0     | - 0 -<br>0<br>1                 |         | po pour<br>s s | 0 0                  | E/1<br>E/1 |                       |                  |
| CMP = Compare:<br>Register/memory and register<br>Immediate with register/memory<br>Immediate with accumulator<br>AAS = ASCII adjust for subtract | 0000    | 1 0 0 1 1<br>1 0 0 0<br>1 1 0 0 | - 0 v d | por v v v      | reg<br>1 1 1<br>data | ш,'.<br>Г, | data<br>data if w = 1 | data if s:w = 01 |

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

LOGIC

| NOT = Inver+                             | ŀ | -   | -   | C   | -   |        | bom w | 7  |     | -            | r/m |                 |                 |
|------------------------------------------|---|-----|-----|-----|-----|--------|-------|----|-----|--------------|-----|-----------------|-----------------|
|                                          |   | • • |     | ) ( |     |        | _     |    |     |              |     |                 |                 |
| SHL/SAL = Shift logical/arithmetic left  |   |     | 0   | 0   | 0   | >      | w mod | p  | -   | 0            | r/m |                 |                 |
| SHR = Shift logical right                | - | -   | 0   | 0   | 0   | >      | w mod | p  | 0   | -            | r/m |                 |                 |
| SAR = Shift arithmetic right             | - | -   | 0   | 0   | 0   | >      | w mod | P  | -   | -            | r/m |                 |                 |
| ROL = Rotate left                        | - | -   | 0   | •   | 0   | >      | w mod | pq | 0   | 0            | r/m |                 |                 |
| ROR = Rotate right                       |   | -   | 0   | 0   | 0   | >      | w mod | p  | 0   | -            | r/n |                 |                 |
| RCL = Rotate left through carry          | - | -   | 0   | 0   | 0   | >      | w mod | D. | -   | 0            | r/m |                 |                 |
| RCR = Rotate right through carry         | - | -   | 0   | 0   | 0   | >      | w mod | p  | 1   | -            | n/n |                 |                 |
| AND = And:                               |   |     |     |     |     |        | _     |    |     |              |     |                 |                 |
| Rea /memory and register to either       | C | c   | 1   | 0   | c   |        | mod   | τ  |     | Lon          | r/m |                 |                 |
| Immediate to register/memory             |   | 0   | . 0 |     | 0   | 0      |       |    | 0   | 0 0          | r/m | data            | data if w = 1   |
| Immediate to accumulator                 | 0 | 0   | 1 0 | 0   | -   |        |       |    | 0   | data         |     | data if $w = 1$ |                 |
| TEST = And function to flags, no result: |   |     |     |     |     |        | _     |    |     |              |     |                 |                 |
| Register/memory and register             | - | c   | 0   | 0   | -   | 0      | pom w | τ  |     | Lou          | r/m |                 |                 |
| Immediate data and renister/memory       | • | , - |     | ) C | • • |        |       |    | 0   |              |     | data            | data if w = 1   |
| Immediate data and accumulator           |   | - 0 |     |     | - c | - 0    |       |    |     | data<br>data |     | data if w = 1   |                 |
|                                          | - | >   | _   | -   | >   |        | 2     |    |     | 919          |     |                 |                 |
| OR = Or:                                 |   |     |     |     |     |        |       |    |     |              | _   |                 |                 |
| Reg./memory and register to either       | 0 | 0   | 0 0 | -   | 0   |        | w mod | Q  |     | reg          | r/m |                 |                 |
| Immediate to register/memory             | - | 0   |     | 0   | 0   |        | w mod |    | 0 0 | 0 1          | r/m | data            | data if w = 1   |
| Immediate to accumulator                 | 0 | 0   | 0 0 | -   | -   | >      | N     |    | U   | data         |     | data if $w = 1$ |                 |
| XOR = Exclusive or:                      |   |     |     |     |     |        |       |    |     |              |     |                 |                 |
| Reg./memory and register to either       | 0 | 0   | -   | 0   | 0   |        | w mod | Ð  |     | reg          | r/m |                 |                 |
| Immediate to register/memory             | - | 0   | 0   | 0   | 0   | ><br>0 | w mod | p  | -   | 0            | r/m | data            | data if $w = 1$ |
| Immediate to accumulator                 | 0 | 0   | -   | 0   | -   |        | 3     |    | Ð   | data         |     | data if $w = 1$ |                 |
| STRING MANIPULATION                      |   |     |     |     |     |        |       |    |     |              |     |                 |                 |
| REP = Repeat                             | - | -   | -   | 0   | 0   | -      |       |    |     |              |     |                 |                 |
| MOVS = Move byte/word                    | - | 0   | 1   | 0   | -   | 0      | 3     |    |     |              |     |                 |                 |
| CMPS = Compare byte/word                 | - | 0   | 1 0 | 0   | -   | 1      | 3     |    |     |              |     |                 |                 |
| SCAS = Scan byte/word                    | - | 0   | 1   | -   | -   |        | 3     |    |     |              |     |                 |                 |
| LODS = Load byte/word to AL/AX           | - | 0   | -   | -   | -   | 0      | 3     |    |     |              |     |                 |                 |
| STOS = Store byte/word from AL/AX        | - | •   | -   | -   | 0   | -      | 3     |    |     |              |     |                 |                 |

--- • CPU · MSM80C88RS/GS •

r/m × type disp disp disp × × bou 0 00 00 0 0 0 0 0 0 0 0 0 0 × o 0 0 0 0 0 0 C × 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 C 00 0 0 0 0 00000000000 0 0 0 LOOPNZ/LOOPNE = Loop while not zero/equal JB/JNAE = Jump on below/not above or equal JBE/JNA = Jump on below or equal/not above JNB/JAE = Jump on not below/above or equal JNBE/JA = Jump on not below or equal/above JZ/JNGE = Jump on less/not greater or equal JLE/JNG = Jump on less or equal/not greater JNL/JGE = Jump on not less/greater or equal JNLE/JG = Jump on not less or equal/greater JNP/JPO = Jump on not parity/parity odd LOOPZ/LOOPE = Loop while zero/equal JNE/JNZ = Jump on not equal/not zero JP/JPE = Jump on parity/parity even ESC = Escape (to external device) PROCESSOR CONTROL INTO = Interrupt on overflow JNO = Jump on not overflow JE/JZ = Jump on equal/zero JCX2 = Jump on CX zero CMC = Complement carry IRET = Interrupt return CJMP = Conditional JMP JO = Jump on over flow JNS = Jump on not sign LOOP = Loop CX times LOCK = Bus lock prefix CLD = Clear direction CLI = Clear interrupt STD = Set direction STI = Set interrupt JS = Jump on sign CLC = Clear carry INT = Interrupt: STC = Set carry Type specified WAIT = Wait HLT = Halt Type 3

| <b>—</b> |  |
|----------|--|
| ш        |  |
| L        |  |
| S        |  |
| Ž        |  |
|          |  |
| R.       |  |
| Ē        |  |
|          |  |
|          |  |
| _        |  |
| Ы        |  |
|          |  |
| RO       |  |
| ō        |  |
| RO       |  |

| CALL = Call:                        | 7654321076543                   | 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 | 3 2 1 0 7 6 5 4 | 3 2 1 0 |
|-------------------------------------|---------------------------------|---------------------------------|-----------------|---------|
| Direct within segment               | 1 1 1 0 1 0 0 0 disp-lov        | w disp                          | disp-high       |         |
| Indirect within segment             | 1 1 1 1 1 1 1 1 1 1 mod 0 1 0   |                                 |                 |         |
| Direct intersegment                 | 1 0 0 1 1 0 1 0 offset-low      |                                 | offset-high     |         |
|                                     | seg-low                         |                                 | -high           |         |
| Indirect intersegment               | 1 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-lov        |                                 | 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 1 1 1 1 mod 1 0 0 | r/m                             |                 |         |
| Direct intersegment                 | 1 1 1 0 1 0 1 0 offset-low      |                                 | offset-high     |         |
|                                     | seg-low                         |                                 | -high           |         |
| Indirect intersegment               | 1 1 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    | сх      | 001   | CL      | 01 CS   |
| 010    | DX      | 010   | DL      | 10 SS   |
| 011    | вX      | 011   | BL      | 11 DS   |
| 100    | SP      | 100   | АН      |         |
| 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):(TF):(SF):(ZF):X:(AF):X:(PF):X:(CF)