# DANSK DATA ELEKTRONIK <br> ID-7022 COMBINED <br> RAM-PROM-I/O-MODULE <br> for the <br> ID-7000 MICROPROCESSOR SYSTEM 

Januar 1977

FEATURES:

- 4 KBYTE PROM
- 512 BYTE RAM
- 8 LEVEL VECTORED INTERRUPT
- 5 INTERVAL TIMERS
- 18 BIT OUTPUT PORT
- I TTY/CRT PORT
- 18 BIT INPUT PORT.
- FULL COMPATIBILITY WITH

OTHER ID-7000 MODULES
ALLOWS USE OF POWERFULL
ID-7000 DEBUGGING
FACILITIES.

- LOW COST.


## GENERAL DESCRIPTION:

The ID-7022 module is designed to be used in small ID-7000 systems. The module contains a max. of 4 Kbyte PROM memory, 512 byte RAM memory, one 8 bit input port', one 8 bit buffered output port and connection for asynchronous data communication equipment (TTY, CRT, modem etc.). Furthermore the module contains 5 programable interval timers and logic to handle internal and external interrupts. Selective activating and deactivating of the different interrupt sources is possible by means of an interrupt mask register on the module.

The module may be used together with the ID-7000 CPU-module to make a complete microcomputer. Although the module is designed for small ID-7000 systems, the module may be used in combination with any other ID-7000 modules (including the debugging facilities. It is possible, too, to use several (max. 8) ID-7022 modules in a single system: In this case, the interrupts are handled in a daisy chained manner.

Fig. 1 shows a blocked schematic of the module.
page 2


Fig. 1 ID-7022 RAM/PROM/I-0-module, blocked schematic.


PARALLEL OUTPUTS: 8 bit buffered output port. Output buffers may be different TT-gates (active pull-up, high voltage passive pull-up etc.) to direct interface different peripheral equipment (LED-displays, Relays etc.)

PARALLEL INPUT:

INTERVAL TIMERS:

INTERRUPT:

8 bit high impedance input port.

58 bit interval timers to control 5 independent events. Timing range from 64usec to 16.3 msec . Longer periods can be obtained by counting interrupts in software. Timer interrupts in 5 different levels.

Vectored interrupt processing of: Serial transmit ready, serial receive ready, interval timers and two external interrupts. 8 bit interrupt mask register permits selective activating/deactivating of separate interrupts. General deactivating of module response to interrupt acknowledge cycles.

The module uses 8 k of the 64 k memory addresses of the 8080 . The base address of the module is determined by a 3 bit switch register on the module.

The PROM memory occupies the first 4 k of the addresses. The next 512 bytes are used by the RAM memory.

The I/O-functions ( parallel $1 / 0$, serial $1 / 0$, interval timers ) and the interrupt capabilities of the module is performed by a TMS 55ol Multifunction I/O Controller. The different functions of this controller are addressed in a memory mapped manner as follows:


A detailled description of the TMS 55ol Controller is given in appendix 1 ( data sheets for TMS 55ol ) and appendix 2 ( application note for TMS 55ol ).

The interrupt request line from the TMS 550l, INTO, is connected to the top connector of the module together with a buffered input line, INTI. By means of straps on the module, the output of the INTI buffer may be connected to the $\overline{\mathrm{INT}}$-request line directly to the CPU-module in applications where no ID-7oo3 interrupt priority module is present, or to any of the $\overline{\operatorname{IR}}(7: 0)$ interrupt request lines when an ID-7oo3 module is present. In applications where several ID-7o22 modules are used, it is possible to handle the interrupts in a daisy-chained manner. In this case, only the INTO signal from the first ID-7o22 module may be connected to the INTrequest line ( via the buffer ). The INTO outputs from the following ID-7o22 modules are thenconnected to the SENS input of the previous module.

## INPUT/OUTPUT SPECIFICATIONS:

Parallel inputs $X I(7: 0):$ These inputs are high impedance inputs ( input current less than louA ). Input voltages in the range from 3.3 V to 5.75 V are assigned the logical one level, and input voltages in the range from -1 V to 0.8 V are assigned the logical zero level.

Parallel outputs $X 0(7: 0):$ The parallel outputs $\overline{X 0}(7: 0)$ from the TMS 55ol are connected to 82 -input NAND/AND gates of the types 7400, 7403, 7438, 7438A, 7408, 7409 or other TTL-circuits with the same pin configuration. These components are placed in sockets. In this way different output requirements can be met. Unused inputs of the gates are connected together and pulled to the +5 V supply voltage by a $l$ kohm resistor. This input, $\overline{\text { XDDISABLE, }}$ is connected to the topconnector for external control of the outputs. Notice that the outputs directly from the TMS 5501 are active low. The logical representation of the module outputs depends on the selected gate type.

Serial input/output: 4 different standards may be used for these signals by approiate strapping in the top connector. Please refer to table $l$ describing the top connections of the module for further information.

Table 1: ID-7022, Top connections.

*) Strapping infarmation:

1 TTL-normal:
output: $\operatorname{pin} m$
imput: $\quad$ in $M$
GMD is I/O common
2) TTL-inverted: $\quad$ 3) $\sqrt{24}$ :
strop: $n \rightarrow M \quad$ strap $=L-B$
outpunt: $p_{i n} l$
input: $p$ ma $p$
GWD is I/o common
". : D-E = outat
" : L-p-m
connuct $V_{24}$ inpat to $F$ thragh ext 4x'7rsish GWD is I/O common
4) 20 mA currat lop:

Strap: $J \rightarrow F$
$L \rightarrow p$
$n \rightarrow M$
$m \rightarrow B$
$+\operatorname{mipht}:$

- input = $H$

| + output: $=C$ |
| :--- |
| - outpot: |

The commands are gener ated by executing memory referencing instructions such as MOV (register to memory) with the
memory address being the TMS 5501 command. This provides a high degree of flexibility for $/$ O operations by letting
The commands are generated by executing memory referencing instructions such as MOV (register to memory) with the
memory address being the TMS 5501 command. This provides a high degree of flexibility for $/ / O$ operations by letting the systems programmer use a variety of instructions.
1.2 SUMMARY OF OPERATION
A convenient method for addressing the TMS 5501 is to tie the chip enabie input to the highest order address line of the CPU's 16 -bit address bus and the four TMS 5501 address inputs to the four lowest order bits of the bus. This, of
course, limits the system to 32,768 words of memory but in many applications the full 65,536 word memory addressing capability of the TMS 8080 is not required.
The communications section of the TMS 5501 is an asynchronous transmitter and receiver for serial communications
and provides the following functions:
Programmable baud rate - A CPU command selects a taud rate of 110, 150, 300, 1200, 2400, 4800, or 9600 baud.
Incoming character detection - The receiver detects the start and stop bits of an incoming character and places, the
Character transmission - The transmitter generates start and stop bits for a character received from the CPU and
shifts it out.
Status and command signals - Via the data bus, the TMS 5501 signals the status of: framing errot und overrun error from externai equipment. It also issues break signals to external equipment.

## Data Interface

The TMS 5501 moves data between the CPU and external devices through its internal data bus, input port, and output port. When data is present on the bus that is to be sent to an external device, a Load Output Port (LOP) command from
the CPU puts the data on the XO pins of the TMS 5501 by latching it in the output port. The data remains in the port until another LOP command is received. When the CPU requires data that is present on the External Input (XI) lines, it issues a command that gates the data onto the internal data bus of the TMS 5501 and consequently onto the CPU's
data bus at the correct time during the CPU cycles. Interval Timers
To start a countdown by any of the five interval timers, the program selects the particular timer by an address to the
TMS 5501 and loads the required interval into the timer via the data bus. Loading the timer activates it and it counts TMS 5501 and loads the required interval into the timer via the data bus. Loading the timer activates it and it counts
down in increments of 64 microseconds. The 8 -bit counters provide intervals that vary in duration from 64 to 16,320
 zero, it generates an interrupt that typically will be used to point to a subroutine that performs a servicing function such as polling a peripheral or scanning a keyboard. Loading an interval value of zero causes an immediate interrupt. A new value loaded while the interval timer interval. When an interval timer reaches zero it remains inactive until a new interval is loaded.

## TMS 5501 MULTIFUNCTION INPUT/OUTPUT CONTROLLER

## introduction

The TMS 5501 is a multifunction input/output circuit for use with T1's TMS 8080 CPU . It is fabricated with the same N-channel silicon-gate process as the TMS 8080 and has compatible timing, signal levels, and powernearions requirements. The TMS 5501 provides a TMS 8080 microprocessor
interface, data I/O buffers, interrupt control logic, and interval timers.


FIGURE 1-TMS 5501 bLOCK DIAGRAM
The I/O section of the TMS 5501 contains an eight-bit parallet input port and a separate eight-bit parallel output port with storage register. Five programmabie interval timers provide time intervais from $64 \mu s$ to 16.32 ms .

The interrupt system allows the processor to effectively communicate with the interval timers, external signais, and the
communications interface by providing TMS 8080 -compatible interrupt logic with masking capability.
Data transfers between the TMS 5501 and the CPU are carried by the data bus and controlled by the interrupt, chip which the TMS 5501 will respond. These commands allow the CPU to:
.-. read the receiver buffer
… read the interrupt address
... read TMS 5501 status
-. issue discrete commands
-- load baud rate register
-- load the transmitter buffer

- load the output port
- load the mask register



| 咢 |  |  |  | 8 <br> 9 <br> ．믕 <br> $\stackrel{\leftrightarrow}{3}$ <br> 产䔍 <br> 解 <br> $\stackrel{\circ}{\circ}$ <br> $\stackrel{+}{+}$ <br>  <br> 兵占 <br> $\dot{U}^{2}$ <br> 은 <br> 茦 <br> 묻 莒 a 0 <br> ． <br> $\stackrel{0}{5}$ <br> 9. <br> 둥 <br> 둔 <br> 滳 <br> 믈 <br> 皆 <br> $\stackrel{\circ}{8}$ <br> 릉 <br> 운 $\sum_{1}^{\circ}$ <br>  <br> 方 <br>  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |


Bit 4 , transmitter buffer empty
A high in bit 4 indicates that the
A high in bitt 4 indicates that the transmitter buffer register is empty and ready to accept a character. Note, however, that the serial transmitter register may be in the process of shifting out a character. The reset function sets the
transmitter buffer-empty fiag high.
Ait 5 , interrupt pending enabled. This bit is the status of the interrupt signal INT.
Bit 6 , full bit detected
A high in bit 6 indicates that the first data bit of a receive-data character has foe est purposes.
Bit 7 , start bit detected
A high in bit 7 indicates that the start bit of an incoming data character has been detected. This bit remains high until the entire character has been received or until a reset is issued and is provided for test purposes.
2.2.5 Issue discrete commands
Addressing the discrete command function causes the TMS 5501 to interpret the data bus information.according to the
following descriptions. See Figure 4 for the discrete command format. Bits 1 through 5 are latched until a different following descriptions. See Figure 4 tor NORMALLY LOW

| $\xrightarrow{\sim}$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| NOT | NOT | TEST | TEST | INT. | INT. 7 |  |  |
| USED | USED | BIT | 815 | ACK. | SELECT | break | RESET |

## $E_{\text {E }}$ H: Reset, No action

 $\left.\begin{array}{r}\text { H: Selects XI 7 } \\ \text { L: Selects interval timer } 5\end{array}\right] \quad\left[\begin{array}{l}-H: L \text { Sets XMT output low } \\ \text { L: H Sets XMT output high }\end{array}\right.$FIGURE 4-DISCRETE COMMAND FORMAT
Bit 0 , rese:
A high in bit 0 will cause the following:

1) The receiver buffer and register are cleared to the search mode including the receiver-buffer-loaded flag. the start-bit-detected flag, the full-bit-detected flag, and the overrun-error tlag. The receiver buffer is not cleared and will contain the last character received.
The transmitter data output is set high
The transmitter data output is set high (marking). The transmitter-buffer-empty flag is set high indicating that the
transmitter buffer is ready to accept a character from the TMS 8080 . transmitter buffer is ready to accept a character from the TMS 8080 .

> The interval timers are inhibited.
A low in bit 0 causes no action. The reset function has no affect on the output port, the external inputs, interrupt
acknowiedge enable, the mask register, the rate register, the transmitter register, or the transmitter buffer.
$\begin{array}{rr}\text { Bit } 0 & 110 \text { baud } \\ \text { Bit } 1 & 150 \text { baud } \\ \text { Bit } 2 & 300 \text { baud } \\ \text { Bit } 3 & 1200 \text { baud } \\ \text { Bit } 4 & 2400 \text { baud } \\ \text { Bit } 5 & 4800 \text { baud } \\ \text { Bit } 6 & 9600 \text { baud }\end{array}$
$\stackrel{\ddot{H}}{\infty}$
Bit 1, break
A low in bit
A low in bit 1 causes the transmitter data output to be reset iow (spacing).
If bit 0 and bit 1 are both high, the reset function will override.
Bit 2 , interrupt 7 select
Interrupt 7 may be generated either by a low to high transition of external input 7 or by interval timer 5 .
A high in bit 2 selects the interrupt 7 source to be the transition of external input 7. A low in bit interrupt 7 source to be interval timer 5 .
Bit 3, interrupt acknowledge enable acknowiedge is being issued.
The TMS 5501 decodes data bus ICPU statuus) bit 0 at SYNC of each machine cycle to determine if an interrupt A high in bit 3 enables the TMS 5501 to ac
to ignore the interrupt acknowiedge decode.
Bit 4 and bit 5 are used only during testing of the TMS 5501 . For correct system operation both bits must be kept low. Bit 6 and bit 7 are not used and can assume any value. 2.2.6 Load rate register
Addressing the load-rate-register function caises the TMS 5501 to load the rate register from the data bus and interpret

FIGURE 5-DATA BUS ASSIGNMENTS FOR RATE COMMANDS
Bits 0 through 6, rate select
The rate select bits (bits 0 through 6) are mutually exclusive, i.e., onty one bit may be high. A high in bits 0 through 6 will select the baud rate for both the transmitter and receiver circuitry as defined below and in Figure 5:
$\begin{array}{rr}\text { Bit } 1 & 150 \text { baud } \\ \text { Bit } 2 & 300 \text { baud } \\ \text { Bit } 3 & 1200 \text { baud }\end{array} \quad . \quad . \quad$.



SWITCHING CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED
OPERATING CONDITIONS (SEE FIGURES 6 AND 7 )

| parameter |  | test conditions | min max | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| tpzx | Data ous output enable time | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} . \\ & \mathrm{R}_{\mathrm{L}}=1.3 \mathrm{k} \Omega \end{aligned}$ | 200 | ns |
| tpxz | Data bus output disable ume to niph Mmpecance state |  | 180 | m |
| tPD | External data output propagation delay ume from o2 |  | 200 | $n$ |



FIGURE G-READ CYCLE TIMING

## A Texas Instruments Application Report

## TABLE OF CONTENTS

Section Title Page
I. INTRODUCTION ..... 4
II. TMS 5501 OPERATION ..... 4
A. TMS 5501 Interface Signals ..... 5

1. Power ..... 5
2. Clocks ..... 5
3. Chip Enable (CE) ..... 5
4. SYNC ..... 5
5. Address Bus (A0 Through A3) ..... 5
6. External Interrupt (SENS) ..... 6
7. Interrupt (INT) ..... 6
8. Receiver Serial Data ( $\overline{\mathrm{RCV}})$ ..... 6
9. Transmitter Serial Data (XMT) ..... 6
10. External Inputs (X10 Through X17) ..... 6
11. External Outputs ( $\overline{\mathrm{XOO}}$ Through X07) ..... 6
B. Interrupt Processing Operation ..... 6
12. Interrupt Register ..... 7
13. Mask Register ..... 7
14. Priority Gating ..... 7
15. Interrupt Servicing ..... 7
C. Interval Timer Operation ..... 7.
D. Serial Communication Operation ..... 8
16. Serial Data Receiver ..... 8
17. Serial Data Transmitter ..... 9
18. UART Accuracy ..... 9
E. Function Addressing ..... $\cdot 9$
19. Read Receiver Buffer ..... 11
20. Read External Inputs ..... 11
21. Read Interrupt Address ..... 11
22. Read TMS 5501 Status ..... 11
23. Issue Discrete Commands ..... 12
24. Load Rate Register ..... 12
25. Load-Transmitter Buffer ..... 13
26. Load Output Port ..... 13
27. Load Mask Register ..... 13
28. Load Timer ..... 13
III. USING THE TMS 5501 ..... 13
A. Initialization ..... 13
B. Interrupt Service ..... 13
C. Interrupt Expansion ..... 14
D. Serial Communications ..... 15
E. Design Considerations ..... 16
29. Clock Frequency ..... 16
30. WAIT States ..... 16
31. Halt ..... 16
32. I/O Addressing ..... 16
IV. TMS 5501 APPLICATIONS ..... 18

## LIST OF ILLUSTRATIONS

Figure Title Page

1. TMS 5501 Block Diagram ..... 4
2. TMS 8080A/TMS 5501 Interface ..... 5
3. I/O Interrupt Masking and Priority ..... 7
4. Receive Character Timing ..... 8
5. Receiver Flow Chart ..... 8
6. Transmit Data Format ..... 9
7. Serial Data Transmitter Flow Chart ..... 11
8. Data Bus Assignments for TMS 5501 Status ..... 11
9. Discrete Command Format ..... 12
10. Data Bus Assignments for Rate Commands ..... 13
11. Sample TMS 5501 Initialization Routine ..... 14
12. Example of Interrupt-Driven Routine ..... 14
13. Example of Polling Routine ..... 14
14. Interrupt Expansion for TMS 5501s ..... 14
15. Example Memory Map for Multiple TMS 5501 System ..... 15
16. Transmission Format for Five-Level Code ..... 16
17. Example UART Control Routine ..... 16
18. Sequential Controller Using TMS 5501 With Slow Memory ..... 17
LIST OF TABLES
Table
Title
Page
I. TMS 5501 Power Supply Requirements ..... 5
II. Command Address Decoding ..... 6
III. Read/Write Function Decoding ..... 6
IV. RST Instructions ..... 7
V. TMS 5501 Receiver Accuracy ..... 10
VI. TMS 5501 Transmitter Accuracy ..... 10
VII. Interrupt Priorities for Expanded System ..... 15
VIII. TMS 5501 I/O Addressing ..... 18

# TMS 5501 I/O CONROLLER IN TMS 8080A $\mu$ P SYSTEMS 

The Engineering Staff of<br>Texas Instruments Incorporated MOS Houston

## I. INTRODUCTION

The TMS 5501 multifunction input/output controller is designed for use in TMS 8080A microprocessor systems. The TMS 5501 performs interrupt processing, parallel data input/output, asynchronous serial data input/output, and multiple event timing. The TMS 5501 can significantly reduce the system package count and cost.

This note describes the general operation of the TMS 5501 and the software necessary for its control. Examples of hardware configurations and software routines are included as a guide for the designer.

The reader is assumed to be familiar with the TMS 8080A architecture and instruction set. The "TMS 8080A Microprocessor Data Book" and the "TMS 5501 Multifunction Input/Output Controller Data Book" provide detailed descriptions of timing, signal sequences, and device interactions.

## II. TMS 5501 OPERATION

The TMS 5501 is fabricated with the same N -channel silicon-gate process as the TMS 8080A and has compatible timing, signal levels, and power supply requirements. Figure 1 is a block diagram of the TMS 5501.

The I/O section contains an eight-bit input port and an eight-bit latched output port. The inputs and outputs are TTL compatible.

The timer section contains five programmable interval timers which provide time intervals from 64 microseconds to 16.32 milliseconds with a 2 -megahertz system clock.

The communication section contains a universal asynchronous receiver and transmitter (UART) for serial data transfers with user peripherals. The TMS 5501 contains a programmable baud rate generator based on the 2-megahertz system clock for the selection of the serial transfer rate.

The TMS 5501 interrupt control processor provides the TMS 8080A with external interval timer, and


Figure 1. TMS 5501 Block Diagram
communication interface interrupts. The interrupt control processor provides programmable interrupt masking, interrupt level prioritizing, and generation of the interrupt service address. The TMS 5501 and the TMS 8080A data transfers are through the TMS 8080A data bus and are controlled by the control, address, and interrupt lines. The TMS 8080A addresses the TMS 5501 control registers to:

- read the receiver buffer .
- read the input port
- read the interrupt address
- read the TMS 5501 status
- issue discrete commands
- load the baud rate register
- load the transmitter register
- load the output port
- load the mask register
- load an interval timer.

The commands are generated by executing memory reference instructions (such as MOV) to the addressed register.

## A. TMS 5501 INTERFACE SIGNALS

The TMS 5501 has TMS 8080A compatible timing, signal levels, and power supply requirements. The TMS 5501 directly interfaces to the TMS 8080A data bus for status and data transfers as shown in Figure 2.


Figure 2. TMS 8080A/TMS 5501 Interface
The TMS 5501 does not use the TMS 8080A DBIN and $\overline{\mathrm{WR}}$ control signals because of pin-out limitations. The TMS 8080A status word is used by the TMS 5501 to control the direction of the data transfers (see SYNC).

The TMS 5501 and the TMS 8080A signal levels are compatible. For systems requiring a small number of memory and I/O circuits, the TMS 8080A can be directly connected to the other circuits such as the TMS 5501. Larger systems may require buffer circuits between the TMS 8080A and the memory and $1 / 0$. The additional buffer circuits introduce propagation delays which will affect system timing.

## 1. Power

The TMS 5501 uses the same power supply voltages as the TMS 8080A (see Table I).

Table I. TMS 5501 Power Supply Requirements


## 2. Clocks

The TMS 5501 two-phase clock is identical to the TMS 8080A clock. The clock inputs are not TTL compatible and require high level drivers. Since the clock inputs of the TMS 8080A and the TMS 5501 are driven in parallel, the clock input capacitances for both devices must be summed to determine the AC loading on the clock lines.

The TMS 5501 derives the interval timer clock and the serial communication clock from the input clock (Sections II-C and D).

## 3. Chip Enable (CE)

When CE is low, the TMS 5501 address decoding is inhibited, which prevents execution of any of the TMS 5501 commands. CE is usually fully or partially decoded from the upper address bits which are not directly input to the TMS 5501. For a minimum system, it may be convenient to connect CE to the most-significant address bit (A15) and to select the system memory only when A15 is low. The TMS 5501 is then selected whenever the upper half of memory is selected. Since the address word is not fully decoded, the TMS 5501 is actually enabled by many unique addresses. If more than one TMS 5501 is used in the system, then the next most-significant bits of the address can be decoded as required. Although this technique limits the size of memory to 32,768 bytes, few applications actually require the full 65,536 byte memory addressing capability of the TMS 8080A.

Since the TMS 5501 is addressed as memory, CE must be low when interrupt acknowledge occurs or improper operation will occur. Since the TMS 8080A acknowledges interrupts during an instruction fetch cycle, this limitation should not affect system operation.

## 4. SYNC

The SYNC signal is output by the TMS 8080A at the beginning of the machine cycle. While SYNC is high, the TMS 8080A data bus contains the machine status which is used externally to determine the type of machine cycle to occur.

The TMS 5501 monitors the data bus during SYNC for bit D0 (INTA, Interrupt Acknowledge) and bit DI ( $\overline{\mathrm{WO}}$, Read/Write). If D0 is high, then the TMS 8080A is acknowledging an interrupt. If the TMS 5501 has previously received an interrupt acknowledge enable command from the CPU (Section II-E), the RST instruction is transferred by the TMS 5501 to the data bus,

If bit D0 is low and CE is low, then the TMS 5501 will not be affected by the machine cycle. If bit D0 is low and CE is high, then the machine cycle will be either a read or a write data transfer between the TMS 8080A and the TMS 5501.

## 5. Address Bus (A0 Through A3)

The TMS 5501 operates as a memory device for the TMS 8080A. The TMS 5501 functions are initiated through a four-bit address bus. The TMS 5501, when CE is high, decodes the address bus to determine the command function to be performed.

As shown by Table II, address bits A2 and A3 determine whether the data transfer will be from the TMS 8080A to the TMS 5501 (issue or load) or from the TMS 5501 to the TMS 8080A (read). A2 and A3 are both low for read transfers. An attempt to write data to the TMS 5501 when a read function is addressed will not cause
the TMS 5501 to output data. The contents of the TMS 5501 buffers, however, are affected just as if a normal read transter had occurred. For example, if the TMS 8080A addresses the TMS 5501 read receiver buffer function during a memory write cycle, the TMS 550] will not output the receiver buffer contents on the data bus, but will clear the receiver buffer loaded flag. An attempt to read data from a write buffer (either A2 or A3 or both are high) will input invalid data both to the TMS 8080A and the addressed TMS 5501 buffer (see Table III).

Table II. Command Address Decoding

| OFFSET (HEX) |  |  |  |  | WHEN CHIP ENABLE IS HIGH |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | A3 | A2 | A1 | A0 | COMMAND | FUNCTION |
| $\phi$ | $L$ | L | L | L | Read receiver buffer | $\mathrm{RBn} \rightarrow \mathrm{Dn}$ |
| 1 | $L$ | L | 1. | H | Read external inputs | $\mathrm{XIn} \rightarrow \mathrm{D}$ |
| 2 | L | L | H | L | Read interrupt address | RST $\rightarrow$ Dn |
| 3 | $L$ | L | H | H | Read TMS 5501 status | (Status) $\rightarrow$ Dn |
| 4 | L | $\mathrm{H}^{+}$ | L | L | Issue discrete commands |  |
| 5 | L | H | L | H | Load rate register |  |
| 6 | L | H | H | L | Load transmitter buffer | $\mathrm{Dn} \rightarrow \mathrm{TBn}$ |
| 7 | L | H | H | H | Load output port | $\mathrm{Dn}_{n} \rightarrow \overline{\mathrm{XO}} \mathrm{O}$ |
| 8 | H | $L$ | L | L | Load mask register | Dn $\rightarrow$ MRn |
| 9 | H | $L$ | L | H | Load interval timer 1 | Dn $\rightarrow$ Timer 1 |
| A | H | $L$ | H | L | Load interval timer 2 * | $\mathrm{Dn} \rightarrow$ Timer 2 |
| B | H | L | H | H | Load interval timer 3 | Dn $\rightarrow$ Timer 3 |
| C | H | H | L | L | Load interval timer 4 | $\mathrm{Dn} \rightarrow$ Timer 4 |
| D | H | H | L | H | Load interval timer 5 | $\mathrm{Dn} \rightarrow$ Timer 5 |
| E | H | H | H | L | No function |  |
| $F$ | H | H | H | H | No function |  |

$R B n \geq$ Receiver buffer bit $n$ Dn $\#$ Data bus I/O terminal $n$ XIn $\equiv$ External input terminal $n$ RST $\equiv 11\left(\mid A_{2}\right)\left(\mid A_{1}\right)\left(\mid A_{0}\right) 111$
$T B n \equiv$ Transmit buffer bit $n$
$\overline{X O n} \equiv$ Output register bit $n$ $M R n \equiv$ Mask register bit $n$

Table III. Read/Write Function Decoding

| CE | WO $^{*}$ | A3 | A2 | FUNCTION |
| :--- | :--- | :--- | :--- | :--- | :--- |
| L | X | X | X | None |
| H | H | L | L | Read |
| H | H | H | X | Invalid Read from Write Buffer |
| H | H | X | H |  |
| H | L | H | X | Write |
| H | L | X | H | Write |
| H | L | L | L | Invalid Write to Read Buffer |

X - Don't Care
*Status Bit 1 (D1)

## 6. External Internupt (SENS)

The SENS input interfaces an external interrupt to the TMS 5501. A low-to-high transition at the SENS input sets a bit in the TMS 5501 interrupt register which, if enabled, generates an interrupt to the TMS 8080A.

## 7. Interrupt (INT)

The INT output is high when the TMS 5501 has sensed an enabled interrupt from an interval timer, the

UART, or the SENS input. INT can be connected to the TMS 8080A INT input to interrupt the CPU.

## 8. Receiver Serial Data ( $\overline{\mathrm{RCV}}$ )

Serial data is input to the TMS 5501 through $\overline{\mathrm{RCV}}$. Between asynchronous input characters, $\overline{\mathrm{RCV}}$ should be held high. A transition from high to low activates the TMS 5501 recciver circuitry which converts the serial input to parallel format, loads the input character into the receiver buffer, and sets the appropriate bits in the status buffer.

## 9. Transmitter Serial Data (XMT)

Serial data is output by the TMS 5501 through XMT. When the TMS 5501 is not outputting data, XMT is high. A high-to-low transition on XMT following an idle period indicates that the TMS 5501 is outputting a serial character.

## 10. External Inputs (XI0 Through XI7)

The eight external inputs are gated by the TMS 5501 to the TMS 8080A data bus when the read external inputs function is addressed. The inputs are not complemented; a low (high) external input is gated to the CPU as a low (high) data bit. The TMS 5501 can be programmed to use XI7 as an additional external interrupt. When XI7 is used as an interrupt, interval time number 5 is not used. External pull-up resistors are necessary for many TTL outputs to reach the minimum high-level input voltage of 3.3 V for the TMS 5501.

## 11. External Outputs ( $\overline{\mathrm{XO0}}$ Through $\overline{\mathrm{XO7}}$ )

The eight external outputs are driven by the output register. Each output bit is the complement of the bit loaded into the TMS 5501 output register by the TMS 8080A. If the output register is loaded with a low (high) bit, then the corresponding output bit is high (low). The external outputs change only when the load output register function is addressed. The outputs are TTL compatible and are capable of driving a standard TTL load.

## B. INTERRUPT PROCESSING OPERATION

The TMS 5501 generates and stores a total of eight interrupts. Four of the interrupts originate with four interval timers, two originate with the serial transmitter and receiver, one originates from the external input (SENS), and the final interrupt originates either from the fifth interval timer or a second external interrupt (XI7).

The interrupts from the interval timers are generated at the end of the programmed time interval (Section II-C). The interrupt from the serial transmitter is generated when the TMS 5501 has finished sending a character and is ready to accept a new character. The interrupt from the serial receiver is generated when a character has been input (Section II-D). The external interrupts are generated by a low-to-high transition on the external inputs (SENS, XI7). The TMS 5501 is programmed to select either the fifth timer interrupt or the second external interrupt (Section II-E).

## 1. Interrupt Register

The TMS 5501 interrupt register stores cach interrupt until the interrupt has been serviced. A discrete reset command from the TMS 8080A resets all interrupts except the serial transmitter interrupt which is set (Section II-E). The interrupt register is eight bits long with one bit for each interrupt. A stored interrupt is a high bit.

## 2. Mask Register

The TMS 5501 interrupt mask register inhibits undesired interrupts. The mask register contains a separate bit for each of the eight interrupts and is loaded by the TMS 8080A (Section II-E). The contents of the interrupt register and the mask register are ANDed and then input to the TMS 5501 priority gating logic. Thus, a low bit in the mask register will inhibit the corresponding interrupt, while a high bit will enable the interrupt.

An interrupt is stored in the interrupt register independently of the state of the corresponding bit in the mask register. If the interrupt is generated while the mask bit is low, the interrupt is stored but not enabled. If. the interrupt is still stored (no reset command) when the mask bit is set high, then the newly enabled interrupt is input to the priority gating logic.

## 3. Priority Gating

The TMS 5501 prioritizes the enabled interrupts in the following order:

| 1st $-\quad$ Interval Timer 1 |  |
| :--- | :--- |
| 2nd $-\quad$ Interval Timer 2 |  |
| 3rd $-\quad$ External Sensor |  |
| 4th $-\quad$ Interval Timer 3 |  |
| 5th $-\quad$ Receiver Buffer Loaded |  |
| 6th $-\quad$ Transmitter Buffer Emptied |  |
| 7th $-\quad$ Interval Timer 4 |  |
| 8th $-\quad$ Interval Timer 5 or |  |
|  | External Input (XI 7) |

The TMS 5501 interrupt address is then generated for the highest priority enabled interrupt (Section II-E). Interrupt masking and priority gating are shown in Figure 3.

## 4. Interrupt Servicing

The TMS 5501 provides two methods of servicing interrupts: interrupt-driven or polled. In the interruptdriven system, the TMS 5501 INT output is connected directly to the TMS 8080A INT input. In the polled system, the TMS 8080A must read the TMS 5501 status to determine the status of the TMS 5501 interrupt line (Section III-A). A multiple TMS 5501 system could employ both of these methods (Section III-B).

In the interrupt-driven system, the TMS 5501 INT output goes high when an enabled interrupt is generated. The INT output stays high until all enabled interrupts have been serviced. If the TMS 8080A is enabled to accept the interrupt, it sets the INTA (interrupt acknowledge) status bit (D0) high during SYNC of the next instruction fetch machine cycle. If the TMS 5501 has previously been


Figure 3. I/O Interrupt Masking and Priority
enabled to respond to INTA by a discrete command function (Section II-E), it will jam the RST instruction onto the data bus. The RST byte is generated by the TMS 5501 priority logic. The highest priority enabled high interrupt bit in the interrupt register is then reset. If the TMS 5501 is not enabled to respond to INTA, it does not output the RST instruction, and the interrupt register is not affected. RST instructions are listed in Table IV.

The polied interrupt system is described in Section III-X.B.

Table IV. RST Instructions


## C. INTERVAL TIMER OPERATION

The TMS 5501 has five interval timers, each of which can be addressed by the TMS 8080A. The timers are eight-bits long and can be programmed for intervals from 64 microseconds to 16.32 milliseconds.

The TMS 8080A loads an interval counter by addressing one of the five load interval timer command functions and outputting an eight-bit count value ( 0 to 255). The counter begins the count interval immediately after it is loaded. At the end of the interval, the corresponding bit in the interrupt register is set, and the counter is inhibited until a new count is loaded.

The count clock for the interval timers is derived by dividing the TMS 5501 input clock by 128. For the nominal 2 MHz input clock, the clock resolution is 64 microseconds. The total count interval is then the product of the loaded count and the count resolution. Thus, the maximum count interval is 255 X 64 microseconds $=16.32$ milliseconds.

Since the count clock and the loading of the interval count are asynchronous, the accuracy of the timed interval is plus 0 , minus 64 microseconds.

Loading of a zero count generates an immediate interrupt and inhibits the counter. Loading a new count while the timer is still counting a previous interval nullifies the old count and initiates a new interval.

## D. SERIAL COMMUNICATION OPERATION

The TMS 5501 contains a UART for communicating with user peripherals. The TMS 5501 generates a common receive/transmit clock from the 2 -megahertz system clock. The UART provides serial-to-parallel/parallel-to-serial data format conversion, buffers transmit and receive data, and generates interrupts to synchronize the CPU with the serial data communication link.

## 1. Serial Data Receiver

The function of the serial data receiver is to synchronize with the incoming serial data at the selected baud rate and to provide bit-to-bit timing for input to the 8 -bit character buffer. The serial data receiver has a resettable counter and decoding logic for determining half-bit and full-bit times as shown in Figure 4. When a high-to-low transition is detected on the serial input data line and the counter is in the search (start bit) mode, the counter is incremented until the middle of the start bit is reached. If
A- high to low transition is detected and half ait cohinter is enableo. B. CENTER OF START BIT FOUND ANO FULL BIT COUNTER IS ENABLFD
c- center of each data bit found and shaftedinto the serial receive registfr.
0- FON wBit CODE, CHECK FDR VALIO STOP RIT GENERATE INTERRUPT. AND TRAASFER CHARACTER TO RECEIVE BUFFLR REGISTEI.
O- FOR 11. Bit CODE. CHECX FOR IWO VALID STOP BITS GENERATE INTERRIJPI, AHO TRANSFER CHAR
ACTER TO RECEIVE BUFFER REGISTER.

|  |  | COUNTS AT 125 k kit |  | RESOLumon. |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| baud rate | BIT PERIOD (ms). | HALF BIt | Evelair |  |  |
| 110 | 9.08 | 568 | 1136 | $09^{2}$ |  |
| 150 | 6.67 | 416 | ${ }^{83}$ | 0.15 . |  |
| 300 | 3.33 | 208 | 416 | $0.25 \%$, | , |
| 1200 | 0.833 | 52 | 104 | 18 |  |
| 2400 | 0.416 | 26 | 52 | 7x |  |
| 4800 | 0.208 | ${ }^{13}$ | ${ }^{26}$ | 4 | - |
| 9600 | 0.104 | 1 | 33 | ${ }^{\circ}$ |  | clock (int., 21 .

the serial input data line should return to a high during this interval, the counter resets and starts over again. After the start bit is detected, the counter waits full-bit times to determine the center of all succeeding bits.

When the middle of the start bit is detected, the start bit detected flag is set. When the middle of the first data bit is detected, the full bit detected flag is set. Both of these flags are reset when the (last) stop bit is detected. These flags may be read as I/O status and are intended for test purposes.

When a character has been received, it is transferred from the receiver (serial) register to the receive buffer register from which it is gated to the data bus when the read receive buffer function is addressed by the TMS 8080A.

When the receive buffer register is loaded, the receive buffer loaded flag is set, indicating that a new received character is ready, and an interrupt is generated. This flag is available as a status bit and is reset when the read receive buffer function is addressed.

If a new character is received before the previous character is read, the previous character is lost and the overrun flag is set. The overrun flag may be read as I/O status and is reset when the read TMS 5501 status function is addressed.

When the last stop bit of a character is received, a check is made for the validity of the stop bit(s). If one (or both) of the stop bits is incorrect, the framing error flag is set. If the stop bit(s) is (are) correct, the framing error flag is reset. The framing error flag may be read as I/O status.

Figure 5 is a flow chart describing the serial data receiver.


Figure 5. Receiver Flow Chart

## 2. Serial Data Transmitter

The function of the serial data transmitter is to accept a character from data bus and transmit the character serially at the selected baud rate. Figure 6 shows the data formats for 10 -bit and 11 -bit codes.


Figure 6. Transmit Data Format
Data transmission is handled automatically once a character from the TMS 8080A has been loaded into the transmit buffer register. If the transmitter is not currently busy, the character in the transmit buffer register is transferred to the serial transmit register and shifted out at the selected baud rate. A start bit is generated before the data character is shifted out, and one or two stop bits (as selected) are generated after the last bit of the data character is shifted out.

Once the transmit buffer register is emptied (contents transferred to the transmit register and transmission is initiated), the buffer register is again ready to be loaded and an interrupt is generạted (if enabled). If the buffer register is loaded while a character transmission is in progress, then the new character is simply held in the buffer register until the current transmission is completed.

The transmit buffer empty flag is available as a status bit. A high bit indicates that the buffer is empty (not loaded) and that a new character may be loaded. This flag is reset when the load transmit buffer function is addressed. The flag is set when a character to be transmitted is transferred from the buffer register to the transmit register or when a RESET discrete command is issued by the TMS 8080A.

When a transmission is completed, the transmit data output remains high until the next transmission is initiated.

## 3. UART Accuracy

Distortion in the UART receiver is the difference between the half-bit sample point and the ideal center of the bit. Distortion in the UART transmitter is the difference between the actual and the ideal center of each transmitted bit relative to the idealleading edge of the start bit. The transmitter distortion, the receiver distortion, and the transmission link distortion can combine under many circumstances to cause the loss of bit synchronization during data reception.

There are four basic causes for the TMS 5501 receiver distortion.

1. The receiver tests for the leading edge of the start bit using a 125 -kilohertz sample clock derived from the 2 -megahertz system clock asynchronous to the ideal sample period. The leading edge of the start bit can be detected as much as one clock period or 8 microseconds after it actually occurs. Since the receiver begins the half-bit count at this point, as shown in Figure 5, the maximum initial distortion is 8 microseconds.
2. The half-bit time using a standard baud rate may not be an exact multiple of the sample clock. The nearest multiple is used and the difference generates the half-bit distortion.
3. The full-bit time may also not be an exact multiple of the sample clock and results in the full-bit distortion term. This term is cumulative for each of the nonstart bits in the character.
4. If the system clock frequency is not exactly 2 megahertz, the receiver half-bit and full-bit times can be larger or smaller than expected.
The maximum recciver distortion is approximated by summing the distortion terms as shown in Table V. The "maximum distortion accepted" term indicates the amount of distortion that can be generated by the transmission link and transmitter without loss of bit synchronization.

The transmitter distortion is similarly produced. Start-bit generation is asynchronous to the sample clock and the leading edge can be transmitted 8 microseconds later than expected. The bit times are again not exact multiples of the internal sample clock, and the approximations generate bit distortions. Finally, the system clock can also drift from 2 megahertz as before. The transmitter distortion terms are summed as shown in Table VI.

The transmission link distortion is dependent upon the specific application and is normally measured experimentally. The sum of the distortion terms should not exceed $50 \%$ of a bit time to avoid false bit sampling.

## E. FUNCTION ADDRESSING

The fourteen command functions are used to control the TMS 5501. The TMS 8080A can issue discrete commands to the TMS 5501, select the serial data transfer rate, load and start the interval timers, load the mask register, load the parallel output byte, load the serial output byte, read the parallel input byte, read the serial input byte, read the I/O status, or read the interrupt service address. The serial data transmitter flow chart is shown in Figure 7.

The TMS 8080A executes a memory read or write instruction to a TMS 5501 address to perform each of these functions. The effective address of each of the TMS 5501 command functions is derived by adding the base address of the TMS 5501 to the offset address (value of A0 through A3 in Table II). For example, a possible TMS 5501 base address is 8000 (HEX). Then the effective address of the load output port function is $8000+0007=8007$ (HEX). If A15 alone is used to select the TMS 5501, the base address is actually any multiple of 16 from 8000 to FFF0 (HEX).

Table V. TMS 5501 Receiver Accuracy

| Baud <br> Rate | ```Bit (1/2 Bit) Period ( }\mu\textrm{s}\mathrm{ )``` | TMS 5501 Bit Timing |  |  |  | Max. TMS 5501 Error ( $\mu \mathrm{s}$ ) (\% Bit) | $\begin{gathered} 0.05 \% \\ \text { Crystal } \\ \text { Error } \\ (\mu \mathrm{s}) \\ (\% \mathrm{Bit}) \end{gathered}$ | Max. <br> Total <br> Error <br> ( $\mu \mathrm{s}$ ) <br> (\% Bit) | Maximum Distortion Accepted (\%) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Counts |  | Half | Full |  |  |  |  |
|  |  | Half Bit | $\begin{gathered} \text { Full } \\ \text { Bit } \end{gathered}$ | Bit Error | Bit <br> Error |  |  |  |  |
| $\begin{gathered} 110 \\ (2 \text { stop bits) } \end{gathered}$ | $\begin{gathered} 9091.0 \\ (4545.5) \end{gathered}$ | 568 | 1136 | $\begin{gathered} 4544 \\ (\Delta=-1.5) \end{gathered}$ | $\begin{gathered} 9088 \\ (\Delta=-3.0) \end{gathered}$ | $\begin{gathered} -39.5 \\ (0.435 \%) \end{gathered}$ | $\begin{gathered} -47.7 \\ (0.525 \%) \end{gathered}$ | $\begin{gathered} -87.2 \\ (0.96 \%) \end{gathered}$ | 49.0 |
| 150 | $\begin{gathered} 6666.7 \\ (3333.3) \end{gathered}$ | 41.6 | 832 | $\begin{gathered} 3328 \\ (\Delta=-5.3) \end{gathered}$ | $\begin{gathered} 6656 \\ (\Delta=-10.7) \end{gathered}$ | $\begin{aligned} & -109.6 \\ & (1.64 \%) \end{aligned}$ | $\begin{gathered} -31.6 \\ (0.475 \%) \end{gathered}$ | $\begin{aligned} & -141.2 \\ & (2.12 \%) \end{aligned}$ | 47.8 |
| 300 | $\begin{gathered} 3333.3 \\ (1666.7) \end{gathered}$ | 208 | 416 | $\begin{gathered} 1664 \\ (\Delta=-2.7) \end{gathered}$ | $\begin{gathered} 3328 \\ (\Delta=-5.3) \end{gathered}$ | $\begin{gathered} -58.4 \\ (1.75 \%) \end{gathered}$ | $\begin{gathered} -15.8 \\ (0.475 \%) \end{gathered}$ | $\begin{gathered} -74.2 \\ (2.23 \%) \end{gathered}$ | 47.7 |
| 1200 | $\begin{gathered} 833.3 \\ (416.7) \end{gathered}$ | 52 | 104 | $\begin{gathered} 416 \\ (\Delta=-0.7) \end{gathered}$ | $\begin{gathered} 832 \\ (\Delta=-1.3) \end{gathered}$ | $\begin{gathered} -20.4 \\ (2.45 \%) \end{gathered}$ | $\begin{gathered} -3.96 \\ (0.475 \%) \end{gathered}$ | $\begin{gathered} -24.4 \\ (2.93 \%) \end{gathered}$ | 47.0 |
| 2400 | $\begin{gathered} 416.7 \\ (208.4) \end{gathered}$ | 26 | 52 | $\begin{gathered} 208 \\ (\Delta=-0.4) \end{gathered}$ | $\begin{gathered} 416 \\ (\Delta=-0.7) \end{gathered}$ | $\begin{gathered} -14.7 \\ (3.53 \%) \end{gathered}$ | $\begin{gathered} -1.98 \\ (0.475 \%) \end{gathered}$ | $\begin{gathered} -16.7 \\ (4.02 \%) \end{gathered}$ | 46.0 |
| 4800 | $\begin{gathered} 208.4 \\ (104.2) \end{gathered}$ | 13 | 26 | $\begin{gathered} 104 \\ (\Delta=-0.2) \end{gathered}$ | $\begin{gathered} 208 \\ (\Delta=-0.4) \end{gathered}$ | $\begin{gathered} -11.8 \\ (5.67 \%) \end{gathered}$ | $\begin{gathered} -0.988 \\ (0.475 \%) \end{gathered}$ | $\begin{gathered} -12.8 \\ (6.14 \%) \end{gathered}$ | 43.8 |
| 9600 | $\begin{gathered} 104.2 \\ (52.1) \end{gathered}$ | 7 | 13 | $\begin{gathered} 56 \\ \{\Delta=+3.9) \end{gathered}$ | $\begin{gathered} 104 \\ (\Delta=-0.2) \end{gathered}$ | $\begin{gathered} -5.9 \\ (5.67 \%) \end{gathered}$ | $\begin{array}{r} -0.496 \\ (0.48 \%) \end{array}$ | $\begin{gathered} -6.40 \\ (6.14 \%) \end{gathered}$ | 43.8 |

Note: TMS 5501 error consists of:

1. Initial $8 \mu$ s error (asyrichronous clock)
2. Half-bit count error
3. Full-bit count error

For overall error calculation, a $0.05 \%$ crystal is utilized.

Table VI. TMS 5501 Transmitter Accuracy

| Baud Rate | Bit <br> Period ( $\mu \mathrm{s}$ ) | $8 \mu \mathrm{~s}$ <br> Counts | TMS 5501 <br> Count <br> Time <br> ( $\mu \mathrm{s}$ ) <br> Error | Max. <br> TMS 5501 <br> Error ( $\mu \mathrm{s}$ ) <br> TMS 5501 <br> Distortion | 0.05\% <br> Crystal <br> Error <br> ( $\mu \mathrm{s}$ ) <br> Clock <br> Distortion | Max. <br> Total <br> Error ( $\mu \mathrm{s}$ ) <br> Total XMT <br> Distortion |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} 110 \\ \text { (2 stop bits) } \end{gathered}$ | 9091.0 | 1136 | $\begin{gathered} 9088 \\ (\Delta=-3.0) \end{gathered}$ | $\begin{gathered} -41 \\ (0.45 \%) \end{gathered}$ | $\begin{gathered} -50 \\ (0.55 \%) \end{gathered}$ | $\begin{gathered} -91 \\ (1.0 \%) \end{gathered}$ |
| 150 | 6666.7 | 833 | $\begin{gathered} 6664 \\ (\Delta=-2.7) \end{gathered}$ | $\begin{gathered} -35 \\ (0.53 \%) \end{gathered}$ | $\begin{gathered} -33.32 \\ (0.5 \%) \end{gathered}$ | $\begin{aligned} & -68.32 \\ & (1.03 \%) \end{aligned}$ |
| 300 | 3333.3 | 417 | $\begin{gathered} 3336 \\ (\Delta=+2.7) \end{gathered}$ | $\begin{gathered} +27 \\ (0.81 \%) \end{gathered}$ | $\begin{aligned} & +16.68 \\ & (0.5 \%) \end{aligned}$ | $\begin{aligned} & +43.68 \\ & (1.31 \%) \end{aligned}$ |
| 1200 | 833.3 | 104 | $\begin{gathered} 832 \\ (\Delta=-1.3) \end{gathered}$ | $\begin{gathered} -21 \\ (2.52 \%) \end{gathered}$ | $\begin{aligned} & -4.16 \\ & (0.5 \%) \end{aligned}$ | $\begin{aligned} & -25.16 \\ & (2.54 \%) \end{aligned}$ |
| 2400 | 416.7 | 52 | $\begin{gathered} 416 \\ (\Delta=-0.7) \end{gathered}$ | $\begin{gathered} -15 \\ (3.6 \%) \end{gathered}$ | $\begin{aligned} & -2.08 \\ & (0.5 \%) \end{aligned}$ | $\begin{gathered} -17.08 \\ (4.1 \%) \end{gathered}$ |
| 4800 | 208.4 | 26 | $\begin{gathered} 208 \\ (\Delta=-0.4) . \end{gathered}$ | $\begin{gathered} -12 \\ (5.76 \%) \end{gathered}$ | $\begin{aligned} & -1.04 \\ & (0.5 \%) \end{aligned}$ | $\begin{aligned} & -13.04 \\ & (6.26 \%) \end{aligned}$ |
| 9600 | 104.2 | 13 | $\begin{gathered} 104 \\ (\Delta=-0.2) \end{gathered}$ | $\begin{gathered} -10 \\ (9.6 \%) \end{gathered}$ | $\begin{array}{r} -0.52 \\ (0.5 \%) \end{array}$ | $\begin{aligned} & -10.52 \\ & (10.1 \%) \end{aligned}$ |

Note: TMS 5501 error consists of:

1. Initial $8 \mu \mathrm{~s}$ error (asynchronous clock)
2. Full-bit count error

For overall error calculation, a $0.05 \%$ crystal is utilized.


Figure 7. Serial Data Transmitter Flow Chart
The redundancy of addresses is the result of not fully decoding the address. It is convenient, however, to select an arbitrary address such as 8000 (HEX) as the base address.

The TMS 8080A uses memory reference instructions to address and to transfer data to the command functions. For example, the following instruction sequence forces the TMS 5501 output bit $\overline{\mathrm{XO7}}$ to be high and bits $\overline{\mathrm{XOO-6}}$ to be low. The routine then reads the input port into the accumulator.

| MVI | A, 7FH |
| :--- | :--- |
| STA | 8007 H |
| LDA | 8001 H |
| $:$ |  |

The TMS 5501 output bits are the complements of the bits loaded into the output port. Therefore, when 7 F (HEX) is loaded into the output port, 80 (HEX) is actually output by the TMS 5501 on $\overline{\mathrm{XOO}-7}$. The new value in the accumulator is equal to the input data port value since the input port bits are not complemented by the TMS 5501.

The following descriptions of the TMS 5501 command functions assume that TMS 8080A read instructions are used to address the read functions and write instructions are used to address issue or load functions.

## 1. Read Receiver Buffer

Offset $\phi$
Addressing the read receiver buffer function gates the contents of the serial receive buffer onto the data bus and clears the receiver buffer loaded flag in the status buffer.
2. Read External Inputs

Offset 1
Addressing the read external inputs function gates the true values of the eight external input lines to the data bus. No status bits are affected.

## 3. Read Interrupt Address

Offset 2
Addressing the read interrupt address function gates to the data bus the encoded address of the highest priority interrupt currently pending. The corresponding bit in the interrupt register is reset following completion of the read operation.

If no interrupt is pending when this function is addressed, a false interrupt address will be read. The false interrupt address is identical to the interrupt 7 encoded address.

Addressing this function produces the same action as does the TMS 8080A interrupt acknowledge except that the function is independent of the interrupt acknowledge enable and the RST op code is placed on the data bus as an operand rather than as an instruction.

## 4. Read TMS 5501 Status

Offset 3
Addressing the read TMS 5501 status function gates the various status conditions of the TMS 5501 onto the data bus. The status conditions, available as indicated in Figure 8, are described in the following paragraphs.


Figure 8. Data Bus Assignments for TMS 5501 Status

## Bit 0, Framing Error

A high in bit 0 indicates that a framing error was detected on the last character reccived (either one or both stop bits were in error). The framing error flag is updated at the end of each character. Bit 0 of the TMS 5501 status will remain high until the next valid character is received.

## Bit 1, Overrun Error

A high in bit 1 indicates that a new character was loaded into the receiver buffer before a previous character was read out. The overrun error flag is cleared each time the read TMS $5501 \mathrm{I} / \mathrm{O}$ status function is addressed or a reset command is issued.

## Bit 2, Serial Received Data

Bit 2 monitors the receiver serial data input line. This line is provided as a status input for use in detecting a break and for test purposes. Bit 2 is normally high when no data is being received.

## Bit 3, Receiver Buffer Loaded

A high in bit 3 indicates that the receiver buffer is loaded with a new character. The receiver buffer loaded flag remains high until the read receiver buffer function is
addressed, at which time the flag is cleared. The reset functịon also clears this flag.

## Bit 4, Transmitter Buffer Empty

A high in bit 4 indicates that the transmitter buffer register is empty and ready to accept a character. Note, however, that the serial transmitter register may be in the process of shifting out a character. The reset function sets the transmitter buffer empty flag high.

## Bit 5, Interrupt Pending

A high in bit 5 indicates that one or more of the interrupt conditions has occurred and the corresponding interrupt is enabled. This bit is the status of the interrupt signal INT.

## Bit 6, Full Bit Detected

A high in bit 6 indicates that the first data bit of a receive data character has been detected. This bit remains high until the entire character has been received or until a reset is issued and is provided for test purposes.

## Bit 7, Start Bit Detected

A high in bit 7 indicates that the start bit of an incoming data character has been detected. This bit remains high until the entire character has been received or until a reset is issued and is provided for test purposes.

## 5. Issue Discrete Commands

Offset 4
Addressing the discrete command function causes the TMS 5501 to interpret the data bus information according to the following descriptions. See Figure 9 for the discrete command format. Bits 1 through 5 are latched until a different discrete command is received.

-Figure 9. Discrete Command Format

## Bit 0, Reset

A high in bit 0 will cause the following:

1. The receiver buffer and register are cleared to the search mode including the receiver buffer loaded flag, the start bit detected flag, the full bit detected flag, and the overrun error flag. The receiver buffer is not cleared and will contain the last character received.
2. The transmitter data output is set high (marking). The transmitter buffer empty flag is set high indicating that the transmitter buffer is ready to accept a character from the TMS 8080A.
3. The interrupt register is cleared except for the bit corresponding to the transmitter buffer interrupt, which is set high.
4. The interval timers are inhibited.

A low in bit 0 causes no action. The reset function has no affect on the output port, the external inputs, interrupt acknowledge enable, the mask register, the rate register, the transmitter register, or the transmitter buffer.

## Bit 1, Break

A low in bit 1 causes the transmitter data output to be reset low (spacing).

If bit 0 and bit 1 are both high, the reset function will override.

## Bit 2, Interrupt 7 Select

Interrupt 7 may be generated either by a low-to-high transition of external input 7 or by interval timer 5 .

A high in bit 2 selects the interrupt 7 source to be the transition of external input 7. A low in bit 2 selects the interrupt 7 source to be interval timer 5.

## Bit 3, Interrupt Acknowledge Enable

The TMS 5501 decodes data bus (CPU status) bit 0 at SYNC of each machine cycle to determine if an interrupt acknowledge is being issued.

A high in bit 3 enables the TMS 5501 to accept the interrupt acknowledge decode. A low in bit 3 causes the TMS 5501 to ignore the interrupt acknowledge decode.

## Bit 4, Test Bit

When test bit 4 is low, the interval timer clock and serial communication clock operate as described in Sections II-C and D. A high in bit 4 causes both clocks to run eight times faster than normal. Bit 4 should be low for normal operation. When bit 4 is high the TMS 5501 can be used for high-speed-data transfers at rates up to 76.8 kilobaud.

## Bit 5, Test Bit

Test bit 5 should be low for proper operation. When test bit 5 is high, the TMS 5501 INT output is not the output of the interrupt priority logic but the buffered output of the logic which derives the interval timer and serial communication clocks from the TMS 5501 input clock. Therefore, when bit 5 is high, the INT output is a clock with a frequency equal to the system clock frequency divided by 128 (test bit 4 low) or by 16 (test bit 4 high). If the TMS 5501 INT is not needed as an interrupt, then a high bit 5 permits the INT output to be used to derive a TTL compatible clock for the system.

## 6. Load Rate Register

Offset 5
Addressing the load rate register function causes the TMS 5501 to load the rate register from the data bus and interpret the data bits (see Figure 10) as follows.


Figure 10. Data Bus Assignments for Rate Commands

## Bits 0 Through 6, Rate Select

The rate select bits (bits 0 through 6) are mutually exclusive, i.e., only one bit may be high. A high in bits 0 through 6 will select the baud rate for both the transmitter and receiver circuitry as defined below and in Figure 10:

| Bit 0 | 110 baud |
| ---: | ---: |
| Bit 1 | 150 baud |
| Bit 2 | 300 baud |
| Bit 3 | 1200 baud |
| Bit 4 | 2400 baud |
| Bit 5 | 4800 baud |
| Bit 6 | 9600 baud |

If more than one bit is high, the highest rate indicated will result. If bits 0 through 6 are all low, both the receiver and the transmitter circuitry will be inhibited. The nominal baud rates are valid for a 2 -megahertz system clock. A slower system clock will cause proportionally slower baud rates.

## Bit 7, Stop Bits

Bit 7 determines whether one or two stop bits are to be used by both the transmitter and receiver circuitry. A high in bit 7 selects one stop bit. A low in bit 7 selects two stop bits.

## 7. Load-Transmitter Buffer

Offset 6
Addressing the load transmitter buffer function transfers the contents of the data bus into the transmit buffer.

## 8. Load Output Port

Offset 7
Addressing the load output port function transfers the contents of the data bus to the output port. The data is latched and remains on $\overline{\mathrm{XO} \mathrm{0-7}}$ as the complement of the load data until the load output port function is addressed again.

## 9. Load Mask Register

Offset 8
Addressing the load mask register function transfers the contents of the data bus to the interrupt mask register.

## 10. Load Timer

Offsets 9-13
Addressing the load timer functions transfers the contents of the data bus to the appropriate timer and initiates the count interval.

## III. USING THE TMS 5501

The TMS 5501 is a powerful design tool because of the simplicity of its interface to the TMS 8080A and because of its multifunction operation.

This section contains examples of interrupt processing, serial data communications, and design precautions for the TMS 5501.

## A. INITIALIZATION

The TMS 5501 does not have an external reset input and must be initialized under program control. Moreover, the TMS 8080A reset routine and the interrupt service routine for the level 0 interrupt share the same memory location. Because of this ambiguity, the service routine starting at address 0 must determine whether a reset or an interrupt has occurred if the TMS 5501 timer 1 interrupt is used.

Since both a reset and a TMS 5501 level 0 interrupt can occur concurrently, it is not sufficient to check for the presence or absence of the interrupt. The service routine should check for the occurrence of the reset. If a reset has occurred, the TMS 5501 (and the interrupt) will normally be reset by the initialization routine. If a reset has not occurred, the interrupt service routine is then entered.

The reset signal can be stored externally in a flip-flop or latch which can be tested and cleared under program control. The reset signal can also be connected to the TMS 5501 SENS or XI7 inputs. The reset then generates an interrupt. If the reset and the timer 1 interrupt occur simultaneously, then the timer 1 interrupt has precedence. The service routine can then selectively enable the TMS 5501 interrupts to determine if a reset has occurred.

The application requirements must dictate which approach is used. If timer 1 is not required, it can be disabled. Otherwise, the designer should weigh the cost of the added storage element against the use of an interrupt input for the reset. The speed and complexity of the service routine must also be considered.

Once the TMS 8080A reset service routine is entered, the TMS 5501 is initialized by addressing the issue discrete commands function with a high reset bit. The TMS 5501 registers should then be loaded with the required initialization values.

The routine in Figure 11 is an example of a TMS 5501 initialization routine. The TMS 5501 has a base address of 8000 (HEX). The output port is cleared, the timer interrupts are enabled, the 300 baud rate is selected, and interrupt acknowledge is enabled.

## B. INTERRUPT SERVICE

The TMS 8080A has a special one-byte call for interrupt processing. The restart (RST) instruction stores the program counter on the stack and transfers control to one of cight locations. A three-bit field in the RST opcode specifies which location is used. The eight locations are 0 , $8,10,18,20,28,30$, and 38 (HEX). Each location and the seven succeeding bytes are normally used for the reset or an interrupt service routine. If a service routine requires more than eight bytes, then a branch statement can be used to transfer control to another part of program memory.

The TMS 5501 provides two methods of servicing interrupts: interrupt-driven and polled (Section II-B). In an interrupt-driven system, the. TMS 5501 generates the


Figure 11. Sample TMS 5501 Initialization Routine
interrupt and inserts the RST op code on the data bus when the interrupt is acknowledged by the TMS 8080A. Since the TMS 5501 prioritizes interrupts and provides the RST op code, the TMS 8080A quickly begins the service routine of the highest priority interrupt. The routine in Figure 12 is an example of an interrupt service routine for timer 2. The routine increments a memory location (COUNT) and reloads the counter for a new interval. The TMS 5501 base address is 8000 (HEX). The programmed interval is equal to $179 \times 64$ microseconds $=11.46$ milliseconds.

## ADDRESS (HEX)

| 0-7 | : RESET/TIMER I SERVICE ROUTINE |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 8 | TIME 2. | PUSH | PSW | : SAVE ACC + STATUS ON STACK |
| 9 |  | LDA | COUNT | : INCREMENT COUNT |
| 12 |  | INR | A |  |
| 13 |  | JMP | REST | :GO TO REST OF ROUTINE |
| 10-39 | : OTHER SERVICE ROUTINES |  |  |  |
| - | . |  |  |  |
| : |  |  |  |  |
|  | REST: | STA | COUNT |  |
|  |  | MVI | A. 0 B3 3 H | : LOAD COUNTER FOR |
|  |  | STA | 800AH | ; NEW Interval. |
|  |  | PULL | PSW | ; RESTORE ACC + STATUS |
|  |  | EI |  | : ENABLE INTERRUPTS |
|  |  | RET |  | RETURN |

Figure 12. Example of Interrupt-Driven Routine
Some applications may, however, preclude use of the interrupt-driven method. The TMS 8080A tests or polls the TMS 5501 interrupt request under program control. If an interrupt request is present, the TMS 8080A addresses the read interrupt address function to determine the origin of the interrupt. The TMS 5501 interrupt address is identical to the opcode for the RST instruction. The TMS 8080A must decode the interrupt address under program control.

The routine in Figure 13 is an example of an interrupt polling routine. The TMS 8080A tests for an interrupt and reads the interrupt address if an interrupt is present. Sixty-four program bytes beginning at location 40 (HEX) are reserved for the interrupt service routines with eight bytes for each interrupt. The polling routine and one service routine are shown. The service routine pulses the

ADDRESS (HEX)

| 40-47 | : TIMER 1 SERVICE ROUTINE |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 48-4F | : SERIAL RECEIVE SEAVICE ROUTINE |  |  |  |
| 5057 | ; External sensor service routine |  |  |  |
| 58-5F | : TIMER 4 SERVICE ROUTINE |  |  |  |
| 60--67 | : TIMER 2 SERVICE ROUTINE |  |  |  |
| 67-6F | ; SERIAL TRANSMIT SERVICE ROUTINE |  |  |  |
| 70 | TIME 3: | SUB | A | : ALL ZEROES $\rightarrow$ ACCUMULATOR |
| 71 |  | STA | OA006H | ; OUTPUT ONES |
| 74 |  | CMA |  | ; ALL ONES $\rightarrow$ ACCUMULATOR |
| 75 |  | JMP | REST | : GO TO AEST OF ROUTINE |
| 78-7F | ; TIMER 5 OR XI7 SERVICE ROUTINE |  |  |  |
|  |  |  |  |  |
|  | REST: | STA | 0 A 006 H | ; OUTPUT ZEROES |
|  |  | MVI | A,313D | : INTERVAL COUNT - A |
|  |  | STA | OAOOEH | : LOAD TIMER 3 |
|  |  | JMP | POLL | ; RETURN TO START OF POLLING |
|  |  |  |  | ; ROUTINE TOTEST FOR |
|  |  |  |  | $\therefore$ NEXT INTERRUPT |
|  |  |  |  |  |
|  | POLL: | LDA | OA003H | ; READ I/O STATUS. |
|  |  | ANI | 20 H | : TEST INTERRUPT STATUS |
|  |  | JNC | NOINT | ; BRANCH IF NO INTERRUPT |
|  |  | LDA | 0 OA 002 H | ; READ INTERRUPT ADDRESS |
|  |  | ANI | 1 CH | : MASK VECTOR FIELD . |
|  |  | RLC |  | : MULTIPLY VECTOR BY TWO |
|  |  | ORI | 40 H | : ADD OFFSET OF 40 (HEX) |
|  |  | MVI | H,O | : CLEAR H |
|  |  | MOV | L,A | : JUMP ADDRESS $\rightarrow L$. |
|  |  | PCHL |  | : JUMP TO SERVICE ROUTINE |
|  | NOINT: |  | . |  |

Figure 13. Example of Polling Routine
TMS 5501 output bits when interval timer 3 completes the interval and then loads the timer for a 20 millisecond interval. The TMS 5501 base address is A000 (HEX). Note that the service routines are not stored in the same order as they are prioritized. This is the result of the decoding technique used in the POLL routine.

## C. INTERRUPT EXPANSION

When multiple TMS 5501s are used in the TMS 8080A system, there are more than the eight interrupts normally serviced by the RST instruction. The use of a combination interrupt-driven and polling service routine provides a simple expanded interrupt capability. When two TMS 5501 s are used in a system, thie INT output of one TMS 5501 is connected to the INT input of the TMS 8080A. The INT output of the other TMS 5501 is connected to the SENS or the XI7 input of the first TMS 5501 as shown in Figure 14.


Figure 14. Interrupt Expansion for TMS 5501s

Note that one interrupt input, SENS or XI7, of the first TMS 5501 is used to connect the INT output of the second TMS 5501 and is therefore unavailable for use as an external interrupt input. Consequently, there are fifteen user interrupt sources in a two TMS 5501 system.

The system is interrupt-driven since any enabled interrupt in either TMS 5501 causes an interrupt to the TMS 8080A to be generated. Only the first TMS 5501, however, should be enabled for interrupt acknowledge since only one device should jam the RST instruction on the data bus.

After the TMS 8080A acknowledges the interrupt and executes the RST instruction, one of eight service routines is entered. Seven of the eight service routines should be dedicated to the seven user interrupts of the first TMS 5501. The eighth service routine must poll the second TMS 5501 to determine which of the eight interrupts of the second TMS 5501 generated the interrupt.

The priorities of the interrupt are dependent upon whether SENS or XI7 is used for connecting the INT output of the second TMS 5501. Table VII lists the interrupt priorities for both schemes.

Table VII. Interrupt Priorities for Expanded System

| PRIORITY | SIGNAL |  |
| :---: | :---: | :---: |
|  | USING SENS | USING XI7 |
| 1 | TIMER 1 (1) | TIMER 1 (1) |
| 2 | TIMER 2 (1) | TIMER 2 (1) |
| 3 | TIMER 1 (2) | SENS (1) |
| 4 | TIMER 2 (2) | TIMER 3 (1) |
| 5 | SENS (2) | SERIAL RECEIVE (1) |
| 6 | TIMER 3 (2) | SERIAL TRANSMIT (1) |
| 7 | SERIAL RECEIVE (2) | TIMER 4 (1) |
| 8 | SERIAL TRANSMIT (2) | TIMER 1 (2) |
| 9 | TIMER 4 (2) | TIMER 2 (2). |
| 10 | TIMER 5 OR XI7 (2) | SENS (2) |
| 11 | TIMER 3 (1) | TIMER 3 (2) |
| 12 | SERIAL RECEIVE (1) | SERIAL RECEIVE (2) |
| 13 | SERIAL TRANSMIT (1). | SERIAL TRANSMIT (2) |
| 14 | TIMER 4 (1) | TIMER 4 (2) |
| 15 | TIMER 5 OR XI7 (1) | TIMER 5 OR XI7 (2) |

The interrupt service routine is similar to the routine illustrated in Figure 11. The primary difference is that the poll routine replaces the service routine for SENS or XI7 for the first TMS 5501. The interrupt service routines for the first TMS 5501 require the first sixty-four memory bytes plus whatever additional memory is required in another part of program memory. The interrupt service routines for the second TMS 5501 require the second block of sixty-four memory bytes plus whatever additional memory is required. A possible memory map of the service routines is illustarted in Figure 15.

If three TMS 5501s are used, the interrupt system is similarly expanded. The INT outputs of the second and third TMS 5501s can be connected to the SENS and the XI7 inputs of the first TMS 5501. Alternately, the INT output of the third TMS 5501 is connected to the SENS. or

| A000-A0OF | SECOND TMS 5501 |
| :---: | :---: |
| 9000-900F | FIRST TMS 5501 |
| $100-7 F F F \quad\{$ | MAIN PROGRAM MEMORY |
| $80-F F \quad\{$ | ADDITIONAL PROGRAM AREA FOR SERVICE ROUTINES |
| $40-7 F \quad\{$ | SECOND EIGHT SERVICE ROUTINES |
| $0-3 F$ | FIRST EIGHT SERVICE ROUTINES |

Figure 15. Example Memory Map for Multiple TMS 5501 System

XI7 input of the second TMS 5501, which is similarly connected to the first TMS 5501. Additional TMS 5501s can be added as required.

## D. SERIAL COMMUNICATIONS

The serial communications capability of the TMS 5501 provides a powerful and economical tool for data communications. The asynchronous serial receiver and transmitter, often referred to as a UART, perform the communications related tasks such as format conversion, timing, and buffering as described in Section II-D.

The TMS 8080A initiates a serial output by addressing the load transmitter buffer function in order to transfer the output character to the UART. To avoid loading the UART faster than it can transmit characters, the TMS 5501 has an I/O status bit called transmitter buffer empty. This status bit is high whenever the UART is ready to accept a new character from the TMS 8080A. If enabled, a low-tohigh transition (full-to-empty) of the transmitter buffer empty bit generates the level 5 interrupt. Consequently, the TMS 5501 should be polled for a high transmitter buffer empty bit or the level 5 interrupt should be received before a new character is loaded into the UART.

When a serial character is input to the UART, the receiver buffer loaded status is set. If enabled, the level 4 interrupt is generated. Since the input data stream is asynchronous to the main program, the receiver buffer loaded status bit must be polled or the level 4 interrupt received before the TMS 8080A can read in the character. The UART also has I/O flags which indicate transmission errors and UART status. The I/O service routine can check the frame error and overrun error flags to determine the validity of the input. Some applications, however, may not need to test these flags.

The TMS 5501 UART does not implement modem control signals. These signals are not used in many applications where control of a modem is not required such as communications with a local data terminal. If the modem control signals are required, the TMS 8080A can use the TMS 5501 parallel input and output ports to test and to control the modem under program control.

The UART is designed to send and to receive eight-bit data characters (plus framing). Shorter characters may be transmitted by right justifying the character and left filling with high or one bits. Figure 16 shows how a five-bit character is formatted for transmission. The most significant three.bitsare high and cause the receiver to interpret them as stop and idle bits.


Figure 16. Transmission Format for Five-Level Code
The receiver, however, cannot interpret shorter codes correctly unless sufficient stop or idle bits are transmitted to space start bits at least 10 bit times apart.

The UART does not perform parity generation or checking. The TMS 8080A, however, has a parity condition flag which simplifies the parity generation and check tasks.

The routine in Figure 17 illustrates the use of the UART. The routine inputs ASCII characters, checks their parity (ODD), and outputs them. A null character is transmitted if the parity is incorrect. The routine demonstrates the use of the interrupt (receive buffer loaded) and polling (transmit buffer empty) techniques. The transmit

| IORCV: | PUSH | PSW | ; SAVE STATUS AND ACC. |
| :---: | :---: | :---: | :---: |
|  | LDA | 8000 H | ; INPUT CHAR $\rightarrow$ ACC |
|  | CMP | A | ; TEST PARITY |
|  | JPO | SKIP | : JUMP IF GOOD PARITY |
|  | MVI | A,80H | ; ELSE REPLACE WITH NULL |
| SKIP: | PUSH | PSW | ; SAVE CHARACTER ON STACK |
|  | JMP | REST | ; JUMP TO REST OF ROUTINE |
| REST: | LDA | 8003 H | ; INPUT I/O STATUS |
|  | ANI | 10 H | ; TEST TRANSMIT STATUS |
|  | JZ | REST | ; LOOP UNTIL READY |
|  | POP | PSW | ; RESTORE CHAR $\rightarrow$ ACC |
|  | STA | 8006 H | ; TRANSMIT CHARACTER |
|  | POP | PSW | ; RESTORE STATUS AND ACC |
|  | E. 1 |  | ; ENABLE INTERRUPTS |
|  | RET |  | : RETURN |

Figure 17. Example UART Control Routine
interrupt is disabled which allows the receive service routine to use a 16 -byte block.

The transmitter and receiver outputs are TTL compatible and normally require buffering to interface with a transmission line. The Texas Instruments Linear and Interface Circuits Applications book contains a description of common line transmission interface circuits.

## E. DESIGN CONSIDERATIONS

## 1. Clock Frequency

The TMS 5501 interval count frequency and serial communication clock frequency are derived from the system clock inputs ( $\phi 1, \phi 2$ ). The 64 -microsecond interval count time and the standard baud rates are dependent upon using a two-megahertz system clock. Operation at any other frequency will result in a different interval count time and non-standard baud rates.

## 2. WAIT States

The TMS 8080A READY input is used to synchronize the CPU with slow memories such as ROMs. When not-ready is indicated during a memory cycle, the TMS 8080A enters a wait state and suspends operation until the memory system indicates ready. The TMS 5501 does not have a ready input or output and cannot detect that the TMS 8080A is in a wait state. Therefore, the TMS 5501 will not operate correctly if wait states occur while it is being addressed. Therefore, READY must be true whenever the TMS 5501 is selected. This requirement can be met by disabling a wait request whenever the TMS 5501 is addressed. Figure 18 illustrates the use of slow memories with the TMS 5501.

## 3. Halt

A halt instruction should not be placed in a memory location immediately contiguous to a TMS 5501 base address. The execution of the halt in such a location would inadvertently select the TMS 5501 read receiver buffer function and clear the receiver buffer loaded flag. The designer should be particularly careful to avoid this situation in systems which do not fully decode the memory address.

## 4. $1 / 0$ Addressing

During I/O operations, the TMS 8080A I/O address appears in duplicate on A7 through A0 and A15 through A8. Since the TMS 5501 does not check the status word during SYNC for the INP and OUT status indicators, it is possible to select the TMS 5501 during an $1 / O$ operation. The restriction of the $1 / O$ addressing space or the external gating of the TMS 5501 chip select by the I/O status indicators will eliminate this problem. The designer can use this characteristic to use I/O instructions to access the TMS 5501. For example, use address bit 15 to select the TMS 5501 as described in Section II-A. The TMS 5501 can then be accessed by the OUT and IN instructions. Any I/O address greater than 7F (HEX) sclects the TMS 5501

Figure 18. Sequential Controller Using TMS 5501 With Slow Memory
since the $\mathrm{I} / \mathrm{O}$ address is duplicated on the address bus. The least-significant four bits still select the TMS 5501 function. Table VIII lists a few of the memory and I/O instructions which perform the same function in such a system.

Table VIII. TMS 5501 I/O Addressing

| MEMORY |  | 1/0 |  | FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| LDA | 8000 H | IN | 80 H | RECEIVE BUFFER $\rightarrow$ ACCUMULATOR |
| LOA | - 8003 H | in | 83 H | HO STATUS -* ACCUMULATOR |
| mov | A, M | IN | 81 H | EXT INPUTS $\rightarrow$ ACCUMULATOR |
|  | $(\mathrm{HL})=800.1 \mathrm{H}$ |  |  |  |
| stax | 0 | OUT | 88 H | ACCUMULATOR $\rightarrow$ MASK REGISTER |
|  | (DE) $=8008 \mathrm{H}$ |  |  |  |
| STA | 800AH | OUT | 8AH | ACCUMULATOR $\rightarrow$ TIMER 2 |

## IV. TMS 5501 APPLICATIONS

The TMS 5501 is a multifunction 1/O controller suitable for any TMS 8080A-based system requiring data I/O, serial communications, interrupt control, and interval timing. It is ideal for applications such as intelligent terminals, data entry equipment, data collection, machinery control, and process control.

The system shown in Figure 18 is an example of a TMS 8080A-based system using the $1 / 0$ functions of the TMS 5501. The sample system is an intelligent sequential controller with remote data entry capability. The controller can maintain up to eight relay closures and can sense up to eight discrete process inputs. The serial asynchronous communication link is used for data transfers between the control computer and the remote controller.

The central computer transmits control data, such as contact closure interval times, to the sequential controller over the serial communication link. The TMS 8080A then executes the ROM-based control program and sequences the output closures in response to transmitted intervals and process inputs. For example, the controller can close a relay for either one second or until an input becomes true, whichever occurs first. The controller releases all relay closures whenever the trip switch is closed. At periodic intervals, the controller transmits the output and input status to the central computer, which is connected to the sequential controller by a 1000 -foot long double twisted pair cable.

The TMS 5501 provides the multiple $1 / \mathrm{O}$ functions needed by the controller. The TMS 5501 buffers the
process inputs and outputs, performs the serial data communication task, times event intervals for accurate control, and senses the trip signal. The interrupt control logic of the TMS 5501 generates a prioritized interrupt to the CPU at the end of an interval, when new data has been received, when the transmitter is ready, or when the controller is to be tripped. The CPU is thus free to execute the main control program or diagnostics concurrently with event timing and serial data transfers.

Note that the serial transmission baud rate is generated by the TMS 5501 and requires no external timing elements. Test bit 4 can be set high to allow high speed data transfer at up to 76.8 kilobaud. The interval timers, however, are also then driven by a higher speed clock. Long events can be accurately timed by dividing the long delay into several smaller delays and sequentially timing the lesser intervals.

The system memory consists of a TMS 4700 1024 X 8 ROM and two TMS 4042-1 256 X 4 RAMs. The 650 -nanosecond access TMS 4042-1 RAM has been selected to demonstrate the use of wait states for slow memory in TMS 5501 systems. Recall that memory cycles which reference the TMS 5501 should not contain wait states. The memory READY input is false only when the RAM is addressed (A10 high) and for only one wait state since an active WAIT output disables the wait request. The TMS 4042-2 RAM can be used instead to eliminate the need for wait states.

The SN75450B dual peripheral drivers interface the TMS 5501 external outputs to the relays. The process inputs are assumed to be TTL compatible inputs. Input filtering, if desired, can be performed either by a RC network or by the CPU under program control. A SN75107A receiver and a SN75109 transmitter are used to buffer the TMS 5501 serial input and output signals. The differential line driver and receiver provide reliable data transmission over twisted pair cables in excess of 1000 feet with excellent noise rejection. Other line transmission circuits are available for applications requiring RS-232C or current loop interfaces.

The TMS 5501 multifunction input/output controller is a powerful and versatile design tool for a TMS 8080Abased system. It performs parallel I/O buffering, serial data transfers, multiple event timing, and interrupt processing in a single integrated circuit. It provides improved system performance and flexibility, reduced component count, and reduced system cost.





Navn ID-7022 pRor1/RAm/IO mod. Lb. nr. Logic Schematic. PRoviarray


 , $\overline{R R}$


3) $\sqrt{ } 24$ :
strop $l-B$
$11 \quad D-E=V 24$ out.
" $L \rightarrow p \rightarrow m$
connect $V 24$ input to $F$ through ext. $4 k 7$ resister.
4) $20-A$ current $100 \rho$

Strap $\quad J \rightarrow F$

$$
L \rightarrow P_{M}
$$

$$
\begin{aligned}
& n \rightarrow M \\
& m \rightarrow R
\end{aligned}
$$

$$
m \rightarrow B
$$

timput: $K$.
$\div$ input: $H$

+ outs. : C
© outs: $E$


Prato TTLRAI $O M$
$\overline{R C V}$

In reactive state $T \times D$ is on a high level


A tramxiti- for high $\rightarrow$ low on the rok like activates the receiver.

