



# UM82C452

# Single Chip Multi-I/O

PRELIMINARY

#### **Features**

- IBM PC/AT Compatible
- Centronics printer interface
- Dual channel version of UM82C450
- Independent control of transmit, receive, line status and modem status interrupts on each channel
- Individual modem control signals for each channel
- Programmable serial interface characteristics for each

#### channel:

- 5-, 6-, 7- or 8-bit characters
- Even-, odd-or no-parity bit generation and detection 1, 1 1/2 or 2 stop bit generation
- Three-state TTL drive capabilities for bidirectional data bus and control bus for each channel

### Description

The UM82C452 is an enhanced dual channel version of the popular UM82C450 asynchronous communication element (ACE). The device services two serial input/output interfaces simultaneously in microcomputer or microprocessor based systems. Each channel performs serial-to-parallel conversion on data characters received from peripheral devices or modems, and parallel-to-serial conversion on data characters transmitted by the CPU. The complete status of each channel of the dual ACE can be read at any time during functional operation by the CPU. The information obtained includes the type and condition of the transfer operations being performed, and error conditions.

In addition to its dual communications interface capabil-

ities, the UM82C452 provides the user with a fully bidirectional parallel data port that fully supports the parallel Centronics type printer. This port allows data transmitted by the CPU to be printed. The parallel port, together with the two serial ports, provide IBM PC/AT compatible computers with a single device to serve the three functions.

A programmable baud rate generator is included that can divide the timing reference clock input by a divisor between 1 and  $(2^{16}-1)$ .

The UM82C452 is packaged in a 68-pin plastic leaded chip carrier.

### Pin Configuration



### **Block Diagram**





## Pin Description

| Pin No.   | Symbol          | 1/0 | Description                                                                                                                                                                                                                                                                                                                              |
|-----------|-----------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 37        | ĪOR             | ı   | Input/Output Read strobe: This is an active Low input signal used to cause the selected channel to output data to data bus (DB0-DB7).                                                                                                                                                                                                    |
| 36        | īow             | l   | Input/Output Write strobe: This is an active Low input signal used to cause data input from data bus (DB0-DB7) to the channel selected.                                                                                                                                                                                                  |
| 33-35     | A2-A0           | 1   | Address lines A2-A0: The address lines are used to select the internal register in selected channels during the CPU cycle.                                                                                                                                                                                                               |
| 32, 3, 38 | CSO, CST,       | ı   | Chip Selects: Each chip select input acts as an enable of each channel during read and write. CSO selects Serial Channel 0, CS1 selects Serial Channel 1 and CS2 selects Parallel Port.                                                                                                                                                  |
| 44        | BDO             | 0   | Bus Buffer Output: This active high output is asserted when any channel is selected. This output can be used to control the system bus driver device (74LS245).                                                                                                                                                                          |
| 14-21     | DB0-DB7         | 1/0 | Data Bit DB0-DB7: The data bus provides eight three-state I/O lines for the transfer of data, control and status information between CPU and UM82C452. These lines are normally in a high-impedance state except during read operation. D0 is the least significant bit (LSB) and is the first serial bit to be transmitted or received. |
| 39        | RESET           | ı   | Reset: When low, the reset input forces the UM82C452 into an idle state in which all serial data activities are suspended. The Registers and signals of the UM82C452 are all cleared to the state as indicated in Table 1.                                                                                                               |
| 26, 10    | SOUTO,<br>SOUT1 | 0   | Serial Data Outputs. These lines are the serial data outputs of UARTs, used to transmit serial data to the communication link. Each SOUT is held in marking (logic 1) state when the transmitter is disabled, reset, the Transmitter Register is empty, or when in the loop mode.                                                        |
| 41,62     | SINO, SIN1      | ı   | Serial Data Inputs: These lines are used to receive serial data from the communication line or modem into the UARTs, Data on serial data inputs is disabled during loop mode.                                                                                                                                                            |
| 24, 12    | RTSO,<br>RTS1   | 0   | Request To Send Outputs: This signal is an active low output for each UART. When active, it informs the Modem or data set that the controller is ready to send data. This signal is set low by writing logic 1 to MCR (1) and reset to high by Reset.                                                                                    |
| 25, 11    | DTRO,<br>DTR1   | 0   | Data Terminal Ready Lines: This signal is an active low output for each UART. When active, it informs the modem or data set that the controller is ready to communicate. This signal is set low by writing logic 1 to MCR (0) and reset to high by Reset.                                                                                |



## Pin Description (Continued)

| Pin No. | Symbol         | I/O | Description                                                                                                                                                                                                                                                                                                                                  |
|---------|----------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28, 13  | СТS0,<br>СТS1  | ı   | Clear to send Inputs: This signal is an active low input for each UART. The logic state of this signal is reflected in MSR (4) and any change of state in either CTS pin will set DCTS bit MSR (0) of each Modem Status Register. When active, it informs that the Modem or data set is ready to receive data.                               |
| 31,5    | DSR0<br>DSR1   | ţ   | Data Set Ready: This signal is an active low input for each UART. The logic state of this signal is reflected in MSR (5) and any change of state in either DSR pin will set DDSR bit MSR (1) of each Modem Status Register. When active, it informs that the Modem or data set is ready to establish communication.                          |
| 29,8    | RLSD0<br>RLSD1 | 1   | Receive Line Signal Detect: This is an active low input for each UART. The logic state of this signal is reflected in MSR (7) and any change of state in either $\overline{\text{RLSD}}$ pin will set DRLSD bit MSR (3) of each Modem Status Register. When active, it informs that the data carrier has been detected by Modem or data set. |
| 30, 6   | RIO<br>RI1     | 1   | Ring Indicator: This signal is an active low input for each UART. The logic state of this signal is reflected in MSR (6) and TERI bit MSR (2) will be set when the state of either RI pin is changed from Low to high.                                                                                                                       |
| 4       | CLK            | 1   | Clock Input: The external clock input from a crystal oscillator.                                                                                                                                                                                                                                                                             |
| 1       | LPTOE          |     | Line Printer Output Enable: This input signal enables the data outputs of the parallel line printer when it is low. When it is high, the data pins of the line printer are held in a high-impedance state. This pin may be tied to ground for normal line printer operation.                                                                 |
| 53-46   | PD0-PD7        | 0   | Parallel Data Bus: This bus provides a byte-wide input or output port to the system. The eight lines are held in a high-impedance state when the port is not selected.                                                                                                                                                                       |
| 68      | ACK            | 1   | Acknowledge: This signal goes low to indicate that the printer has already received a character and is ready to accept another.                                                                                                                                                                                                              |
| 67      | PE             | 1   | Paper Empty: This signal goes high when the line printer has run out of paper.                                                                                                                                                                                                                                                               |
| 66      | BUSY           | ı   | Busy: This signal goes high when the line printer has a local operation in progress and cannot accept data.                                                                                                                                                                                                                                  |
| 65      | SLCT           |     | Selected: This signal goes high when the line printer has been selected.                                                                                                                                                                                                                                                                     |



## Pin Description (Continued)

| Pin No.                     | Symbol          | 1/0 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------|-----------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 63                          | ERR             | 1   | Error: This signal goes low when the line printer has encountered an error condition.                                                                                                                                                                                                                                                                                                                                                                                   |
| 58                          | SLIN            | 1/0 | Line Printer Select: This signal is used to select the printer when it is low.                                                                                                                                                                                                                                                                                                                                                                                          |
| 57                          | ĪNIT            | 1/0 | Line Printer Initialize: When this signal goes low, it will allow the line printer initialization routine to be started.                                                                                                                                                                                                                                                                                                                                                |
| 56                          | AFD             | 1/0 | Line Printer Autofeed: When this signal goes low, it will cause the printer to line-feed after a line is printed.                                                                                                                                                                                                                                                                                                                                                       |
| 55                          | STB             | 1/0 | Line Printer Strobe: When this signal is low, it provides the line printer a signal to latch the data currently on the parallel port. This signal should keep low at least $0.5~\mu s$ to ensure the completion of data latch.                                                                                                                                                                                                                                          |
| 45, 60                      | INTO<br>INT1    | 0   | Serial Channel Interrupts. Each Serial channel interrupt goes high when one of the following interrupts has an active condition and is enabled by the IER of its associated channel: Receiver Error Flag, Receiver Data Available, Transmitter Holding Register Empty, and Modem Status. The interrupt is reset to low upon appropriate service. This pin will be held in a high-impedance state if the MCR (3) of each associated channel is programmed low (logic 0). |
| 59                          | INT2            | 0   | Line Printer Interrupt: This interrupt goes low when ACK goes low. This signal is enabled by Bit 4 of the Printer Control Register and will be held in a high-impedance state if Bit 4 of the printer Control Register is programmed low.                                                                                                                                                                                                                               |
| 23, 40, 64                  | V <sub>CC</sub> | 1   | Power Supply: +5V                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2,7,9,22,27,<br>42,43,54,61 | GND             |     | Ground: 0V                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

### **Functional Description:**

#### Serial Channel Registers:

Three types of internal registers are used in each serial channel of the UM82C452. They are used in the operation of the device, and are the control, status, and data registers. The control registers are the Baud Rate Select Register DLL (Divisor Latch LSB) and DLM (Divisor Latch MSB), Line Control Register. Interrupt Enable Register, and the Modem Control register. The status registers are the Line Status Registers and the Modem Status Register. The data registers are the Receiver Buffer Register and the Transmitter Holding Register. Address, Read, and Write inputs are used in conjunction with the Divisor Latch Access Bit (DLAB) in the Line Control Register LCR (7) to select the register to be written or read (see Table 1). Individual bits within these registers are referred to by the register mnemonic and the bit number in parenthesis. An example, LCR (7) refers to Line Control Register Bit 7.

The Transmitter Buffer Register and Receiver Buffer

Register are data registers holding from five to eight bits of data. If less than eight data bits are transmitted, data is right justified to the LSB. Bit 0 of a data word is always the first serial data bit received and transmitted. The UM82C452 data registers are double-buffered so that read and write operations can be performed at the same time the UART is performing the parallel-to-serial and serial-to-parallel conversion.

The format of the data character is controlled by the Line Control Register. The contents of the LCR may be read, eliminating the need for separate storage of the line characteristics in system memory. The contents of the LCR are described below.

LCR (0) Word Length Select Bit 0 (WLS0)

LCR (1) Word Length Select Bit 1 (WLS1)

LCR (2) Stop Bit Select (STB)

LCR (3) Parity Enable (PEN)



| DLAB | A2 | A1 | A0 | Mnemonic | Register                                      |
|------|----|----|----|----------|-----------------------------------------------|
| 0    | 0  | 0  | 0  | RBR      | Receiver Buffer Register (read only)          |
| 0    | 0  | 0  | 0  | THR      | Transmitter Holding Register (write only)     |
| 0    | 0  | 0  | 1  | IER      | Interrupt Enable Register                     |
| ×    | 0  | 1  | 0  | IIR      | Interrupt Identification Register (read only) |
| X    | 0  | 1  | 1  | LCR      | Line Control Register                         |
| ×    | 1  | 0  | 0  | MCR      | Modem Control Register                        |
| X    | 1  | 0  | 1  | LSR      | Line Status Register                          |
| ×    | 1  | 1  | 0  | MSR      | Modem Status Register                         |
| X    | 1  | 1  | 1  | SCR      | Scratch Register                              |
| 1    | 0  | 0  | 0  | DLL      | Divisor Latch (LSB)                           |
| 1    | 0  | 0  | 1  | DLM      | Divisor Latch (MSB)                           |

Table 1. Serial Channel Internal Registers

X = "Don't Care"

0 = Logic Low

1 = Logic High

Note: Serial Channel 0 is accessed when  $\overline{CS0}$  is low; Serial Channel 1 is accessed when  $\overline{CS1}$  is low. Selecting both channels simultaneously is an invalid condition.

LCR (4) Even Parity Select (EPS)

LCR (5) Stick Parity

LCR (6) Set Break

LCR (7) Divisor Latch Access Bit (DLAB)

LCR (0) and LCR (1) word length select bit 1: The number of bits in each serial character is programmed as shown in the following chart:

| LCR (1) | LCR (0) | Word Length |
|---------|---------|-------------|
| 0       | 0       | 5 Bits      |
| 0       | 1       | 6 Bits      |
| 1       | 0       | 7 Bits      |
| 1       | 1       | 8 Bits      |

LCR (2) Stop Bit Select: LCR (2) specifies the number of stop bits in each transmitted character. If LCR (2) is a logic 0, one stop bit is generated in the transmitted data. If LCR (2) is a logic 1 when a 5-bit word length is selected, 1.5 stop bits are generated. If LCR (2) is a logic 1 when either a  $6_7$  7-, or 8-bit word length is selected, two stop bits are generated. The receiver checks for two stop bits if programmed.

LCR (3) Parity Enable. When LCR (3) is high, a parity bit between the last data word bit and stop bit is generated and checked.

LCR (4) Even Parity Select: When parity is enabled (LCR (3) = 1). LCR (4)-0 selects odd parity, and LCR (4) = 1 selects even parity.

LCR (5) Stick Parity: When parity is enabled (LCR (3) =

1), LCR (5) = 1 causes the transmission and reception of a parity bit to be in the opposite state from that indicated by LCR (4). This allows the user to force parity to a known state and for the receiver to check the parity bit in a known state.

LCR (6) Break Control: When LCR (6) is set to a logic "1", the serial output (SOUT) is forced to the spacing (logic 0) state. The break is disabled by setting LCR (6) to a logic "0". The Break Control bit acts only on SOUT and has no effect on the transmitter logic. Break Control enables the CPU to alert a terminal in a computer communications system. If the following sequence is used, no erroneous or extraneous characters will be transmitted because of the break.

- 1. Load an all "0"s pad character in response to THRE.
- 2. Set break in response to the next THRE.
- Wait for the transmitter to be idle (TEMT = 1), and clear break when normal transmission has to be restored.

LCR (7) Divisor Latch Access Bit (DLAB): LCR (7) must be set high (logic "1") to access the Divisor Latches DLL and DLM of the Baud Rate Generator during a read or write operation. LCR (7) must be input low to access the Receiver Buffer, the Transmitter Holding, or the Interrupt Enable Registers.

The Line Status Register (LSR) is a single register that provides status indications. The LSR is usually the first register read by the CPU to determine the cause of an interrupt or to poll the status of each serial channel of the UM82C452.

Three error flags OE, FE, and PE provide the status of





Figure 1. Line Control Register

any error conditions detected in the receiver circuitry. During reception of the stop bits, the error flags are set high by an error condition. The error flags are not reset by the absence of an error condition in the next received character. The flags reflect the last character only if no overrun occurred. The Overrun Error (OE) indicates that a character in the Receiver Buffer Register has been overwritten by a character from the Receiver Shift Register before being read by the CPU. The character is thereby lost. Framing Error (FE) indicates that the last character received contained incorrect (low) stop bits. This is caused by the absence of the required stop bit or by a stop bit too short to be detected. Parity Error (PE) indicates that the last character received had a parity error based on the programmed and calculated parity of the received character.

The Break Interrupt (BI) status bit indicates that the last character received was a break character. A break character is an invalid data character. However, it is an entire character, including parity and stop bits.

The Transmitter Holding Register Empty (THRE) bit indicates that the THR register is empty and may receive another character. The Transmission Shift Register Empty (TEMT) bit indicates that the Transmitter Shift Register

is empty, and the serial channel has completed transmission of the last character to be sent. If the interrupt is enabled [IER (1)], an active THRE causes an interrupt (INTRPT).

The Data Ready (DR) bit indicates that the RBR has been loaded with a received character (including Break) and that the CPU may access this data.

Reading the LSR clears LSR (1)-LSR (4), (OE, PE, FE, and  $BI_{\star}$ )

The contents of the Line Status Register shown in Table 2 are described below:

LSR (0) Data Ready (DR): Data Ready is set high when an incoming character has been received and transferred into the Receiver Buffer Register. LSR (0) is reset low by a CPU read of the data in the Receiver Buffer Register.

LSR (1) Overrun Error (OE): Overrun Error indicates that data in the Receiver Buffer Register was not read by the CPU before the next character was transferred into the Receiver Buffer Register, overwriting the previous character. The OE indicator is reset whenever the CPU reads the contents of the Line Status Register.



| Table | 2. | Line | Status | Register | Bits |
|-------|----|------|--------|----------|------|
|-------|----|------|--------|----------|------|

|         | LSR Bits                                  | Logic 1 | Logic 0   |
|---------|-------------------------------------------|---------|-----------|
| LSR (0) | Data Ready (DR)                           | Ready   | Not Ready |
| LSR (1) | Overrun Error (OE)                        | Error   | No Error  |
| LSR (2) | Parity Error (PE)                         | Error   | No Error  |
| LSR (3) | Framing Error (FE)                        | Error   | No Error  |
| LSR (4) | Break Interrupt (BI)                      | Break   | No Break  |
| LSR (5) | Transmitter Holding Register Empty (THRE) | Empty   | Not Empty |
| LSR (6) | Transmitter Empty (TEMT)                  | Empty   | Not Empty |
| LSR (7) | Not Used                                  |         | ,         |

LSR (2) Parity Error (PE): Parity Error indicates that the received data character does not have the correct even or odd parity, as selected by the Even Parity Select bit [LCR (4)]. The PE bit is set high upon detection of a parity error, and is reset low when the CPU reads the contents of the LSR.

LSR (3) Framing Error (FE): Framing Error indicates that the received character did not have a valid stop bit. LSR (3) is set high when the stop bit following the last data bit or parity bit is detected as a zero bit (spacing level). The FE indicator is reset low when the CPU reads the contents of the LSR.

LSR (4) Break Interrupt (BI): Break Interrupt is set high when the received data input is held in the spacing (logic 0) state for longer than a full word transmission time (start bit + data bits + parity + stop bits). The BI indicator is reset when the CPU reads the contents of the Line Status Register.

LSR (1) LSR (4) are the error conditions that produce a Receiver Line Status interrupt (priority 1 interrupt in the Interrupt Identification Register (IIR)) when any of the conditions are detected. This interrupt is enabled by setting IER (2) = 1 in the Interrupt Enable Register.

LSR (5) Transmitter Holding Register Empty (THRE): THRE indicates that the UM82C450 is ready to accept a new character for transmission. The THRE bit is set high when a character is transferred from the Transmitter

Holding Register into the Transmitter Shift Register. LSR (5) is reset low by the loading of the Transmitter Holding Register by the CPU. LSR (5) is not reset by a CPU read of the LSR.

When the THRE interrupt is enabled (IER (1) = 1), THRE causes a priority 3 interrupt in the IIR, If THRE is the interrupt source indicated in IIR, INTRPT is cleared by a read of the IIR.

LSR (6) Transmitter Empty (TEMT): TEMT is set high when the Transmitter Holding Register (THR) and the Transmitter Shift Register (TSR) are both empty. LSR (6) is reset low when a character is loaded into the THR and remains low until the character is transferred out of SOUT. TEMT is not reset low by a CPU read of the LSR.

LSR (7): This bit is always 0.

The Modem Control Register (MCR) controls the interface with the modem or data set as described in Table 3. The MCR can be written and read. The RTS and DTR outputs are directly controlled by their control bits in this register. A high input asserts a low (true) at the output pins. MCR Bits 0, 1, 3, and 4 are shown below:

MCR (0): When MCR (0) is set high, the DTR output is forced low. When MCR (0) is reset low, the DTR output is forced high. The DTR output of the serial channel may be input into an inverting line driver in order to

Table 3. Modem Control Register Bits

| MCR Bits                                                                  | Logic 1                          | Logic 0                            |
|---------------------------------------------------------------------------|----------------------------------|------------------------------------|
| MCR (0) Data Terminal Ready (DTR) MCR (1) Request to Send (RTS) MCR (2) 0 | DTR Output Low<br>RTS Output Low | DTR Output High<br>RTS Output High |
| MCR (3) Interrupt (INT) Enable MCR (4) Loop MCR (5) 0 MCR (6) 0 MCS (7) 0 | INT Enabled<br>Loop Enabled      | INT Disabled<br>Loop Disabled      |





Figure 2. Modem Control Register

obtain the proper polarity input at the modem or data set,

MCR (1): When MCR (1) is set high, the RTS output is forced low. When MCR (1) is reset low, the RTS output is forced high. The RTS output of the serial channel may be input into an inverting line driver in order to obtain the proper polarity input at the modem or data set.

MCR (3): When MCR (3) is set high, the INT output is enabled.

MCR (4). MCR (4) provides a local loopback feature for diagnostic testing of the channel. When MCR (4) is set high, Serial Output (SOUT) is set to the marking (logic "1") state, and the receiver data input Serial Input (SIN) is disconnected. The output of the Transmitter Shift Register is looped back into the Receiver Shift Register input. The three modem control inputs (CTS, DSR, and RI) are disconnected. The modem control outputs (DTR and RTS) are internally connected to the four modem control inputs. The modem control output pins are forced to their inactive state (high).

In the diagnostic mode, data transmitted is immediately received. This allows the processor to verify the transmit and receive data paths of the selected serial channel. Bits MCR(5)—MCR(7) are permanently set to logic 0.

The MSR provides the CPU with status of the modem input lines from the modem or peripheral devices. The MSR allows the CPU to read each of the several channel modem signal inputs by accessing the data bus interface of the UM82C452. In addition to the current status information, four bits of the MSR indicate whether the

modem inputs have changed since the last reading of the MSR. The delta status bits are set high when a control input from the modem changes state, and reset low when the CPU reads the MSR.

The modem input lines for each channel are CTS, DSR, RT and RLSD. MSR (4) MSR (7) are status indications of these lines. The status indications follow the status of the input lines. If the modem status interrupt in the Interrupt Enable Register is enabled [IER (3)], a change of state in modem input signals will be reflected by the modem status bits in the ITR register, and an interrupt (INTRPT) is generated. The MSR is a priority 4 interrupt. The contents of the Modem Status Register are described in Table 4. Note that the states (high or low) of the status bits are inverted versions of the actual input pins.

MSR (0) Delta Clear to Send (DCTS): DCTS indicates that the CTS input to the serial channel has changed state since the last time it was read by the CPU.

MSR (1) Delta Data Set Ready (DDSR): DDSR indicates that the DSR input to the serial channel has changed state since the last time it was read by the CPU.

MSR (2) Trailing Edge of Ring Indicator (TERI): TERI indicates that the RI input to the serial channel has changed state from high to low since the last time it was read by the CPU. Low to high transitions on RI do not activate TERI.

MSR (3) Delta Data Carrier Detect (DRSLD): DRSLD indicates that the RSLD input to the serial channel has changed state since the last time it was read by the CPU.



Table 4. Modem Status Register Bits

| MSR Bit                                                                              | Mnemonic                             | Description                                                                                                                                                                |
|--------------------------------------------------------------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MSR (1)<br>MSR (2)<br>MSR (0)<br>MSR (3)<br>MSR (4)<br>MSR (5)<br>MSR (6)<br>MSR (7) | DDSR TERI DCTS DRLSD CTS DSR RI RLSD | Delta Data Set Ready Trailing Edge of Ring Indicator Delta Clear to Send Delta Data Carrier Detect Clear To Send Data Set Ready Ring Indicator Receiver Line Signal Detect |

MSR (4) Clear to Send (CTS): Clear to Send (CTS) is the status of the CTS input from the modem indicating to the serial channel that the modem is ready to receive data from the serial channel is transmitter output (SOUT). If the serial channel is in loop mode [MSR (4) = 1]. MSR (4) is equivalent to  $\overline{RTS}$  in the MCR.

MSR (5) Data Set Ready (DSR): Data Set Ready (DSR) is a status of the DSR input from the modem to the serial channel which indicates that the modem is ready to provide received data to the serial channel receiver circuitry. If the channel is in the loop mode [MCR (4) = 1], MSR (5) is equivalent to DTR in the MCR.

MSR (6) Ring Indicator: Indicates the status to the RI input (pin 39). If the channel is in the loop mode [MCR (4) = 1], MSR (6) is not connected in the MCR.

MSR (7) Receive Line Signal Detect: Receive Line Signal Detect indicates the status of the Receive Line Signal Detect  $(\overline{RLSD})$  input. If the channel is in the loop mode [MCR (4) = 1], MSR (4) is equivalent to OUT2 of the MCR.

The modem status inputs (RI, RLSD, DSR, and CTS) reflect the modem input lines with any change of status. Reading the MSR register will clear the delta modem status indications but has no effect on the status bits. The status bits reflect the state of the input pins regardless of the mask control signals. If DCTS, DDSR, TERI, or DRLSD are true, and a state change occurs during a read operation (DISTR), the state change is not indicated in the MSR. If DCTS, DDSR, TERI, or DRLSD are false, and a state change occurs during a read operation, the state change is indicated after the read operation.

For LSR and MSR, the setting of status bits is inhibited during status register read DISTR operations. If a status condition is generated during a read DISTR operation, the status bit is not set until the trailing edge of the read DISTR.

If a status bit is set during a read  $\overline{\text{DISTR}}$  operation, and the same status condition occurs, that status bit will be cleared at the trailing edge of the read  $\overline{\text{DISTR}}$  instead

of being set again.

Each UM82C452 serial channel contains a programmable Baud Rate Generator (BRG) that divides the clock (DC to 3.1 MHz) by any divisor from 1 to  $2^{16}-1$  (see also BRG description). The output frequency of the Baud Generator is 16X the data rate [divisor # = clock + (baud rate × 16)]. Two 8-bit divisor latch registers store the divisor in a 16-bit binary format. These Divisor Latch registers must be loaded during initialization. Upon loading either of the Divisor latches, a 16-bit baud counter is immediately loaded. This prevents long counts on initial load.

The receiver circuitry in each serial channel of the UM82C452 is programmable for 5, 6, 7, or 8 data bits per character. For words of less than 8 bits, the data is right justified to the least significant bit LSB = Data Bit 0 [RBR (0)]. Data Bit 0 of a data word [RBR (0)] is the first data bit received. The unused bits in a character less than 8 bits are output low to the parallel output by the serial channel.

Received data at the SIN input pin is shifted into the Receiver Shift Register by the 16X clock provided at the RCLK input. This clock is synchronized to the incoming data based on the position of the start bit. When a complete character is shifted into the Receiver Shift Register, the assembled data bits are parallel loaded into the Receiver Buffer Register. The DR flag in the LSR register is set.

Double buffering of the received data permits continuous reception of data without losing received data. While the Receiver Shift Register is shifting a new character into the serial channel, the Receiver Buffer Register is holding a previously received character for the CPU to read. Failure to read the data in the RBR before complete reception of the next character result in the low of the data in the Receiver Register. The OE flag in the LSR register indicates the overrun condition.

RBR Bits 0 thru 7:

| RBR | (0) | Data Bit 0 |
|-----|-----|------------|
| RBR | (1) | Data Bit 1 |
| RBR | (2) | Data Bit 2 |
| RBR | (3) | Data Bit 3 |
| RBR | (4) | Data Bit 4 |
| RBR | (5) | Data Bit 5 |
| RBR | (6) | Data Bit 6 |
| RBR | (7) | Data Bit 7 |

The Transmitter Holding Register (THR) holds parallel data from the data bus (D0-D7) until the Transmitter Shift Register is empty and ready to accept a new character for transmission. The transmitter and receiver word length and number of stop bits are the same. If the character is less than eight bits, unused bits at the microprocessor



data bus are ignored by the transmitter.

Data Bit 0 [THR (0)] is the first serial data bit transmitted. The THRE flag [LSR (5)] reflect the status of the THR. The TEMT flag [LSR (5)] indicates if both the THR and TSR are empty.

#### THR Bits 0 thru 7

| THR | (0) | Data | Bit | 0 |
|-----|-----|------|-----|---|
| THR | (1) | Data | Bit | 1 |
| THR | (2) | Data | Bit | 2 |
| THR | (3) | Data | Bit | 3 |
| THR | (4) | Data | Bit | 4 |
| THR | (5) | Data | Bit | 5 |
| THR | (6) | Data | Bit | 6 |
| THR | (7) | Data | Bit | 7 |
|     |     |      |     |   |

The Scratchpad Register is an 8-bit Read/Write register that has no effect on either channel in the UM82C452. It is intended to be used by the programmer to hold data temporarily.

### SCR Bits 0 thru 7

| SCR | (0) | Data Bit 0 |
|-----|-----|------------|
| SCR | (1) | Data Bit 1 |
| SCR | (2) | Data Bit 2 |
| SCR | (3) | Data Bit 3 |
| SCR | (4) | Data Bit 4 |
| SCR | (5) | Data Bit 5 |
| SCR | (6) | Data Bit 6 |
| SCR | (7) | Data Bit 7 |

### Interrupts

The Interrupt Identification Register (IIR) of each serial channel of the UM82C452 has interrupt capability for interfacing to current microprocessors. In order to minimize software overhead during data character transfers, the serial channel prioritizes interrupts into four levels. The four levels of interrupt conditions are as follows:

- 1. Receiver Line Status (priority 1)
- 2. Received Data Ready (priority 2)
- 3. Transmitter Holding Register Empty (priority 3)
- 4. Modem Status (priority 4)

Information indicating that a prioritized interrupt is pending and the type of interrupt is stored in the Interrupt Identification Register (IIR). When addressed during chip select time, the IIR indicates the highest priority interrupt pending. No other interrupts are acknowledged until the interrupt is serviced by the CPU. The logic equivalent of the interrupt control circuit is shown in Figure 3. The contents of the IIR are indicated in Table 5 and are described below.

IIR (0): IIR (0) can be used in either a hard-wired prioritiz-

ed or polled environment to indicate whether an interrupt is pending. When IIR (0) is low, an interrupt is pending, and IIR contents may be used as a pointer to the appropriate interrupt service routine. When IIR(0) is high, no interrupt is pending.

IIR (1) and IIR (2) are used to identify the highest priority interrupt pending as indicated in Table 5.

IIR (3)-IIR (7): These five bits of the IIR are logic 0.

The Interrupt Enable Register (IER) is a Write register used to independently enable the four serial channel interrupts which activate the interrupt (INTRPT) output. All interrupts are disabled by resetting IER (0)-IER (3) of the Interrupt Enable Register. Interrupts are enabled by setting the appropriate bits of the IER high. Disabling the interrupt system inhibits the Interrupt Identification Register and the active (high) INTRPT output. All other system functions operate in their normal manner, including the setting of the Line Status and Modem Status Registers. The contents of the Interrupt Enable Register are indicated in Table 6 and are described below.

IER (0): When programmed high [IER (0) = Logic 1], IER (0) enables Received Data Available Interrupt.

IER (1): When programmed high [IER (1) = Logic 1], IER (1) enables the Transmitter Holding Register Empty interrupt.

IER (2): When programmed high [IER (2) = Logic 1], IER (2) enables the Receiver Line Status interrupt.

IER (3): When programmed high [IER (3) = Logic 1], IER (3) enables the Modern Status Interrupt.

IER (4)-IER (7): These four bits of the IER are logic 0.

#### Transmitter

The serial transmitter section consists of a Transmitter Holding Register (THR), Transmitter Shift Register (TSR), and associated control logic. The Transmitter Holding Register Empty (THRE) and Transmitter Shift Register Empty (TEMT) are two bits in the Line Status Register which indicate the status of THR and TSR. To transmit a 5- to 8-bit word, the word is written through D0-D7 to the THR. The microprocessor should perform a write operation only if THRE is high. The THRE is set high when the word is automatically transferred from the THR to the TSR during the transmission of the start bit.



| Table 5 | 5. 1 | nterrupt | Identification | Register |
|---------|------|----------|----------------|----------|
|---------|------|----------|----------------|----------|

|       | Interrupt I | dentifica            | tion   | Interrupt Set and Reset Functions |                            |                                                          |  |  |
|-------|-------------|----------------------|--------|-----------------------------------|----------------------------|----------------------------------------------------------|--|--|
| Bit 2 | Bit 1       | Bit 0 Priority Level |        | Interrupt<br>Flag                 | Interrupt<br>Source        | Interrupt<br>Reset Control                               |  |  |
| ×     | ×           | 1                    |        | None                              | None                       |                                                          |  |  |
| 1     | 1           | 0                    | First  | Receiver<br>Line Status           | OE, PE<br>FE, or BI        | LSR Read                                                 |  |  |
| 1     | 0           | 0                    | Second | Received Data<br>Available        | Received Data<br>Available | RBR Read                                                 |  |  |
| 0     | 1           | 0                    | Third  | THRE                              | THRE                       | IIR Read if THRE is the<br>Interrupt Source or THR Write |  |  |
| 0     | 0           | 0                    | Fourth | Modem Status                      | -CTS, -DSR<br>-RI, -RSLD   | MSR Read                                                 |  |  |

X = Not Defined.



Figure 3. Interrupt Control Logic



Table 6. Serial Channel Accessible Registers

| D 111                | Register Bit Number             |                                |                                                       |                                   |                                                   |                                                 |                                                             |                                                                 |  |  |  |
|----------------------|---------------------------------|--------------------------------|-------------------------------------------------------|-----------------------------------|---------------------------------------------------|-------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------|--|--|--|
| Register<br>Mnemonic | Bit 7                           | Bit 6                          | Bit 5                                                 | Bit 4                             | Bit 3                                             | Bit 2                                           | Bit 1                                                       | Bit 0                                                           |  |  |  |
| RBR<br>(Read Only)   | Data<br>Bit 7<br>(MSB)          | Data<br>Bit 6                  | Data<br>Bit 5                                         | Data<br>Bit 4                     | Data<br>Bit 3                                     | Data<br>Bit 2                                   | Data<br>Bit 1                                               | Data<br>Bit 0<br>(LSB)*                                         |  |  |  |
| THR<br>(Write Only)  | Data<br>Bit 7                   | Data<br>Bit 6                  | Data<br>Bit 5                                         | Data<br>Bit 4                     | Data<br>Bit 3                                     | Data<br>Bit 2                                   | Data<br>Bit 1                                               | Data<br>Bit 0                                                   |  |  |  |
| DLL                  | Bit 7                           | Bit 6                          | Bit 5                                                 | Bit 4                             | Bit 3                                             | Bit 2                                           | Bit 1                                                       | Bit 0                                                           |  |  |  |
| DLM                  | Bit 15                          | Bit 14                         | Bit 13                                                | Bit 12                            | Bit 11                                            | Bit 10                                          | Bit 9                                                       | Bit 8                                                           |  |  |  |
| IER                  | 0                               | 0                              | 0                                                     | 0                                 | (EDSSI)<br>Enable<br>Modem<br>Status<br>Interrupt | (ELSI) Enable Receiver Line Status Interrupt    | (ETBEI) Enable Transmitter Holding Register Empty Interrupt | (ERBFI)<br>Enable<br>Received<br>Data<br>Available<br>Interrupt |  |  |  |
| IIR<br>(Read Only)   | 0                               | 0                              | 0                                                     | 0                                 | 0                                                 | Interrupt<br>ID<br>Bit (1)                      | Interrupt<br>ID<br>Bit (0)                                  | "0" 1F<br>Interrupt<br>Pending                                  |  |  |  |
| LCR                  | (DLAB) Divisor Latch Access Bit | Set<br>Break                   | Stick<br>Parity                                       | (EPS)<br>Even<br>Parity<br>Select | (PEN)<br>Parity<br>Enable                         | (STB)<br>Number<br>of Stop<br>Bits              | (WLSB1)<br>Word<br>Length<br>Select<br>Bit 1                | (WLSB0)<br>Word<br>Length<br>Select<br>Bit 0                    |  |  |  |
| MCR                  | 0                               | 0                              | 0                                                     | Loop                              | Out 2                                             | Out 1                                           | (RTS)<br>Request<br>To<br>Send                              | (DTR)<br>Data<br>Termina<br>Ready                               |  |  |  |
| LSR                  | 0                               | (TEMT)<br>Transmitter<br>Empty | (THRE)<br>Transmitter<br>Holding<br>Register<br>Empty | (BI)<br>Break<br>Interrupt        | (FE)<br>Framing<br>Error                          | (PE)<br>Parity<br>Error                         | (OE)<br>Overrun<br>Error                                    | (DR)<br>Data<br>Ready                                           |  |  |  |
| MSR                  | (DCD) Data Carrier Detect       | (RI)<br>Ring<br>Indicator      | (DSR)<br>Data<br>Ready<br>Set                         | (CTS)<br>Clear<br>to<br>Send      | (DRSLD) Delta Receive Line Signal Detect          | (TERI)<br>Trailing<br>Edge<br>Ring<br>Indicator | (DDSR)<br>Delta<br>Data<br>Set<br>Ready                     | (DCTS)<br>Delta<br>Clear<br>to<br>Send                          |  |  |  |
| SCR                  | Bit 7                           | Bit 6                          | Bit 5                                                 | Bit 4                             | Bit 3                                             | Bit 2                                           | Bit 1                                                       | Bit 0                                                           |  |  |  |

LSB Data Bit 0 is the first bit transmitted or received.



When the transmitter is idle, both THRE and TEMT are high. The first word written causes THRE to be reset to 0. After completion of the transfer, THRE returns high. TEMT remains low for at least the duration of the transmission of the data word. If a second character is transmitted to the THR, the THRE is reset low. Since the data word cannot be transferred from the THR to the TSR until the TSR is empty. THRE remains low until the TSR has completed transmission of the word. When the last word has been transmitted out of the TSR, TEMT is set high. THRE is set high one THR to TSR transfer time later.

#### Receiver

Serial asynchronous data is input into the SIN pin. The idle state of the line providing the input into SIN is high. A start bit detect circuit continually searches for a high to low transition from the idle state. When the transition is detected, a counter is reset, and counts the 16X clock to 7½ which is the center of the start bit. The start bit is valid if the SIN is still low at the midbit sample of the start bit, Verifying the start bit prevents the receiver from assembling an incorrect data character due to a low going noise spike on the SIN input.

The Line Control Register determines the number of data bits in a character (LCR (0), LCR (1)), number of stop bits LCR (2), if parity is used LCR (3), and the polarity of parity LCR (4). If Status information for the receiver is provided in the Line Status Register to the Receiver Buffer Register, the Data Received indication in LSR (0) is set high, the CPU reads the Receiver Buffer Register through D0-D7. This read resets LSR (0). If D0-D7 are not read prior to a new character transfer from the RSR to the RBR, the overrun error status indication is set in LSR (1). The parity check tests for even or odd parity on the parity bit, which precedes the first stop bit. If there is a parity error, the parity error is set in LSR (2). There is circuitry which tests whether the stop bit is high. If it is not, a framing error indication is generated in LSR (3).

The center of the start bit is defined as clock count 7%. If the data into SIN is a symmetrical square wave, the center—of the data cells will occur within  $\pm 3.125\%$  of the actual center, providing an error margin of 46.875%. The start bit can begin as much as one 16X clock cycle prior to being detected.

### Baud Rate Generator (BRG)

The BRG generates the clocking for the UART function, providing standard ANSI/CCITT bit rates. The oscillator driving the BRG is provided by an external clock into CLK.

The bit rate is selected by programming the two divisor latches, Divisor Latch Most Significant Byte and Divisor Latch Least Significant Byte. Setting DLL=1 and DLM=0 selects the divisor to divide by 1 (divide by 1 gives maximum baud rate for a given input frequency at the CLK input).

The BRG can use any of three different popular frequencies to provide standard baud rates. These frequencies are 1.8432 MHz, 2.4576 MHz, and 3.072 MHz. With these frequencies, standard bit rates from 50 to 38.5 kbps are available. Tables 7, 8, and 9 illustrate the divisors needed to obtain standard rates using these three crystal frequencies.

### Reset

After power up, the UM82C452 RESET input (MR) should be held low for 500 ns to reset the UM82C452 circuits to an idle mode until initialization. A low on RESET causes the following:

- Initializes the transmitter and receiver internal clock counters
- Clears the Line Status Register (LSR), except for Transmitter Shift Register Empty (TEMT) and Transmit Holding Register Empty (THRE), which are set. The Modem Control Register (MCR) is also cleared. All of the discrete lines, memory elements and logic associated with these register bits are also cleared or turned off. The Line Control Register (LCR), Divisor Latches, Receiver Buffer Register, Transmitter Buffer Register are not affected.

Following removal of the reset condition (Reset high), the UM82C452 remains in the idle mode until programmed.

A hardware reset of the UM82C452 sets the THRE and TEMT status bit in the LSR. When interrupts are subsequently enabled, an interrupt occurs due to THRE.

A summary of the effect of a reset on the UM82C452 is given in Table 10.

### **Programming**

Each serial channel of the UM82C452 is programmed by the control registers LCR, IER, DLL and DLM, and MCR. These control words define the character length, number of stop bits, parity, baud rate, and modem interface. While the control register can be written in any order, the IER should be written to last because it controls the interrupt enables. Once a serial channel is programmed and operational, these registers can be updated any time the UM82C452 serial channel is not transmitting or receiving data.



The control signals required to access each serial channel's internal registers are shown below.

### Software Reset

A software reset of the serial channel is a useful method for returning to a completely known state without a system reset. Such a reset consists of writing to the LCR, Divisor Latches, and MCR registers. The LSR and RBR registers should be read prior to enabling interrupts in order to clear out any residual data or status bits which may be invalid for subsequent operation.

## **Clock Input Operation**

The maximum input frequency of the external clock of the UM82C452 is 3.1 MHz.

Table 7. Baud Rates (1,8432 MHz Clock)

| Desired<br>Baud Rate | Divisor Used | Percent Error<br>Difference Between<br>Desired and Actual |
|----------------------|--------------|-----------------------------------------------------------|
| 50                   | 2304         | _                                                         |
| 75                   | 1536         | _                                                         |
| 110                  | 1047         | 0.026                                                     |
| 134.5                | 857          | 0.058                                                     |
| 150                  | 768          | _                                                         |
| 300                  | 384          | _                                                         |
| 600                  | 192          | _                                                         |
| 1200                 | 96           | _                                                         |
| 1800                 | 64           | _                                                         |
| 2000                 | 58           | 0.69                                                      |
| 2400                 | 48           | -                                                         |
| 3600                 | 32           | _                                                         |
| 4800                 | 24           | _                                                         |
| 7200                 | 16           | _                                                         |
| 9600                 | 12           | _                                                         |
| 19200                | 6            | _                                                         |
| 38400                | 3            | -                                                         |
| 56000                | 2            | 2.86                                                      |

Table 8. Baud Rates (2.4576 MHz Clock)

| Desired<br>Baud Rate | Divisor Used | Percent Error<br>Difference Between<br>Desired and Actual |
|----------------------|--------------|-----------------------------------------------------------|
| 50                   | 3072         | -                                                         |
| 75                   | 2048         | -                                                         |
| 110                  | 1396         | 0.026                                                     |
| 134.5                | 1142         | 0.0007                                                    |
| 150                  | 1024         | _                                                         |
| 300                  | 512          | -                                                         |
| 600                  | 256          | -                                                         |
| 1200                 | 128          | _                                                         |
| 1800                 | 85           | 0.392                                                     |
| 2000                 | 77           | 0.260                                                     |
| 2400                 | 64           | _                                                         |
| 3600                 | 43           | 0.775                                                     |
| 4800                 | 32           | -                                                         |
| 7200                 | 21           | 1.587                                                     |
| 9600                 | 16           | -                                                         |
| 19200                | 8            | _                                                         |
| 38400                | 4            | _                                                         |

Table 9. Baud Rates (3.072 MHz Clock)

| Desired<br>Baud Rate | Divisor Used | Percent Error<br>Difference Between<br>Desired and Actual |
|----------------------|--------------|-----------------------------------------------------------|
| 50                   | 3840         | _                                                         |
| 75                   | 2560         | -                                                         |
| 110                  | 1745         | 0.026                                                     |
| 134.5                | 1428         | 0.034                                                     |
| 150                  | 1280         | -                                                         |
| 300                  | 640          | _                                                         |
| 600                  | 320          | -                                                         |
| 1200                 | 160          | _                                                         |
| 1800                 | 107          | 0.312                                                     |
| 2000                 | 96           | _                                                         |
| 2400                 | 80           | _                                                         |
| 3600                 | 53           | 0.628                                                     |
| 4800                 | 40           | _                                                         |
| 7200                 | 27           | 1,23                                                      |
| 9600                 | 20           | _                                                         |
| 19200                | 10           | _                                                         |
| 38400                | 5            | -                                                         |



Table 10. Reset Control of Register and Pinout Signals

| Register/Signal                   | Reset Control  | Reset Status                                 |
|-----------------------------------|----------------|----------------------------------------------|
| Interrupt Enable Register         | Reset          | All Bits low                                 |
| Interrupt Identification Register | Reset          | Bit 0 is high and Bits 1-7 are low           |
| Line Control Register             | Reset          | All Bits low                                 |
| Line Status Register              | Reset          | Bits 5,6 are high, others are low            |
| Modem Status Register             | Reset          | Bits 0-3 are low, Bits 4-7 are input signals |
| SOUTO, SOUT1                      | Reset          | High                                         |
| RTSO, RTS1, DTRO, DTR1            | Reset          | High                                         |
| INTO, INT1, INT2                  | Reset          | High-Impedance                               |
| STB, AFD, SLIN                    | Reset<br>Reset | High,<br>Low                                 |

## **Device Application**





### **Functional Description:**

### Parallel Port Registers

The UM82C452 parallel port interfaces the device to a Centronics-style printer. When Chip Select 2 ( $\overline{\text{CS2}}$ ) is low, the parallel port is selected. Table 11 shows the registers associated with this parallel port. The read or write function of the register is controlled by the states of the read ( $\overline{\text{IOR}}$ ) and write ( $\overline{\text{IOW}}$ ) pins as shown. The top four registers are read-only registers, and the bottom four are write-only registers.

Since the parallel port is bidirectional, the first register (READ PORT) allows the microprocessor to read the information on the parallel bus. The second register (READ STATUS) allows the microprocessor to read the status of the printer in the five most significant bits. The status bits are Printer Busy (BUSY), Acknowledge (ACK), which is a handshake function, Paper Empty (PE), Printer Selected (SLCT), and Error (ERROR). The third register (READ CONTROL functions are duplicated in the sixth register (WRITE CONTROL).

The control bits are found in the five least significant bits of these registers,. They are Interrupt Enable (IRQ ENB), Select In  $\overline{(SLIN)}$ , Initialize the Printer  $\overline{(INIT)}$ ,

Autofeed the Paper (AUTOFD), and Strobe (\$11000), which informs the printer of the presence of a valid byte on the parallel bus. The fifth register (WRITE PORT) allows the microprocessor to write a byte to the printer.

The parallel port is completely compatible with the parallel port implementation used in the IBM Serial/Parallel Adaptor.

Table 12. Parallel Port Register Select

|      | Cor  | Register Selected |    |    |               |
|------|------|-------------------|----|----|---------------|
| -IOR | -IOW | -CS2              | A1 | A0 |               |
| 0    | 1    | 0                 | 0  | 0  | Read Port     |
| 0    | 1    | 0                 | 0  | 1  | Read Status   |
| 0    | 1    | 0                 | 1  | 0  | Read Control  |
| 0    | 1    | 0                 | 1  | 1  | Invalid       |
| 1    | 0    | 0                 | 0  | 0  | Write port    |
| 1    | 0    | 0                 | 0  | 1  | Invalid       |
| 1    | 0    | 0                 | 1  | 0  | Write Control |
| 1    | 0    | 0                 | 1  | 1  | Invalid       |

Table 11. Parallel Port Registers

| Register      |       | Register Bits |       |         |       |       |        |        |  |
|---------------|-------|---------------|-------|---------|-------|-------|--------|--------|--|
|               | Bit 7 | Bit 6         | Bit 5 | Bit 4   | Bit 3 | Bit 2 | Bit 1  | Bit 0  |  |
| Read Port     | PD7   | PD6           | PD5   | PD4     | PD3   | PD2   | PD1    | PD0    |  |
| Read Status   | BUSY  | ACK           | PE    | SLCT    | ERROR | 1     | 1      | 1      |  |
| Read Control  | 1     | 1             | 1     | IRQ ENB | SLIN  | INIT  | AUTOFD | STROBE |  |
| Write Port    | PD7   | PD6           | PD5   | PD4     | PD3   | PD2   | PD1    | PD0    |  |
| Write Control | 1     | 1             | 1     | IRQ ENB | SLIN  | INIT  | AUTOFD | STROBE |  |

AC Characteristics  $T_A = 0^{\circ} C \text{ to } +70^{\circ} C, V_{CC} = 5V \pm 5\% \text{ (Notes 1, 5)}$ Serial

| Symbol           | Parameter                       | Min | Max | Unit | Conditions          |
|------------------|---------------------------------|-----|-----|------|---------------------|
| <sup>1</sup> DIW | DISTR to Floating Data Delay    | 125 |     | ns   |                     |
| RC               | Read Cycle                      | 360 |     | ns   |                     |
| t <sub>DDD</sub> | Delay from DISTR to Data        |     | 125 | ns   | 100 pF Load         |
| t <sub>HZ</sub>  | .DISTR to Floating Data Delay   | 0   | 100 | ns   | 100 pF Load, Note 4 |
| t <sub>DOW</sub> | DOSTR Strobe Width              | 100 |     | ns   |                     |
| WC               | Write Cycle                     | 360 |     | ns   |                     |
| t <sub>DS</sub>  | Data Setup Time                 | 40  |     | ns   |                     |
| t <sub>DH</sub>  | Data Hold Time                  | 40  |     | ns   |                     |
| t <sub>RA</sub>  | Address Hold Time from DISTR    | 20  |     | ns   | Note 2              |
| t <sub>RCS</sub> | Chip Select Hold Time for DISTR | 20  |     | ns   | Note 2              |
| t <sub>AR</sub>  | DISTR Delay from Address        | 60  |     | ns   | Note 2              |



## **AC Characteristics (Continued)**

| Symbol            | Parameter                                                      |     | Max | Units         | Conditions     |
|-------------------|----------------------------------------------------------------|-----|-----|---------------|----------------|
| t <sub>CSR</sub>  | DISTR Delay from Chip Select                                   | 50  |     | ns            | Note 2         |
| t <sub>WA</sub>   | Address Hold Time from DOSTR                                   | 20  |     | ns            | Note 2         |
| twcs              | Chip Select Hold Time from DOSTR                               | 20  |     | ns            | Note 2         |
| t <sub>AW</sub>   | DOSTR Delay from Address                                       | 60  |     | ns            | Note 2         |
| t <sub>CSW</sub>  | DOSTR Delay from Select                                        | 50  |     | ns            | Note 2         |
| tRW               | Reset Pulse Width                                              | 5   |     | μs            |                |
| t <sub>XH</sub>   | Duration of Clock High Pulse                                   | 140 |     | ns            | External Clock |
| t <sub>XL</sub>   | Duration of Clock Low Pulse                                    | 140 |     | ns            | External Clock |
| Transmitte        | er                                                             |     |     |               |                |
| t <sub>HR 1</sub> | Delay from Rising Edge of DOSTR<br>(WR THR) To Reset Interrupt |     | 175 | ns            | 100 pF Load    |
| t <sub>IRS</sub>  | Delay from Initial INTR Reset to Transmit Start                | 8   | 24  | CLK<br>Cycles | Note 3         |
| <sup>t</sup> SI   | Delay from Initial Write to Interrupt                          | 16  | 32  | CLK<br>Cycles | Note 3         |
| <sup>t</sup> STI  | Delay from Stop to Interrupt (THRE)                            | 8   | 8   | CLK<br>Cycles | Note 3         |
| t <sub>IR</sub>   | Delay from DISTR (RD IIR)<br>to Reset Interrupt (THRE)         |     | 250 | ns            | 100 pF Load    |
| Modem Co          | ntrol                                                          |     |     |               | •              |
| t <sub>MDO</sub>  | Delay from DOSTR<br>(WR MCR) to Output                         |     | 200 | ns            | 100 pF Load    |
| t <sub>SIM</sub>  | Delay to Set Interrupt from MODEM Input                        |     | 200 | ns            | 100 pF Load    |
| t <sub>RIM</sub>  | Delay to Reset Interrupt from DISTR (RS MSR)                   |     | 250 | ns            | 100 pF Load    |
| Receiver          |                                                                |     |     |               |                |
| t <sub>SINT</sub> | Delay from Stop to Set Interrupt                               | 1   | 1   | CLK<br>Cycles | Note 3         |
| t <sub>RINT</sub> | Delay from DISTR<br>(RD RBR/RDLSR) to Reset Interrupt          |     | 1   | μs            | 100 pF Load    |

### **Parallel Port**

| WRITE           | RITE                        |      |      |      |  |  |  |  |
|-----------------|-----------------------------|------|------|------|--|--|--|--|
| Symbol          | Parameter                   | Min. | Max. | Unit |  |  |  |  |
| T <sub>ww</sub> | Write Pulse Width           | 200  | -    | ns   |  |  |  |  |
| T <sub>AW</sub> | Address to IOW Set-up Time  | 20 - | _    | ns   |  |  |  |  |
| T <sub>WA</sub> | Address Hold Time after 10W | 20   | -    | ns   |  |  |  |  |
| T <sub>DW</sub> | Data to IOW Set-up Time     | 70   |      | ns   |  |  |  |  |
| T <sub>WD</sub> | Data Hold Time after IOW    | 30   | _    | ns   |  |  |  |  |
| TwoL            | IOW = 1 to Data Latched     | -    | 90   | ns   |  |  |  |  |



### READ

| Symbol           | Parameter                       |     | Max. | Unit |
|------------------|---------------------------------|-----|------|------|
| T <sub>RR</sub>  | Read Pulse Width                | 300 | _    | ns   |
| TAR              | Address to IOR Set-up Time      | 20  | _    | ns   |
| T <sub>RA</sub>  | Address Hold Time after IOR     | 20  | _    | ns   |
| T <sub>PR</sub>  | Printer Bus to IOR Set-up Time  | 0   |      | ns   |
| T <sub>RP</sub>  | Printer Bus Hold Time after IOR | 0   | _    | ns   |
| T <sub>RDS</sub> | IOR to D0 - D7 Output           | _   | 70   | ns   |
| TRDR             | D0 – D7 Released after TOR      | -   | 30   | ns   |

<sup>\*</sup>Note: When the CPU reads the printer's status, output data may change if the printer signals are unstable

### **OTHERS**

| Symbol              | Parameter                                                        |   | Max. | Unit |
|---------------------|------------------------------------------------------------------|---|------|------|
| T <sub>RSW</sub>    | Reset Pulse Width                                                |   | _    | ns   |
| T <sub>RSCH</sub>   | Reset to Control Bus = 1 (STROB, AUTOFD, SLCT) Propagation Delay |   | 90   | ns   |
| T <sub>RSIN 1</sub> | Reset to Control Bus INIT = 0 Propagation Delay                  |   | 60   | ns   |
| T <sub>ID</sub>     | ACK to IRQ Propagation Delay                                     | _ | 45   | ns   |

Notes: 1. All timing specifications apply to pins to both serial channels (e.g. Ri refers to both R10 and R11).

- 2. The internal address strobe is always active.
- 3. RCLK =  $t_{XH}$  and  $t_{XL}$ .
- 4. Charge and discharge time is determined by VOL, VOH and the external loading.
- 5. All timings are referenced to valid 0 and valid 1 (see AC TEST POINTS).

## Serial Port Timing:

## Write Cycle Timing





## Read Cycle Timing



## **Receiver Timing**



### **Transmitter Timing**





### **Modem Timing**



## **Parallel Port Timing:**

## A.C. Testing Input Waveform



# Write Cycle Waveform





## Interrupt Request Waveform



## Read Cycle Waveform



### Reset Waveform





## **Absolute Maximum Ratings \***

| $\begin{array}{llllllllllllllllllllllllllllllllllll$ |
|------------------------------------------------------|
| Supply Voltage to Ground                             |
| Potential $-0.5$ V to $V_{CC}$ + $0.3$ V             |
| Applied Output Voltage                               |
| $-0.5$ V to V <sub>CC</sub> + 0.3V                   |
| Applied Input Voltage                                |
|                                                      |
| Power Dissipation 500 mW                             |

### \*Comments

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.

# **DC Electrical Characteristics** $(T_A = 0 \text{ to } +70^{\circ}\text{C}, V_{CC} = 5\text{V} \pm 5\%)$

| Symbol                | Parameter                     | Min  | Max | Units | Conditions                                                                                                                                                     |
|-----------------------|-------------------------------|------|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>ILX</sub>      | Clock Input Low Voltage       | -0.5 | 0.8 | V     |                                                                                                                                                                |
| V <sub>IHX</sub>      | Clock Input High Voltage      | 2.0  | Vcc | ٧     |                                                                                                                                                                |
| V <sub>IL</sub>       | Input Low Voltage             | -0.5 | 0.8 | V     |                                                                                                                                                                |
| V <sub>IH</sub>       | Input High Voltage            | 2.0  | Vcc | V     |                                                                                                                                                                |
| V <sub>OL</sub>       | Output Low Voltage            |      | 0.4 | V     | I <sub>OL</sub> = 4.0 mA on DB0-DB7, 12 mA on PD0-PD7, 2 mA on all other outputs                                                                               |
| V <sub>OH</sub>       | Output High Voltage           | 2.4  |     | V     | I <sub>OH</sub> =-0.4 mA on DB0-DB7, -0.2 mA on PD0-PD7, -0.2 mA on all other outputs                                                                          |
| <sup>1</sup> cc       | Power Supply Current          |      | 40  | mA    | V <sub>CC</sub> = 5.25V, No loads on SIN0, 1;-DSR0, 1;-RLSD0, 1;-CTS0, 1. RI0, RI1 = 0 2.0V. Other inputs = 0.8V. Baud rate generator = 4 MHz, Baud rate = 56K |
| l <sub>IL</sub>       | Input Leakage                 |      | 10  | μΑ    | $V_{CC} = 5.25V$ , GND = 0V.<br>All other pins floating.                                                                                                       |
| CL                    | Clock Leakage                 |      | 10  | μΑ    | V <sub>IN</sub> = 0V, 5.25V                                                                                                                                    |
| loz                   | 3-State Leakage               |      | 20  | μΑ    | V <sub>CC</sub> = 5,25V, GND = 0V.<br>VOUT = 0V, 5,25V<br>1) Chip deselected<br>2) Chip and write mode selected                                                |
| VIL (RES)             | Reset Schmitt V <sub>IL</sub> |      | 0.8 | V     |                                                                                                                                                                |
| V <sub>IH</sub> (RES) | Reset Schmitt V <sub>IH</sub> | 2.0  |     | V     |                                                                                                                                                                |



### **Application Circuit**





## **Application Circuit (Continued)**

