# **CALINDS**

# CA82C59A

# PROGRAMMABLE INTERRUPT CONTROLLER

- Pin and functional compatibility with the industry standard 8259/8259A
- · Fully static, high speed design (10 & 8 MHz)
- Compatible with 8080/85, 8086/88, 80286/386 and 68000 family micro-processor systems
- · TTL input/output compatibility
- Low power CMOS implementation
- Eight level priority controller
- · Expandable to 64 levels
- Programmable Interrupt modes, with each interrupt maskable
- Edge- or level-triggered interrupt request inputs
- Polling operation

The CA82C59A is a high performance, completely programmable interrupt controller. It can process eight interrupt request inputs, assigning a priority level to each one, and is cascadable up to 64 interrupt requests. Individual interrupting sources are maskable. Its two modes of operation (Call and Vector) allow it to be used with virtually all 8000 and 80000 type processors, as well as with the 68000 family of microprocessors.

Featuring fully static, very high speed operation, the CA82C59A is designed to relieve the system CPU from polling in a multi-level priority interrupt system. Its high performance makes it ideally suited for aerospace and defense applications. Its very low power consumption makes it useful in portable systems and systems with low power standby modes.



Figure 1: CA82C59A BLOCK DIAGRAM

Figure 2: PLCC and DIP PIN CONFIGURATIONS

Document: 808259.MD500.01

Table 1: PIN DESCRIPTIONS

| Symbol                          | PI            | ins           | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------|---------------|---------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 | PLCC          | PDIP          |      | Name and Function                                                                                                                                                                                                                                                                                                                                      |
| A <sub>0</sub>                  | 27            | 27            | ]    | A <sub>0</sub> Address Line: This signal acts in conjunction with the $\overline{\text{CS}}$ , $\overline{\text{WR}}$ and $\overline{\text{RD}}$ signals. It is used by the CA82C59A to decipher various command words written by the CPU, and Status information read by the CPU. It is typically connected to the CPU - A <sub>0</sub> address line. |
| CAS <sub>0-2</sub>              | 12, 13,<br>15 | 12, 13,<br>15 | 100  | Cascade Line: These signals are outputs for the master CA82C59A, and inputs for slaved CA82C59As. The CAS lines are used as a private bus by a CA82C59A master to control a multiple CA82C59A system structure.                                                                                                                                        |
| CS                              | 1             | 1             | l    | <b>Chip Select:</b> An active LOW signal used to enable $\overline{\text{RD}}$ and $\overline{\overline{\text{WR}}}$ communication between the CPU and the CA82C59A. Note that $\overline{\text{INTA}}$ functions are independent of $\overline{\text{CS}}$ .                                                                                          |
| D <sub>7</sub> - D <sub>0</sub> | 4-11          | 4-11          | Ю    | <b>Data Bus:</b> Bi-directional, 3-state, 8-bit data bus for the transfer of control, status and interrupt vector information.                                                                                                                                                                                                                         |
| INT                             | 17            | 17            | 0    | Interrupt: This signal goes HIGH when a valid interrupt request is asserted. It is used to interrupt the CPU, and is thus connected to the CPU interrupt pin.                                                                                                                                                                                          |
| INTÁ                            | 26            | 26            | ı    | Interrupt Acknowledge: Signal used to enable the CA82C59A interrupt vector data onto the data bus by a sequence of interrupt acknowledge pulses issued by the CPU.                                                                                                                                                                                     |
| IR <sub>0-7</sub>               | 18-25         | 18-25         | ı    | Interrupt Requests: Asynchronous input signals, an interrupt request is executed by raising an IR input (LOW to HIGH), and holding it HIGH until it is acknowledged (Edge Triggered Mode), or just by a HIGH level on an IR input (Level Triggered Mode).                                                                                              |
| RD                              | 3             | 3             | I    | Read: Active LOW signal used to enable the CA82C59A to output status information onto the data bus for the CPU, when CS is LOW.                                                                                                                                                                                                                        |
| SP/EN                           | 16            | 16            | VO   | Slave Program/Enable Buffer: Active LOW, dual function control signal. When in the <u>Buffered Mode</u> , it can be used as an output to control buffer transceivers ( $\overline{\text{EN}}$ ). When not in the buffered mode it can be used as an input to designate a master ( $SP = 1$ ) or a slave ( $SP = 0$ ).                                  |
| V <sub>DD</sub>                 | 28            | 28            | -    | Power: 5 v ± 10% DC Supply                                                                                                                                                                                                                                                                                                                             |
| V <sub>SS</sub>                 | 14            | 14            | -    | Ground: 0 v                                                                                                                                                                                                                                                                                                                                            |
| WR                              | 2             | 2             | I    | Write: Active LOW signal used to enable the CA82C59A to accept command words from the CPU, when $\overline{\text{CS}}$ is LOW.                                                                                                                                                                                                                         |

#### **FUNCTIONAL DESCRIPTION**

The CA82C59A Programmable Interrupt Controller is designed for use in interrupt driven micro-computer systems. Acting as an overall peripherals manager, its functions include:

- Accepting interrupt requests from assorted peripheral devices
- · Determining which is the highest priority
- Establishing whether or not the new interrupt is of a higher priority than any interrupts which might be currently being serviced, and if so,
- · Issuing an interrupt to the CPU
- Then providing the CPU with the interrupt service routine address of the interrupting peripheral

Each peripheral device usually has a specific interrupt service routine which is particular to its operational or functional requirements within the system. The CA82C59A can be programmed to hold a pointer to the service routine addresses associated with each of the peripheral devices under its control. Thus when a peripheral interrupt is passed through to the CPU, the CA82C59A can set the CPU Program Counter to the interrupt service routine required. These pointers (or vectors) are addresses in a vector table.

The CA82C59A is intended to run in one of two major operational modes, according the type of CPU being used in the system. The *CALL Mode* is used for 8085 type microprocessor systems, while the *VECTOR Mode* is reserved for those systems using more sophisticated processors such as the 8088/86, 80286/386 or 68000 family.

In either mode, the CA82C59A can manage up to eight interrupt request levels individually, with a maximum capability of up to 64 interrupt request levels when cascaded with other CA82C59As. A selection of priority modes is also available such that interrupt requests can be processed in a number of different ways to meet the requirements of a variety of system configurations.

Priority modes can be changed or reconfigured dynamically at any time during system operation using the operation command words (OCWs), allowing the overall interrupt structure to be defined for a complete

system. Note that the CA82C59A is programmed by the system software as an I/O peripheral.

The major functional components of the CA82C59A are laid out in the block diagram of Figure 1. Vector data and device programming information are transferred from the system bus to the CA82C59A via the 3-state, bi-directional Data Bus Buffer which is connected to the internal bus of the controller. Control data between the CA82C59A and the CPU, and between master and slave CA82C59A devices, is managed by one of three functional blocks:

- The Read/Write Control block processes CPU initiated reads and writes to the CA82C59A registers
- The Control Logic block receives and generates the signals that control the sequence of events during an interrupt
- The Cascade Control block is used to operate a private bus (CAS<sub>0</sub> - CAS<sub>2</sub>) connecting master and slave CA82C59As in those systems having cascaded CA82C59As.

Programming data passed over the system bus is saved in the Initialization and Command Word Registers. Note that the contents of these registers cannot be read back by the CPU.

Peripheral interrupt requests (IR<sub>0</sub> - IR<sub>7</sub>) are handled by the functional blocks comprising the Interrupt Request Register (IRR), the Interrupt Mask Register (IMR), the InService Register (ISR) and the Priority Decision Logic block. Interrupt requests are received at the IRR, the IMR masks those interrupts which cannot be accepted by the CA82C59A, and the ISR shows those interrupt requests which are currently being processed. These three registers can all be read by the CPU under software control. The Priority Decision Logic block determines which interrupt will be processed next according to a variety of indicators which include the current priority, mode status, current interrupt mask and interrupt service status.

The actual operation of the CA82C59A and its many modes are described in the section following device specifications and characteristics.

Table 2 : AC CHARACTERISTICS ( $T_A = -40^{\circ}$  to +85°C,  $V_{DD} = 5V \pm 10\%$ )

| Symbol            | Parameter                                                                                                                     | Test          | Limits | (8 MHz) | Limits | (10 MHz) | Units |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------|---------------|--------|---------|--------|----------|-------|
|                   | `                                                                                                                             | Conditions    | Min    | Max     | Min    | Max      |       |
| <sup>t</sup> AHDV | Data valid from stable address                                                                                                | Note 5        | ]      | 200     | •      | 160      | ns    |
| t <sub>AHRL</sub> | A <sub>0</sub> /CS setup to RD/INTA↓                                                                                          |               | 0      | -       | 0      |          | ns    |
| tahwl.            | A <sub>0</sub> /CS setup to WR↓                                                                                               |               | 0      | -       | 0      | _        | ne    |
| †CHCL             | End of Command to next Command (Not same command type) End of INTA sequence to next INTA sequence (same as t <sub>RV2</sub> ) | Note 1        | 200    | •       | 160    | -        | ns    |
| †CVDV             | Cascade valid to valid data                                                                                                   | Note 5        |        | 200     | -      | 130      | ns    |
| †CVIAL.           | Cascade setup to second or third INTA (slave only)                                                                            | Slave         | 40     | •       | 30     | -        | ns    |
| †DVWH             | Data setup to WRT                                                                                                             |               | 160    | •       | 100    |          | ns    |
| †IAIAH            | INTA pulse width HIGH                                                                                                         | INTA Sequence | 160    | •       | 100    | -        | ns    |
| <b>TAIAL</b>      | INTA pulse width LOW                                                                                                          |               | 160    | -       | 100    | -        | ns    |
| \$ALCV            | Cascade valid from first INTAL (master only)                                                                                  | Note 5        | -      | 260     | -      | 160      | ns    |
| Uнін              | Interrupt output delay                                                                                                        | Note 5        | -      | 200     | -      | 120      | ns    |
| ŲШН               | Interrupt request width (LOW)1                                                                                                | Note 2        | 100    | •       | 100    | -        | ns    |
| TRHAX             | A <sub>0</sub> /CS hold after RD/INTA1                                                                                        |               | 0      |         | 0      |          | ns    |
| <sup>‡</sup> RHDZ | Data float after RD/INTA↑                                                                                                     | Note 6        | 10     | 85      | 10     | 65       | ns    |
| <sup>t</sup> RHEH | Enable inactive from RDT or INTAT                                                                                             | Note 5        | -      | 50      | - 1    | 50       | ns    |
| <sup>†</sup> RHRL | End of RD to next RD End of INTA to next INTA within an INTA sequence only                                                    |               | 160    | -       | 100    | -        | ns    |
| ¶RLDV             | Data valid from RD/INTAL                                                                                                      | Note 5        | . 1    | 120     | -      | 95       | ns    |
| RLEL              | Enable active from RDJ or INTAJ                                                                                               | Note 5        | -      | 100     | -      | 70       | ns    |
| <sup>t</sup> RLRH | RD pulse width                                                                                                                |               | 160    | -       | 100    | - 1      | ns    |
| <sup>t</sup> RV1  | Command recovery time                                                                                                         | Note 3        | 200    | -       | 100    | -        | ns    |
| tRV2              | INTA recovery time                                                                                                            | Note 4        | 200    | - 1     | 100    |          | ns    |
| ™HAX              | A <sub>0</sub> ∕CS hold after WR↑                                                                                             |               | 0      | -       | 0      | -        | ns    |
| tWHDX             | Data hold after WRT                                                                                                           |               | 0      | -       | 0      |          | ns    |
| tw/wL             | End of WR to next WR                                                                                                          |               | 160    | -       | 100    | . +      | ns    |
| <sup>1</sup> WLWH | WR pulse width                                                                                                                |               | 160    |         | 100    |          | ns    |

- Notes: 1. The time to move INTA to/from command (read/write).
  - 2. The time to clear the input latch in edge-triggered mode.
  - 3. The time to move from read to write operation.
- 4. The time to move to the next INTA operation.
- 5. See Figure 5, Note 5 for load circuit values.6. See Figure 5, Note 6 for load circuit values

S

#### Figure 3: TIMING DIAGRAMS

### a) interrupt Cycle (CALL Mode)



#### b) Interrupt Cycle (VECTOR Mode)



Note that IR input should remain at a high level until the leading edge of the first  $\overline{\text{INTA}}$  pulse.

## c) Read Cycle



### d) Write Cycle



#### e) Other Timing





AC Testing: All input signals must switch between  $V_{IL}-0.4V$  and  $V_{IH}+0.4V$ . Input rise and fall times must be  $\leq$  15 ns. All timing measurements are made at 2.4V and 0.45V.

\*Includes stray and jig capacitance

|      |      |       | -     | -     |
|------|------|-------|-------|-------|
| Note | V1   | R1    | R2    | C1    |
| 5    | 1.7V | 523Ω  | open  | 100pf |
| 6    | 4.5V | 1.8kΩ | 1.8kΩ | 30pf  |

Figure 4: AC TESTING I/O WAVEFORMS

Figure 5: AC TESTING LOAD CIRCUIT

Table 3 : DC CHARACTERISTICS ( $T_A = -40^{\circ}$  to +85°C,  $V_{DD} = 5V \pm 10\%$ )

| Symbol          | Parameter                      | Test                                                                                                       | Li                           | mit                   | Units                    |  |
|-----------------|--------------------------------|------------------------------------------------------------------------------------------------------------|------------------------------|-----------------------|--------------------------|--|
| -,              |                                | Conditions                                                                                                 | Min                          | Max                   |                          |  |
| IDD             | V <sub>DD</sub> supply current |                                                                                                            | -                            | 10                    | mA                       |  |
| IDDSB           | Standby power supply current   | V <sub>DD</sub> = 5.5v, V <sub>IN</sub> = V <sub>DD</sub> or Gnd<br>Outputs Open, All IR = V <sub>DD</sub> | •                            | 10                    | μΑ                       |  |
| î <sub>Ll</sub> | Input leakage current          | $0v \le V_{IN} \le V_{DD}$                                                                                 | -10                          | +1.0                  | μА                       |  |
| ILIR            | IR input load current          | V <sub>IN</sub> = 0v<br>V <sub>IN</sub> = V <sub>DD</sub> , All temp ranges                                | :                            | -300<br>10            | μ <b>Α</b><br>μ <b>Α</b> |  |
| LOL             | Output leakage current         | 0v≤V <sub>OUT</sub> ≤V <sub>DD</sub>                                                                       | -100                         | +10.0                 | μА                       |  |
| ViH             | Input HIGH voltage             |                                                                                                            | 22                           | V <sub>DD</sub> + 0.5 | ٧                        |  |
| V <sub>IL</sub> | Input LOW voltage              |                                                                                                            | -0.5                         | 0.8                   | ٧                        |  |
| V <sub>OH</sub> | Output HIGH voltage            | I <sub>OH</sub> = -2.5 mA<br>I <sub>OH</sub> = -100 μA                                                     | 3.0<br>V <sub>DD</sub> = 0.4 | -                     | <b>&gt;</b>              |  |
| V <sub>OL</sub> | Output LOW voltage             | I <sub>OL</sub> = +2.5 mA                                                                                  |                              | 0.4                   | ٧                        |  |

#### Table 4: CAPACITANCE (TA = 25°C, VDD = VSS = 0V)

| Symbol           | Parameter          | Test                |     | Units |     |    |
|------------------|--------------------|---------------------|-----|-------|-----|----|
| -,               |                    | Conditions          | Min | Тур   | Max |    |
| C <sub>IN</sub>  | Input capacitance  | Freq = 1 MHz        | -   | 7     |     | pF |
| C <sub>VO</sub>  | I/O capacitance    | Unmeasured pins are |     | 20    | -   | pF |
| C <sub>OUT</sub> | Output capacitance | returned to Gnd     |     | 15    | -   | pF |

### Table 5: RECOMMENDED OPERATING CONDITIONS

| Operating Voltage Range     |            | +4.0 to +6.0 Volts |
|-----------------------------|------------|--------------------|
| Operating Temperature Range | Commercial | 0°C to +70°C       |
|                             | Industrial | -40°C to +85°C     |

#### Table 6: ABSOLUTE MAXIMUM RATINGS

| Power Supply Voltage (VDD)                      | -0.5 to +7.0 Volts                                   |  |  |
|-------------------------------------------------|------------------------------------------------------|--|--|
| Input (V <sub>IN</sub> ) or I/O Voltage Applied | $V_{SS}$ = 0.5 to $V_{DD}$ + 0.5 Volts               |  |  |
| Output (V <sub>OUT</sub> ) Voltage Applied      | V <sub>SS</sub> - 0.5 to V <sub>DD</sub> + 0.5 Volts |  |  |
| Maximum Power Dissipation                       | 1 Watt                                               |  |  |
| Storage Temperature Range                       | -65°C to +150°C                                      |  |  |

Stresses beyond those listed above may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

#### **OPERATIONAL DESCRIPTION**

The CA82C59A is designed to operate in one of two mutually exclusive modes, selected according to the type of system processor used; Call Mode for 8080/85 type processors, and Vector Mode for 8088/86 and 80286/386 type processors. The major difference between these two modes is the way in which interrupt service routine address data is passed to the system CPU. Unless specifically programmed to the contrary, the CA82C59A defaults to the CALL Mode of operation, (see section on Programming).

#### Call Mode

In CALL mode, the *interrupt service routine* address is passed in two steps, (first the lower byte of the address, followed by the upper byte), in response to three Interrupt Acknowledge (INTA) signals sent by the CPU to the CA82C59A. In a system containing a single Interrupt Controller, the sequence of steps to respond to a peripheral interrupt request is outlined below, and shown graphically in Figure 6. The interrupt service routine addresses are loaded into the CA82C59A during the initialization procedures.

#### Step

#### **Event Sequence**

- One or more interrupt request lines (IR<sub>0</sub> IR<sub>7</sub>) are raised HIGH, setting corresponding IRR bits.
- 2 The requests are evaluated by the CA82C59A, and if their priority is high enough, or if they are not masked, an INT signal is sent to the CPU.
- 3 The CPU acknowledges the INT with an interrupt acknowledge (INTA).
- On receipt of the INTA, the CA82C59A sets the highest priority ISR bit, and resets the corresponding IRR bit. In addition, the CA82C59A sends a CALL instruction (OCDH) to the CPU via the data bus.
- 5 The CALL instruction causes the CPU to send two more INTA signals to the CA82C59A.
- On receipt of the first of these two INTA signals, the CA82C59A sends the low order 8-bit address byte to the CPU via the data bus. On receipt of the second INTA, the high order address byte is sent to the CPU.
- 7 This completes the 3-byte CALL instruction procedure. The ISR bit is reset at the end of the interrupt sequence except in the Automatic EOI mode, where the ISR bit is reset automatically at the end of the third INTA.

#### Vector Mode

In VECTOR mode, the interrupt service routine address is calculated by the CPU from a one byte *interrupt vector* supplied by the CA82C59A. The significant bits T<sub>7-3</sub> of the interrupt vectors are loaded into the CA82C59A during the initialization procedures.

Note that no data is transferred by the CA82C59A to the CPU after the first iNTA signal (the CA82C59A data bus buffers are disabled). It is similar to the CALL mode in that this cycle is used for internal operations that freeze the state of the interrupts for priority resolution or, in cascaded mode; to issue the interrupt code on the cascade lines (CAS<sub>0-2</sub>) at the end of this cycle.

The sequence of steps that occur to respond to a peripheral interrupt request in Vector mode are outlined below and illustrated in Figure 9.

#### Step

#### Event Sequence

- One or more interrupt request lines (IR0 IR7) are raised HIGH, setting corresponding IRR bits.
- 2 The requests are evaluated by the CA82C59A, and if their priority is high enough, or if they are not masked, an INT signal is sent to the CPU.
- 3 The CPU acknowledges the INT with an interrupt acknowledge (INTA).
- 4 After receipt of the first INTA signal from the CPU, the CA82C59A sets the highest priority ISR bit and resets the corresponding IRR bit. The CA82C59A data bus buffer is not active during this cycle (high impedance state).
- Following receipt of the second INTA signal generated by the CPU, the CA82C59A sends an 8-bit interrupt vector to the CPU via the data bus.
- 6 This completes the 1-byte VECTOR mode procedure. In the Automatic End-of-Interrupt (AEOI) mode, the ISR bit is reset at the end of the second INTA.

In other EOI modes the ISR bit remains set until an appropriate EOI command is received after the end of the interrupt sequence.

The interrupt sequence procedures when several CA82C59As are cascaded together is shown for both CALL and VECTOR modes in Figures 8 and 11 respectively.



Figure 6: CALL MODE OPERATION (Single CA82C59A Systems)

#### CONTENTS OF FIRST INTERRUPT VECTOR BYTE

|      | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | $D_2$ | D <sub>1</sub> | D <sub>0</sub> |
|------|----------------|----------------|----------------|----------------|----------------|-------|----------------|----------------|
| CODE | 1              | 1              | 0              | 0              | 1              | 1     | 0              | 1              |

The lower address of the appropriate service routine is enabled onto the data bus during the second INTA pulse.

When the Interval = 4, bits A<sub>5</sub> - A<sub>7</sub> are programmed, and A<sub>0</sub> - A<sub>4</sub> are inserted automatically by the CA82C59A.

When the Interval = 8, bits A<sub>6</sub> and A<sub>7</sub> only are programmed, with A<sub>0</sub> - A<sub>5</sub> inserted automatically by the CA82C59A.

#### CONTENTS OF SECOND INTERRUPT VECTOR BYTE

| la la |                | INTERVAL = 4   |                |    |                |                |                |                |
|-------|----------------|----------------|----------------|----|----------------|----------------|----------------|----------------|
|       | D <sub>7</sub> | D <sub>6</sub> | 05             | D4 | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
| 7     | A7             | A <sub>6</sub> | A <sub>5</sub> | 1  | 1              | 1              | 0              | ٥              |
| 6     | A7             | A <sub>6</sub> | A <sub>5</sub> | 1  | 1              | ٥              | 0              | ٥              |
| 5     | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | 1  | 0              | -              | 0              | 0              |
| 4     | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | 1  | 0              | ٥              | 0              | 0              |
| 3     | A <sub>7</sub> | As             | A <sub>5</sub> | 0  | 1              | 1              | 0              | 0              |
| 2     | A7             | As             | A <sub>5</sub> | 0  | 1              | 0.             | 0              | 0              |
| -     | A7             | Ag             | A <sub>5</sub> | 0  | 0              | 1              | ٥              | ٥              |
| 0     | A7             | As             | A <sub>5</sub> | ٥  | 0              | 0              | 0              | 0              |

| <br> R |                | INTERVAL = 0   |                |                |                |                |                |    |  |
|--------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----|--|
| Ľ      | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | Do |  |
| 7      | A <sub>7</sub> | A <sub>6</sub> | 1              | 1              | 1              | 0              | 0              | 0  |  |
| 6      | A <sub>7</sub> | A <sub>6</sub> | 1              | 1              | ٥              | 0              | 0              | 0  |  |
| 5      | A <sub>7</sub> | As             | 1              | ٥              | 1              | 0              | 0              | 0  |  |
| 4      | A <sub>7</sub> | A <sub>6</sub> | 1              | 0              | 0              | 0              | 0              | ۰  |  |
| 3      | A7             | As             | 0              | 1              | •              | 0              | 0              | ٥  |  |
| 2      | A7             | A <sub>6</sub> | ٥              | -              | o              | 0              | 0              | 0  |  |
| 1      | A <sub>7</sub> | A <sub>6</sub> | 0              | 0              | 1              | 0              | 0              | 0  |  |
| 0      | A7             | As             | 0              | 0              | 0              | 0              | ٥              | 0  |  |

During the third INTA pulse, the higher address of the appropriate service routine is enabled onto the bus. This address was initially programmed as byte 2 of the initialization sequence  $(A_8 - A_{15})$ .

#### CONTENTS OF THIRD INTERRUPT VECTOR BYTE

Figure 7: CALL MODE ADDRESS BYTE SEQUENCE



Figure 8: CALL MODE OPERATION (Cascaded CA82C59A Systems)



Figure 9: VECTOR MODE OPERATION (Single CA82C59A Systems)

# Ç

#### CONTENTS OF FIRST INTERRUPT VECTOR BYTE

| #R | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D2 | D1 | Do |
|----|----------------|----------------|----------------|----------------|----------------|----|----|----|
| 7  | Т7             | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | Т3             | 1  | 1  | -  |
| 6  | Т7             | T <sub>6</sub> | T <sub>5</sub> | T4             | Тэ             | 3  | 1  | ٥  |
| 5  | Т7             | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | Тз             | -  | ٥  | 1  |
|    | Т7             |                |                |                |                |    |    |    |
| 3  | T <sub>7</sub> | T <sub>6</sub> | Т5             | T <sub>4</sub> | Ta             | 0  | 1  | -  |
| 2  | Т7             | Te             | T <sub>5</sub> | T <sub>4</sub> | T <sub>3</sub> | o  | 1  | 0  |
| 1  | Т7             | T <sub>6</sub> | Т5             | T4             | Тз             | 0  | ٥  | 1  |
| 0  | Т7             | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | Тз             | ٥  | 0  | 0  |

The value  $T_7$  to  $T_3$  is programmed during byte 2 of the initialization (ICW<sub>2</sub>). During the second INTA pulse, the interrupt vector of the appropriate service routine is enabled onto the bus. The low order three bits are supplied by the CA82CS9A according to the IR input causing the interrupt.

Figure 10: VECTOR MODE ADDRESS BYTE



Figure 11: VECTOR MODE OPERATION (Cascaded CA82C59A Systems)

#### REGISTERS

The CA82C59A contains a number of registers, used to keep track of interrupts which are being serviced, or pending, as well as those which are masked. These registers are described in Table 7. They can be written

to using the *command word* structure, or in the case of IRR, are set by external peripheral devices requesting interrupt service. The contents of all registers can be read by the CPU for status updates (see Table 8).

Table 7: CA82C59A REGISTERS

| Symbol | Name                       | Function                                                                                                                                                                                                |
|--------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IMR    | Interrupt Mask Register    | An 8 - bit wide register that contains the interrupt request lines which are masked.                                                                                                                    |
| IRR    | Interrupt Request Register | An 8 - bit wide register that contains the levels requesting an interrupt to be acknowledged. The highest request level is RESET from the IRR when an interrupt is acknowledged, (not affected by IMR). |
| ISR    | In-Service Register        | An 8 - bit wide register that contains the priority levels which are currently being serviced. The ISR is updated when an <i>End of Interrupt</i> Command (EOI) is received.                            |

Table 8: REGISTER READ/WRITE OPERATIONS

| Operations                                                                                                  |                                                                            | Other                                                                                                                                                                    | Bit Programming |     |    |                |
|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|----|----------------|
| CA82C59A                                                                                                    | CPU                                                                        | Conditions                                                                                                                                                               | cs              | RD  | WR | A <sub>0</sub> |
| IRR to Data Bus<br>ISR to Data Bus                                                                          | IRR Read<br>ISR Read                                                       | IRR set by OCW <sub>3</sub><br>ISR set by OCW <sub>3</sub>                                                                                                               | o l             | . 0 | 1  | 0              |
| Polling data to Data Bus                                                                                    | Polling                                                                    | Poiling data is read instead of IRR and ISR                                                                                                                              |                 |     |    |                |
| IMR to Data Bus                                                                                             | IMR Read                                                                   |                                                                                                                                                                          | 0               | 0   | 1  | 1              |
| Data Bus to ICW <sub>1</sub> Reg.<br>Data Bus to OCW <sub>2</sub> Reg.<br>Data Bus to OCW <sub>3</sub> Reg. | ICW <sub>1</sub> Write<br>OCW <sub>2</sub> Write<br>OCW <sub>3</sub> Write | Set ICW <sub>1</sub> (D <sub>4</sub> = 1)<br>Set OCW <sub>2</sub> (D <sub>4</sub> , D <sub>3</sub> = 0)<br>Set OCW <sub>3</sub> (D <sub>4</sub> = 0, D <sub>3</sub> = 1) | 0               | 1   | 0  | 0              |
| Data Bus to ICW <sub>2</sub> Reg.<br>Data Bus to ICW <sub>3</sub> Reg.<br>Data Bus to ICW <sub>4</sub> Reg. | ICW <sub>2</sub> Write<br>ICW <sub>3</sub> Write<br>ICW <sub>4</sub> Write | Refer to section on Control Words for ICW <sub>2</sub> - ICW <sub>4</sub> writing procedure                                                                              | 0               | 1   | 0  | 1              |
| Data Bus to IMR                                                                                             | OCW <sub>1</sub> Write                                                     | After initialization                                                                                                                                                     |                 |     |    |                |
| Data Bus set to                                                                                             |                                                                            |                                                                                                                                                                          | 0               | 1   | 1  | x              |
| High Impedance State                                                                                        |                                                                            |                                                                                                                                                                          | 1               | x   | ×  | x              |
| Illegal State                                                                                               |                                                                            |                                                                                                                                                                          | 0               | 0   | 0  | ×              |

#### **PROGRAMMING**

The CA82C59A is initialized and programmed with special command words issued by the CPU. These commands fall into two major categories: Initialization Command Words (ICW<sub>1</sub> - ICW<sub>4</sub>), and Operational Command Words (OCW<sub>1</sub> - QCW<sub>3</sub>). Initialization commands are used to bring the CA82C59A to a known state when the system is first activated, or after a system restart.

Operational commands are used once the CA82C59A is in operation (and *after* it has been initialized), to set, or alter specific interrupt program modes. The format and use of these two command types is described below.

#### **Initialization Commands**

The CA82C59A is initialized by a sequence of 2 to 4 command words (ICWs), where the actual number of commands sent depends on the system configuration, and the initial operating modes to be programmed. Note that *each* CA82C59A in the system *must* be initialized before operations begin in earnest (Figure 13).

The initialization sequence is started when the CPU sends  $A_0 = 0$  and  $ICW_1$  with  $D_4 = 1$  (Figure 12). During initialization, the events below occur automatically:

- Edge sense circuit is reset. Thus, after initialization, an interrupt request must make a LOW-to-HIGH transition to be recognized.
- IMR is cleared.
- The priority of IR<sub>7</sub> is set to 7 (the lowest priority).
- · Special Mask Mode is reset.
- · Status read is set to IRR.
- If SNGL bit of ICW<sub>1</sub> = 1, then ICW<sub>3</sub> must be programmed.
- If IC<sub>4</sub> bit of ICW<sub>1</sub> = 0, then functions selected in ICW<sub>4</sub> are reset: Non-buffered Mode, no Automatic EOI, Call Mode operation.
- If IC<sub>4</sub> = 1, then CA82C59A will expect ICW<sub>4</sub>.

#### Bit Definitions (ICW<sub>1</sub>, ICW<sub>2</sub>)

- IC<sub>4</sub> Set if ICW<sub>4</sub> is to be issued. This bit must be set for systems operating in Vector Mode.
- SNGL Set if this CA82C59A is not cascaded to other CA82C59As in the system (ICW<sub>3</sub> not issued). When CA82C59As are cascaded, SNGL is reset and ICW<sub>3</sub> is issued.
- ADI CALL Address Interval. If ADI = 1, then interval = 4. If ADI = 0, then interval = 8.
- LTIM Level Trigger Mode. If LTIM = 1, edge detect logic on the IR inputs is disabled, and the CA82C59A operates in level triggered mode.

- A<sub>5-15</sub> Service routine *Page Starting Address* (Call Mode). In a single CA82C59A system, the 8 interrupt request levels generate CALLs to 8 equally spaced locations in memory. These are spaced at intervals of either 4 or 8 memory locations according to the ADI value. Thus, the service routines associated with each CA82C59A in the system occupy pages of 32 or 64 bytes respectively.

  Bits A<sub>0</sub> A<sub>4</sub> are automatically inserted to give an address length of 2 bytes (A<sub>0</sub> A<sub>4</sub>).
- an address length of 2 bytes (A<sub>0</sub> A<sub>15</sub>).

  Note that the 8-byte interval is compatible with CA80C85B restart instructions.

  A<sub>11,15</sub> Service routine Vector Address Byte. In the
- A<sub>11-15</sub> Service routine Vector Address Byte. In the vector mode, bits A<sub>11</sub> A<sub>15</sub> are inserted in the five most significant places of the vector byte. The three least significant bits are inserted by the CA82C59A according to the interrupt request level. The ADI and A<sub>5</sub> A<sub>10</sub> bits are ignored.

#### Bit Definitions (ICW<sub>3</sub>)

This word is used only when SNGL = 0 in ICW<sub>1</sub>, at which time the contents then depend on whether it is being sent to a master CA82C59A, or a slave device.

- Master Mode: Sent to the master CA82C59A, each bit of ICW<sub>3</sub> represents a potential slave device connected to an IR input. If a slave exists, the corresponding bit in ICW<sub>3</sub> is set. Where a slave is not attached to an IR input of the master, the corresponding bit is reset.
  - In operation, the master outputs byte 1 of the interrupt sequence to the bus, then enables the appropriate slave (via the cascade bus  $CAS_{0-2}$ ) to output bytes 2 and 3 (Call Mode) or byte 2 only (Vector Mode).
- Slave Mode: When sent to a slave CA82C59A, bits ID<sub>0-2</sub> contain the slave address on the cascade bus. Each slave device in the system must be initialized with a unique address. Remaining bits are not used.
  - In operation, the slave compares the cascade input to its 3-bit address and if they match, outputs byte 2 and 3 (Call Mode), or byte 2 only (Vector Mode) to the bus.

#### Bit Definitions (iCW<sub>4</sub>)

This word is used only when bit  $IC_4$  in  $ICW_1$  is set. Note that only five bits are used.

- μPM Microprocessor System Mode: μPM = 0 for Call Mode, μPM = 1 for Vector Mode.
- AEOI This bit is set if the Automatic End of Interrupt Mode is to be programmed.

- WS When Buffered Mode is selected, the M/S bit is used to determine the master/slave programming. That is, M/S = 1 indicates the device is a master, while M/S = 0 indicates a slave. If the BUF bit is not set, M/S is not used.
- BUF Buffered Mode is programmed by setting BUF = 1. In buffered mode, the output pin SP/EN becomes an enable output, and the M/S bit determines whether the device is a master or a slave.
- SFNM Special Fully Nested Mode is programmed by setting SFNM = 1.



Figure 12: INITIALIZATION FLOW CHART

#### **Operational Commands**

Once the CA82C59A has been initialized, it can accept and process interrupt requests received on its IR input lines. Interrupts are processed according to the modes programmed during the initialization process. A number of commands, sent to the CA82C59A from the CPU, allow the programmed modes or the interrupt request priorities to be changed on the fly during operation. These commands are described in the sections following (and in Figure 14).

#### Bit Definitions (OCW<sub>1</sub>)

OCW<sub>1</sub> is used to set and clear mask bits in the IMR, thus enabling or disabling specific IR inputs. In the *Special Mask Mode*, the ISR is also masked.

M<sub>0-7</sub> Bits M<sub>0-7</sub> correspond to the 8 IR inputs.
 If bit M<sub>n</sub> = 1, the IR<sub>n</sub> input is disabled.
 If M<sub>n</sub> = 0, the IR<sub>n</sub> input is enabled.

#### Bit Definitions (OCW2)

OCW<sub>2</sub> is used to program the different End of Interrupt (EOI) Modes, and alter the interrupt request priorities.

- L<sub>0-2</sub> These bits designate the interrupt level to be acted upon when bit SL = 1 (active).
- EOI The End of Interrupt command is issued by the CPU, rather than by the CA82C59A (in automatic EOI mode). Note that this bit is used in conjunction with bits R and SL to control the interrupt priority assignments and rotations.
- SL Set Interrupt Level bit. This lowest priority interrupt is assigned to the IR input corresponding to the octal value of L<sub>0-2</sub>.
- R This bit determines if interrupt priority rotation is in effect. R = 1 indicates priorities will be rotated, perhaps combined with other modes.

#### Bit Definitions (OCW<sub>3</sub>)

OCW<sub>3</sub> is used to program the Special Mask Mode, the Polling Mode, and select internal registers to be read by the CPU.

- RIS If RIS = 0, select ISR. If RIS = 1, select IRR.
- RR Read Register bit. If RR = 1, output the contents of the register selected by bit RIS onto
  the bus. The register selection is retained, so
  OCW<sub>3</sub> does not have to be reissued in order
  to read the same register again.
- P If P = 1, the Polling Mode is selected for this CA82C59A. In this mode the CPU will poll for new interrupt requests, rather than having the CA82C59A actively set the CPU INT input.
- SMM If Special Mask Mode is enabled (ESMM = 1), then SMM = 1 programs the special mask mode, and SMM = 0 clears the special mask mode.
- ESMM If ESMM = 1, then the special mask mode is enabled, and can be set or reset by the SMM bit. If ESMM = 0, the special mask mode is disabled and SMM is ignored.



Figure 13: INITIALIZATION COMMAND WORD FORMAT

SETINTERRUPTIMASK

RESET INTERRUPT MASK

INTERRUPT MASK

~

OCW<sub>1</sub>

D6 D5

M5 M4 M3 M2 M1 M0

Ao

M7

03

٥

1

POLLING

SPECIAL MASK MODE

X NO OPERATION

READIS-REGONNEXTRD

POLLING COMMAND

NO OPERATION

0 READIR-REGONNEXTRD

0

READ

REGISTER

Figure 14: OPERATIONAL COMMAND WORD FORMAT

X NO OPERATION

1 1 SET SPECIAL MASK
1 0 RESET SPECIAL MASK

0 X

#### **OPERATIONAL MODES**

The CA82C59A can be programmed to operate in a number of different modes which are summarized and described below. Depending on the mode, some are set during initialization, and some during operation (with the command word structure).

| Mode                                        | Location Set                                |
|---------------------------------------------|---------------------------------------------|
| Buffer Mode                                 | BUF, M/S (ICW <sub>4</sub> )                |
| Cascaded Mode                               | SNGL (ICW <sub>1</sub> )                    |
| Master Mode                                 | (ICW <sub>3</sub> )                         |
| Slave Mode                                  | ID <sub>0-2</sub> (ICW <sub>3</sub> )       |
| End of Interrupt (EOI) Modes                | EOI (OCW <sub>2</sub> )                     |
| Automatic EOI Mode                          | AEOI (ICW <sub>4</sub> )                    |
| Non-specific EOI     Specific EOI           | EOI, SL, R (OCW <sub>2</sub> )              |
| Nested Modes                                | EOI, SL, R (OCW <sub>2</sub> )              |
| Fully Nested Mode                           | default mode                                |
| Special Fully Nested Mode                   | SFNM (ICW <sub>4</sub> )                    |
| openia i eny ricolae mose                   | AEOI (ICW <sub>4</sub> )                    |
| Polling Mode                                | P (OCW <sub>3</sub> )                       |
| Rotation Modes                              |                                             |
| <ul> <li>Automatic Rotation Mode</li> </ul> | R, SL, EOI (OCW2)                           |
| <ul> <li>Specific Rotation Mode</li> </ul>  | R, SL, L <sub>0-2</sub> (OCW <sub>2</sub> ) |
| Special Mask Mode                           | ESMM, SMM (OCW3)                            |
| System Modes                                |                                             |
| CALL Mode                                   | μPM (ICW <sub>4</sub> )                     |
| VECTOR Mode                                 | μPM (ICW <sub>4</sub> )                     |
|                                             | IC <sub>4</sub> (ICW <sub>1</sub> )         |
| Trigger Modes                               |                                             |
| Edge Triggered Mode                         | LTIM (ICW <sub>1</sub> )                    |
| <ul> <li>Level Triggered Mode</li> </ul>    | LTIM (ICW <sub>1</sub> )                    |
|                                             |                                             |

#### **Buffer Mode**

In larger systems the CA82C59A may be required to drive the data bus through a buffer. To handle this situation, the *Buffer Mode* is programmed during initialization (using the BUF and M/S bits in  $ICW_4$ ).

When in buffer mode,  $\overline{SP/EN}$  is used to enable the data bus buffers, and determine the direction of data flow through the buffer (Figure 15). This signal is active when the output ports of the CA82C59A are activated.

Note that when *cascaded* CA82C59As are required to be used in the buffer mode, the master/slave selection is done using the M/S bit of ICW<sub>4</sub>, (and SNGL bit of ICW<sub>1</sub> is set to 1). M/S is set to 1 for the master mode, 0 for the slave mode.



Figure 15: BUFFER MODE

#### Cascaded Mode

In systems that contain more than 8 priority interrupt levels, several CA82C59A devices can be easily cascaded together to handle a maximum of 64 interrupt levels. In a cascaded configuration, one CA82C59A serves as a master, controlling up to 8 slaves (able to handle 8 interrupts each). The master selects the slaves via the cascade local bus (CAS<sub>0-2</sub>), enabling the corresponding slave to output the interrupt service routine address (or vector) following each of the second and third INTA signals (second INTA signal only in Vector mode). At the end of the interrupt cycle, the EOI command must be issued twice, one for the master, and one for the appropriate slave.

The CAS<sub>0-2</sub> bus lines are normally held in a LOW state, and activated only for slave inputs (non-slave inputs to the master do not affect the cascade bus). The slave address will be held on the cascade bus from the trailing edge of the first INTA signal to the trailing edge of the last INTA signal (either second or third depending on the system mode).

Within the system, each slave can be programmed to operate in a different mode (except AEOI), independently of other slave devices. The interrupt output (INT) of each slave is tied to one of the interrupt request lines (IR<sub>0.7</sub>) of the master device. Unused IR pins on the master device can be connected to other peripheral devices (as in the single standalone mode of operation), or left unconnected.

Note that an address decoder is required to activate the chip select  $(\overline{CS})$  input of each CA82C59A in the system.

#### **Master Mode**

A CA82C59A operating in the *Master Mode* can be controlling both peripheral interrupts as well as other CA82C59A slave devices. Since both types of inputs are connected to the IR<sub>0-7</sub> pins, it is necessary to differentiate between the two. This is accomplished in the initialization control word (ICW<sub>3</sub>) sent out to the master. ICW<sub>3</sub> sets the S<sub>n</sub> bits corresponding to IR<sub>n</sub> pins connected to slaves equal to one (1), while S<sub>m</sub> bits corresponding to IR<sub>m</sub> pins connected to peripheral inputs are reset to zero.

Peripheral interrupt requests to  $IR_m$  pins  $(S_m = 0)$  are handled by the master as if it were operating singly. That is, the CAS line remain LOW, and the master provides the interrupt or vector as required.

Slave interrupt requests to  $IR_n$  pins  $(S_n=1)$  are handled as follows; the master sends an interrupt to the CPU if the slave requesting the interrupt has priority. If so, the master outputs the slave address n to the CAS bus on the first  $\overline{INTA}$  signal, then lets the slave complete the remainder of the interrupt cycle. Note again however, that two EOI commands are required to terminate the sequence, one each for the master and slave.

#### Slave Mode

When a slave CA82C59A receives a peripheral interrupt request, and it has no higher interrupt requests pending, the slave sends an interrupt request to the master via its INT output. This interrupt request is passed by the master to the CPU, which then initiates the interrupt cycle, in turn causing the master to output the slave's address on the CAS bus. Each slave in the system continuously monitors the CAS bus, comparing the addresses thereon until a match is found with its own address. When the slave initiating the interrupt request finds an address match, it completes the interrupt sequence as though it were a single CA82C59A.

Note: Since the master holds the CAS bus LOW (corresponding to CAS address 0) when processing peripheral interrupt requests, address 0 should not be used as a slave address unless the system contains the full complement of 8 slaves.

#### End of Interrupt (EOI) Modes

The EOI Modes are used to terminate the request for interrupt service sequence, update the ISR register and alter the interrupt priorities. The EOI mode selected depends on the nesting mode currently programmed. The options are discussed in the sections following.

#### Automatic EOI (AEOI) Mode

In AEOI Mode, the ISR bit corresponding to the interrupt is set and reset automatically during the final INTA signal. This means that the CPU does not have to issue an EOI command at the end of the interrupt routine.

Caution is urged in using AEOI however, as the ISR does not save the *routine currently in service* in this mode. Thus, unless the interrupts are disabled by the interrupt service routine, a stack overflow situation can result from newly generated interrupts (which bypass the priority structure), or from level triggered interrupts.

The Automatic EOI mode is programmed by setting the AEOI bit in  $ICW_4 = 1$ .

#### Non-specific (Normal) EOI Mode

When the CA82C59A is operated in the Fully Nested Mode, it can easily determine which ISR bit is to be reset at the conclusion of an interrupt sequence. In this case, the non-specific EOI command is used to reset the highest priority level selected from the interrupts in service, (the valid assumption being that the last interrupt level acknowleged and serviced necessarily corresponds to the highest priority ISR bit set).

A Non-specific EOI Mode is selected via  $OCW_2$ , where EOI = 1, SL = 0 and R = 0). Refer to Figure 14a, c.

#### Specific EOI Mode

The Specific EOI Mode is required when the fully nested (normal) mode is not used, and the CA82C59A is unable to determine the last interrupt level acknowledged (such as might be encountered if the Special Mask Mode is programmed). The Specific EOI command identifies the ISR bit (interrupt level) to be reset using bits  $L_{0.2}$  of OCW<sub>2</sub>, which also has the following bit settings: EOI = 1, SL = 1 and R = 0. Refer to Figure 16b, d.



a) Non-specific EOI Command

OCW 2 0 1 1 0 0 LE L1 LE

b) Specific EOI Command

OCW2 1 0 1 0 0 X X X

c) Rotate on Non-specific EOI Command

OCWg 1 1 1 0 0 Lg L1 L0

d) Rotate on Specific EOI Command

Figure 16: EOI COMMANDS

#### Mask Modes

The *Mask Modes* are used to selectively enable or disable interrupt requests. This is distinct from the automatic disabling of an interrupt which is in effect while a request from the same interrupt is being serviced.

#### Normal Mask Mode

Interrupt request lines  $IR_{0-7}$  can be individually masked in the Interrupt Mask Register (IMR), using  $OCW_1$ . Each bit in IMR masks one interrupt request line if it is set (= 1), with no effect on the other interrupt request lines. Bit 0 masks  $IR_0$ , bit 1 masks  $IR_1$  etc.

#### Special Mask Mode

The Special Mask Mode is used to dynamically alter the interrupt priority structure under software control during program execution. In this mode, when a mask bit is set in OCW<sub>1</sub>, it disables further interrupts at that level, and enables interrupts from all other levels that are not masked. This includes those interrupts which are lower (as well as higher) in priority.

The Special Mask Mode is set by ESMM = 1 and SMM = 1 in OCW $_3$ . To clear this mode, the CPU must issue another OCW $_3$  with ESMM = 1 and SMM = 0. Setting ESMM = 0 alone has no effect. To correctly enter the Special Mask Mode, use the following procedure:

- 1. CPU reads the ISR
- 2. CPU writes the ISR data from (1) to the IMR
- CPU selects Special Mask Mode by issuing OCW<sub>3</sub>: with ESMM = 1 and SMM = 1.

This procedure ensures that all interrupt requests not currently in service will be enabled.

Note that if IMR is not set equal to ISR when *Special Mask Mode* is selected, bits which may be set in the ISR will be ignored. If a corresponding bit is not set in IMR, that interrupt request may be serviced, causing all interrupts of lower priority to be effectively disabled. This is illustrated in Figure 17.

When the Special Mask Mode is selected, the Specific EOI Mode must be used to terminate the interrupt sequence, so the CPU can explicitly specify which ISR bit is to be reset.



Interrupt requests IR $_6$  and IR $_7$  cannot be accepted when IMR  $\neq$  ISR, even with the Special Mask Mode set



All interrupt requests, except those being serviced can be accepted when IMR = ISR, and the Special Mask Mode is set Priority Levels That Can Interrupt (White Boxes)

Figure 17: SPECIAL MASK MODE

#### **Nested Modes**

The nesting modes are used to determine, and change, the priority of incoming interrupt requests.

#### Fully Nested Mode

The default nesting mode, entered automatically after initialization, unless another mode has been programmed. In the *Fully Nested Mode*, the interrupt request priorities are set in descending order from 0 to 7. That is: IR<sub>0</sub> is the highest priority interrupt, IR<sub>7</sub> the lowest.

When an interrupt is acknowledged, the highest priority request is selected, the corresponding ISR bit is set, and the service routine address information is output to the data bus. The ISR bit is reset by the EOI command from the CPU, or automatically if AEOI Mode is programmed, at the completion of the interrupt sequence. While the ISR bit is set, all interrupt requests of equal or lower priority are inhibited. Interrupt requests of higher priority will generate an interrupt to the CPU, but whether or not

these will be acknowledged depends on the system software logic. Interrupt priorities can be altered in this mode using one of the *Rotation Modes*.

Note that fully nested interrupt priorities are not necessarily preserved in those systems containing cascaded CA82C59As, as it is possible for interrupts of higher priority than the one being serviced to be ignored. This situation occurs when a slave accepts a peripheral interrupt request (and passes the request to the master). When the master accepts the request, it locks out further interrupts from that slave. Should an interrupt of higher priority come in to the same slave, it will not be recognized until the interrupt being serviced has completed processing. To preserve interrupt priorities in this situation, use the Special Fully Nested Mode.





Interrupt request  $\mbox{IR}_4$  can be accepted after  $\mbox{IR}_2$  has been completely serviced. The HIGH level is maintained at  $\mbox{IR}_4$  until  $\mbox{IR}_4$  is accepted.

# Figure 18: FULLY NESTED MODE

#### Special Fully Nested Mode

Interrupt request IR4 cannot be accepted

This mode is very similar to the *Fully Nested Mode*, but is used in systems with cascaded CA82C59s, so as to preserve the interrupt priorities within each slave, as well as

within the master. The Special Fully Nested Mode is programmed by setting the SFNM bit in the ICW4 word in both the master and the slave during initialization. This allows interrupt requests of a higher level than the one being serviced to be accepted by the master from the same slave. That is, the slave is not locked out from the priority logic in the master, and higher priority interrupts within the slave will be recognized by the master, which will generate an interrupt to the CPU.

Caution should be exercised in this mode during the End Of Interrupt processing. It is essential that the system software check whether or not the interrupt just serviced was the *only* one from that slave. After the first non-specific EOI has been issued to the slave, the CPU should read the slave's ISR and check that no other bits are set (ISR = 0). Only if the slave ISR is zero, should a non-specific EOI be sent to the master to complete the interrupt sequence. If bits are set in the slave ISR, no EOI should be sent to the master.

#### **Polling Mode**

The Polling Mode is used to bypass the CA82C59A Interrupt control logic in favour of CPU software control over interrupt request processing. This allows systems to be built up with more than one master CA82C59A, and consequently, the system can contain more than 64 interrupt priority levels (since each master can handle 64 levels individually). In this case, the CPU polls each master looking for the highest priority interrupt request within the realm of each master.

In the *Polling Mode*, the INT outputs of the CA82C59A masters, and the INT input of the CPU are disabled. Interrupt service to individual peripheral devices is accomplished in system software by using the *Poll Command* (Bit 'P' = 1 in OCW<sub>3</sub>). When a poll command has been issued, the CA82C59A waits for the CPU to perform a register read. This read is treated by the CA82C59A as an interrupt acknowledge, and it sets the appropriate ISR bit and determines the priority level if there is an interrupt request pending. It then outputs the polling data byte onto the data bus (see Figure 19), including the binary code of the highest priority level requesting service. The CPU then processes the interrupt according to the polling data read, terminating the interrupt sequence with an EOI.



#### NOTES:

- 1. W<sub>0</sub> W<sub>2</sub> is binary code of highest priority level requesting service.
- 2. INT is equal to one (1) if there is an interrupt.

Figure 19: POLL COMMAND

#### **Rotation Modes**

The different Rotation Modes allow the interrupt request priorities to be changed either automatically, or under software control. This is particularly useful for situations where there are a number of equal priority devices, or where a particular application may call for a specific priority change.

#### **Automatic Rotation Mode**

The Automatic Rotation Mode is recommended where there are a number of equal priority devices. In this mode the device is assigned the lowest priority immediately after it has had an interrupt request serviced. Its priority is subsequently increased as other devices have their interrupt requests serviced, and are then rotated to the bottom of the priority list. In the worst case, a device would have to wait for a maximum of seven other device interrupts of equal priority to be serviced once, before it was serviced. The effect of rotation on interrupt priority is illustrated in Figure 20.

Automatic Rotation can be activated in one of two ways, both using the command word OCW<sub>2</sub>, and both combined with EOI modes:

- Rotation in Non-specific EOI Mode (R = 1, SL = 0 and EOI = 1)
- Rotation in Automatic EOI Mode (R = 1, SL = 0 and EOI = 0). This mode must be cleared by the CPU (accomplished by sending OCW<sub>2</sub> with: R = 0, SL = 0 and EOI = 1.

#### Specific Rotation Mode

The Specific Rotation Mode provides a mechanism to arbitrarily change interrupt priority assignments. This is accomplished by programming the lowest priority interrupt request line (specified by bits  $L_{0-2}$  in OCW<sub>2</sub>), thereby fixing the other priorities. That is, if  $IR_4$  is programmed as the lowest priority device, then  $IR_5$  will have the highest priority.

Caution: Because this change in priority levels is different from the normal Fully Nested Mode, it is essential that the user manage the interrupt nesting via the system software.

Specific rotation can be activated in one of two ways, both using the command word  $OCW_2$ :

The Set Priority command is issued in OCW<sub>2</sub> with:
 R = 1, SL = 1 and L<sub>0.2</sub> equal to the binary code of the lowest priority device.

As part of the Specific EOI Mode, with OCW<sub>2</sub>, (Rotate on Specific EOI command) values: R = 1, SL = 1, EOI = 1 and L<sub>0-2</sub> equal to the binary priority level code of the lowest priority device. When the specific EOI is issued by the CPU, the CA82C59A resets the ISR bit designated by bits L<sub>0-2</sub> in OCW<sub>2</sub>, then rotates the priorities so that the interrupt just reset becomes the lowest priority.



BEFORE ROTATE: IR4 is the highest priority requiring service

AFTER ROTATE: IR4 was serviced, all other priorities have been rotated correspondingly



Figure 20: EFFECT OF ROTATION



a) Rotate in Automatic EOI Mode (Set)



b) Rotate in Automatic EOI Mode (Reset)



c) Rotate on Non-specific EOI Command



d) Rotate on Specific EOI Command



e) Set Priority Command (Specific Rotation)

Figure 21: ROTATION COMMANDS

#### **System Modes**

The CA82C59A *must* operate in the system mode that corresponds to the processor type used in the system. *Call Mode* is used for 8085 type systems (and features an interrupt cycle controlled by three INTA signals), while *Vector Mode* is used for more sophisticated 8088/86 and 80286/386 type sytems (and features an interrupt cycle controlled by only two INTA signals). These modes are described in more detail back in the Operational Description section.

#### **Trigger Modes**

In the CA82C59A, the interrupt request lines (IR $_{0.7}$ ) can be programmed for either edge or level triggering sensitivity, with the requirement that all IR lines must be in the same mode. That is, all edge triggered, or all level triggered. Figure 23 illustrates the priority cell diagram which shows a conceptual circuit of the level sensitive and edge sensitive input circuitry of the IR lines.

Note that to ensure a valid interrupt request is registered by the CA82C59A, it is essential that the IR input remain HIGH until after the first INTA has been received. In both modes, if the IR input goes LOW before this time, the interrupt will be registered as a default IR7 regardless of which IR input initiated the interrupt request. This default IR7 can be used to detect (and subsequently ignore) spurious interrupt signals such as those caused by glitches or noise on the IR input lines. The technique is described below:

- If the IR<sub>7</sub> input is not used, it can be assigned solely to intercepting spurious interrupt requests, invoking a simple service routine that contains a return only, thus effectively ignoring the interrupt.
- If IR<sub>7</sub> is used for a peripheral interrupt, a default IR<sub>7</sub> is detected with the extra step of reading the ISR. A normal IR<sub>7</sub> interrupt causes the corresponding bit to be set in the ISR, while a default IR<sub>7</sub> interrupt does



Figure 22: TRIGGER MODE TIMING

not. It is necessary that the system software keep track of whether or not the IR<sub>7</sub> service routine has been entered. In the event that another IR<sub>7</sub> interrupt occurs before servicing is complete, it will be a default IR<sub>7</sub> interrupt (and should be ignored).

#### **Edge Triggered Mode**

Programmed by setting the LTIM bit in ICW3: LTIM = 0 for *low-to-high-transition* edge triggering. An interrupt request is detected by a rising edge on an IR line. The IR line <u>must</u> remain HIGH until after the falling edge of the first INTA signal has been received from the CPU. This is required to latch the corresponding IRR bit. It is recommended that the IR line be kept HIGH to help filter out noise spikes that might cause spurious interrupts. To send the next interrupt request, temporarily lower the IR line, then raise it.

#### **Level Triggered Mode**

Programmed by setting the LTIM bit in ICW3: LTIM = 1 for level triggering. An interrupt request is detected by a HIGH level on an IR line. This HIGH level must be maintained until the falling edge of the first INTA signal (as in the edge-triggered mode), to ensure the appropriate IRR bit is set. However, in the level triggered mode, interrupts are requested as long as the IR line remains HIGH. Thus, care should be exercised so as to prevent a stack overflow condition in the CPU.



Figure 23: PRIORITY CELL STRUCTURE

SYSTEMA

SYSTEM B

SYSTEM n

INTERRUPT REQUEST

#### **APPLICATION DIAGRAMS**



Figure 24: CA82C59A IN STANDARD SYSTEM CONFIGURATION

NOTES:

- 1. MASTERICAR2CSBAs IN POLL MODE
- 2. MAXIMUM OF 64 INPUTS PER SYSTEM

MASTER IR INPUTS

3. TOTAL CAPACITY LIMITED BY CPU

Figure 26: MULTIPLE CA82C59A MASTERS IN A POLLED SYSTEM



Figure 25: MULTIPLE CA82C59As IN A CASCADED SYSTEM