

950 Rittenhouse Rd., Norristown, PA 19403 • Tel.: 215/666-7950 • TWX: 510/660-4168

# **6525 TRI-PORT INTERFACE**

## CONCEPT ...

The 6525 TRI-PORT Interface (TPI) is designed to simplify the implementation of complex I/O operations in microcomputer systems. It combines two dedicated 8-bit I/O ports with a third 8-bit port programmable for either normal I/O operation or priority interrupt/handshaking control. Depending on the mode selected, the 6525 can provide 24 individually programmable I/O lines or 16 I/O lines, 2 handshake lines and 5 priority interrupt inputs.

#### **FEATURES:**

- 24 individually programmable I/O lines or 16 I/O lines, 2 handshake lines and 5 interrupt inputs.
- Priority or non-priority interrupts
- Automatic handshaking
- Completely static operation
- Two TTL Drive Capability
- 8 directly addressable registers
- 1 MHz, 2MHz and 3MHz operation

| Ś   | Construction of the owner | 6525 Addressing                  |
|-----|---------------------------|----------------------------------|
| 65  | 25 REGISTE                | RS (Direct Addressing)           |
| *00 | IQ RO                     | PRA-Port Register A              |
| 000 | )1 🔪 🖁 🖪 🔪                | PRB-Port Register B              |
| 01  | 0 R2                      | PRC-Port Register C              |
| 01  | 1 R3                      | DDRA – Data Direction Register A |
| 10  | 0 R4                      | DDRB – Data Direction Register B |
| 10  | 1 R5                      | DDRC-Data Direction Register     |
|     | 2                         | C/Interrupt Mask Register        |
| 11  | 0 R6                      | CR-Control Register              |
| 11  | 1 R7                      | AIR – Active Interrupt Register  |
| 1*  | NOTE: RS2, R              | S1, RS0 respectively             |



## 6525 PIN CONFIGURATION

| VSS   | 1  | 40 | DB7 |
|-------|----|----|-----|
| PAO   | 2  | 39 | DB6 |
| PA1   | 3  | 38 | DB5 |
| PA2   | 4  | 37 | DB4 |
| PA3   | 5  | 36 | DB3 |
| PA4   | 6  | 35 | DB2 |
| PA5   | 7  | 34 | DB1 |
| PA6   | 8  | 33 | DB0 |
| PA7   | 9  | 32 | PC7 |
| PB0   | 10 | 31 | PC6 |
| PB1   | 11 | 30 | PC5 |
| PB2   | 12 | 29 | PC4 |
| PB3   | 13 | 28 | PC3 |
| PB4   | 14 | 27 | PC2 |
| PB5   | 15 | 26 | PC1 |
| PB6   | 16 | 25 | PCO |
| PB7   | 17 | 24 | RSO |
| CS    | 18 | 23 | RS1 |
| WRITE | 19 | 22 | RS2 |
| VDD   | 20 | 21 | RST |



## **MAXIMUM RATINGS**

| RATING                      | SYMBOL           | VALUE         | UNIT            |
|-----------------------------|------------------|---------------|-----------------|
| SUPPLY VOLTAGE              | V <sub>cc</sub>  | -0.3 to +7.0  | V <sub>dc</sub> |
| INPUT VOLTAGE               | V <sub>in</sub>  | -0.3 to +7.0  | V <sub>dc</sub> |
| OPERATING TEMPERATURE RANGE | Τ <sub>Α</sub>   | 0 to +70      | °C              |
| STORAGE TEMPERATURE RANGE   | T <sub>stg</sub> | - 55 to + 150 | °C              |

This device contains circuitry to protect the inputs against damage due to high static voltages, however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this circuit.

## CHARACTERISTICS (V<sub>CC</sub> = 5.0 V $\pm$ 5%, V<sub>SS</sub> = 0V, T<sub>A</sub> = 0° to 70°C)

| CHARACTERISTIC                                                                                                                                                                    | SYMBOL           | MIN             | TYP    | MAX   | UNIT |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------|--------|-------|------|
| Input High Voltage (Normal Operating Levels)                                                                                                                                      | VIH              | + 2.0           | 1.5    | Vcc   | Vdc  |
| Input Low Voltage (Normal Operating Levels)                                                                                                                                       | v <sub>IL</sub>  | - 0.3           | 1.2    | + .8  | Vdc  |
| Input Leakage Current<br>Vin = 0 to 5.0 Vdc<br>WRITE RST, CS, RS <sub>0</sub> -RS <sub>2</sub>                                                                                    | <sup>I</sup> IN  | 0               | ± 1.0  | ± 2.5 | μAdc |
| Three-State (Off State) Input Current<br>(V <sub>in</sub> = 0.4 to 2.4 Vdc, V <sub>CC</sub> = max)<br>D0-D7, PA0-PA7, PB0-PB7. PC0-PC7                                            | ITSI             | 0               | ±2.0   | ± 10  | μAdc |
| Output High Voltage ( $V_{CC}$ = min, Load = 200 $\mu$ Adc)                                                                                                                       | VOH              | 2.4             | 3.5    | Vcc   | Vdc  |
| Output Low Voltage<br>(V <sub>CC</sub> = min, Load = 3.2 mAdc)                                                                                                                    | VOL              | V <sub>SS</sub> | 0.2    | 0.4   | Vdc  |
| Output High Current (Sourcing)<br>(V <sub>OH</sub> = 2.4 Vdc)                                                                                                                     | ЮН               | -200            | - 1000 |       | μAdc |
| Output Low Current (Sinking)<br>(V <sub>OL</sub> = 0.4 Vdc)                                                                                                                       | IOL              | 3.2             | _      |       | mAdo |
| Supply Current                                                                                                                                                                    | <sup>1</sup> CC  | -               | 50     | 100   | mA   |
| Input Capacitance<br>( $V_{in} = 0V$ , $T_A = 25^{\circ}C$ , $f = 1.0 \text{ MHz}$ )<br>D0-D7, PAO-PA7, PBO-PB7, PCO-PC7 PC7,<br>WRITE RST, RS <sub>0</sub> -RS <sub>2</sub> , CS | C <sub>in</sub>  |                 | 7      | 10    | pF   |
| Output Capacitance<br>( $V_{in} = 0V, T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ )                                                                                                   | C <sub>out</sub> | _               | 7      | 10    | pF   |

Note: Negative sign indicates outward current flow, positive indicates inward flow.



## **READ CYCLE**

|                  |                                    | 11  | ۱Hz | 21  | л́Нz | 3MHz |     |       |
|------------------|------------------------------------|-----|-----|-----|------|------|-----|-------|
| Symbol           | Parameter                          | MIN | MAX | MIN | MAX  | MIN  | MAX | UNITS |
| <sup>t</sup> RC  | Read Cycle Time                    | 700 |     | 350 |      | 220  |     | nS    |
| tACC             | Access time                        | 450 |     | 225 |      | 160  |     | nS    |
| tCO              | Chip Select to Output Valid        | 450 |     | 225 |      | 160  |     | nS    |
| tOTD             | Chip Deselected to Output Off      | 0   | 100 | 0   | 100  | 0    | 100 | nS    |
| <sup>t</sup> OHA | Output Hold From<br>Address Change | 50  |     | 50  |      | 50   |     | nS    |
| <b>t</b> DAR     | Peripheral Data Set-Up             | 120 |     | 60  |      | 40   |     | nS    |
| <sup>t</sup> DHR | Peripheral Data Hold               | 0   |     | 0   |      | 0    |     | nS    |
| tAWR             | Write to Address Setup             | 0   |     | 0   |      | 0    |     | nS    |
| tWAR             | Write to Address Hold              | 0   |     | 0   | 8    | 0    |     | nS    |

## WRITE CYCLE

|        |                              | 1N   | 1Hz | 2N  | IHz | 3N  | IHz |       |
|--------|------------------------------|------|-----|-----|-----|-----|-----|-------|
| Symbol | Parameter                    | MIN  | MAX | MIN | MAX | MIN | MAX | UNITS |
| tWC    | Write Cycle Time             | 700  |     | 350 |     | 220 |     | nS    |
| taw    | Address to write set-up time | 0    |     | 0   |     | 0   |     | nS    |
| tw     | Write Pulse Width            | 450  | 1   | 225 |     | 160 |     | nS    |
| tWR    | Write Release Time           | 250  |     | 150 |     | 90  |     | nS    |
| tDW    | Data to Write Overlap        | 150  |     | 75  |     | 75  |     | nS    |
| tDH    | Data Hold                    | 50   |     | 40  |     | 40  |     | nS    |
| tWD    | Write to Peripheral Output   | 1000 |     | 500 |     | 330 |     | nS    |
|        |                              |      |     |     |     |     |     |       |

|                                          | e               | 6525            | Interr          | nal Re          | giste          | rs              |                |                |
|------------------------------------------|-----------------|-----------------|-----------------|-----------------|----------------|-----------------|----------------|----------------|
|                                          | D7              | D6              | D5              | D4              | D3             | D2              | D1             | DO             |
| CR                                       | CB <sub>1</sub> | CB <sub>0</sub> | CA <sub>1</sub> | CA <sub>0</sub> | IE4            | IE <sub>3</sub> | IP             | MC             |
| AIR                                      |                 |                 |                 | A <sub>4</sub>  | A <sub>3</sub> | A <sub>2</sub>  | A <sub>1</sub> | A <sub>0</sub> |
| $\frac{\text{DDRC}}{\text{When MC}} = 1$ |                 |                 |                 | M₄              | M₃             | M <sub>2</sub>  | M <sub>1</sub> | M <sub>o</sub> |
| PRC When $MC = 1$                        | СВ              | CA              | ĪRQ             | I <sub>4</sub>  | l <sub>3</sub> | l <sub>2</sub>  | I <sub>1</sub> | lo             |

## CA, CB Functional Description

## CA OUTPUT MODES

| CA <sub>1</sub><br>0 | CA₀<br>0 | MODE<br>"Handshake"<br>on Read | DESCRIPTION<br>CA is set high on an active transition of the $I_3$ interrupt input signal<br>and set low by a microprocessor "Read A Data" operation. This<br>allows positive control of data transfers from the peripheral device to<br>the microprocessor. |
|----------------------|----------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                    | 1        | Pulse Output                   | CA goes low for I $\mu S$ after a "Read A Data" operation. This pulse can be used to signal the peripheral device that data was taken.                                                                                                                       |
| 1                    | 0        | Manual<br>Output               | CA set low.                                                                                                                                                                                                                                                  |
| 1                    | 1        | Manual<br>Output               | CA set high.                                                                                                                                                                                                                                                 |

## **CB OUTPUT MODES**

| CB <sub>1</sub> | CB₀ | MODE                    | DESCRIPTION                                                                                                                                                                                                                                  |
|-----------------|-----|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | 0   | "Handshake"<br>on Write | CB is set low on microprocessor "Write B Data" operation and is set<br>high by an active transition of the I₄ interrupt input signal. This allows<br>positive control of data transfers from the microprocessor to the<br>peripheral device. |
| 0               | 1   | Pulse Output            | CB goes low for I $\mu S$ after a microprocessor "Write B Data" operation. This can be used to signal the peripheral device that data is available.                                                                                          |
| 1               | 0   | Manual<br>Output        | CB set low.                                                                                                                                                                                                                                  |
| 1               | 1   | Manual<br>Output        | CB set high.                                                                                                                                                                                                                                 |

## INTERRUPT MASK REGISTER DESCRIPTION

When the Interrupt Mode is selected (MC = 1), the Data Direction Register for Port C (DDRC) is used to enable or disable a corresponding interrupt input. For example: If  $M_0 = 0$  then  $I_0$  is disabled and any  $I_0$  interrupt latched in the interrupt latch register will not be transferred to the AIR and will not cause IRQ to go low. The interrupt latch can be cleared by writing a zero to the appropriate bit in PRC.

## PORT REGISTER C DESCRIPTION

Port Register C (PRC) can operate in two modes. The mode is controlled by bit MC in register CR. When MC = 0, PRC is a standard I/O port, operating identically to PRA & PRB. If MC = 1, then port register C is used for hand-shaking and priority interrupt input and output.

## PRC When MC = 0:

| PC, | PC | PC <sub>6</sub> | PC <sub>4</sub> | PC <sub>3</sub> | PC <sub>2</sub> | PC <sub>1</sub> | PC <sub>0</sub> |
|-----|----|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
|-----|----|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|

## **PRC When MC** = 1:

| CB | CA | ĪRQ | I4 | l <sub>3</sub> | 12 | 1, | lo |
|----|----|-----|----|----------------|----|----|----|
|----|----|-----|----|----------------|----|----|----|

## INTERRUPT EDGE CONTROL

Bits  $IE_4$  and  $IE_3$  in the control register (CR) are used to determine the active edge which will be recognized by the interrupt latch.

If  $IE_4$  ( $IE_3$ ) = 0 then  $I_4$  ( $I_3$ ) latch will be set on a negative transition of  $I_4$  ( $I_3$ ) input.

If  $IE_4$  ( $IE_3$ ) = 1 then  $I_4$  ( $I_3$ ) latch will be set on a positive transition of the  $I_4$  ( $I_3$ ) input.

All other interrupt latches (I<sub>2</sub>, I<sub>1</sub>, I<sub>0</sub>) are set on a negative transition of the corresponding interrupt input.

| $\begin{vmatrix} I_4 & I_3 & I_2 & I_1 & I_0 \end{vmatrix}$ | Interrupt Latch Register<br>Clears on Read of AIR Using Following Equation:<br>ILR ← ILR (+) AIR |
|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| $\begin{bmatrix} A_4 & A_3 & A_2 & A_1 & A_0 \end{bmatrix}$ | Active Interrupt Register<br>Clears following read of AIR                                        |
| IP                                                          | Interrupt Priority Select<br>IP = 0 No Priority<br>IP = 1 Interrupts Prioritized                 |
|                                                             | 2<br>                                                                                            |

#### FUNCTIONAL DESCRIPTION

#### 1. IP=0:No Priority

In this mode, the first interrupt latched into the Interrupt Latch Register (ILR) is transferred immediately into the Active Interrupt Register (AIR) and IRQ is pulled low (assuming the interrupt isn't masked). Upon reading the AIR, IRQ is reset high, the interrupt latch in the ILR is cleared as described above and the chip is ready to receive new interrupts. In non-priority mode, if multiple interrupts occur simultaneously, all corresponding bits in the AIR will be set. When AIR is read, all associated bits in the ILR will be cleared, therefore it is a software effort to recognize that multiple interrupts have occurred and to service them appropriately.

#### 2. IP=1:Priority Interrupt

In this mode, the interrupts are prioritized in the following order: 14>13>12>11>10.

With priority selected, only one bit in the AIR can be set at any time. When an interrupt occurs, it is latched in the ILR, then priority is compared. If the interrupt is of highest priority, it will be transferred to the AIR and an Interrupt Request will be generated. To fully understand the operation of the priority interrupts, consider the following examples:

A. The least complicated case involves a single interrupt which the processor services completely before another interrupt occurs:

- 1. An interrupt is received on I1.
- 2. Bit I1 is set in the ILR.
- 3. IRQ goes low.
- 4. Bit A1 is set in the AIR.
- 5. Processor responds to IRQ by reading AIR to determine which interrupt has occurred.
- 6. A1 is pushed onto interrupt stack and I1 is cleared.
- 7. A1 is cleared and IRQ goes high.
- 8. Processor services interrupt and signals completion by writing to AIR.
- 9. Interrupt stack automatically pops on write to AIR, completing interrupt sequence.

B. The next case occurs when an interrupt is in the process of being serviced and a lower priority interrupt occurs:

- 1. Interrupt I1 is received and latched.
- 2. IRQ goes low and A1 is set.
- 3. Processor reads AIR and determines I1 has occurred.
- 4. A1 is pushed onto interrupt stack and 11 is cleared.
- 5. A1 is cleared and IRQ goes high.
- 6. Processor services I1, during which an I0 interrupt occurs and is latched.
- 7. The interrupt stack prevents IO from interrupting 11 service.
- 8. Upon completion of I1 service, processor writes AIR, popping interrupt stack.
- 9. IRQ goes low and A0 is set, beginning a new interrupt sequence for I0.
- C. The final case occurs when an interrupt is in the process of being serviced and a higher priority interrupt occurs:
  - 1. Interrupt I1 is received and latched.
  - 2. IRQ goes low and A1 is set.
  - 3. Processor reads AIR and determines I1 has occurred.
  - 4. A1is pushed onto interrupt stack and I1 is cleared.
  - 5. A1 is cleared and IRQ goes high.
  - 6. Processor services I1, during which an I2 interrupt occurs and is latched.
  - 7. IRQ goes low and A2 is set.
  - 8. I1 service is interrupted and processor automatically stacks program counter.
  - 9. Processor reads AIR and determines A2 has occurred.
  - 10. A2 is pushed onto interrupt stack and I2 is cleared.
  - 11. A2 is cleared and IRQ goes high.
  - 12. Processor services 12.
  - 13. Upon completion of I2 service, processor writes AIR, popping the interrupt stack, which restores A1 on top of stack.
  - 14. Return From Interrupt causes processor to resume service of I1 which had been interrupted.
  - 15. Interrupt stack prevents lower priority interrupt of resumed 11 service.
  - 16. Upon completion of 11 service, processor writes AIR, popping interrupt stack and completing interrupt sequence.

**NOTE:** A five-level interrupt stack maintains priority information for all interrupts under service. This stack is pushed on any READ of AIR and popped on any WRITE to AIR. No extraneous reading or writing of AIR should be performed as this will cause unwanted stack operations.

The only time a READ of AIR should occur is in response to an interrupt request.

The only time a WRITE to AIR should occur is to signal the 6525 that an interrupt service is complete.

COMMODORE SEMICONDUCTOR GROUP reserves the right to make changes to any products herein to improve reliability, function or design. COMMODORE SEMICONDUCTOR GROUP does not assume any liability arising ot of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others.

