# R65C21 Peripheral Interface Adapter (PIA) #### DESCRIPTION The R65C21 Peripheral Interface Adapter (PIA) is designed to solve a broad range of peripheral control problems in the implementation of microcomputer systems. This device allows a very effective trade-off between software and hareware by providing significant capability and flexibility in a low cost chip. When coupled with the power and speed of the R6500, R6500/\* or R65C00 family of microprocessors, the R65C21 allows implementation of very complex systems at a minimum overall cost. Control of peripheral devices is handled primarily through two 8-bit bidirectional ports. Each of these lines can be programmed to act as either an input or an output. In addition, four peripheral control/interrupt input lines are provided. These lines can be used to interrupt the processor or to "handshake" data between the processor and a peripheral device. #### **FEATURES** - Low power CMOS N-well silicon gate technology - Direct replacement for NMOS R6520 or MC6821 PIA - Two 8-bit bidirectional I/O ports with individual data direction control - · Automatic "Handshake" control of data transfers - . Two interrupts (one for each port) with program control - 1, 2, 3, and 4 MHz versions - · Commercial and industrial temperature range versions - Wide variety of packages - 40-pin plastic and ceramic DIP - 44-pin plastic leaded chip carrier (PLCC) - Single +5 Vdc power requirement - Compatible with the R6500, R6500/\* and R65C00 family of microprocessors Figure 1. R65C21 Pin Assignments #### ORDERING INFORMATION ### INTERFACE SIGNALS The PIA interfaces to the R6500, R6500/\* or the R65C00 micro-processor family with a reset line, a \$\psi 2\$ clock line, a read/write line, two interrupt request lines, two register select lines, three chip select lines, and an 8-bit bidirectional data bus. The PIA interfces to the peripheral devices with four interrupt/ control lines and two 8-bidirectional data ports. Figure 1 (on the front page) shows the R65C21 PIA pin assignments and Figure 2 groups the signals by functional interface. #### CHIP SELECT (CS0, CS1, CS2) The PIA is selected when CS0 and CS1 are high and CS2 is low. These three chip select lines are normally connected to the processor address lines either directly or through external decoder circuits. When the PIA is selected, data will be transferred between the data lines and PIA registers, and/or peripheral interface lines as determined by the $R/\overline{W}$ , RS0, and RS1 lines and the contents of Control Registers A and B. #### **RESET SIGNAL (RES)** The Reset ( $\overline{\text{RES}}$ ) input initializes the R65C21 PIA. A low signal on the $\overline{\text{RES}}$ input causes all internal registers to be cleared. #### CLOCK SIGNAL (\$2) The Phase 2 Clock Signal (\$\textit{\textit{0}}\) is the system clock that triggers all data transfers between the CPU and the PIA. \$\textit{0}\$2 is generated by the CPU and is therefore the synchronizing signal between the CPU and the PIA. #### READ/WRITE SIGNAL (R/W) Read/Write (R/W) controls the direction of data transfers between the PIA and the data lines associated with the CPU and the peripheral devices. R/W high permits the peripheral devices to transfer data to the CPU from the PIA. R/W low allows data to be transferred from the CPU to the peripheral devices from the PIA. #### **REGISTER SELECT (RS0, RS1)** The two Register Select lines (RS0, RS1), in conjunction with the Control Registers' (CRA, CRB) Data Direction Register access bits select the various R65C21 registers to be accessed by the CPU. RS0 and RS1 are normally connected to the microprocessor (CPU) address output lines. Through control of these lines, the CPU can write directly into the Control Registers (CRA, CRB), the Data Direction Registers (DDRA, DDRB) and the Peripheral Output Registers (ORA, ORB). In addition, the processor may directly read the contents of the Control Registers and the Data Direction Registers. Accessing the Peripheral Output Register for the purpose of reading data back into the processor operates differently on the ORA and the ORB registers and, therefore, are shown separately in Table 1. Figure 2. R65C21 ACIA Interface Signals Table 1. ORA and ORB Register Addressing | Register | Reg<br>Select | lster<br>Lines | Data Di<br>Con | | | Operation | |------------------|---------------|----------------|----------------|----------------|-----------|------------| | Address<br>(Hex) | RS1 | RS0 | CRA<br>(Bit 2) | CRB<br>(Bit 2) | R/W=H | R/W=L | | 0 | L | L | 1 | - | Read PIBA | | | 0 | L | L | 0 | - | Read DDRA | Write DDRA | | 1 | L | н | _ ' | | Read CRA | Write CRA | | 2 | Н | L | _ | 1 | Read PIBB | Write ORB | | 2 | Н | L | | 0 | Read DDRB | Write DDRB | | 3 | Н | н | | _ | Read CRB | Write CRB | #### INTERRUPT REQUEST LINES (IRQA, IRQB) The active low Interrupt Request lines (IRQA and IRQB) act to interrupt the microprocessor either directly or through external interrupt priority circuitry. These lines are open drain and are capable of sinking 1.6 mA from an external source. This permits all interrupt request lines to be tied together in a wired-OR configuration. The A and B in the titles of these lines correspond to the peripheral port A and the peripheral port B so that each interrupt request line services one peripheral data port. Each Interrupt Request line has two interrupt flag bits which can cause the Interrupt Request line to go low. These flags are bits 6 and 7 in the two Control Registers (CRA, CRB). These flags act as the link between the peripheral interrupt signals and the microprocessor interrupt inputs. Each flag has a corresponding interrupt disable bit which allows the processor to enable or disable the interrupt from each of the four interrupt inputs (CA1, CA2, CB1, CB2). The four interrupt flags are set by active transitions of the signal on the interrupt input (CA1, CA2, CB1, CB2). CRA bit 7 (IRQA1) is always set by an active transition of the CA1 interrupt input signal. However, $\overline{\text{IRQA}}$ can be disabled by setting bit 0 in CRA to a 0. Likewise, CRA bit 6 (IRQA2) is set by an active transition of the CA2 interrupt input signal and $\overline{\text{IRQA}}$ can be disabled by setting bit 3 in CRA to a 0. Both bit 6 and bit 7 in CRA are reset by a "Read Peripheral Output Register A" operation. This is defined as an operation in which the read/write, proper data direction register and register select signals are provided to allow the processor to read the Peripheral A I/O port. A summary of IRQA control is shown in Table 2. Control of IRQB is performed in exactly the same manner as that described above for IRQA (Table 2). Bit 7 in CRB (IRQB1) is set by an active transition on CB1 and IRQB from this flag is controlled by CRB bit 0. Likewise, bit 6 (IRQB2) in CRB is set by an active transition on CB2, and IRQB from this flag is controlled by CRB bit 3. Also, both bit 6 and bit 7 of CRB are reset by a "Read Peripheral B Output Register" operation. Table 2. IRQA and IRQB Control Summary | Control Register Bits | Action | |-------------------------|------------------------| | CRA-7 = 1 and CRA-0 = 1 | IRQA goes low (Active) | | CRA-6 = 1 and CRA-3 = 1 | IRQA goes low (Active) | | CRB-7 = 1 and CRB-0 = 1 | IRQB goes low (Active) | | CRB-6 = 1 and CRB-3 = 1 | IRQB goes low (Active) | # INTERRUPT INPUT/PERIPHERAL CONTROL LINES (CA1, CA2, CB1, CB2) The four interrupt input/peripheral control lines provide a number of special peripheral control functions. These lines greatly enhance the power of the two general purpose interface ports (PAO-PA7), PBO-PB7). Figure 4 summarizes the operation of these control lines. CA1 is an interrupt input only. An active transition of the signal on this input will set bit 7 of the Control Register A to a logic 1. The active transition can be programmed by setting a 0 in bit 1 of the CRA if the interrupt flag (bit 7 of CRA) is to be set on a negative transition of the CA1 signal or a 1 if it is to be set on a positive transition. CA2 can act as a totally independent interrupt or as a peripheral control output. As an input (CRA, bit 5 = 0) it acts to set the interrupt flag, bit 6 of CRA, to a logic 1 on the active transition selected by bit 4 of CRA. These control register bits and interrupt inputs serve the same basic function as that described above for CA1. The input signal sets the interrupt flag which serves as the link between the peripheral device and the processor interrupt structure. The interrupt disable bit allows the processor to exercise control over the system interrupt. In the output mode (CRA, bit 5=1), CA2 can operate independently to generate a simple pulse each time the microprocessor reads the data on the Peripheral A I/O port. This mode is selected by setting CRA, bit 4 to a 0 and CRA, bit 3 to a 1. This pulse output can be used to control the counters, shift registers, etc., which make sequential data available on the Peripheral input lines. A second output mode allows CA2 to be used in conjunction with CA1 to "handshake" between the processor and the peripheral device. On the A side, this technique allows positive control of data transfers from the peripheral device into the microprocessor. The CA1 input signals the processor that data is available by interrupting the processor. The processor reads the data and sets CA2 low. This signals the peripheral device that it can make new data available. The final output mode can be selected by setting bit 4 of CRA to a 1. In this mode, CA2 is a simple peripheral control output which can be set high or low by setting bit 3 of CRA to a 1 or 0, respectively. CB1 operates as an interrupt input only in the same manner as CA1. Bit 7 of CRB is set by the active transition selected by bit 0 of CRB. Likewise, the CB2 input mode operates exactly the same as the CA2 input modes. The CB2 output modes, CRB bit 5 = 1, differ somewhat from those of CA2. The pulse output occurs when the processor writes data into the Peripheral B Output Register. Also, the "handshaking" operates on data transfers from the processor into the peripheral device. # **FUNCTIONAL DESCRIPTION** The R65C21 PIA is organized into two independent sections referred to as the A Side and the B Side. Each section consists of a Control Register (CRA, CRB), Data Direction Register (DRA, DRB), Output Register (ORA, ORB), Interrupt Status Control (ISCA, ISCB), and the buffers necessary to drive the Peripheral Interface buses. Data Bus Buffers (DBB) interface data from the two sections to the data bus, while the Data Input Register (DIR) interfaces data from the DBB to the PIA registers. Chip Select and R/W control circuitry interface to the processor bus control lines. Figure 3 is a block diagram of the R65C21 PIA. # **DATA INPUT REGISTER (DIR)** When the microprocessor writes data into the PIA, the data which appears on the data bus during the $\emptyset 2$ clock pulse is latched into the Data Input Register (DIR). The data is then transferred into one of six internal registers of the PIA after the trailing edge of the Ø2 clock. This assures that the data on the peripheral output lines will make smooth transitions from high to low (or from low to high) and the voltage will remain stable except when it is going to the opposite polarity. #### **CONTROL REGISTERS (CRA AND CRB)** Table 3 illustrates the bit designation and functions in the two control registers. The control registers allow the microprocessor to control the operation of the Interrupt Control inputs (CA1, CA2, CB1, CB2), and Peripheral Control outputs (CA2, CB2). Bit 2 in each register controls the addressing of the Data Direction Registers (DDRA, DDRB) and the Output Registers (ORA, ORB). In addition, two bits (bit 6 and 7) in each control register indicate the status of the Interrupt Input lines (CA1, CA2, CB1, CB2). These Interrupt Status bits (IRQA1, IRQA2 or IRQB1, IRQB2) are normally interrogated by the microprocessor during the IRQ interrupt service routine to determine the source of the interrupt. Figure 3. R65C21 PIA Block Diagram Table 3. Control Registers Bit Designations | | | | Table 3. Co | nuoi negiai | era pir peaid | manone | | | | |-----|-------|-------|-------------|-------------|---------------|--------------------|-------|---------|--| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 | | | | CRA | IRQA1 | IRQA2 | | CA2 Control | | DDRA/ORA<br>Select | CA1 C | Control | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CRB | IRQB1 | IRQB2 | | CB2 Control | | DDRB/ORB<br>Select | CB1 C | Control | | #### **DATA DIRECTION REGISTERS (DDRA, DDRB)** The Data Direction Registers (DDRA, DDRB) allow the processor to program each line in the 8-bit Peripheral I/O port to be either an input or an output. Each bit in DDRA controls the corresponding line in the Peripheral A port and each bit in DDRB controls the corresponding line in the Peripheral B port. Writing a 0 in a bit position in the Data Direction Register causes the corresponding Peripheral I/O line to act as an input; a 1 causes it to act as an output. Bit 2 in each Control Register (CRA and CRB) controls access to the Data Direction Register or the Peripheral interface. If bit 2 is a 1, a Peripheral Output register (ORA, ORB) is selected, and if bit 2 is a 0, a Data Direction Register (DDRA, DDRB) is selected. The Data Direction Register Access Control bit, together with the Register Select lines (RS0, RS1) selects the various internal registers as shown in Table 1. #### PERIPHERAL OUTPUT REGISTER (ORA, ORB) The Peripheral Output Registers (ORA, ORB) store the output data from the Data Bus Buffers (DBB) which appears on the Peripheral I/O port. If a line on the Peripheral A Port is programmed as an output by the DDRA, writing a 0 into the corresponding bit in the ORA causes that line to go low (≤0.4 Vdc); writing a 1 causes the line to go high. The lines of the Peripheral B port are controlled by ORB in the same manner. #### **INTERRUPT STATUS CONTROL (ISCA, ISCB)** The four interrupt/peripheral control lines (CA1, CA2, CB1, CB2) are controlled by the Interrupt Status Control logic (A, B). This logic interprets the contents of the corresponding Control Register and detects active transitions on the interrupt inputs. #### PERIPHERAL I/O PORTS (PA0-PA7, PB0-PB7) The Peripheral A and Peripheral B I/O ports allow the microprocessor to interface to the input lines on the peripheral device by writing data into the Peripheral Output Register. They also allow the processor to interface with the peripheral device output lines by reading the data on the Peripheral Port input lines directly onto the data bus and into the internal registers of the processor. Each of the Peripheral I/O lines can be programmed to act as an input or an output. This is accomplished by setting a 1 in the corresponding bit in the Data Direction Register for those lines which are to act as outputs. A 0 in a bit of the Data Direction Register causes the corresponding Peripheral I/O lines to act as an input. The buffers which drive the Peripheral A I/O lines contain "passive" pull-up devices. These pull-up devices are resistive in nature and therefore allow the output voltage to go to $V_{CC}$ for a logic 1. The switches can sink a full 3.2 mA, making these buffers capable of driving two standard TTL loads. In the input mode, the pull-up devices are still connected to the I/O pin and still supply current to this pin. For this reason, these lines also represent two standard TTL loads in the input mode. The Peripheral B I/O port duplicates many of the functions of the Peripheral A port. The process of programming these lines to act as an input or an output is similar to the Peripheral A port, as is the effect of reading or writing this port. However, there are several characteristics of the buffers driving these lines which affect their use in peripheral interfacing. The Peripheral B I/O port buffers are push-pull devices, i.e., the pull-up devices are switched OFF in the 0 state and ON for a logic 1. Since these pull-ups are active devices, the logic 1 voltage will not go higher than +2.4 Vdc. Another difference between the PA0-PA7 lines and the PB0 through PB7 lines is that they have three-state capability which allows them to enter a high impedance state when programmed to be used as input lines. In addition, data on these lines will be read properly, when programmed as output lines, even if the data signals fall below 2.0 Vdc for a "high" state or are above 0.8 Vdc for a "low" state. When programmed as output, each line can drive at least a two TTL load and may also be used as a source of up to 3.2 mA at 1.5 Vdc to directly drive the base of a transistor switch, such as a Darlington pair. Because these outputs are designed to drive transistors directly, the output data is read directly from the Peripheral Output Register for those lines programmed to act as inputs. The final characteristic is the high-impedance input state which is a function of the Peripheral B push-pull buffers. When the Peripheral B I/O lines are programmed to act as inputs, the output buffer enters the high impedance state. #### **DATA BUS BUFFERS (DBB)** The Data Bus Buffers are 8-bit bidirectional buffers used for data exchange, on the D0–D7 Data Bus, between the microprocessor and the PIA. These buffers are tri-state and are capable of driving a two TTL load (when operating in an output mode) and represent a one TTL load to the microprocessor (when operating in an input mode). # CONTROL REGISTER A (CRA) #### CA2 INPUT MODE (BIT 5 = 0) | 7 | 6 | 5 | 4 | 3 | 2 | 11 | 0 | |---------------|---------------|----------------------------------|-------------------------------|-----------------------------|--------------------|-------------------------------|-----------------------------| | IRQA1<br>FLAG | IRQA2<br>FLAG | CA2 INPUT<br>MODE SELECT<br>(=0) | IRQA2<br>TRANSITION<br>SELECT | IRQA<br>ENABLE<br>FOR IRQA2 | DDRA/ORA<br>SELECT | IRQA1<br>TRANSITION<br>SELECT | ÎRQA<br>ENABLE<br>FOR IRQA1 | | | | | IRQA/I<br>CONT | | | IRQĀ/I<br>CONT | | #### CA2 OUTPUT MODE (BIT 5 = 1) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|-----------------------------------|--------------------------|---------------------------|--------------------|-------------------------------|-----------------------------| | IRQA1<br>FLAG | 0 | CA2 OUTPUT<br>MODE SELECT<br>(=1) | CA2<br>OUTPUT<br>CONTROL | CA2<br>RESTORE<br>CONTROL | DDRA/ORA<br>SELECT | IRQA1<br>TRANSITION<br>SELECT | IRQA<br>ENABLE<br>FOR IRQA1 | | | | | CA<br>CON | A2<br>TROL | | IRQA/I<br>CONT | | # CA2 INPUT OR OUTPUT MODE (BIT 5 = 0 OR 1) | Bit 7 | IRQA1 FLAG | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | A transition has occurred on CA1 that satisfies the bit 1 IRQA1 transition polarity criteria. This bit is cleared by a read of Output Register A or by RES. | | 0 | No transition has occurred on CA1 that satisfies the bit 1 IRQA1 transition polarity criteria. | | Bit 2 | DATA DIRECTION REGISTER A/OUTPUT REGISTER A SELECT | | 1 | Select Output Register A. | | 0 | Select Data Direction Register A. | | Bit 1 | IRQA1 TRANSITION SELECT | | 1 | Set IRQA1 Flag (bit 7) on a positive (low-to-high) transition of CA1. | | 0 | Set IRQA1 Flag (bit 7) on a negative (high-to-low) transition of CA1. | | Bit 0 | IRQA ENABLE FOR IRQA1 | | 1 | Enable assertion of IRQA when IRQA1 Flag (bit 7) is set. | | 0 | Disable assertion of IRQA when IRQA1 Flag (bit 7) is set. | #### CA2 INPUT MODE (BIT 5 = 0) | Bit 6 | IRQA2 FLAG | |-------|---------------------------------------------------------------| | 1 | A transition has occurred on CA2 that satisfies the bit 4 | | | IRQA2 transition polarity criteria. This flag is cleared by | | | a read of Output Register A or by RES. | | 0 | No transition has occurred on CA2 that satisfies the | | | bit 4 IRQA2 transition polarity criteria. | | Bit 5 | CA2 MODE SELECT | | 0 | Select CA2 Input Mode. | | | · | | Bit 4 | IRQA2 TRANSITION SELECT | | 1 | Set IRQA2 Flag (bit 6) on a positive (low-to-high) transition | | | of CA2. | | 0 | Set IRQA2 Flag (bit 6) on a negative (high-to-low) transition | | | of CA2. | | Bit 3 | IRQA ENABLE FOR IRQA2 | | 1 | Enable assertion of IRQA when IRQA2 Flag (bit 6) is set. | | 0 | Disable assertion of IRQA when IRQA2 Flag (bit 6) is set. | # CA2 OUTPUT MODE (BIT 5 = 0) | Bit 6 | NOT USED | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Always zero. | | Bit 5 | CA2 MODE SELECT | | 1 | Select CA2 Output Mode. | | Bit 4 | CA2 OUTPUT CONTROL | | 1 | CA2 goes low when a zero is written into CRA bit 3. CA2 goes high when a one is written into CRA bit 3. | | 0 | CA2 goes low on the first negative (high-to-low) \$\psi 2\$ clock transition following a read of Output Register A. CA2 returns high as specified by bit 3 | | | CA2 feturns high as specified by bit 3 | | Bit 3 | CA2 READ STROBE RESTORE CONTROL (4 = 0) | | 1 | CA2 returns high on the next \$2 clock negative | | | transition following a read of Output Register A. | | 0 | CA2 returns high on the next active CA1 transition following a read of Output Register A as specified by bit 1. | Figure 4. Control Line Operations Summary (1 of 2) #### **CONTROL REGISTER B (CRB)** # CB2 INPUT MODE (BIT 5 = 0) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---------------|----------------------------------|-------------------------------|-----------------------------|--------------------|-------------------------------|-----------------------------| | IRQB1<br>FLAG | IRQB2<br>FLAG | CB2 INPUT<br>MODE SELECT<br>(=0) | IRQB2<br>TRANSITION<br>SELECT | IRQB<br>ENABLE<br>FOR IRQB2 | DDRB/ORB<br>SELECT | IRQB1<br>TRANSITION<br>SELECT | IRQB<br>ENABLE<br>FOR IRQB1 | | | : | | IRQB/I | | | IRQB/II<br>CONT | | #### CB2 OUTPUT MODE (BIT 5 = 1) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|------------------------------------|--------------------------|---------------------------|--------------------|-------------------------------|-----------------------------| | IRQB1<br>FLAG | 0 | CB2 OUTPUT<br>MODE SELECT<br>(= 1) | CB2<br>OUTPUT<br>CONTROL | CB2<br>RESTORE<br>CONTROL | DDRB/ORB<br>SELECT | IRQB1<br>TRANSITION<br>SELECT | IRQB<br>ENABLE<br>FOR IRQB1 | | | | | CI<br>CON | 32<br>TROL | | IRQB/I<br>CONT | | #### CB2 INPUT OR OUTPUT MODE (BIT 5 = 0 OR 1) | Bit 7 | IRQB1 FLAG A transition has occurred on CB1 that satisfies the bit 1 IRQB1 transition polarity criteria. This bit is cleared by a read of Output Register B or by RES. | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | No transition has occurred on CB1 that satisfies the bit 1 IRQB1 transition polarity criteria. | | Bit 2 | DATA DIRECTION REGISTER B/OUTPUT REGISTER B SELECT | | 1 | Select Output Register B. | | 0 | Select Data Direction Register B. | | Bit 1 | IRQB1 TRANSITION SELECT | | 1 | Set IRQB1 Flag (bit 7) on a positive (low-to-high) transition of CB1. | | 0 | Set IRQB1 Flag (bit 7) on a negative (high-to-low) transition of CB1. | | Bit 0 | IRQB ENABLE FOR IRQB1 | | 1 | Enable assertion of IRQB when IRQB1 Flag (bit 7) is set. | | 0 | Disable assertion of IRQB when IRQB1 Flag (bit 7) is set. | #### CB2 INPUT MODE (BIT 5 = 0) | Bit 6 | IRQB2 FLAG | |-------|-----------------------------------------------------------------------------------------------------------------------| | 1 | A transition has occurred on CB2 that satisfies the bit 4 IRQB2 transition polarity criteria. This flag is cleared by | | | a read of Output Register B or by RES. | | 0 | No transition has occurred on CB2 that satisfies the | | | bit 4 IRQB2 transition polarity criteria. | | Bit 5 | CB2 MODE SELECT | | 0 | Select CB2 Input Mode. | | Bit 4 | IRQB2 TRANSITION SELECT | | 1 | Set IRQB2 Flag (bit 6) on a positive (low-to-high) transition of CB2. | | 0 | Set IRQB2 Flag (bit 6) on a negative (high-to-low) transition of CB2. | | Bit 3 | IRQB ENABLE FOR IRQB2 | | 1 | Enable assertion of IRQB when IRQB2 Flag (bit 6) is set. | | 0 | Disable assertion of IRQB when IRQA2 Flag (bit 6) is set. | # CB2 OUTPUT MODE (BIT 5 = 0) | Bit 6 | NOT USED | |-------|-----------------------------------------------------------| | 0 | Always zero. | | Bit 5 | CB2 MODE SELECT | | 1 | Select CB2 Output Mode. | | Bit 4 | CB2 OUTPUT CONTROL | | 1 | CB2 goes low when a zero is written into CRB bit 3. | | 1 | CB2 goes high when a one is written into CRB bit 3. | | 0 | CB2 goes low on the first negative (high-to-low) Ø2 clock | | | transition following a read of Output Register B. | | | CB2 returns high as specified by bit 3 | | Bit 3 | CB2 READ STROBE RESTORE CONTROL (4 = 0) | | 1 | CB2 returns high on the next Ø2 clock negative | | | transition following a read of Output Register B. | | 0 | CB2 returns high on the next active CB1 transition | | | following a read of Output Register B as specified by | | | bit 1. | Figure 4. Control Line Operations Summary (2 of 2) #### **READING THE PERIPHERAL A I/O PORT** Performing a Read operation with RS1 = 0, RS0 = 0 and the Data Direction Register Access Control bit (CRA-2) = 1, directly transfers the data on the Peripheral A I/O lines to the data bus. In this situation, the data bus will contain both the input and output data. The processor must be programmed to recognize and interpret only those bits which are important to the particular peripheral operation being performed. Since the processor always reads the Peripheral A I/O port pins instead of the actual Peripheral Output Register (ORA), it is possible for the data read by the processor to differ from the contents of the Peripheral Output Register for an output line. This is true when the I/O pin is not allowed to go to a full +2.4 Vdc when the Peripheral Output register contains a logic 1. In this case, the processor will read a 0 from the Peripheral A pin, even though the corresponding bit in the Peripheral Output register is a 1. #### **READING THE PERIPHERAL B I/O PORT** Reading the Peripheral B I/O port yields a combination of input and output data in a manner similar to the Peripheral A port. However, data is read directly from the Peripheral B Output Register (ORB) for those lines programmed to act as outputs. It is therefore possible to load down the Peripheral B Output lines without causing incorrect data to be transferred back to the processor on a Read operation. Figure 5. Read Timing Waveforms Figure 6. Write Timing Waveform # **SWITCHING WAVEFORMS** (V<sub>CC</sub> = 5.0 Vdc $\pm$ 5%, V<sub>SS</sub> = 0, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub>, unless otherwise noted) #### **BUS TIMING** | | | 1 1 | #Hz | 2 1 | ИHz | 3 M | #Hz | 4 MHz | | | |------------------------------------------|-----------------------------------|------|------|----------|------|------|------|-------|------|------| | Parameter | Symbol | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | Ø2 Cycle | t <sub>CYC</sub> | 1.0 | _ | 0.5 | _ | 0.33 | | 0.25 | | μS | | Ø2 Pulse Width | t <sub>C</sub> | 450 | - | 220 | T | 160 | | 110 | | ns | | Ø2 Rise and Fall Time | t <sub>rc</sub> , t <sub>fc</sub> | _ | 25 | | 15 | _ | 12 | | 10 | ns | | Read | | | | | | | | | | | | Address Set-Up Time | t <sub>ACR</sub> | 140 | _ | 70 | _ | 53 | | 35 | _ | ns | | Address Hold Time | t <sub>CAR</sub> | 0 | _ | 0 | _ | 0 | | 0 | | ns | | Peripheral Data Set-Up Time | t <sub>PCR</sub> | 300 | _ | 150 | | 110 | | 75 | | ns | | Data Bus Delay Time | t <sub>CDR</sub> | _ | 335 | <u> </u> | 145 | | 105 | | 85 | ns | | Data Bus Hold Time | t <sub>HR</sub> | 20 | | 20 | | 20 | | 20 | | ns | | Write | | | | | | | | | | | | Address Set-Up Time | tacw | 140 | T - | 70 | _ | 53 | - | 35 | _ | ns | | Address Hold Time | t <sub>CAW</sub> | 0 | _ | 0 | | 0 | _ | 0 | | ns | | R/W Set-Up Time | twcw | 180 | - | 90 | _ | 67 | _ | 45 | | ns | | R/W Hold Time | t <sub>cww</sub> | 0 | _ | 0 | - | 0 | _ | 0 | _ | ns | | Data Bus Set-Up Time | t <sub>DCW</sub> | 180 | _ | 90 | | 67 | | 45 | | ns | | Data Bus Hold Time | t <sub>HW</sub> | 10 | _ | 10 | _ | 10 | | 10 | | ns | | Peripheral Data Delay Time | t <sub>CPW</sub> | | 1.0 | _ | 0.5 | _ | 0.5 | _ | 0.5 | μS | | Peripheral Data Delay Time to CMOS Level | tcmos | _ | 2.0 | _ | 1.0 | _ | 0.7 | _ | 0.5 | μS | #### PERIPHERAL INTERFACE TIMING | Peripheral Data Set-Up | t <sub>PCR</sub> | 300 | _ | 150 | _ | 110 | | 75 | | ns | |---------------------------------------------------|---------------------------------|-----|-----|----------|------|----------|------|----|------|----| | \$2 Low to CA2 Low Delay | t <sub>CA2</sub> | _ | 1.0 | | 0.5 | | 0.5 | _ | 0.5 | μS | | Ø2 Low to CA2 High Delay | t <sub>RS1</sub> | T - | 1.0 | - | 0.5 | _ | 0.5 | 1 | 0.5 | μS | | CA1 Active to CA2 High Delay | t <sub>RS2</sub> | | 2.0 | _ | 1.0 | _ | 1.0 | | 1.0 | μS | | \$2 High to CB2 Low Delay | t <sub>CB2</sub> | _ | 1.0 | _ | 0.5 | _ | 0.5 | _ | 0.5 | μS | | Peripheral Data Valid to CB2 Low Delay | t <sub>DC</sub> | 0 | 1.5 | 0 | 0.75 | 0 | 0.5 | 0 | 0.37 | μS | | \$2 High to CB2 High Delay | t <sub>RS1</sub> | T - | 1.0 | _ | 0.5 | <u> </u> | 0.5 | _ | 0.5 | μS | | CB1 Active to CB2 High Delay | t <sub>RS2</sub> | _ | 2.0 | <u> </u> | 1.0 | | 0.67 | - | 0.5 | μS | | CA1, CA2, CB1 and CB2<br>Input Rise and Fall Time | t <sub>r</sub> , t <sub>f</sub> | _ | 1.0 | _ | 1.0 | _ | 1.0 | _ | 1.0 | μS | NOTE: Timing measurements are referenced to and from a low voltage of 0.8 Vdc and a high voltage of 2.0 Vdc. # **ABSOLUTE MAXIMUM RATINGS\*** | Parameter | Symbol | Value | Unit | |---------------------------------------------------------|------------------|------------------------------|------| | Supply Voltage | V <sub>CC</sub> | -0.3 to +7.0 | Vdc | | Input Voltage | V <sub>IN</sub> | -0.3 to V <sub>CC</sub> +0.3 | Vdc | | Output Voltage | V <sub>OUT</sub> | -0.3 to V <sub>CC</sub> +0.3 | Vdc | | Operating Temperature Range<br>Commercial<br>Industrial | T <sub>A</sub> | 0 to +70<br>-40 to +85 | °C | | Storage Temperature | T <sub>STG</sub> | - 55 to + 150 | °C | \*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. #### **OPERATING CONDITIONS** | Parameter | Symbol | Value | |---------------------------------|-----------------|-------------------------------------------------| | Supply Voltage | V <sub>cc</sub> | 5V ±5% | | Temperature Range<br>Commercial | T <sub>A</sub> | T <sub>L</sub> to T <sub>H</sub><br>0°C to 70°C | | Industrial | | -40°C to +85°C | #### **ELECTRICAL CHARACTERISTICS** ( $V_{CC} = 5.0 \text{ Vdc } \pm 5\%$ , $V_{SS} = 0$ , $T_A = T_L \text{ to } T_H$ , unless otherwise noted) | Parameter | Symbol | Min. | Typ.3 | Max. | Unit <sup>2</sup> | Test Conditions | |-------------------------------------------------------------------------------------------------------------|------------------|--------------|---------------|-----------------|-------------------|--------------------------------------------------------------------------| | Input High Voltage | V <sub>IH</sub> | +2.0 | _ | V <sub>cc</sub> | ٧ | | | Input Low Voltage | V <sub>IL</sub> | -0.3 | | + 0.8 | V | | | Input Leakage Current<br>R/W, RES, RS0, RS1, CS0, CS2, CA1, CB1, Ø2<br>CS1 | I <sub>IN</sub> | | ±1 | ±2.5<br>±10.0 | μΑ | V <sub>IN</sub> = 0V to V <sub>CC</sub><br>V <sub>CC</sub> = 5.25V | | Input Leakage Current for Three-State Off D0-D7, PB0-P87, CB2 | I <sub>TSI</sub> | _ | ±2 | ± 10 | μА | $V_{IN} = 0.4V \text{ to } 2.4V$<br>$V_{CC} = 5.25V$ | | Input High Current<br>PA0-PA7, CA2 | I <sub>IH</sub> | - 200 | - 300 | _ | μΑ | V <sub>IH</sub> = 2.0V | | Input Low Current<br>PA0-PA7, CA2 | I <sub>1L</sub> | _ | -2 | -3.2 | mA | V <sub>IL</sub> = 0.8V | | Output High Voltage<br>Logic<br>PB0-PB7, CB2 (Darlington Drive) | V <sub>OH</sub> | 2.4<br>1.5 | _ | | V | $V_{CC} = 4.75V$ $I_{LOAD} = -200\mu A$ $I_{LOAD} = -3.2mA$ | | Output Low Voltage<br>PA0-PA7, CA2, PB0-PB7, CB2<br>D0-D7, IRQA, IRQB | V <sub>OL</sub> | _ | _ | + 0.4 | V | $V_{CC} = 4.75V$ $I_{LOAD} = 3.2 \text{ mA}$ $I_{LOAD} = 1.6 \text{ mA}$ | | Output High Current (Sourcing) Logic PB0-PB7, CB2 (Darlington Drive) | l <sub>OH</sub> | -200<br>-3.2 | - 1500<br>- 6 | | μ <b>A</b><br>mA | V <sub>OH</sub> = 2.4V<br>V <sub>OH</sub> = 1.5V | | Output Low Current (Sinking)<br>PA0-PA7, PB0-PB7, CB2, CA2<br>D0-D7, IRQA, IRQB | l <sub>OL</sub> | 3.2<br>1.6 | = | | mA<br>mA | V <sub>OL</sub> = 0.4V | | Output Leakage Current (Off State)<br>IRQA, IRQB | l <sub>OFF</sub> | _ | 1 | ± 10 | μА | V <sub>OH</sub> = 2.4V<br>V <sub>CC</sub> = 5.25V | | Power Dissipation | Po | | 7 | 10 | mW/MHz | | | Input Capacitance<br>D0-D7, PA0-PA7, PB0-PB7, CA2, CB2<br>R/W, RES, RS0, RS1, CS0, CS1, CS2<br>CA1, CB1; Ø2 | C <sub>IN</sub> | = | | 10<br>7<br>20 | pF<br>pF<br>pF | $V_{CC} = 5.0V$ $V_{IN} = 0V$ $f = 2 MHz$ $T_A = 25^{\circ}C$ | | Output Capacitance | Cout | _ | _ | 10 | pF | | | | | | | | + | | #### Notes - 1. All units are direct current (dc) except capacitance. - 2. Negative sign indicates outward current flow, positive indicates inward flow. - 3. Typical values are shown for $V_{CC} = 5.0V$ and $T_A = 25^{\circ}C$ . #### PACKAGE DIMENSIONS | | MILLIM | ETERS | INC | HES | | |-----|--------|-------|-----------|-------|--| | DIM | MIN | MAX | MIN | MAX | | | A | 50.29 | 51.31 | 1.980 | 2.020 | | | В | 15.11 | 15.88 | 0.595 | 0.625 | | | С | 2.54 | 4.19 | 0.100 | 0.165 | | | D | 0.38 | 0.53 | 0.015 | 0.021 | | | F | 0.76 | 1.27 | 0.030 | 0.050 | | | G | 2.54 | BSC | 0.100 BSC | | | | Н | 0.76 | 1.78 | 0.030 | 0.070 | | | J | 0.20 | 0.33 | 0.008 | 0.013 | | | К | 2.54 | 4.19 | 0.100 | 0.165 | | | L | 14.60 | 15.37 | 0.575 | 0.605 | | | М | 0° | 10° | 0.0 | 10° | | | N | 0.51 | 1.52 | 0.020 | 0.060 | | #### **40-PIN PLASTIC DIP** | | MILLIM | ETERS | INC | HES | | |-----|--------|-------|-----------|-------|--| | DIM | MIN | MAX | MIN | MAX | | | A | 51.82 | 52.32 | 2.040 | 2.060 | | | В | 13.46 | 13.97 | 0.530 | 0.550 | | | C | 3.56 | 5.08 | 0.140 | 0.200 | | | D | 0.38 | 0.53 | 0.015 | 0.021 | | | F | 1.02 | 1.52 | 0.040 | 0.060 | | | G | 2.54 | BSC | 0.100 BSC | | | | н | 1.65 | 2.16 | 0.065 | 0.085 | | | J | 0.20 | 0.30 | 0.008 | 0.012 | | | K | 3.30 | 4.32 | 0.130 | 0.170 | | | L | 15.24 | BSC | 0.600 | BSC | | | M | 7,0 | 10° | 70 | 10° | | | N | 0.51 | 1.02 | 0.020 | 0.040 | | #### 44-PIN PLASTIC LEADED CHIP CARRIER (PLCC) SECTION A-A TYP FOR BOTH AXIS (EXCEPT FOR BEVELED EDGE) | | MILLIM | ETERS | INC | HES | |-----|--------|---------|-------|-------| | DIM | MIN | MIN MAX | | MAX | | A | 4.14 | 4.39 | 0.163 | 0.173 | | A1 | 1.37 | 1.47 | 0.054 | 0.058 | | A2 | 2.31 | 2.46 | 0.091 | 0.097 | | ь | 0.457 | TYP | 0.018 | TYP | | D | 17.45 | 17.60 | 0.687 | 0.693 | | D1 | 16.46 | 16.56 | 0.648 | 0.652 | | D2 | 12.62 | 12.78 | 0.497 | 0.503 | | D3 | 15.75 | REF | 0.620 | REF | | е | 1.27 | BSC | 0.050 | BSC | | h | 1.15 | TYP | 0.045 | TYP | | j | 0.25 | TYP | 0.010 | TYP | | α | 45° | TYP | 45° | TYP | | R | 0.89 | TYP | 0.035 | TYP | | RI | 0.25 | TYP | 0.010 | TYP | CHAM. 11 PINS EJ 1 × 45° PER SIDE 4 3 PLCS EQUALLY SPACES EJECTOR PIN MARKS 4 PLCS BOTTOM OF PACKAGE ONLY (TYPICAL) **BOTTOM VIEW**