W86C452



## I/O CONTROL CHIP FOR IBM PC/AT

### GENERAL DESCRIPTION

The W86C452 is an enhanced dual-channel version of the popular W86C450 asynchronous communication element (ACE) fabricated using WINBOND'S CMOS process. It is equivalent to VL16C452 of the VLSI Technology Inc.

The device surports two serial-to-parallel conversion on data characters received from a peripheral device or a MODEM, and parallel-to-serial conversion on data characters received from the CPU.

The CPU can read the complete status of the UART at any time during the functional operation. Status information reported includes the type and condition of the transfer operations being performed by the UART as well as any error conditions (parity, overrun, framing, or break interrupt).

The UART includes a programmable baud rate generator that is capable of dividing the timing reference clock input by divisors of 1 to  $(2^{16} - 1)$ , and producing a 16 x clock for driving the internal transmitter logic. Provisions are also included to use this 16 x clock to drive the receiver logic. The UART includes a complete MODEM-control capability and a processorinterrupt system. Interrupts can be programmed to the user's requirements, minimizing the computing required to handle the communications link.

In addition to its communication interface capabilities, the W86C452 provides the user with a fully bidirectional parallel Centronics type printer. This port allows information received from either serial communication port to be printed from the dual ACE.

#### FEATURES

- Easily interfaces to most popular microprocessors.
- Dual-channel version of W86C450
- Centronix printer interface
- Independently controlled transmit, receive, line status, and data set interrupts.
- Programmable baud generator allows division of any input clock by 1 to (2<sup>16</sup> – 1) and generates the internal 16 x clock.
- Independent receiver clock input.
- MODEM control functions (CTS, RTS, DSR, DTR, RI, and DCD).
- Fully programmable serial-interface characteristics:

- -5, 6, 7, or 8-bit characters
- -Even, odd, or no-parity bit generation and detection
- -1, 1.5 or 2-stop bit generation
- False start bit detection.
- TRI-STATE TTL drive capabilities for bidirectional data bus and control bus on each channel
- Internal diagnostic capabilities:
- -Loopback controls for communications link fault isolation
- -Break, parity, overrun, framing error simulation.
- Fully prioritized interrupt system controls.



#### **PIN CONFIGURATION**



#### **PIN DESCRIPTIONS**

| SINGAL<br>NAME  | PIN<br>NO.    | TYPE | SIGNAL<br>DESCRIPTION                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|---------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ĪOR             | 37            | ļ    | Input/Output Read Strobe: This is an active low input which<br>causes the selected channel to output data to the data bus<br>(DB0-DB7). The data output depends upon the register selected<br>by the address inputs A0, A1, A2. Chip select 0 (ACE1) selects<br>UART #1, chip select 1 (ACE2) selects UART #2, and chip select<br>2 (PRT1) selects the line printer part. |
| ĪŌŴ             | 36            | t    | Input/Output Write Strobe: This is an active low input which<br>causes data from the data bus (DS0-DB7) to be input to either<br>UART or to the parallel port. The data input depends upon the<br>register selected by the address inputs A0, A1, A2. The chip<br>select inputs (ACE1, ACE2, and PRT1) enable UART #1,UART#2,<br>and the parllel port (respectively).     |
| DB0<br>/<br>DB7 | 14<br>/<br>21 | 1/0  | Data Bits DB0-DB7: The Data Bus provides eight, three-state I/O<br>lines for the transfer of data, control and status information bet-<br>ween the W86C452 and the CPU. These lines are normally in<br>a high-impedance state except during read operations. D0<br>is the least significant bit (LSB) and is the first serial data bit to<br>be received or transmitted.  |



| SINGAL<br>NAME    | PIN<br>NO.     | TYPE | SIGNAL<br>DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------|----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0<br>A1<br>A2    | 35<br>34<br>33 | ł    | Address Lines A0-A2: The address lines select the internal registers<br>during CPU bus operations. See Table 1 for the decode of the<br>serial channels. Table 5 for the decde of the parallel line printer<br>port.                                                                                                                                                                                                                                                                                                                    |
| CLK               | 4              | 1    | Clock Input: The external clock input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| SOUT1<br>SOUT2    | 26<br>10       | 0    | Serial Data Outputs: These lines are the serial data outputs from<br>the UARTs' transmitter circuitry. A mark (1) is a logic "one" (high)<br>and space (0) is a logic "zero" (low). Each SOUT is held in the<br>mark condition when the transmitter is disabled, Reset is true,<br>the Transmitter Register is empty, or when in the Loop Mode.                                                                                                                                                                                         |
| CTS1<br>CTS2      | 28<br>13       | 1    | Clear to Send Inputs: The logical state of each CTS pin is<br>reflected in the CTS bit of the (MSR) Modem Status Register [CTS<br>is bit 4 of the MSR, written MSR (4)] of each UART. A change of<br>state in either CTS pin since the previous reading of the<br>associated MSR causes the setting of DCTS [MSR(0)] of each<br>Modem Status Register. When a CTS pin is active (low), the<br>modem is indicating that data on the associated SOUT can be<br>transmitted.                                                               |
| DSR1<br>DSR2      | 31<br>5        | 7    | Data Set Ready Inputs: The logical state of the DSR pins is<br>reflected in MSR(5) of its associated MODEM Status Register. DDSR<br>[MSR(1)] indicates whether the associated DSR pin has chang-<br>ed state since the previous reading of the MSR. When a DSR pin<br>is low, its modem is indicating that it is ready to exchange data<br>with the associated UART.                                                                                                                                                                    |
| DTR1<br>DTR2      | 25<br>11       | 0    | Data Terminal Ready Lines: Each DTR pin can be set (low) by<br>writing a logic 1 to MCR(0), Modem Control Register bit 0 of its<br>associated UART. This signal is cleared (high) by writing a logic<br>0 to the DTR bit (MCR(0)) or whenever a reset occurs. When ac-<br>tive (low), the DTR pin indicates to the DCE that its UART is ready<br>to receiver data.                                                                                                                                                                      |
| RTS1<br>RTS2      | 24<br>12       | 0    | Request to Send Outputs: The $\overline{\text{RTS}}$ signal is an output on each UART used to enable the modem. An $\overline{\text{RTS}}$ pin is set low by writing a logic 1 to MCR(1) bit 1 of its UART's Modem Control Register. Both $\overline{\text{RTS}}$ pins are reset high by Reset. When active, an RTS pin indicates to the DCE that its UART has data ready to transmit. In half duplex operations, $\overline{\text{RTS}}$ is used to control the direction of the line.                                                 |
| <u>R11</u><br>R12 | 30<br>6        | 1    | Ring Indicator Inputs: When low, $\overline{RI}$ indicates that a telephone<br>ringing signal has been received by the modem or data set. The<br>$\overline{RI}$ signal is a modem control input whose condition is tested<br>by reading MSR(6) (RI) of each UART. The Modem Status Register<br>output TERI [MSR(2)] indicates whether the RI input has changed<br>from high to low since the previous reading of the MSR. If the in-<br>terrupt is enabled [IER(3)=1] and RI changes from a high to low,<br>an interrupt is generated. |



| SINGAL<br>NAME       | PIN<br>NO.                                | TYPE | SIGNAL<br>DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------|-------------------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PRTOE                | 1                                         | 1    | Line Printer Output Enable: This input signal enables the parallel<br>line printer when it is low. When this signal is high, the pins of<br>the line printer are held in a high-impedence state. This line may<br>be tied to ground for normal line printer operation.                                                                                                                                                                                                                                                           |
| V <sub>DD</sub>      | 23<br>40<br>64                            | 1    | Power Supply: 5V ±5%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Vss                  | 2,7<br>9,22<br>27<br>42<br>43<br>54<br>61 | l    | Ground (0V): All pins must be tied to ground for proper operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| DCD1<br>DCD2         | 29<br>8                                   | I    | Data Carry Detect: When active (low), DCD indicates that<br>the data carrier has been detected by the modem or data<br>set. DCD is a modem input whose condition can be tested by<br>the CPU by reading MSR(7) (DCD) of the Modem Status Registers.<br>MSR(3) (DDCD) of the Modem Status Register indicates whether<br>the DCD input has changed since the previous reading of the<br>MSR. DCD has no effect on the receiver. If the DCD changes state<br>with the modem status interrupt enabled, an interrupt is<br>generated. |
| RESET                | 39                                        | l    | Reset: When low, the reset input forces the W86C452 into an idle<br>mode in which all serial data activities are suspended. The<br>Modem Control Register (MCR) along with its associated outputs<br>are cleared. The Line Status Register (LSR) is cleared except for<br>the THRE and TEMT bits, which are set. All functions of the device<br>remain in an idle state until programmed to resume serial data<br>activities.                                                                                                    |
| INTO<br>INT1         | 45<br>60                                  | 0    | Serial Channel Interrupts: Each serial channel interrupt goes ac-<br>tive (high) when one of the following interrupts has an active<br>(high) condition and is enabled by the Interrupt Enable Register<br>of its associated channel: Receiver Error flag. Received Data<br>Available, Transmitter Holding Register Empty, and Modem<br>Status. The interrupt is reset low upon appropriate service or a<br>reset operation.                                                                                                     |
| SIN1<br>SIN2         | 41<br>62                                  | 1    | Serial Data Inputs: The serial data inputs move information from<br>the communication line or moderm to the W85C452 receiver cir-<br>cuits. A mark (1) is high, and a space (0) is low. Data on serial<br>data inputs is disabled when operating in the loop mode.                                                                                                                                                                                                                                                               |
| ACE1<br>ACE2<br>PRT1 | 32<br>3<br>38                             | 1    | Chip Selects: Each Chip Select input acts as an enable for the write and read signals for the serial channels (ACE1) and 2 (ACE2). PRT1 enables the the signals to the line printer port.                                                                                                                                                                                                                                                                                                                                        |



.

| SINGAL<br>NAME  | PIN<br>NO.    | TYPE | SIGNAL<br>DESCRIPTION                                                                                                                                                                                                                |
|-----------------|---------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BDO             | 44            | ο    | Bus Buffer Output: This active high output is asserted when either<br>serial channel or the parallel port is selected as an output. This<br>output can be used to control the system bus driver device<br>(74LS245).                 |
| PD0<br>/<br>PD7 | 53<br>1<br>46 | 1/0  | Parallel Data Bits (0-7): These eight lines provide a byte-wide in-<br>put or output port to the system. The eight lines are held in a<br>high-impedance state when the port is not selected (PRT1<br>is high).                      |
| STB             | 55            | 1/0  | Line Printer Strobe: This I/O line provides communication bet-<br>ween the W86C452 and the line printer. When it is active low,<br>it provides the line printer with a signal to latch the data cur-<br>rently on the parallel port. |
| ĀFD             | 56            | 1/0  | Line Printer Autofeed: This I/O line provides the line printer with<br>an active low signal when continuous form paper is to be autof-<br>ed to the printer.                                                                         |
| INIT            | 57            | 1/0  | Line Printer Autofeed: This I/O line provides the line printer with<br>an active low signal when continuous form paper is to be autof-<br>ed to the printer.                                                                         |
| SLIN            | 58            | 1/0  | Line Printer Select: This I/O line selects the printer when it is ac-<br>tive low.                                                                                                                                                   |
| INT2            | 59            | 0    | Interrupt Printer Port: This signal is an input line from the line printer<br>that goes active high when an error signal is received. The in-<br>terrupt is reset low upon a reset operation.                                        |
| ERR             | 63            | 1    | Line Printer Error: This is an input line from the line printer. The<br>line printer reports and error by holding this line low during the<br>error condition. This causes INT2 to be asserted high.                                 |
| SLCT            | 65            | I    | Line Printer Select: This is an input line from the line printer that goes high when the line printer has been selected.                                                                                                             |
| BUSY            | 66            | I    | Line Printer Busy: This is an input line from the line printer that goes high when the line printer has a local operation in progress.                                                                                               |
| PE              | 67            | 1    | Line Printer Paper Empty: This is an input line from the line printer<br>that goes high when the printer runs out of paper, and causes<br>INT2 to be asserted high.                                                                  |
| ACK             | 68            | I    | Line Printer Acknowledge: This input goes low to indicate a successful data transfer has taken place.                                                                                                                                |



## **BLOCK DIAGRAM**

A. UART/PARALLEL





#### **BLOCK DIAGRM (CONTINUE)**

B. UART

.





## BLOCK DIAGRAM (CONTINUE)

C. PARALLEL PORT





## FUNCTIONAL DESCRIPTION

### UART

The system programmer may access any of the UART registers summarized in Table 2 via the CPU. These registers control UART operations including tansmission and reception of data. Each register bit in Table 1 has it's name and reset state shown.

|            |                                                  |                                                       |                                             |                                                   | REGIST                                      | ER ADDRES                          | 5                                            |                                              |                          |                          |                          |
|------------|--------------------------------------------------|-------------------------------------------------------|---------------------------------------------|---------------------------------------------------|---------------------------------------------|------------------------------------|----------------------------------------------|----------------------------------------------|--------------------------|--------------------------|--------------------------|
|            | 0 DLAB = 0                                       | O DLAB=0                                              | 1 DLAB=0                                    | 2                                                 | 3                                           | 4                                  | 5                                            | 6                                            | 7                        | 0 DLAB=1                 | 1 DLAB = 1               |
| BIT<br>NO. | RECEIVER<br>BUFFER<br>REGISTER<br>(READ<br>ONLY) | TRANSMITTER<br>HOLDING<br>REGISTER<br>(WRITE<br>ONLY) | INTERRUPT<br>ENABLE<br>REGISTER             | INTERRUPT<br>IDENT.<br>REGISTER<br>(READ<br>ONLY) | LINE<br>CONTROL<br>REGISTER                 | MODEM<br>CONTROL<br>REGISTER       | LINE<br>STATUS<br>REGISTER                   | MODEM<br>STATUS<br>REGISTER                  | SCRATCH<br>REG-<br>ISTER | DIVISOR<br>LATCH<br>(LS) | DIVISON<br>LATCH<br>(MS) |
|            | RBR                                              | THR                                                   | IER                                         | IIR                                               | LCR                                         | MCR                                | LSR                                          | MSR                                          | SCR                      | DLL                      | DLM                      |
| 0          | Data Bit 0<br>(Note 1)                           | Data Bit O                                            | Received<br>Data<br>Available               | "0" if<br>Interrupt<br>Pending                    | Word<br>Length<br>Select<br>Bit 0<br>(WLS0) | Data<br>Terminal<br>Ready<br>(DTR) | Data<br>Ready<br>(DR)                        | Delta 0<br>Clear<br>to Send<br>(DCTS)        | Bit O                    | Bit O                    | Bit 8                    |
| 1          | Data Bit 1                                       | Data Bit 1                                            | Transmitter<br>Holding<br>Register<br>Empty | Interrupt<br>ID<br>Bit (0)                        | Word<br>Length<br>Select<br>Bit 1<br>(WLS1) | Request<br>to Send<br>(RTS)        | Overrun<br>Error<br>(OE)                     | Delta<br>Data<br>Set<br>Ready<br>(DDSR)      | Bit 1                    | Bit 1                    | Bit 9                    |
| 2          | Daba Bit 2                                       | Data Bit 2                                            | Receiver<br>Line Status                     | Interrupt<br>ID<br>Bit (1)                        | Number of<br>Stop Bits<br>(STB)             | Out 1                              | Parity<br>Error<br>(PE)                      | Trailing<br>Edge Ring<br>Indicator<br>(TERI) | Bit 2                    | Bit 2                    | Bit 10                   |
| 3          | Data Bot 3                                       | Data Bit 3                                            | MODEM<br>Status                             | 0                                                 | Parity<br>Enable<br>(PEN)                   | Intea                              | Framing<br>Error<br>(FE)                     | Delta<br>Data<br>Carrier<br>Detect<br>(DDCD) | Bit 3                    | Bit 3                    | Bit 11                   |
| 4          | Data Bit 4                                       | Data Bit 4                                            | 0                                           | O                                                 | Even<br>Parity<br>Select<br>(EPS)           | Loop                               | Break<br>Interrupt<br>(BI)                   | Clear<br>to<br>Send<br>(CTS)                 | Bit 4                    | Bit 4                    | Bit 12                   |
| 5          | Data Bit 5                                       | Data Bit 5                                            | 0                                           | 0                                                 | Stick<br>Parity                             | D                                  | Transmitter<br>Holding<br>Register<br>(THRE) | Data<br>Set<br>Ready<br>(DSR)                | Bit 5                    | Bit 5                    | Bit 13                   |
| 6          | Data Bit 6                                       | Data Bit 6                                            | O                                           | 0                                                 | Set<br>Break                                | 0                                  | Transmitter<br>Empty<br>(TEMT)               | Ring<br>Indicator<br>(RI)                    | Bit 6                    | Bit 6                    | Bit 14                   |
| 7          | Data Bit 7                                       | Data Bit 7                                            | 0                                           | 0                                                 | Divisor<br>Latch<br>Access<br>Bit<br>(DLAB) | 0                                  | 0                                            | Data<br>Carrier<br>Detect<br>(DCD)           | Bit 7                    | Bit 7                    | Bit 15                   |

#### Table 1. Summary of Registers

# 

#### a. Line Control Register

The system programmer specifies the format of the asynchronous data communications exchange and sets the Divisor Latch Access bit via the Line Control Register (LCR). The programmer can also read the contents of the Line Control Register. The read capability simplifies system programming and eliminates the need for separate storage in system memory of the line memory of the line characteristics. Table 2 shows the contents of the LCR. Details on each bit follow:

**Bits 0 and 1**: These two bits specify the number of bits in each transmitted or received serial character. The encoding of bits 0 and 1 is as follows:

| BIT 1 | BIT O | CHARACTER LENGTH |  |
|-------|-------|------------------|--|
| 0     | 0     | 5 Bits           |  |
| 0     | 1     | 6 Bits           |  |
| 1     | 0     | 7 Bits           |  |
| 1     | 1     | 8 Bits           |  |

Bit 2: This bit specifies the number of Stop bits transmitted and received in each serial character. If bit 2 is a logic 0, one Stop bit is generated or checked in the transmitted data. If bit 2 is a logic 1 when a 5-bit word length is selected via bits 0 and 1, one and a half Stop bits are generated. If bit 2 is a logic 1 when either a 6-, 7- or 8-bit word length is selected, two Stop bits are generated. The Receiver checks the first Stop-bit only, regardless of the number of Stop bits selected.

Bit 3: This bit is the Parity Enable bit. When bit 3 is a logic 1, a Parity bit is generated (transmit data) or checked (receive data) between the last data word bit and Stop bit of the serial data. (The Parity bit is used to produce an even or odd number of 1s when the data word bits and the Parity bit are summed.) Bit 4: This bit is the Even Parity Select bit. When bit 3 is a logic 1 and bit 4 is a logic 0, an odd number of logic 1s is transmitted or checked in the data word bits and Parity bit. When bit 3 is a logic 1 and bit 4 is a logic 1, an even number of logic 1s is transmitted or checked. Bit 5: This bit is the Stick Parity bit. When bits 3,4 and 5 are logic 1 the Parity bit is transmitted and checked as a logic 0. If bits 3 and 5 are 1 and bit 4 is a logic 0 then the Parity bit is transmitted and checked as a logic 1. If bit 5 is a logic 0 Stick Parity is disabled. Bit 6: This bit is the Break Control bit. It causes a break condition to be transmitted by the UART. When it is set to a logic 1, the serial output (SOUT) is forced to the Spacing (logic 0) state. The break is disabled by clearing bit 6 to a logic 0. The Break Control bit acts only on SOUT and has no effect on the transmitter logic.

# 

## W86C452

- Note: This feature enables the CPU to alert a terminal in a computer communications system. If the following squence is used, no erroneous or extraneous characters will be transmitted because of the break.
- 1. Load an all 0s, pad character, in response the TERE.
- 2. Set break after the next TERE.
- Wait for the transmitter to be idle, (TEMT = 1), and clear break when normal transmisson has to be restored.

During the break, the Transmitter can be used as a character timer to accurately establish the break duration.

**Bit 7:** This bit is the Divisor Latch Access Bit (DLAB). It must be set high (logic 1) to access the Divisor Latches of the Baud Generator during a Read or Write operation.

It must be set low (logic 0) to access the Receiver Buffer, the Transmitter Holding Register, or the interrupt Enable Register.

#### b. Programmable Baud Generator

The UART contains a programmable Baud Generator that is capable of taking any clock input from DC to 3.1 MHz and dividing it by any divisor from 1 to  $2^{76} - 1$ . The output frequency of the Baud Generator is is 16 x the Baud (divisor # = (frequency input) (baud rate x 16)]. Two 8-bit latches store the divisor in a 16-bit binary format. These Divisor Latches must be loaded during initialization in order to ensure proper operation of the Baud Generator. Upon loading either of the Divisor Latches, a 16-bit Baud counter is immediately loaded.

Table 3 provide decimal divisors to use with crystal frequencies of 1.8432 MHz and 3.072

MHz respectively for common baud rates. For baud rates of 38400 and below, the error obtained is minimal. The accuracy of the of the desired baud rate is dependent on the crystal frequency chosen. Using a division of 0 is not recommended.

#### Note:

The maximum operating frequency of the Baud Generator is 3.1 MHz. However, when using divisors of 3 and below, the maximum frequency is equal to the divisor in MHz. For example, if the divisor is 1, then the maximum frequency is 1 MHz. In no case should the data rate be greater than 56K Baud.



| DESIRED BAUD RATE | to ge   | IVISOR USED<br>NERATE<br>CLOCK | PERCENT ERROR<br>DIFFERENCE BETWEEN<br>DESIRED AND ACTUAL |        |  |
|-------------------|---------|--------------------------------|-----------------------------------------------------------|--------|--|
|                   | 1.8432M | 3.072M                         | 1.8432M                                                   | 3.072M |  |
| 50                | 2304    | 3840                           | -                                                         | _      |  |
| 75                | 1536    | 2560                           |                                                           |        |  |
| 110               | 1047    | 1745                           | 0.026                                                     | 0.026  |  |
| 134.5             | 857     | 1428                           | 0.058                                                     | 0.034  |  |
| 150               | 768     | 1280                           | _                                                         | -      |  |
| 300               | 384     | 640                            | —                                                         | _      |  |
| 600               | 192     | 320                            | _                                                         | —      |  |
| 1200              | 96      | 160                            | -                                                         | -      |  |
| 1800              | 64      | 107                            |                                                           | 0.312  |  |
| 2000              | 58      | 96                             | 0.69                                                      | -      |  |
| 2400              | 48      | 80                             |                                                           | -      |  |
| 3600              | 32      | 53                             | -                                                         | 0.628  |  |
| 4800              | 24      | 40                             | -                                                         | —      |  |
| 7200              | 16      | 27                             | -                                                         | 1.23   |  |
| 9600              | 12      | 20                             | -                                                         |        |  |
| 19200             | 6       | 10                             | —                                                         | —      |  |
| 38400             | 3       | 5                              | _                                                         | _      |  |
| 56000             | 2       | -                              | 2.86                                                      | —      |  |

#### Table 3. Baud Rates Using 1.8432 MHz Crystal and 3.072 MHz Crystal

#### c. Line Status Register

This 8-bit register provides status information to the CPU concerning the date transfer. Table 2 shows the contents of the Line Status Register. Details on each bit follow:

Bit 0: This bit is the reciver Data Ready (DR) indicator. Bit 0 is set to a logic 1 whenever a complete incoming character has been received and transferred into the Receiver Buffer Register. Bit 0 is reset to a logic 0 by reading the data in the Receiver Buffer Register.

Bit 1: This bit is the Overrun Error (OE) indicator. Bit 1 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, thereby destroying the previous character. The OE indicator is set to a logic 1 upon detection of an overrun condition and reset whenever the CPU reads the contents of the Line Status Register. Bit 2: This bit is the Parity Error (PE) indicator. Bit 2 indicates that the received data character does not have the correct even or odd parity, as selected by the even-parityselect bit. The PE Bit is set to a logic 1 upon detection of a parity error and is reset to a logic 0 whenever the CPU reads the contents of the Line Status Register.

# Winbond

Bit 3: This bit is the Framing Error (FE) indicator. Bit 3 indicates that the received character did not have a valid Stop bit. Bit 3 is set to a logic 1 whenever the Stop bit following the last data bit or parity bit is a logic 0 (Spacing level). The FE indicator is reset whenever the CPU reads the contens of the Line Status Register. The UART will try to resynchronize after a framing error. To do this it assumes that the framing error was due to the next start bit, so it samples this "STtart" bit twice and then takes in the "data".

Bit 4: This bit is the Break Interrupt (BI) indicator. Bit 4 is set to a logic 1 whenever the received data input is held in the Spacing (logic 0) state for longer than a full word transmission time (that is, the total time of Start bit + data bits + Parity + Stop bits). The BI indicator is reset whenever the CPU reads the contents of the Line Status Register. Restarting after a break is received, requires the SIN pin to be logical 1 for at least 1/s bit time.

Note: Bits 1 through 4 are the error conditions that produce a Receiver Line Status interrupt whenever any of the corresponding conditions are detected and the interrupt is enabled.

Bit 5: This bit is the Transmitter Holding Register Empty (TERE) indicator. Bit 5 indicates that the UART is ready to accept a new character for transmission. In addition, this bit causes the UART to issue an interrupt to the CPU when the Transmit Holding Register Empty Interrupt enable is set high. The TERE bit is set to a logic 1 when a character is transferred from the Transmitter Holding Register into the Transmitter Shift Register. The bit is reset to logic 0 whenever the CPU loads the Transmitter Holding Register.

Bit 6: This bit is the Transmitter Empty (TEMT) indicator. Bit 6 is set to a logic 1 whenever the Transmitter Holding Register (THR) and the Transmitter Shift Register (TSR) are both empty. It is reset to a logic 0 whenever either the THR or TSR contains a data character.

Bit 7: This bit is permanently set to logic 0.

- Note: The Line Status Register is intended for read operations only. Writing to this register is not recommended as this operation is not recommended as this operation is only used for factory testing.
- d. Interrupt Indentification Register (IIR)

In order to provide minimum software overhead during data character transfers, the UART prioritizes interrupts into four levels and records these in the Interrupt Identification Register. The four levels of interrupt conditions in order of priority are Receiver Line Status; Received Data Ready; Transmitter Holding Register Empty; and MODEM Status. When the CPU accesses the IIR, the UART freezes all interrupts and indicates the highest priority pending interrupt to the CPU. While this CPU access is occurring, the UART records new interrupts, but does not change its current indication until the access is complete. Table 2 shows the contents of the IIR. Details on each bit follow:



Bit 0: This bit can be used in an interrupt environment to indicate whether an interrupt condition is pending. When bit 0 is a logic 0, an interrupt is pending and the IIR contents may be used as a pointer to the appropriate interrupt service routine. When bit 0 is a logic 1, no interrupt is pending.

**Bit 1 and 2:** These two bits of the IIR are used to identify the highest priority interrupt pending as indicated in Table 4.

Bits 3 through 7: These five bits of the IIR are always logic 0.

|          | IIR      |          |                   | INTERRUPT SET AND RESET FUNCTIONS           |                                                                                      |                                                                                                                   |  |  |  |
|----------|----------|----------|-------------------|---------------------------------------------|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--|--|--|
| BIT<br>2 | BIT<br>1 | BIT<br>O | PRIORITY<br>LEVEL | INTERRUPT<br>TYPE                           | INTERRUPT<br>SOURCE                                                                  | INTERRUPT RESET<br>CONTROL                                                                                        |  |  |  |
| 0        | 0        | 1        |                   | None                                        | None                                                                                 | _                                                                                                                 |  |  |  |
| 1        | 1        | 0        | Highest           | Receiver<br>Line<br>Status                  | Overrun Error or<br>Parity Error or<br>Framing Error or<br>Break Interrupt           | Reading the Line<br>Status Register                                                                               |  |  |  |
| 1        | 0        | 0        | Second            | Receiver<br>Data<br>Available               | Receiver Data<br>Available                                                           | Reading the<br>Receiver Butter<br>Register                                                                        |  |  |  |
| 0        | 1        | 0        | Third             | Transmitter<br>Holding<br>Register<br>Empty | Transmitter<br>Holding<br>Register<br>Empty                                          | Reading the IIR<br>Register (if source<br>of interrupt) or<br>Writing into the<br>Transmitter<br>Holding Register |  |  |  |
| 0        | 0        | 0        | Fourth            | MODEM<br>Status                             | Clear to Send or<br>Data Set Ready or<br>Ring Indicator or<br>Data Carrier<br>Detect | Reading the<br>MODEM<br>Status<br>Register                                                                        |  |  |  |

Table 4 Interrupt Control Functions

#### e. Interrupt Enable Register

This register enables the four types of UART interrupts. Each interrupt can individually activate the interrupt (INTR) output signal. It is possible to totally disable the interrupt system by resetting bits 0 through 3 of the Interrupt Enable Register (IER). Similarly, setting bits of this register to a logic 1, enables the selected interrupt (s). Disabling an interrupt prevents it from being indicated as active in the IIR and from activating the INTR output signal. All other system functions operate in their normal manner, including the setting of the Line Status and MODEM Status Registers. Table 2 shows the contents of the IER. Details on each bit follow.

## 

Bit 0: This bit enables the Received Data Available Interrupt when set to logic 1.

Bit 1: This bit enables the Transmitter Holding Register Empty Interrupt when set to logic 1. Bit 2: This bit enables the receiver Line Status Interrupt when set to logic 1.

Bit 3: This bit enables the MODEM Status Interrupt when set to logic 1.

**Bit 4 through 7:** These four bits are always logic 0.

#### f. Modem Control Register

This register controls the interface with the MODEM or data set (or a peripheral device emulating a MODEM). The contents of the MODEM Control Register (MCR) are indicated in Table 2 and are described below. Table 2 shows the contents of the MCR. Details on each bit follow.

Bit 0: This bit controls the Data Terminal Ready  $(\overline{\text{DTR}})$  output. When bit 0 is set to a logic 1, the DTR output is forced to a logic 0. When bit 0 is reset to a logic 0, the DTR output is forced to a logic 1.

Note: The DTR output of the UART may be applied to an EIA inverting line driver (such as the DS1488) to obtain the proper polarity input at the succeeding MODEM or data set.

Bit 1: This bit controls the Request to Send ( $\overline{RTS}$ ) output bit 1 affects the RTS output in a manner identical to that described above for bit 0.

Bit 2: This bit is not connected

Bit 3: This bit is set high, the INT output is enabled.

**Bit 4:** This bit provides a local loopback feature for diagnostic testing of the UART. When bit 4 is set to logic 1, the following oc-

cur. the transmitter Serial Output (SOUT) is set to the Marking (logic 1) state; the receiver Serial Input (SIN) is disconnected; the output of the Transmitter Shift Register is "looped back" into the Receiver Shift Register input; the four MODEM Control inputs (CTS, DSR, RI, and DCD) are disconnected; and the four MODEM Control outputs (DTR, RTS, OUT 1, and OUT 2) 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 that is transmitted is immediately received. This feature allows the processor to verify the transmit-and-received-data paths of the UART.

In the diagnostic mode, the receiver and transmitter interrupts are fully operational. The MODEM Control Register instead of the four MODEM Control inputs. The interrupts are still controlled by the Interrupt Enable Register.

**Bit 5 through 7:** These bits are permanently set to logic 0.



#### g. MODEM Status Register

This register provides the current state of the control lines from the MODEM (or peripheral device) to the CPU. In addition to this current-state information, four bits of the MODEM Status Register provide change information. These bits are set to a logic 1 whenever a control input from the MODEM changes state. They are reset to logic 0 whenever the CPU reads the MODEM Status Register.

Table 2 shows the contents of the MSR. Details on each bit follow.

Bit 0: This bit is the Delta Clear to Send (DCTS) indicator. Bit 0 indicates that the CTS input

Note: Whenever bit 0, 1, 2, or 3 is set to logic 1, a MODEM Status Interrupt os generated.

to the chip has changed state since the last time it was read by the CPU.

Bit 1: This bit is the Delta Data Set Ready (DDSR) indicator. Bit 1 indicates that the  $\overline{\text{DSR}}$  input to the chip has changed state since the last time it was read by the CPU.

Bit 2: This bit is the Trailing Edge of Ring Indicator (TERI) detector. Bit 2 indicates that the RI input to the chip has changed from a low to a high state.

Bit 3: This bit is the Delta Data Carrier Detect (DDCD) indicator. Bit 3 indicates that the  $\overline{DCD}$  input to the chip has changed state.

Bit 4: This bit is the complement of the Clear to Send ( $\overline{CTS}$ ) input. If bit 4 (loop) of the MCR is set to a 1, this bit is equivalent to RTS in the MCR.

Bit 5: This bit is the complement of the Data Set Ready (DSR) input. If bit 4 of the MCR is set to a 1, this bit is equivalent to DTR in the MCR. **Bit 6:** This bit is the complement of the Ring Indicator ( $\overline{RI}$ ) input. If bit 4 of the MCR is set to a 1, this bit is equivalent to OUT 1 in the MCR.

**Bit 7:** This bit is the complement of the Data Carrier Detect ( $\overline{DCD}$ ) input. If bit 4 of the MCR is set to a 1, this bit is equivalent to INTEA 2 in the MCR.

#### h. Scratchpad Register

This 8-bit Read/Write Register does not control the UART in any way. It is intended as a scratchpad register to be used by the programmer to hold data temporarily.

#### **B. PARALLEL PORT**

The W86C452's parallel port interfaces the device to a Centronices-style printer. When ( $\overline{PRT1}$ ) is low, the parallel is selected. Table 5 shows the registers associated with this parallel port. The read or write function of the register is controlled by the state of the read ( $\overline{IOR}$ ) and write ( $\overline{IOW}$ ) pin as shown. The top four registers are read-only registers, and the botton four are write-only registers. Table 6 shows the selection of PARALLEL PORT registers.



## Table 5. Parallel Port Registers

| REGISTER      | REGISTER BITS |       |       |         |       |       |        |        |  |
|---------------|---------------|-------|-------|---------|-------|-------|--------|--------|--|
|               | Bit 7         | Bit 6 | Bit 5 | Bit 4   | Bit 3 | Bit 2 | Bit 1  | Bit O  |  |
| 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    | PD <b>7</b>   | PD6   | PD5   | PD4     | PD3   | PD2   | PD1    | PD0    |  |
| Write Control | 1             | 1     | 1     | IRQ ENB | SLIN  | INIT  | AUTOFD | STROBE |  |

|     |     | CONTROL PINS | REGISTER SELECTED |    |               |
|-----|-----|--------------|-------------------|----|---------------|
| IOR | ĪŌŴ | PRT1         | 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            | 1                 | 0  | Write Control |
| 1   | 0   | 0            | 0                 | 0  | Write Port    |
| 1   | 0   | 0            | 0                 | 1  | Invalid       |
| 1   | 0   | 0            | 1                 | 1  | Invalid       |

### **ABSOLUTE MAXIMUM RATINGS**

| PARAMETER         | SYM.                              | RATING                   | UNIT |
|-------------------|-----------------------------------|--------------------------|------|
| Supply Voltage    | V <sub>DD</sub> - V <sub>SS</sub> | -0.2 ~ 7                 | V    |
| Input Voltage     | VIN                               | $-0.2 \sim V_{DD} + 0.2$ | V    |
| Operating Temp.   | TOP                               | 0 ~ 70                   | °C   |
| Storage Temp.     | TST                               | -20 - 150                | °C   |
| Power Dissipation | Р                                 | 700                      | mW   |

## D.C. CHARACTERISTICS

 $(V_{DD} = 5.0V \pm 5\%, V_{SS} = 0V, T_A = 0^{\circ}C \text{ to } 70^{\circ}C)$ 

| PARAMETER     | SYM. | CONDITIONS   | MIN.  | MAX. | UNIT |
|---------------|------|--------------|-------|------|------|
| Input Voltago | VILX | Clock input  | - 0.5 | 0.8  | V    |
| Input Voltage | VIHX |              | 2.0   | Vcc  | V    |
|               | VIL  | Other inputs | -0.5  | 0.8  | V    |
| Input Voltage | VIH  |              | 2.0   | Vcc  | V    |



| PARAMETER                                             | SYM.         | CONDITIONS                                                                                                                                                         | MIN. | MAX. | UNIT |
|-------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|
| Output Voltage                                        | VOL          | IOL=4.0mA on all DB0-DB7,<br>12mA on PD0-PD7, 2mA on<br>all other outputs                                                                                          | -    | 0.4  | v    |
|                                                       | VOH          | $I_{OH} = -0.4$ mA on all DB0-DB7,<br>-0.2mA on PD0-PD7, -0.2mA<br>on all other outputs                                                                            | 2.4  | _    | v    |
| Average Power<br>Supply Current<br>(V <sub>CC</sub> ) | ICCA         | $V_{DD}$ =5.25V, $T_A$ =25°C<br>No load on output<br>SIN, DSR, DCD, CTS, RI=2.0V<br>All other inputs = 0.8V<br>Baud Rate Generator is<br>4 MHz<br>Baud Rate is 56k | _    | 50   | mA   |
| Input Leakage                                         | ΙĮ           | $V_{DD} = 5.25V, V_{SS} = 0V$                                                                                                                                      |      | ±10  | μA   |
| Clock Leakage                                         | ICL          | All other pins floating V <sub>IN</sub> =0V, 5.25V                                                                                                                 | —    | ±10  | μA   |
| Tri-state Lekage                                      | loz          | V <sub>DD</sub> =5.25V, V <sub>SS</sub> =0V<br>V <sub>OUT</sub> =0V, 5.25V<br>1) Chip deselected<br>2) WRITE mode,<br>chip selected                                | _    | ±20  | μΑ   |
| Reset Schmitt<br>VIL                                  | VIL<br>(res) |                                                                                                                                                                    | _    | 0.8  | V    |
| Reset Schmitt<br>VIH                                  | ViH<br>(res) |                                                                                                                                                                    | 2.0  | _    | V    |

## A.C. CHARACTERISTICS

 $(V_{DD} = 5.0V \pm 5\%, V_{SS} = 0V, T_A = 0^{\circ}C \text{ IO } 70^{\circ}C)$ 

| PARAMETER                  | SYM. | CONDITIONS                | MIN. | MAX. | UNIT |
|----------------------------|------|---------------------------|------|------|------|
| IOR Delay From Address     | TAR  | (Note 2)                  | 60   | _    | nS   |
| IOW Delay from Address     | TAW  | (Note 2)                  | 60   | -    | nS   |
| IOR Delay from Chip Select | TCSR | (Note 2)                  | 50   | -    | nS   |
| IOW Delay from Select      | TCSW | (Note 2)                  | 50   |      | nS   |
| Data Hold Time             | TDH  |                           | 40   | _    | nS   |
| Data Setup Time            | TDS  |                           | 40   | —    | nS   |
| IOR to Floating Data Delay | THZ  | 100pF loading<br>(Note 4) | 0    | 100  | nS   |
| Address Hold Time from IOR | TRA  | (Note 2)                  | 20   | _    | nS   |

# 

| PARAMETER                         | SYM. | CONDITIONS     | MIN. | MAX. | UNIT |
|-----------------------------------|------|----------------|------|------|------|
| IOR Strobe Width                  | TRD  |                | 125  | -    | nS   |
| Delay from IOR to Data            | TRVD | @100pF loading | _    | 125  | nS   |
| Address Hold Time form IOW        | TWA  | (Note 2)       | 20   | _    | nS   |
| Chip Select Hold Time from<br>IOW | TWCS | (Note 2)       | 20   |      | nS   |
| Chip Select Hold Time from IOR    | TRCS | (Note 2)       | 20   | _    | nS   |
| IOW Strobe Width                  | TWR  |                | 100  |      | nS   |
| Duration of Clock High Pulse      | Тхн  | External Clock | 140  | —    | nS   |
| Duration of Clock Low Pulse       | TXL  | External Clock | 140  | -    | nS   |
| Reset Pulse WIDTH                 | TRW  |                | 5    |      | nS   |
| Read Cycle                        | RC   |                | 360  | —    | nS   |
| Write Cycle                       | WC   |                | 360  | —    | nS   |

Note 1: All timing specifications apply to pin on both serial channels.

2: The internal address strobe is always active.

3:  $RCLK = T_{XL}$  and  $T_{XL}$ .

4: Charge and discharge time is determined by  $V_{\mbox{OL}},\,V_{\mbox{OH}}$  and the external loading.

### **CHARACTERISTICS** (Continue)

 $(V_{DD} = 5.0V \pm 5\%, V_{SS} = 0V, T_A = 0^{\circ}C \text{ to } 70^{\circ}C)$ 

| PARAMETER                                               | SYM.            | CONDITIONS    | MIN. | MAX. | UNIT          |
|---------------------------------------------------------|-----------------|---------------|------|------|---------------|
| Receiver                                                |                 |               |      |      |               |
| Delay from IOR (RD RBR or<br>RD LSR) to Reset Interrupt | TRINT           | 100pF loading | _    | 1    | μS            |
| Delay from Stop to<br>Set Interrupt                     | TSINT           |               | 1    | 1    | RCLK<br>Cycle |
| Transmitter                                             |                 | _             |      |      |               |
| Delay from IOW (WR THR)<br>to Reset Interrupt           | T <sub>HR</sub> | 100pF Load    | -    | 175  | nS            |
| Delay from IOR (RD IIR)<br>to Reset Interrupt (THRE)    | TIR             | 100pF Load    |      | 250  | nS            |
| Delay from Initial INTR Reset<br>to Transmit Start      | TIRS            |               | 1    | 8    | B.C.          |
| Delay from Initial Write to<br>Interrupt                | TSI             |               | 9    | 16   | B.C.          |
| Delay from Stop to Interrupt (THRE)                     | TSTI            |               | 8    | 8    | B.C.          |



| PARAMETER                                        | SYM.             | CONDITIONS | MIN. | MAX. | UNIT |
|--------------------------------------------------|------------------|------------|------|------|------|
| Modem Control                                    |                  |            |      |      |      |
| Delay from IOW (WR MCR) to Output                | TMDO             | 100pF Load | _    | 200  | nS   |
| Delay to Reset Interrupt from IOR<br>(RD MSR)    | T <sub>RIM</sub> | 100pF Load | _    | 250  | nS   |
| Delay to Reset Interrupt from MODEM input        | Tsim             | 100pF Load | -    | 200  | nS . |
| Parallel Port                                    |                  |            |      |      |      |
| Data Time                                        | TDT              |            | 0.5  | -    | μS   |
| Strobe Time                                      | TSB              |            | 1    | 500  | μS   |
| Acknowledge Delay (Busy Start to<br>Acknowledge) | T <sub>AD</sub>  | (Note 5)   |      |      | μS   |
| Acknowledge Delay (Busy End to<br>Acknowledge)   | TAKD             | (Note 5)   |      |      | μS   |
| Acknowledge Duration time                        | TAK              | (Note 5)   |      |      | μS   |
| Busy Duration Time                               | TBSY             | (Note 5)   |      |      | μS   |
| Busy Delay Time                                  | TBSD             | (Note 5)   |      |      | μS   |

Note 1: All timing specifications apply to pin on both serial channels.

- 2: The internal address strobe is always active.
- 3:  $RCLK = T_{XL}$  and  $T_{XL}$ .
- 4: Charge and discharge time is determined by  $V_{\mbox{OL}},\,V_{\mbox{OH}}$  and the external loading.
- 5: Defined by Printer.

**TIMING WAVEFORM** (All timings are referenced to valid 0 and valid 1) A.C. TESTING INPUT/OUTPUT WAVEFORMS



Note 1: The 2.4V and 0.4V levels are the voltages that the inputs are driven to during A.C. testing. 2: The 2.0V and 0.8V levels are the voltages at which the timing tests are made.



#### A.C. TEST LOAD



## TIMING WAVEFORM (Continue) WRITE CYCLE TIMING





### READ CYCLE TIMING



#### TIMING WAVEFORM (Continue)

RECEIVER TIMING





#### TRANSMITTER TIMING



### MODEM TIMING





#### TIMING WAVEFORMS (Continue)

#### PARALLEL PORT TIMING



#### TYPICAL APPLICATION





## Winbond



#### CORPORATE HEADQUARTERS:

No. 2, R&D Rd. VI, Science-Based Industrial Park. Hsin chu, Taiwan, R.O.C. TEL: (035)770066 FAX: 886-35-774527

#### SALES OFFICE:

11 FI, No. 673, Min Sheng E. Rd, Taipei, Taiwan, R.O.C. TEL: (02)7190505 TLX: 16485 WINTPE FAX: 886-2-7197502

#### Winbond Electronics (H.K.) Ltd.

Room 305, 3/F, 17 Wang Hoi Road Shun Fat Industrial Bldg. Kowloon Bay Kowloon, Hong Kong TEL: 7516023-7 FAX: 7552064 Winbond Electronics (North America) Corp. 3350, Scott Blvd., Bldg. #20 Santa Clara, CA 95054 U.S.A. TEL: (408) 982-0381

#### Winbond Europe

Leuvensesteenweg 613 B-1930 Zaventem, Belgium TEL: (32) (2) 7592910 FAX: (32) (2) 7592964 TLX: 20370 BC.Zav.B.

Note: All data and specifications are subject to change without notice.

25

FAX: (408) 982-9231