## **Programmable Interrupt Controller (PIC)** #### Features: - Compatible with CDP1800 series - Programmable long branch vector address and vector interval - 8 levels of interrupt per chip - Easily expandable - Latched interrupt requests - Hard wired interrupt priorities - Memory mapped - Multiple chip select inputs to minimize address space requirements #### TERMINAL ASSIGNMENT The RCA-CDP1877 and CDP1877C• are programmable 8-level interrupt controllers designed for use in CDP1800-series microprocessor systems. They provide added versatilty by extending the number of permissible interrupts from 1 to N in increments of 8. When a high to low transition occurs on any of the PIC interrupt lines (IRO to IR7), it will be latched and, unless the request is masked, it will cause the INTERRUPT line on the PIC and consequently the INTERRUPT input on the CPU to go low. The CPU accesses the PIC by having interrupt vector register R(1) loaded with the memory address of the PIC. After the interrupt S3 cycle, this register value will appear at the CPU address bus, causing the CPU to fetch an instruction from the PIC. This fetch cycle clears the interrupt request latch bit to accept a new high-to-low transition, and also causes the PIC to issue a long branch instruction (CO) followed by the preprogrammed vector address written into the PIC's address registers, causing the CPU to branch to the address corresponding to the highest priority active interrupt request. Formerly RCA-Dev. Type No. TA10911 and TA10911C, respectively. If no other unmasked interrupts are pending, the INTERRUPT output of the PIC will return high. When an interupt is requested on a masked interrupt line, it will be latched but it will not cause the PIC INTERRUPT output to go low. All pending interrupts, masked and unmasked, will be indicated by a "1" in the corresponding bit of the status register. Reading of the status register will clear all pending interrupt request latches. Several PICs can be cascaded together by connecting the INTERRUPT output of one chip to the CASCADE input of another. Each cascaded PIC provides 8 additional interrupt levels to the system. The number of units cascadable depends on the amount of memory space and the extent of the address decoding in the system. Interrupts are prioritized in descending order; $\overline{IR7}$ has the highest and $\overline{IR0}$ has the lowest priority. The CDP1877 and CDP1877C are functionally identical. They differ in that the CDP1877 has a recommended operating voltage range of 4 to 10.5 volts, and the CDP1877C has a recommended operating voltage range of 4 to 6.5 volts. They types are supplied in 28-lead dual-in-line ceramic packages (D suffix), and 28-lead dual-in-line plastic packages (E suffix). ### Programmable Interrupt Controller (PIC) Programming Model | BUS 7 | | | | | | | BUS 0 | | |-------|-----|-----|---------------|---------------|-----|----|----------|------------| | | | | PAGE R | PAGE REGISTER | | | | | | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 | WRITE ONLY | | BUS 7 | | | | | | | BUS 0 | <u>-</u> . | | | | | CONTROL | REGISTER | | | i | ] | | B7 | B6 | B5 | B4 | В3 | B2 | B1 | B0 | WRITE ONLY | | BUS 7 | | | | | | | BUS 0 | - | | | | | MASK REGISTER | | | 1 | <u> </u> | ] | | M7 | М6 | M5 | M4 | M3 | M2 | M1 | MO | WRITE ONLY | | BUS 7 | | | | | | | BUS 0 | • | | | | | STATUS | REGISTER | 1 | | | 1 | | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | READ ONLY | | BUS 7 | | | | | | | BUS 0 | • | | | | | POLLING | REGISTER | | | l | 1 | | P7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 | READ ONLY | ## MAXIMUM RATINGS, Absolute-Maximum Values: | DC SUPPLY-VOLTAGE RANGE, (V <sub>DD</sub> ) | | |-----------------------------------------------------------------------------|---------------------------------------| | (Voltage referenced to VSS terminal) | | | CDP1877 | | | CDP1877C | 0.5 to +7 V | | INPUT VOLTAGE RANGE, ALL INPUTS | -0.5 to Vpp +0.5 V | | DC INPUT CURRENT, ANY ONE INPUT | ±10 mA | | POWER DISSIPATION PER PACKAGE (PD): | | | For TA=-40 to +60°C (PACKAGE TYPE E) | 500 mW | | For TA=+60 to +85°C (PACKAGE TYPE E) | Derate Linearly at 12 mW/°C to 200 mW | | For T <sub>A</sub> =-55 to +100°C (PACKAGE TYPE D) | 500 mW | | For T <sub>A</sub> =+100 to 125°C (PACKAGE TYPE D) | Derete Linearly at 12 mW/°C to 200 mW | | DEVICE DISSIPATION PER OUTPUT TRANSISTOR | Derate Linearly at 12 mm/ C to 200 mw | | FOR TA=FULL PACKAGE-TEMPERATURE RANGE (All Package Types) | 100 -W | | OPERATING-TEMPERATURE RANGE (TA): | | | PACKAGE TYPE D | | | | | | PACKAGE TYPE E | | | STORAGE-TEMPERATURE RANGE (Tstg) | 65 to +150°C | | LEAD TEMPERATURE (DURING SOLDERING): | | | At distance 1/16 $\pm$ 1/32 in. (1.59 $\pm$ 0.79 mm) from case for 10 s max | +265°C | | | | ## STATIC ELECTRICAL CHARACTERISTICS at TA=-40 to +85° C, VDD $\pm$ 5%, Except as noted | | | CC | NDITIO | NS | | | LIM | IITS | | | | |------------------------|-------------------|---------|--------|-----|-------|-------------------|------|----------|-------------------|------|---------------| | CHARACTERIST | IC | ٧o | VIN | VDD | | CDP1877 | | | CDP1877 | C | UNITS | | | | (V) | (V) | (V) | Min. | Typ.* | Max. | Min. | Typ.* | Max. | | | Quiescent Device | | | 0, 5 | 5 | _ | 0.01 | 50 | <b>—</b> | 0.02 | 200 | | | Current | םס <sup>ו</sup> | | 0, 10 | 10 | _ | ] 1 | 200 | - | _ | _ | μΑ | | Output Low Drive | | 0.4 | 0, 5 | 5 | 1.6 | 3.2 | Γ – | 1.6 | 3.2 | | | | (Sink) Current | lOL | 0.5 | 0, 10 | 10 | 2.6 | 5.2 | | _ | _ | _ | m <b>A</b> | | Output High Drive | | 4.6 | 0, 5 | 5 | -1.15 | -2.3 | - | -1.15 | -2.3 | _ | IIIA | | (Source) Current | ЮН | 9.5 | 0, 10 | 10 | -2.6 | -5.2 | _ | _ | _ | _ | | | Output Voltage | | _ | 0, 5 | 5 | _ | 0 | 0.1 | | 0 | 0.1 | | | Low-Level | V <sub>OL</sub> ‡ | _ | 0, 10 | 10 | _ | 0 | 0.1 | _ | _ | _ | | | Output Voltage | | | 0, 5 | 5 | 4.9 | 5 | _ | 4.9 | 5 | | | | High Level | ∨он‡ | - | 0, 10 | 10 | 9.9 | 10 | - | _ | | _ | v | | Input Low | | 0.5,4.5 | _ | 5 | _ | | 1.5 | _ | | 1.5 | v | | Voltage | ٧ <sub>IL</sub> | 0.5,9.5 | _ | 10 | _ | - | 3 | ! - ! | | _ | | | Input High | | 0.5,4.5 | _ | 5 | 3.5 | _ | | 3.5 | | | | | Voltage | ٧н | 0.5,9.5 | - 1 | 10 | 7 | _ | | 1 - 1 | _ | _ | | | Input Leakage | | Any | 0, 5 | 5 | _ | _ | ±1 | | _ | ±1 | | | Current | IIN | Input | 0, 10 | 10 | _ | _ | ±2 | _ | _ | _ | | | 3-State Output Leakage | | 0, 5 | 0, 5 | 5 | | ±10 <sup>-4</sup> | ±1 | | ±10 <sup>-4</sup> | ±1 | μΑ | | Current | IOUT | 0, 10 | 0, 10 | 10 | _ | ±10 <sup>-4</sup> | ±10 | - | _ | | | | Input Capacitance | CIN | _ | _ | _ | _ | 5 | 7.5 | _ | 5 | 7.5 | - <del></del> | | Output Capacitance | COUT | | | - | | 10 | 15 | _ | 10 | 15 | pF | | Operating Device | loorn# | | | 5 | _ | 0.5 | 1.0 | 1 - | 0.5 | 1.0 | | | Current | OPER# | | | 10 | | 1.9 | 3.0 | | _ | _ | mA | <sup>\*</sup>Typical values are for TA=25°C and nominal VDD. <sup>‡&</sup>lt;sub>IOL</sub>=I<sub>OH</sub>=1 μA. <sup>#</sup> Operating current measured under worst-case conditions in a 3.2-MHz CDP1802A system: one PIC access per instruction cycle. OPERATING CONDITIONS at $T_A$ =Full Package-Temperature Range. For maximum reliability, operating conditions should be selected so that operation is always within the following ranges: | | LIMITS | | | | | | |----------------------------|--------|-----------------|-------|------|-----|--| | CHARACTERISTIC | CDF | CDP | UNITS | | | | | | Min. | Max. | Min. | Max. | l | | | DC Operating Voltage Range | 4 | 10.5 | 4 | 6.5 | T v | | | Input Voltage Range | VSS | V <sub>DD</sub> | VSS | VDD | 7 ° | | ## Functional Definitions for CDP1877 and CDP1877C Terminals | TERMINAL | USAGE | TYPE | |----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | V <sub>DD</sub> -V <sub>SS</sub> | Power | | | BUS0BUS7 | Data bus—Communicates information to and from CPU | Bidirectional | | IR0—IR7 | Interrupt Request Lines | Input | | INTERRUPT | Interrupt to CPU | Output | | MRD, MWR | Read/Write controls from CPU | Input | | TPA, TPB | Timing pulses from CPU | Input | | cs, <del>cs</del> | Chip selects, Enable Chip if valid during TPA | Input | | CS/Ax, CS/Ay | Used as a Chip Select during TPA and as a Register address during<br>Read/Write Operations | Input | | CASCADE | Used for cascading several PIC units. The INTERRUPT output from a higher priority PIC can be tied to this input, or the input can be tied to Vdd if cascading | | | | is not used. | Input | ## PIC Programming Model ### **INTERNAL REGISTERS** The PIC has three write-only programmable registers and two read-only registers. #### Page Register This write only register contains the high order vector address the device will issue in response to an interupt request. This high-order address will be the same for any of the 8 possible interrupt requests; thus, interrupt vectoring differs only in location within a specified page. | BUS 7 | | | | | | | BUS 0 | | |-------|-----|-----|----------|------------|-----|----|-------|------------| | 1 | | | PAGE REG | ISTER BITS | | | | WDITE ON V | | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 | WRITE ONLY | #### **Control Register** The upper nibble of this write-only register contains the low order vector address the device will issue in response to an interrupt request. The lower nibble is used for a master interrupt reset, master mask reset and for interval select. THE LOW ORDER VECTOR ADDRESS WILL BE SET ACCORDING TO THE TABLE BELOW: | INTERVAL SELECTED- | | LOW ADD | RESS BITS | | |--------------------|---------|---------|-----------|--------| | NO. OF BYTES | BIT B7 | BIT B6 | BIT B5 | BIT B4 | | 2 | SETS A7 | SETS A6 | SETS A5 | SET A4 | | 4 | SETS A7 | SETS A6 | SETS A5 | X | | 8 | SETS A7 | SETS A6 | X | Ŷ | | 16 | SETS A7 | Χ | X | Ŷ | X=DON'T CARE NOTE: All DON'T CARE Addresses and Addresses A0-A3 are determined by interrupt request. | CMOS | <b>Peripherals</b> | | |------|--------------------|--| | | | | #### Mask Register A "1" written into any location in this write only register will mask the corresponding interrupt request line. All interrupt inputs (except CASCADE) are maskable. | 1 | BUS 7 | | | | | | | BUS 0 | | |---|-------|----|----|----|------|----|----|-------|------------| | | | | | • | BITS | | | | WRITE ONLY | | Į | M7 | M6 | M5 | M4 | М3 | M2 | M1 | M0 | White ONE | ### Status Register In this read only register a "1" will be present in the corresponding bit location for every masked or unmasked pending interrupt. | _ | BUS 7 | | | | | | | BUS 0 | | |---|-------|----|----|-------|--------|----|----|-------|-----------| | | | | | STATL | S BITS | | | | 1 | | L | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | READ ONLY | ## **Polling Register** This read only register provides the low order vector address and is used to identify the source of interrupt if a polling technique, rather than interrupt servicing, is used. | BUS 7 | | | | | | | BUS 0 | | |-------|----|----|--------------|---------------|----|----|-------|-----------| | P7 | P6 | P5 | POLLIN<br>P4 | NG BITS<br>P3 | P2 | P1 | P0 | READ ONLY | ### **RESPONSE TO INTERRUPT (AFTER S3 CYCLE)** The PIC's response to interrogation by the CPU is always 3 bytes long, placed on the data bus in consecutive bytes in the following format: #### First (instruction) Byte: LONG BRANCH INSTRUCTION - CO (Hex) | BUS 7 | | | | | | | BUS 0 | |-------|---|---|---|---|---|---|-------| | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | #### Second (High-Order Address) Byte This byte is the High-Order vector Address that was written into the PIC's Page Register by the user. The PIC does not alter this value in any way. #### **High-Order Vector Address** | BUS 7 | | | | | | | BUS 0 | |-------|-----|-----|-----|-----|-----|----|-------| | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 | | 434 | | |-----|--| | | | ## Third (Low-Order Address) Bytes | INTERVAL 2<br>BUS 7 | ?<br>_ | | | | | | BUS 0 | |---------------------|-----------|---------------------------------------|--------------|----------|----------|----------------|-----------| | A7 | A6 | A5 | A4 | //// | X/:// | 1/10/ | 0 | | INTERVAL 4<br>BUS 7 | | | | <u> </u> | <u> </u> | <u>///:º//</u> | 1 U BUS 0 | | A7 | A6 | A5 | 12 | | 10/ | 0 | 0 | | INTERVAL 8<br>BUS 7 | | · · · · · · · · · · · · · · · · · · · | | | | | BUS 0 | | A7 | A6 | 12 | <u>//i//</u> | /10/ | 0 | 0 | 0 | | BUS 7 | 0<br>//// | <i>V777</i> | | | | | BUS 0 | | A7 | /12/ | 1/11/2 | /10/ | 0 | 0 | 0 | 0 | Indicates active interrupt input number (binary 0 to 7). Bits indicated by Ax (x=4 to 7) are the same as programmed into the Control Register. All other bits are generated by the PIC. ## REGISTER ADDRESSES In order to read/write or obtain an interrupt vector from any PIC in the system, all chip selects (CS/Ax, CS/Ay, CS, CS) must be valid during TPA. CS/Ax and CS/Ay are multiplexed addresses; both must be high during TPA, and set according to this table during TPB to access the proper register. | CS/Ax | CS/Ay | RD | WR | ACTION TAKEN | |-------|-------|----|----|-----------------------------------------------------------------------------------------------------------------------| | 1 | 0 | 0 | 1 | READ Long Branch instruction and vector for highest priority unmasked interrupt pending. | | 11 | 0 | 1 | 0 | WRITE to Page Register | | 0 | 1 | 1 | 0 | WRITE to Control Register | | 0 | 0 | 0 | 1 | READ Status Register | | 0 | 0 | 1 | 0 | WRITE to Mask Register | | 0 | 1 | 0 | 1 | READ Polling Register (Used to identify INTERRUPT source if Polling technique rather than INTERRUPT service is used.) | | 1 | 1 | X | Х | Unused condition | ### **PIC Application Examples** Example !- Single PIC Application Fig. 2 shows all the connections required between CPU and PIC to handle eight levels of interrupt control. Fig. 2 - PIC and CPU connection diagram. #### **Programming** Programming the PIC consists of the following steps: - 1. Disable interrupt at CPU. - 2. Reset Master Interrupt Bit, B3, of Control Register. - Write a "1" into the Interrupt Input bit location of the Mask Register, if masking is desired. - Write the High-Order Address byte into the Page Register. - Write the Low-Order Address and the vector interval into the Control Register. - Program R(1) of the CPU to point to the PIC so that the Long Branch instruction can be read from the PIC during the Interrupt Service routine. Values for Example I with LOCATION 84E0 arbitrarily chosen as the Vector Address with interval of eight bytes, IR4 pending, is shown in Table I. In deriving the above addresses, all DON'T CARE bits are assumed to be 0. When an INTERRUPT $(\overline{IR4})$ is received by the CPU, it will address the PIC and will branch to the interrupt service routine. The three bytes generated by the PIC will be: 1st Byte=C0<sub>H</sub> 2nd Byte=84<sub>H</sub> 3rd Byte=E0<sub>H</sub> | Table 1 | I — Register | Address | Values | |---------|--------------|---------|--------| | | | | | | REGISTER | REGISTER ADDRESS | OPERATION | DATA BYTE | | | |---------------|------------------|-----------|-----------------|--|--| | MASK | E000H | WRITE | 00H | | | | CONTROL | E040H | WRITE | CEH | | | | PAGE | E080H | WRITE | 84H | | | | STATUS | E000H | READ | 10 <sub>H</sub> | | | | POLLING | E040H | READ | E0H | | | | R(1) (IN CPU) | E080H | | _ | | | ## Example II—Multi-PIC Application Fig. 3 shows all the connections required between CPU and PICs to handle sixteen levels of interrupt control. Fig. 3 - PICs and CPU connection diagram. ### **Register Address Assignments** The low-byte register address for any WRITE or READ operation is the same as shown in Table I. The high-byte register differs for each PIC because of the linear addressing technique shown in the example: PIC 1=111XXX01 (E1<sub>H</sub> FOR X=0) PIC 2=111XXX10 (E2<sub>H</sub> FOR X=0) The R(1) vector address is unchanged. This address will select both PICs simultaneously (R(1).1=111XXX00=E0<sub>H</sub>). Internal CDP1877 logic controls which PIC will respond when an interrupt request is serviced. ### **Additional PIC Application Comments** The interval select options provide significant flexibility for interrupt routine memory allocations: - The 2-byte interval allows one to dedicate a full page to interrupt servicing, with variable space between routines, by specifying indirect vectoring with 2 byte short branch instructions on the current page. - The 4-byte interval allows for a 3 byte long branch to any location in memory where the interrupt service routine is located. The branch can be preceded by a Save Instruction to save previous contents of X and P on the stack. ■ The 8-byte and 16-byte intervals allow enough space to perform a service routine without indirect vectoring. The amount of interval memory can be increased even further if all 8 INTERRUPTS are not required. Thus a 4-level interrupt system could use alternate IR Inputs, and expand the interval to 16 and 32 bytes, respectively. The 4 Chip Selects allow one to conserve total allotted memory space to the PIC. For one chip, a total of 4 address lines could be used to select the device, mapping it into as little as 4-K of memory space. Note that this selection technique is the only one that allows the PIC to work properly in the system: I/O mapping cannot be used because the PIC must work within the CDP1800 interrupt structure to define the vector address. Decoded signals also will not work because the chip selects must be valid on the trailing edge of TPA. DYNAMIC ELECTRICAL CHARACTERISTICS at T\_A=-40 to +85° C, V\_DD $\pm 5\%$ , t\_r,t\_f=20 ns, V\_IH=0.7 V\_DD, V\_IL=0.3 V\_DD, C\_L=50 pF | | | | LIMITS | | | | | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----|---------|------|----------|----------|-------|------|-----| | CHARACTERISTIC | | VDD | CDP1877 | | CDP1877C | | UNITS | | | | | | (V) | Min. | Тур. | Max. | Min. | Typ.* | Max. | | | Address to TPA Setup Time | tAS | 5 | 60 | _ | _ | 60 | _ | _ | | | | 'AS | 10 | 40 | | | | | | | | Address to TPA Hold Time | tau | 5 | 60 | _ | _ | 60 | _ | l – | | | | tAH_ | 10 | 40 | | | | | _ | | | Data Valid after TPB | * | 5 | 370 | _ | _ | 370 | _ | _ | | | | †DTPB | 10 | 210 | 310 | l – . | <b> </b> | | _ | | | Data Hold Time from Write | * | 5 | 30 | _ | | 30 | _ | - | | | The rest of the second | tHW | 10 | 40 | _ | | _ | _ | _ | | | Address to Valid Data Access Time | <sup>t</sup> DR | 5 | _ | 340 | 490 | _ | 340 | 490 | ns | | THE PART PART ACCOUNTY THE | | 10 | _ | 125 | 230 | _ | _ | _ | 113 | | Data Setup Time to Write | tpsu | 5 | 0 | _ | _ | 0 | _ | _ | | | | | 10 | 0 | _ | l – | - | _ | | | | Address Hold from TPB | * | 5 | 80 | _ | _ | 80 | _ | - | | | | tHTPB | 10 | 40 | ·- | _ | ] — | _ | | | | Minimum MWR Pulse Width | t <del>MWR</del> | 5 | 130 | _ | _ | 130 | _ | _ | | | WINDER WITTER CISE WICEII | | 10 | 60 | l – | - | l – | - | _ | | | Minimum IR Pulse Width | •=== | 5 | 130 | _ | | 130 | | -=: | | | William III Goo Width | tinx | 10 | 60 | l – | _ | _ | _ | l — | | $<sup>^{\</sup>bullet}$ Typical values are for TA=25°C and VDD $\pm 5\%.$ Fig. 4 - Timing waveforms for CDP1877.