MPS 6525 TRI-PORT INTERFACE # 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 #### 6525 REGISTERS | | | • | |------|----|---------------------------------------| | .000 | RO | PRA Port Register A | | 001 | R1 | PRB - Port Register B | | 010 | R2 | PRC Port Register C | | 011 | R3 | DDRA - Data Direction Register A | | 100 | R4 | DDRB - Data Direction Register 8 | | 101 | R5 | DDRC - Data Direction Register C | | 110 | R6 | CR - Control Register | | 111 | R7 | AIR - Active Interrupt Register | | | | · · · · · · · · · · · · · · · · · · · | \*NOTE: RS2, RS1, RS0 respectively # SPEED RANGE NO SUFFIX = 450 ns A = 225 ns B = 155 ns PACKAGE DESIGNATOR C = CERAMIC P = PLASTIC # 6525 PIN CONFIGURATION | | | | _ | |-----|----|----|-----| | VSS | 1 | 40 | 087 | | PAQ | 2 | 39 | 086 | | PA1 | 3 | 38 | 085 | | PAZ | 4 | 37 | 084 | | PAJ | 5 | 36 | 083 | | PA4 | 6 | 35 | 082 | | PAS | 7 | 34 | 081 | | PAS | | 33 | 080 | | PA7 | • | 32 | PC7 | | P80 | 10 | 31 | PCS | | PS1 | 11 | 30 | PCS | | P82 | 12 | 29 | PC4 | | PB3 | 13 | 28 | PC3 | | P84 | 14 | 27 | PC2 | | PBS | 15 | 26 | PC1 | | P84 | 16 | 25 | PCO | | P87 | 17 | 24 | ASO | | टड | 18 | 23 | ASI | | R/W | 19 | 22 | RS2 | | VDD | 20 | 21 | RES | # MAXIMUM RATINGS Supply Voltage, VCC Input/Output Voltage, VIN Operating Temperature, TOP Storage Temperature, TSTG -0.3V to +7.0V All inputs contain protection circuitry to prevent damage due to high static discharges. Care should be exercised to prevent unnecessary application of voltages in excess of the allowable limits. # COMMENT Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those indicated in the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability. CHARACTERISTICS (VCC = 5.0 V ± 5%, VSS = 0V. TA = 0" to 70"C" | CHARACTERISTIC | SYMBOL | MIN | TYP | MAX | UNIT | |------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|-------|-------|--------------------------------------------------| | input High Voltage (Normal Operating Levels) | VIH | + 2.0 | 1.5 | VCC | \ \ \ \ \ | | Input Low Voltage (Normal Operating Levels) | ٧١٤ | -0.3 | 12 | +0.8 | <del> </del> | | Input Leekage Current Vin = 0 to 5.0 v WRITE, RES. CS, RS2-RS0 | İIN | 0 | ± 1.0 | ± 25 | μ. | | Three-State (Off-State) Input Current (V <sub>ID</sub> = 0.4 to 2.4 V V <sub>CC</sub> = max) D0-D7, PA0-P7, PB0-PB7, PC0-PC7 | ITSI | 0 | ±20 | ± 10 | μ.Α. | | Output High Voltage<br>(VCC = min, Load = 200 µA) | VOH | 2.4 | 35 | vcc · | . v | | Output Low Valtage (VCC = min. Load = 3.2 mA) | YOL | <b>∨</b> S\$ | 0.2 | 0.4 | V | | Output High Current (Sourcing) (VOH = 2.4 V) | ЮН | -200 | -1000 | - | μ <b>A</b> | | output Low Current (Sinking) (VOL = 0.4 V) | lOL | 32 | - | - | mA | | upply Current | 'cc | - | 50 | 100 | mA. | | Out Capacitance (Vin 0V, TA = 25°C, I = 1.0 MHz) D0-07, PA0-PA7, PB0-PB7, PC0-PC7 WRITE, RES, RS2-RS0, CS | C <sub>in</sub> | <del>-</del> | 7 | 10 | pF | | Vin = 0V, T <sub>A</sub> = 25°C, f = 1.0 MHz | Cout | - | 7 | 10 | oF | Note: Negative sign indicates outward current flow, positive indicates inward flow. # 6525 INTERNAL REGISTERS | | ACOMESS , MEGISTER SITS . | | register mame | COMMENT | | | | | | | | | | |------------|---------------------------|--------------|---------------|---------------------------------------|-----------------|-----|-------|----------|----------------|-----------------|-----------------|---------------------------------------------|-------------------------------------------------------| | <b>6</b> 2 | RS1 | <b>NOO</b> - | MC | 92 | 06 | 06 | 04 | <u> </u> | OR | 01 | 00 | | | | 0 | ٥ | 0 | X | PAT | PAG | PAS | PA4 | PA3 | PAZ | PAT | PAQ | Port Register & (PRA) Port Register & (PRS) | | | ) | ā | 1 | X | PB7 | PS | P55 | P8. | PBj | PB? | 751 | P80 | | | | | i | 0 | 0 | PC7 | PC6 | PCs | PC4 | PC 3 | PC | FC1 | PCO | Port Register C (PRC) | Handshake and Internot Lateres (MODE 1 | | | 1 | ò | 1 | C | CA | HO | II.a | 163 | ILZ | 161 | ,ω | 1 | O-input 1-Output | | | 1 | Ĭ | X | OAT | DAG | DAg | DA4 | DA3 | DAZ | QA <sub>1</sub> | | Register A (DORA) | | | ) | 0 | 0 | x | 087 | 086 | 065 | 084 | 083 | 082 | 061 | 000 | 1 - | Geinaut 1 = Oulaut | | | 0 | 1 | 0 | 007 | DC6 | ∞, | oc. | ∞3 | oc 2 | 001 | oc <sub>0</sub> | Hedister C (00 mm) | Q=ingut, 1=Output (MODE 0) Q=Mask, 1=Enable (MODE 1). | | | _ | | , | l _ | _ | _ | Ma | Mg | M <sub>2</sub> | M, | Mo | | | | | 0 | 4 | X | .ه | C8 <sub>0</sub> | ca, | Cán | ıεı | 183 | iP | MC | Control Register (CR) | Made Selected by MC | | | 1 | ٥ | • | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | | ه الح | Alg | | Al 1 | Alo | Active Interrupt Register (AIR) | | # 6525 FUNCTIONAL DESCRIPTION # Control Register (CR) The bits of the control register select the various operating modes of the 6525. Although the exact function of each bit is explained throughout the functional description, the functions are summarized here for convenience. | CONTROL REGISTER BIT | 7 | | 5 | | | 2 | 1_ | 0 | |------------------------|------|-----------------|----|-----|-------------------|-----|----|----| | FUNCTIONAL DESIGNATION | VC81 | C8 <sub>0</sub> | CA | ودي | ı€1 | 163 | IP | WC | | | | | | | $\overline{\Box}$ | | 1 | 1 | | C3 Line Control | | | | | | | | | | CA Line Control | | | | ل | | | | | | 14 Active Edge Select | | | | | | | | ļ | | 13 Active Edge Select | | | | | | | | | | Interruot Priority | _ | | | | | | | | | Mode Control | | | | | | | | | ## MODE 0 - (MC-0) In Mode 0, three 8 bit bi-directional ports (A, B, C) are available on the 6525. Each port has two associated read/write registers: # Data Direction Registers (DDRA, DDRB, DDRC) Each bit of the data direction registers controls the corresponding pin of the associated port as follows: | J | | |--------|-----------------------------------------------------------------| | CORpit | Direction of portioin | | 0 | Input (Output driver 3:320ed)<br>Culput (Output driver enabled) | # Port Registers (PRA, PRB, PRC) Reading the Port Register returns the logic states of the associated port pins. The pin voltage levels must meet the VIH and VIL specification limits to ensure valid data. (Excessive loading of the output driver may cause the data read to differ from the expected output). If the port pin is programmed as an output by the DDR, the output driver is set to the last data written to the corresponding PR bit. # MODE 1 - (MC=1) In Mode 1, the 6525 provides 2. 8-bit bi-directional ports (A and B) as in Mode 0. By writing MC=1, Port C is automatically converted to a 5 level priority interrupt controller with interrupt output (IRQ) and a handshake control line for each port (CA and CB). | · | | | | | _ | | | | |------------------|--------------|-----|------|-----|-----|-----|-----|-----| | MODE O PIN NAMES | <b>9</b> C 7 | PCS | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 | | MODE I PIN NAMES | 90 | | - | 14 | 13 | 12 | 11 | iQ | | MODE I PIN NAMES | CB | | ing. | | | | | | # Port Register C — PRC (Mode 1) All bits of the PRC can be read as in Mode 0 but the state of the interrupt latches, rather than the interrupt pins, is returned in the five low order bits of PRC. Writing "0" to a PRC bit clears the corresponding interrupt latch but has no effect on the CA, CB, or IRQ outputs. Writing "1" to a PRC bit has no effect on Mode 1. | MODE O BIT NAMES | PC 7 | PCs | PC <sub>5</sub> | PC4 | PC 3 | PC <sub>2</sub> | PC <sub>1</sub> | PCg | |------------------|------|-----|-----------------|-----|------|-----------------|-----------------|-----| | MODE O BIT NAMES | CB | CA | IHO | IL. | IL3 | ILZ | ILI | 5 | # READ CYCLE TIMING | | | 65 | 25 | 652 | 25A | 652 | | | |---------------|------------------------|------------|----------|-----|----------|-------|-----|-------| | <b>Symbol</b> | Characteristic | MIN | MAX | MIN | MAX | MIN | MAX | UNITS | | TRC | Read Cycle | 450 | - | 225 | _ | 165 | - | ns | | TACC | Access Time1 | . <b>–</b> | 450 | - | 225 | - | 155 | ns | | TCO | CS to Output Valid | - | 270 | - | 120 | - | 70 | ns | | TACS. | RS to CS Set Up . | 0 | - | 0 | _ | . 0 | _ | ns | | TACH | RS to CS Hold | 0 | _ | 0 | _ | 0 | _ | . ns | | TRCS | R/W high to CS Set Up | 0 | _ | 0 | _ | 0 | _ | ns | | TACH" | R/W high to CS Hold | 0 | <b>-</b> | 0 | <b>–</b> | 0 | - | ns | | TOTO | CS to Output off Delay | 20 | 120 | 20 | 120 | 20 | 100 | ns | | TPOS | Port input Set Up | 120 | _ | 60 | - | 40 | - | ns | | TPOH | Port Input Hold | 150 | - | 150 | - | · 150 | - | ns | NOTE 1 — Access time measured from later of R/W high or RS stable. # WRITE CYCLE TIMING | | | 65 | 25 | 652 | | 652 | | | |--------|-----------------------|-----|------|------------|------------|-----|----------|-------------| | Symbol | Characteristic | MIN | MAX | MIN | MAX | MIN | MAX | UNITS | | TWC | Write Cycle | 450 | - | 225 | <b>-</b> , | 165 | _ | <b>ា</b> \$ | | TACS | RS to CS Set Up | 0 | - | 0 | - | 0 | _ | ns | | TACH | RS to CS Hold | 0 | - | 0 | - | 0 | <b>–</b> | ns | | Twcs | R/W low to CS Set Up | 0 | _ | 0 | _ | 0 | - | n <b>s</b> | | TWCH | R/W low to CS Hold | 0 | _ | 0 | _ | 0 | - | ns | | TOS | Data Bus to CS Set Up | 150 | - | 100 | - | 50 | - | ns | | ТОН | Data Bus to CS Hold | 0 | _ | o | _ | 0 | - | ns | | TCPD | CS to Port Out Delay | _ | 1000 | <b>–</b> . | 500 | _ | 330 | ns | | TCSP | CS Pulse Width | 420 | _ | 200 | _ | 150 | _ | ns | # CA and CB Outputs - (PCS and PC7) CA and CB may be used as general purpose outputs of as data transfer signals for ports A and B. The operation of CA and CB is selected as follows: | | CAI | CAO | CA OUTPUT MODE | CB, | CB <sub>0</sub> | CB OUTPUT MODE | |---|-----|-----|---------------------------------------------------------------------|-----|-----------------|----------------------------------------------------------------------| | | 0 | 1 | Set high by active<br>transition of IS. Reset low<br>by reading PRA | 0 | i I | Set low by writing PRS.<br>Recet high by active<br>transition of 14. | | ı | 0 | 1 1 | Pulses low for at least 500 ns after reading PRA. | 0 | 1 1 | Pulses low locat least 500 ns after writing PRS. | | | 1 | 0 | CA low<br>CA high | 1 | 0 | CB law<br>CB high | # IRQ Output .- (PCS) The Interrupt Request is set low when an unmasked interrupt (see below) is activated. IRQ is reset high by reading the Active Interrupt Register (AIR). The IRQ output has an open drain to allow wire AND tying of multiple outputs. # 14, 13, 12, 11, 10 Inputs - (PC4-PC0) The five low order pins of Port C are interrupt inputs in Mode 1. A negative (high to low) transition on 12,11 or 10 sets the corresponding latch in PRC to indicate an interrupt, while either transition of 13 or 14 can be selected to set its latch as follows: | 1E3 | 13 EDGE SELECTION | 164 | 14 EDGE SELECTION | |-----|-------------------------------------------------------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------| | 1 | 13 sets IL3 latch on negative (hi-low) transition. 13 sets IL3 latch as positive (low-hi) transition. | | 14 sets IL <sub>4</sub> latch on negative transition. 14 sets IL <sub>4</sub> latch on positive transition. | #### Interrupt Mask Register (DDRC in Mode 1) In Mode 1, the five low order bits of the DDRC are utilized as interrupt mask bits of the five corresponding interrupt latches. Writing a "1" to the mask register enables the corresponding interrupt latch to initiate an interrupt while a "0" masks the interrupt latch output. Masking does not prevent the interrupt latch from being set by an active input transition. The interrupt mask register can be read and written. #### Active Interrupt Register (AIR) The five low order bits of the AIR contain the present interrupt status of the 6525. A "1" in a bit of the AIR indicates that the corresponding interrupt is active. Reading the AIR clears all AIR bits and resets any interrupt latch which had set a bit in the AIR. READING AND WRITING OF THE AIR AFFECTS THE INTERRUPT PRIORITY STACK. Therefore, the AIR should be accessed only in strict accordance to the following rules: - READ THE AIR ONLY TO INDICATE BEGINNING OF INTERRUPT SERVICE. - 2. WRITE THE AIR ONLY TO INDICATE CONCLUSION OF INTERRUPT SERVICE. # DESCRIPTION OF PRIORITY INTERRUPT OPERATION # No Priority Operation Selected — (IP=0): When an active transition occurs on an interrupt input (see 14-10), the corresponding interrupt latch is set. If this latch is not masked, the corresponding bit of the AIR is set, IRQ (PC5) is activated low, and other interrupt latches are prevented from setting new bits in the AIR. After reading the AIR, the interrupt latch corresponding with the bit set in the AIR is cleared to await new input and IRQ is reset high. Any interrupt latches remaining set will now restart this interrupt sequence. If multiple interrupts have been received in the interrupt latches will be set in the AIR and all corresponding interrupt latches will be cleared when the AIR is read. Therefore, software must recognize the occurrence of multiple interrupts when no priority operation is selected. # Priority Operation Selected — (IP-1) The five interrupt inputs have a fixed priority: 14>13>12>11>10. When priority operation is selected, only the highest priority interrupt is placed in the AIR, ensuring only one bit set in the AIR at any time. When an interrupt occurs, the corresponding interrupt latch is set as before but is then compared with the present active interrupt, the new bit in the AIR is set and IRQ is activated low. When AIR is read, the contents of the AIR are pushed onto a 5 level stack for comparison with subsequent interrupts and AIR is cleared. After servicing the new interrupt, the processor must write to the AIR (clearing the AIR) to instruct the 6525 that this interrupt service is complete. The previous interrupt status is then recalled (popped) to the top of the stack to be used for evaluating new interrupt inputs, interrupts of lesser priority than the active interrupt are masked until all higher level interrupts are acknowledged and completed by the processor (as indicated by AIR reads and writes). When all higher priority interrupts have been serviced, the 6525 will allow a lower priority interrupt to indicate a new interrupt sequence. The following examples illustrate the priority interrupt operation: #### A. Single Interrupt - 1. Interrupt received by negative transition on I1. - 2. Interrupt latch 1 (IL1) is set. - 3. Bit A<sub>1</sub> set in AIR. - 4. IRQ activated low. - Processor responds by reading AIR to determine which interrupt occurred. - 6. AIR is pushed onto interrupt stack and latch 1 is cleared. - 7. AIR is cleared and IRQ reset high. - 8. Upon completion of service, processor writes to AIR. - Interrupt stack is popped, restoring previous interrupt status. - B. Lower priority interrupt received during active interrupt - 1. If received and latched. - 2. At is set and IRQ activated low. - 3. Processor reads AIR to determine I1 is active. - 4. AIR pushed onto stack and IL1 cleared. - 5. AIR cleared and IRQ reset high. - Processor is servicing 11 while 10 occurs and sels. - Interrupt stack prevents lower priority ILg from initiating a new interrupt. - Upon completion of I1 service, processor writes to AIR, popping I1 interrupt out of stack. - ILO is now permitted to initiate a new interrupt service. - C. Higher priority interrupt received during active interrupt - 1. Interrupt I1 received and latched. - 2. At is set and IRO activated low. - 3. Processor reads AIR to determine I1 is active. - 4. AIR is pushed onto stack and IL1 cleared. - 5. AIR cleared and IRQ reset high. - 6. Processor is servicing 11 when 12 occurs and sets IL2. - A2 is set and IRQ activated low because IL2 has higher priority than IT in stack. - Processor recognizes interrupt request and calls interrupt service routine. - 9. Processor reads AIR to determine I2 is active. - New AIR is pushed onto interrupt stack and IL2 cleared. - 11. AIR cleared and IRQ reset high. - 12. Processor services 12. - Upon completion of I2 service, processor writes to AIR popping I2 interrupt from stack, restoring I1 status to top of stack (still preventing an I0 interrupt). - 14. Processor return from interrupt resumes services of suspended I1 routine. - Upon completion of I1, processor writes to AIR, popping I1 interrupt from stack, leaving no active interrupts. ## 6525 INTERFACE AND CONTROL #### Initialization A low on the RES pin clears all 6525 internal registers. This puts the 6525 in Mode 0 with all three ports selected as inputs (floating), preventing any conflicts on the bi-directional port lines. For port pins to be used as outputs, the desired output data may be written to the port register before enabling the output driver. This sequence can eliminate undesired output conditions when the outputs are enabled via the DDR. When selecting Mode 1, all interrupt inputs and 163, 164 must be stable before writing MC bit to "1." If this can not be ensured, the interrupt latches (PRC4-PRCg) should be cleared by writing 0 to PRC after MC=1 and before unmesting the interrupt latches. Similarly, if CA and CB are to be used as data transfer handshake lines, no PRA reads or PRB writes should occur after RES or before actual data transfers are to begin. #### Processor Interface The 6525 is a fully static device with interface characteristics similar to a static RAM. To read, the RS and R/W lines are stabilized and then $\overline{CS}$ is switched low, gating the desired register onto the system data bus. (In 650X systems, $\overline{CS}$ may be gated with $\underline{B2}$ ). The system timing must accommodate both the TACC (address) and TCO (chip select) delays before requiring valid data. To write to the 6525, similar timing is required, with the processor providing valid write data at least DS before $\overline{CS}$ switches high. To guarantee proper operation of the 6525, THE R/W LINE MUST BE STABLE ANY TIME $\overline{CS}$ IS LOW. 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 of 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.