## Z-80° SIO Serial Input/Output Controller



## Product Specification

| -                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | February 1980                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Features               | <ul> <li>Two independent full-duplex channels, with separate control and status lines for modems or other devices.</li> <li>Data rates of 0 to 500K bits/second in the xl clock mode with a 2.5 MHz clock (Z-80 SIO), or 0 to 800K bits/second with a 4.0 MHz clock (Z-80A SIO).</li> <li>Asynchronous protocols: everything necessary for complete messages in 5, 6, 7 or 8 bits/character. Includes variable stop bits and several clock-rate multipliers; break generation and detection; parity; overrun and framing error detection.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                          | <ul> <li>Synchronous protocols: everything<br/>necessary for complete bit- or byte-oriented<br/>messages in 5, 6, 7 or 8 bits/character,<br/>including IBM Bisync, SDLC, HDLC,<br/>CCITT-X.25 and others. Automatic CRC<br/>generation/checking, sync character and<br/>zero insertion/deletion, abort genera-<br/>tion/detection and flag insertion.</li> <li>Receiver data registers quadruply buffered,<br/>transmitter registers doubly buffered.</li> <li>Highly sophisticated and flexible daisy-<br/>chain interrupt vectoring for interrupts<br/>without external logic.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| General<br>Description | The Z-80 SIO Serial Input/Output Control-<br>ler is a dual-channel data communication<br>interface with extraordinary versatility and<br>capability. Its basic functions as a serial-to-<br>parallel, parallel-to-serial converter/controller<br>can be programmed by a CPU for a broad<br>range of serial communication applications.<br>The device supports all common asyn-<br>chronous and synchronous protocols, byte- or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | bit-oriented, and performs all of the functions<br>traditionally done by UARTs, USARTs and<br>synchronous communication controllers com-<br>bined, plus additional functions traditionally<br>performed by the CPU. Moreover, it does this<br>on two fully-independent channels, with an<br>exceptionally sophisticated interrupt structure<br>that allows very fast transfers.<br>Full interfacing is provided for CPU or DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|                        | CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL<br>CONTROL | $     IL A      D_1      D_1     D_2     D_2     D_2     D_3     D_3     D_3     D_2     D_3     D_4     D_7     D_5     D_5     D_5     D_5     D_1     D_2     D_2     D_2     D_2     D_2     D_2     D_2     D_1     D_1     D_1     D_2     D_2     D_1     D_1     D_1     D_1     D_1     D_2     D_2     D_2     D_1     D_2     D_2     D_1     D_1 $ |  |  |  |

Figure 1. Z-80 SIO/0 Pin Functions

Figure 2. Z-80 SIO/0 Pin Assignments

General control. In addition to data communication, the The Z-80 SIO is an n-channel silicon-gate Description depletion-load device packaged in a 40-pin circuit can handle virtually all types of serial (Continued) I/O with fast (or slow) peripheral devices. plastic or ceramic DIP. It uses a single +5 V power supply and the standard Z-80 family While designed primarily as a member of the Z-80 family, its versatility makes it well suited single-phase clock. to many other CPUs. Pin Figures 1 through 6 illustrate the three pin **CE.** Chip Enable (Input, active Low). A Low Description configurations (bonding options) available in level at this input enables the SIO to accept the SIO. The constraints of a 40-pin package command or data input from the CPU during a make it impossible to bring out the Receive write cycle, or to transmit data to the CPU Clock ( $\overline{RxC}$ ), Transmit Clock ( $\overline{TxC}$ ), Data Terduring a read cycle. minal Ready (DTR) and Sync (SYNC) signals **CLK.** System Clock (input). The SIO uses the for both channels. Therefore, either Channel B standard Z-80 System Clock to synchronize lacks a signal or two signals are bonded internal signals. This is a single-phase clock. together in the three bonding options offered: **CTSA**, **CTSB**. Clear To Send (inputs, active Z-80 SIO/2 lacks SYNCB Low). When programmed as Auto Enables, a Z-80 SIO/1 lacks DTRB Low on these inputs enables the respective transmitter. If not programmed as Auto Z-80 SIO/0 has all four signals, but TxCB Enables, these inputs may be programmed as and  $\overline{RxCB}$  are bonded together general-purpose inputs. Both inputs are The first bonding option above (SIO/2) is the Schmitt-trigger buffered to accommodate slowpreferred version for most applications. The risetime signals. The SIO detects pulses on pin descriptions are as follows: these inputs and interrupts the CPU on both **B/A.** Channel A Or B Select (input, High logic level transitions. The Schmitt-trigger bufselects Channel B). This input defines which fering does not guarantee a specified noisechannel is accessed during a data transfer level margin. between the CPU and the SIO. Address bit  $A_0$ **D**<sub>0</sub>-**D**<sub>7</sub>. System Data Bus (bidirectional, from the CPU is often used for the selection 3-state). The system data bus transfers data function. and commands between the CPU and the Z-80 C/D. Control Or Data Select (input, High SIO.  $D_0$  is the least significant bit. selects Control). This input defines the type of **DCDA**, **DCDB**. Data Carrier Detect (inputs, information transfer performed between the active Low). These pins function as receiver CPU and the SIO. A High at this input during enables if the SIO is programmed for Auto a CPU write to the SIO causes the information Enables; otherwise they may be used as on the data bus to be interpreted as a comgeneral-purpose input pins. Both pins are mand for the channel selected by  $B/\overline{A}$ . A Low Schmitt-trigger buffered to accommodate slowat  $C/\overline{D}$  means that the information on the data risetime signals. The SIO detects pulses on bus is data. Address bit  $A_1$  is often used for these pins and interrupts the CPU on both this function. logic level transitions. Schmitt-trigger buffer-



Figure 3. Z-80 SIO/1 Pin Functions

Figure 4. Z-80 SIO/1 Pin Assignments

ing does not guarantee a specific noise-level margin.

**DTRA**, **DTRB**. Data Terminal Ready (outputs, active Low). These outputs follow the state programmed into Z-80 SIO. They can also be programmed as general-purpose outputs.

In the Z-80 SIO/1 bonding option,  $\overline{\text{DTRB}}$  is omitted.

**IEI.** Interrupt Enable In (input, active High). This signal is used with IEO to form a priority daisy chain when there is more than one interrupt-driven device. A High on this line indicates that no other device of higher priority is being serviced by a CPU interrupt service routine.

**IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an interrupt from this SIO. Thus, this signal blocks lower priority devices from interrupting while a higher priority device is being serviced by its CPU interrupt service routine.

**INT.** Interrupt Request (output, open drain, active Low). When the SIO is requesting an interrupt, it pulls INT Low.

**IORQ.** Input/Output Request (input from CPU, active Low). IORQ is used in conjunction with  $B/\overline{A}$ ,  $C/\overline{D}$ ,  $\overline{CE}$  and  $\overline{RD}$  to transfer commands and data between the CPU and the SIO. When  $\overline{CE}$ ,  $\overline{RD}$  and  $\overline{IORQ}$  are all active, the channel selected by  $B/\overline{A}$  transfers data to the CPU (a read operation). When  $\overline{CE}$  and  $\overline{IORQ}$  are active, the channel selected by  $B/\overline{A}$  is inactive, the channel selected by  $B/\overline{A}$  is written to by the CPU with either data or control information as specified by  $C/\overline{D}$ . As mentioned previously, if  $\overline{IORQ}$  and

MI are active simultaneously, the CPU is acknowledging an interrupt and the SIO automatically places its interrupt vector on the CPU data bus if it is the highest priority device requesting an interrupt.

**M1.** Machine Cycle (input from Z-80 CPU, active Low). When M1 is active and RD is also active, the Z-80 CPU is fetching an instruction from memory; when M1 is active while IORQ is active, the SIO accepts M1 and IORQ as an interrupt acknowledge if the SIO is the highest priority device that has interrupted the Z-80 CPU.

**RxCA**, **RxCB**. Receiver Clocks (inputs). Receive data is sampled on the rising edge of  $\overline{RxC}$ . The Receive Clocks may be 1, 16, 32 or 64 times the data rate in asynchronous modes. These clocks may be driven by the Z-80 CTC Counter Timer Circuit for programmable baud rate generation. Both inputs are Schmitttrigger buffered (no noise level margin is specified).

In the Z-80 SIO/0 bonding option,  $\overline{RxCB}$  is bonded together with  $\overline{TxCB}$ .

**RD.** Read Cycle Status (input from CPU, active Low). If RD is active, a memory or I/O read operation is in progress. RD is used with B/A, CE and IORQ to transfer data from the SIO to the CPU.

**RxDA**, **RxDB**. *Receive Data* (inputs, active High). Serial data at TTL levels.

**RESET.** Reset (input, active Low). A Low RESET disables both receivers and transmitters, forces TxDA and TxDB marking, forces the modem controls High and disables all interrupts. The control registers must be



Figure 5. Z-80 SIO/2 Pin Functions

#### Pin Description

(Continued)

Pin Description (Continued) rewritten after the SIO is reset and before data is transmitted or received.

**RTSA**, **RTSB**. Request To Send (outputs, active Low). When the RTS bit in Write Register 5 (Figure 14) is set, the RTS output goes Low. When the RTS bit is reset in the Asynchronous mode, the output goes High after the transmitter is empty. In Synchronous modes, the RTS pin strictly follows the state of the RTS bit. Both pins can be used as general-purpose outputs.

SYNCA, SYNCB. Synchronization (inputs/outputs, active Low). These pins can act either as inputs or outputs. In the asynchronous receive mode, they are inputs similar to  $\overline{\text{CTS}}$  and DCD. In this mode, the transitions on these lines affect the state of the Sync/Hunt status bits in Read Register 0 (Figure 13), but have no other function. In the External Sync mode, these lines also act as inputs. When external synchronization is achieved, SYNC must be driven Low on the second rising edge of RxC after that rising edge of  $\overline{RxC}$  on which the last bit of the sync character was received. In other words, after the sync pattern is detected, the external logic must wait for two full Receive Clock cycles to activate the SYNC input. Once SYNC is forced Low, it should be kept Low until the CPU informs the external synchronization detect logic that synchronization has been lost or a new message is about to start. Character assembly begins on the rising edge of RxC that immediately precedes the falling edge of SYNC in the External Sync mode.

In the internal synchronization mode (Monosync and Bisync), these pins act as outputs that are active during the part of the receive clock ( $\overline{RxC}$ ) cycle in which sync characters are recognized. The sync condition is not latched, so these outputs are active each time a sync pattern is recognized, regardless of character boundaries.

In the Z-80 SIO/2 bonding option,  $\overline{SYNCB}$  is omitted.

**TxCA**, **TxCB**. Transmitter Clocks (inputs). TxD changes from the falling edge of TxC. In asynchronous modes, the Transmitter Clocks may be 1, 16, 32 or 64 times the data rate; however, the clock multiplier for the transmitter and the receiver must be the same. The Transmit Clock inputs are Schmitt-trigger buffered for relaxed rise- and fall-time requirements (no noise level margin is specified). Transmitter Clocks may be driven by the Z-80 CTC Counter Timer Circuit for programmable baud rate generation.

In the Z-80 SIO/0 bonding option,  $\overline{\text{TxCB}}$  is bonded together with  $\overline{\text{RxCB}}$ .

**TxDA, TxDB.** *Transmit Data* (outputs, active High). Serial data at TTL levels.

**W/RDYA**, **W/RDTB.** Wait/Ready A, Wait/Ready B (outputs, open drain, when programmed for Wait function; driven High and Low when programmed for Ready function). These dual-purpose outputs may be programmed as Ready lines for a DMA controller or as Wait lines that synchronize the CPU to the SIO data rate. The reset state is open drain.



# Functional Description

The functional capabilities of the Z-80 SIO can be described from two different points of view: as a data communications device, it transmits and receives serial data in a wide variety of data-communication protocols; as a Z-80 family peripheral, it interacts with the Z-80 CPU and other peripheral circuits, sharing the data, address and control buses, as well as being a part of the Z-80 interrupt structure. As a peripheral to other microprocessors, the SIO offers valuable features such as nonvectored interrupts, polling and simple handshake capability.

Figure 8 illustrates the conventional devices that the SIO replaces.

The first part of the following discussion covers SIO data-communication capabilities; the second part describes interactions between the CPU and the SIO.



Figure 8. Conventional Devices Replaced by the Z-80 SIO

Data Communication Capabilities The SIO provides two independent fullduplex channels that can be programmed for use in any common asynchronous or synchronous data-communication protocol. Figure 9 illustrates some of these protocols. The following is a short description of them. A more detailed explanation of these modes can be found in the *Z-80 SIO Technical Manual*.

Asynchronous Modes. Transmission and reception can be done independently on each channel with five to eight bits per character, plus optional even or odd parity. The transmitters can supply one, one-and-a-half or two stop bits per character and can provide a break output at any time. The receiver breakdetection logic interrupts the CPU both at the start and end of a received break. Reception is protected from spikes by a transient spikerejection mechanism that checks the signal one-half a bit time after a Low level is detected on the receive data input (RxDA or RxDB in Figure 5). If the Low does not persist—as in the case of a transient—the character assembly process is not started.

Framing errors and overrun errors are detected and buffered together with the partial character on which they occurred. Vectored interrupts allow fast servicing of error conditions using dedicated routines. Furthermore, a built-in checking process avoids interpreting a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit is begun.

The SIO does not require symmetric transmit and receive clock signals—a feature that allows it to be used with a Z-80 CTC or many other clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32 or 1/64 of the clock rate supplied to the receive and transmit clock inputs.

In asynchronous modes, the SYNC pin may be programmed as an input that can be used for functions such as monitoring a ring indicator.

**Synchronous Modes.** The SIO supports both byte-oriented and bit-oriented synchronous communication.

Synchronous byte-oriented protocols can be handled in several modes that allow character synchronization with an 8-bit sync character (Monosync), any 16-bit sync pattern (Bisync), or with an external sync signal. Leading sync Data Communication Capabilities (Continued) characters can be removed without interrupting the CPU.

Five-, six- or seven-bit sync characters are detected with 8- or 16-bit patterns in the SIO by overlapping the larger pattern across multiple in-coming sync characters, as shown in Figure 10.

CRC checking for synchronous byteoriented modes is delayed by one character time so the CPU may disable CRC checking on specific characters. This permits implementation of protocols such as IBM Bisync.

Both CRC-16  $(X^{16} + X^{15} + X^2 + 1)$  and CCITT  $(X^{16} + X^{12} + X^5 + 1)$  error checking polynomials are supported. In all non-SDLC modes, the CRC generator is initialized to 0's; in SDLC modes, it is initialized to 1's. The SIO can be used for interfacing to peripherals such as hard-sectored floppy disk, but it cannot generate or check CRC for IBM-compatible soft-sectored disks. The SIO also provides a feature that automatically transmits CRC data when no other data is available for transmission. This allows very high-speed transmissions under DMA control with no need for CPU intervention at the end of a message. When there is no data or CRC to send in synchronous modes, the transmitter inserts 8- or 16-bit sync characters regardless of the programmed character length.

The SIO supports synchronous bit-oriented protocols such as SDLC and HDLC by performing automatic flag sending, zero insertion and CRC generation. A special command can be used to abort a frame in transmission. At the end of a message the SIO automatically transmits the CRC and trailing flag when the transmit buffer becomes empty. If a transmit underrun occurs in the middle of a message, an external/status interrupt warns the CPU of this status change so that an abort may be issued. One to eight bits per character can be sent, which allows reception of a message with no prior information about the character structure in the information field of a frame.

The receiver automatically synchronizes on the leading flag of a frame in SDLC or HDLC, and provides a synchronization signal on the SYNC pin; an interrupt can also be programmed. The receiver can be programmed to search for frames addressed by a single byte to only a specified user-selected address or to a global broadcast address. In this mode, frames that do not match either the user-selected or broadcast address are ignored. The number of address bytes can be extended under software control. For transmitting data, an interrupt on the first received character or on every character can be selected. The receiver automatically deletes all zeroes inserted by the transmitter during character assembly. It also calculates and automatically checks the CRC to validate frame transmission. At the end of transmission, the status of a received frame is available in the status registers.

The SIO can be conveniently used under DMA control to provide high-speed reception or transmission. In reception, for example, the SIO can interrupt the CPU when the first character of a message is received. The CPU then enables the DMA to transfer the message to memory. The SIO then issues an end-offrame interrupt and the CPU can check the status of the received message. Thus, the CPU is freed for other service while the message is being received.



Figure 9. Some Z-80 SIO Protocols



I/O Interface Capabilities The SIO offers the choice of polling, interrupt (vectored or non-vectored) and blocktransfer modes to transfer data, status and control information to and from the CPU. The block-transfer mode can also be implemented under DMA control.

**Polling.** Two status registers are updated at appropriate times for each function being performed (for example, CRC error-status valid at the end of a message). When the CPU is operated in a polling fashion, one of the SIO's two status registers is used to indicate whether the SIO has some data or needs some data. Depending on the contents of this register, the CPU will either write data, read data, or just go on. Two bits in the register indicate that a data transfer is needed. In addition, error and other conditions are indicated. The second status register (special receive conditions) does not have to be read in a polling sequence, until a character has been received. All interrupt modes are disabled when operating the device in a polled environment.

**Interrupts.** The SIO has an elaborate interrupt scheme to provide fast interrupt service in real-time applications. A control register and a status register in Channel B contain the interrupt vector. When programmed to do so, the SIO can modify three bits of the interrupt vector in the status register so that it points directly to one of eight interrupt service routines in memory, thereby servicing conditions in both channels and eliminating most of the needs for a status-analysis routine.

Transmit interrupts, receive interrupts and external/status interrupts are the main sources of interrupts. Each interrupt source is enabled under program control, with Channel A having a higher priority than Channel B, and with receive, transmit and external/status interrupts prioritized in that order within each channel. When the transmit interrupt is enabled, the CPU is interrupted by the transmit buffer becoming empty. (This implies that the transmitter must have had a data character written into it so it can become empty.) The receiver can interrupt the CPU in one of two ways:

- Interrupt on first received character
- Interrupt on all received characters

Interrupt-on-first-received-character is typically used with the block-transfer mode. Interrupt-on-all-received-characters has the option of modifying the interrupt vector in the event of a parity error. Both of these interrupt modes will also interrupt under special receive conditions on a character or message basis (end-of-frame interrupt in SDLC, for example). This means that the special-receive condition can cause an interrupt only if the interrupt-onfirst-received-character or interrupt-on-allreceived-characters mode is selected. In interrupt-on-first-received-character, an interrupt can occur from special-receive conditions (except parity error) after the first-receivedcharacter interrupt (example: receive-overrun interrupt).

The main function of the external/status interrupt is to monitor the signal transitions of the Clear To Send (CTS), Data Carrier Detect (DCD) and Synchronization (SYNC) pins (Figures 1 through 6). In addition, an external/status interrupt is also caused by a CRCsending condition or by the detection of a break sequence (asynchronous mode) or abort sequence (SDLC mode) in the data stream. The interrupt caused by the break/abort sequence allows the SIO to interrupt when the break/abort sequence is detected or terminated. This feature facilitates the proper termination of the current message, correct initialization of the next message, and the accurate timing of the break/abort condition in external logic.

I/O Interface Capabilities (Continued) In a Z-80 CPU environment (Figure 11), SIO interrupt vectoring is "automatic": the SIO passes its internally-modifiable 8-bit interrupt vector to the CPU, which adds an additional 8 bits from its interrupt-vector (I) register to form the memory address of the interrupt-routine table. This table contains the address of the beginning of the interrupt routine itself. The process entails an indirect transfer of CPU control to the interrupt routine, so that the next instruction executed after an interrupt acknowledge by the CPU is the first instruction of the interrupt routine itself.

**CPU/DMA Block Transfer.** The SIO's blocktransfer mode accommodates both CPU block transfers and DMA controllers (Z-80 DMA or other designs). The block-transfer mode uses the Wait/Ready output signal, which is selected with three bits in an internal control register. The Wait/Ready output signal can be programmed as a WAIT line in the CPU blocktransfer mode or as a READY line in the DMA block-transfer mode.

To a DMA controller, the SIO  $\overline{\text{READY}}$  output indicates that the SIO is ready to transfer data to or from memory. To the CPU, the  $\overline{\text{WAIT}}$  output indicates that the SIO is not ready to transfer data, thereby requesting the CPU to extend the I/O cycle.

Internal Structure The internal structure of the device includes a Z-80 CPU interface, internal control and interrupt logic, and two full-duplex channels. Each channel contains its own set of control and status (write and read) registers, and control and status logic that provides the interface to modems or other external devices.

The registers for each channel are designated as follows:

WR0-WR7 — Write Registers 0 through 7 RR0-RR2 — Read Registers 0 through 2

The register group includes five 8-bit control registers, two sync-character registers and two status registers. The interrupt vector is written into an additional 8-bit register (Write Register 2) in Channel B that may be read through another 8-bit register (Read Register 2) in Channel B. The bit assignment and functional grouping of each register is configured to simplify and organize the programming process. Table 1 lists the functions assigned to each read or write register.



Figure 11. Typical Z-80 Environment

#### **Read Register Functions**

- RR0 Transmit/Receive buffer status, interrupt status and external status
- RR1 Special Receive Condition status
- RR2 Modified interrupt vector (Channel B only)

#### Write Register Functions

- WR0 Register pointers, CRC initialize, initialization commands for the various modes, etc.
- WR1 Transmit/Receive interrupt and data transfer mode definition.
- WR2 Interrupt vector (Channel B only)
- WR3 Receive parameters and control
- WR4 Transmit/Receive miscellaneous parameters and modes
- WR5 Transmit parameters and controls
- WR6 Sync character or SDLC address field
- WR7 Sync character or SDLC flag

Internal Structure (Continued) The logic for both channels provides formats, synchronization and validation for data transferred to and from the channel interface. The modem control inputs, Clear To Send ( $\overline{\text{CTS}}$ ) and Data Carrier Detect ( $\overline{\text{DCD}}$ ), are monitored by the external control and status logic under program control. All external control-and-status-logic signals are generalpurpose in nature and can be used for functions other than modem control.

**Data Path.** The transmit and receive data path illustrated for Channel A in Figure 12 is identical for both channels. The receiver has three 8-bit buffer registers in a FIFO arrangement, in addition to the 8-bit receive shift register. This scheme creates additional time for the

CPU to service an interrupt at the beginning of a block of high-speed data. Incoming data is routed through one of several paths (data or CRC) depending on the selected mode and—in asynchronous modes—the character length.

The transmitter has an 8-bit transmit data buffer register that is loaded from the internal data bus, and a 20-bit transmit shift register that can be loaded from the sync-character buffers or from the transmit data register. Depending on the operational mode, outgoing data is routed through one of four main paths before it is transmitted from the Transmit Data output (TxD).



Figure 12. Transmit and Receive Data Path (Channel A)

#### Programming

The system program first issues a series of commands that initialize the basic mode of operation and then other commands that qualify conditions within the selected mode. For example, the asynchronous mode, character length, clock rate, number of stop bits, even or odd parity might be set first; then the interrupt mode; and finally, receiver or transmitter enable.

Both channels contain registers that must be programmed via the system program prior to operation. The channel-select input  $(B/\overline{A})$  and the control/data input  $(C/\overline{D})$  are the commandstructure addressing controls, and are normally controlled by the CPU address bus. Figures 15 and 16 illustrate the timing relationships for programming the write registers and transferring data and status.

**Read Registers.** The SIO contains three read registers for Channel B and two read registers for Channel A (RR0-RR2 in Figure 13) that can be read to obtain the status information; RR2 contains the internally-modifiable interrupt vector and is only in the Channel B register set. The status information includes error conditions, interrupt vector and standard communications-interface signals.

To read the contents of a selected read register other than RR0, the system program must first write the pointer byte to WR0 in exactly the same way as a write register operation. Then, by executing a read instruction, the contents of the addressed read register can be read by the CPU.

The status bits of RR0 and RR1 are carefully grouped to simplify status monitoring. For example, when the interrupt vector indicates that a Special Receive Condition interrupt has occurred, all the appropriate error bits can be read from a single register (RR1).

Write Registers. The SIO contains eight write registers for Channel B and seven write registers for Channel A (WR0-WR7 in Figure 14) that are programmed separately to configure the functional personality of the channels; WR2 contains the interrupt vector for both channels and is only in the Channel B register set. With the exception of WR0, programming the write registers requires two bytes. The first byte is to WR0 and contains three bits ( $D_0$ - $D_2$ ) that point to the selected register; the second byte is the actual control word that is written into the register to configure the SIO. WR0 is a special case in that all of the basic commands can be written to it with a single byte. Reset (internal or external) initializes the pointer bits  $D_0$ - $D_2$  to point to WR0. This implies that a channel reset must not be combined with the pointing to any register.



#### Figure 13. Read Register Bit Functions







Figure 14. Write Register Bit Functions

The SIO must have the same clock as the CPU (same phase and frequency relationship, not necessarily the same driver).

Timing

**Read Cycle.** The timing signals generated by a Z-80 CPU input instruction to read a data or status byte from the SIO are illustrated in Figure 15.

**Write Cycle.** Figure 16 illustrates the timing and data signals generated by a Z-80 CPU output instruction to write a data or control byte into the SIO.

Interrupt-Acknowledge Cycle. After receiving an interrupt-request signal from an SIO ( $\overline{INT}$  pulled Low), the Z-80 CPU sends an interrupt-acknowledge sequence ( $\overline{M1}$  Low, and  $\overline{IORQ}$  Low a few cycles later) as in Figure 17.

The SIO contains an internal daisy-chained interrupt structure for prioritizing nested interrupts for the various functions of its two channels, and this structure can be used within an external user-defined daisy chain that prioritizes several peripheral circuits.

The IEI of the highest-priority device is terminated High. A device that has an interrupt pending or under service forces its IEO Low. For devices with no interrupt pending or under service, IEO = IEI.

To insure stable conditions in the daisy chain, all interrupt status signals are prevented from changing while  $\overline{M1}$  is Low. When  $\overline{IORQ}$  is Low, the highest priority interrupt requestor (the one with IEI High) places its interrupt vector on the data bus and sets its



Figure 15. Read Cycle



Figure 16. Write Cycle

internal interrupt-under-service latch.

**Return From Interrupt Cycle.** Figure 18 illustrates the return from interrupt cycle. Normally, the Z-80 CPU issues a RETI (Return From Interrupt) instruction at the end of an interrupt service routine. RETI is a 2-byte opcode (ED-4D) that resets the interruptunder-service latch in the SIO to terminate the interrupt that has just been processed. This is accomplished by manipulating the daisy chain in the following way.

The normal daisy-chain operation can be used to detect a pending interrupt; however, it cannot distinguish between an interrupt under service and a pending unacknowledged interrupt of a higher priority. Whenever "ED" is decoded, the daisy chain is modified by forcing High the IEO of any interrupt that has not yet been acknowledged. Thus the daisy chain identifies the device presently under service as the only one with an IEI High and an IEO Low. If the next opcode byte is "4D," the interruptunder-service latch is reset.

The ripple time of the interrupt daisy chain (both the High-to-Low and the Low-to-High transitions) limits the number of devices that can be placed in the daisy chain. Ripple time can be improved with carry-look-ahead, or by extending the interrupt-acknowledge cycle. For further information about techniques for increasing the number of daisy-chained devices, refer to the Z-80 CPU Product Specification.



Figure 17. Interrupt Acknowledge Cycle



Figure 18. Return from Interrupt Cycle

 Absolute
 Voltages on all inputs and outputs

 Maximum
 with respect to GND....-0.3 V to +7.0 V

 Ratings
 Operating Ambient

 Temperature
 As Specified in

 Ordering Information

Storage Temperature .....-65°C to +150°C

StandardThe characteristics below apply for the<br/>following standard test conditions, unlessConditionsotherwise noted. All voltages are referenced to<br/>GND. Positive current flows into the refer-<br/>enced pin. Standard conditions are as follows:

- +4.75 V ≤  $V_{CC}$  ≤ +5.25 V
- $\blacksquare$  GND = 0 V
- T<sub>A</sub> as specified in Ordering Information

Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.



All ac parameters assume a load capacitance of 100 pF max. Timing references between two

output signals assume a load difference of 50 pF max.

| DC<br>Charac- | Symbol             | Parameter                                     | Min                  | Μαχ   | Unit | Test Condition            |
|---------------|--------------------|-----------------------------------------------|----------------------|-------|------|---------------------------|
| teristics     | V <sub>ILC</sub>   | Clock Input Low Voltage                       | -0.3                 | +0.45 | V    |                           |
|               | V <sub>IHC</sub>   | Clock Input High Voltage                      | V <sub>CC</sub> -0.6 | +5.5  | V    |                           |
|               | V <sub>IL</sub>    | Input Low Voltage                             | -0.3                 | +0.8  | V    |                           |
|               | V <sub>IH</sub>    | Input High Voltage                            | +2.0                 | + 5.5 | V    |                           |
|               | V <sub>OL</sub>    | Output Low Voltage                            |                      | +0.4  | V    | $I_{OL} = 2.0 \text{ mA}$ |
|               | V <sub>OH</sub>    | Output High Voltage                           | +2.4                 |       | V    | $I_{OH} = -250 \ \mu A$   |
|               | ILI                | Input Leakage Current                         | -10                  | +10   | μA   | $0 < V_{IN} < V_{CC}$     |
|               | Ι <sub>Ζ</sub>     | 3-State Output/Data Bus Input Leakage Current | -10                  | +10   | μA   | $0 < V_{IN} < V_{CC}$     |
|               | I <sub>L(SY)</sub> | SYNC Pin Leakage Current                      | -40                  | +10   | μA   | $0 < V_{IN} < V_{CC}$     |
|               | $I_{CC}$           | Power Supply Current                          |                      | 100   | mA   |                           |

Over specified temperature and voltage range.

| Capacitance | Symbol           | Parameter          | Min | Μαχ | Unit | Test Condition |
|-------------|------------------|--------------------|-----|-----|------|----------------|
|             | С                | Clock Capacitance  |     | 40  | pF   | Unmeasured     |
|             | C <sub>IN</sub>  | Input Capacitance  |     | 5   | pF   | pins returned  |
|             | C <sub>OUT</sub> | Output Capacitance |     | 10  | pF   | to ground      |

Over specified temperature range; f =  $1MH_z$ 

| Ordering<br>Information | Part Number  | Maximum<br>Clock Rate | Temperature Range | Package |
|-------------------------|--------------|-----------------------|-------------------|---------|
|                         | Z-80 SIO PS  | 2.5 MHz               | 0°C to 70°C       | Plastic |
|                         | Z-80 SIO CS  | 2.5 MHz               | 0°C to 70°C       | Ceramic |
|                         | Z-80 SIO CE  | 2.5 MHz               | -40°C to 85°C     | Ceramic |
|                         | Z-80 SIO CM  | 2.5 MHz               | -55℃ to 125℃      | Ceramic |
|                         | Z-80A SIO PS | 4.0 MHz               | 0°C to 70°C       | Plastic |
|                         | Z-80A SIO CS | 4.0 MHz               | 0°C to 70°C       | Ceramic |
|                         | Z-80A SIO CE | 4.0 MHz               | -40°C to 85°C     | Ceramic |
|                         | Z-80A SIO CM | 4.0 MHz               | –55°C to 125°C    | Ceramic |

### AC Electrical Characteristics



|        |               |                                                                                                                            | Z-80  | SIO    | Z-80/ | A SIO  |                   |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------|-------|--------|-------|--------|-------------------|
| Number | Symbol        | Parameter                                                                                                                  | Min   | Μαχ    | Min   | Μαχ    | Unit              |
| 1      | TcC           | Clock Cycle Time                                                                                                           | 400   | 4000   | 250   | 4000   | ns                |
| 2      | TwCh          | Clock Width (High)                                                                                                         | 170   | 2000   | 105   | 2000   | ns                |
| 3      | TfC           | Clock Fall Time                                                                                                            |       | 30     |       | 30     | ns                |
| 4      | TrC           | Clock Rise Time                                                                                                            |       | 30     |       | 30     | ns                |
| 5      | TwCl          | Clock Width (Low)                                                                                                          | -170- | - 2000 | 105   | - 2000 | — ns <del>–</del> |
| 6      | TsAD(C)       | $\overline{\operatorname{CE}}$ , C/ $\overline{\operatorname{D}}$ , B/ $\overline{\operatorname{A}}$ to Clock † Setup Time | 160   |        | 145   |        | ns                |
| 7      | TsCS(C)       | $\overline{\mathrm{IORQ}}$ , $\overline{\mathrm{RD}}$ to Clock † Setup Time                                                | 240   |        | 115   |        | ns                |
| 8      | TdC(DO)       | Clock 1 to Data Out Delay                                                                                                  |       | 240    |       | 220    | ns                |
| 9      | TsDI(C)       | Data In to Clock † Setup (Write or $\overline{\text{Ml}}$ Cycle)                                                           | 50    |        | 50    |        | ns                |
|        | TdRD(DOz)     | - RD † to Data Out Float Delay                                                                                             |       | - 230- |       | - 110  | — ns —            |
| 11     | TdIO(DOI)     | IORQ ↓ to Data Out Delay (INTA Cycle)                                                                                      |       | 340    |       | 160    | ns                |
| 12     | TsMl(C)       | MI to Clock † Setup Time                                                                                                   | 210   |        | 90    |        | ns                |
| 13     | TsIEI(IO)     | IEI to IORQ ↓ Setup Time (INTA Cycle)                                                                                      | 200   |        | 140   |        | ns                |
| 14     | TdM1(IEO)     | $\overline{\mathrm{Ml}}$ \$\ to IEO \$\ Delay (interrupt before $\overline{\mathrm{Ml}}$ )                                 | 300   |        | 190   | ns     |                   |
| 15     | - TdIEI(IEOr) | - IEI † to IEO † Delay (after ED decode)                                                                                   |       | - 150- |       | - 100  | — ns —            |
| 16     | TdIEI(IEOf)   | IEI ↓ to IEO ↓ Delay                                                                                                       |       | 150    |       | 100    | ns                |
| 17     | TdC(INT)      | Clock † to INT ↓ Delay                                                                                                     |       | 200    |       | 200    | ns                |
| 18     | TdIO(W/RWf)   | $\overline{\text{IORQ}}$   or $\overline{\text{CE}}$   to $\overline{\text{W/RDY}}$   Delay Wait<br>Mode)                  |       | 300    |       | 210    | ns                |
| 19     | TdC(W/BB)     | Clock 1 to W/RDY   Delay (Ready Mode)                                                                                      |       | 120    |       | 120    | ns                |
| 20     | · TdC(W/RWz)- | - Clock ↓ to W/RDY Float Delay (Wait Mode)—                                                                                |       | - 150- |       | - 130  | ns                |
| 21     | Th            | Any unspecified Hold when Setup is specified                                                                               | 0     |        | 0     | 100    | ns                |
|        |               |                                                                                                                            | -     |        | •     |        |                   |

### AC Electrical Characteristics (Continued)



| Number | Symbol       | Parameter                                                                               | Z-80<br>Min | ) SIO<br>Max | Z-80.<br>Min | A SIO<br>Max | Unit           |
|--------|--------------|-----------------------------------------------------------------------------------------|-------------|--------------|--------------|--------------|----------------|
| 1      | TwPh         | Pulse Width (High)                                                                      | 200         |              | 200          |              | ns             |
| 2      | TwPl         | Pulse Width (Low)                                                                       | 200         |              | 200          |              | ns             |
| 3      | TcTxC        | TxC Cycle Time                                                                          | 400         | œ            | 400          | 8            | ns             |
| 4      | TwTxCl       | TxC Width (Low)                                                                         | 180         | 8            | 180          | 8            | ns             |
| 5      | -TwTxCh      | - TxC Width (High)                                                                      | -180-       |              |              |              | ns             |
| 6      | TdTxC(TxD)   | TxC ↓ to TxD Delay (x1 Mode)                                                            |             | 400          |              | 300          | ns             |
| 7      | TdTxC(W/RRf) | $\overline{\text{TxC}} \downarrow \text{to W/RDY} \downarrow \text{Delay (Ready Mode)}$ | 5           | 9            | 5            | 9            | Clk Periods*   |
| 8      | TdTxC(INT)   | TxC ↓ to INT ↓ Delay                                                                    | 5           | 9            | 5            | 9            | Clk Periods*   |
| 9      | TcRxC        | RxC Cycle Time                                                                          | 400         | œ            | 400          | 8            | ns             |
| 10     | TwRxC1       | - RxC Width (Low)                                                                       | -180-       | <u> </u>     |              |              | ns             |
| 11     | TwRxCh       | RxC Width (High)                                                                        | 180.        | 8            | 180          | 8            | ns             |
| 12     | TsRxD(RxC)   | RxD to $\overline{RxC}$ 1 Setup Time (x1 Mode)                                          | 0           |              | 0            |              | ns             |
| 13     | ThRxD(RxC)   | $\overline{\text{RxC}}$ † to RxD Hold time (x1 Mode)                                    | 140         |              | 140          |              | ns             |
| 14     | TdRxC(W/RRf) | $\overline{\text{RxC}}$ 1 to $\overline{\text{W/RDY}}$   Delay (Ready Mode)             | 10          | 13           | 10           | 13           | Clk Periods*   |
|        | TdRxC(INT)   | - RxC   to INT   Delay                                                                  |             | —13—         |              |              | -Clk Periods*— |
| 16     | TdTxC(INT)   | TxC ↓ to INT ↓ Delay                                                                    | 5           | 9            | 5            | 9            | Clk Periods*   |
| 17     | TdRxC(SYNC)  | $\overline{\text{RxC}}$ † to $\overline{\text{SYNC}}$ ↓ Delay (Output Modes)            | 4           | 7            | 4            | 7            | Clk Periods*   |
| 18     | TsSYNC(RxC)  | SYNC ↓ to RxC ↑ Setup (External Sync<br>Modes)                                          | -100        |              | -100         |              | ns             |

In all modes, the System Clock rate must be at least five times the maximum data rate. RESET must be active a minimum of one complete Clock Cycle. \*System Clock



40-Pin Plastic Package



40-Pin Ceramic Package