# **OKI** semiconductor MSM82C59A-2RS/GS

PROGRAMMABLE INTERRUPT CONTROLER

# GENERAL DESCRIPTION

The MSM82C59A-2 is a programmable interrupt controller for use in MSM80C85A1A-2 and MSM80C86/88 microcomputer systems.

Based on CMOS silicon gate technology, this device features an extremely low standby current of 100µA (max.) in chip non-selective status. And during interrupt control status, the power consumption is still very low with only 5 mA (max.) being required.

Internally, the MSM82C59A-2 can control priority interrupts up to 8 levels, and can be expanded up to 64 levels by cascade connections of a number of devices.

# **FEATURES**

- Silicon gate CMOS technology for high speed and low power consumption.
- 3 V to 6 V single power supply
- 80C85A system compatibility
- 80C86/88 system compatibility
- 8-level priority interrupt control
- Interrupt levels expandable up to 64 levels

- Programmable interrupt mode
- Maskable interrupt
- Automatically generated CALL code (85 mode)
- TTL compatible
- 28-pin plastic DIP (MSM82C59A-2RS)
- 32-pin plastic flat package (MSM82C59A-2GS)





# **PIN CONNECTIONS**



# ELECTRIC CHARACTERISTICS

# Absolute Maximum Ratings

| D                    | Sumbal | Graditians     | Lin           | Unit          |    |  |
|----------------------|--------|----------------|---------------|---------------|----|--|
| Parameter            | Symbol | Conditions     | MSM82C59A-2RS | MSM82C59A-2GS |    |  |
| Power supply voltage | Vcc    |                | -0.5          | ~ +7          | v  |  |
| Input voltage        | VIN    | Respect to GND | -0.5 ~ V      | v             |    |  |
| Output voltage       | Vout   |                | -0.5 ~ V      | v             |    |  |
| Storage temperature  | Tstg   | _              | -55 ~ +150    |               | °C |  |
| Power dissipation    | PD     | Ta = 25° C     | 0.9 0.7       |               | w  |  |

### **Operating Ranges**

| Parameter             | Symbol | Range     | Unit |
|-----------------------|--------|-----------|------|
| Power supply voltage  | Vcc    | 3 ~6      | v    |
| Operating temperature | Тор    | -40 ~ +85 | °C   |

## **Recommended Operating Conditions**

| Parameter               | Symbol | Max. | Typ. | Min.                 | Unit |
|-------------------------|--------|------|------|----------------------|------|
| Power supply voltage    | Vcc    | 4.5  | 5    | 5.5                  | V    |
| Operating temperature   | Тор    | -40  | +25  | +85                  | °C   |
| "L" level input voltage | VIL    | -0.5 |      | +0.8                 | v    |
| "H" level input voltage | VIH    | 2.2  |      | V <sub>CC</sub> +0.5 | V    |

------ ■ I/O · MSM82C59A-2RS/GS ■

## **DC** Characteristics

| Parameter                              | Symbol          | Condi                                                                                              | Conditions                 |           |                       | Max. | Unit |
|----------------------------------------|-----------------|----------------------------------------------------------------------------------------------------|----------------------------|-----------|-----------------------|------|------|
| "L" level output voltage               | VOL             | I <sub>OL</sub> = 2.5 mA                                                                           |                            |           |                       | 0.4  | v    |
| //////                                 |                 | IOH = -2.5 mA                                                                                      |                            | 3.0       |                       |      | v    |
| "H" level output voltage               | ∨он             | I <sub>OH</sub> = -100 μA                                                                          | ]                          | Vcc - 0.4 | Тур.<br>4<br>4<br>0.1 | ł    |      |
| Input leak current                     | 1               |                                                                                                    | V <sub>CC</sub> =4.5V~5.5∨ | -1        |                       | 1    | μA   |
| IR Input leak current                  | LIR             | 0V≦VIN≦VCC                                                                                         | Ta=-40°C∼+85°C             | -300      |                       | 10   | μA   |
| Output leak current                    | 1LO             | 0V≦VOUT≦VCC                                                                                        |                            | -10       |                       | 10   | μA   |
| Standby power supply current           | Iccs            | CS=V <sub>CC</sub> , IR = V <sub>CC</sub><br>V <sub>1L</sub> =0V, V <sub>IH</sub> =V <sub>CC</sub> |                            |           | 0.1                   | 100  | μА   |
| Average operation power supply current | <sup>I</sup> cc | V <sub>IN</sub> =0V/V <sub>CC</sub><br>C <sub>L</sub> = 0 pF                                       |                            |           |                       | 5    | mA   |

## **AC Characteristics**

 $T_a = -40^{\circ}C \sim +85^{\circ}C, V_{CC} = 5V \pm 10\%$ 

| Parameter                                        | Symbol | Min. | Max. | Unit | TEST | Conditions       |
|--------------------------------------------------|--------|------|------|------|------|------------------|
| Address setup time (to RD)                       | TAHRL  | 10   |      | nS   |      |                  |
| Address hold time (after RD)                     | TRHAX  | 5    | Ĩ    | nS   |      | Read INTA timing |
| RD/INTA pulse width                              | TRLRH  | 160  |      | nS   |      |                  |
| Address setup time (to WR)                       | TAHWL  | 0    |      | nS   |      |                  |
| Address hold time (after WR)                     | TWHAX  | 0    |      | nS   |      |                  |
| WR pulse width                                   | TWLWH  | 190  |      | nS   |      | Write timing     |
| Data setup time (to WR)                          | тоумн  | 160  |      | nS   |      |                  |
| Data hold time (after WR)                        | TWHDX  | 0    |      | nS   |      |                  |
| IR input width (Low)                             | TJLJH  | 100  |      | nS   |      | INTA sequence    |
| CAS input setup time (to INTA) (slave)           | TCVIAL | 40   |      | nS   |      | INTA sequence    |
| End of RD to Next RD<br>End of INTA to Next INTA | TRHRL  | 160  |      | nS   |      |                  |
| End of WR to Next WR                             | TWHWL  | 190  |      | nS   |      | Other timing     |
| End of Command to Next command                   | TCHCL  | 400  |      | nS   |      | ĺ                |
| Data valid following RD/INTA                     | TRLDV  |      | 120  | nS   | 1    |                  |
| Data floating following RD/INTA                  | TRHDZ  | 10   | 85   | nS   | 2    |                  |
| INT output delay time                            | тјнін  |      | 300  | nS   | 1    |                  |
| CAS valid following 1st. INTA (master)           | TIALCV |      | 360  | nS   | - 1  | Delay times      |
| EN active following RD/INTA                      | TRLEL  |      | 100  | nS   | 1    | -                |
| EN inactive following RD/INTA                    | TRHEH  |      | 150  | nS   | 1    |                  |
| Data valid after address                         | TAHDV  |      | 200  | nS   | 1    |                  |
| Data valid after CAS                             | TCVDV  |      | 200  | nS   | 1    | -                |

Note: Timing measured at VL = 0.8 V and VH = 2.2 V for both inputs and outputs.



■ I/O · MSM82C59A-2RS/GS ■ ------

## TIME CHART

## Write Timing



# Read/INTA Timing







# INTA Sequence (85 mode)



# INTA Sequence (86 mode)



# I/O · MSM82C59A-2RS/GS = \_\_\_\_\_\_

| PIN | FUNCTION | DESCRIPTION |
|-----|----------|-------------|
|     |          |             |

| Pin Symbol | Name                                           | Input/output | Function                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|------------------------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D7 ~ D0    | Bidirectional<br>data bus                      | Input/output | This 3-state 8-bit bidirectional data bus is used in reading status register and writing command word by RD/WR signal from the CPU, and also in reading the CALL instruction code by the INTA signal from the CPU.                                                                                                                                                                                                         |
| CS         | Chip select<br>input                           | Input        | Data transfer with the CPU is enabled by RD/WR when this pin is at low level. The data bus (D0 thru D7) is switched to high impedance when the pin is at high level. Note that CS does not effect INTA.                                                                                                                                                                                                                    |
| RD         | Read input                                     | Input        | Data is transferred from the 82C59A to the CPU when this pin is<br>at low level. IRR (Interrupt Request Register), ISR (In-Service<br>Register), IMR (Interrupt Mask Register), or a Poll word is<br>selected by OCW3 and A0.                                                                                                                                                                                              |
| WR         | Write input                                    | Input        | Commands are transferred from the CPU to the 82C59A when this pin is at low level.                                                                                                                                                                                                                                                                                                                                         |
| AO         | Address input                                  | Input        | This pin is used together with the CS, WR, and RD signals to<br>write commands in the command registers, and to select and read<br>status registers. This is normally connected to the least significant<br>bit of the address bus. (A0 for 80C85A, and A1 for 80C86/88).                                                                                                                                                  |
| CAS0 ~ 2   | Cascade address                                | Input/output | These pins are outputs when the 82C59A is used as the master,<br>and inputs when used as a slave, (in cascade mode). These pins are<br>inputs when in single mode.                                                                                                                                                                                                                                                         |
| SP/EN      | Slave program<br>input/enable<br>buffer output | Input/output | This dual function pin is used as an output to enable the data bus<br>buffer in Buffered mode, and as an input for deciding whether<br>the 82C59A is to be master ( $\overline{SP}/\overline{EN} = 1$ ) or a slave ( $\overline{SP}/\overline{EN} = 0$ )<br>during Non-buffered mode.                                                                                                                                      |
| INT        | Interrupt<br>output                            | Output       | When an interrupt request is made to the 82C59A, the INT output is switch to high level, and INT interrupt is sent to the CPU.                                                                                                                                                                                                                                                                                             |
| INTA       | Interrupt<br>acknowledge<br>input              | Input        | When this pin is at low level, the CALL instruction code or the interrupt vector data is enabled onto the data bus. When the CPU acknowledge the INT Interrupt, INTA is sent to 82C59A. (Interrupt acknowledge sequence).                                                                                                                                                                                                  |
| IR0~7      | Interrupt<br>request input                     | Input        | These interrupt request input pins for 82C59A can be set to edge<br>trigger mode or level trigger mode (by ICW1). In edge trigger<br>mode, interrupt request is executed by the rising edge of the IR<br>input and holding it until that input is acknowledged by the CPU.<br>In level trigger mode, interrupt requests are executed by high leve<br>IR inputs and holding it until that input is acknowledged by the CPU. |

.

# SYSTEM INTERFACE



# BASIC OPERATION DESCRIPTION

Data transfers between the 82C59A internal registers and the data bus are listed below.

| A0 | D4 | D3 | RD | WR | CS | Function                                       | Operation |
|----|----|----|----|----|----|------------------------------------------------|-----------|
| 0  | ×  | ×  | 0  | 1  | 0  | IRR, ISR, or Poll word → Data bus              | Read      |
| 1  | x  | x  | 0  | 1  | 0  | IMR → Data bus                                 | Read      |
| 0  | 0  | 0  | 1  | 0  | 0  | Data bus → OCW2                                | Write     |
| 0  | 0  | 1  | 1  | 0  | 0  | Data bus → OCW3                                | Write     |
| 0  | 1  | x  | 1  | 0  | 0  | Data bus → ICWI                                | Write     |
| 1  | ×  | x  | 1  | 0  | 0  | Data bus → OCW1, ICW2, ICW3, ICW4              | Write     |
| ×  | ×  | x  | 1  | 1  | 0  |                                                |           |
| x  | x  | x  | x  | x  | 1  | Data bus set to high impedance (when INTA = 1) |           |
| x  | x  | x  | 0  | 0  | x  | Combinations prohibited                        | -         |

## **OPERATION DESCRIPTION**

The 82C59A device has been designed for real time interrupt driven microcomputer systems. The 82C59A is capable of handling up to 8 levels of interrupt requests, and can be expanded to cover a maximum of 64 levels when connected to other 82C59A devices.

Programming involves the use of system software in the same way as other microcomputer peripheral I/O

| (1) | Functional | Description | of Each | Block |
|-----|------------|-------------|---------|-------|
|-----|------------|-------------|---------|-------|

devices. Selection of priority mode involves program execution, and enables the method of requesting interrupts to be processed by the 82C59A to be suitably configured for system requirements. That is, the priority mode can be dynamically updated or reconfigured during the main program at any time. A complete interrupt structure can be defined as required, based on the entire system environment.

| Block name                | Description of function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRR, ISR                  | IR input line interrupts are processed by a cascaded interrupt request register (IRR) and the in-service register (ISR). The IRR stores all request levels where interrupt service is requested, and the ISR stores all interrupt levels being serviced.                                                                                                                                                                                                                                                              |
| Priority resolver         | This logic block determines the priority level of the bits set in the IRR. The highest priority level is selected, and the corresponding ISR bit is set during INTA pulses.                                                                                                                                                                                                                                                                                                                                           |
| Read/write logic          | This block is capable of receiving commands from the CPU. These command words (ICW) and the operation command words (OCW) which store the various control formats for 82C59A operations. This block is also used to transfer the status of 82C59A to the Data Bus.                                                                                                                                                                                                                                                    |
| Cascade buffer comparator | This functional block is involved in the output and comparison of all 82C59A<br>IDs used in the system. These three I/O pins (CASO thru CAS2) are outputs<br>when the 82C59A operates as a master, and inputs when it operates as a slave.<br>When operating as a master, the 82C59A sends a slave ID output to the slave<br>where an interrupt has been applied.<br>Furthermore, the selected slave sends the preprogrammed subroutine address<br>onto the data bus during next one or two INTA pulses from the CPU. |

#### (2) Interrupt Sequence

The major features of the 82C59A device used in microcomputer systems are the programmability and the addressing capability of interrupt routines. This latter feature enables direct or indirect jumping to specific interrupt routines without polling the interrupt devices. The operational sequence during an interrupt varies for different CPUs.

The procedure for the 85 system (8085A/80C85A) is outlined below.

- (i) One or more interrupt requests (IR0 thru IR7) becomes high, and the corresponding IRR bit is set.
- (ii) The 82C59A evaluates these requests, and sends an INT signal to the CPU if the request is judged to be suitable.
- (iii) The CPU issues an INTA output pulse upon reception of the INT signal.
- (iv) Upon reception of the INTA signal from the CPU, the ISR bit with the highest priority is set, and the corresponding IRR bit is reset. The 82C59A then release the CALL instruction code (11001101) to the 8-bit data bus.
- (v) A further two INTA pulses are then sent to the 82C59A from the CPU by this CALL instruction.

- (vi) These two INTA pulses result in a preprogrammed subroutine address being sent from the 82C59A to the data bus. The lower 8bit address is released by the first INTA pulse, and the higher 8-bit address is released by the second pulse.
- (vii) 3-byte CALL instructions are thus released by the 82C59A. In Automatic End Of Interrupt (AEOI) mode, the ISR bit is reset at the end of the third INTA pulse. In other cases, the ISR bit remains set until reception of a suitable EOI command at the end of the interrupt routine.

The procedure for the 86 system (80C86/88) is identical to the first three steps of the 85 system. The subsequent steps are described below.

- (iv) Upon reception of the INTA signal from the CPU, the ISR bit with the highest priority is set, and the corresponding IRR bit is reset. In this cycle, the 82C59A sets the data bus to high impedance without driving the Data Bus.
- (v) The CPU generates a second INTA output pulse, resulting in an 8-bit pointer to the data bus by the 82C59A.
- (vi) This completes the interrupt cycle. In AEOI mode, the ISR bit is reset at the end of the second INTA pulse. In other cases, the ISR

## I/O · MSM82C59A-2RS/GS =

bit remains set until reception of a suitable EOI command at the end of the interrupt routine.

If the interrupt request is cancelled prior to step (iv), that is, before the first  $\overline{INTA}$  pulse has been received, the 82C59A operates as if a level 7 interrupt has been received, and the vector byte and CAS line operate as if a level 7 interrupt has been requested.

## (3) Interrupt Sequence Output 85 Mode (80C85A)

CA

The sequence in this case consists of three INTA pulses. A CALL operation code is released to the data bus by the first INTA pulse.

Content of the first interrupt vector byte

|         | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO |
|---------|----|----|----|----|----|----|----|----|
| LL code | 1  | 1  | 0  | 0  | 1  | 1  | 0  | 1  |

The lower address of the interrupt service routine is released to the data bus by the second INTA pulse. If  $A5 \sim A7$  is programmed with an address interval of 4,  $A0 \sim A4$ , is automatically inserted. And if A6 and A7 are programmed at an address interval of 8,  $A0 \sim A5$  is automatically inserted.

Contents of the second interrupt vector byte

| IR |    | Interval = 4 |    |    |    |    |    |    |  |  |
|----|----|--------------|----|----|----|----|----|----|--|--|
|    | D7 | D6           | D5 | D4 | D3 | D2 | D1 | D0 |  |  |
| 7  | A7 | A6           | A5 | 1  | 1  | 1  | 0  | 0  |  |  |
| 6  | A7 | A6           | A5 | 1  | 1  | 0  | 0  | 0  |  |  |
| 5  | A7 | A6           | A5 | 1  | 0  | 1  | 0  | 0  |  |  |
| 4  | A7 | A6           | A5 | 1  | 0  | 0  | 0  | 0  |  |  |
| 3  | A7 | A6           | A5 | 0  | 1  | 1  | 0  | 0  |  |  |
| 2  | A7 | A6           | A5 | 0  | 1  | 0  | 0  | 0  |  |  |
| 1  | A7 | A6           | A5 | 0  | 0  | 1  | 0  | 0  |  |  |
| 0  | A7 | A6           | A5 | 0  | 0  | 0  | 0  | 0  |  |  |

| IR | Interval = 8 |    |    |    |    |    |    |    |  |
|----|--------------|----|----|----|----|----|----|----|--|
|    | D7           | D6 | D5 | D4 | D3 | D2 | D1 | DO |  |
| 7  | A7           | A6 | 1  | 1  | 1  | 0  | 0  | 0  |  |
| 6  | Α7           | A6 | 1  | 1  | 0  | 0  | 0  | 0  |  |
| 5  | A7           | A6 | 1  | 0  | 1  | 0  | 0  | 0  |  |
| 4  | A7           | A6 | 1  | 0  | 0  | 0  | 0  | 0  |  |
| 3  | A7           | A6 | 0  | 1  | 1  | 0  | 0  | 0  |  |
| 2  | A7           | A6 | 0  | 1  | 0  | 0  | 0  | 0  |  |
| 1  | A7           | A6 | 0  | 0  | 1  | 0  | 0  | 0  |  |
| 0  | A7           | A6 | 0  | 0  | 0  | 0  | 0  | 0  |  |

The higher address of the interrupt service routine programmed by the second byte (A8  $\sim$  A15) of the initialization sequence is released to the data bus.

Content of the third interrupt vector byte

| D7  | D6  | D5  | D4  | D3  | D2  | D1 | DO |
|-----|-----|-----|-----|-----|-----|----|----|
| A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |

#### 86 Mode (80C86/88)

Apart from the two interrupt acknowledge cycles and the absence of a CALL operation code, the 86 mode is the same as the 85 mode. The first INTA cycle freezes interrupt status to resolve the priority internally in the same way as in 85 mode. When the device is used as a master, an interrupt code is issued to the cascade line at the end of the INTA pulse. During this first cycle, the data bus buffer is kept at high impedance without any data to the CPU. During the second INTA cycle, the 82C59A sends a byte of interrupt code to the CPU. Note that in 86 mode, the Address Interval (ADI) control status is ignored and A5 ~ A10 is not used.

|     | D7         | D6 | D5 | D4         | D3 | D2 | D1 | D0 |
|-----|------------|----|----|------------|----|----|----|----|
| IR7 | т7         | т6 | Т5 | Т4         | тз | 1  | 1  | 1  |
| IR6 | т7         | т6 | т5 | Т4         | тз | 1  | 1  | 0  |
| IR5 | <b>T</b> 7 | т6 | т5 | Т4         | тз | 1  | 0  | 1  |
| IR4 | T7         | т6 | т5 | Т4         | тз | 1  | 0  | 0  |
| IR3 | т7         | т6 | Т5 | Т4         | тз | 0  | 1  | 1  |
| IR2 | т7         | т6 | Т5 | Т4         | тз | 0  | 1  | 0  |
| IR1 | т7         | Т6 | Т5 | Т4         | тз | 0  | 0  | 1  |
| IR0 | т7         | т6 | Т5 | <b>T</b> 4 | тз | 0  | 0  | 0  |

Contents of interrupt vector byte in 86 system mode

#### (4) Programming 82C59A

The 82C59A receives two types of command words generated by the CPU.

(i) Initialization Command Words (ICW1 thru ICW4)

Before commencing normal operations, each 82C59A in the system must be initialized by two to four  $\overline{WR}$  pulse sequence.



(ii) Operation Command Words (OCW1 thru OCW3)

These commands are used in operating the 82C59A in the following modes.

- a. Fully Nested Mode
- b. Rotating Priority Mode
- c. Special Mask Mode
- d. Polled Mode

The OCW can be written into the 82C59A any time after initialization has been completed.

#### (5) Initialization Command Words (ICW1 thru ICW4)

When a command is issued with D4 = 1 and A0 = 0, it is always regarded as Initialization Command Word 1 (ICW1). Starting of the initialization sequence by ICW1 results in automatic execution of the following steps.

- The edge sense circuit is reset, and an low to high transition is necessary to generate an interrupt.
- b. The interrupt mask register is cleared.
- c. The IR7 input is assigned priority 7 (lowest priority)
- d. Slave mode address is set to 7.
- e. The Special<sup>a</sup> Mask Mode is cleared, and the Status Read is set to IRR.
- f. All ICW4 functions are cleared if IC4 = 0, resulting in change to Non-Buffered mode, no-Auto EOI, and 85 mode.
- Note: Master/slave in ICW4 can only be used in buffered mode.
- (i) litialization Command Words 1 and 2 (ICW1 and ICW2)
  - A4 thru (Starting address of interrupt A15: service routines)

In 85 mode, 8 request levels CALL 8 locations at equivalent intervals in the memory. The memory location interval can be set at this stage to 4 or 8 by program. (→ ADI) Hence, either 32 or 64 bytes/page respectively is used in the 8 routines. The address format is 2 bytes long (A0 thru A15). When the routine interval is 4. A0 thru A4 is inserted automatically by the 82C59A, and A5 thru A15 is programmed externally. When the interval is 8, on the other hand, A0 thru A5 are inserted automatically by the 82C59A, and A6 thru A15 are programmed externally. In 86 mode, T3 thru T7 are inserted in the 5 most significant bits of the vector type, and the 82C59A sets the 3 least significant bits according to the interrupt level. A0 thru A10 are ignored, and the ADI (address interval) has no effect.

- LTIM: The 82C59A is operated in level triggered mode when LTIM = 1, and the interrupt input edge circuit becomes disable.
- ADI: Designation of the CALL address interval. Interval = 4 when ADI = 1, and interval = 8 when ADI = 0.
- SNGL: SNGL = 1 indicates the existence of only one 82C59A in the system. ICW3 is not required when SNGL = 1.
- IC4: ICW4 is required when this bit is set, but not required when IC4 = 0.
- (ii) Initialization Command Word 3 (ICW3) This command word is written when there is more than one 82C59A used in cascade connections in the system, and is loaded into an 8-bit slave register. The functions of this slave register are listed below.
  - a. In a master mode system (BUF = 1 and M/ S = 1 in ICW4 or SP/EN = 1). "1" is set in each bits where a slave has been connected. In 85 mode, the master 82C59A release byte 1 of the CALL sequence to enable the corresponding slave to release byte 2 or 3 (only byte 2 in 86 mode) through cascade line.

- b. In slave mode (BUF = 1 and M/S = 0 in ICW4 or  $\overline{SP/EN}$  = 0). Bits 0 thru 2 identify the slave. The slave compares these bits with the cascade input, and release bytes 2 and 3 of CALL sequence (only byte 2 in 86 mode) if a matching result is obtained.
- (iii) Initialization Command Word 4 (ICW4)
  - SFNM: Special Fully Nested Mode is programmed when SFNM = 1.
  - BUF: Buffered mode is programmed when BUF = 1. In Buffered mode, SP/EN is an output, and Master/ slave is selected by the M/S bit.
  - M/S: If Buffered mode is Selected. The 82C59A is programmed as the master when M/S = 1, and as a slave when M/S = 0. M/S is ignored, however, when BUF = 0.
  - AEOI: Automatic End Of Interrupt mode is programmed by AEOI = 1.
  - μPM: (Microprocessor mode) The 82C59A is set to 85 system operation when μPM = 0, and to 86 system operation when μ PM = 1.

I/O MSM82C59A-2RS/GS = -



#### (6) Operation Command Words (OCW1 thru OCW3)

When Initialization Command Words (ICW) are programmed in the 82C59A, the interrupt input line is ready to receive interrupt requests. The Operation Command Words (OCWs) enable the 82C59A to be operated in various modes while the device is in operation.

- (i) Operation Command Word 1 (OCW1)
  OCW1 sets and resets the mask bits of Interrupt Mask Register (IMR) M0 thru M7 represent 8 mask bits. The channel is masked when M = 1, but is enabled when M = 0.
- (ii) Operation Command Word 2 (OCW2)
  - R, SL, The Priority Rotation and the End EOI: of Interrupt mode plus combinations of the two are controlled by combinations of these 3 bits. These

combinations are listed in the operation command word format table.

- L2, L1, These bits indicate the specified
- LO: interrupt level when SL = 1.
- (iii) Operation Command Word 3 (OCW3)
  - ESMM: This enables the Special Mask Mode. The special mask mode can be set and reset by the SMM bit when ESMM = 1. The SMM bit is ignored when ESMM = 0.
  - SMM: (Special Mask Mode) The 82C59A is set to Special Mask Mode when ESMM = 1 and SMM = 1, and is returned to normal mask mode when ESMM = 1 and SMM = 0. SMM is ignored when ESMM = 0.



## I/O · MSM82C59A-2RS/GS = -

#### (7) Fully Nested Mode

As long as the 82C59A has not been programmed to another mode, this Fully Nested mode is set automatically after initialization. The interrupt requests are ordered in priority sequentially from 0 to 7 (where 0 represents highest priority). If an interrupt is then requested and is acknowledged highest priority, a corresponding vector address is released, and the corresponding bit in the in-service register (ISR) is set. The IS bit remains set until an End of Interrupt (EOI) command is issued from the microprocessor before returning from the interrupt service routine, or until the rising edge of the last INTA pulse arrives when the AEOI bit has been set.

When the IS bit is set, interrupts of the same or lower priority are inhibited - only interrupts of higher priority can be generated. In this case, interrupts can be ackowledged only when the internal interrupt enable F/F in the microprocessor has been enabled again through software. Following the initialization sequence, IRO has the highest priority, and IR7 has the lowest. This priority can be changed by rotating priority mode in OCW2.

#### (8) End of Interrupt (EOI)

When the AEOI bit in ICW4 is set, the in-service (IS) bit is automatically reset by the rising edge of the last INTA pulse, or else is reset only when an EOI command is issued to the 82C59A prior to returning from the interrupt service routine.

And in cascade mode, the EOI command must be issued twice - once for the master, and once for the corresponding slave.

EOI commands are classified into specific EOI command and Non-Specific EOI command. When the 82C59A is operated in Fully Nested mode, the IS bit to be reset can be determined on EOI. If the Non-Specific EOI command is issued, the highest IS bit of those that are set is reset automatically, because the highest IS level is always the last servicing level in Fully Nested mode. If, however, it is not in the Fully Nested mode, the 82C59A will no longer be able to determine the last acknowledged level. In this case, it will be necessary to issue a Specific EOI which includes the IS level to be reset as part of the command. When the 82C59A is in Special Mask mode, care must be taken to ensure that IS bits masked by the IMR bit can not reset by the Non-Specific EOI.

#### (9) Automatic End of Interrupt (AEOI) Mode

When AEOI = 1 in ICW4, the 82C59A continues to operate in AEOI mode until programmed again by ICW4. In this mode, the 82C59A automatically performs Non-Specific EOI operation at the rising edge of the last INTA pulse (the third pulse in 85 systems, and the second pulse in 86 systems). In terms of systems, this mode is best used in nested multiple level interrupt configurations. It is not necessary in when there is only one 82C59A. AEOI mode is only used in a master 82C59A device, not in a slave.

#### (10) Automatic Rotation (Devices with Equal Priority)

In some applications, there is often a number of devices with equal priority. In this mode, the device where an interrupt service has just been completed is set to the lowest priority. At worst, therefore, a particular interrupt request device may have to wait for seven other devices to be serviced at least once each. There are two methods for Automatic Rotation using OCW2 - Rotation on Non-Specific EOI command, and Rotation in Automatic EOI mode.

Before Rotation (IR4 the highest priority requesting service)



After Rotation (IR4 was serviced, all other priorities rotated correspondingly)



#### (11) Specific Rotation (Specific Priority)

All priority levels can be changed by programming the lowest priority level (Set Priority Command in OCW2). For example, if IR5 is programmed as the device of lowest priority, IR6 will have the highest priority. In this mode, the internal status can be updated during OCW2 by software control. This is unrelated, however, to the EOI command in the same OCW2.

Priority level can also be changed by using the OCW2 Rotate On Specific EOI command.

#### (12) Interrupt Mask

Interrupt inputs can be masked individually by Interrupt Mask Registers (IMR) programmed through the OCW1. Each interrupt channel is masked (disabled) when the respective IMR bit is set to "1"... IRO is masked by bit 0, and IR1 is masked by bit 1. Masking of any particular channel has no effect on other channels.

#### (13) Special Mask Mode

In some applications, there is a need for dynamic updating of the system's priority level structure by software control during execution of an interrupt service routine. For example, it may be necessary to inhibit the lower priority requests for part of the execution of a certain routine while enabling for another parts. In this kind of case, it is difficult to enable all lower priority requests if the IS bit has not yet been reset by the EOI command after an interrupt request has been acknowledged (during execution of a service routine). All of these requests would normally be disabled.

Hence the use of the Special Mask mode. When a mask bit is set by OCW1 in this mode, the corresponding interrupt level requests are disabled. And all other unmasked level requests (at both higher and lower priority levels) are enable. Interrupts can thus be enable selectively by loading the mask register.

In this mode, the specific EOI Command should be used.

This Special Mask mode is set by OCW3 ESMM = 1 and SMM = 1, and reset by ESMM = 1 and SMM = 0.

#### (14) POLL Command

In this mode, the INT output in not used, and the internal interrupt enable F/F of the microprocessor is reset, and interrupt inputs are disabled. Servicing I/O device is executed by software using the Poll command.

The Poll command is issued by setting P in OCW3 to "1". The 82C59A regards the next  $\overline{RD}$  pulse as reception of an interrupt, and if there is a request, the corresponding IS bit is set and the priority level is read out. Interrupts are frozen between WR and RD.

|           | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|-----------|----|----|----|----|----|----|----|----|
| Poll word | 1  | 0  | 0  | 0  | 0  | W2 | W1 | WO |

W0 thru W2: Binary coded highest priority level of service being requested.

1: Set to "1" when there is an interrupt.

This mode is useful when there is a common routine for a number of levels, and the INTA sequence is not required. ROM space can thus be saved.

#### (15) Reading 82C59A Status

The status of a number of internal registers can be read out for updating user information on the system. The following registers can be read by means of OCW3 (IRR and ISR) and OCW1 (IMR).

- a. IRR: (Interrupt Request Register) 8-bit register for storing interrupt requesting levels.
- b. ISR: (In-Service Register) 8-bit register for storing priority levels being serviced.

 IMR: (Interrupt Mask Register) 8-bit register for storing interrupt request lines to be masked.

The IRR can be read when a Read Register Command is issued with OCW3 (RR = 1 and RIS = 0) prior to the  $\overline{RD}$  pulse, and the ISR can be read when a Read Register Command is issued with OCW3 (RR = 1 and RIS = 1) prior to the  $\overline{RD}$  pulse. And as long as the read status does not change, OCW3 is not required each time before the status is read. This is because the 82C59A remembers whether IRR or ISR was selected by the previous OCW3. But this is not true when poll is used.

The 82C59A is set to IRR after initialization. OCW3 is not required to read IMR. IMR is issued to the data bus if  $\overline{RD}$  = 0 and A0 = 1 (OCW1).

Reading status is disabled by polling when P = 1 and RR = 1 in OCW3.

#### (16) Edge and Level Trigger Mode

This mode is programmed by using bit 3 (LTIM) in ICW1. When LTIM = 0, the interrupt request is recognized by the IR input transition from Low to High. And as long as the IR input is kept at High, no other interrupt is generated. Since interrupt requests are recognized by the IR input 'H' level when LTIM = 1, edge detection is not required. The interrupt request must be cancelled before output of the EOI command, and before the interrupt is enabled in order to prevent the generation of a second interrupt by the CPU.

The IR input must be held at High level until the falling edge of the first INTA pulse, irrespective of whether edge sense or level sense is employed. If the IR input is switched to Low level before the first INTA pulse, the default IR7 is generated when the interrupt is acknowledged by the CPU. This can be an effective safety guard to be adopted to detect interrupts generated by the noise glitches on the IR inputs. To take advantage of this feature, the IR7 routine is used as a "clean up" routine where the routine is simply executed a return instruction and the interrupt is subsequently ignored. When the IR7 is required for other purposes, the default IR7 can be detected by reading the ISR. Although correct IR7 interrupts involve setting of the corresponding ISR bit, the default IR7 is not set.



## I/O · MSM82C59A-2RS/GS = -

#### (17) Sepcial Fully Nested Mode

This mode is used in large systems where the cascade mode is used and the respective Interrupt Requests within each slave have to be given priority levels. In this case, the Special Fully Nested mode is programmed to the master by using ICW4. This mode is practically identical to the normal Fully Nested mode, but differs in the following two respects.

- a. When an interrupt request is received from a particular slave during servicing, a new interrupt request from an IR with a higher priority level than the interrupt level of the slave being serviced is recognized by the master and the interrupt is applied to the processor without the master priority logic being inhibited by the slave. In normal Fully Nested mode, if the request is in service, a slave is masked and no other requests can be recognized from the same slave.
- b. When exiting from an interrupt service routine, it is first necessary to check whether or not the interrupt which has just been serviced by software was the only interrupt from that slave. This is done by sending a Non-Specific EOI command to that slave, followed by reading of the In-Service Register (ISR) to see whether that register has become all '0'. A Non-Specific EOI is sent to the master too if the ISR is empty, and if not no EOI should be sent.

#### (18) Buffered Mode

Control for buffer enabling is required when the 82C59A is used in a large system where data bus drive buffer is needed and cascade mode is used. When buffered mode is selected, the 82C59A sends an enable signal on the  $\overline{SP}/EN$  pin to enable the buffer. In this mode, the  $\overline{SP}/EN$  output always becomes active while the 82C59A's data bus output is enabled. Therefore, the 82C59A requires programming to enable it to distinguish master from slave. Buffered mode is programmed by bit 3 in ICW4, and the ability to distinguish master from slave is programmed by bit 2 in ICW4.

#### (19) Cascade Mode

To enable the 82C59A handle up to 64 priority levels, a maximum of 8 slaves can be easily connected to one master device.

The master controls the slaves through three cascade lines, the cascade bus executes like a slave chip select during the INTA sequence.

In cascade configuration, slave interrupt outputs (INT) are connected to master interrupt request inputs (IR). When a slave IR becomes active and then it is acknowledged, the master enables the corresponding slave to release the routine address for that device during bytes 2 and 3 (only byte 2 in 86 mode) of the INTA sequence.

The cascade bus line is normally kept at low level, and holds slave address during the period from the rising edge of the first INTA pulse up to the rising edge of the third INTA pulse (or the second INTA pulse in 86 mode).

Each 82C59A device in the system can operate in different modes in accordance with their initialization sequences. And EOI commands must be issued twice, once for the master once for the corresponding slave. Each 82C59A requires an address decoder to activate the respective chip select  $(\overline{CS})$  inputs.

Since the cascade line is normally kept at low level, note that slaves must be connected to the master IRO only after all slaves have been connected to the other IRs.



= I/O · MSM82C59A-2RS/GS =