# TM 990 # TM 990/189 Microcomputer User's Guide MICROPROCESSOR SERIES Information contained in this publication is believed to be accurate and reliable. However, responsibility is assumed neither for its use nor for any infringement of patents or rights of others that may result from its use. No license is granted by implication or otherwise under any patent or patent right of Texas Instruments or others. Copyright © 1979 Texas Instruments Incorporated # **TABLE OF CONTENTS** | Section | Title | Page | |------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------| | | I. INTRODUCTION | | | 1.1<br>1.2<br>1.3<br>1.4<br>1.5 | General Manual Organization General Specifications Glossary Applicable Documents | 1-4 | | | II. INSTALLATION AND OPERATION | | | 2.1<br>2.2<br>2.3<br>2.4<br>2.5<br>2.5.1<br>2.5.2<br>2.5.3<br>2.5.3.1<br>2.5.3.2<br>2.5.3.3<br>2.5.3.4<br>2.5.3.5<br>2.6<br>2.7<br>2.7.1 | General Required Equipment Power Up Procedure Operation Keyboard Keyboard Description Keyboard Use Special Keys Description Shift Display Left (←D) Display Right (→D) External Terminal Use LOAD Switch L.E.D. Display Using Audio Cassette Interface (ACI) Recorder Considerations Example Operation | 2-1<br>2-2<br>2-2<br>2-2<br>2-2<br>2-5<br>2-5<br>2-5<br>2-5<br>2-5<br>2-6<br>2-8 | | | III. UNIBUG MONITOR | | | 3.1<br>3.2<br>3.3<br>3.3.1<br>3.3.2<br>3.3.3<br>3.3.4<br>3.3.5<br>3.3.6<br>3.3.7<br>3.3.8 | General UNIBUG Commands Program Example Typewriter Program (T) Memory Inspect/Change (M) Assembler Execute (A) Assembler Execute with Current Symbol Table (B) CRU Inspect/Change (C) Dump Memory to Cassette (D) Execute to Breakpoint (E) Status Register (F) Inspect/Change | 3-1<br>3-2<br>3-5<br>3-5<br>3-6<br>3-6<br>3-7<br>3-8<br>3-9 | | 3.3.9<br>3.3.10<br>3.3.11<br>3.3.12<br>3.3.13<br>3.3.14<br>3.3.15 | Jump to Start of Expansion EPROM (J) Load Memory From Cassette (L) Program Counter (P) Inspect/Change Workspace Register Inspect/Change (R) Single Step(s) Workspace Pointer Inspect/Change (W) New Line Request (RET) | 3-10<br>3-11<br>3-12<br>3-13<br>3-13 | | 3,3,16<br>3,4<br>3,4,1 | Terminal Load/Dump Option (\$) User Accessible Utilities Write One Hexadecimal Character to Terminal (XOP 8)* | 3-14 | # **TABLE OF CONTENTS (Continued)** | Section | Title | Page | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | 3.4.2<br>3.4.3<br>3.4.4<br>3.4.5<br>3.4.6<br>3.4.7<br>3.5 | Read Hexadecimal Word From Terminal (XOP 9) Write Four Hexadecimal Characters to Terminal (XOP 10)* Echo Character (XOP 11) Write One Character to Terminal (XOP 12)* Read One Character From Terminal (XOP 13) Write Message to Terminal (XOP 14) UNIBUG Error Message | 3-17<br>3-18<br>3-18<br>3-18<br>3-19 | | | IV. SYMBOLIC ASSEMBLER | | | 4.1<br>4.2<br>4.2.1<br>4.2.2<br>4.2.3<br>4.2.4<br>4.2.5<br>4.2.6<br>4.3<br>4.4<br>4.4.1<br>4.4.2<br>4.5<br>4.6<br>4.7<br>4.8<br>4.8.1.1<br>4.8.1.2<br>4.8.1.3<br>4.8.1.4<br>4.8.1.5<br>4.8.1.6 | General Labels and Comments Labels Comments Use Dollar Sign to Indicate "At This Location" Expressions Cancel Source Statement Being Input Translate Characters Into ASCII Code Using Single Quotes Assembler Action Operation Calling the Assembler Exiting to the Monitor Entering Instructions Errors Pseudo-Instruction TM 990/189 Symbolic Assembler Listing Listing Format Location Counter Assembled Object Code Label Field Op Code Field Operand Field Comment Field | . 4-1<br>. 4-1<br>. 4-1<br>. 4-2<br>. 4-2<br>. 4-2<br>. 4-2<br>. 4-3<br>. 4-3<br>. 4-3<br>. 4-3<br>. 4-7<br>. 4-7<br>. 4-7<br>. 4-7<br>. 4-8<br>. 4-8 | | | V. INSTRUCTION SET FOR THE TM 990/189 | | | 5.1<br>5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.3.3.1<br>5.3.3.2<br>5.3.3.3<br>5.3.3.4<br>5.3.3.5<br>5.3.3.6<br>5.3.3.7<br>5.3.3.8 | General User Memory Hardware Registers Program Counter (PC) Workspace Pointer (WP) Status Register (ST) Logical Greater Than Arithmetic Greater Than Equal Carry Overflow Odd Parity Extended Operation Status Bit Summary | 5-1<br>5-2<br>5-2<br>5-4<br>5-4<br>5-4<br>5-4<br>5-5<br>5-5 | # **TABLE OF CONTENTS (Continued)** | Section | Title | Page | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 5.4<br>5.5<br>5.5.1<br>5.5.1.2<br>5.5.1.3<br>5.5.1.4<br>5.5.1.6<br>5.5.1.7<br>5.6.1<br>5.6.2<br>5.6.2<br>5.6.2.1<br>5.6.2.2<br>5.6.3<br>5.6.4<br>5.6.5<br>5.6.6<br>5.6.7<br>5.6.8<br>5.6.8.1<br>5.6.8.2 | Instruction Formats and Addressing Modes Addressing Modes Direct Register Addressing (T = 002) Indirect Register Addressing (T = 012) Indirect Register Autoincrement Addressing (T = 112) Symbolic Memory Addressing, Not Indexed (T = 102) Symbolic Memory Addressing, Indexed (T = 102) Immediate Addressing Program Counter Relative Addressing Instructions Format 1 Instructions Format 2 Instructions Jump Instructions CRU Single-Bit Instructions Format 4 (CRU Multibit) Instructions Format 5 (Shift) Instructions Format 7 (RTWP, Control) Instructions Format 8 (Immediate, Internal Register Load/Store) Instructions Internal Register Load Immediate Instructions Internal Register Store Instructions | 5-17<br>5-12<br>5-12<br>5-14<br>5-15<br>5-17<br>5-18<br>5-18<br>5-22<br>5-24<br>5-26<br>5-26<br>5-26<br>5-30<br>5-31<br>5-34<br>5-36<br>5-36<br>5-36 | | 5.6.8.3<br>5.6.9 | Format 9 (XOP) Instruction | . 5-38 | | | VI. ASSEMBLER DIRECTIVES | | | 6.1<br>6.2<br>6.2.1<br>6.2.2<br>6.2.3<br>6.2.4<br>6.2.5<br>6.2.6 | General Directive Formats AORG Directive BSS Directive Data Directive End Directive EQU Directive Text Directive | 6-1<br>6-2<br>6-2<br>6-2 | | | VII. I/O PROGRAMMING USING THE CRU | | | 7.1<br>7.2<br>7.2.1<br>7.2.2<br>7.2.3<br>7.3<br>7.4<br>7.5 | General CRU Addressing CRU Bit Address CRU Hardware Base Address CRU Software Base Address CRU Timing CRU Instructions I/O Programming with the TMS 9901 | 7-3<br>7-3<br>7-3<br>7-4 | | | VIII. THEORY OF OPERATION | | | 8.1<br>8.1.1<br>8.2 | Introduction | | ٧ # TABLE OF CONTENTS (Concluded) | Section | Title | Page | |----------------|----------------------------------|--------| | 8.2.1 | Data Bus | 8-1 | | 8.2.2 | Address Bus | 8-3 | | 8.2.3 | CRU Bus | 8-3 | | 8.2.4 | Control Bus | 8-3 | | 8.3 | Processor | 8-4 | | 8.3.1 | Clock Oscillator | 8-4 | | 8.3.2 | External Instruction Decoding | 8-4 | | 8.4 | Interrupts | 8-8 | | 8.5 | Memory | . 8-14 | | 8.5.1 | Memory Address Decoding | . 8-14 | | 8.5.2 | Memory Expansion | . 8-14 | | 8.6 | Input-Output | . 8-18 | | 8.6.1 | User I/O Port | | | 8.6.2 | System I/O Port | . 8-20 | | 8.6.2.1 | Keyboard and Display Interface | . 8-20 | | 8.6.2.2 | Audio Cassette Interface | . 8-25 | | 8.6.2.3 | Sound Disc | . 8-26 | | 8.6.3 | Serial Communications Port | . 8-26 | | 8.6.4 | External I/O Port | . 8-27 | | | IX. USER OPTIONS | | | 9.1 | Introduction | | | 9.2 | Memory Options | | | 9.2.1 | On-Board RAM Expansion | | | 9.2.2 | On-Board EPROM, 1K Bytes | | | 9.2.3 | On-Board EPROM, 2K Bytes | | | 9.2.4 | On-Board EPROM, 4K Bytes | | | 9.2.5 | Off-Board Memory Expansion | | | 9.3 | Input-Output Options | | | 9.3.1 | Asynchronous Communications, EIA | | | 9.3.2 | Asynchronous Communications, TTY | | | 9.3.3 | On-Board Cassette Relay | | | 9.3.4<br>9.3.5 | Off-Board CRU Evansing | | | 9.3.5<br>9.3.6 | Off-Board CRU Expansion | . 9-4 | | 9.3.6<br>9.4 | Processor Options | | | 9.4.1 | Communications Interrupts | 9-6 | | 9.4.2 | System Clock Frequency | 9-6 | | 3.4.2 | System Clock Frequency | 9-6 | | | X. TROUBLESHOOTING SUGGESTIONS | | | 10.1 | Introduction | 10-1 | | 10.2 | Troubleshooting Procedure | | | 10.2.1 | Visual Checks | 10-1 | | 10.2.2 | Static Checks | 10-1 | | 10.2.3 | Dynamic Checks | | # APPENDICES | Α | SCHEMATICS | |---|-------------------------------------------------------------| | В | MEMORY DATA SHEETS | | С | ASCII CODE | | Ď | BINARY, DECIMAL AND HEXADECIMAL NUMBERING | | Ē | TMS 9901 PROGRAMMABLE SYSTEMS INTERFACE (DATA MANUAL) | | F | TMS 9902 ASYNCHRONOUS COMMUNICATIONS CONTROLLER DATA MANUAL | | G | TMS 9980A/TMS 9981 MICROPROCESSOR DATA MANUAL | | H | TMS 9900 FAMILY MACHINE CYCLES | | ï | DATA TERMINAL HOOKUP | | J | I/O CABLES AND CONNECTORS | | K | PARTS LIST | | | | # LIST OF ILLUSTRATIONS | Figure No. | Title | Page | |------------|--------------------------------------------------------------------------|--------| | 1-1 | Principal TM 990/189 Components | 1-2 | | 1-2 | System Block Diagram | 1-3 | | 2-1 | Power Supply Hook Up | 2-1 | | 2-2 | Unshifted Key Code Designation | 2-3 | | 2-3 | Shifted Key Code Designation | 2-3 | | 2-4 | Power Up Initialization Flow Chart | 2-4 | | 2-5 | Display Left Operation | 2-5 | | 2-6 | Display Right Operation | 2-5 | | 2-7 | External Terminal Hook Up | 2-6 | | 2-8 | Display Segment Designation | 2-8 | | 2-9 | ACI Connector Pins | 2-9 | | 3-1 | CRU Bits Inspected By C Command | 3-7 | | 5-1 | Memory Map | 5-2 | | 5-2 | TMS 9980A With RAM/ROM Memory | 5-3 | | 5-3 | Status Register | 5-4 | | 5-4 | Workspace Example | 5-7 | | 5-5 | TM 990/189M Instruction Formats | 5-8 | | 5-6 | Direct Register Addressing Examples | 5-13 | | 5-7 | Indirect Register Addressing Example | 5-14 | | 5-8 | Indirect Register Autoincrement Addressing Example | . 5-15 | | 5-9 | Symbolic Memory Addressing Examples | 5-16 | | 5-10 | Symbolic Memory Addressing, Indexed Example | 5-17 | | 5-11 | BLWP Example | 5-34 | | 5-12 | XOP Example | 5-39 | | 7-1 | Typical Application TMS 9902 Asynchronous Communication Controller (ACC) | 7-1 | | 7-2 | Typical TMS 9901 Programmable System Interface (PSI) Application | 7.2 | | 7-3 | CRU Address in R12 Vs. Address Bus Lines | 7-3 | | 7-4 | TMS 9980 CRU Interface Timing | 7-5 | | 7-5 | LDCR Byte Instruction | 7-6 | | 7-6 | STCR Word Instruction | 7-7 | | 7-7 | LDCR Word Execution to TMS 9901 | 7-9 | | 7-8 | LDCR Byte Execution to TMS 9901 | 7-10 | | 7-9 | STCR Word Execution to TMS 9901 | 7-11 | | 7-10 | STCR Byte Execution to TMS 9901 | 7-12 | | 7-11 | Test CRU Bit at TMS 9901 | 7-13 | | 7-12 | Set CRU Bit at TMS 9901 | 7-14 | | 8-1 | System Block Diagram | 8-2 | | 8-2 | TMS 9980A Internal Architecture | 8-5 | | 8-3 | TMS 9980A CPU Flow Chart | 8-6 | | 8-4 | TMS 9980A Signals | 8.7 | | 8-5 | External Instruction Decode | 8.7 | | 8-6 | Interrupt Signal Flow | 0.0 | | 8-7 | Load Interrupt Generator and Power Up Reset Circuit | Q_11 | | 8-8 | Power-Up Sequence Timing | 8-12 | | 8-9 | Load Timing | 8-13 | | 8-10 | System Memory Map | Q_15 | | 8-11 | Memory Address Decoding | 8-16 | | 8-12 | Memory Partitioning Signals | 8.16 | # LIST OF ILLUSTRATIONS (Concluded) | Figure No. | Title | Page | |----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------| | 8-13<br>8-14<br>8-15<br>8-16<br>8-17<br>8-18<br>8-19<br>8-20<br>8-21<br>8-22<br>8-23<br>8-24 | RAM Read Cycle Timing RAM Write Cycle Timing Expansion Data Bus Control Logic System CRU Map CRU Address Decoding Logic Keyboard and Display Interface Block Diagram Display Segment Designation Display Driver Circuitry Keyboard Interface Cassette Write Circuit Cassette Read Circuit External I/O Port TM 990/189 Board Layout | 8-17<br>8-18<br>8-19<br>8-19<br>8-21<br>8-21<br>8-23<br>8-24<br>8-25<br>8-26<br>8-28 | | 10-1 | Photo Interpretation Code | | | | LIST OF TABLES | | | Table No. | Title | Page | | 2-1<br>2-2<br>2-3 | Power Supply Requirements Display Character Font Recorder and ACI Connections | . 2-7 | | 3-1<br>3-2<br>3-3 | UNIBUG Commands Command Syntax Conventions User Accessible Utilities | . 3-2<br>3-14 | | 5-1<br>5-2<br>5-3<br>5-4<br>5-5<br>5-6<br>5-7 | Status Bits Affected by Instructions Op Codes (Alphabetical) Op Codes by Format Instruction Description Terms Instruction Set, Alphabetical Index Instruction Set, Numerical Index Comparison of Jumps, Branches, XOP's | 5-9<br>5-10<br>5-18<br>5-19<br>5-21 | | 7-1 | CRU Address Map | . 7-2 | | 8-1<br>8-2<br>8-3<br>8-4<br>8-5<br>8-6<br>8-7 | Control Bus Functions External Instruction Results TMS 9980A Interrupt Decoding Interrupt Sources User Port I/O Map System Port I/O Map Communications I/O Map | . 8-8<br>. 8-9<br>8-20<br>8-22<br>8-27 | | 9-1<br>9-2<br>9-3<br>9-4<br>9-5<br>9-6 | List of Materials, Offboard Memory Expansion List of Material, EIA Option List of Materials, TTY Option LED Disconnection Modification Communications Interrupt Modification List of Materials, System Frequency Modification | . 9-3<br>. 9-4<br>. 9-5<br>. 9-6 | | 10-1 | Supply Voltage Operational Limits | 10-2 | ### **SECTION 1** ### INTRODUCTION # 1.1 GENERAL The TM 990/189 is a self-contained, single-board microcomputer system. It is intended for use as a learning aid in the instruction of microcomputer fundamentals, machine and assembly language programming, and microcomputer interfacing. It also demonstrates TMS 9900 family applications and advantages. Figure 1-1 shows the principal TM 990/189 components. The system's features include: - TMS 9980A (MP9529) microprocessor - 1024 bytes of random access memory (RAM) expandable on board to 2048 bytes (each byte contains 8 bits of data) - 4096 bytes of read only memory (ROM) expandable on board to 6144 bytes - 2 MHz crystal controlled clock - Audio cassette interface - 16 bit programmable I/O port and interrupt monitor (TMS 9901) - 45-key alphanumeric keyboard - Ten-digit, seven-segment L.E.D. type alphanumeric display - Visual and acoustic indicators - Resident system monitor and assembler - Single step instruction execution In addition to onboard memory expansion, two other system expansion options are available: - A TMS 9902 asynchronous communications controller, and accompanying interface circuits for either RS-232-C or 20 mA current loop terminals can be added. - The bus can be expanded by use of the Bus Interface. Figure 1-2 shows the system architecture along with the user options. # 1.2 MANUAL ORGANIZATION This manual is organized as follows: - Section 1 covers board specifications and characteristics. A glossary in paragraph 1.4 explains terms used throughout the manual. - Section 2 shows how to install, power up, and operate the TM 990/189 microcomputer. Figure 1-1. Principal TM 990/189 Components Figure 1-2. System Block Diagram - Section 3 explains the UNIBUG monitor. UNIBUG commands, XOPs and error indicators are topics included. - Section 4 is an introduction to the Symbolic Assembler used in the TM 990/189. - Section 5 covers the instruction set used with the TM 990/189. Instruction formats and addressing modes are explained in detail. - Section 6 covers assembler directives. - Section 7 presents the fundamental concepts involved in I/O programming. The Communications Register Unit (CRU) and two interface adaptors (TMS 9901 and TMS 9902) are described along with their programming techniques. - Section 8 covers theory of operation including memory and I/O mapping, block diagram, and circuit descriptions. - Section 9 provides the necessary information to utilize the available options and modify the system. - Section 10 provides a very useful troubleshooting checklist and debugging hints. Both static and dynamic checks are given. # 1.3 GENERAL SPECIFICATIONS Power consumption (Typical): | | +5 V | +12 V | −12 V | |--------------------------------|--------|--------|--------| | 1024 bytes RAM, 4096 bytes ROM | 595 mA | 76 mA | 5.6 mA | | 2048 bytes RAM, 5120 bytes ROM | 701 mA | 121 mA | 36 mA | | 2048 bytes RAM, 6144 bytes ROM | 696 mA | 102 mA | 16 mA | Clock rate: 2 MHz Baud rates (set by UNIBUG monitor): 110 baud and 300 baud Memory size: RAM (TMS 4014), 1024 bytes expandable on-board to 2048 bytes. (Equivalent RAM is TMS 4045.) ROM (TMS 4732), 4096 bytes expandable on-board to 6144 bytes. Board dimensions: 8.15 by 11 inches (20.7 by 27.9 cm) ### 1.4 GLOSSARY The following are definitions of terms used with the TM 990/189. Absolute address: The actual memory address in quantity of bytes. Memory addressing is usually represented in hexadecimal from 000016 to 3FFF16 for the TM 990/189. Alphanumeric character: Letters, numbers, and associated symbols. ASCII Code: A seven-bit code used to represent alphanumeric characters and control. Assembler: Program that interprets assembly language source statement into object code. Assembly Language: Mnemonics which can be interpreted by an assembler and translated into an object program. Bit: The smallest part of a word; it has a value of either a 1 or 0. Breakpoint: Memory address where a program is intentionally halted. This is a program debugging tool. Byte: Eight bits or half a word. Carry: A carry occurs when the most-significant bit is carried out in an arithmetic operation (i.e., resultant cannot be contained in only 16 bits). Central Processing Unit (CPU): The "heart" of the computer: responsibilities include instruction access and interpretation, arithmetic functions, I/O memory access. The TMS 9980A (MP9529) is the CPU of the TM 990/189. Command Scanner: A given set of instructions in the UNIBUG monitor which takes the user's input from the terminal and searches a table for the proper code to execute. Context Switch: Change in program execution environment, includes new program counter (PC) value and new workspace area. CRU (Communications Register Unit): The TMS 9980A's general purpose, command-driven input/output interface. The CRU provides up to 2048 directly addressable input and output bits. Effective Address: Memory address resulting from interpretation of an instruction, required for execution of that instruction. EPROM: See Read Only Memory. Hexadecimal: Numerical notation in the base 16. Immediate Addressing: An immediate or absolute value (16-bits) is part of the instruction (second word of instruction). Indexed Addressing: The effective address is the sum of the contents of an index register and an absolute (or symbolic) address. Indirect Addressing: The effective address is the contents of a register. Interrupt: Context switch in which new workspace pointer (WP) and program counter (PC) values are obtained from one of 4 interrupt traps in memory addresses 000016 to 001216. I/O: The input/output lines are the signals which connect an external device to the data lines of the TMS 9980A. Least Significant Bit (LSB): Bit having the smallest value in a byte or word (smallest power of base 2); represented by the right-most bit. Link: The process by which two or more object code modules are combined into one, with cross-referenced label address locations being resolved. Loader: Program that places one or more absolute or relocatable object programs into memory. Machine Language: Binary code that can be interpreted by the CPU. Monitor: A program that assists in the real-time aspects of program execution such as operator command interpretation and supervisor call execution. Sometimes called supervisor. Most Significant Bit (MSB): Bit having the most value in a byte or word; the left-most bit representing the highest power of base 2. This bit is sometimes used to show sign with a 1 indicating negative and a 0 indicating positive. Object Program: The hexadecimal interpretations of source code output by an assembler program. This is the code executed when loaded into memory. One's Complement: Binary representation of a number in which the negative of the number is the complement or inverse of the positive number (all ones become zeroes, vice versa). The MSB is one for negative numbers and zero for positive. Two representations exist for zero: all ones or all zeroes. Op Code: Binary operation code interpreted by the CPU to execute an instruction. Overflow: An overflow occurs when the result of an arithmetic operation cannot be represented in two's complement (i.e., in 15 bits plus sign bit). Parity: Means for checking validity of a series of bits, usually a byte. Odd parity means an odd number of one bits; even parity means an even number of one bits. A parity bit is set to make all bytes conform to the selected parity. If the parity is not as anticipated, an error flag can be set by software. The parity jump instruction can be used to determine parity. Program Counter (PC): Hardware register that points to the next instruction to be executed or next word to be interpreted. PROM: See Read Only Memory. Random Access Memory (RAM): Memory that can be written to as well as read from (vs. ROM). Read Only Memory (ROM): Memory that can only be read from (can't change contents). Some can be programmed (PROM) using a PROM Programmer. Some PROM's can be erased (EPROM's) by exposure to ultraviolet light. Source Program: Programs written in mnemonics that can be translated into machine language (by an assembler). Status Register (ST): Hardware register that reflects the outcome of a previous instruction and the current interrupt mask. Supervisor: See Monitor. Utilities: A unique set of instructions used by different parts of the program to perform the same function. In the case of UNIBUG, the utilities are the I/O XOP's. Word: Sixteen bits or two bytes. Workspace Register Area: Sixteen words, designated registers 0 to 15, located in RAM for use by the executing program. Workspace Pointer (WP): Hardware register that contains the memory address of the beginning (register 0) of the workspace area. ### 1.5 APPLICABLE DOCUMENTS The following is a list of documents that provide supplementary information for the TM 990/189 user. - TMS 9901 Programmable Systems Interface Data Manual - TMS 9902 Asynchronous Communication Controller (Data Manual) - TMS 9980A/TMS 9981 Microprocessor Data Manual - TMS 9900 Family System Development Manual ### **SECTION 2** # **INSTALLATION AND OPERATION** ### 2.1 GENERAL This section covers power supply requirements, power up procedure, operation (keyboard and display), and use of the audio cassette interface. ### 2.2 REQUIRED EQUIPMENT - TM 990/189 University Board - Suitable power supply such as TM 990/519 An equivalent power supply capable of meeting the requirements given in Table 2-1 may be used. TABLE 2-1. POWER SUPPLY REQUIREMENTS | Voltage | Regulation | CURRENT | |---------|------------|---------| | +5 V | +/-5% | 1.787 A | | +12 V | +/-5% | 0.214 A | | -12 V | +/-5% | 0.155 A | ### 2.3 POWER UP PROCEDURE Figure 2-1 shows how to connect voltage to the TM 990/189 board. A cable is supplied which directly facilitates connection of the TM 990/189 to a TM 990/519 power supply. The connections on each end are positively keyed and prohibit misconnection of the power supply. Also, since the connectors are identical and this cable is wired "one for one," either end may be connected to the TM 990/189 or the TM 990/519. Figure 2-1. Power Supply Hook Up When using a power supply other than the TM 990/519, the user should remove one connector from the cable and attach the proper connector or plugs for the power supply to be used. The power cable conductors are color coded as follows: +5 V - Red +12 V - White -12 V - Green Ground - Black ### NOTE It is advisable to check the connections from the TM 990/189 to the power supply output terminals with an ohmmeter before applying power. ### **CAUTIONS** - Avoid applying incorrect voltage levels to the TM 990/189. Texas Instruments assumes no responsibility for damage caused by improper wiring or voltage application by the user. - Do not operate the TM 990/189 board on metal or other conductive surfaces without use of a protective insulator between the two. ### 2.4 OPERATION - Verify that all wiring has been correctly connected. - 2. Apply power to board. - 3. The TM 990/189 has a power up load feature. The system initialization routine performs a self-check operation on the major system components and indicates a successful self-check completion by displaying "CPU READY" in the display. # 2.5 KEYBOARD # 2.5.1 KEYBOARD DESCRIPTION The keyboard consists of 45 keys. Figure 2-2 and Figure 2-3 show the unshifted and shifted key code designations respectively. Keys are shifted when the SHIFT key is depressed; while in this mode, the shift L.E.D. will illuminate. The keyboard becomes unshifted as soon as any key is pressed with the exception of DISPLAY RIGHT $(\rightarrow D)$ or DISPLAY LEFT $(\leftarrow D)$ . ### 2.5.2 KEYBOARD USE The keyboard is used to enter commands and data to the microprocessor. The TM 990/189 will energize in a power up LOAD state and the display will show CPU READY. At this point the microprocessor will wait for one character to be input. If the character is P, the TM 990/189 will be configured to receive data from a terminal (assuming that the User I/O and Interrupt Port modifications have been made as described in Section 4). If the RETURN (Ret) key is pressed, the microprocessor is configured to accept data from the keyboard. The display will show a question mark indicating that the command scanner is available to interpret keyboard inputs. A flowchart covering power up initialization is given in Figure 2-4. Figure 2-2. Unshifted Key Code Designation Figure 2-3. Shifted Key Code Designation Fig. 2-4. Power Up Initialization Flow Chart ### 2.5.3 SPECIAL KEYS DESCRIPTION ### 2.5.3.1 Shift The SHIFT key carries out the same function as that carried out by the shift key on a typewriter: it invokes a secondary definition for each key on the keyboard. The shift indicator L.E.D. (shown in Figure 1-1) will be activated to indicate that the shift mode has been entered. The shift mode may be exited by pressing any key except DISPLAY RIGHT or DISPLAY LEFT. # 2.5.3.2 Display Left (←D) The Display LEFT key shifts the field of view of the display to the left six character positions in the display buffer. This key does not change the contents of the display buffer. Figure 2-5 illustrates the operation of this key. Figure 2-5. Display Left Operation ### 2.5.3.3 Display Right (→D) The DISPLAY RIGHT key shifts the field of view of the display to the right six character positions in the display buffer. This key does not change the contents of the display buffer. Figure 2-6 illustrates the operation of this key. Figure 2-6. Display Right Operation # 2.5.3.4 External Terminal Use. The receipt of an alphabetic or numeric character when "CPU READY" is displayed will cause the TM 990/189 to be configured for communication with the optional TMS 9902 Serial Communications Controller and transfers control to the remainder of the system monitor (see Figure 2-4.) EXAMPLE: Using the TM 990/189 with an External Terminal\* <sup>\*</sup>See Section 8 for an explanation detailing the installation of the serial communications port and interface circuitry. ### Procedure: - 1. Plug in the cable from the terminal to connector P3 on the TM 990/189 (See Figure 2-7). - Connect the power supply cable from the TM 990/189 power pins to the TM 990/519 power supply. Figure 2-7. External Terminal Hook Up - Apply power to the system. - Turn terminal power on. - Place terminal ON LINE. - Turn power supply on. - The TM 990/189 will energize in a power up LOAD state and the display will show CPU READY. - For communications at 110 baud (10 characters per second) press a numeric key (0 through 9) on the TM 990/189. for communications at 300 baud (30 char/sec) press an alphabetic key (A through Z). - 6. UNIBUG prints a "?" prompt. The terminal is now ready for use. ### 2.5.3.5 LOAD Switch. The LOAD switch (S1) activates circuitry on the board which generates a non-maskable load interrupt to the processor. Activating the load switch causes the processor to discontinue execution of the current program and pass control to the UNIBUG monitor. Load switch activation does not alter the contents of user memory. Since the processor cannot ignore the load stimulus, the load switch provides the user with ultimate control over processor actions. Should program control ever be lost (e.g., if the processor gets caught in an infinite loop) pressing LOAD forces control back to UNIBUG where the user can enter commands and direct system operation. TABLE 2-2. DISPLAY CHARACTER FONT | ASCII CHARACTER | TABLE 2-2. DISPLAY CHARACTER FONT | | | | | | |-----------------------------------------|-----------------------------------|------------|-----------|--------|--------------------|---------------| | B | | | | | | | | B | Α | R | a,b,c,e,f | 6 | <u> </u> | a,c,d,e,f,g | | C | | 1 | | 7 | <u> </u> | a,b,c | | D | | | | 8 | 별 | a,b,c,d,e,f,g | | F | | ₫ | | 9 | 닠 | a,b,c,d,f,g | | I | | Ε | | 0 | IJ | a,b,c,d,e,f | | I | | F | | SPACE | | (none) | | I | | | | 6 | Ë | a,b,d,e,f,g | | J | | 님 | | \$ | <b>'</b> -!• | a,c,d,f,p | | J | | 1 | | * | -¦• | b,c,g,p | | K | | J | | i | - | b | | L | | | | > | 7 | a,b | | M | | <u> </u> | | + | $\dashv$ | b,c,g | | N | | _ | | - | - | g | | O | | | | ( | C | d,e,g | | P | | | | ) | コ | c,d,g | | Q | | P | | % | ا <sup>ــا</sup> • | b,e,g,p | | R | | 딕 | | / | <u></u> | b,e,g | | S | | _ | | = | Ξ | d,g | | T | | <u>ا _</u> | | ^ | | a,b,f | | U | | F | | < | C | a,f,g | | V = b.d.f.g | | | | , | • | d,p | | W | | ij | | • | • | р | | X | | = | | ÷ | <b></b> • | c,d,p | | Y | | Ξ | | : | l<br>• | c,p | | Z | | 딕 | | ? | ₽. | a,b,e,g,p | | 1 b,c | | Fi | | ! | 1 | b,c,p | | 2 | 1 | - | | | _ | d | | 3 3 a,b,c,d,g # 5 b,c,d,g 4 b,c,f,g | 1 | į | | -<br>n | ñ | b,f | | 4 b,c,f,g | L | Ę | | # | | b,c,d,g | | 1 4 ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' | l l | Ÿ | | | | | | 5 a,c,d,f,g | | Ġ. | | | | | ### 2.6 L.E.D. DISPLAY The display is a ten-digit, seven-segment L.E.D. type. It is used to display data, instructions, and error messages. The display segment designation is given in Figure 2-8. Table 2-2 shows display character font. The font gives the ASCII character, the display character, and the segments illuminated. Figure 2-8. Display Segment Designation # 2.7 USING AUDIO CASSETTE INTERFACE (ACI) An audio cassette recorder can be used as a storage medium for programs used with the TM 990/189. The TM 990/189 provides audio cassette interface circuitry and optional user installed recorder control circuitry. The ACI theory of operation is covered in Section 8. The TM 990/189 monitor provides two commands for use with a recorder. These commands are the L (load memory from cassette) and D (dump memory to cassette). Following entry of the L command, software will activate the motor control bit and begin looking for data from the audio cassette interface. Software will synchronize with the data, convert the data into proper digital format, and deposit the data in memory. After the data is loaded, the motor control bit is deactivated and the module identifier displayed. After entry of the D command and the parameters, the monitor will respond with READY and wait for a "Y" (yes) input from the keyboard. Upon receipt of the "Y" ready acknowledgement, the motor control bit is activated and an appropriate time allowed for the cassette deck to reach operating speed. Memory will be dumped from the start address to the stop address in 990 object record format. Following completion of the memory jump, the motor control bit will be deactivated. The syntax and description for these commands is given in Section 3. Figure 2-9 shows the location of the pins for audio in, audio out, and motor control. Figure 2-9. ACI Connector Pins ### 2.7.1 RECORDER CONSIDERATIONS In order to use the audio cassette efficiently several other aspects relevant to the recorder need further comment. These topics include: - Cable hook up - Volume and tone control positions - Tape position - Digital tape counter. ### CAUTION The TM 990/189 audio cassette interface is not compatible with certain models of audio cassette decks. Reliable operation is only warranted with the following audio cassette models: General Electric 3-5121B Panasonic RQ-413 AS Realistic CTR-40 Realistic CTR-41 Sears Model No. 799-21683700 Sharp RD610. A Panasonic Model RQ-413AS tape recorder will be used for illustrative purposes. Table 2-3 provides a listing of the connections that are needed between the TM 990/189 and the recorder. TABLE 2-3. RECORDER AND ACI CONNECTIONS | Recorder | P2 Connections | | | |-----------------|---------------------------------------|--|--| | Auxiliary Input | P2-5 (Audio Output) and P2-2 (Ground) | | | | Earphone Output | P2-6 (Audio Input) and P2-3 (Ground) | | | The volume control should be set to approximately 80 percent of maximum and the tone control to mid-point. The tape should be turned to the desired place on the tape where the recording is to be made and the initial value of the digital tape counter noted. After a "dump operation" is completed, the final reading of the digital tape counter should also be recorded. In this manner a number of programs may be stored and located on a single tape. ### 2.7.2 EXAMPLE OPERATION This example will provide a step-by-step approach to using the audio cassette interface. It is assumed that the optional cassette control relay has not been installed. ### NOTE If the relay circuitry is installed, a cable will be required between the remote input on the recorder to P2-4 (Motor A) and P2-1 (Motor B). This will allow the processor to start and stop the recorder. It should be noted at this time that this cable would have to be unplugged from the remote input for rewind operations. ### Procedure: ### Initial Set Up - a. Make the necessary connections between the recorder and P2 as given in Table 2-3. Do not make any connections to the remote input on the recorder. - b. Apply power to the TM 990/189 and the recorder. - Enter the example program given in Section 3.3 into memory. Examine memory to ensure that the program has been accurately entered. - d. After inserting the cassette, position the tape to the desired starting place for the recording. If the desired starting place is the beginning of the tape, reset the digital tape counter to 000 prior to recording. - e. Set the volume and tone controls to 80 percent and 50 percent respectively. ### 2. Dump Routine The D command will be used to dump memory from the "start address" to the "stop address." The "entry address" is the address in memory where it is desired to begin program execution. In this case the proper syntax (See Section 3.3.6) for the D command is as follows: $$D200 < T2 > 20\,E < T2 > 200 < T2 > IDT = EXAMPLE < T1 > READY? < Y >$$ After entering the D command, the monitor will respond with READY and wait for a Y (yes) keyboard entry indicating that the receiving device is ready. This allows the user to check recorder controls, tape position and the like before proceeding with the dump. If the recorder is set up correctly, press the RECORD button and then enter a Y on the keyboard to execute the D command. An appropriate time is allowed for the recorder to reach operating speed as indicated by a count down on the sound disc and LEDs CR0-CR3. In a similar fashion, the sound disc and the LEDs will signal when the dump has been completed. If the user wants to expedite the dump sequence, two asterisks can be used following the IDT tag. Example: IDT = \*\*EXAMPL could be inserted in the syntax above to reduce dump time. ### 3. Load Routine - a. In order to verify that the program can be properly loaded back into memory, change the contents of M.A. 0200 to 020E to zeros. - b. Rewind the tape to the dump starting position as indicated by the digital tape counter in this case reading 000. - c. Enter the L command on the TM 990/189 keyboard. CR6 (FWD LED) will light indicating that the processor is now ready for the recorder to be turned on. - d. Depress the PLAY button on the recorder. The SHIFT LED will go on and off while data transfer is occurring. LEDs CR0-CR3 and the sound disc will signal the end of the load routine. - e. When the FWD indicator extinguishes, stop the recorder. ### 4. Check Out Routine - a. The display on the TM 990/189 should display the name identifying the program. In this case, EXAMPLE should be displayed. - b. Use the M command to inspect memory locations M.A. 0200 to M.A. 020E and verify that the contents are correct. - c. The program counter has been loaded with the starting address of the program: the program is now ready to be executed. ### **SECTION 3** ### **UNIBUG MONITOR** ### 3.1 GENERAL A monitor is a program that implements the UNIBUG commands and subroutines. A command specifes the operation that is to be performed (example: Memory Inspect/Change). A subroutine is a program that carries out a specific task (example: typewriter program configures the TM 990/189 so that the keyboard acts as a typewriter keyboard). The monitor used in the TM 990/189 provides sixteen commands and seven subroutines. The commands and subroutines available in the TM 990/189 reside in a TMS 4732 ROM (board socket U 33). This section provides a description of the commands and subroutines available in the monitor. # 3.2 UNIBUG COMMANDS The 16 UNIBUG commands are given in Table 3-1. The following paragraphs will give the syntax and description for each command along with examples involving most of the commands. Conventions used to define command syntax are listed in Table 3-2. TABLE 3-1. UNIBUG COMMANDS | Input | Results | Paragraph | |-------|---------------------------------------------|-----------| | Α | Assembler Execute | 3.3.3 | | В | Assembler Execute With Current Symbol Table | 3.3.4 | | C | CRU Inspect/Change | 3.3.5 | | D | Dump Memory to Cassette | 3.3.6 | | E | Execute to Breakpoint | 3.3.7 | | F | Status Register Inspect/Change | 3.3.8 | | j | Jump to EPROM | 3.3.9 | | ı | Load Memory from Cassette | 3.3.10 | | M | Memory Inspect/Change | 3.3.2 | | P. | Program Counter Inspect/Change | 3.3.11 | | R | Workspace Register Inspect/Change | 3.3.12 | | s | Single Step | 3.3.13 | | T | "Typewriter" Program | 3.3.1 | | w | Workspace Pointer Inspect/Change | 3.3.14 | | Ret | New Line Request | 3.3.15 | | \$ | Terminal Load/Dump Option | 3.3.16 | **TABLE 3-2. COMMAND SYNTAX CONVENTIONS** | Convention<br>Symbol | Explanation | |----------------------|-------------------------------------------| | < > | Required items to be supplied by the user | | [ ] | Optional items to be supplied by the user | | (Ret) | Return | | T1 | Space | | T2 | Space or comma | | Т3 | Space, comma, or return | | LF | Line Feed | | R or Rn | Register (n = $0$ to $15$ ) | | WP | Current User Workspace Pointer contents | | PC | Current User Program Counter contents | | ST | Current User Status Register contents | ## NOTE Except where indicated otherwise, no space is necessary between the parts of these commands. All numeric input is assumed to be hexadecimal; the last four digits input will be the value used. Thus a mistaken numerical input can be corrected by merely making the last four digits the correct value. If fewer than four digits are input, they are right justified with leading zeros. Prior to discussing the aforementioned commands, an example program will be given. The example program serves as an aid to developing an understanding of command operations. # 3.3 PROGRAM EXAMPLE ### a. Problem: XOP 1,13 0210 Write a program that will add $33_{10}$ and $15_{10}$ and display the answer. | b. | Program S<br>LWPI | olution:<br>>0300 | Load immed | iate to workspace pointer. | |----|-------------------|---------------------|----------------------------------------------|---------------------------------------------------------------------------| | | LI<br>Li | 0,33<br>1,15 | | n first number (33 <sub>10</sub> )<br>n second number (15 <sub>10</sub> ) | | | A<br>XOP<br>XOP | 1,0<br>0,10<br>1,13 | Add, answer<br>Display conto<br>Turn display | | | C. | Program<br>LWPI | >300 | Address<br>0200<br>0202 | Hex Contents<br>02E0<br>0300 | | | LI | 0,33 | 0204 | 0200 | | | LI | 1,15 | 0206<br>0208<br>020A | 0021<br>0201<br>000F | | | A | 1,0 | 020C | A001 | | | XOP | 0,10 | 020E | 2E80 | 2F41 - d. To enter the previous program: - 1. Apply power to the TM 990/189 - The TM 990/189 will energize in a power up LOAD state and the display will show CPU READY. | DISPLAY | ENTER | COMMENTS | |--------------|-------|---------------------------------------------------| | CPU READY_ | (Ret) | | | ?_ | (Net/ | UNIBUG commands can be entered now | | ?M_ | | Memory Inspect/Change | | ?M 200_ | 200 | M.A. 0200 | | 0200 = XXXX_ | (Ret) | Current Contents M.A. 0200 | | XXXX 02E0_ | 02E0 | Enter New Contents | | 0202 = XXXX_ | (Sp) | Advance to Next M.A. Current Contents M.A. 0202 | | 0202 0300_ | 0300 | Enter New Contents | | | (Sp) | | | 0204 = XXXX_ | 0200 | | | XXXX 0200 | (Sp) | | | 0206 = XXXX_ | 0021 | | | XXXX 0021_ | (Sp) | | | 0208 = XXXX_ | 0201 | | | XXXX 0201_ | (Sp) | | | 020A = XXXX_ | 000F | | | XXXX 000F_ | | | | 020C = XXXX_ | (Sp) | | | XXXX A001_ | A001 | | | 020E = XXXX | (Sp) | | | XXXX 2E80 | 2E80 | | | 0210 = XXXX | (Sp) | | | XXXX 2F41 | 2F41 | The entire program has been entered at this point | e. Now that the example program has been entered, it will be examined for errors prior to executing it. To examine the previous program: | DISPLAY | ENTER | COMMENTS | |------------|-------|-----------------------------------------------------------------------------------------------------------| | ?_ | (Ret) | | | :-<br>?M_ | M | Memory Inspect/Change | | ?M 200_ | 200 | Program Starting M.A. | | | (Ret) | | | 0200=02E0_ | (Sp) | Data is Correct (DIC) | | 0202=0300 | (Sp) | DIC | | 0204=0200_ | (Sp) | DIC | | 0206=0021_ | • | DIC | | 0208=0201_ | (Sp) | DIC | | 020A=000F_ | (Sp) | DIC | | 020C=A001 | (Sp) | DIC | | 020E=2E80 | (Sp) | DIC | | 0210=2F41 | (Sp) | | | UZ IU=2F41 | | DIC Note: If an error is found at any M.A., simply enter the correct data and proceed to the next M.A. | Now that the sample program has been presented and the proper method for entering and examining a program given, the method for executing the previous program will be given. - f. To execute the previous program: - Set the program counter using the P command to the starting address of the program (0200 in this case). - 2. Use the E command without breakpoint to execute the program. | DISPLAY | ENTER | COMMENTS | |-----------|-------|-----------------------------------------| | ?_ | (Ret) | | | P=XXXX | Р | Current PC value | | XXXX 0200 | 0200 | Set PC to 0200 | | ?_ | (Ret) | | | ?E_ | E | | | 0030_ | (Ret) | Execute program The answer is displayed | # 3.3.1 TYPEWRITER PROGRAM (T) Syntax Т ### Description Each time the T command is entered, a subroutine called the "Typewriter" program is called up. This program allows the user to use the keyboard as a typewriter and insert a string of characters in the display buffer. This program is quite useful in familiarizing the user with the characters produced at the display (see Table 2-1). ### **EXAMPLE:** | DISPLAY | ENTER | COMMENTS | |------------|--------|-------------------------------------| | 001105407 | (LOAD) | Initialize System | | CPU READY_ | (Ret) | Provides entry into command scanner | | ?_ | т | Call "Typewriter" program | | ?T_ | A | | | ?T A_ | В | Character A displayed | | ?T AB_ | ь ь | Character B is added to display | ### 3.3.2 MEMORY INSPECT/CHANGE (M) Syntax M [address] < T3 > Description Memory inspect/change "opens" the memory location specified, displays it, and gives the option of changing the data in the location. If a memory location is not specified, the default of 000016 is used. The termination character causes the following: - If a return, control is returned to the command scanner. - If a space, the next memory location is opened and displayed. - If a minus sign, the previous memory location is opened and displayed. If a hexadecimal value is entered before the termination character, the displayed memory location is updated to the value entered. The last four digits input will be the value used; thus a mistaken numerical input can be corrected by merely making the last four digits the correct value. If fewer than four digits are input, they are right justified. The following example checks memory for the program loaded in paragraph 3.3(d). # Example: | DISPLAY | ENTER | COMMENTS | |-------------|--------|--------------------------------------------| | CPU READY_ | (LOAD) | Initialize System | | OI OTIEND! | (Ret) | Provides entry into Command Monitor | | ?_ | | | | ?M | М | Memory Inspect/Change Command | | 1 W | 200 | Memory address (M.A.) 0200<br>entered | | ?M 200_ | | 5.1.6. | | 0200 - 0250 | (Ret) | 0 | | 0200=02E0_ | (Sp) | Contents of M.A. 0200 | | 0202=0300_ | (ОР) | | | ••• | (Sp) | | | 0204=0200_ | | Contents of M.A. 0204 | | 0202=0300_ | - | Minus entered<br>Contents of M.A. 0202 | | | (Sp) | CONCORDO I WILA. UZUZ | | 0204=0200_ | | Contents of M.A. 0204 | | 0200 1234_ | 1234 | Enter new contents (M.A. 0204) | | 0200 1204_ | (Sp) | | | 0206=0021_ | (0) | Contents of M.A. 0206 | | 0204=1234 | - | Minus entered<br>New contents in M.A. 0204 | | | | | # 3.3.3 ASSEMBLER EXECUTE (A) **Syntax** A [address] < T3 > Description After entry of the "A" command, the monitor passes program control to the resident Symbolic Assembler. The assembler's symbol table is cleared. The Symbolic Assembler is covered in Section 4. # 3.3.4 ASSEMBLER EXECUTE WITH CURRENT SYMBOL TABLE (B) **Syntax** B [address] < T3 > Description After entry of the "B" command, the monitor passes program control to the Symbolic Assembler. The previous symbol table is kept, allowing the user to resume assembly of a program after exiting the assembler. The Symbolic Assembler is covered in Section 4. ## 3.3.5 CRU INSPECT/CHANGE (C) #### **Syntax** C [CRU R12 address] < T2 > [No. of CRU bits] < T3 > #### Definition The CRU inspect/change monitor command is used to inspect/change the contents of the Communication Register Unit (CRU). The CRU inspect/change monitor command displays from 1 to 16 CRU bits, right justified. The command syntax includes the CRU base address and the number of CRU bits to be displayed. The CRU base address is the 16-bit contents of R12. The user must use 2 $\times$ CRU bit address desired to obtain data about CRU bits. As an example, assume that seven CRU bits beginning with CRU bit 8016 are requested. If either the CRU R12 address or the number of CRU bits is not specified, the default values of 000016 and 16 bits are used respectively. Figure 3-1. CRU Bits Inspected By C Command #### Examples: 1. Examine eight CRU input bits. CRU base address is 2016. | DISPLAY | ENTER | COMMENTS | |------------|--------|---------------------| | CRUBEADY | (LOAD) | | | CPU READY_ | (Ret) | | | ?_ | С | | | ?C_ | 20,8 | | | ?C 20,8_ | (Ret) | | | 0020=00F0 | | Eight CRU bits = F0 | # Set value of eight CRU output bits at CRU base address 2016; new value is 0216. | DISPLAY | ENTER | COMMENTS | |------------|-------|-----------------------------------| | ?_ | С | | | ?C_ | C | | | | 20,8 | | | ?C 20,8 | (Ret) | | | 0020=00F0_ | | Previous value = F0 | | 20=00F0 2_ | 2 | Enter new value | | 20-00-02_ | (Ret) | | | ?_ | С | Check to see if new value entered | | ?C_ | 20.0 | | | ?C 20,8_ | 20,8 | | | : 0 20,0_ | (Ret) | | | 0020=0002_ | | New value = 02 | ## 3.3.6 DUMP MEMORY TO CASSETTE (D) #### Description The D command allows a program to be stored on Audio Cassette Tape. Memory is dumped from "start address" to "stop address." "Entry address" is the address in memory where it is desired to begin program execution. After entering a space or comma following the entry address, the monitor responds with an "IDT=" prompt asking for an input of up to eight characters that will identify the program. After entering the D command, the monitor will respond with "READY" and wait for a Y keyboard entry indicating the receiving device is ready. This allows the user to verify switch settings, etc., before proceeding with the dump. Upon receipt of the ready acknowledge (Y input), the motor control bit is activated, the FWD light is illuminated, and an appropriate time is allowed for the cassette deck to reach operating speed. Memory is dumped from the start address to the stop address in absolute 990 object record format. Following completion of the memory dump, the motor control bit is deactivated and the FWD light extinguished. As an example, assume that the starting address of the program to be dumped is M.A. 0200 and the stop address is M.A. 0210: the entry address in this example will be the same as the starting address. The correct syntax would be as follows: D $$200 < T2 > 210 < T2 > 200 < T2 > IDT = EXAMPLE < T1 > READY < Y >$$ The use of a double asterisk following the IDT tag will allow for a faster dump sequence. The correct syntax would be as follows: D 200 $$<$$ T2 $>$ 210 $<$ T2 $>$ 200 $<$ T2 $>$ IDT = \*\* EXAMPL $<$ T1 $>$ READY $<$ Y $>$ A detailed step-by-step example illustrating the use of this command is given in Section 2.7. #### 3.3.7 EXECUTE TO BREAKPOINT (E) Syntax E [breakpoint address] < T3 > #### Description The E command can be used for two purposes: it can be used to execute an entire program, and it can be used to execute a program up to a specified address (breakpoint address) where it is desired to halt the program. This feature allows longer programs to be broken into smaller sections for debugging. Program execution begins at the values of PC, WP, and ST previously established. An optional breakpoint address can be specified; if given, execution continues to breakpoint address at which time control returns to the monitor and the contents of the PC will be displayed. If no breakpoint address is specified, then execution begins with no halt point specified. To illustrate one use of this command the sample program given in paragraph 3.3 was previously entered into memory. To execute the sample program, the Ecommand is used (without breakpoint). | DISPLAY | ENTER | COMMENTS | | | | | |-----------|------------|--------------------------------------------|--|--|--|--| | ?_ | P | | | | | | | P=XXXX | 0200 | Starting address of program to be executed | | | | | | XXXX 0200 | | | | | | | | ?_ | (Ret)<br>E | PC set to 0200 | | | | | | ?E | | | | | | | | 0030_ | (Ret) | Execute program Solution | | | | | ## 3.3.8 STATUS REGISTER INSPECT/CHANGE(F) Syntax F Description This command is used to inspect or change the contents of the Status Register. ## Example: | DISPLAY | ENTER | COMMENTS | |------------|-------|--------------------------------| | ?_ | | | | | F | | | ?F = XXXX_ | 44 | Contents of Status Register | | =XXXX 44_ | 44 | Enter new contents | | 70001-1-1 | (Ret) | | | ?_ | | | | 35 0044 | F | Check status register contents | | ?F = 0044_ | | New contents | ## 3.3.9 JUMP TO START OF EXPANSION EPROM (J) **Syntax** J [VALUE 1] < T2 > [VALUE 2] < T2 > [VALUE 3] < T3 > # Description The J command causes a branch to memory address 0800<sub>16</sub>, the beginning address of the onboard expansion EPROM at socket U32. The user program at that address will define its own workspace and return-to-program procedure (return vectors are *not* transferred as in a BLWP instruction). The command format allows the insertion of three parameters that will be stored in three contiguous memory locations beginning at address >80<sub>16</sub>. The first parameter following the insertion of the J key will be stored in the first address, the second parameter in the next address and the third parameter in the last address. The parameters will be delimited by commas; if a parameter is not entered in a field, its corresponding memory address will be all zeroes. | DISPLAY | ENTER | COMMENTS | |-----------------|-----------|---------------------------------------------| | ?_ | | | | ?J | J | | | 21 | 4142,4344 | Parameters to be stored in memory addresses | | ?J<br>4142,4344 | | 0080 <sub>16</sub> and 0082 <sub>16</sub> | | | (Ret) | Program at 0800 <sub>16</sub> executes | # 3.3.10 LOAD MEMORY FROM CASSETTE (L) **Syntax** L ## Description The L command is used to load a program into memory from tape on an audio cassette recorder/player. After loading the cassette into the cassette recorder, position the tape at the start of the program that is to be read into memory. Following entry of the L command, the UNIBUG monitor activates the motor control bit, illuminates the FWD indicator, and begins looking for data from the audio cassette interface. The data will be synchronized, interpreted and deposited in memory. After the data is loaded, the motor control bit is deactivated, the FWD light extinguished, and the name of the program as recorded on the object program is displayed. A detailed step-by-step example illustrating the use of this command is given in Section 2.7. # 3.3.11 PROGRAM COUNTER INSPECT/CHANGE(P) **Syntax** P[new PC] < (Ret) > Description This command is used to inspect or change the contents of the program counter. As an example, assume that a program starting at M.A. 0200 is to be executed. The program counter would first have to be set to the starting address of the program prior to executing it. | NTER | COMMENTS | |------|-----------------------------------------| | P | | | | PC is at this address Enter new address | | Ret) | PC contains address 0200 | | Р | Check PC address PC address = 0200 | | Ret) | Return to UNIBUG | | | P 200 Ret) P | # 3.3.12 WORKSPACE REGISTER INSPECT/CHANGE (R) Syntax R [Workspace Register number] < T3 > Description The R command is used to display the contents of any workspace register and allows the user to change the register contents. The workspace begins at the address given by the Workspace Pointer. The R command followed by an optional register number in hexadecimal and a return causes the display of the specified register's contents. The user may then enter a new value into the register by entering a hexadecimal value. If a Workspace Register number is not specified, register zero is the default value. The following are termination characters whether or not a new value is entered: - A space causes display of the next register (next memory word). - A minus sign causes display of the previous register (previous memory word). - A return returns control to the command scanner. The workspace pointer (W) must be set to the user RAM before attempting to change register contents. M.A. 0200 will be used in the following example. | DISPLAY | ENTER | COMMENTS | |------------|-------|-----------------------------------| | ?_ | W | Inspect workspace pointer address | | ?W=XXXX | | Workspace pointer address | | | 200 | Input new contents | | =XXXX 200 | | | | | (Ret) | New WP address = 0200 | | ?_ | | | | ?R_ | R | | | ?R 0_ | 0 | | | | (Ret) | | | R0=XXXX | 222 | Contents of R0 Enter new contents | | =XXXX 222_ | | Enter new contents | | ?_ | (Ret) | Check to see new R0 contents | | | R | Check to see new No contents | | ?R_ | 0 | | | ?R 0_ | U | | | R0=0222_ | (Ret) | R0 has new contents | ## 3.3.13 SINGLE STEP(S) Syntax S < (Ret) > Description The S command is used to execute one instruction at a time in a program. Each time the S command is entered, a single instruction is executed starting at the address in the Program Counter. After the command is executed, the contents of the workspace pointer, status register on any other workspace register can be examined. The program given in paragraph 3.3 was entered prior to running this example. ## Example: | DISPLAY | ENTER | COMMENTS | |-----------------|-------|------------------------------------------------------| | ?_ | P | Examine PC | | ?P = XXXX_ | r | LXanime ( 0 | | {F = \\\\\_ | 200 | Enter starting address of program | | =XXXX 200 | | | | | (Ret) | | | ?_ | s | Execute 1st step of program (further S key | | ?S 0204_ | 3 | entries execute successive steps) | | :502042 | (Ret) | | | ?_ | | | | | W | Examine workspace pointer Workspace pointer contents | | $?W = 0300_{-}$ | | MADIKShare hourser coureurs | # 3.3.14 WORKSPACE POINTER INSPECT/CHANGE (W) Syntax W < T3 > Description This command allows the user to inspect or change the workspace pointer which is the memory address of register zero. | DISPLAY | ENTER | COMMENTS | | | | | | |------------|-------|----------------------------------------------|--|--|--|--|--| | ?_ | W | | | | | | | | ?W = XXXX_ | 44 | Workspace pointer address Input new contents | | | | | | | =XXXX 44_ | (Ret) | inpat non contains | | | | | | | ?_ | W | Check new address | | | | | | | ?W = 0044_ | VV | New workspace pointer address | | | | | | #### 3.3.15 NEW LINE REQUEST (RET) Syntax (Ret) Description Receipt of a New Line Request command causes the monitor to respond with a carriage return, line feed, and new line request if a terminal is used. If the keyboard is used, the previous display will be blanked and a prompt (?\_) displayed. ## Example: DISPLAY ENTER (LOAD) CPU READY\_ (Ret) # 3.3.16 TERMINAL LOAD/DUMP OPTION (\$) Syntax \$ (Ret) Description When using an external data terminal, entry of the \$command causes all subsequent load and dump memory operations to input from and output to the terminal instead of the audio cassette. Therefore programs could be stored on digital cassette or paper tape by use of the appropriate data terminal. When loading from the terminal, the monitor automatically sends the appropriate control characters (DC1 for playback on and DC3 for playback off) to the terminal to control playback/reader operation. Likewise when dumping to the terminal, the monitor sends control characters (DC2 for record on and DC4 for record off) to initiate record/punch operations. Users should examine the capabilities of their terminals to determine if they are equipped to respond to the playback and record control characters automatically. In cases where terminals are not so equipped, users will be required to initiate the appropriate playback and record operations manually based on the status of the FWD indicator as in the case of the audio cassette. ## 3.4 USER ACCESSIBLE UTILITIES UNIBUG contains seven utility subroutines that perform I/O functions as listed in Table 3-3. These subroutines are called through the XOP (extended operation) assembly language instruction. TABLE 3-3. USER ACCESSIBLE UTILITIES | XOP | Function | Paragraph | | | |-----|--------------------------------------------|-----------|--|--| | 8 | Write 1 Hexadecimal Character to Terminal | 3.4.1 | | | | 9 | Read Hexadecimal Word from Terminal | 3.4.2 | | | | 10 | Write 4 Hexadecimal Characters to Terminal | 3.4.3 | | | | 11 | Echo Character | 3.4.4 | | | | 12 | Write 1 Character to Terminal | 3.4.5 | | | | 13 | Read 1 Character from Terminal | 3.4.6 | | | | 14 | Write Message to Terminal | 3.4.7 | | | - 1. All characters are in ASCII code. - 2. Most of the XOP format examples herein use a register for the source address, however, all XOP's can also use a symbolic memory address or any of the addressing forms available for the XOP instruction. The XOP instruction uses Format 9. The machine language format is given below. | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|---|---|---|---|---|---|---|------|-------|----|----|----|----|----|----|----| | General Format: | 0 | 0 | 1 | 0 | 1 | 1 | D | (XOP | NUMBE | R) | Т | s | | s | R | | Bits 6-9 contain the desired XOP number. Bits 10, 11 indicate the source register address mode (Ts) and bits 12-15 indicate the source register number (SR). An example will best illustrate the use of this format. #### Example: Assume that XOP 8 is to be used to write one hexadecimal character from register five to the display. XOPs 8, 10, and 12 can be used with the display provided that XOP 13 (needed to turn the display on) is added to the program following the required XOP. To illustrate the use of XOP 8 in conjunction with the display, the following example program will be used. | PROGRAM | ADDRESS | HEX CONTENTS | |------------|---------|--------------| | LWPI > 300 | 0200 | 02E0 | | | 0202 | 0300 | | LI 0,3 | 0204 | 0200 | | <b></b> | 0206 | 0003 | | LI 1,2 | 0208 | 0201 | | LI 1/2 | 020A | 0002 | | A 1,0 | 020C | A001 | | XOP 0.8 | 020E | 2E00 | | XOP 1,13 | 0210 | 2F41 | This program adds two numbers (3 and 2) and places their sum in register 0. XOP 8 is used to display the answer and XOP 13 is used to turn the display on. This XOP could be used to display answers in the range of 0 to F (hexadecimal). #### 3.4.1 WRITE ONE HEXADECIMAL CHARACTER TO TERMINAL (XOP 8) Format: XOP Rn,8 The least significant four bits of user register Rn are converted to their ASCII coded hexadecimal equivalent (0 to F) and output on the terminal or display. Control returns to the instruction following the extended operation. ## Example: $Assume \ user \ register \ 5 \ contains \ 203C16. \ The \ assembly \ language \ (A.L.) \ and \ machine \ language \ (M.L.)$ values are shown below. | A.L. | XOP | | R5,8 | 3 | | SEN | ID 4 LS | SB'S O | F R5 T | O TER | MINA | L | | | | | | |------|-----|---|------|---|---|-----|---------|--------|--------|-------|------|----|----|----|----|----|-------| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 1: | 12 | 13 | 14 | 15 | | | M.L. | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | >2EO5 | Terminal Output: C #### 3.4.2 **READ HEXADECIMAL WORD FROM TERMINAL (XOP 9)** Format: **XOP** Rn,9 **DATA** ADDRESS OF CONTINUED EXECUTION IF NULL **NULL IS ENTERED** DATA **ERROR** ADDRESS OF CONTINUED EXECUTION IF NON-HEX NO. ENTERED (NEXT INSTRUCTION) **EXECUTION CONTINUED HERE IF VALID HEX** NUMBER AND TERMINATOR ENTERED Binary representation of the last four hexadecimal digits input from the terminal is accumulated in user register Rn. The termination character is returned in register Rn+1. Valid termination characters are space, minus, comma, and a carriage return. Return to the calling task is as follows: - If a valid termination character is the only input, return is to the memory address contained in the next word following the XOP instruction (NULL above). - If a non-hexadecimal character or an invalid termination character is input, control returns to the memory address contained in the second word following the XOP instruction (ERROR above). - If a hexadecimal string followed by a valid termination character is input, control returns to the word following the DATA ERROR statement above. #### Example: | A.L. | | XOP<br>DAT | Α. | | 9<br>:F80<br>:F86 | RET | TURN | ADDR | CIMAL<br>ESS, II<br>ESS, II | F NO | NUMB | | | | | | | | |------|------|------------|----------------|----------------|-------------------|-----|------|------|-----------------------------|------|------|----|----|----|----|----|----|--------| | M.L. | | Λ. | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | | M.A. | 3F00 | <u></u> | <del>- i</del> | <del>-</del> 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | > 2E46 | | W.A. | | $\vdash$ | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | > 3F80 | | | 3F02 | <u> </u> | 0 | | | | | | | | | | | | | | | > 3F86 | | | 3F04 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | 1 | 0 | / 3500 | If the valid hexadecimal character string 12C is input from the terminal followed by a carriage return, control returns to memory address (M.A.) FFB616 with register 6 containing 012C16 and register 7 containing 000D16. If the hexadecimal character string 12C is input from the terminal followed by an ASCII plus (+) sign, control returns to location FFC616. Registers 6 and 7 are returned to the calling program without being altered. "+" is an invalid termination character. If the only input from the terminal is a carriage return, register 6 is returned unaltered while register 7 contains 000D16. Control is returned to address FFC016. # 3.4.3 WRITE FOUR HEXADECIMAL CHARACTERS TO TERMINAL (XOP 10) Format: XOP Rn,10 The four-digit hexadecimal representation of the contents of user register Rn is output to the terminal or display. Control returns to the instruction following the XOP call. ## Example: Assume register 1 contains 2C4616. A.L. XOP R1,10 WRITE HEX NUMBER Terminal Output: 2C46 ## 3.4.4 ECHO CHARACTER (XOP 11) This is a combination of XOP's 13 (read character) and 12 (write character). A character in ASCII code is read from the keyboard placed in the left byte of Rn, then written (echoed back) to the display. Control returns to the instruction following the XOP after a character is read and written. By using a code to determine a character string termination, a series of characters can be echoed and stored at a particular address. The typewriter program uses this XOP. ## Example: The keyboard will generate a character that will be stored in R10, then written (echoed back) to the display. The following program (Typewriter program) uses XOP 11. The JMP \$-2 instruction allows the program to be continually repeated. | PROGRAM | ADDRESS | HEX CONTENTS | |------------|---------|--------------| | LWPI > 220 | 0200 | 02E0 | | | 0202 | 0220 | | XOP R10,11 | 0204 | 2ECA | | JMP\$-2 | 0206 | 10FE | # 3.4.5 WRITE ONE CHARACTER TO TERMINAL (XOP 12) Format: XOP Rn,12 The ASCII character in the left byte of user register Rn is output to the terminal. The right byte of Rn is ignored. Control is returned to the instruction following the call. # 3.4.6 READ ONE CHARACTER FROM TERMINAL (XOP 13) Format: XOP Rn,13 The ASCII representation of the character input from the terminal is placed in the left byte of user register Rn. The right byte of register Rn is zeroed. When this utility is called, control is returned to the instruction following the call only after a character is input. # 3.4.7 WRITE MESSAGE TO TERMINAL (XOP 14) Format: XOP @MESSAGE,14 # 3.5 UNIBUG ERROR MESSAGE If an error is detected due to incorrect operation, the message "ERR" will be displayed. The following errors can be detected: - Invalid command entered. - Invalid termination character detected. Error 1 is the result of entering an invalid command. As an example, assume that the N key was pressed instead of the M key. An error would be indicated by the display and further entry of the data inhibited. To clear the error, press Ret. Error 2 is the result of entering an invalid termination character. In the event of error 2, the command is terminated. Clear the error using the Ret key then reissue the command and parameters with a valid termination character. #### **SECTION 4** #### SYMBOLIC ASSEMBLER ## 4.1 GENERAL An assembler is a program that interprets assembly language source statements into object code. The TM 990/189 Symbolic Assembler assembles the 69 instructions of the TMS 9980 as well as: - The pseudo instruction NOP which assembles as the instruction JMP \$+2 (i.e., acts as a "no operation" or "go to next instruction") - The following assembler directives (Directives used with the assembler are explained in Section 6): - AORG: Absolute origin of statement (absolute start location) - BSS: Block of memory reserved with starting symbol - DATA: Sixteen-bits of immediate value - END: End of program, exit to monitor, load program counter - EQU: Symbol equated to value in operand - TEXT: String of ASCII coded characters Comments and labels (two characters maximum) can be used with this assembler. The assembler program is contained in a TMS 4732 ROM located at board socket U33. Two UNIBUG commands can be used to call the assembler (A and B). If the A command is used, the previous symbol table will be cleared. If the B command is used, the previous symbol table is kept. ## 4.2 LABELS AND COMMENTS #### 4.2.1 LABELS Labels may consist of one or two characters. The first character must be alphabetic and a second character must be alphanumeric. Labels may be used either as resolved (defined in label field of previous instruction) or unresolved (to be defined in label field of upcoming instructions) references. Labels may be used in the label field only once in a program. ## 4.2.2 COMMENTS Comments can be a part of the source statement. The comment field may include any printable character and is concluded by a return. # 4.2.3 USE DOLLAR SIGN TO INDICATE "AT THIS LOCATION" Use the dollar (\$) sign to indicate a current value of the location counter (the location counter contains the next address at which object will be loaded). If the location counter contains a value of 020016, then the following comments apply as shown in these statements: ``` D1 EQU $ D1 VALUE = LOCATION COUNTER VALUE = HEX 200 E1 EQU $+4 E1 VALUE = LOC COUNTER + 4 = 204 F1 EQU D1 F1 AND D1 HAVE SAME VALUE = HEX 200 LI R7,$ HEX 200 TO R7 LI R8,D1 HEX 200 TO R8 LI R9,$+2 HEX 20A TO R9 (LOC COUNTER NOW AT HEX 208) LI R10,E1 HEX 204 TO R10 ``` #### NOTE In EQU (equate) directives, labels must be equated to either absolute values or defined labels. ## 4.2.4 EXPRESSIONS Expressions can be used containing addition or subtraction functions. For example, if the location counter (contains the next memory address at which object will be loaded) contains 0200<sub>16</sub>, then the following comments apply as shown in these statements: ``` A1 EQU A1 VALUE = LOCATION COUNTER VALUE = HEX 200 B1 EQU $+8 B1 = LOCATION COUNTER + 8 = HEX 208 C1 EQU Α1 C1 = A1 VALUE = HEX 200 LI R0,A1 HEX 200 TO RO LI HEX 204 TO R1 R1,A1+4 LI R2,A1+C1 HEX 400 TO R2 LI R3,A1+B1+C1 HEX 608 TO R3 П R4,A1-B1 HEX FFF8 TO R4 ``` # 4.2.5 CANCEL SOURCE STATEMENT BEING INPUT If it is desired to cancel a source statement in the middle of entering it from the keyboard, press the SHIFT key followed by the letter X key. The current location counter contents will be displayed, waiting for new input. This must be executed prior to entering a return after the source statement. The SHIFT X key is the ASCII cancel function. When using an external terminal, the CANCEL function is generated by holding the CONTROL key while pressing X. ASCII coding is explained in Appendix C. # 4.2.6 TRANSLATE CHARACTERS INTO ASCII CODE USING SINGLE QUOTES If it is desired to translate alphabetical or numerical keyboard values in ASCII code, enclose the characters in single quotes. This is the normal procedure for the TEXT assembler directive (Section 6); however, it can also apply in other situations. For example: | Α | EQU | 'AB' | ASCII FOR AB = HEX 4142 | |------------|------|---------|-------------------------------| | | LI | R1,A | LOAD HEX 4142 IN R1 | | | LI | R1,'AB' | LOAD HEX 4142 IN R1 | | <b>A</b> 1 | DATA | 'AB' | <b>ASSEMBLE HEX 4142 HERE</b> | ## 4.3 ASSEMBLER ACTION The Symbolic Assembler accepts assembly language inputs from the keyboard. As each instruction is input, the assembler interprets it, places the resulting machine code in an absolute address, and prints the machine code (in hexadecimal) next to its absolute address. ## Example: ## 4.4 OPERATION # 4.4.1 CALLING THE ASSEMBLER - Call up the monitor by pressing the LOAD switch and the Ret key. - Press either the A or B key. (If the A command is used, the previous symbol table will be cleared). - Enter the hexadecimal address at which the program is to be assembled. - Press Ret and entry to the assembler will occur. #### Example: | DISPLAY | ENTER | COMMENTS | |------------|--------|---------------------------| | | (LOAD) | | | CPU READY_ | (Ret) | Monitor Entry Gained | | ?_ | Α | Assembler Call | | ?A_ | 0200 | Starting Assembly Address | | ?A 0200_ | (Ret) | | | 0200_ | | Assembler Entry Gained | ## 4.4.2 EXITING TO THE MONITOR Enter the END directive and two returns to cause an exit from the assembler and return control to the monitor. # 4.5 ENTERING INSTRUCTIONS Any of the 69 instructions applicable to the TM 990/189 microcomputer can be interpreted by the Symbolic Assembler. An instruction generally consists of four fields: Label, Opcode, Operand(s), and Comment. The Label field is optional and its omission is indicated by a space. The Label field may be followed by one or more spaces. There should be a single space between the mnemonic and the operand(s). In the case of multiple operands, a single comma should be used between the two. The operand(s) can be followed by a Comment field. The operand should be followed by a space if the Comment field is desired or a return, if not. The Comment field may include any printable character and is concluded by a return. Up to the return ending either the Operand field or the Comment field, the instruction may be cancelled by use of the Cancel command explained in paragraph 4.2.5. - The following example illustrates these functions: - A. Calling the assembler (paragraph 4,4.1) - B. Enter instruction one (paragraph 4.5) - C. Enter instruction two (paragraph 4.5) - D. Exiting to the monitor (paragraph 4.4.2) | DISPLAY | ENTER | COMMENTS | |-------------|-----------|--------------------------------------------| | CPU READY | (LOAD) | | | ?_ | (Ret) | Monitor entry gained | | ?A. | Α | Assembler call | | ?A 0200 | 0200 | Starting assembly address | | 0200 | (Ret) | Assembly | | 00 | (Sp) | Assembler entry gained<br>Omit label field | | LWPI >220_ | LWPI >220 | Enter first instruction | | LVVF1 /22U_ | (Ret) | | The following additional concepts apply to instruction entry: Register numbers are in decimal or hexadecimal. Only decimal register numbers can be predefined (preceded by an R). LI R13, 33 LI >D, 33 2. Jump instruction operand can be \$, \$+n, \$-n, or M where n is a decimal or hexadecimal value of bytes $(+256 \ge n \ge -254)$ and M is a memory address in decimal or hexadecimal. JMP \$+0 JMP \$-2 JMP \$+2 JMP >210 Absolute numerical values can be decimal or hexadecimal. Decimal values have no prefix in an operand. Hexadecimal values are preceded by the greater-than sign ( > ). LI R13, > 33 LI R13, 51 4. Where an address can be either a register or symbolic memory location, the symbolic address is preceded by an at sign (@) to differentiate a numerical memory address from a register number. These alphanumeric labels must be preceded by an @ sign; numerical values preceded by an @ sign will be assembled as an absolute address. | MOV | @ ST, R1 | Move ST Contents to R1 | |-----|---------------|---------------------------------| | Α | @SM, @ > FE00 | Move SM Contents to M.A. > FE00 | ## NOTE Jump and immediate operand instructions do not use the at sign before a symbol. ## 4.6 ERRORS Syntax errors are indicated by an 'ERR' message. A displacement range error (such as with jump instructions and single-bit CRU instructions) will be flagged with an RERR message. 1. Syntax error. The instruction syntax was incorrect: | DISPLAY | ENTER | COMMENTS | |---------|-------|---------------------------------------------------------| | 0200 | | | | 00 | (Sp) | | | | LDA | | | LDAERR_ | (Ret) | Error message (ERR) Use (Ret) and enter proper mnemonic | 2. Range error. The operand is out of range for its field. | DISPLAY | ENTER | COMMENTS | |------------|------------|-------------------------------| | 0200 | | | | 00 | (Sp) | | | LI R44_ | LI R44 | | | | (Ret) | | | LI R44ERR_ | (Ret) | Error message (ERR)<br>Cancel | | 0200 | (Sp) | | | 00 | - | _ | | LI R4,200_ | LI R4, 200 | Enter proper data | | 0200 0204_ | (Ret) | <b>←</b> | | 0202 00C8 | (Ret) | Properly assembled code | | 0202 00C8 | (Ret) | Properly assembled code | 3. Displacement Error. The jump instruction destination is more than +256 or -254 bytes away. | DISPLAY | ENTER | COMMENTS | |-------------------|------------|----------------------------------------------------------------------| | 0200 | (Sp) | | | 00<br>JNC \$+300_ | JNC \$+300 | | | \$+300RERR | (Ret) | Error message (RERR)<br>Cancel and enter proper<br>jump displacement | # 4.7 PSEUDO-INSTRUCTION The assembler also interprets one pseudo-instruction. This pseudo-instruction is not an additional instruction but actually is an additional mnemonic that conveniently represents a member of the instruction set. The NOP mnemonic can be used in place of a JMP \$+2 instruction which is essentially a no-op (no operation). This can be used to replace an existing instruction in memory, or it can be included in code to force additional execution time in a routine. Both NOP and JMP \$+2 assemble to the machine code 100016. # 4.8 TM 990/189 SYMBOLIC ASSEMBLER LISTING ## 4.8.1 LISTING FORMAT Figure 4-1 identifies the different fields of the listing. Figure 4-1. Listing and Source Statement Fields ## 4.8.1.1 Location Counter This is the hexadecimal number showing the location of assembled object code. This location is relative to the beginning of the program; thus it should begin with location 000016. One exception is where an absolute origin assembler directive (AORG) is used. Essentially, the location counter number is the location in memory of the corresponding object code after a program has been loaded into memory. For example, the object code in Figure 4-1 at M.A. FE2416 is 2F2016, at M.A. FE2616 it is FF3416, etc. ## 4.8.1.2 Assembled Object Code This column contains the resulting object code in hexadecimal after the source statement has been assembled. #### 4.8.1.3 Label Field This two-character field contains an alphanumeric label that identifies the location of the source statement. ## 4.8.1.4 Op Code Field This four-character field contains assembly language operation code mnemonics. It is separated from the label field and operand field by at least one space. ## 4.8.1.5 Operand Field This field contains the operands of the instruction. This field is separated from the op code and comment fields by at least one space. ## 4.8.1.6 Comment Field The comments in this field are abbreviated auxiliary data to help further understand the instruction or the data flow. #### **SECTION 5** #### **INSTRUCTION SET FOR THE TM 990/189** ## 5.1 GENERAL This section covers the instruction set used with the TM 990/189 including assembly language and machine language. This instruction set is compatible with other members of the 990 family. Other topics include: - User Memory (paragraph 5.2) - Hardware and software registers (paragraphs 5.3 and 5.4) - Instruction forms and addressing modes (paragraph 5.5) The TM 990/189 microcomputer is designed for use by a variety of users with varying technical backgrounds and available support equipment. Because a TM 990/189 user has the capability of writing his programs in machine language and entering them into memory using the UNIBUG monitor, emphasis is on binary/hexadecimal representations of assembly language statements. The assembly language described herein can be assembled on a 990 family assembler such as the TM 990/189 Symbolic Assembler explained in Section 4. If an assembler is used, this section assumes that the user will be aware of all prerequisites for using the particular assembler including assembler directives. It is also presumed that all users learning this instruction set have a working knowledge in: - ASCII coded character set (described in Appendix C). - Decimal/hexadecimal, binary number system (described in Appendix D). #### 5.2 USER MEMORY The memory provided in the TM 990/189 microcomputer consists of RAM (read/write memory) and ROM (read only memory). The RAM is used for user programs while the ROM contains the monitor and assembler programs. The monitor program provides keyboard commands, I/O programs, and other user utilities. The memory address (M.A.) value is the number of bytes beginning at 000016; thus all word addresses are even values from 000016 to 3FFE16. Figure 5-1 shows the memory map for the TM 990/189. Interrupt and XOP vectors extend from M.A. $0000_{16}$ to M.A. $007F_{16}$ . UNIBUG Monitor workspaces extend from M.A. $0080_{16}$ to M.A. $0147_{16}$ . If the assembler is used, the symbol table begins at M.A. $0146_{16}$ . Four bytes are used for each label; the number of labels that are used will determine the beginning address for user RAM (Y). As an example, if 50 labels are used, 200 bytes will be needed for the label table. The end of the label table will be $0146_{16} + C8_{16} = 20E_{16}$ (note that $200_{10} = C8_{16}$ ). Therefore the start of the permissable user RAM would be M.A. $210_{16}$ in this case. Figure 5-1. Memory Map ## 5.3 HARDWARE REGISTERS Figure 5-2 shows the architecture of the TMS 9980A (MP 9529) microprocessor with affiliated RAM and ROM memory. The TM 990/189 uses three major hardware registers in executing the instruction set: Program Counter (PC), Workspace Pointer (WP), and Status Register (ST). These registers reside in the microprocessor and are controlled by the programmer. #### 5.3.1 PROGRAM COUNTER (PC) This register contains the memory address of the next instruction to be executed. After an instruction image is read in for interpretation by the processor, the PC is incremented by two so that it "points" to the next sequential 16-bit memory word. ## 5.3.2 WORKSPACE POINTER (WP) This register contains the memory address of the beginning of the register file currently being used by the program under execution. This workspace consists of 16 contiguous memory words designated registers 0 to 15. The WP points to register 0. Paragraph 5.4 explains a workspace in detail. Figure 5-2. TMS 9980A With RAM/ROM Memory ## 5.3.3 STATUS REGISTER (ST) The Status Register contains relevant information on preceding instructions and current interrupt level. Included are: - Results of logical and two's complement comparisons (many instructions automatically compare the results to zero). - Carry and overflow. - Odd parity found (byte instructions only). - XOP being executed. - Lowest priority interrupt level that will be currently recognized by the processor. The status register is shown in Figure 5-3. ## 5.3.3.1 Logical Greater Than This bit contains the result of a comparison of words or bytes as unsigned binary numbers. In this case, the most significant bit (MSB) does not indicate a positive or negative sign. The MSB of words being logically compared represents 2<sup>15</sup> (32,768), and the MSB of bytes being logically compared represents 2<sup>7</sup> (128). Figure 5-3. Status Register #### 5.3.3.2 Arithmetic Greater Than The arithmetic greater than bit contains the result of a comparison of words or bytes as two's complement numbers. In this comparison, the MSB of words or bytes being compared represents the sign of the number, zero for positive, or one for negative. ## 5.3.3.3 Equal The equal bit is set when the words or bytes being compared are equal. #### 5.3.3.4 Carry The carry bit is set by a carry out of the MSB of a word or byte (sign bit) during arithmetic operations. The carry bit is used by the shift operation to store the value of the last bit shifted out of the workspace register being shifted. ## 5.3.3.5 Overflow The overflow bit is set when the result of an arithmetic operation is too large or too small to be correctly represented in two's complement (arithmetic) representation. In addition operations, overflow is set when the MSB's of the operands are equal and the MSB of the result is not equal to the MSB of the destination operand. In subtraction operations, the overflow bit is set when the MSB's of the operands are not equal, and the MSB of the result is not equal to the MSB of the destination operand. For a divide operation, the overflow bit is set when the most significant sixteen bits of the dividend (a 32-bit value) are greater than or equal to the divisor. For an arithmetic left shift, the overflow bit is set if the MSB of the workspace register being shifted changes value. For the absolute value and negate instructions, the overflow bit is set when the source operand is the maximum negative value, 800016. #### 5.3.3.6 Odd Parity The odd parity bit is set in byte operations when the parity of the result is odd, and is reset when the parity is even. The parity of a byte is odd when the number of bits having a value of one is odd; when the number of bits having a value of one is even, the parity of the byte is even. #### 5.3.3.7 Extended Operation The extended operation bit of the Status Register is set to one when a software implemented extended operation (XOP) is initiated. #### 5.3.3.8 Status Bit Summary Table 5-1 lists the instruction set and the status bits affected by each instruction. #### **5.4 SOFTWARE REGISTERS** Registers used by programs are contained in memory. This speeds up context-switch time because the content of only one register (WP hardware register) needs to be saved instead of the entire register file. The WP, PC, and ST register contents are saved in a context switch. A workspace is a contiguous 16 word area; its memory location can be designated by placing a value in the WP register through software or a keyboard monitor command. A program can use one or several workspace areas, depending upon register requirements. More than three-fourths of the instructions can address the workspace register file; all shift instructions and most immediate operand instructions use workspace registers exclusively. Figure 5-4 is an example of a workspace file in high-order memory (RAM). A workspace in ROM would be ineffective since it could not be written into. Note that several registers are used by particular instructions. TABLE 5-1. STATUS BITS AFFECTED BY INSTRUCTIONS | A X X X X X X LDCR X X X AB X X X X X LI X X X X ABS X X X X X X LIMI AI X X X X X LWPI ANDI X X X X LWPI BB MOV X X X X BLWP MOVB X X X X BLWP MPY CX X X X NEG X X X X X X CB X X X X NEG X X X X X X X X X X X X X X X X X X X | 1 X | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | AB | | | ABS X X X X X LIMI ANDI X X X X LWPI BL MOV X X X BLWPI MOV X X X MOV X X X CC X X X X MPY MPY CC X X X X MPG X X X X X X X X X X X X X X X X X X X | | | AI | | | ANDI X X X LWPI BLWP MOV X X X BLWP MOVB X X X X MOVB X X X X MOVB X X X X MOVB X X X X MOVB X X X X X X X X X X X X X X X X X X X | | | B MOV X X X BLWP MPY C X X X NEG X X X X C NEG X X X X NEG X X X X NEG X X X X X X X X X X X X X X X X X X X | x - | | BL - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - </td <td>X -</td> | X - | | BLWP - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | | | C | | | CB | | | | | | l a. l., ,, ,, | | | CI | | | CLR RTWP X X X X | x x | | coc x s x x x x x | | | CZC X SB X X X X | х – | | DEC X | | | DECT X | | | DIV | | | IDLE | | | INC X X X X X SOC X X X | | | INCT X X X X SOCB X X X | Х – | | INV X X X SRA X X X X - | | | JEQ SRC X X X - | | | JGT SRL X X X | | | JH STCR X X X | 1 – | | JHE | | | JL | | | JLE | | | JLT SZC X X X | | | JMP SZCB X X X | х – | | JNC TB X | | | JNE | 2 2 | | JNO XOP 2 2 2 2 2 | 2 2 | | JOC XOR X X X | | | JOP | | #### NOTES <sup>1.</sup> When an LDCR or STCR instruction transfers eight bits or less, the OP bit is set or reset as in byte instructions. Otherwise these instructions do not affect the OP bit. <sup>2.</sup> The X instruction does not affect any status bit; the instruction executed by the X instruction sets status bits normally for that instruction. When an XOP instruction is implemented by software, the XOP bit is set, and the subroutine sets status bits normally. Figure 5-4. Workspace Example ## 5.5 INSTRUCTION FORMATS AND ADDRESSING MODES Instructions designate the operations for a computer to perform. The TM 990/189 microcomputer can execute 69 instructions. To implement this instruction set, nine instruction formats are used. Figure 5-5 shows the TM 990/189 instruction formats. In order to construct instructions in machine language, the programmer must have a knowledge of the fields and formats of the instructions. This knowledge is often very important in debugging operations because it allows the programmer to change bits within an instruction in order to solve an execution problem. Each 16 bit word is broken down into fields. As an example, Format 1 consists of six different fields. These fields are Op Code, B, T<sub>D</sub>, DR, T<sub>S</sub> and SR. Examination of other formats in Figure 5-5 will yield three more fields: these fields are Signed Displacement, C, and R. These nine fields can be divided into five groups. A brief description of each field group follows: - Op Code purpose of instruction (op codes are listed alphabetically in Table 5-2 and by format number in Table 5-3). - 2. T<sub>D</sub> or T<sub>S</sub> Type of Addressing Mode used for destination or source registers or if symbolic addressing is used. | FORMAT | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | GENERAL USE | |--------|---|-------|------|------|------|-------|---|-----|----|---|-------|--------|------|--------|----|----|---------------| | 1 | С | P COD | E | В | 1 | D | Τ | | DR | | 1 | s | Г | | R | | ARITHMETIC | | 2 | | | | OP C | ODE | | | | | | SIGNE | D DISF | LACE | MENT | | | JUMP | | 3 | | | OP C | ODE | | | Ī | 1 | NR | | 1 | S | | 5 | R | | LOGICAL | | 4 | | | OP 0 | ODE | | | | | С | | 1 | s | | 5 | R | | CRU | | 5 | | | | OP C | ODE | | | | | | С | | | | R | | SHIFT | | 6 | | | | | OP C | ODE | | | | | | S | | 5 | R | | PROGRAM | | 7 | | | | | 0 | P COD | E | | | | | | N | OT USI | D | | CONTROL | | 8 | | | | | C | P COD | E | | | | | N | | **** | R | | IMMEDIATE | | 9 | | | OP C | ODE | | | | - 1 | DR | | 1 | S | | | R | | MPY, DIV, XOP | | KEY | | |------------|-----------------------------------| | В | BYTE INDICATOR (1=BYTE) | | $\tau_{D}$ | DESTINATION ADDRESS TYPE* | | DR | DESTINATION REGISTER | | $T_S$ | SOURCE ADDRESS TYPE* | | SR | SOURCE REGISTER | | С | CRU TRANSFER COUNT OR SHIFT COUNT | | R | REGISTER | | N | NOT USED | | *TD OR TS | ADDRESS MODE TYPE | |-----------|--------------------------------------------------------| | 00 | DIRECT REGISTER | | 01 | INDIRECT REGISTER | | | SYMBOLIC MEMORY ADDRESSING, NOT INDEXED (SR OR DR = 0) | | 10 | SYMBOLIC MEMORY ADDRESSING, INDEXED (SR OR DR > 0) | | 11 | INDIRECT REGISTER, AUTOINCREMENT REGISTER | Figure 5-5. TM 990/189M Instruction Formats - R, DR, SR register fields, R (one register involved), DR (destination register), and SR (source register). - Signed Displacement a signed word (not byte) count to be added to the program counter in jump instructions or a signed value to be added to the CRU base address in single-bit CRU instructions. - 5. C number of bits to be transferred or shifted. For C=1 to C=15, 1 to 15 bits will be transferred or shifted. If C=0, 16 bits will be transferred or the shift count will be in the LSB's of register 0. TABLE 5-2. OP CODES (ALPHABETICAL) | Mnemonic | Op Code (Binary Value)<br>012345678910 | Op Code<br>(Hex Value)* | Format* | |----------|----------------------------------------|-------------------------|---------| | ^ | 1010 | А | 1 | | A | 1011 | B | 1 | | AB | | 074 | 6 | | ABS | 0000011101 | | 8 | | Al | 0000010001 | 022 | | | ANDI | 0000010010 | 024 | 8 | | В | 0000010001 | 044 | 6 | | BL | 0000011010 | 068 | 6 | | BLWP | 0000010000 | 040 | 6 | | C | 1000 | 8 | 1 | | СВ | 1001 | 9 | 1 | | ci l | 00000010100 | 028 | 8 | | - 1 | 00000011110 | 03C | 7 | | CKOF | | 03A | 7 | | CKON | 00000011101 | 1 | 6 | | CLR | 0000010011 | 04C | | | coc | 001000 | 20 | 3 | | czc | 001001 | 24 | 3 | | DEC | 0000011000 | 060 | 6 | | DECT | 0000011001 | 064 | 6 | | DIV | 001111 | 3C | 3 | | IDLE | 00000011010 | 034 | 7 | | | | 058 | 6 | | INC | 0000010110 | | 6 | | INCT | 0000010111 | 05C | | | INV | 0000010101 | 054 | 6 | | JEQ | 00010011 | 13 | 2 | | JGT | 00010101 | 15 | 2 | | JH | 00011011 | 1B | 2 | | JHE | 00010100 | 14 | 2 | | JL | 00011010 | 1A | 2 | | JLE | 00010010 | 12 | 2 | | - | 00010001 | 11 | 2 | | JLT | | 10 | 2 | | JMP | 00010000 | | 2 | | JNC | 00010111 | 17 | | | JNE | · 00010110 | 16 | 2 | | JNO | 00011001 | 19 | 2 | | JOC | 00011000 | 18 | 2 | | JOP | 00011100 | 1C | 2 | | LDCR | 001100 | 30 | 4 | | LI | 0000010000 | 020 | 8 | | LIMI | 0000011000 | 030 | 8 | | | 00000011111 | 03E | 7 | | LREX | | 02E | 8 | | LWPI | 0000010111 | 1 | 1 | | MOV | 1100 | C | | | MOVB | 1101 | D | 1 | | MPY | 001110 | 38 | 3 | | NEG | 0000010100 | 050 | 6 | | ORI | 00000010011 | 026 | 8 | | RSET | 0000011011 | 036 | 7 | | RTWP | 00000011100 | 038 | 7 | | S | 0110 | 6 | 1 | | SB | 0111 | 7 | 1 | | | | 1D | 2 | | SBO | 00011101 | | 2 2 | | SBZ | 00011110 | 1E | | | SETO | 0000011100 | 070 | 6 | | SLA | 00001010 | 0A | 5 | | SOC | 1110 | E | 1 | | SOCB | 1111 | F | 1 | | SRA | 00001000 | 08 | 5 | TABLE 5-2. OP CODES (ALPHABETICAL) (Concluded) | Mnemonic | Op Cod (Binary Value)<br>012345678910 | Op Code<br>(Hex Value)* | Format* | |----------|---------------------------------------|-------------------------|---------| | SRC | 00001011 | OB | 5 | | SRL | 00001001 | 09 | 5 | | STCR | 001101 | 34 | 4 | | STST | 0000010110 | 02C | 8 | | STWP | 00000010101 | 02A | 8 | | SWPB | 0000011011 | 06C | 6 | | SZC | 0100 | 4 | 1 | | SZCB | 0101 | 5 | 1 | | ТВ | 00011111 | 1F | 2 | | X | 0000010010 | 048 | 6 | | XOP | 001011 | 2C | 9 | | XOR | 001010 | 28 | 3 | TABLE 5-3. OP CODES BY FORMAT | Format No. | Mnemonic | Op Code<br>012345678910 | В | Op Code<br>(Hex Value)* | |------------------------------------------------|----------|-------------------------|---|-------------------------| | 1 | A | 101 | 0 | A | | 1 | AB | 101 | 1 | В | | 1 | С | 100 | 0 | 8 | | 1 | СВ | 100 | 1 | 9 | | 1 | MOV | 110 | 0 | l c | | 1 | MOVB | 110 | 1 | D | | 1 | S | 011 | 0 | 6 | | 1 | SB | 011 | 1 | 7 | | 1 | soc | 111 | 0 | E | | 1 | SOCB | 111 | 1 | l F | | 1 | SZC | 010 | 0 | 4 | | 1 | SZCB | 010 | 1 | 5 | | 2 | JEQ | 00010011 | | 13 | | 2 | JGT | 00010101 | | 15 | | 2 | JH | 00011011 | ] | 1B | | 2 | JHE | 00010100 | | 14 | | 2 | JL | 00011010 | | 1A | | 2 | JLE | 00010010 | | 12 | | 2 | JLT | 00010001 | | 11 | | 2 | JMP | 00010000 | | 10 | | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2 | JNC | 00010111 | | 17 | | 2 | JNE | 00010110 | | 16 | | 2 | JNO | 00011001 | | 19 | | 2 | JOC | 00011000 | | 18 | | 2<br>2<br>2<br>2<br>2<br>2 | JOP | 00011100 | | 1C | | 2 | SBO | 00011101 | 1 | 1D | | 2 | SBZ | 00011110 | | 1E | <sup>\*</sup>NOTES 1. The op code value for Format 1 instructions was obtained by combining the 3-bit op code and the 1-bit byte field. <sup>2.</sup> To obtain the op code (hex value) for a particular instruction, divide the op code bits into groups of four starting at the left and convert each group into its hex equivalent (supply zeroes to complete any incomplete block of four). TABLE 5-3. OP CODES BY FORMAT (Concluded) | Format No. | Mnemonic | Op Code<br>012345678910 | В | Op Code<br>(Hex Value)* | | |------------|----------|-------------------------|---|-------------------------|--| | 2 | TB | 00011111 | | 1F | | | 3 | coc | 001000 | | 20 | | | 3 | CZC | 001001 | | 24 | | | 3 | XOR | 001010 | | 28 | | | 3 | MPY | 001110 | | 38 | | | 3 | DIV | 001111 | | 36 | | | 4 | LDCR | 001100 | | 30 | | | 4 | STFCR | 001101 | | 34 | | | 5 | SLA | 00001010 | | 0A | | | 5 | SRA | 00001000 | | 08 | | | 5 | SRC | 00001011 | | OB | | | 5 | SRL | 00001001 | | 09 | | | 6 | В | 0000010001 | | 044 | | | 6 | BL | 0000011010 | | 068 | | | 6 | BLWP | 0000010000 | | 040 | | | 6 | CLR | 0000010011 | | 04C | | | 6 | SETO | 0000011100 | 1 | 070 | | | 6 | INV | 0000010101 | | 054 | | | 6 | NEG | 0000010100 | | 050 | | | 6 | ABS | 0000011101 | | 074 | | | 6 | SWPB | 0000011011 | | 06C | | | 6 | INC | 0000010110 | | 058 | | | 6 | INCT | 0000010111 | | 05C | | | 6 | DEC | 0000011000 | | 060 | | | 6 | DECT | 0000011001 | | 064 | | | 6 | X X | 0000010010 | | 048 | | | 7 | IDLE | 00000011010 | | 034 | | | 7 | RSET | 00000011011 | İ | 036 | | | 7 | CKOF | 00000011110 | İ | 03C | | | 7 | CKON | 00000011101 | İ | 03A | | | 7 | LREX | 00000011111 | | 03E | | | 7 | RTWP | 00000011100 | | 038 | | | 8 | Al | 00000010001 | | 022 | | | 8 | ANDI | 00000010010 | İ | 024 | | | 8 | CI | 00000010100 | | 028 | | | 8 | L | 0000010000 | | 020 | | | 8 | ÖRI | 00000010011 | | 026 | | | 8 | LWPI | 00000010111 | ł | 02E | | | 8 | LIMI | 00000011000 | 1 | 030 | | | 8 | STST | 00000010110 | 1 | 02C | | | 8 | STWP | 00000010101 | | 02A | | | 9 | XOP | 001011 | | 2C | | <sup>\*</sup>NOTES 1. The op code value for Format 1 instructions was obtained by combining the 3-bit op code and the 1-bit byte field. <sup>2.</sup> To obtain the op code (hex value) for a particular instruction, divide the op code bits into groups of four starting at the left and convert each group into its hex equivalent (supply zeroes to complete any incomplete block of four). #### 5.5.1 ADDRESSING MODES The TM 990/189 microcomputer provides seven addressing modes. The addressing modes are as follows: - 1. Direct Register Addressing - 2. Indirect Register Addressing - 3. Indirect Register Autoincrement Addressing - 4. Symbolic Memory Addressing, Not Indexed - 5. Symbolic Memory Addressing, Indexed - 6. Immediate Addressing - 7. Program Counter Relative Addressing These addressing modes are described in the following paragraphs. ## 5.5.1.1 Direct Register Addressing (T=002) In direct register addressing, execution involves data contained within one of the 16 workspace registers. In the first example in Figure 5-6, both the source and destination operands are registers as noted in the assembly language example at the top of the figure. Both T fields contain 002 to denote direct register addressing and their associated register fields contain the binary value of the number of the register affected. The 1102 in the op code field identifies this instruction as a move instruction. Since the B field contains a zero, the data moved will be the full 16 bits of the register (1 byte instruction addressing a register would address the left byte of the register). The instruction specifies moving the contents of register 1 to register 4, thus changing the contents of register 4 to the same value as in register 1. Note that the assembly language statement is constructed so that the source register is the first item in the operand while the destination register is the second item in the operand. This order is reversed in the machine language construction with the destination register and its T field first and the source register and its T field second. ## 5.5.1.2 INDIRECT REGISTER ADDRESSING (T=012) In indirect register addressing, the register does not contain the data to be affected by the instruction; instead, the register contains the address within memory of where that data is stored. For example, the instruction in Figure 5-7 specifies to move the contents of register 1 to the address which is contained in register 4 (indirect register 4). (Note that an indirect register address is written as a term preceded by an asterisk (\*).) Instead of moving the value in register 1 to register 4 as was the case in Figure 5-6, the CPU must first read in the 16-bit value in register 4 and use that value as a memory address at which location the contents of register 1 will be stored. In the example, register 4 contains the value 3D00<sub>16</sub>. This instruction stores the value in register 1 into memory address (M.A.) 3D00<sub>16</sub>. ## EXAMPLE 1 ## EXAMPLE 2 Figure 5-6. Direct Register Addressing Examples MOV R1,\*R4 MOVE THE CONTENTS OF RI (SOURCE) TO ADDRESS IN R4 (DESTINATION) Figure 5-7. Indirect Register Addressing Example In direct register addressing, the contents of a register are addressed. In indirect register addressing, the CPU goes to the register to find out what memory location to address. This form of addressing is especially suited for repeating an instruction while accessing successive memory addresses. For example, if you wished to add a series of numbers in 100 consecutive memory locations, you could place the address of the first number in a register, and execute and add indirect through that register, causing the contents of the first memory address (source operand) to be added to another register or memory address (destination operand). Then you could increment the contents of the register containing the address of the number, loop back to the add instruction, and repeat the add, only this time you will be adding the contents of the next memory address to the accumulator (destination operand). This way a whole string of data can be summed using a minimum of instructions. Of course, you would have to include control instructions that would signal when the entire list of 100 addresses have been added, but there are obvious advantages in speed of operation, better utilization of memory space, and ease in programming. ## 5.5.1.3 Indirect Register Autoincrement Addressing (T=112) Indirect register autoincrement addressing is the same as indirect register addressing (paragraph 5.5.1.2) except for an additional feature — automatic incrementation of the register. This saves the requirement of adding an increment (by one or two) instruction to increment the register being used in the indirect mode. The increment will be a value of one for byte instructions (e.g., add byte or AB) or a value of two for full word instructions (e.g., add word or A). In assembly language the register number is preceded by an asterisk (\*) and followed by a plus sign (+) as shown in Figure 5-8. Note in the figure that the contents of register 4 was incremented by two since the instruction was a move word (vs. byte) instruction. If the example used a move byte instruction, the contents of the register would be incremented by one so that successive bytes would be addressed (the 16-bit word addresses in memory are always even numbers or multiples of two since each contains two bytes). Bytes are also addressed by various instructions of the 990 instruction set. Note that only a register can contain the indirect address. Figure 5-8. Indirect Register Autoincrement Addressing Example # 5.5.1.4 Symbolic Memory Addressing, Not Indexed (T=102) This mode does not use a register as an address or as a container of an address. Instead, the address is a 16-bit value stored in the second or third word of the instruction. The SR or DR fields will be all zeroes as shown for the destination register field in the first example of Figure 5-9. When the T field contains 102, the CPU retrieves the contents of the memory location and uses these contents as the effective address. In assembly language, a symbolic address is preceded by an at sign (@) to differentiate a numerical memory address from a register number. All alphanumeric labels must be preceded by an @ sign; numerical values preceded by an @ sign will be assembled as an absolute address. In the second example in Figure 5-9, both the source and destination operands are symbolic memory addresses. In this case, the source address is the first word following the instruction and the destination is the second word following the instruction in machine language. #### EXAMPLE 1 ASSEMBLY LANGUAGE: MOV R1,@>3F00 MOVE THE CONTENTS OF R1 TO ADDRESS>3F00 #### NOTE The > sign indicates hexidecimal representation. MACHINE LANGUAGE: | | OP CODE | | В | ™ <sub>D</sub> | | | DR | | TS | | SR | | | | | | | |----------|---------|---|---|----------------|---|---|----|---|----|---|----|----|----|----|----|----|--------| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | | 1st WORD | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | O | 0 | 0 | 0 | 1 | > C801 | | 2nd WORD | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | > 3F00 | ### EXAMPLE 2 ASSEMBLY LANGUAGE: MOV @>3F0A,@>3F08 MOVE THE CONTENTS OF >3F0A T0 >3F08 MACHINE LANGUAGE: OP CODE TD DR $\tau_{\text{S}}$ SR 0 10 11 12 14 15 1st WORD 0 0 1 0 0 0 0 0 1 0 0 0 >C820 0 0 2nd WORD 0 0 > 3F0A(SOURCE) 3rd WORD 0 0 0 1 0 0 0 >3F08(DESTINATION) | M.A. | BEFORE | AFTER | |------|--------|-------| | 3F08 | FFFF | 0000 | | 3F0A | 0000 | 0000 | | | | | Figure 5-9. Symbolic Memory Addressing Examples # 5.5.1.5 Symbolic Memory Addressing, Indexed (T=102) Note that the T field for indexed as well as non-indexed symbolic addressing is the same (10<sub>2</sub>). In order to differentiate between the two different modes, the associated SR or DR field is interrogated; if this field is all zeroes (0000<sub>2</sub>), non-indexed addressing is specified; if the SR or DR field is greater than zero, indexing is specified and the non-zero value is the index register number. As a result, register 0 cannot be used as an index register. In assembly language, the symbolic address is followed by the number of the index register in parentheses. In the example in Figure 5-10, the source operand is non-indexed symbolic memory addressing while the destination operand is indexed symbolic memory addressing. In this case, the destination effective address is the sum of the 3F02<sub>16</sub> value in the source memory address word plus the value in the index register (0004<sub>16</sub>). The effective address in this case is 3F06<sub>16</sub> as shown by the addition in the left part of the figure. Note that only symbolic addressing can be indexed. Figure 5-10. Symbolic Memory Addressing, Indexed Example #### 5.5.1.6 Immediate Addressing This mode allows an absolute value to be specified as an operand; this value is used in connection with a register contents or is loaded into the WP or the Status Register interrupt mask. Examples are shown below: | LI | R2, 100 | LOAD 100 INTO REGISTER 2 | |------|----------|---------------------------------------------| | CI | R8,> 100 | COMPARE R8 CONTENTS TO > 100, RESULTS IN ST | | LWPI | > 3C00 | SET WP TO MA > 3C00 | ## 5.5.1.7 Program Counter Relative Addressing This mode allows a change in Program Counter contents, either an unconditional change or a change conditional on Status Register contents. Examples are shown below: | JMP | <b>\$</b> +6 | JUMP TO LOCATION, 6 BYTES FORWARD | |-----|--------------|---------------------------------------------------| | JMP | THERE | JUMP TO LOCATION LABELLED THERE | | JEQ | <b>\$+4</b> | IF ST EQ BIT = 1, JUMP 4 BYTES $(MA + 4)$ | | JMP | > 3E26 | JUMP TO M.A. > 3E26 (LINE-BY-LINE ASSEMBLER ONLY) | The dollar symbol (\$) means "from this address"; thus, \$+6 means "this address plus 6 bytes." #### 5.6 INSTRUCTIONS Table 5-4 lists terms used in describing the instructions of the TM 990/189. Table 5-5 is an alphabetical list of instructions. Table 5-6 is a numerical list of instructions by op code. Examples are shown in both assembly language (A.L.) and machine language (M.L.). The greater-than sign (>) indicates hexadecimal. **TABLE 5-4. INSTRUCTION DESCRIPTION TERMS** | TERM | DEFINITION | TERM | DEFINITION | |------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | B<br>C<br>DR<br>DA<br>IOP<br>LSB(n)<br>M.A.<br>MSB(n)<br>N | Byte indicator (1 = byte, 0 · word) Bit count Destination address register Destination address Immediate operand Least significant (right most) bit of (n) Memory Address Most significant (left most) bit of (n) Don't care | T <sub>D</sub> T <sub>S</sub> WR or R WRn or Rn (n) a → b {a} → b [n] + | Destination address modifier Source address modifier Workspace register Workspace register n Contents of n a is transferred to b Contents of a are transferred to b Absolute value of n Arithmetic addition | | PC<br>Result<br>SR<br>SA<br>ST<br>STn | Program counter Result of operation performed by instruction Source address register Source address Status register Bit n of status register | AND OR (+) n > | Arithmetic subtraction Logical AND Logical OR Logical exclusive OR Logical complement of n Hexadecimal value | # TABLE 5-5. INSTRUCTION SET, ALPHABETICAL INDEX | ASSEMBLY<br>LANGUAGE<br>MNEMONIC | MACHINE<br>LANGUAGE<br>OP CODE | FORMAT | STATUS REG.<br>BITS<br>AFFECTED | RESULT<br>COMPARED<br>TO ZERO | INSTRUCTION | |----------------------------------|--------------------------------|--------|---------------------------------|-------------------------------|--------------------------------------------| | A | A000 | 1 | 0-4 | х | Add (word) | | AB | В000 | 1 | 0-5 | x | Add (byte) | | ABS | 0740 | 6 | 0-2 | x [ | Absolute Value | | Al | 0220 | 8 | 0-4 | x | Add Immediate | | ANDI | 0240 | 8 | 0-2 | × | AND Immediate | | В | 0440 | 6 | | 1 | Branch | | BL | 0680 | 6 | - | i | Branch and Link (R11) | | BLWP | 0400 | 6 | .ee | i | Branch, New Workspace Pointer | | C | 8000 | 1 | 0-2 | | Compare (word) | | СВ | 9000 | 1 | 0-2,5 | | Compare (byte) | | CI | 0280 | 8 | 0-2 | | Compare Immediate | | CKOF | 03C0 | 7 | | | User Defined | | CKON | 03A0 | 7 | - | | User Defined | | CLR | 04C0 | 6 | - | | Clear Operand | | COC | 2000 | 3 | 2 | | Compare Ones Corresponding | | CZC | 2400 | 3 | 2 | | Compare Zeroes Corresponding | | DEC | 0600 | 6 | 0-4 | x | Decrement (by one) | | DECT | 0640 | 6 | 0-4 | × | Decrement (by two) | | DIV | 3C00 | 9 | 4 | | Divide | | IDLE | 0340 | 7 | | | Computer Idle | | INC | 0580 | . 6 | 0-4 | × | Increment (by one) | | INCT | 05C0 | 6 | 0-4 | × | Increment (by two) | | INV | 0540 | 6 | 0-2 | × | Invert (One's Complement) | | JEQ | 1300 | 2 | - | | Jump Equal (ST2-1) | | JGT | 1500 | 2 | - | | Jump Greater Than (ST1-1), Arithmetic | | JH | 1800 | 2 | | | Jump High (STO-1 and ST2-0), Logical | | JHE | 1400 | 2 | - | | Jump High or Equal (ST0 or ST2=1), Logical | | JL | 1A00 | 2 | - | | Jump Low (ST0 and ST2=0), Logical | | JLE | 1200 | 2 | - | | Jump Low or Equal (ST0=0 or ST2=1), Logica | | JLT | 1100 | 2 | _ | | Jump Less Than (ST1 and ST2=0), Arithmetic | | JMP | 1000 | 2 | | | Jump Unconditional | | JNC | 1700 | 2 | - | | Jump No Carry (ST3=0) | | JNE | 1600 | 2 | | | Jump Not Equal (ST2=0) | | ONL | 1900 | 2 | - | | Jump No Overflow (ST4-0) | | JOC | 1800 | 2 | _ | | Jump On Carry (ST3=1) | TABLE 5-5. INSTRUCTION SET, ALPHABETICAL INDEX (Concluded) | ASSEMBLY<br>LANGUAGE<br>MNEMONIC | MACHINE<br>LANGUAGE<br>OP CODE | FORMAT | STATUS REG.<br>BITS<br>AFFECTED | RESULT<br>COMPARED<br>TO ZERO | INSTRUCTION | |----------------------------------|--------------------------------|--------|---------------------------------|-------------------------------|-----------------------------------------------------------------| | JOP | 1 <b>C</b> 00 | 2 | _ | | Jump Odd Parity (ST5-1) | | LDCR | 3000 | 4 | 0-2,5 | × | Load CRU | | LI | 0200 | 8 | -140 | x | Load Immediate | | LIMI | 0300 | 8 | 12-15 | | Load Interrupt Mask Immediate | | LREX | 03E0 | 7 | 12-15 | | Load and Execute | | LWPI | 02E0 | 8 | | ĺ | Load Immediate to Workspace Pointer | | MOV | C000 | 1 | 0-2 | × | Move (word) | | MOVB | D000 | 1 | 0-2,5 | x | Move (byte) | | MPY | 3800 | 9 | _ ' | | Multiply | | NEG | 0500 | 6 | 0-2 | × | Negate (Two's Complement) | | ORI | 0260 | 8 | 0-2 | × | OR Immediate | | RSET | 0360 | 7 | 12-15 | ,, | Reset AU | | RTWP | 0380 | 7 | 0-15 | | Return from Context Switch | | s | 6000 | 1 | 0-4 | x | Subtract (word) | | SB | 7000 | 1 | 0-5 | × | Subtract (byte) | | SBO | 1D00 | 2 | | | Set CRU Bit to One | | SBZ | 1E00 | 2 | _ | | Set CRU Bit to Zero | | SETO | 0700 | 6 | | 1 | Set Ones | | SLA | 0A00 | 5 | 0-4 | × | Shift Left Arithmetic | | soc | E000 | 1 | 0-2 | x | Set Ones Corresponding (word) | | SOCB | F000 | 1 | 0-2,5 | × | Set Ones Corresponding (byte) | | SRA | 0800 | 5 | 0-3 | x | Shift Right (sign extended) | | SRC | 0В00 | 5 | 0-3 | x | Shift Right Circular | | SRL | 0900 | 5 | 0.3 | â | Shift Right Logical | | STCR | 3400 | 4 | 0-2,5 | x | Store From CRU | | STST | 02C0 | 8 | | | | | STWP | 02A0 | 8 | _ 1 | | Store Status Register Store Workspace Pointer | | SWPB | 06C0 | 6 | | 1 | Store workspace Pointer Swap Bytes | | szc | 4000 | 1 | 0-2 | × | Set Zeroes Corresponding (word) | | SZCB | 5000 | i | 0-2,5 | x | Set Zeroes Corresponding (word) Set Zeroes Corresponding (byte) | | тв | 1F00 | 2 | 2 | | Test CRU Bit | | x | 0480 | 6 | 2 | | | | XOP | 2000 | 9 | 6 | j | Execute | | XOR | 2800 | 3 | 0-2 | × | Extended Operation Exclusive OR | | | | | 0.2 | ^. | EXCIUSIVE ON | TABLE 5-6. INSTRUCTION SET, NUMERICAL INDEX | MACHINE<br>LANGUAGE<br>OP CODE<br>(HEXADECIMAL) | ASSEMBLY<br>LANGUAGE<br>MNEMONIC | INSTRUCTION | FORMAT | STATUS BITS<br>AFFECTED | |-------------------------------------------------|----------------------------------|----------------------------|--------|-------------------------| | 0200 | LI | Load Immediate | 8 | 0-2 | | 0220 | Al | Add Immediate | 8 | 0-4 | | 0240 | ANDI | And Immediate | 8 | 0-2 | | 0260 | ORI | Or Immediate | 8 | 0-2 | | 0280 | CI | Compare Immediate | 8 | 0-2 | | · · | | 1 ' | 8 | _ | | 02A0 | STWP | Store WP | 8 | _ | | 02C0 | STST | Store ST | 8 | _ | | 02E0 | LWPI | Load WP Immediate | 8 | 12-15 | | 0300 | LIMI | Load Int. Mask | | 1 | | 0340 | IDLE | Idle | 7 | _ | | 0360 | RSET | Reset AU | 7 | 12-15 | | 0380 | RTWP | Return from Context Sw. | 7 | 0-15 | | | CKON | User Defined | 7 | _ | | 03A0 | CKOF | User Defined | 7 | - | | 03C0 | 1 | Load & Execute | 7 | - | | 03E0 | LREX | | • | | | 0400 | BLWP | Branch; New WP | 6 | _ | | 0440 | В | Branch | 6 | _ | | 0480 | × | Execute | 6 | _ | | 04C0 | CLR | Clear to Zeroes | 6 | | | 0500 | NEG | Negate to Ones | 6 | 0-2 | | | INV | Invert | 6 | 0-2 | | 0540 | 1 | Increment by 1 | 6 | 0-4 | | 0580 | INC | Increment by 2 | 6 | 0-4 | | 05C0 | INCT | Decrement by 1 | 6 | 0-4 | | 0600 | DEC | 1 | 6 | 0-4 | | 0640 | DECT | Decrement by 2 | | _ | | 0680 | BL | Branch and Link | 6 | _ | | 06C0 | SWPB | Swap Bytes | 6 | _ | | 0700 | SETO | Set to Ones | 6 | 0-2 | | 0740 | ABS | Absolute Value | 6 | - | | 0800 | SRA | Shift Right Arithmetic | 5 | 0-3 | | 0900 | SRL | Shift Right Logical | 5 | 0-3 | | 1 | SLA | Shift Left Arithmetic | 5 | 0-4 | | 0A00 | SRC | Shift Right Circular | 5 | 0-3 | | 0800 | | Unconditional Jump | 2 | _ | | 1000 | JMP<br>JLT | Jump on Less Than | 2 | _ | | 1100 | | 1 | 2 | _ | | 1200 | JLE | Jump on Less Than or Equal | 2 | _ | | 1300 | JEQ | Jump on Equal | 2 | _ | | 1400 | JHE | Jump on High or Equal | 2 | _ | | 1500 | JGT | Jump on Greater Than | 2 | | | 1600 | JNE | Jump on Not Equal | | _ | | 1700 | JNC | Jump on No Carry | 2 | - | | 1800 | JOC | Jump on Carry | 2 | - | | 1900 | JNO | Jump on No Overflow | 2 | - | | 1900<br>1A00 | JL | Jump on Low | 2 | - | | 1800 | JH | Jump on High | 2 | - | | 1 | 1 | | 2 | _ | | 1000 | JOP | Jump on Odd Parity | 2 | _ | | 1D00 | SBO | Set CRU Bits to Ones | 2 | _ | | 1E00 | SBZ | Set CRU Bits to Zeroes | 2 | 2 | | 1F00 | ј тв | Test CRU Bit | 3 | 2 | | 2000 | coc | Compare Ones Corresponding | | | TABLE 5-6. INSTRUCTION SET, NUMBERICAL INDEX (Concluded) | MACHINE<br>LANGUAGE<br>OP CODE<br>(HEXADECIMAL | ASSEMBLY<br>LANGUAGE<br>MNEMONIC | INSTRUCTION | FORMAT | STATUS BITS<br>AFFECTED | |------------------------------------------------|----------------------------------|---------------------------------|--------|-------------------------| | 2400 | czc | Compare Zeroes Corresponding | 3 | 2 | | 2800 | XOR | Exclusive Or | 3 | 0-2 | | 2C00 | XOP | Extended Operation | 9 | | | 3000 | LDCR | Load CRU | 4 | 0-2,5 | | 3400 | STCR | Store CRU | 4 | 0-2,5 | | 3800 | MPY | Multiply | 9 | _ | | 3C00 | DIV | Divide | 9 | 4 | | 4000 | SZC | Set Zeroes Corresponding (Word) | 1 | 0-2 | | 5000 | SZCB | Set Zeroes Corresponding (Byte) | 1 | 0-2,5 | | 6000 | s | Subtract Word | 1 | 0-4 | | 7000 | SB | Subtract Byte | 1 | 0-5 | | 8000 | C | Compare Word | 1 | 0-2 | | 9000 | СВ | Compare Byte | 1 | 0-2,5 | | A000 | A | Add Word | 1 | 0-4 | | B000 | AB | Add Byte | 1 | 0-5 | | C000 | MOV | Move Word | 1 | 0-2 | | D000 | MOVB | Move Byte | 1 1 | 0-2,5 | | E000 | soc | Set Ones Corresponding (Word) | 1 | 0-2 | | F000 | SOCB | Set Ones Corresponding (Byte) | 1 1 | 0-2,5 | # 5.6.1 FORMAT 1 INSTRUCTIONS These are dual operand instructions with multiple addressing modes for source and destination operands. ## **GENERAL FORMAT:** | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |---|-------|---|---|---|---|---|---|---|---|----|----|----|----|----|----| | 0 | P COD | E | В | 1 | D | | C | R | | T | s | | s | R | | If B = 1, the operands are bytes and the operand addresses are byte addresses. If B=0, the operands are words and the operand addresses are word addresses. | | ОР | co | DE | В | MEANING | RESULT<br>COMPARED | STATUS<br>BITS | DESCRIPTION | |-------------|-----|----|----|-----|--------------------------------|--------------------|----------------|-------------------------------------------------------------------------------| | MNEMONIC | 0 | 1 | 2 | 3 | MEANING | то о | AFFECTED | | | Α | 1 | 0 | 1 | 0 | Add | Yes | 0-4 | (SA)+(DA) → (DA) | | AB | | 0 | | 1 | Add bytes | Yes | 0-5 | (SA)+(DA) → (DA) | | C | ; | 0 | | 0 | Compare | No | 0-2 | Compare (SA) to (DA) and set | | СВ | 1 | Ī | 0 | 1 | Compare bytes | No | 0-2,5 | appropriate status bits Compare (SA) to (DA) and set appropriate status bits | | MOV | ١, | 1 | 0 | 0 | Move | Yes | 0-2 | (SA) → (DA) | | MOVB<br>S | 1 0 | 1 | 0 | 1 0 | Move bytes Subtract | Yes<br>Yes | 0-2,5<br>0-4 | (SA) → (DA)<br>(DA) – (SA) → (DA) | | S<br>SB | 0 | | 1 | 1 | Subtract bytes | Yes | 0-5 | (DA) - (SA) → (DA) | | | 1 | 1 | • | ; | Set ones corresponding | Yes | 0-2 | (DA) OR (SA) → (DA) | | SOC | ' | 1 | 1 | 1 | Set ones corresponding bytes | Yes | 0-2,5 | (DA) OR (SA) → (DA) | | SOCB | 0 | 1 | Ċ | 0 | Set zeroes corresponding | Yes | 0-2 | (DA) AND (SA) → (DA) | | SZC<br>SZCB | 0 | | - | 1 | Set zeroes corresponding bytes | Yes | 0-2,5 | (DA) AND (SA) → (DA) | #### EXAMPLES (1) ASSEMBLY LANGUAGE: A @>100,R2 ADD CONTENTS OF MA >100 & R2, SUM IN R2 MACHINE LANGUAGE: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | |---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|-------| | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | >A0A0 | | 0 | | | | | | | | | | | | | | | | >0100 | (2) ASSEMBLY LANGUAGE: CB R1,R2 COMPARE BYTE R1 TO R2, SET ST # MACHINE LANGUAGE: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | - | |---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|-------| | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | >9081 | # NOTE In byte instruction designating a register, the left byte is used. In the above example, the left byte (8 MSB's) of R1 is compared to the left byte of R2, and the ST set to the results. #### 5.6.2 FORMAT 2 INSTRUCTIONS #### 5.6.2.1 Jump Instructions Jump instructions cause the PC to be loaded with the value PC+2 (signed displacement) if bits of the Status Register are at specified values. Otherwise, no operation occurs and the next instruction is executed since the PC was incremented by two and now points to the next instruction. The signed displacement field is a word (not byte) count to be added to PC. Thus, the jump instruction has a range of -128 to 127 words (-256 to 254 bytes) from the memory address following the jump instruction. No ST bits are affected by a jump instruction. #### GENERAL FORMAT: | ********* | | | 0 | P C | OD | E | | | | OT COMPLETION TO CHANGE BO | |-----------|---|---|---|-----|----|---|---|---|--------------------|----------------------------| | MNEMONIC | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | MEANING | ST CONDITION TO CHANGE PC | | JEQ | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | Jump equal | ST2 = 1 | | JGT | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | Jump greater than | ST1 = 1 | | JH | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | Jump high | ST0 = 1 and ST2 = 0 | | JHE | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | Jump high or equal | ST0 = 1 or ST2 = 1 | | JL | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | Jump low | ST0 = 0 and ST2 = 0 | | JLE | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | Jump low or equal | ST0 = 0 or ST2 = 1 | | JLT | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | Jump less than | ST1 = 0 and ST2 = 0 | | JMP | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Jump unconditional | unconditional | | JNC | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | Jump no carry | ST3 = 0 | | JNE | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | Jump not equal | ST2 = 0 | | JNO | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | Jump no overflow | ST4 = 0 | | JOC | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | Jump on carry | ST3 = 1 | | JOP | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | Jump odd parity | ST5 = 1 | In assembly language, \$ in the operand indicates "at this instruction". Essentially JMP \$ causes an unconditional loop to the same instruction location, and JMP \$+2 is essentially a no-op (\$+2 means "here plus two bytes"). Note that the number following the \$ is a *byte* count while displacement in machine language is in *words*. #### **EXAMPLES** #### ASSEMBLY LANGUAGE: IF EQ BIT SET, SKIP 1 INSTRUCTION \$+4 JEQ MACHINE LANGUAGE: The above instruction continues execution 4 bytes (2 words) from the instruction location or, in other words, two bytes (one word) from the Program Counter value (incremented by 2 and now pointing to next instruction while JEQ executes). Thus, the signed displacement of 1 word (2 bytes) is the value to be added to the PC. This causes an unconditional loop back to one word less than the Program Counter value (PC $\pm$ FF = PC-1 word). The Status Register is not checked. A JMP \$+2 means "go to the next instruction" and has a displacement of zero (a no-op). No-ops can substitute for deleted codes or can be used for timing purposes. ## 5.6.2.2 CRU Single-Bit Instructions These instructions test or set values at the Communications Register Unit (CRU). The CRU bit is selected by the CRU address in bits 4 to 14 of register 12 plus the signed displacement value. The selected bit is set to a one or zero, or it is tested and the bit value placed in equal bit (2) of the Status Register. The signed displacement has a value of -128 to 127. NOTE CRU addressing is discussed in detail in Section 7. | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|---|---|---|------|-----|---|---|---|---|---|-------|-------|-------|------|----|----| | General Format: | | | | OP C | ODE | | | | | : | SIGNE | D DIS | PLACE | MENT | | | | MNEMONIC | OP CODE<br>0 1 2 3 4 5 6 7 | MEANING | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|----------------------------|-----------------|----------------------------|---------------------------------------------| | SBO | 00011101 | Set bit to one | - | Set the selected CRU output bit to 1. | | SBZ | 00011110 | Set bit to zero | | Set the selected CRU output bit to 0. | | ТВ | 00011111 | Test bit | 2 | If the selected CRU input bit = 1, set ST2. | #### EXAMPLE R12, BITS 4 TO 14 = >100 ASSEMBLY LANGUAGE: SBO 4 SET CRU ADDRESS >104 TO ONE MACHINE LANGUAGE: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | |---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|-------| | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | >1D04 | ### 5.6.3 FORMAT 3/9 INSTRUCTIONS These are dual operand instructions with multiple addressing modes for the source operand, and workspace register addressing for the destination. The MPY and DIV instructions are termed format 9 but both use the same format as format 3. The XOP instruction is covered in paragraph 5.6.9. 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 General Format: OP CODE DR (REGISTER ONLY) T<sub>S</sub> SR | MNEMONIC | OP CODE<br>0 1 2 3 4 5 | MEANING | RESULT<br>COMPARED<br>TO 0 | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|------------------------|-----------------------------|----------------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | coc | 001000 | Compare ones corresponding | No | 2 | Test (DR) to determine if O's are in each bit position where 1's are in (SA). If so, set ST2. | | czc | 001001 | Compare zeros corresponding | No | 2 | Test (DR) to determine if 0's are in each bit position where 1's are in (SA). If so, set ST2. | | XOR | 001010 | Exclusive OR | Yes | 0-2 | (DR) ⊕ (SA) → (DR) | | MPY | 001110 | Multiply | No | | Multiply unsigned (DR) by unsigned (SA) and place unsigned 32-bit product in DR (most significant) and DR + 1 (least significant). If WR15 is DR, the next word in memory after WR15 will be used for the least significant half of the product. | | DIV | 001111 | Divide | No | 4 | If unsigned (SA) is less than or equal to unsigned (DR), perform no operation and set ST4. Otherwise divide unsigned (DR) and (DR) by unsigned (SA). Quotient → (DR), remainder → (DR+1). If DR=15, the next word in memory after WR15 will be used for the remainder. | Exclusive OR Logic - 1 ⊕ 0 = 1 0 ⊕ 0 = 0 1 ⊕ 1 = 0 # EXAMPLES (1) ASSEMBLY LANGUAGE: MPY R2,R3 MULTIPLY CONTENTS OF R2 AND R3, RESULT IN R3 AND R4 32-BIT RESULT # MACHINE LANGUAGE: 0000 0006 0003 N R3 The destination operand is always a register, and the values multiplied are 16-bits, unsigned. The 32-bit result is placed in the destination register and destination register +1, zero filled on the left. #### (2) ASSEMBLY LANGUAGE: DIV @>3E00, R5 DIVIDE CONTENTS OF R5 AND R6 BY VALUE AT M.A. $>\!$ 3E00 # MACHINE LANGUAGE: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | |---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|-------| | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | >3D60 | | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | >3E00 | The unsigned 32-bit value in the destination register and destination register +1 is divided by the source operand value. The result is placed in the destination register. The remainder is placed in the destination register +1. #### (3) ASSEMBLY LANGUAGE: COC R10,R11 ONES IN R10 ALSO IN R11? #### MACHINE LANGUAGE: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | |---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|-------| | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | >22CA | Locate all binary ones in the source operand. If the destination operand also has ones in these positions, set the equal flag in the Status Register; otherwise, reset this flag. The following sets the equal flag: 5-28 # 5.6.4 FORMAT 4 (CRU MULTIBIT) INSTRUCTIONS | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|---|---|------|-----|---|---|---|---|---|---|----|----|----|----|----------|----| | General Format: | | | OP C | ODE | | | | ( | С | | T: | S | | SF | <b>1</b> | | The C field specifies the number of bits to be transferred. If C=0, 16 bits will be transferred. The CRU base register (WR 12, bits 4 through 14) defines the starting CRU bit address. The bits are transferred serially and the CRU address is incremented with each bit transfer, although the contents of WR12 are not affected. $T_S$ and SA provide multiple mode addressing capability for the source operand. If 8 or fewer bits are transferred (C=1 through 8), the source address is a byte address. If 9 or more bits are transferred (C=0, 9 through 15), the source address is a word (even number) address. If the source is addressed in the workspace register indirect autoincrement mode, the workspace register is incremented by 1 if C=1 through 8, and is incremented by 2 otherwise. | MNEMONIC | OP CODE | MEANING | RESULT<br>COMPARED | STATUS<br>BITS | DESCRIPTION | |----------|---------|------------------------------|--------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------| | | 012345 | | TO 0 | AFFECTED | | | LDCR | 001100 | Load communication register | Yes | 0-2,5 <sup>†</sup> | Beginning with LSB of (SA), transfer the specified number of bits from (SA) to | | STCR | 001101 | Store communication register | Yes | 0-2,5 <sup>†</sup> | the CRU. Beginning with LSB of (SA), transfer the specified number of bits from the CRU to (SA). Load unfilled bit positions with 0. | tST5 is affected only if 1 ≤ C ≤ 8. #### **EXAMPLE** ASSEMBLY LANGUAGE: LDCR @>3E00,8 LOAD 8 BITS ON CRU FROM M.A. >3E00 MACHINE LANGUAGE: | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6. | 5 | 4 | 3 | 2 | 1 | 0 | |-------|----|----|----|----|----|----|---|---|---|----|---|---|---|---|---|---| | >3220 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | | >3E00 | | | | | | | | | | | | | | | | | **NOTE**CRU addressing is discussed in detail in Section 7. # 5.6.5 FORMAT 5 (SHIFT) INSTRUCTIONS These instructions shift (left, right, or circular) the bit patterns in a workspace register. The last bit value shifted out is placed in the carry bit (3) of the Status Register. If the SLA instruction causes a one to be shifted into the sign bit, the ST overflow bit (4) is set. The C field contains the number of bits to shift. If C=0, bits 12 through 15 of R0 contain the shift count. If C=0 and bits 12 through 15 of WR0 = 0, the shift count is 16. | MNEMONIC | L | | | 0 | PC | :01 | DE | | | | RESULT | STATUS | | |----------|---|---|-------|---|----|-----|----|---|-----|------------------------|------------------|------------------|---------------------------------------------------------------------------| | | 0 | | i<br> | 2 | 3 | 4 | 5 | | 3 7 | MEANING | COMPARED<br>TO 0 | BITS<br>AFFECTED | DESCRIPTION | | SLA | 0 | ( | ) | 0 | 0 | 1 | 0 | | 0 | Shift left arithmetic | Yes | 0-4 | Shift (R) left. Fill vacated bit | | SRA | 0 | ( | ) | 0 | 0 | 1 | 0 | ( | 0 | Shift right arithmetic | Yes | 0-3 | positions with 0. Shift (R) right, Fill vacated bit | | SRC | 0 | C | ) | 0 | 0 | 1 | 0 | 1 | 1 | Shift right circular | Yes | 0-3 | positions with original MSB of (R)<br>Shift (R) right. Shift previous LSB | | SRL | 0 | C | ) | 0 | 0 | 1 | 0 | C | 1 | Shift right logical | Yes | 0-3 | into MSB.<br>Shift (R) right. Fill vacated bit | #### **EXAMPLES** # (1) ASSEMBLY LANGUAGE: SRA R1,2 SHIFT R1 RIGHT 2 POSITIONS, CARRY SIGN #### MACHINE LANGUAGE: # 5.6.6 FORMAT 6 INSTRUCTIONS These are single operand instructions. VACATED BITS ZERO FILLED The $T_S$ and S fields provide multiple mode addressing capability for the source operand. | MNEMONIC | OP CODE<br>0 1 2 3 4 5 6 7 8 9 | MEANING | RESULT<br>COMPARED<br>TO 0 | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|--------------------------------|-------------------|----------------------------|----------------------------|-------------------------------------| | В | 0000010001 | Branch | No | - | SA → (PC) | | BL | 0000011010 | Branch and link | No | _ | (PC) → (R11); SA → (PC) | | BLWP | 0000010000 | Branch and load | No | - | (SA) →(WP); (SA+2) →(PC); | | | | workspace pointer | | | (old WP) → (new WR 13); | | | | | | | (old PC) → (new WR14); | | | | | | | (old ST) → (new WR15); | | | | | | | the interrupt input (INTREQ) is not | | | | | | | tested upon completion of the | | | | | | | BLWP instruction. | | CLR | 0000010011 | Clear operand | No | | 0000 → (SA) | | SETO | 0000011100 | Set to ones | No | _ | FFFF16 (SA) | | INV | 0000010101 | Invert | Yes | 0-2 | (SA) = (SA) (ONE'S complement) | | NEG | 0000010100 | Negate | Yes | 0.4 | =(SA) → (SA)(TWO'S complement) | | ABS | 0000011101 | Absolute value* | No | 0-4 | [(SA)] →(SA) | | SWPB | 0000011011 | Swap bytes | No | _ | (SA), bits 0 thru 7 → (SA), bits | | | | | | | 8 thru 15; (SA), bits 8 thru 15 | | | | | | | (SA), bits 0 thru 7. | | INC | 0000010110 | Increment | Yes | 0.4 | (SA) + 1 · * (SA) | | INCT | 0000010111 | Increment by two | Yes | 0-4 | (SA) + 2 → (SA) | | DEC | 0000011000 | Decrement | Yes | 0-4 | (SA) - 1 ··· (SA) | | DECT | 0000011001 | Decrement by two | Yes | 0.4 | (SA) - 2 * (SA) | | x † | 0000010010 | Execute | No | _ | Execute the instruction at SA. | <sup>\*</sup>Operand is compared to zero for setting the status bit (i.e., before execution). #### **EXAMPLES** (1) ASSEMBLY LANGUAGE: B \*R2 BRANCH TO M.A. IN R2 #### MACHINE LANGUAGE: <sup>†</sup>If additional memory words for the execute instruction are required to define the operands of the instruction located at SA, these words will be accessed from PC and the PC will be updated accordingly. The instruction acquisition signal (IAQ) will not be true when the TMS 9900 accesses the instruction at SA. Status bits are affected in the normal manner for the instruction executed. #### (2) ASSEMBLY LANGUAGE: BL @ > 3F00 BRANCH TO M.A. > 3F00, SAVE OLD PC VALUE (AFTER EXECUTION) IN R11 #### MACHINE LANGUAGE: ## (3) ASSEMBLY LANGUAGE: BLWP @ > 3F00 BRANCH, GET NEW WORKSPACE AREA #### MACHINE LANGUAGE: | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | _ | |---|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|-------| | | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | >0420 | | Ī | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | >3F00 | This context switch provides a new workspace register file and stores return values in the new workspace. See Figure 5-11. The operand (> 3F000 above) is the M.A. of a two-word transfer vector, the first word the new WP value, the second word the new PC value. Figure 5-11. BLWP Example # 5.6.7 FORMAT 7 (RTWP, CONTROL) INSTRUCTIONS External instructions cause the three address lines (A13, A0, A1) to be set to the levels described in the table below and cause the CRUCLK line to be pulsed, allowing external control functions to be interpreted during CRUCLK at A13, A0, and A1. The RSET instruction resets the I/O lines on the TMS 9901 to input lines; the TMS 9902 is not affected. RSET also clears the interrupt mask in the Status Register. The LREX instruction causes a delayed load interrupt, delayed by two IAQ cycles after LREX execution. The load operation gives control to the monitor. | MNEMONIC | OP CODE<br>0 1 2 3 4 5 6 7 8 9 10 | MEANING | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | ADD<br>BI<br>A13 | JS, | • | |----------|-----------------------------------|----------------|----------------------------|----------------------------------------------------------------------------------|------------------|-----|---| | IDLE | 00000011010 | ldle | - | Suspend TMS 9980 instruction execution until an interrupt, LOAD, or RESET occurs | L | Н | L | | RSET | 00000011011 | Reset I/O & SR | 12-15 | 0 → ST12 thru ST15, RESET | L | Н | Н | | CKOF | 00000011110 | User defined | | | н | Н | L | | CKON | 00000011101 | User defined | | | Н | Ļ | Н | | LREX | 00000011111 | Load interrupt | | Control to UNIBUG | н | Н | Н | | RTWP | 00000011100 | Return from | 0-15 | (R13) → (WP) | | | | | | | Subroutine | | (R14) → (PC) | | | | | | | | | (R15) → (ST) | | | | <sup>\*</sup> This instruction causes the interrupt mask in the TMS 9980 to be zeroed, generates a signal to reset the I/O devices (except 9902's), and also traps to location 000016 (causes a level 0 or RESET interrupt). Essentially, the RTWP instruction is a return to the next instruction that follows the BLWP instruction (i.e., RTWP is a return from a BLWP context switch, similar to the B \*R11 return from a BL instruction). BLWP provides the necessary values in registers 13, 14, and 15 (see Figure 5-11.) # EXAMPLE ASSEMBLY LANGUAGE: RTWP RETURN FROM CONTEXT SWITCH MACHINE LANGUAGE: ## RTWP RETURN TO PREVIOUS PC(R14), WP(R13), AND ST(R15) VALUES # 5.6.8 FORMAT 8 (IMMEDIATE, INTERNAL REGISTER LOAD/STORE) INSTRUCTIONS # 5.6.8.1 Immediate Register Instructions | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|---|---|---|---|---|-------|---|---|-----|---|----|----|----|----|----|----| | General format: | | | | | 0 | P COD | E | | | | | N | | F | 3 | | | | | | | | | | | | IOP | | | | | | | | | | | OP CODE | | | | | | | | | | | | RESULT | STATUS | | | | |---------------------------------|---------|------------------|------------------|-------------|---|---|---|---|-----|---|---|---|----------------|--------|--------|----------------------------|--|--| | MNEMONIC 0 1 2 3 4 5 6 7 8 9 10 | MEANING | COMPARED<br>TO 0 | BITS<br>AFFECTED | DESCRIPTION | | | | | | | | | | | | | | | | ΑI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | ( | ) | 0 | 0 | 1 | Add immediate | Yes | 0-4 | (R) + IOP → (R) | | | | ANDI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | ( | ) | 0 | 1 | 0 | AND immediate | Yes | 0-2 | (R) AND IOP → (R) | | | | CI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | ( | ) | 1 | 0 | 0 | Compare | Yes | 0-2 | Compare (R) to IOP and set | | | | | | | | | | | | | | | | | immediate | İ | | appropriate status bits | | | | LI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | ( | ) | 0 | 0 | 0 | Load immediate | Yes | 0-2 | IOP → (R) | | | | ORI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | ( | י כ | 0 | 1 | 1 | OR immediate | Yes | 0-2 | (R) OR IOP → (R) | | | AND Logic: 0.1, 1.0 = 0 OR Logic: 0 + 1, 1 + 0 = 1 0.0 = 0 0 + 1 = 1 1.1 = 1 1.1 = 1 1.1 = 0 1.1 = 1 1.1 = 1 5.6.8.2 Internal Register Load Immediate Instructions | | | OP CODE | | | | | | | | | | | _ | |----------|---|---------|---|---|---|---|---|---|---|---|----|----------------------------------|---------------------------------| | MNEMONIC | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | MEANING | DESCRIPTION | | LWPI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | Load workspace pointer immediate | IOP → (WP), no ST bits affected | | LIMI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | Load interrupt mask | IOP, bits 12 thru 15 → ST12 | | | | | | | | | | | | | | | thru ST15 | # 5.6.8.3 Internal Register Store Instructions #### No ST bits are affected. | MNEMONIC | | | | | 0 | PC | OE | ÞΕ | | | | | MEANING. | BECODIETION. | | | |-----------|---|---|---|---|---|----|----|----|---|---|---|----|-------------------------|--------------|--|--| | MINEMONIC | 0 | 1 | 2 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | MEANING | DESCRIPTION | | | | STST | 0 | 0 | ( | ) | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | Store status register | (ST) (R) | | | | STWP | 0 | 0 | C | ) | 0 | 0 | 9 | 1 | 0 | 1 | 0 | 1 | Store workspace pointer | (WP) → (R) | | | # EXAMPLES (1) ASSEMBLY LANGUAGE: ADD >FF TO CONTENTS OF R2 R2,>FF MACHINE LANGUAGE: 14 15 >0222 >00FF AFTER BEFORE 0 1 0 E 0 0 0 F R2 (2) ASSEMBLY LANGUAGE: COMPARE R2 TO >10E R2,>10E MACHINE LANGUAGE: >0282 >010E R2 contains "after" results (>IOE) of instruction in Example (1) above; thus the ST equal bit becomes set. ASSEMBLY LANGUAGE: WP SET AT > 3E00 (M.A. OF R0) LWPI > 3E00 MACHINE LANGUAGE: G >02E0 >3E00 O This is used to define the workspace area in a task, usually placed at the beginning (4) ASSEMBLY LANGUAGE: STORE WP CONTENTS IN R2 STWP R2 MACHINE LANGUAGE: This places the M.A. of R0 in a workspace register. 10 11 12 13 14 15 >02A2 #### 5.6.9 FORMAT 9 (XOP) INSTRUCTION Other format 9 instructions (MPY, DIV) are explained in paragraph 5.6.3 (format 3). | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|---|---|---|---|---|---|----|--------|------|-----|----|----|----|----|----|----| | General Format: | 0 | 0 | 1 | | 1 | 1 | DR | (XOP I | NUMB | ER) | T | s | | s | R | | The $T_S$ and SR fields provide multiple mode addressing capability for the source operand. When the XOP is executed, ST6 is set and the following transfers occur: ``` \begin{array}{lll} (40_{16}+4D)\rightarrow (WP) & \text{First vector at } 40_{16} \\ (42_{16}+4D)\rightarrow (PC) & \text{Each vector uses 4 bytes (2 words)} \\ SA\rightarrow (\text{new R11}) \\ (\text{old WP})\rightarrow (\text{new WR13}) \\ (\text{old PC})\rightarrow (\text{new WR14}) \\ (\text{old ST})\rightarrow (\text{new WR15}) \\ \end{array} ``` The TMS 9980 does not test interrupt request (INTREQ) upon completion of the XOP instruction, but does test for RESET and LOAD. An XOP is a means of calling one of 16 subtasks available for use by any executing task. The memory area between M.A. 40<sub>16</sub> and 7E<sub>16</sub> is reserved for the transfer vectors of XOP's 0 to 15 (see Figure 5-1). Each XOP vector consists of two words, the first a WP value, the second a PC value, defining the workspace pointer and entry point for a new subtask. These values are placed in their respective hardware registers when the XOP is executed. The old WP, PC, and ST values (of the XOP calling task) are stored (like the BLWP instruction) in the new workspace, registers 13, 14, and 15. Return to the calling routine is through the RTWP instruction. Also stored, in the new R11, is the M.A. of the source operand. This allows passing a parameter to the new subtask, such as the memory address of a string of values to be processed by the XOP-called routine. Figure 5-12 depicts calling an XOP to process a table of data; the data begins at M.A. 3F0016. XOP's 8 to 14 are used by the UNIBUG monitor, calling software routines (supervisor calls) as requested by tasks. This user-accessible software performs tasks such as write to terminal, convert binary to hex ASCII, etc. These monitor XOP's are discussed in Section 3. #### MACHINE LANGUAGE: Figure 5-12. XOP Example # 5.7 COMPARISON OF JUMPS, BRANCHES AND XOPS See Table 5-7. TABLE 5-7. COMPARISON OF JUMPS, BRANCHES, XOP'S | Mnemonic | Paragraph | Definition Summary | |----------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | JMP | 5.6.2 | One-word instruction, destination restricted to +127, -128 words from Program. Counter value. | | В | 5.6.6 | Two-word instruction, branch to any memory location. | | BL | 5.6.6 | Same as B with PC return address in R11. | | BLWP | 5.6.7 | Same as B with new workspace; old WP, PC and ST contents (return vectors) are in new R13, R14, R15. | | XOP | 5.6.9 | Same as BLWP with address of parameter (source operand) in new R11. Sixteen XOP vectors outside program in M.A. 40 <sub>16</sub> to 7E <sub>16</sub> ; can be called by any program. | ## **SECTION 6** #### **ASSEMBLER DIRECTIVES** ## 6.1 GENERAL This section defines the following six assembler directives recognized by the Symbolic Assembler (described in Section 4). These directives and corresponding paragraph number are: | • | AORG Absolute origin of statement (absolute location) | 6.2.1 | |---|-------------------------------------------------------|-------| | • | BSS Block of memory starting with symbol | 6.2.2 | | • | DATA Sixteen-bit immediate value | 6.2.3 | | • | END End of source code | 6.2.4 | | • | EQU Label equated to symbol or value | 6.2.5 | | • | TEXT Code character string in ASCII code | 6.2.6 | ## 6.2 DIRECTIVE FORMATS Syntax used in this subsection: - < > Required items to be supplied by the user - [ ] Optional items to be supplied by the user - T1 Space - T2 Space or comma - T3 Space, comma, or return ### 6.2.1 AORG DIRECTIVE Format: [label] $$<$$ T1 $>$ $<$ AORG $>$ $<$ T1 $>$ $<$ location $>$ $<$ T1 $>$ [comment] The AORG directive places a value in the location counter and begins assembly at the location specified. The location value must be in decimal or hexadecimal. By default, the location counter for the assembler begins at 0000<sub>16</sub> and is incremented by two (bytes) for each word occupied by the instruction. When a label is used with the AORG directive, it is assigned the value in the location counter. Comment field is optional. ### Example: AORG > 200 Begin assembling source code at location counter value of > 200 AORG 200 Begin assembling source code at location counter value of > C8 #### 6.2.2 BSS DIRECTIVE Format: [label] $$<$$ T1 $>$ $<$ BSS $>$ $<$ T1 $>$ $<$ number of bytes $>$ $<$ T1 $>$ [comment] The BSS (block with starting symbol) directive advances the location counter (which the assembler uses to count the bytes of machine code) a quantity of bytes as specified in the directive. In essence, it "reserves" a block of bytes starting at the location counter value; this block will be void of object code. An optional label (in the label field) can be specified to identify the first location in the block. The byte count can be in decimal or hexadecimal. #### 6.2.3 DATA DIRECTIVE Format: [label] $$<$$ T1 $>$ $<$ DATA $>$ $<$ T1 $>$ $<$ 1-16 bit value ,.., 1-16 bit value $>$ $<$ T1 $>$ [comment] This directive places 16 bit values into (successive) memory locations. Data is placed at even address locations. Operand values can be chained (i.e., successive 1 to 16 bit values separated by commas). Example: #### 6.2.4 END DIRECTIVE Format: [label] $$< T1 > < END > < T1 > [entry point] < T1 > [comment]$$ This directive is mandatory for each program. It designates to the assembler that this is the final input from the source program and causes a transfer of control back to the monitor. This is the last input to the assembler, and the only means of direct transfer from the assembler to the monitor. When the optional label is used, it is assigned the current value in the location counter. The optional load-point operand field contains a symbol or absolute memory address specifying the entry point (execution start) of the program. When the entry-point operand is used, the entry point address will be placed in the Program Counter so that the program can be executed by the E command immediately after being loaded. Example: ## 6.2.5 EQU DIRECTIVE Format: $$<$$ label $>$ $<$ T1 $>$ $<$ EQU $>$ $<$ T1 $>$ $<$ value or expression $>$ $<$ T1 $>$ [comment] This directive assigns a value to a label for use during assembly. The expression field can contain an absolute numeric value or expression. Expressions are further defined in paragraph 4.2.4. This directive allows the user to substitute easily remembered mnemonics for absolute values in program source lines. The optional label will be assigned the current value in the location counter. #### Examples: 1. SM EQU 1 SUM ACCUMULATOR allows using SM for register 1 such as MOV @>FC00,SM MOVE QTY TO R1 instead of MOV @>FC00,1 MOVE QTY TO R1 IN EQU 9681 DIVISOR CONSTANT allows this constant value to be used in subsequent source lines LI R1,IN PLACE CONSTANT IN R1 instead of remembering the constant value. If IN has been previously defined as above, the following MOV @IN+4,@OT will result in moving the value located four bytes beyond location IN into location OT. A label can be equated to a string of labels being added or subtracted (expression). For example: 4. A EQU 5 B EQU 10 C EQU A+B EQUALS VALUE 15 NO DATA C+A EQUALS VALUE 20 would result in the value 20 in location NO. #### 6.2.6 TEXT DIRECTIVE Format: $$[label] < T1 > < TEXT > < T1 > [-,] < 'character string' > < T1 > [comment]$$ This directive, like the DATA directive, is used to generate absolute data for program use. The DATA statement operand is interpreted as a numerical value. The TEXT statement operand contains an alphanumeric character string of keyboard inputs which are to be interpreted into ASCII code. Besides keyboard characters, the user can also input control characters (e.g., carriage return, line feed, DC1, DC2) which are output in ASCII code via the keyboard. ASCII code is defined in Appendix C. Character string inputs in the operand field are enclosed in single quotes (SHIFT/Ret). The assembler begins all character strings on an even boundary and places a zero byte after the last character that can be used as a delimiter by the XOP I/O commands. The optional label field will be assigned the value in the location counter; this value will identify the location of the first character in the string. # Examples: - 1. CM TEXT 'LOAD TAPE, HIT CR\_\_' Followed by carriage return and line feed key inputs - 2. CM TEXT 'LOAD TAPE, HIT CR.' ## **SECTION 7** # I/O PROGRAMMING USING THE CRU ## 7.1 GENERAL The Communications Register Unit (CRU) is a separate I/O port, used only for data transfers to or from external devices. It is the medium through which the microprocessor communicates with the outside world. The CRU is an internal port of the TMS 9980A microprocessor. An interface is a common boundary between automatic data-processing systems or parts of a single system. In the TM 990/189, an interface will be needed between the microprocessor and an I/O device (e.g., terminal or keyboard). The TM 990/189 provides circuitry for two types of Texas Instruments interface devices: two onboard TMS 9901 Programmable Systems Interfaces (PSI's) and an optional TMS 9902 Asynchronous Communications Controller (ACC). The TMS 9902 ACC can be used as an interface between the TMS 9980A and a terminal (such as those in Texas Instruments' Silent 700 series). Figure 7-1 shows a system using the optional TMS 9902. Figure 7-2 shows the TMS 9901 PSI used as an interface between the keyboard and the TMS 9980A. An additional TMS 9901 is provided onboard as a user I/O port. Figure 7-1. Typical Application TMS 9902 Asynchronous Communication Controller (ACC) Careful examination of Figures 7-1 and 7-2 will reveal three CRU control lines between the interface and the microprocessor. These lines are used for serial data input (CRUIN), serial data output (CRUOUT), and data timing strobes (CRUCLK). In order to transfer data in or out, CRU programming must be understood. When CRU instructions are executed, data is written or read through the CRUOUT or CRUIN pins respectively of the TMS 9980A. These signals come from or are sent to designated devices selected by decode logic attached to the address bus of the microprocessor. CRUOUT is also address line A13, it is not used to designate a CRU address. Figure 7-2. Typical TMS 9901 Programmable System Interface (PSI) Application Essentially, the CRU process follows this sequence: - 1. The CRU instruction is executed. - Bit address of the desired external device is placed on the address bus. - Decode logic on the address bus enables an external device so that it can serially send or receive using the CRU input or output lines and clock. - 4. Bits are serially sent or received over the CRU lines. The CRU address is loaded by software and maintained in register 12 of the workspace register area. Only bits 4 through 14 of the register are interpreted by the CPU for the desired CRU address, and this 11-bit value is called the CRU base address or bit number. As mentioned before, the TM 990/189 drives (via the CRU port) the onboard TMS 9901 parallel interface and the optional TMS 9902 serial interface. These interfaces are accessed (enabled) through the CRU addresses noted in Table 7-1. This table also lists the functions of the other CRU addresses which can be used for on-card or off-card I/O use. The TMS 9901 and the TMS 9902 interfaces can be used as interval timers, further detailed information on these two devices can be obtained from their respective data manuals. TABLE 7-1. CRU ADDRESS MAP | Contents of R12<br>(Bits 0 to 15) | CRU Base Address<br>(R12, Bits 4 to 14) | Function | |-----------------------------------|-----------------------------------------|----------------------------------------------------------------------| | 0000 to 003E | 0000 to 001F | User TMS 9901 programmable inter-<br>face at U10 (uses port P5) | | 0400 to 043E | 0200 to 021F | System TMS 9901 programmable interface at U11 | | 0800 to 083E | 0400 to 041F | System TMS 9902 asynchronous interface (EIA interface using port P3) | | 0C00 to 0C3E | 0600 to 061F | User CRU addresses* | <sup>\*</sup>Expandable to 512 bits, see Section 9. Paragraph 7-2 explains CRU addressing while timing is covered in paragraph 7.3. Paragraph 7-4 describes the five CRU instructions. # 7.2 CRU ADDRESSING The CRU software base address is contained in the 16 bits of register 12. From the CRU software base address, the processor is able to determine the CRU hardware base address and the resulting CRU bit address. These three CRU addressing forms are shown in Figure 7-3. \*The displacement added to the CRU hardware base address is a signed eight-bit value, with sign extended, used only when executing one of the single-bit instructions (TB, SBO, and SBZ). Shown above is an example displacement of $48_{16}$ ( $72_{10}$ ) added to an example hardware base address of $040_{16}$ ( $64_{10}$ ). Figure 7-3. CRU Base and Bit Addresses ## 7.2.1 CRU BIT ADDRESS The CRU bit address is the address that will be placed on the address bus at the beginning of a CRU instruction. This is the address bus value that, when decoded by hardware attached to the address bus, will enable the device so that it can be driven by the CRU control and clock lines. The CRU bit address is the sum of the displacement value of the CRU instruction (displacement applies to instructions TB, SBO, and SBZ only) and the CRU hardware base address in bits 4 to 14 of register 12. Note that the sign bit of the eight-bit value is extended to the left and added as part of the displacement. The resulting CRU bit address will be placed on address lines A2 to A12; address lines A0 and A1 always will be zeroes. # 7.2.2 CRU HARDWARE BASE ADDRESS The CRU hardware base address is the value in bits 4 to 14 of register 12. For instructions that do not specify a displacement (the LCDR and STCR do not), the CRU hardware base address is the same as the CRU bit address on address lines $A_2$ to $A_{12}$ as explained in paragraph 7.2.1. An important aspect of the CRU hardware base address is that it does not use the least significant bit of register 12 (bit 15); this bit is ignored in deriving the CRU bit address. # 7.2.3 CRU SOFTWARE BASE ADDRESS The CRU software base address is the entire 16-bit contents of register 12. In essence, this is the CRU hardware base address divided by two. Bits 0, 1, 2, 3, and 15 of the CRU software base address are ignored in deriving the CRU hardware base address and the CRU bit address. Because bit 15 of R12 is not used, some confusion can result in programming. Instead of loading the CRU base address in bits 0 to 15 of Register 12 (e.g., LI R12, 400 to address the TMS 9902 at CRU base address 40016), the programmer must shift the base address value one bit to the left so that it is in bits 4 to 14 instead of in bits 5 to 15. Several programming methods can be used to ensure this correct placement. All of the following examples place the TMS 9902 base address of 40016 correctly in R12. | LI | R12, >800 | PLACES 400 IN BITS 3 TO 14 | |-----|-------------|----------------------------------------------------------------------------| | | or | | | LI | R12, >400*2 | MULTIPLY BASE ADDRESS BY 2 (NOT<br>RECOGNIZED BY THE TM 990/189 ASSEMBLER) | | | or | | | LI | R12, >400 | BASE ADDRESS IN BITS 4 TO 15 | | SLA | R12, 1 | SHIFT BASE ADDRESS ONE BIT TO THE LEFT | From a programming standpoint, it may be best to view addressing of the CRU through the entire 16 bits of R12. In this context, blocks of a maximum of 16 CRU bits can be addressed, and in order to address an adjacent 16-bit block, a value of $0020_{16}$ , CRU bits 0 to F<sub>16</sub> can be addressed. By adding $0020_{16}$ to R12, CRU bits $10_{16}$ to $1F_{16}$ can be addressed, etc. #### 7.3 CRU TIMING Timing during the execution of a CRU output instruction (e.g., LDCR) and a CRU input instruction (e.g., STCR) is shown in Figure 7-4. In a CRU output operation, the CRU base address in bits 4 to 14 of R12 is valid on the address bus (lines A<sub>2</sub> to A<sub>12</sub>) when signal $\phi$ 3 (inverted phase $\phi$ 3) is active. At the next phase $\phi$ 3, CRUCLK is active; at this same time, the data at A<sub>13</sub> (CRUOUT) is true. When $\phi$ 3 becomes active again, the next consecutive CRU address (as in an LDCR operation) is active on address lines A<sub>2</sub> to A<sub>12</sub>, and at the next $\phi$ 3 phase, CRUCLK is active again. The cycle repeats itself until the designated number of CRU bits are output (made available) at A<sub>13</sub>. Thus the output of data using the CRU involves making the desired CRU address available on address lines A<sub>2</sub> to A<sub>12</sub>, and sampling the logic level at A<sub>13</sub> (during CRUCLK). In a CRU input operation, the desired address is placed on address lines A<sub>2</sub> to A<sub>12</sub>. The next time $\phi 3$ becomes active, data will be sampled at the CRUIN line. Data should remain valid for two clock phases beginning with $\phi 3$ becoming active. ## 7.4 CRU INSTRUCTIONS The five instructions that program the CRU interface are: - LDCR: Place the CRU base address on address lines A<sub>2</sub> to A<sub>12</sub>. Load from memory a pattern of 1 to 16 bits and serially transmit this pattern through the CRUOUT pin of the TMS 9980. Increment the address on A<sub>2</sub> to A<sub>12</sub> after each CRUOUT transmission. - STCR: Place the CRU base address on address lines A<sub>2</sub> to A<sub>12</sub>. Store into memory a pattern of 1 to 16 bits obtained serially at the CRUIN pin of the TMS 9980. Increment the address on A<sub>2</sub> to A<sub>12</sub> after each CRUIN sampling. - SBO: Place the CRU base address plus the instruction signed displacement on address lins A<sub>2</sub> to A<sub>12</sub>. Send a logical one through the CRUOUT pin of the TMS 9980. - SBZ: Place the CRU base address plus the instruction signed displacement on address lines A<sub>2</sub> to A<sub>12</sub>. Send a logical zero through the CRUOUT pin of the TMS 9980. - TB: Place the CRU base address plus the instruction signed displacement on address lines A2 to A12. Test the value at the CRUIN pin of the TMS 9980, and reflect the test results in the equal bit of the Status Register (one or zero). The LDCR and STCR instructions use a byte or word of memory depending respectively if 1 to 8 bits or more than 8 bits are to be loaded or stored. In STCR instructions, the right bits of the memory area are used for storage, and unused left-side bits are zero filled. Figure 7-4 depicts an LDCR instruction using a byte of memory. Figure 7-6 depicts an STCR instruction using a word of memory. Figure 7-4. TMS 9980 CRU Interface Timing Figure 7-5. LDCR Byte Instruction The TB, SBO, and SBZ instructions use a maximum displacement of +128 bits and -128 bits from the CRU bit designated in bits 4 to 14 of R12. Thus, if bit $400_{16}$ is designated in R12, bits 4 to 14, the following assembly language instructions and comments would apply. $\begin{array}{ccc} TB & > 10 & TEST \, CRU \, BIT \, > \, 410 \\ SBO & -1 & SET \, CRU \, BIT \, > \, 3FF \, TO \, ONE \\ SBZ & 16 & SET \, BIT \, > \, 410 \, TO \, ZERO \\ \end{array}$ The LDCR and STCR instructions address the CRU using the value in R12; these instructions do not have the advantage of specifying a displacement from the R12 value such as used by the CRU bit instructions. If it is necessary to change the CRU address, it is important to understand that only bits 4 to 14 need be modified. For example, if it is desired to load (LDCR) successive groups of 16 CRU ports, a value of 32 (not 16) must be added to the contents of R12 for each group in order to accurately change the contents of R12 bits 4 to 14 (AI R12,32). An alternate method would be to load a new value into R12 (LI R12, > 400; LI R12, > 420, etc.). | LI | | R12,>4 | 00*2 | LO | AD C | RU B | T AD | DRES | SS > 2 | 00 IN | BITS | 4 TO | 14 O F | R12 | | | |-----|---|------------------|----------------------------|----------------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|----------------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|------------|------------|----------------------------------------------------------------------------|------------| | STC | R | R4,10 | | | 10 | BITS | FRO | M CI | RU T | 0 R4 | | | | | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | _ | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | >020C | | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | >0400 | | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | >3684 | | | 0 | STCR 0 1 0 0 0 0 | STCR R4,10 0 1 2 0 0 0 0 0 | STCR R4,10 0 1 2 3 0 0 0 0 0 0 0 | STCR R4,10 0 1 2 3 4 0 0 0 0 0 0 0 0 0 | STCR R4,10 10 0 1 2 3 4 5 0 0 0 0 0 0 0 0 0 0 1 | STCR R4,10 10 BITS 0 1 2 3 4 5 6 0 0 0 0 0 1 0 0 0 0 0 0 1 0 | STCR R4,10 10 BITS FRO 0 1 2 3 4 5 6 7 0 0 0 0 0 0 1 0 0 0 0 0 1 0 0 | STCR R4,10 10 BITS FROM CI | STCR R4,10 10 BITS FROM CRU T 0 1 2 3 4 5 6 7 8 9 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 | STCR R4,10 10 BITS FROM CRU TO R4 0 1 2 3 4 5 6 7 8 9 10 0 0 0 0 0 1 0 0 0 0 0 0 0 0 1 0 0 0 0 | STCR R4,10 10 BITS FROM CRU TO R4 0 1 2 3 4 5 6 7 8 9 10 11 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 | STCR R4,10 | STCR R4,10 | 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 0 0 0 0 0 0 1 0 0 0 0 0 0 1 1 0 0 0 0 0 | STCR R4,10 | Figure 7-6. STCR Word Instruction ### 7.5 I/O PROGRAMMING WITH THE TMS 9901 The following figures, 7-7 to 7-12 are examples of addressing the TMS 9901 through the CRU, pointing out in graphic form: - External I/O in parallel (multibit) and serial (single bit) forms. - The relationship between the CRU bits addressed and the bits in the source operand of the STCR instructions. - The relationship between the CRU bit addressed and the displacement in TB, SBO, and SBZ instructions. The user TMS 9901 at U10 occupies 32 bit positions of CRU space with the low 16 bits beginning at CRU address 0000<sub>16</sub> and the high 16 bits beginning at CRU address 0020<sub>16</sub> (R12 contents). To access the low 16 bits of the TMS 9901 through the CRU, load 0000<sub>16</sub> into register 12. The high 16 bits starting at CRU address 0020<sub>16</sub> are the parallel I/O bits, shown in the accompanying figures. These may be set, reset, or read in any order or combination with length from 1 to 16 bits. Since CRU operations are serial, data from the microprocessor (either serial or parallel) is transmitted serially to the TMS 9901, which outputs it in parallel. Likewise, during input, data present at the I/O pins is shifted serially to the microprocessor using the CRU bus for programming. It is necessary only to load register 12 with 0020<sub>16</sub> and use either the LDCR or STCR instructions. Bear in mind that CRU operations of 1 to 8 bits affect the left byte (more significant half) of a word. The lower 16 bits of the TMS 9901 starting at CRU address 0000<sub>16</sub> are used for control of interrupts and the timer function, and to reset the I/O lines to the input mode with output buffers disabled and floating. Interrupt requests are presented to the TMS 9901, each on its own line, and are compared against an internal mask. If the internal interrupt mask allows, the particular interrupt request is encoded onto IC0 through IC3 of the TMS 9901 as explained on page 5 of the TMS 9901 data manual. LI R12, > 0020 LDCR R0, 15 # (2) SOURCE ADDRESS IN MEMORY: Figure 7-7. LDCR Word Execution to TMS 9901 LI R12, >0030 LDCR R2, 2 Figure 7-8. LDCR Byte Execution to TMS 9901 Li R12, > 0020 STCR R3, 11 ### (2) SOURCE ADDRESS IN MEMORY: Figure 7-9. STCR Word Execution to TMS 9901 LI R12, > 020 STCR R1, 6 # (2) SOURCE ADDRESS IN MEMORY: Figure 7-10. STCR Byte Execution to TMS 9901 NOTE IF A JEQ (JUMP ON EQUAL) INSTRUCTION FOLLOWS A TB INSTRUCTION, A 1 FOUND WILL CAUSE A JUMP, AND A 0 FOUND WILL NOT CAUSE A JUMP (1 = EQUAL STATE). Figure 7-11. Test CRU Bit at TMS 9901 LI R12, > 0020 SBZ 7 Figure 7-12. Set CRU Bit at TMS 9901 # **SECTION 8** # THEORY OF OPERATION # 8.1 INTRODUCTION This section presents the theory of operation of the TM 990/189 Microcomputer. Information from the following manuals may be used to supplement material in this section: - TMS 9980 Microprocessor Data Manual - TMS 9901 Programmable Systems Interface Data Manual - TMS 9902 Asynchronous Communications Controller Data Manual - TMS 2532 Programmable Read Only Memory Data Sheet - TMS 2708/2716 Programmable Read Only Memory Data Sheet - TMS 4014 Random Access Memory Data Sheet - TMS 4732 Read Only Memory Data Sheet - TMS 9900 Family System Design Handbook - The TTL Data Manual # 8.1.1 SYSTEM ARCHITECTURE Figure 8-1 shows the major function blocks of the TM 990/189 representing the processing, memory, and I/O portions of the microcomputer. Also shown in the figure are the primary signal buses of the system which are: the data bus, address bus, Communications Register Unit (CRU) bus, and the control bus. Throughout the remainder of this section, the operation of these buses and function blocks will be discussed. The first topic is the buses, since they tie all the blocks together. # 8.2 SYSTEM BUSES # 8.2.1 DATA BUS The data bus consists of eight bidirectional lines, D0 through D7, used to transfer information between the processor and memory, either onboard or offboard through the bus expansion interface. D0 is the most significant bit and D7 is the least significant. The direction of data transfer is controlled by the processor and indicated by the state of control bus signal DBIN which is set to a logic one when the processor has disabled its data bus drivers and entered an input mode. Figure 8-1. System Block Diagram ### 8.2.2 ADDRESS BUS The address bus is composed of fourteen lines, A0 through A13 CRUOUT, which are normally driven by the processor and are used to reference individual memory and CRU locations. Memory references are distinguished from CRU operations by observing the state of control bus signal MEMEN— which the processor sets to a logic zero during memory cycles. During memory references A0 through A13 CRUOUT present the address of the byte being accessed, where A0 is the most significant bit and A13 CRUOUT is the least significant bit of the address. During CRU cycles, A0 and A1 are set to zero and A2 through A12 contain the effective CRU bit address being referenced, where A2 is the most significant bit and A12 is the least significant bit of the address. A13 CRUOUT is shared with the CRU bus during CRU operations and is discussed further below. In addition, A0, A1, and A13 CRUOUT are used during the execution of external instructions (CKON, CKOF, RSET, IDLE, and LREX) to present the 3-bit code identifying each instructions. # 8.2.3 CRU BUS The CRU bus consists of four signals: A13 CRUOUT, CRUCLK, IOCLK, and CRUIN. During CRU output intructions (SBZ, SBO, and LDCR), A13 CRUOUT contains the value of the bit being output. After a delay to allow the CRU bit address (A2 through A12) and the output bit A13 CRUOUT) to stabilize, the processor strobes CRUCLK to latch the output bit in the output device. IOCLK is a buffered derivative of CRUCLK and is the actual strobing signal connected to the output devices. During CRU input instructions (TB and STCR) the processor again sets up the CRU bit address on A2 through A12 and, after a delay for settling, reads the input bit from CRUIN. ### 8.2.4 CONTROL BUS The control bus consists of a number of timing, request, and status signals used by the processor and support circuitry. Included in this group are DBIN and MEMEN—, which were mentioned above, along with WE—, READY, DRE—, INT 0 through INT 2, HOLD—, HOLDA, IAQ, and $\phi$ 3—. A brief description of each signal is given in Table 8-1. **TABLE 8-1. CONTROL BUS FUNCTIONS** | | | TABLE 8-1. CONTROL BUS FUNCTIONS | |-------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------| | SIGNAL | ACTIVE STATE | PURPOSE | | WE— | LOW | Strobe to memory devices for writing data to memory. | | READY | HIGH | Indicates to the processor that the memory is ready to be accessed. Wait states are generated by pulling this line low. | | DRE | LOW | Delays RAM chip selects during write operations to avoid bus conflicts. See paragraph 8.5.1. | | INT 0<br>INT 1<br>INT 2 | HIGH | Encoded interrupt request lines to processor. See paragraph 8.4. | | HOLD- | LOW | Requests processor to give up control of address, data buses, MEMEN—, WE—, and DBIN. | | HOLDA | HIGH | Acknowledges that processor has given up signals mentioned above, and has suspended activity. | | IAQ | HIGH | Indicates that an instruction acquisition is under way. | | φ3— | LOW | Clock signal generated by the processor for synchronization of external devices. | #### 8.3 PROCESSOR The processor function block in Figure 8-1 consists of a MP9529 microprocessor which is functionally equivalent to the TMS 9980A. The factors which distinguish the two are: (1) the MP9529 requires a VDD supply of +9.3 volts typical, (2) has a maximum external clock frequency of 8.08 MHz, and (3) has a maximum free air operating temperature of 50°C. They are otherwise identical. The processor is perhaps the most important part of the system since within it resides the capacity to make decisions and take different courses of action based on those decisions. Processor decisions may result not only through the execution of program instructions involving the processor's STATUS REGISTER (see Figure 8-2) but also as a result of interrupt signal inputs to the processor (see Figure 8-3). In addition to decision making, the processor is responsible for: - Instruction acquisition and interpretation - Timing of most control signals and data transfers - Data, Address, and CRU bus control. Figure 8-4 shows the processor signals grouped by function along with the clock oscillator circuit. #### 8.3.1 CLOCK OSCILLATOR The clock oscillator, composed of two inverters from U14, R9, R10, C6 and Y1, generates the 8 MHz signal INTCLK which is then buffered and routed to the processor as CKIN. From CKIN, the processor internally generates four mutually exclusive clock signals ( $\phi$ 1 through $\phi$ 4) which it uses to synchronize its operations. In addition, the processor inverts and buffers one of its internal clocks to provide $\phi$ 3— which is used externally by processor support and CRU circuitry. ### 8.3.2 EXTERNAL INSTRUCTION DECODING Recall that the address bus is used not only to reference memory and CRU locations but also to identify external instructions. These instructions are CKON, CKOF, IDLE, LREX, and RSET. They allow user-defined external functions to be initiated under program control. When any of these five instructions are executed by the TMS 9980A, a unique three-bit code appears on A0, A1, and A13CRUOUT along with a CRUCLK pulse. IDLE also causes the TMS 9980A to enter the idle state and remain until an interrupt, RESET, or LOAD occurs. While in this state, the code and CRUCLK pulses occur repeatedly until the idle state is terminated. Also recall that the CRU instructions SBZ, SBO, and LDCR also cause CRUCLK to strobe, but that A0 and A1 were always low (logic 0) for CRU operations. To prevent external instruction CRUCLK pulses from affecting CRU devices, the signal IOCLK is decoded by Network U5 from CRUCLK, A0, A1, and A13CRUOUT and is routed to the strobe inputs of CRU devices. U5 also decodes the external instruction codes into mutually exclusive signals for implementation as shown in Figure 8-5. The result of executing external instructions on the TM 990/189 is tabulated in Table 8-2. Figure 8-2. TMS 9980A Internal Architecture Figure 8-3. TMS 9980A CPU Flow Chart Figure 8-4. TMS 9980A Signals Figure 8-5. External Instruction Decode **TABLE 8-2. EXTERNAL INSTRUCTION RESULTS** | INSTRUCTION | EXECUTION RESULTS | |-------------|----------------------------------------------------------------------------------------| | CKON | Illuminates FWD indicator, activates DECK CONTROL— signal to audio cassette interface. | | СКОР | Extinguishes FWD indicator, deactivates DECK CONTROL— signal. | | IDLE | Places TMS 9980A in idle state, illuminates IDLE indicator. | | LREX | Causes TMS 9980A to execute a LOAD operation. | | RSET | Not implemented. Available for user definition. | Control of the FWD indicator is accomplished through flip-flop U4. The decoded signals corresponding to the CKON and CKOF codes are wire-ORed and used to clock U4, which sets or resets depending on the external instruction code. Network U9 is used to "stretch" the decoded IDLE—pulses to fully illuminate the IDLE indicator. #### 8.4 INTERRUPTS Observe that the TMS 9980A has no separate lines for RESET and LOAD signals. Instead, those functions are decoded from the state of interrupt inputs to the microprocessor INTO, 1, and 2 as shown in Table 8-3. Receipt of an active interrupt code causes the processor to respond as illustrated in the CPU Flow Chart, Figure 8-3. Note that the inputs on INTO to INT2 for interrupt levels 1 to 4 are a binary 3 to 6 (0112 to 1102). TABLE 8-3. TMS 9980A INTERRUPT DECODING | INTERRUPT CODE<br>INTO-INT2 | FUNCTION | VECTOR<br>ADDRESS | |-----------------------------|-------------|-------------------| | 000 | RESET | 0000 | | 001 | RESET | 0000 | | 010 | LOAD | 3FFC | | 011 | INTERRUPT 1 | 0004 | | 100 | INTERRUPT 2 | 000B | | 101 | INTERRUPT 3 | 000C | | 110 | INTERRUPT 4 | 0010 | | 111 | _ | | Encoding of the interrupt code signals is performed by the interrupt section of the USER I/O PORT and the LOAD INTERRUPT GENERATOR. Interrupt signal flow is diagrammed in Figure 8-6. The interrupt code is normally generated by the TMS 9901 (U10) in the USER I/O PORT which receives interrupt requests from the SYSTEM I/O PORT and from external sources through connector P5. Interrupt sources are tabulated in Table 8-4. Figure 8-6. Interrupt Signal Flow TABLE 8-4. INTERRUPT SOURCES | CPU FUNCTION | INTERRUPT SOURCE* | SIGNAL<br>NAME | U10 INTERNAL<br>SIGNAL NAME | |--------------|----------------------------|----------------|-----------------------------| | RESET | POWER-UP RESET CIRCUIT, P5 | RESET— | RST1 | | | P5 | USER INT 1— | INT 1 | | | P5. U10 | USER P14 | INT 8/P14 | | | P5, U10 | USER P13 | INT 9/P13 | | LOAD | P5 | USER INT 2— | INT2— | | | P5, U10 | USER P12 | INT 10—/P12 | | INTERRUPT 1 | P5 | USER INT 3— | INT 3— | | | P5, U10 | USER P11 | INT 11—/P11 | | INTERRUPT 2 | P5 | USER INT 4— | INT 4— | | | P5, U10 | USER P10 | INT 12—/P10 | | INTERRUPT 3 | P5 | USER INT 5 | INT 5— | | | P5, U10 | USER P9 | INT 13—/P9 | | INTERRUPT 4 | SYSTEM I/O PORT | KBINT | INT 6— | | | P5, U10 | USER P8 | INT 14—/P8 | | _ | P5, U10 | USER P15 | INT 7/P15 | | | P5, U10 | USER P7 | INT 15/P7 | <sup>\*</sup>P5 -- Connector P5; U10 = User TMS 9901 Two features of the TMS 9901 should be understood before proceeding. First, observe in the TMS 9901 Data Manual that interrupt signals INT7— through INT15— share device pins with input-output signals P15 through P7 respectively. The TMS 9901 automatically disables interrupts from shared pins when that pin is programmed as an output. Without this protection, unwanted interrupts might be generated merely by writing a zero to an I/O bit which shares a device pin with an interrupt input signal. Second, observe in Table 8-3 that INT7— and INT15— generate no interrupt codes usable to the processor in this system. However, they do affect the TMS 9901. For instance, if enabled, pulling the INT15—/P7 pin (signal USERP7) low will cause the TMS 9901 to set its internal INTREQ— bit low, which could then be polled by the processor. Likewise, pulling the INT7—/P15 pin low will cause the same result with the following added action: since the TMS 9901 prioritizes interrupt requests, INT7— being active effectively disables INT8— through INT14— which do cause processor action in this system. INT 15— would also be disabled. From the USER PORT, the interrupt code is routed to the LOAD INTERRUPT GENERATOR which may pass the code on to the processor or interpose its own code depending on the state of POWERGOOD and LOADREQ—. POWERGOOD is generated by the POWER-UP RESET circuit composed of R29, R31, C11, CR8, Q11, U1, U14 and U36 shown in Figure 8-7. At the instant power is applied, C11 begins charging through R31. Q11 and R29 form a voltage follower to buffer the relatively low input impedance of the Schmitt trigger (U36) from the RC network. After approximately one second, the voltage at the emitter of Q11 will have risen to the upper threshold voltage of the Schmitt trigger and its output will go low. That signal is inverted by U14 and becomes POWERGOOD which is fed to a section of U2, a quad two input multiplexer and edge triggered flip-flop. Since POWERGOOD is connected to both D multiplexer inputs, the signal is latched in the flip-flop regardless of the state of the multiplexer select input. The latching operation synchronizes changes in POWERGOOD with $\phi$ 3— and produces PG SYNC. Also notice that while POWERGOOD is low, RESET— is also low, thereby driving the I/O ports (U10 and U11) to known states. PG SYNC is then fed back into U2 to generate the interposing reset and load codes, and to U3 in the load delay circuit. Power-up sequence timing is shown in Figure 8-8. LOADREQ— is generated by the external instruction decoder U5 during an LREX instruction (see Section 8.3.2) or by the load switch S1 and its debounce circuitry U6 and U7 shown in Figure 8-7. The falling edge of LOADREQ— clocks U4, which allows the timing sequence to proceed even if LOADREQ— stays low for an extended period as is possible during actuation of S1. The output of U4 is then clocked by IAQSYNC through two delaying stages in U3 before activating the LOAD— signal. This two-instruction delay is utilized by the UNIBUG monitor when executing a SINGLE STEP command. The timing sequence initiated by a single step execution is shown in Figure 8-9. The timing for a LOAD sequence due to S1 actuation is similar except that LOADREQ— may stay low for an extended time, and the instructions executed before and after LOAD code recognition may differ from those described. The reader may wonder how a single LOAD vector fixed in EPROM could correctly direct the processor through both power-up and LREX sequences, where obviously different actions are performed. To accomplish this, the UNIBUG monitor keeps a flag in memory to tell it if a single step command is currently being performed. Based on the contents of this flag, the processor branches either to the completion of the single step routine or to the power-up routine as appropriate. Figure 8-7. Load Interrupt Generator and Power Up Reset Circuit Figure 8-8. Power-Up Sequence Timing Figure 8-9. Load Timing #### 8.5 MEMORY With fourteen address lines, the TMS 9980A can address up to 16,384 eight-bit memory locations. In this system, a total of 8192 locations are dedicated to onboard devices and the remaining locations are reserved for offboard functions. The system memory map, Figure 8-10 shows the organization of the memory space. #### 8.5.1 MEMORY ADDRESS DECODING The memory address decoding circuit is shown in Figure 8-11. Chip enables for the various onboard memory devices are generated by the coincidence of certain control signals discussed below. Address decoding is performed by U34 which divides the address space into four 4096 byte sectors identified by the control signals LOMEMENA— (low memory enable), DECODE 1, DECODE 2, and HIMEMENA— (high memory enable) as shown in Figure 8-12. As seen from the diagram, the 4K byte system ROM (U33) is enabled by ROMCE— whenever HIMEMENA— is low (3000 $_{16} \le \text{ADDRESS} \le 3\text{FFF}_{16}$ ) and DBIN is high (read cycle in progress). In addition U34 subdivides each sector into 1024 byte blocks, identified by BLOCK 0— through BLOCK 3—. Thus system RAM (U20 and U22) is enabled by RAMCE— whenever LOMEMENA— is low (0000 $\leq$ ADDRESS $\leq$ 0FFF), BLOCK 0— is low (X000 $\leq$ ADDRESS $\leq$ X400), and DRE— is low. DRE— (delayed RAM enable) is derived from DBIN and WE— and is used to prevent data bus conflicts. The RAM devices used in this system normally enable their data output buffers in response to a chip enable unless WE— goes low first. If the data buffers were enabled while the processor was outputting write data on the same lines, erroneous data may be written into the memory. DRE—avoids this problem by delaying RAM chip enables during write operations until WE— has gone low. RAM read and write cycle timing is shown in Figure 8-13 and 8-14. In a similar manner, onboard expansion RAM (U21 and U23) is enabled by EXPRAMCE— under the true conditions of LOMEMENA—, BLOCK 1—, and DRE—. The expansion ROM (U32) is enabled by EPROMCE— when LOMEMENA—, DBIN—, and BLOCK 2— are all low. A jumper option allows BLOCK 3— to be OR'ed with BLOCK 2— to increase the EPROM memory space to 2K bytes for a TMS 2716. #### 8.5.2 MEMORY EXPANSION Offboard memory expansion capability is provided through the Bus Expansion Interface which generates buffered signals corresponding to A0 through A13 CRUOUT, D0 through D7, MEMEN—, WE—, DBIN, and HOLDA. READY and HOLD— inputs to the processor are also provided. The direction of the expansion data bus buffers is controlled by the DIN—signal which is generated as shown in Figure 8-15. The buffers are directed inward whenever DECODE 1— or DECODE 2— is low (1000 $_{16} \le ADDRESS \le 2FFF_{16}$ ) and DBIN is high (read cycle in progress) to allow offboard memory data to be read by the processor. At all other times, the data buffers are directed outward, as are the address and control buffers. With one exception, all expansion buffer outputs go to a passive high impedance state in response to the HOLDA signal from the processor. The exception is EXPHOLDA (expansion hold acknowledge) which always drives outward to inform offboard circuitry that the system has relinquished control of the expansion buses. <sup>\*</sup> USER STRAPPABLE OPTION (SEE SECTION 9). Figure 8-10. System Memory Map Figure 8-11. Memory Address Decoding Figure 8-12. Memory Partitioning Signals NOTE: PROPAGATION DELAYS EXAGGERATED TO SHOW SEQUENCE OF EVENTS. Figure 8-13. RAM Read Cycle Timing Figure 8-15. Expansion Data Bus Control Logic #### 8.6 INPUT-OUTPUT Input-output operations are performed via the Communications Register Unit (CRU). The TMS 9980A CRU addresses a total of 2048 input-output bits effecting data transfers of from one to sixteen bits. #### NOTE In this write-up, reference is made to R12 CRU address and to CRU base address. CRU base address is the actual bit being addressed and is the value on address lines A2 to A12 during a CRU operation, as explained in Section 7. The R12 CRU address is the contents of register 12 during a CRU operation and is used by the processor to determine the address bus contents during the CRU operation. The CRU base address is the R12 CRU address multiplied by two (or the R12 CRU base address shifted left one bit) as described in Section 7. Onboard I/O for the TM 990/189 is defined as four blocks of 32 bits as shown in the System CRU Map, Figure 8-16. Each block (or port) is enabled by a separate signal (USERIOCE—, KBIOCE—, COMIOCE—, or EXTCRUENA) decoded from the address bus as shown in Figure 8-17. CRUENA—insures that each 32-bit block is unique (i.e., appears only once in the CRU map) by requiring that address lines A4 through A7 be low for CRU operations. A8 through A12 route to the individual CRU devices to select the individual bit being referenced while A2 and A3 are decoded to BLOCK 0—through BLOCK 3— and gated with CRUENA— to generate the four enable signals. #### 8.6.1 **USER I/O PORT** The User I/O Port extends from R12 CRU address 000<sub>16</sub> to 03E<sub>16</sub> and consists of a TMS 9901 (U10) which provides 16 bidirectional signal lines available to the user through connector P5. The low order four bits (R12 CRU addresses 020 through 026) are also connected to the drivers for light emitting diodes CR1 through CR4 which illuminate in response to a logic one input. The individual bit assignments of the User Port are shown in Table 8-5. Figure 8-16. System CRU Map Figure 8-17. CRU Address Decoding Logic TABLE 8-5. USER PORT I/O MAP | R12 CRU | | | | | |---------|------------------|------------------------------|-----------------|----------------------| | ADDRESS | BIT<br>ADDRESSED | TMS 9901 BIT ASSIGN<br>INPUT | OUTPUT | SIGNAL LINE AFFECTED | | 000 | 0 | CONTROL BIT | CONTROL BIT | | | 002 | 1 | INT1—, CLK 1 | MASK 1, CLK 1 | UINT 1- | | 004 | 2 | INT2—, CLK 2 | MASK 2, CLK 2 | UINT 2— | | 006 | 3 | INT3—, CLK 3 | MASK 3, CLK 3 | UINT3- | | 800 | 4 | INT4—, CLK 4 | MASK 4, CLK 4 | UINT 4- | | 00A | 5 | INT5—, CLK 5 | MASK 5, CLK 5 | UINT 5- | | 00C | 6 | INT6, CLK 6 | MASK 6, CLK 6 | KBINT— | | 00E | 7 | INT7—, CLK 7 | MASK 7, CLK 7 | USER P15 | | 010 | 8 | INT8—, CLK 8 | MASK 8, CLK 8 | USER P14 | | 012 | 9 | INT9, CLK 9 | MASK 9, CLK 9 | USER P13 | | 014 | 10 | INT10-, CLK 10 | MASK 10, CLK 10 | USER P12 | | 016 | 11 | INT11—, CLK 11 | MASK 11, CLK 11 | USER P11 | | 018 | 12 | INT12—, CLK 12 | MASK 12, CLK 12 | USER P10 | | 01A | 13 | INT13, CLK 13 | MASK 13, CLK 13 | USER P9 | | 01C | 14 | INT14, CLK 14 | MASK 14, CLK 14 | USER P8 | | 01E | 15 | INT15, INTREQ | MASK 15, RST 2— | USER P7 | | 020 | 16 | PO INPUT | P0 OUTPUT | USER PO | | 022 | 17 | P1 INPUT | P1 OUTPUT | USER P1 | | 024 | 18 | P2 INPUT | P2 OUTPUT | USER P2 | | 026 | 19 | P3 INPUT | P3 OUTPUT | USER P3 | | 028 | 20 | P4 INPUT | P4 OUTPUT | USER P4 | | 02A | 21 | P5 INPUT | P5 OUTPUT | USER P5 | | 02C | 22 | P6 INPUT | P6 OUTPUT | USER P6 | | 02E | 23 | P7 INPUT | P7 OUTPUT | USER P7 | | 030 | 24 | P8 INPUT | P8 OUTPUT | USER P8 | | 032 | 25 | P9 INPUT | P9 OUTPUT | USER P9 | | 034 | 26 | P10 INPUT | P10 OUTPUT | USER P10 | | 036 | 27 | P11 INPUT | P11 OUTPUT | USER P11 | | 038 | 28 | P12 INPUT | P12 OUTPUT | USER P12 | | 03A | 29 | P13 INPUT | P13 OUTPUT | USER P13 | | 03C | 30 | P14 INPUT | P14 OUTPUT | USER P14 | | 03E | 31 | P15 INPUT | P15 OUTPUT | USER P15 | # 8.6.2 SYSTEM I/O PORT The System I/O Port occupies CRU addresses 400<sub>16</sub> through 43E<sub>16</sub> and consists of another TMS 9901 (U11) dedicated to onboard devices such as the keyboard, display, sound disc, and the audio cassette interface. Individual bit assignments for the system port are shown in Table 8-6. # 8.6.2.1 Keyboard and Display Interface Signal flow between the TMS 9901 and keyboard and display is diagrammed in Figure 8-18. UNIBUG software routines scan both the keyboard and display thereby minimizing the hardware required to drive the 80 display segments and read the 45 keyswitches. The display is a twelve digit common cathode seven segment L.E.D. type of which the middle ten digits are used. Used digits are numbered left to right from 1 to 10. Segments within a digit are designated as shown in Figure 8-19. Figure 8-18. Keyboard and Display Interface Block Diagram Figure 8-19. Display Segment Designation TABLE 8-6. SYSTEM PORT I/O MAP | R12 CRU | | | | | |---------|------------------|-----------------|-----------------|----------------------| | ADDRESS | BIT<br>ADDRESSED | INPUT | OUTPUT | SIGNAL LINE AFFECTED | | 400 | 0 | CONTROL BIT | CONTROL BIT | | | 402 | 1 | INT1—, CLK 1 | MASK 1, CLK 1 | КВ1— | | 404 | 2 | INT2—, CLK 2 | MASK 2, CLK 2 | KB2— | | 406 | 3 | INT3, CLK 3 | MASK 3, CLK 3 | KB3 | | 408 | 4 | INT4—, CLK 4 | MASK 4, CLK 4 | KB4— | | 40A | 5 | INT5—, CLK 5 | MASK 5, CLK 5 | KB5— | | 40C | 6 | INT6—, CLK 6 | MASK 6, CLK 6 | RDATA | | 40E | 7 | INT7—, CLK 7 | MASK 7, CLK 7 | | | 410 | 8 | INT8, CLK 8 | MASK 8, CLK 8 | | | 412 | 9 | INT9—, CLK 9 | MASK 9, CLK 9 | | | 414 | 10 | INT10-, CLK 10 | MASK 10, CLK 10 | | | 416 | 11 | INT11, CLK 11 | MASK 11, CLK 11 | | | 418 | 12 | INT12, CLK 12 | MASK 12, CLK 12 | | | 41A | 13 | INT13-, CLK 13 | MASK 13, CLK 13 | | | 41C | 14 | INT14, CLK 14 | MASK 14, CLK 14 | | | 41E | 15 | INT15—, INTREQ— | MASK 15, RST 2— | | | 420 | 16 | P0 INPUT | P0 OUTPUT | DIGITSEL A | | 422 | 17 | P1 INUT | P1 OUTPUT | DIGITSELB | | 424 | 18 | P2 INPUT | P2 OUTPUT | DIGITSELC | | 426 | 19 | P3 INPUT | P3 OUTPUT | DIGITSEL D | | 428 | 20 | P4 INPUT | P4 OUTPUT | SEGMENT A- | | 42A | 21 | P5 INPUT | P5 OUTPUT | SEGMENT B | | 42C | 22 | P6 INPUT | P6 OUTPUT | SEGMENT C— | | 42E | 23 | P7 INPUT | P7 OUTPUT | SEGMENT D— | | 430 | 24 | P8 INPUT | P8 OUTPUT | SEGMENT E- | | 432 | 25 | P9 INPUT | P9 OUTPUT | SEGMENT F | | 434 | 26 | P10 INPUT | P10 OUTPUT | SEGMENT G— | | 436 | 27 | P11 INPUT | P11 OUTPUT | SEGMENT P— | | 438 | 28 | P12 INPUT | P12 OUTPUT | DSPLYTRIGR— | | 43A | 29 | P13 INPUT | P13 OUTPUT | SHIFTLIGHT | | 43C | 30 | P14 INPUT | P14 OUTPUT | SPKRDRIVE | | 43E | 31 | P15 INPUT | P15 OUTPUT | WDATA | Display segment and digit driver circuits are shown in Figure 8-20. Current is sourced to all A segment anodes by pulling SEGMENT A— low, provided DISPLAYENA— is also low. Current is sunk from all digit 1 cathodes by pulling DIGIT 1— low, which is accomplished through U8 (a 74LS145, one of ten decoder) by placing an all zero code on DIGITSEL A through DIGITSEL B. The remaining segments and digits are driven in a similar manner. All L.E.D.'s between sourced anode connections and sunk cathode connections will be illuminated. While scanning the display does reduce the amount of display drive circuitry needed, it also reduces each segment's duty cycle, and hence, its apparent brightness. To counteract this effect, the segment currents are set much higher than normally required for continuous operation. The resulting high-intensity pulse is perceived by the eye to be of normal brightness. The increased segment current does not harm the display because the average power dissipated in each segment is still within normal limits. However, should normal program control ever be lost, it is possible that segments could remain illuminated for extended periods resulting in display damage. The fail-safe timer (U29) guards against that possibility by requiring constant reassurance from the scan routine that program control is being maintained. That reassurance is provided by periodic pulsing of the DSPLYTRIGR— line. Loss of that drive signal allows the timer to expire and drives DISPLAYENA—high disabling the entire display. Figure 8-20. Display Driver Circuitry The keyboard is composed of 45 normally open switches connected in a matrix between 9 rows and 5 columns as shown in Figure 8-21. Keyboard scanning is normally performed in conjunction with the display scan. As mentioned above, digits are enabled by outputting a four bit select code on DIGITSEL A through DIGITSEL D which is decoded to ten active low enable lines. Nine of those lines (DIGIT 1— through DIGIT 9—) are routed to the keyboard row lines. Once a display digit is selected and the corresponding keyboard row line enabled, key closures on that row are detected by reading the state of the keyboard column lines KB1— through KB5—. Since the column lines have pull-up resistors and therefore normally float at a logic one, a low level on a column line indicates a key closure to the enabled row line. The column lines KB1— through KB5— are read through U11 using another unique feature of the TMS 9901. Since the device contains an interrupt mask register, activity on the interrupt inputs may be prevented from causing interrupt code generation. However, the actual state of the interrupt input lines may still be read using the TB and STCR instructions. Therefore, with interrupts masked, the dedicated interrupt request pins (INT 1— through INT 6—) may be used as ordinary input pins for reading data. The state of the keyboard column lines is then read by interrogating the INT 1— through INT 5— bits in U11. Figure 8-21. Keyboard Interface # 8.6.2.2 Audio Cassette Interface The Audio Cassette Interface allows the user to read and write digital data on a voice-quality cassette or reel recorder. The purpose of the interface is to translate the TTL level data signals to recorder-compatible signal levels, and vice versa. The actual generation and interpretation of the data streams is done by the processor under software control. The UNIBUG monitor encodes data on tape using a frequency—hift keying (FSK) technique where a logic zero is represented by two complete cycles at 1200 Hz and clogic one is represented by two cycles at 2400 Hz. UNIBUG computes the required signal frequency based on the data bit to be written and outputs an approximate square wave of that frequency on WDATA (P15 of U11). The WDATA signal is then shifted to tape-compatible levels by the write circuit shown in Figure 8-22. Buffered by open-collector gate U7, the signal is then attenuated by the voltage divider composed of R45 and R46 to approximately 500 millivolts peak to peak. A low pass filter consisting of R47 and C10 then removes the higher frequency components and presents the rounded square wave signal to the recorder. Notice that the logical inversion of the signal by U7 is unimportant since the information is contained in the frequency of the signal and not its magnitude. Figure 8-22. Cassette Write Circuit Playback signals from the recorder are conditioned by the read circuit shown in Figure 8-23. Resistor R42 places a light load on the AUDIOIN signal line to reduce effects from induced noise while C9 blocks any DC component of the audio signal. A magnitude limiting stage composed of R43, U38, CR10, and CR11 then clips the signal to a peak level of one diode drop, or approximately 600 millivolts. It is then amplified by a gain stage consisting of the remainder of U38, R40, and R41 and squared by Schmitt trigger U36 to produce RDATA which is read by U11. R30 is used to slightly modify the normal threshold voltages of the device to center its hysteresis characteristics more about zero volts. Observe that due to the double inversion of the signal, once by the limiter and again by the Schmitt trigger, RDATA has the same voltage polarity as AUDIOIN. R50 is used to supply a small amount of positive feedback to the input of the limiter and give the entire circuit the characteristics of a Schmitt trigger. R51, together with R50, sets the overall circuit's threshold voltages and determines its hysteresis. Figure 8-23. Cassette Read Circuit #### 8.6.2.3 Sound Disc The Sound Disc (DS1) is a piezoelectric crystal which flexes when an electric potential is applied across it. The SPKRDRIVE signal (P14 of U11) is amplified by Q10 and applied to the disc which generates a tone of frequency equal to the SPKRDRIVE signal. ### 8.6.3 SERIAL COMMUNICATIONS PORT The Serial Communications Port occupies CRU addresses 80016 through 83E16 and consists of a TMS 9902 Asynchronous Communications Controller and interface devices for conversion of signals to RS-232-C and 20 milliampere current loop levels. The TMS 9902 receives data from the CR4 and generates the timing and handshaking signals necessary to send the data to a data terminal such as a printer or video display. In addition, the TMS 9902 receives data from the terminal and buffers it for presentation to the CRU. The bit assignments of the Serial Communications Port are shown in Table 8-7. These signals can be brought out to an optional 25-pin EIA connector installed by the user at P3. TABLE 8-7. COMMUNICATIONS I/O MAP | TMC 0001 RIT ASSIGNMENT | TRAC | 0001 | DIT | ACCM | 2NB | <b>JENT</b> | |-------------------------|------|------|-----|------|-----|-------------| |-------------------------|------|------|-----|------|-----|-------------| | | | TMS 9901 BIT AS | SIGNMENT | | |-------------------------------------------------------------|----------------------------------------------|--------------------------------------------------|-------------------------------------------|----------------------------| | R12 CRU<br>ADDRESS | BIT<br>ADDRESSED | INPUT | OUTPUT | SIGNAL LINE AFFECTED | | 800<br>802 | 0<br>1<br>2 | RBR 0<br>RBR 1<br>RBR 2 | *<br>* | | | 804<br>806<br>808<br>80A<br>80C<br>80E<br>810 | 3<br>4<br>5<br>6<br>7<br>8 | RBR 3<br>RBR 4<br>RBR 5<br>RBR 6<br>RBR 7 | *<br>*<br>*<br>* | | | 812<br>814<br>816<br>818<br>81A<br>81C<br>81E<br>820<br>822 | 9<br>10<br>11<br>12<br>13<br>14<br>15<br>16 | RCVERR RPER ROVER RFER RFBD RSBD RIN RBINT XBINT | * LXDR LRDR LDIR LDCTRL TSTMD RTSON BRKON | RCVDATA<br>RST—<br>XMTDATA | | 824<br>826<br>828<br>82A<br>82C<br>82E<br>830<br>832 | 18<br>19<br>20<br>21<br>22<br>23<br>24<br>25 | 0 TIMINT DSCINT RBRL XBRE XSRE TIMERR TIMELP | RIENB<br>XRIENB<br>TIMENB<br>DSCENB | | | 834<br>836<br>838<br>83A<br>83C<br>83E | 26<br>27<br>28<br>29<br>30<br>31 | RTS<br>DSR<br>CTS<br>DSCH<br>FLAG<br>INT | RESET | RTS—<br>DSR—<br>RTS— | <sup>\*</sup>Control, Interval, Receive Data Rate, Transmit Data Rate, and Transmit Buffer Registers depending on Register Load Control Flags (bits 14-11). See TMS 9902 Data Manual in Appendix F. # 8.6.4 EXTERNAL I/O PORT The External I/O Port allows the user to expand his input-output capability offboard. Signals provided through the Bus Expansion Interface include the address lines, A13 CRUOUT, CRUIN, IOCLK, and EXPCRUENA and are available at connector P4. Signal $\phi 3-$ is alos provided to facilitate I/O expansion using TMS 9900 family I/O devices. P inputs from external CR4 devices are enabled by EXPCRUENA (see Figure 8-24) at R12 CRU addresses C0016. A jumper option is provided to allow expansion of external I/O to R12 CRU addresses C0016 through FFE16. Outputs to external CRU devices are determined by decode logic constructed by the user, typically being a function of EXPCRUENA and address lines A8 through A12. The external CRU bus outputs, like the address and data bus lines, enter a high impedance state in response to the HOLDA signal from the processor. Figure 8-24. External I/O Port #### **SECTION 9** #### **USER OPTIONS** ## 9.1 INTRODUCTION Users wishing to expand the capability of their TM 990/189 are encouraged to make use of the numerous user options already provided on the board. This section describes those options and details procedures for their incorporation. Figure 9-1 shows the layout of the TM 990/189 board. ## 9.2 MEMORY OPTIONS ## 9.2.1 ON-BOARD RAM EXPANSION On-board RAM may be expanded to 2048 bytes by installing memory devices as shown below. User RAM will then extend from memory addresses > 0000 to > 07FF. | QTY | DESCRIPTION | INSTALL AT | |-----|-------------------------------------|------------| | 2 | TMS 4014 OR EQUIVALENT (TMS 4045) * | U21, U23 | ## 9.2.2 ON-BOARD EPROM, 1K BYTES 1024 bytes of EPROM may be added to the board by installing the device listed below. Circuitry is already provided to map the EPROM at memory addresses >0800 to >0BFF. | QTY | DESCRIPTION | INSTALL AT | |-----|-------------|------------| | 1 | TMS 2708 | U32 | ## 9.2.3 ON-BOARD EPROM, 2 K BYTES 2048 bytes of EPROM may be added to the board by modifying the board per the procedure below and installing the device below. Following the modification, the EPROM will be mapped at memory addresses >0800 to >0FFF. | QTY | DESCRIPTION | INSTALL AT | |-----|-------------|------------| | 1 | TMS 2716 | U32 | #### **Modification Procedure:** - a. Cut the conductor trace between E38 and E39. - b. Cut the trace between E40 and E41. - c. Add a jumper wire between E39 and E40. - Add a jumper between E41 and E42. - e. Add a jumper between E49 and E50. <sup>\*</sup>The TMS 4045 RAM (which can tolerate up to 10 percent power supply noise) can be substituted for the TMS 4014 RAM (which can tolerate up to 5 percent power supply noise). Figure 9-1. TM 990/189 Board Layout ## 9.2.4 ON-BOARD EPROM, 4K BYTES 4096 bytes of EPROM may be substituted for the system ROM by removing the device at U33 and replacing it with EPROM listed below: | QTY | DESCRIPTION | INSTALL AT | |-----|-------------|------------| | 1 | TMS 2532 | U33 | While sacrificing the use of the UNIBUG monitor and assembler, this substitution provides the capability for installing resident user programs of up to 4096 bytes on the board. This capability may be expanded to 6144 bytes by installing an additional 2K byte EPROM per Section 9.1.3. Typical applications of this option include user-written operating systems and applications programs. The 4K byte EPROM is mapped at memory addresses >3000 to >3FFF. ## 9.2.5 OFF-BOARD MEMORY EXPANSION Up to 8192 bytes of user-defined off-board memory or memory-mapped I/O may be used, in addition to the on-board memory described above, by installing the Bus Expansion Interface components per Table 9.1. Signals provided through the interface include the address bus, data bus, and memory control signals. These signals are available at connector port P4 as shown on sheet 11 of the schematics in Appendix A. TABLE 9-1. LIST OF MATERIALS, OFFBOARD MEMORY EXPANSION | ITEM | QTY | DESCRIPTION | INSTALL AT | |------------------|-------------|------------------------------------------------------|-------------------------------| | 1<br>2<br>3<br>4 | 1<br>2<br>1 | 74LS126<br>74LS244<br>74LS245<br>RES, 10K, 5%, 0.25W | U30<br>U18, U26<br>U27<br>R34 | ## 9.3 INPUT-OUTPUT OPTIONS ## 9.3.1 ASYNCHRONOUS COMMUNICATIONS, EIA The capability to perform asynchronous serial communications with devices meeting the requirements of RS-232-C may be added to the board by installing Serial Communication Interface components per Table 9-2. The interface occupies CRU base addresses >0800 through >083E. When installed, signals are available at 25-pin connector P3 as shown in sheet 10 of the schematics (Appendix A). This sheet also shows the interconnection of the components in Table 9-2. TABLE 9-2. LIST OF MATERIAL, EIA OPTION | ITEM | QTY | DESCRIPTION | INSTALL AT | |------|-----|----------------------------------------------|------------| | 1 | 1 | TMS 9902 | U31 | | 2 | 1 | 75188 | U37 | | 3 | 1 | RES, 10KΩ, 10%, 0.25W | R34 | | 4 | 2 | RES, 3.3KΩ,10%, 0.25W | R35, R36 | | 5 | 1 | Connector, AMP 206584-2 or CANNON DBP-25S-AA | P3 | #### 9.3.2 **ASYNCHRONOUS COMMUNICATIONS, TTY** The capability to perform asynchronous serial communications with devices having a 20 mA current loop interface may be added by modifying the board as described below and installing Serial Communications Interface components per Table 9-3. When installed, signals will be available at 25-pin connector P3 as shown on sheet 10 of the schematics in Appendix A. This sheet also shows the components in Table 9-3. The serial interface occupies R12 CRU base addresses >0800 through >083E. #### Modification Procedure: Add a jumper wire between E25 and E26. TABLE 9-3. LIST OF MATERIALS, TTY OPTION | ITEM | M QTY DESCRIPTION | | INSTALL AT | | |----------|-------------------|----------------------------------------------|------------|--| | 1 | 1 | TMS 9902 | | | | 2 | 1 | 75188 | U31 | | | 3 | 1 | 2N2905 | U37 | | | 4 | 1 | 1N914B | Q12 | | | 5 | , | , · · · · · · · · · · · · · · · · · · · | CR9 | | | 6 | | RES, 33KΩ, 10%, 0.25W | R32 | | | 7 | ! | RES, 3.3KΩ 10%, 0.25W | R33 | | | <u>'</u> | 7 | RES, 10KΩ, 10%, 0.25W | | | | 8 | 1 | RES, 330Ω, 10%, 0.5W | R34 | | | 9 | 1 | RES, 560Ω, 10%, 0.5W | R37 | | | 10 | 1 | RES, 2.7KΩ 10%, 0.25W | R38 | | | 11 | 1 | CONNECTOR AND SOCIETY | R39 | | | | | CONNECTOR, AMF 206584-2 or CANNON DBP-25S-AA | P3 | | #### 9.3.3 **ON-BOARD CASSETTE RELAY** Control of the cassette deck motors may be performed by the TM 990/189 through the installation of a on-board relay and transient protection diode as listed below, and connection of P2 pins 1 and 4 to the deck's "REMOTE" jack. | ITEM | QTY | DESCRIPTION | INSTALL AT | |------|-----|--------------------------|------------| | 1 | 1 | 1N914B | CR12 | | 2 | 1 | RELAY, COSAR 1112-12-1A* | K1 | Cosar, 3121 Benton St., Garland, Texas 75042 #### CAUTION Operation with cassette models other than those listed in paragraph 2.7.1 may not yield reliable data transfers and certain models of recorders can damage the TM 990/189 control relay due to excessive inrush currents. #### 9.3.4 OFF-BOARD CASSETTE RELAY If the user wishes to control the cassette motors by a means other than the on-board relay described in Section 9.3.3, jumper options make available the open-collector drive signal DECKCONTROL along with connections to +12 volts, +5 volts, and GROUND. Refer to page 12 of the logic diagram in Appendix A for connection details. Care should be exercised to avoid exceeding the maximum output voltage and current ratings of the 7416 which drives the DECKCONTROL— signal. Those ratings are +25V and 40 mA respectively. #### 9.3.5 OFF-BOARD CRU EXPANSION In addition to the three on-board devices comprising the User I/O Port, keyboard I/O Port, and Serial Communications Interface, CRU devices may be expanded off-board through the Bus Expansion Interface by installing the components listed below. | ITEM | QTY | DESCRIPTION | INSTALL AT | |------|-----|-------------|------------| | 1 | 1 | 74LS126 | U30 | | 2 | 2 | 74LS244 | U18, U26 | This CRU expansion uses the buffered outputs of address lines A2 through A12 and the A13 CRUOUT line with a 74LS244 installed in U18 and U26. This is shown in sheet 11 of the schematics in Appendix A. CRU output operations may be performed at any CRU base (bit) address from >00016 through XEFF16 (R12 CRU address 00016 through FFE16) by externally decoding address bus lines A2 to A12 and writing the data present on the EXPA13CRUOUT line at that location. The user should be aware that output operations to offboard devices at R12 CRU address >000 through 03E, >400 through >43E, and >800 through >83E will also cause transfers to the onboard devices at those same locations which may result in unexpected actions being taken. Figure 8-12 is a map of the CRU addressing scheme. CRU input operations from off-board devices are controlled by the EXPCRUENA signal which defines a block of 32 bits extending from R12 CRU address>C00 through>C3E. Derivation of this signal is shown on sheets 2 and 11 of the schematics. Capability to input from off-board devices may be expanded to a block of 512 bits extending from R12 CRU address >C00 through >FFE. Expansion is accomplished by performing the modification procedure below. Modification Procedure for expanding off-board CRU input capability to 512 bits: - a. Cut the conductor trace between E51 and E52. - b. Add a jumper wire between E51 and E65. After installation, data bus, address bus, and control signals are available at port P4 as shown on sheet 11 of the schematics in Appendix A. #### 9.3.6 ON-BOARD LED DISCONNECTION Each TM 990/189 is supplied with LED indicators CR1 through CR4 driven by a 7416 open-collector inverter connected to signals USERP3 through USERP0 respectively, the least significant four bits of the User I/O Port. Thus, each signal USERP3 through USERP0 already drives one TTL load. This is shown on sheet 7 of the schematics, Appendix A. To avoid exceeding the output drive capability of U10 (TMS 9901) when connecting the User I/O Port to offboard circuitry, the user may find it necessary to disconnect the one TTL load established by the LED driver. Disconnection is accomplished by performing the modifications described in Table 9-4. **TABLE 9-4. LED DISCONNECTION MODIFICATION** | TO REMOVE LOAD ON | CUT TRACE BETWEEN | |-------------------|-------------------| | User P0 | E27, E28 | | User P1 | E31, E32 | | User P2 | E33, E34 | | User P2 | E33, E34 | | User P3 | E29, E30 | ## 9.4 PROCESSOR OPTIONS ## 9.4.1 COMMUNICATIONS INTERRUPTS Provision is made to allow the user to connect the interrupt request signal from the TMS 9902 communications controller (COMINT—) to one of five interrupt inputs to the TMS 9901 system interrupt port (INT1— to INT5—). This connection allows the user to utilize the TMS 9902's interrupt in various applications including interrupt-driven I/O routines. Connection is made by performing the modification procedure described in Table 9-5. Interconnections are shown on sheet 7 of the schematics in Appendix A. TABLE 9-5, COMMUNICATIONS INTERRUPT MODIFICATION | TO CONNECT SIGNALS COMINT— AND | ADD JUMPER BETWEEN E16 AF | | |--------------------------------|---------------------------|--| | INT1— | E23 | | | INT 2— | E24 | | | INT 3— | E22 | | | INT 4— | E19 | | | INT 5— | E18 | | ### 9.4.2 SYSTEM CLOCK FREQUENCY Some users may wish to increase the system clock frequency above 2.0 MHz to increase processor throughput. This may be accomplished by removing the MP9529 processor (U19) and oscillator crystal (Y1) and installing the components listed in Table 9-6. The replacement crystal should be a series resonant fundamental-mode type with a frequency four times that of the desired new system frequency. Interconnections are shown on sheet 2 of the schematics in Appendix A. The user should be reminded that timing for the keyboard, display, and communications routines is dependent on the system frequency and may require modification for use at the new frequency. TABLE 9-6. LIST OF MATERIALS, SYSTEM FREQUENCY MODIFICATION | ITEM | QTY | DESCRIPTION | INSTALL AT | |------|-----|----------------------|------------| | 1 | 1 | TMS 9980A | U19 | | 2 | 1 | CRYSTAL, SEE TEXT | Y1 | | 3 | 1 | RES, 10Ω, 10%, 0.25W | R49 | ### **SECTION 10** ## TROUBLESHOOTING SUGGESTIONS ## 10.1 INTRODUCTION This section outlines a suggested procedure for troubleshooting malfunctioning boards. It is assumed that the user has access to the following test equipment: - Oscilloscope, preferably dual-trace, triggered sweep - 10X oscilloscope probes - VOM Additional equipment which the user may find helpful includes: - Logic probe - Logic analyzer - Magnifying glass It is suggested that the user review the theory of operation of the board in Section 8 before proceeding with the troubleshooting procedures. # 10.2 TI⊀OUBLESHOOTING PROCEDURE ## 10.2.1 VISUAL CHECKS Probably the greatest source of board problems is shorts between signals caused by foreign objects and solder bridges between adjacent solder joints. Inspect both sides of the board carefully and remove any shorts observed. Also, brush both sides of the board with a soft dry brush, such as a drafting brush, to sweep away any loose objects which were not spotted in the visual inspection. ## 10.2.2 STATIC CHECKS With power applied to the board, measure the three primary supply voltages and compare the measured values to the operational limits listed in Table10-1. A convenient place to access those voltages is at the power supply bypass capacitors (C3, C4 and C5) near P2 (see Table 10-1). If the primary supplies are within their specified limits, then check the secondary supplies, -5V and VDD, which are derived onboard from the primary supply voltages. See note 8 on sheet 1 of the logic diagram for comments regarding the VDD supply. Operational limits for the secondary supplies are also listed in Table 10-1. **TABLE 10-1. SUPPLY VOLTAGE OPERATIONAL LIMITS** | SUPPLY | LIMI | TS | CHECK AT | COMMENTS | |--------|-------|-------|------------|-----------------------------------| | | MIN | MAX | | COMMENTS | | +5V | 4.75 | 5.25 | +end, C5 | | | +12V | 11.4 | 12.6 | +end, C3 | | | -12V | -11.4 | -12.6 | -end, C4 | | | ~5V | -4.75 | -5.25 | U19 pin 21 | | | VDD | 8.75 | 9.95 | U19 pin 36 | See Note 8, Logic Diagram, Page 1 | ## 10.2.3 DYNAMIC CHECKS If the visual and static checks have not revealed the source of the problem, then proceed with the dynamic checks below. Figures 10-2 through 10-10 show various signal waveforms present on the board under normal conditions. Many waveforms show clock phase $\phi 3-$ at the top of the photo to provide a relative timing reference. The user should keep in mind that the waveforms shown are typical and may vary slightly from board to board due to component variations and instructions being executed at that time. Figure 10-1 provides information to be used in the interpretation of the photographs. The following procedure may be followed to help guide the user's investigation. Figure 10-1. Photo Interpretation Guide a. Refer to sheet 12 of the logic diagrams. Observe the waveform of the voltage across C11 in the power-up reset circuit at application and immediately following application of power to the board. Also observe the waveform of the RESET— and POWERGOOD signals and compare with Figure 10-2. POWERGOOD is not shown in the figure but should follow RESET— high 400 to 1400 milliseconds after power is applied. Figure 10-2. VC11 vs. RESET- b. Refer to sheet 2 of the logic diagram. Observe the waveforms of CKIN and clock phase $\phi$ 3—at the microprocessor and compare with Figure 10-3. #### NOTE When making high frequency measurements such as above, use the shortest possible scope probe ground lead. The increased inductance and stray capacitance associated with longer ground leads can introduce resonant stages in the equivalent circuit of the scope probe which are not negligible at the signal frequencies being observed. The effect will be observed as severe waveform ringing following signal transitions, and greatly degrades the quality of the information obtainable from the waveform. - Refer to sheet 2 of the logic diagrams. Observe the waveforms of MEMEN—, DBIN, IAQ, WE—, and CRUCLK at the microprocessor. Compare with Figures 10-4 through 10-8. - d. For problems associated with the audio cassette interface, refer to sheets 8 and 12 of the logic diagrams. Observe the waveforms of AUDIOIN, RDATA, WDATA, and AUDIOOUT with the recorder connected and operating in the appropriate playback or record mode. #### 10.3 TECHNICAL ASSISTANCE Users experiencing difficulty with the operation or debug of their board may refer their questions to the Microprocessor Customer Support Line at (713) 776-6632 or address them to: Texas Instruments Incorporated 8600 Commerce Park Drive Suite 700, M/S 6404 Houston, Texas 77036 Figure 10-3. CKIN vs. Clock Phase $\phi$ 3 – Figure 10-4. Clock Phase $\phi$ 3— vs, MEMEN— Figure 10-5. Clock Phase $\phi$ 3— vs. DBIN Figure 10-6. Clock Phase $\phi$ 3— vs. IAQ Figure 10-7. Clock Phase $\phi$ 3— vs. WE— Figure 10-8. Clock Phase $\phi$ 3— vs. CRUCLK Figure 10-9. AUDIOIN vs. RDATA Figure 10-10. WDATA vs. AUDIO OUT # APPENDIX A SCHEMATICS ## **APPENDIX B** ## **MEMORY DATA SHEETS** | B.1 TMS 2516 and TMS 2533 | R 1 | TMS | 2516 | and | <b>TMS</b> | 2532 | |---------------------------|-----|-----|------|-----|------------|------| |---------------------------|-----|-----|------|-----|------------|------| - B.2 TMS 4732 - B.3 TMS 2708 - B.4 TMS 4045 - B.5 TMS 4014 # MOS LSI ## TMS 2516 JL AND TMS 2532 JL 16K AND 32K EPROMS APRIL 197 - Organization: - TMS 2516 . . . 2K X 8 - TMS 2532 . . . 4K X 8 - Single +5 V Power Supply - Pin Compatible with Existing ROMs and EPROMs (8 K, 16 K, 32 K, and 64 K) - JEDEC Standard Pinouts - All Inputs/Outputs Fully TTL Compatible - Static Operation (No Clocks, No Refresh) - Max Access/Min Cycle Time . . . 450 ns - 8-Bit Output for Use in Microprocessor-Based Systems - N-Channel Silicon-Gate Technology - 3-State Output Buffers - Low Power - Active: TMS 2516 . . . 285 mW Typical TMS 2532 . . . 400 mW Typical - Standby . . . 50 mW Typical - Guaranteed dc Noise Immunity with Standard TTL Loads - No Pull-Up Resistors Required | PIN NOMENCLATURE | | | | | | |------------------|--------------------|--|--|--|--| | A(N) | Address inputs | | | | | | <u>cs</u> | Chip Select | | | | | | PD/PGM PD/PGM | Power Down/Program | | | | | | Q(N) | Input/Output | | | | | | Vcc | +5 V Power Supply | | | | | | Vpp | +25 V Power Supply | | | | | | V <sub>SS</sub> | 0 V Ground | | | | | #### description The TMS 2516 JL and TMS 2532 JL are 16,384-bit and 32,768-bit, ultraviolet light erasable, electrically programmable read-only memories. These devices are fabricated using N-channel silicon-gate technology for high speed and simple interface with MOS and Bipolar circuits. All inputs (including program data inputs) can be driven by Series 74 TTL circuits without the use of external pull-up resistors, and each output can drive one Series 74 TTL circuit without external resistors. The data outputs are three-state for OR-tying multiple devices on a common bus. The TMS 2516 is upward pin-compatible with the TMS 2532 and the TMS 2532 is plug-in compatible with the TMS 4732 32K ROM. Since these EPROMs operate from a single +5 V supply (in the read mode), they are ideal for use in microprocessor systems. One other (+25 V) supply is needed for programming but all programming signals are TTL level, requiring a single 50 ms pulse. For programming outside of the system, existing EPROM programmers can be used. Locations may be programmed singly, in blocks, or at random. Total programming time for all bits for the TMS 2516 is 100 seconds; 200 seconds for the TMS 2532. #### operation | DE | EVICE | | | | | | | MODE | | | | | | |--------------------|----------------|----------|------|-------|-------------------|-------|------|----------------------|------------|------------------------|------|-------------------------|--| | FUNCTION<br>(PINS) | | Read | | 1 | Output<br>Disable | | Down | Start<br>Programming | | Inhibit<br>Programming | | Program<br>Verification | | | TMS | | 2516 | 2532 | 2516 | 2532 | 2516 | 2532 | 2516 | 2532 | 2516 | 2532 | 2516 | 2532 | 2516 | | | PD/PGM | PD/PGM | VIL | VIL | Don't | VIH | VIH | VIН | Pulsed VIL | Pulsed VIH | VIL | VIH | VIL | | | (18) | (20) | <u> </u> | | Care | | | L. 1 | to VIH | to VIL | | 1 | | | | CS . | Use PD/PGM | VIL | N/A | VIH | N/A | Don't | N/A | VIH | N/A | VIH | N/A | VIL | | | (20) | as chip select | ŀ | | | | Care | | | | | | | | | Vpp | Vpp | +5 | +5 | +5 | +5 | +5 | + 5 | +25 | +25 | +25 | +25 | +25 | | | (21) | (21) | | ļ | | | | | | | ĺ | 1 | (or + 5) | | | Vcc | Vcc | +5 | +5 | +5 | +t5 | +5 | +5 | +5 | +5 | +5 | +5 | +5 | | | (24) | (24) | | | | | | | | | | | | | | α, | Q | a | Q | HI-Z | HI-Z | HI-Z | HI-Z | D | D | HI-Z | HI-Z | a | | | (9 to 11, | (9 to 11, | | | | | | | | | | | | | | 13 to 17) | 13 to 17) | | | | | | | | | | | | | #### read/output disable When the outputs of two or more TMS 2516's and/or TMS 2532's are commoned on the same bus, the output of any particular device in the circuit can be read with no interference from the competing outputs of the other devices. If the device whose output is to be read is a TMS 2516, it should have a low-level TTL signal applied to the $\overline{\text{CS}}$ and PD/PGM pins. If it is a TMS 2532, the low-level signal is applied to the PD/ $\overline{\text{PGM}}$ pin. All other devices in the circuit should have their outputs disabled by applying a high-level signal to these same pins. (PD/PGM on the TMS 2516, can be left low, but it may be advantageous to power down the device during output disable.) Output data is accessed at pins Q1 to Q8. Data can be accessed in 450 ns $^{\pm}$ ta(A). (On the TMS 2516 access time from $\overline{\text{CS}}$ is 150 ns $^{\pm}$ ta( $\overline{\text{CS}}$ ), once the addresses are stable.) #### power down Active power dissipation can be cut by 80% by applying a high TTL signal to the PD/PGM (PD/PGM for the TMS 2532) pin. In this mode all outputs are in a high-impedance state. #### erasure Before programming, the TMS 2516 or TMS 2532 is erased by exposing the chip through the transparent lid to high intensity ultraviolet light (wavelength 2537 angstroms). The recommended minimum exposure dose (= UV intensity X exposure time) is fifteen watt-seconds per square centimeter. A typical 12 milliwatt per square centimeter, filterless UV lamp will erase the device in about 21 minutes. The lamp should be located about 2.5 centimeters above the chip during erasure. After erasure, all bits are in the "1" state. #### start programming After erasure (all bits in logic "1" state), logic "0's" are programmed into the desired locations. A "0" can be erased only by ultraviolet light. The programming mode is achieved when Vpp is 25 V and $\overline{\text{CS}}$ (for TMS 2516 only) is at V IN. Data is presented in parallel (8 bits) on pins Q1 to Q8. Once addresses and data are stable, a 50 millisecond high TTL pulse (low for the TMS 2532) should be applied to the PGM pin at each address location to be programmed. Maximum pulse width is 55 milliseconds. Locations can be programmed in any order. More than one TMS 2516 or TMS 2532 can be programmed when the devices are connected in parallel. TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 5012 • DALLAS, TEXAS 75222 #### inhibit programming When two or more devices (either TMS 2516 or TMS 2532, or a combination of both) are connected in parallel, data can be programmed into all devices or only chosen devices. TMS 2516's not intended to be programmed (i.e., inhibited) should have a low level applied to the PD/PGM pin and a high-level applied to the $\overline{\text{CS}}$ pin. TMS 2532's not intended to be programmed should have a high level applied to PD/ $\overline{\text{PGM}}$ . ### program verification A verify is done to see if the device was programmed correctly. A verify can be done at any time. It can be done on each location immediately after that location ia programmed. To do a verify on the TMS 2516 Vpp may be kept at + 25 V. (Verify on the TMS 2532 is the read operation.) # absolute maximum ratings over operating free-air temperature range (unless otherwise noted)\* | Supply voltage, VCC (see Note 1) | 0.3 to 6 V | |------------------------------------------------|----------------| | Supply voltage, Vpp (see Note 1) | 0.3 to 28 V | | All input voltages (see Note 1) | -0.3 to 6 V | | All input voltages (see Note 1) | 0.3 to 6 V | | Output voltage (operating with respect to VSS) | 0.3 to 0 V | | Operating free-air temperature range | 0 0 00 70 0 | | Storage temperature range | -55°C to 125°C | NOTE 1: Under absolute maximum ratings, voltage values are with respect to the most-negative supply voltage, VSS (substrate). ## functional block diagram TEXAS INSTRUMENTS POST OFFICE BOX 5012 + DALLAS, TEXAS 75222 <sup>\*</sup>Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. #### recommended operating conditions | PARAMETER | TMS 2516 | | | 7 | 32 | T | | |----------------------------------------------|---------------------|-----|----------------------|----------------------|-----|----------------------|------| | FARAMETER | MIN | | MAX | MIN | NOM | MAX | UNIT | | Supply voltage, V <sub>CC</sub> (see Note 2) | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 | V | | Supply voltage, Vpp (see Note 3) | V <sub>CC</sub> 0.6 | Vcc | V <sub>CC</sub> +0.6 | V <sub>CC</sub> -0.6 | Vcc | V <sub>CC</sub> +0.6 | V | | Supply voltage, VSS | | 0 | | | 0 | | V | | High-level input voltage, V <sub>IH</sub> | 2.0 | | V <sub>CC</sub> +1 | 2.2 | | V <sub>CC</sub> +1 | V | | Low-level input voltage, VIL | -0.1 | | 0.8 | -0.1 | | 0.65 | v | | Read cycle time, t <sub>c(rd)</sub> | 450 | | | 450 | | | ns | | Operating free-air temperature, TA | 0 | | 70 | 0 | | 70 | °c | - NOTES: 2. VCC must be applied before or at the same time as Vpp and removed after or at the same time as Vpp. The device must not be inserted into or removed from the board when Vpp is applied so that the device is not damaged. - 3. Vpp can be connected to V<sub>CC</sub> directly (except in the program mode). V<sub>CC</sub> supply current in this case would be I<sub>CC</sub>. Ipp. Tol. erance of ± .6 volts enables the Vpp pin to be switched from V<sub>CC</sub> (read) to 25 volts (programming) using a drive circuit. During programming, Vpp must be maintained at 25V (± 1V). ## electrical characteristics over full ranges of recommended operating conditions | PARAMETER | | | T507 0000 171000 | TMS 25 | TMS 2516 | | | 32 | | |-----------|--------------------------------|----------|---------------------------|----------|----------|------|-----|------|------| | | | | TEST CONDITIONS | MIN TYPT | MAX | MIN | TYP | MAX | UNIT | | Voн | High-level output volta | ge | I <sub>OH</sub> = -400 µA | 2.4 | | 2.4 | | | V | | VOL | Low-level output volta | | I <sub>OL</sub> = 2.1 mA | | 0.45 | | | 0.45 | V | | 31 | Input current (leakage) | | V <sub>I</sub> = 5.25V | | 10 | | | 10 | μА | | lo | Output current (leakag | e) | V <sub>O</sub> = 5.25V | | 10 | | | 10 | μA | | l | Vpp supply current | TMS 2516 | VPP = 5.85V, PD PGM - VIL | | - 6 | | | | | | IPP1 | v pp supply current | TMS 2532 | VPP = 5.85V, PD/PGM = VIL | | | | 12 | | mA | | | Vpp supply current | TMS 2516 | PD/PGM = VIH | | | 30 3 | | | | | IPP2 | (during program pulse) | TMS 2532 | PD/PGM = VIL | | 30 | | | 30 | mA | | | VCC supply current | TMS 2516 | PD/PGM = VIH | | | | | | | | ICC1 | (standby) | TMS 2532 | PD/PGM - VIH | 10 | 25 | 10 | | 25 | mA | | 1 | V <sub>CC</sub> supply current | TMS 2516 | CS = PD/PGM = VIL | 53 | | | | 160 | | | ICC2 | (active) | TMS 2532 | PD/PGM = VIL | 57 | 100 | | 80 | | mA | $<sup>^{\</sup>dagger}$ Typical values are at T<sub>A</sub> = 25 $^{\circ}$ C and nominal voltages. # capacitance over recommended supply voltage and operating free-air temperature range $\mathbf{f} = \mathbf{1} \ \mathbf{MHz}$ | | PARAMETER | TEST CONDITIONS | TYP | MAX | UNIT | |----|--------------------|---------------------------------|-----|-----|------| | C, | Input capacitance | V <sub>I</sub> = 0 V, f = 1 MHz | 4 | 6 | pF | | Co | Output capacitance | V <sub>O</sub> = 0 V, f = 1 MHz | 8 | 12 | pF | $<sup>^{\</sup>dagger}$ All typical values are $^{\dagger}$ A = 25 $^{\circ}$ C and nominal voltage TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 5012 - DALLAS, TEXAS 75222 B-4 # switching characteristics over full ranges of recommended operating conditions, (unless otherwise noted) | | PARAMETER | TEST CONDITIONS (SEE NOTES 4 AND 5) | MIN TYPT | MAX | UNIT | |--------------------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------|-----|------| | ta(A) | Access time from address | | 280 | | ns | | 0(// | Access time from chip select (TMS 2516 only) | $C_L$ = 100 pF,<br>1 Series 74 TTL load,<br>$t_f \leqslant 20$ ns,<br>$t_f \leqslant 20$ ns | | 120 | | | t <sub>a(CS)</sub> | Access time from PD/PGM (PD/PGM for TMS 2532) | | 280 | 450 | | | | Output not valid from address change | | 0 | | ns | | 1 4 / | Output disable time from chip deselect during read only | | 0 | 100 | | | 1 1/2 | Output disable time from chip deselect during program and program verify | | | 120 | ns | | tPXZ<br>tPXZ | Output disable time from PD/PGM (PD/PGM for TMS 2532) during standby | | 0 | 100 | ns | $<sup>^{\</sup>dagger}$ AII typical values are at $T_{A} \approx 25^{\circ}$ C and nominal voltages. # recommended timing requirements for programming $T_{\text{A}}=25^{\circ}\text{C}$ (see Note 4) | | PARAMETER | MIN TYPT MAX | UNI | |------------------------------------------|-----------------------------------------|--------------|-----| | • (00) | Pulse width, program pulse | 45 50 55 | ms | | t <sub>w(PR)</sub><br>t <sub>r(PR)</sub> | Rise time, program pulse | 5 | ns | | tf(PR) | Fall time, program pulse | 5 | ns | | t <sub>su(A)</sub> | Address setup time | 2 | μs | | t <sub>su(CS)</sub> | Chip-select setup time | 2 | μs | | tsu(D) | Data setup time | 2 | μs | | t <sub>su(Vpp)</sub> | Setup time from Vpp | 0 | ns | | th(A) | Address hold time | 2 | μѕ | | th(CS) | Chip-select hold time (TMS 2516 only) | 2 | μs | | th(D) | Data hold time | 2 | μs | | th(PR) | Program pulse hold time (TMS 2532 only) | 0 | ns | | th(Vpp) | Vpp hold time (TMS 2532 only) | 0 | ns | <sup>†</sup>Typical values are at nominal voltages. NOTES: 4. For all switching characteristics and timing measurements, input pulse levels are 0.65 V to 2.2 V and Vpp = 25 V ± 1 V during programming. programming. For $t_{a(A)}$ , $t_{a(\overline{CS})}$ , and $t_{p\chi Z}$ , PD/PGM = $\overline{CS}$ = $V_{|L|}$ for the TMS 2516 and PD/PGM = $V_{|L|}$ for the TMS 2532. #### read cycle timing NOTE: There is no chip select pin on the TMS 2532. The chip-select function is incorporated in the power-down mode. ## standby mode NOTE: $\overline{\text{CS}}$ (TMS 2516) must be in low state during Active Mode, "Don't Care" otherwise. $^{\dagger}$ t<sub>a</sub>(PR) referenced to PD/PGM (PD/PGM for TMS 2532) or the address, whichever occurs last. TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 5012 - DALLAS. TEXAS 75222 NOTE: There is no chip select pin on the TMS 2532. Chip select is incorporated in the power down mode. CS (TMS 2516) is in "don't cere" state. \*HI-Z for the TMS 2532. TEXAS INSTRUMENTS POST OFFICE BOX 5012 • DALLAS, TEXAS 75222 typical device characteristics (read mode) TEXAS INSTRUMENTS INCORPORATED POST OFFICE SOX 5012 • DALLAS, TEXAS 75222 PRINTED IN USA TI cannot assume any responsibility for any circuits shown or represent that they are free from patent infringement. TEXAS INSTRUMENTS RESERVES THE RIGHT TO MAKE CHANGES AT ANY TIME IN ORDER TO IMPROVE DESIGN AND TO SUPPLY THE BEST PRODUCT POSSIBLE. MOS Lis # TMS 4732 JL, NL 4096-WORD BY 8-BIT READ-ONLY MEMORY MAY 1977 #### description The TMS 4732 is a 32,768-bit read-only memory organized as 4096 words of 8-bit length. This makes the TMS 4732 ideal for microprocessor based systems. The device is fabricated using N-channel silicon-gate technology for high speed and simple interface with bipolar circuits. All inputs can be driven directly by Series 74 TTL circuits without the use of any external pull-up resistor. Each output can drive one Series 74 or 74S load without external resistors. The data outputs are three-state for OR-tieing multiple devices on a common bus. Two chip select controls allow data to be read. These controls are programmable, providing additional system decode flexibility. The data is always available; it is not dependent on external CE clocking. The TMS 4732 is designed for high-density fixed-memory applications such as logic function generation and microprogramming. Systems utilizing the TMS 4700 1024 x 8-bit ROM or the TMS 2708 1024 x 8-bit EPROM can expand to the 4096 x 8-bit TMS 4732 with changes only to pins 18, 19, and 21. To upgrade from the 8316B, simply replace CS2 with A11 on pin 18. This ROM is supplied in 24-pin dual-in-line plastic (NL suffix) or ceramic (JL suffix) packages designed for insertion in mounting-hold rows on 600-mil centers. The device is designed for operation from $0^{\circ}$ C to $70^{\circ}$ C. #### operation address (A0-A11) The address-valid interval determines the device cycle time. The 12-bit positive-logic address is decoded on-chip to select one of 4096 words of 8-bit length in the memory array. A0 is the least-significant bit and A11 the most-significant bit of the word address. chip select (CS1 and CS2) Each chip select control can be programmed during mask fabrication to be active with either a high or a low level input. When both chip select signals are active, all eight outputs are enabled and the eight-bit addressed word can be read. When either chip select is not active, all eight outputs are in a high-impedance state. PRELIMINARY DATA SHEET: Supplementary data will be published at a later date. TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 4012 - DALLAS, 18449 75222 ### TMS 4732 JL, NL 4096-WORD BY 8-BIT READ-ONLY MEMORY #### data out (Q1-Q8) The eight outputs must be enabled by both chip select controls before the output word can be read. Data will remain valid until the address is changed or the outputs are disabled (chip deselected). When disabled, the three-state outputs are in a high-impedance state. Q1 is considered the least-significant bit, Q8 the most-significant bit. The outputs will drive TTL circuits without external components. #### functional block diagram #### absolute maximum ratings | Supply voltage to ground potential (see Note 1) | 0.5 to 7 V | |-------------------------------------------------|----------------| | Applied output voltage (see Note 1) | | | Applied input voltage (see Note 1) | 0.5 to 7 V | | Power dissipation | 1 W | | Ambient operating temperature | 0°C to 150°C | | Storage temperature | _55°C to 150°C | Note 1: Voltage values are with respect to VSS # recommended operating conditions | PARAMETER | MIN | NOM | MAX | UNIT | |-------------------------------------------|------|-----|------|------| | Supply voltage, VCC | 4.75 | 5 | 5.25 | V | | High-level input voltage, V <sub>IH</sub> | 2 | 2.4 | Vcc | V | | Low-level input voltage, VIL | Vss | 0.5 | 0.65 | V | | Read cycle time, tc(rd) | 450 | | | ns | | Operating free-air temperature, TA | 0 | | 70 | °c | TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 5012 - DALLAS, YEXAS 75222 # TMS 4732 JL, NL 4096-WORD BY 8-BIT READ-ONLY MEMORY # electrical characteristics, TA = $0^{\circ}$ C to $70^{\circ}$ C, VDD = 5 V +5% (unless otherwise noted) | | PARAMETER | TEST CONE | TEST CONDITIONS | | | | | | |-----|-------------------------|------------------------------------|-----------------------------|-----|-----|----|--|--| | Vон | | V <sub>CC</sub> = 4.75 V, | .¹OH −200 µA | 2 4 | Vcc | V | | | | VOL | | V <sub>CC</sub> = 4.75 V, | IOL = 2 mA | | 0.4 | V | | | | 1, | Input current | VCC = 5.25 V, | OV ≤V <sub>IN</sub> ≤5.25 V | | 10 | μΑ | | | | loz | Ourput leakage current | VO = 0.4 V to V <sub>CC</sub> | Outputs disabled | | ±10 | μΑ | | | | Icc | Supply current from VCC | VCC = 5.25 V, | Vi =VCC output not loaded | | 150 | mA | | | | c, | Input capacitance | V <sub>O</sub> = 0 V,<br>f = 1 MHz | T <sub>A</sub> = 25°C. | | 7 | pF | | | | co | Output capacitance | V <sub>O</sub> = 0 V,<br>f = 1 MHz | T <sub>A</sub> = 25°C, | | 10 | ρF | | | # switching characteristics, $T_A = 0^{\circ}C$ to $70^{\circ}C$ , $V_{CC} = 5$ V +5%, 1 series 74 TTL load, $C_L = 100$ pF | | PARAMETER | WI | N MAX | UNIT | |--------|-------------------------------------------------|----|-------|------| | ta(ad) | Access time from address | | 450 | ns | | | Access time from chip select | | 200 | ns | | | Previous output data valid after address change | | 450 | ns | | | Output disable time from chip select | | 200 | ns | #### read cycle timing ### TMS 4732 JL, NL 4096-WORD BY 8-BIT READ-ONLY MEMORY #### PROGRAMMING DATA PROGRAMMING REQUIREMENTS: The TMS 4732JL, NL is a fixed program memory in which the programming is performed by TI at the factory during manufacturing cycle to the specific customer inputs supplied in the format below. The device is organized as 4096 8-bit words with address locations numbered 0 to 4095. The 8-bit words can be coded as a 2-digit hexadecimal number between 00 and FF. All data words and addresses in the following format are coded in hexadecimal numbers. In coding, all binary words must be in positive logic before conversion to hexadecimal. Q1 is considered the least significant bit and Q8 the most significant bit. For addresses, A0 is least significant bit and A11 is the most significant bit. Every card should include the TI Custom Device Number in the form ZAXXXX (4 digit number to be assigned by TI) in columns 75 through 80. PROGRAMMABLE CHIP SELECTS: The chip select inputs shall be programmed according to the data punched in columns 73 and 74. Every card should include in column 73 a 1 if the output is to be enabled with a high level at CS2 or a 0 (zero) to enable the output with a low level at CS2. The column 74 entry is the same for programming CS1. PROGRAMMED DATA FORMAT: The format for the cards to be supplied to TI to specify the data to be programmed is provided below. The card deck for each device consists of 128 cards with each card containing data for 32 memory locations. | CARD COLUMN | HEXADECIMAL FORMAT | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 to 3 | Hexadecimal address of first word on the card | | 4 | Blank | | 5 to 68 | Data. Each 8-bit memory byte is represented by two ASCII characters to represent a hexadecimal value of '00' to 'FF'. | | 69, 70 | Checksum. The checksum is the negative of the sum of all 8-bit bytes in the record from columns 1 to 68, evaluate modulo 256 (carry from high order bit ignored). (For purposes of calculating the checksum, the value of Column 4 is defined to be zero). Adding together, modulo 256, all 8-bit bytes from Column 1 to 68 (Column 4 = 0), then adding the checksum, results in zero. | | 71, 72 | Blank | | 73 | One (1) or zero (0) for CS2 | | 74 | One (1) or zero (0) for CS1 | | 75, 76 | ZA | | 77 to 80 | XXXX (4 digit number assigned by TI) | PRINTED IN USA AS INSTRUMENTS RESERVES THE RIGHT TO MAKE CHANGES AT ANY TIME ORDER TO IMPROVE DESIGN AND TO SUPPLY THE BEST PRODUCT POSSIBLE. TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 5012 - DALLAB. TEXAS 75222 It cannot assume any responsibility for any circuits shown or represent that they are free from potent infringement # MOS LSI # TMS 2708 JL, TMS 27L08 AND TMS 2716 JL 8K AND 16K ERASABLE PROGRAMMABLE READ-ONLY MEMORIES OCTOBER 1977 - 2716 JL 2048 X 8 Organization - All Inputs and Outputs Fully TTL-Compatible - Static Operation (No Clocks, No Refresh) - Maximum Access Time . . . 450 ns - Minimum Cycle Time . . . 450 ns - 3-State Outputs for OR-Ties - N-Channel Silicon-Gate Technology - 8-Bit Output for Use in Microprocessor-Based Systems - Low Power TMS 27L08 . . . 245 mW (Typical) TMS 2716 . . . 315 mW (Typical) - 10% Power Supply Tolerance (TMS 27L08 Only) - Plug-Compatible Pin-Outs Allowing Interchangeability/Upgrade to 16K With Minimum Board Change #### description The TMS 2708 JL, TMS 27L08 JL, and TMS 2716 JL are ultra-violet light-erasable, electrically programmable read only memories. The TMS 2708 JL and TMS 27L08 JL have 8,192 bits organized as 1024 words of 8-bit length. The TMS 2716 JL has 16,384 bits organized as 2048 words of 8-bit length. The devices are fabricated using N-channel silicon-gate technology for high speed and simple interface with MOS and bipolar circuits. All inputs (including program data inputs) can be driven by Series 74 TTL circuits without the use of external pull-up resistors and each output can drive one Series 74 TTL circuit without external resistors. The TMS 27L08 guarantees 200 mV dc noise immunity in the high state and 250 mV in the low state. It will also directly drive one Series 74, 74S, or 74LS TTL circuit. TMS 2716 also guarantees 250 mV dc noise immunity in the low state. The data outputs for all three circuits are three-state for OR-tying multiple devices on a common bus. The TMS 2716 is plug-in compatible with the TMS 2708 and the TMS 27L08. Pin compatible mask programmed ROMs are available for large volume requirements. These EPROMs are designed for high-density fixed-memory applications where fast turn arounds and/or program changes are required. They are supplied in a 24-pin dual-in-line ceramic (JL suffix) packages designed for insertion in mounting-hole rows on 600-mil centers. They are designed for operation from 0°C to 70°C. #### operation (read mode) #### address (A0-A9/A10) The address-valid interval determines the device cycle time. The 10-bit (11 bit TMS 2716) positive-logic address is decoded on-chip to select one of 1024 words (2048 words TMS 2716) of 8-bit length in the memory array. A0 is the least-significant bit and A9 (A10 TMS 2716) most-significant bit of the word address. #### chip select, program enable [CS (PE)] and chip select, program [CS (Program)] When the chip select is low, all eight outputs are enabled and the eight-bit addressed word can be read. When the chip select is high, all eight outputs are in a nigh-impedance state. PRELIMINARY DATA SHEET: Supplementary data will be published at a later date. TEXAS INSTRUMENTS POST OFFICE BOX 3012 - DALLAE, TEXAS 75222 #### TMS 2708, TMS 27L08 When the chip select program enable is brought to V<sub>DD</sub>, the outputs become inputs and the EPROM is ready for programming. #### TMS 2716 In the program mode, the chip select feature does not function as pin 18 inputs only the program pulse. The program mode is selected by the VCC(PE) pin. Either 0 V or +12 V on this pin will cause the TMS 2716 to assume program cycle. #### data out (Q1-Q8) The chip must be selected before the eight-bit output word can be read. Data will remain valid until the address is changed or the chip is deselected. When deselected, the three-state outputs are in a high-impedance state. The outputs will drive TTL circuits without external components. #### TMS 2708, TMS 27L08 The program pin must be held below VCC in the read mode. #### operation (program mode) #### егаѕе Before programming, the TMS 2708, TMS 27L08 and TMS 2716 are erased by exposing the chip through the transparent lid to high-intensity ultraviolet light (wavelength 2537 angstroms). The recommended exposure is ten watt-seconds per square centimeter. This can be obtained by, for instance, 20 to 30 minutes exposure of a filterless Model S52 short wave UV lamp about 2.5 centimeters above the EPROM. After erasure all bits are in the high state. #### programming Programming consists of successively depositing a small amount of charge to a selected memory cell that is to be changed from the erased high state to the low state. A low can be changed to a high only by erasure. Programming is normally accomplished on a PROM or EPROM Programmer, an example of which is TI's Universal PROM Programming Module in conjunction with the 990 prototyping system. Programming must be done at room temperature (25°C) only. #### to start programming (see program cycle timing diagram on page 148) First bring the $\widetilde{CS}$ (PE) pin (for the TMS 2708, TMS 27L08) to +12 V or the V<sub>CC</sub>(PE) (for the TMS 2716) to +12 V or 0 V to disable the outputs and convert them to inputs. This pin is held high for the duration of the programming sequence. The first word to be programmed is addressed (it is customary to begin with the "0" address) and the data to be stored is placed on the Q1-Q8 program inputs. Then a +26-V program pulse is applied to the program pin. After 0.1 to 1.0 milliseconds the program pin is brought back to 0 V. After at least one microsecond the word address is sequentially changed to the next location, the new data is set up and the program pulse is applied. Programming continues in this manner until all words have been programmed. This constitutes one of N program loops. The entire sequence is then repeated N times with N x $t_W(PR) \ge 100$ ms. Thus, if $t_W(PR) = 1$ ms; then N = 100, the minimum number of program loops required to program the EPROM. #### to stop programming After cycling through the N program loops, the last program pulse is brought to 0 V, then for the TMS 2708 and TMS 27L08, Program Enable [CS(PE)] is brought to V<sub>IL</sub> (for the TMS 2716 Program Enable [VCC(PE)] is brought back to ±5 volts) which takes the device out of the program mode. The data supplied by the programmer must be removed before the address is changed since the program inputs are now data outputs and a change of address could cause a voltage conflict on the output buffer. Q1-Q8 outputs are invalid up to 10 microseconds after the program enable pin is brought from V<sub>IH</sub>(PE) to V<sub>IL</sub> [V<sub>IL</sub>(PE) on TMS 2716]. TEXAS INSTRUMENTS absolute maximum ratings over operating free-air temperature range (unless otherwise noted)\* | Supply voltage, VCC (see Note 1) | | | | | | | | | | | | | | -0.3 to 15 V | |------------------------------------------|-------|------|------|---|--|--|--|--|--|--|--|--|----|---------------| | Supply voltage, VDD (see Note 1) | | | | | | | | | | | | | | -0.3 to 20 V | | Supply voltage, VSS (see Note 1) | | | | | | | | | | | | | | -0.3 to 15 V | | All input voltage (except program) (s | ee i | Vot | e 1) | ) | | | | | | | | | | -0.3 to 20 V | | Program Input (see Note 1) | | | | | | | | | | | | | | -0.3 to 35 V | | Output voltage (operating, with response | ect 1 | to V | 'ss | ) | | | | | | | | | | 2 to 7 V | | Operating free-air temperature range | | | | | | | | | | | | | | 0°C to 70°C | | Storage temperature range | | | | | | | | | | | | | -! | 55°C to 125°C | NOTE 1: Under absolute maximum ratings, voltage values are with respect to the most-negative supply voltage, VBB (substrate), unless otherwise noted. Throughout the remainder of this data sheet, voltage values are with respect to VSS. NOTE: Numbers in parentheses refer to TMS 2716 TEXAS INSTRUMENTS INCORPORATED POST OFFICE SOX SOLS . BALLAS. TEXAS 75222 <sup>&</sup>quot;Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability #### recommended operating conditions | PARAMETER | TM\$ 27 | 08, TN | т | LINIT | | | | |---------------------------------------------------------------------------------------------------|---------|--------|--------------------|----------|-----|--------------------|------| | TANAMETER | MIN | NOM | MAX | MiN | NOM | MAX | UNIT | | Supply voltage, VBB | -4.75 | -5 | -5.25 | -4.5 | -5 | -5.5 | V | | Supply voltage, V <sub>CC</sub> | 4.75 | 5 | 5.25 | 4.5 | 5 . | 5.5 | V | | Supply voltage, V <sub>DD</sub> | 11.4 | 12 | 12.6 | 10.8 | 12 | 13.2 | V | | Supply voltage, V <sub>SS</sub> | | 0 | | <b> </b> | 0 | | V | | High-level input voltage, V <sub>IH</sub> (except program and program enable) | 2.4 | | V <sub>CC</sub> +1 | 2.2 | | V <sub>CC</sub> +1 | V | | High-level program enable input voltage, VIH(PE) | 11.4 | 12 | 12.6 | 10.8 | 12 | 13.2 | | | High-level program input voltage, VIH(PR) | 25 | 26 | 27 | 25 | 26 | 27 | V | | Low-level input voltage, VIL (except program) | VSS | | 0.65 | VSS | | 0.65 | V | | Low-level program input voltage, $V_{IL}(PR)$<br>Note: $V_{IL}(PR)$ max $\leq V_{IH}(PR)$ —25 $V$ | vss | | 1 | VSS | | 1 | V | | High-level program pulse input current (sink), ITH(PR) | | | 40 | | | 40 | mA | | Low-level program pulse input current (source), ILL(PR) | | | 3 | | | 3 | mA | | Operating free-air temperature, TA | 0 | | 70 | 0 | | 70 | °C | # electrical characteristics over full ranges of recommended operating conditions (unless otherwise noted) | PARAMETER | | TEST CONDITIONS | | 1 | TMS 270 | 8 | т | MS 27L | 80 | 1 | | | | |-----------------|----------------------------------------|--------------------------------------------------|--------------------------------------|------------|---------|------|------------|--------|------------|-----|-----|------------|-------| | | | 1201 00110110110 | | | TYP | MAX | MIN | TYP | MAX | MIN | TYP | MAX | UNITS | | V <sub>ОН</sub> | High-level<br>output<br>voltage | I <sub>OH</sub> = 100 µA | | 3.7<br>2.4 | | | 3.7<br>2.4 | | | 3.7 | | | v | | v <sub>OL</sub> | Low-level<br>output<br>voltage | I <sub>OL</sub> = 1.6 mA | | | | 0.45 | | | 0.40 | | | 0.45 | v | | 4 | Input current<br>(leakage) | V <sub>I</sub> = 0 V to 5.25 V | | | 1 | 10 | | 1 | 10 | | 1 | 10 | μА | | 10 | Output<br>current<br>(leakage) | <u>CS(PE) = 5 V</u><br><u>CS (Program) = 5 V</u> | TMS 2708, 27L08<br>7 TMS 2716 | | 1 | 10 | | 1 | 10 | | 1 | າບ | ДΑ | | 88 | Supply<br>current from<br>VBB | All inpu | ts high | | 30 | 45 | | 9 | 18 | | 10 | 20 | mA | | cc | Supply<br>current from<br>VCC | CS(PE) = 5 V<br>CS (Program) = 5 V | TMS 2708, 27L08<br>TMS 2716 | | 6 | 10 | | 9 | 6 | | 1 | 8 | mA | | DD D | Supply<br>current from<br>VDD | For I <sub>DD</sub> MAX, | T <sub>A</sub> = 0°C<br>(worst case) | | 50 | 65 | | 20 | 34 | | 26 | 45 | mA | | PE | Supply<br>current from<br>PE on VCCPin | VPE = VDD | TMS 2716 only | | | | | | | | 2 | 4 | mA | | PD(AV) | Power<br>Dissipation | $T_A = 70^{\circ}C$<br>$T_A = 0^{\circ}C$ | CS = OV | | | 800 | | 245 | 350<br>475 | | 315 | 540<br>595 | mW | | | | TA = 0°C | <u>CS</u> = +5V | | | _ | | 290 | 580 | | 375 | 720 | | $^{\dagger}$ All typical values are at $^{\dagger}$ A $^{=}$ 25 $^{\circ}$ C and nominal voltages. TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 5012 - DALLAB. TEXAS 75222 #### capacitance over recommended supply voltage range and operating free-air temperature range, f = 1 MHz | | PARAMETER | TYP | MAX | UNIT | |--------|----------------------------------------------------------|-----|-----|------| | Ci | Input capacitance [except CS (Program) for the TMS 2716] | 4 | 6 | pF | | Ci(CS) | CS (Program) input capacitance for TMS 2716 only | 20 | 30 | pF | | Co | Output capacitance | 8 | 12 | pF | $<sup>^{\</sup>dagger}$ All typical values are at $T_A = 25^{\circ}$ C and nominal voltages. #### switching characteristics over recommended supply voltage range and operating free-air temperature range | | PARAMETER | TEST CONDITIONS | MIN | MAX | UNIT | |--------------------|------------------------------------|-------------------------------------------------|-----|-----|------| | <sup>t</sup> a(ad) | Access time from address | C - 100 - 5 | | 450 | ns | | ta(CS) | Access time from CS | C <sub>L</sub> ≈ 100 pF<br>1 Series 74 TTL Load | | 120 | ns | | tPVX | Output invalid from address change | | 0 | | ns | | 1PXZ | Output disable time | $t_{f(CS)}$ , $t_{f(ad)} = 20 \text{ ns}$ | 0 | 120 | ns | | tc(rd) | Read Cycle time | · · · · · · · · · · · · · · · · · · · | 450 | | ns | ### T<sub>A</sub> = 25°C program characteristics over recommended supply voltage range | | PARAMETER | MIN | MAX | UNIT | |----------------------|----------------------------------------------------|------|------|------| | tw(PR) | Pulse width, program pulse | 0.1 | 1 | ms | | tŢ | Transition times (except program pulse) | | 20 | ns | | tT(PR) | Transition times, program pulse | 50 | 2000 | ns | | <sup>t</sup> su(ad) | Address setup time | 10 | | μ\$ | | <sup>t</sup> su(da) | Data setup time | 10 | | μs | | t <sub>su</sub> (PE) | Program enable setup time | 10 | | μs | | <sup>t</sup> h(ad) | Address hold time | 1000 | | ns | | th(ad,da R) | Address hold time after program input data stopped | 0 | | ns | | th(da) | Data hold time | 1000 | | ns | | th(PE) | Program enable hold time | 500 | | ns | | <sup>†</sup> CL,adX | Delay time, CS(Program) low to address change | 0 | | ns | TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 5012 + DALLAS, TEXAS 75222 #### **TYPICAL TMS 27L08 JL CHARACTERISTICS** TEXAS INSTRUMENTS POST OFFICE BOX 5012 - DALLAS, TEXAS 75222 #### read cycle timing \* CS (Program) TMS 2716 #### program cycle timing ••CS (PE) is at +12 V for the TMS 2708 and 27L08 and V<sub>CC</sub> (PE) is at 0 V or +12 V for the TMS 2716 through N program loops where N ≥ 100 ms/tw (PR). NOTE: Q1-Q8 outputs are invalid up to 10 µsec after programming [CS(PE) (V<sub>CC</sub>(PE) for TMS 2716) goes low!. NOTE: Items in parentheses refer to TMS 2716. TEXAS INSTRUMENTS POST OFFICE BOX 5012 . DALLAS YEX 13 75222 #### APPLICATIONS INFORMATION #### Ease of Conversion From TMS 2708 To TMS 2716 - A. The TMS 2716 and TMS 2708 have compatible timing, voltage and current parameters in both modes. - B. The TMS 2716 requires less power than the TMS 2708. - C. The pinouts are compatible. (See below.) As can be seen from the above diagrams, only three pins\* are modified in going from TMS 2708 to TMS 2716: - The additional address pin required for the 16K EPROM is located on pin 20 which displaces the <del>CS/PE</del> functions on the TMS 2708. - Since V<sub>CC</sub> is not required during programming, the PE function shares pin 24 with V<sub>CC</sub> on the TMS 2716. - The CS function and program function are mutually exclusive during normal read mode (and are self-actuated complementary during the program/verify mode) and share pin 18 on the TMS 2716. The diagrams below show how these three pins are actually utilized in the read mode and in the program mode. Only pins 18, 20, and 24 need to be shown, as all other pin connections are identical. TEXAS INSTRUMENTS POST OFFICE BOX 5012 - DALLAB, TEXAS 75222 Read Mode Program (Write) Mode TMS 2716 - Easy Programmability On Existing 2708 Programmers Existing EPROM Programmers — Upgrading To The TMS 2716 Most of the EPROM manufacturers have implemented field upgrade modifications to allow TMS 2716 programming on current EPROM programmers. This is greatly simplified because the TMS 2716 and the TMS 2708 are programmed in an identical manner. A slight modification to the socket card, an additional 1K x 8 of RAM, and an extra address signal (A10) are all that is required. All timing and voltage parameters are identical, so the upgrade is easily accomplished. Programmer manufacturers contacted to date on the TMS 2716 include: Data I/O, PRO LOG, Texas Instruments, Technico, CramerKit, Shepardson Micro Systems, Cromenco, MicroPro, Ramtek, Oliver Audio, Inc., etc. Ultraviolet Erasure lights and fixtures are available from Ultraviolet Products, Turner Designs, and others. NOTE: Information on EPROM programmers and erasurers are provided only for user convenience and do not indicate any preference by TI. PRINTED IN U.S.A. Ti cannot assume any responsibility for any circuits shown or represent that they are free from patent infringement TEXAS INSTRUMENTS POST OFFICE BOX 225012 • DALLAS, TEXAS 75265 ### MOS LSI ### TMS 4045 JL, JDL, NL; TMS 40L45 JL, JDL, NL; TMS 4047 JL, JDL, NL; TMS 40L47 JL, JDL, NL 1024-WORD BY 4-BIT STATIC RAMs SEPTEMBER 1978 #### ■ 1024 × 4 Organization - Single +5 V Supply (±10% Tolerance) - High Density 300-mil (7.62 mm) 18- and 20-Pin Packages - Fully Static Operation (No Clocks, No Refresh, No Timing Strobe) - 4 Performance Ranges: | o.vo.vangoo. | ACCESS REA | AD OR WRITE | |----------------------------------|------------|-------------| | | TIME | CYCLE | | | (MAX) | (MIN) | | TMS 4045/L45-45, TMS 4047/L47-45 | 450 ns | 450 ns | | TMS 4045/L45-25, TMS 4047/L47-25 | 250 ns | 250 ns | | TMS 4045/L45-20, TMS 4047/L47-20 | 200 ns | 200 ns | | TMS 4045-15, TMS 4047-15 | 150 ns | 150 ns | - 400 mV Guaranteed DC Noise Immunity with Standard TTL Loads — No Pull-Up Resistors Required - Common I/O - 3-State Outputs and Chip Select Control for OR-Tie Capability - Fan-Out to 2 Series 74, 1 Series 74S, or 8 Series 74LS TTL Loads - Low Power Dissipation | | MAX | MAX | |-----------|-------------|-----------| | | (OPERATING) | (STANDBY) | | TMS 4045 | 550 mW | 170 mW | | TMS 40L45 | 330 mW | 110 mW | | TMS 4047 | 550 mW | 13 mW | | TMS 40L47 | 330 mW | 13 mW | #### description This series of static random-access memories is organized as 1024 words of 4 bits each. Static design results in reducing overhead costs by elimination of refresh-clocking circuitry and by simplification of timing requirements. Because this series is fully static, chip select may be tied low to further simplify system timing. Output data is always available during a read cycle. All inputs and outputs are fully compatible with Series 74, 74S or 74LS TTL. No pull-up resistors are required. This 4K Static RAM series is manufactured using Tl's reliable N-channel silicon-gate technology to optimize the cost/performance relationship. All versions are characterized to retain data at V<sub>CC</sub> = 2.4 V to reduce power dissipation. #### TMS 4045/TMS 40L45 18-PIN CERAMIC AND PLASTIC DUAL-IN-LINE PACKAGES (TOP VIEW) #### TMS 4047/TMS 40L47 20-PIN CERAMIC AND PLASTIC DUAL-IN-LINE PACKAGES (TOP VIEW) | OE 1 | Ŀ | IU | • | 20 | VCC | |--------------------|---|----|---|----|------| | A <sub>6</sub> 2 | | | • | 19 | Vcca | | A <sub>5</sub> 3 | 0 | | • | 18 | A7 | | A <sub>4</sub> 4 | • | | • | 17 | Ag | | A <sub>3</sub> 5 | • | | • | 16 | A9 | | A <sub>0</sub> 6 | • | | • | 15 | DQ1 | | A <sub>1</sub> 7 | • | | • | 14 | DQ2 | | A <sub>2</sub> 8 | • | | • | 13 | DQ3 | | <u>5</u> 9 | • | | • | 12 | DQ4 | | / <sub>SS</sub> 10 | • | | 0 | 11 | w | | | | | - | | | #### PIN NAMES | A <sub>0</sub> - A <sub>9</sub> | Addresses | |---------------------------------|------------------| | DQ | Data In/Data Out | | \$ | Chip Select | | V <sub>CC</sub> (TMS 4045/L45) | +5 V Supply | | V <sub>CC1</sub> (TMS 4047/L47) | +5 V Supply | | V(C) (1m3 4047/147) | (array only) | | VCC2 (TMS 4047/L47) | +5 V Supply | | VCC2(11413 404//E4// | (periphery only) | | Vss | Ground | | W | Write Enable | PRELIMINARY DATA SHEET: Supplementary data will be published at a later date. #### TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 225012 • DALLAS, TEXAS 75265 # TMS 4045 JL, JDL, NL; TMS 40L45 JL, JDL, NL; TMS 4047 JL, JDL, NL; TMS 40L47 JL, JDL, NL 1024-WORD BY 4-BIT STATIC RAMs Furthermore, for applications such as battery back-up, the TMS 4047 and TMS 40L47 have separate $V_{CC}$ pins for the array and periphery, and data will be retained if power to the array alone is maintained. The TMS 4045/40L45 series and the TMS 4047/40L47 series are offered respectively in 18-pin and 20-pin dual-in-line cerdip (JL suffix), sidebraze (JDL suffix), and plastic (NL suffix) packages designed for insertion in mounting-hole rows on 300-mil (7.62 mm) centers. The series is guaranteed for operation from $0^{\circ}$ C to $70^{\circ}$ C. #### operation #### addresses (A0-A11) The ten address inputs select one of the 1024 4-bit words in the RAM. The address inputs must be stable for the duration of a write cycle. The address inputs can be driven directly from standard Series 54/74 TTL with no external pull-up resistors. #### output enable (OE) The output enable terminal, which can be driven directly from standard TTL circuits, affects only the data-in/data-out terminals. When output enable is at a logic high level, the DQ terminals are disabled to the high-impedance state. Output enable provides greater output control flexibility, simplifying data bus design. #### chip select (S) The chip-select terminal, which can be driven directly from standard TTL circuits, affects the data-in and data-out terminals. When chip select is at a logic low level, both terminals are enabled. When chip select is high, data-in is inhibited and data-out is in the floating or high-impedance state. #### write enable (W) The read or write mode is selected through the write enable terminal. A logic high selects the read mode; a logic low selects the write mode. $\overline{W}$ or $\overline{S}$ must be high when changing addresses to prevent erroneously writing data into a memory location. The $\overline{W}$ input can be driven directly from standard TTL circuits. #### data-in/data-out (DQ1-DQ4) Data can be written into a selected device when the write enable input is low. The DQ terminal can be driven directly from standard TTL circuits. The three-state output buffer provides direct TTL compatibility with a fan-out of two Series 74 TTL gates, one Series 74S TTL gate, or eight Series 74LS TTL gates. The DQ terminals are in the high impedance state when chip select ( $\overline{S}$ ) is high or whenever a write operation is being performed. Data-out is the same polarity as data-in. #### standby operation There are two basic standby modes available to retain data when operating the TMS 4045/40L45/4047/40L47 series: - 1. Reduce the VCC supply to 2.4 V - 2. Supply power to the array only (TMS 4047 and TMS 40L47 only). Combining modes 1 and 2 on the TMS 4047 or TMS 40L47 will produce the lowest possible standby power while retaining data. | DEVICE | SUPPLY | OPERATING | STANDBY | | | | |---------------------|------------------|-----------|---------|--------|--|--| | TMS 4045, TMS 40L45 | VCC | +5 V | +2.4 V | | | | | TMS 4047, TMS 40L47 | V <sub>CC1</sub> | +5 V | +5 V | +2.4 V | | | | | V <sub>CC2</sub> | +5 V | 0 V | 0 V | | | INCORPORATED POST OFFICE BOX 225012 . DALLAS, TEXAS 75265 ## TMS 4045 JL, JDL, NL; TMS 40L45 JL, JDL, NL; TMS 4047 JL, JDL, NL; TMS 40L47 JL, JDL, NL 1024-WORD BY 4-BIT STATIC RAMS During standby operation, data can not be read or written into the memory. When resuming normal operation, five cycle times must be allowed after normal supplies are returned for the memory to resume steady state operating conditions. #### absolute maximum ratings over operating free-air temperature (unless otherwise noted)\* | Supply voltage, VCC (see Note 1) | 0.5 to 7 V | |----------------------------------------|----------------| | Input voltage (any input) (see note 1) | 1 to 7 V | | Continuous power dissipation | 1W | | Operating free-air temperature range | 0°C to 70°C | | Storage temperature range | -55°C to 150°C | <sup>\*</sup>Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. NOTE 1: Voltage values are with respect to the ground material. #### functional block diagram #### recommended operating conditions | PARAMETER | | MIN | NOM | MAX | UNIT | |-------------------------------------------------------------------------|-----------|-------|-----|------|------| | Sumplement No (This does This dollar) | Operating | . 4.5 | 5 | 5.5 | | | Supply voltage, V <sub>CC</sub> (TMS 4045, TMS 40L45) | Standby | 2.4 | 5 | 5.5 | V | | C | Operating | 4.5 | 5 | 5.5 | T., | | Supply voltage (array only), V <sub>CC1</sub> (TMS 4047, TMS 40L47) | Standby | 2.4 | 5 | 5.5 | 1 V | | C | Operating | 4.5 | 5 | 5.5 | T., | | Supply voltage (periphery only), V <sub>CC2</sub> (TMS 4047, TMS 40L47) | Standby | 0 | 0 | -5.5 | ٧ | | Supply voltage, V <sub>SS</sub> | | Ì | 0 | | ٧ | | High-level input voltage, VIH | 2.0 | | 5.5 | ٧ | | | Low-level input voltage, V <sub>IL</sub> | | -1.0 | | 0.8 | V | | Operating free-air temperature, TA | | 0 | | 70 | °C | TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 225012 . DALLAS, TEXAS 75265 # TMS 4045 JL, JDL, NL; TMS 40L45 JL, JDL, NL; TMS 4047 JL, JDL, NL; TMS 40L47 JL, JDL, NL 1024-WORD BY 4-BIT STATIC RAMS # electrical characteristics over recommended operating free-air temperature ranges (unless otherwise noted) | | PARAMETER | TEST CONDITIONS | | | | TYP† | MAX | UNIT | |-----------------|----------------------------------------------------------|--------------------------------------------------------------------|---------------------------|-------------------------|----------|------|-----|-------| | Vон | High level voltage | I <sub>OH</sub> = -1.0 mA | V <sub>CC</sub> = 4.5 V | | 2.4 | | | ٧ | | VOL | Low level voltage | I <sub>OL</sub> = 3.2 mA | V <sub>CC</sub> = 4.5 V | | | | 0.4 | ٧ | | li I | Input current | V <sub>I</sub> = 0 V to 5.5 V | | | | | 10 | μΑ | | loz | Off-state output current | S at 2 V or<br>W at 0.3 V, | V <sub>O</sub> = 0 V to 5 | 5.5 V | -10 | | 10 | μΑ | | | | | | V <sub>CC</sub> = 5.5 V | | 90 | 100 | | | | | $I_{\Omega} = 0 \text{ mA},$ | TMS 4045 | V <sub>CC</sub> = 2.4 V | | 60 | 70 | mA | | <sup>1</sup> CC | Supply current from VCC | $T_{\Delta} = 0^{\circ}C$ (worst case) | TMS 40L45 | V <sub>CC</sub> = 5.5 V | | 50 | 60 | III.A | | | | | | V <sub>CC</sub> = 2.4 V | <u> </u> | 35 | 45 | 1 | | | Supply current from VCC1 | $I_{O} = 0 \text{ mA},$ | • | V <sub>CC</sub> = 5.5 V | | 5 | 11 | mA | | ICC1 | (array only) (TMS 4047/L47 only) | T <sub>A</sub> = 70°C (worst case) | | V <sub>CC</sub> = 2.4 V | | 2.5 | 5.5 | IIIA | | | Supply current from | lo= 0 mA, | TMS 4047 | | | 90 | 99 | | | ICC2 | V <sub>CC2</sub> (periphery only)<br>(TMS 4047/L47 only) | $V_{CC} = 5.5 \text{ V},$ $T_{A} = 0^{\circ}\text{C (worst case)}$ | TMS 40L47 | | | 50 | 59 | mA | | Ci | Input capacitance | V <sub>I</sub> = 0 V,<br>f = 1 MHz | | | | | 8 | pF | | Co | Output capacitance | V <sub>O</sub> = 0 V,<br>f = 1 MHz | | | | | 8 | рF | †All typical values are at $V_{CC} = 5 \text{ V}$ , $T_A = 25^{\circ}\text{C}$ . # timing requirements over recommended supply voltage range, TA = 0°C to 70°C 1 Series 74 TTL load CL = 100 pF | PARAMETER | | | | | | | TMS 4045/L45-45<br>TMS 4047/L47-45 | | | |----------------------------------------|-----|-----|-----|-----|-----|-----|------------------------------------|-----|----------| | | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | <u> </u> | | t <sub>c(rd)</sub> Read cycle time | 150 | | 200 | | 250 | | 450 | | ns | | t <sub>C(wr)</sub> Write cycle time | 150 | | 200 | | 250 | | 450 | | ns | | tw(W) Write pulse width | 80 | | 100 | | 100 | | 200 | | ns | | t <sub>su(A)</sub> Address set up time | 0 | | 0 | | 0 | | 0 | | ns | | tsu(S) Chip select set up time | 80 | | 100 | | 100 | | 200 | | ns | | t <sub>su(D)</sub> Data set up time | 80 | | 100 | | 100 | | 200 | | ns | | th(D) Data hold time | 0 | | 0 | | 0 | | . 0 | | ns | | th(A) Address hold time | 0 | | 0 | | 0 | | 0 | | ns | INCORPORATED # TMS 4045 JL, JDL, NL; TMS 40L45 JL, JDL, NL; TMS 4047 JL, JDL, NL; TMS 40L47 JL, JDL, NL **1024-WORD BY 4-BIT STATIC RAMs** # switching characteristics over recommended voltage range, t\_A = 0°C to 70°C, 1 Series 74 TTL load, C\_L = 100 pF | PARAMETER | | TMS 40<br>TMS 40<br>MIN | | | 15/L45-20<br>17/L47-20<br>MAX | | | | _ | UNIT | |--------------------|------------------------------------------------------------------|-------------------------|-----|----|-------------------------------|-------|-----|-------|------------|--------------| | t <sub>a(A)</sub> | Access time from address | 1 | 150 | | 200 | rem t | 250 | IVINA | MAX | <del> </del> | | t <sub>a(S)</sub> | Access time from chip select<br>(or output enable) low | | 70 | | 85 | | 100 | | 450<br>120 | ns | | t <sub>a</sub> (W) | Access time from write enable high | <u> </u> | 70 | | 85 | | 100 | | 120 | ns | | tPVX | Output data valid after address change | 20 | | 20 | | 20 | | 20 | | ns | | tpvz,s | Output disable time after chip select<br>(or output enable) high | | 50 | | 60 | | 60 | | 100 | ns | | tpvz,w | Output disable time after write enable low | | 50 | | 60 | | 60 | | 100 | ns | nanoseconds. ""Write enable is high for a read cycle. INCORPORATED POST OFFICE BOX 225012 • DALLAS, TEXAS 75265 # TMS 4045 JL, JDL, NL; TMS 40L45 JL, JDL, NL; TMS 4047 JL, JDL, NL; TMS 40L47 JL, JDL, NL 1024-WORD BY 4-BIT STATIC RAMS Early write cycle avoids DQ conflicts by controlling the write time with $\overline{S}$ . On the diagram above, the write operation will be controlled by the leading edge of $\overline{S}$ , not $\overline{W}$ . Data can only be written when both $\overline{S}$ and $\overline{W}$ are low. Either $\overline{S}$ or $\overline{W}$ being high inhibits the write operation. To prevent erroneous data being written into the array, the addresses must be stable during the write cycle as defined by $t_{SU}(A)$ , $t_{W}(W)$ , and $t_{h}(A)$ . INCORPORATED POST OFFICE BOX 225012 . DALLAS, TEXAS 75265 FEBRUARY 1979 - 1024 X 4 Organization - Single 5% Tolerance +5 V Supply - High Density, 300-mil (7,62 mm), 18-Pin Package - Fully Static Operation (No Clocks, no refresh, no timing strobe) - Maximum Access Time . . . 450 ns - Minimum Cycle (Read or Write) Time . . . 450 ps - 400 mV Guaranteed dc Noise Immunity With Standard TTL Loads — No Pull-Up Resistors Required - Common I/O With Three-State Outputs and Chip Select Control for OR-Tie Capability - Fan-Out to 1 Series 74 or 74S TTL Load — No Pull-Up Resistors Required - Low Power Dissipation 330 mW Typical 525 mW Maximum #### description The TMS 4014 static random-access memory is organized as 1024 words of 4 bits. Static design results in reduced overhead costs by elimination of refresh-clocking circuitry and by simplification of timing requirements. Because this series is fully static, chip select may be tied low to further simplify system timing. Output data is always available during a read cycle. All inputs and outputs are fully compatible with Series 74 or 74S TTL. No pull-up resistors are required. The TMS 4014 is manufactured using Tl's reliable N-channel silicon-gate technology to optimize the cost/performance relationship. The TMS 4014 is characterized to retain data at $V_{CC}=2.4$ V to reduce power dissipation. The TMS 4014 is offered in 18-pin dual-in-line sidebraze (JDL suffix) and plastic (NL suffix) packages designed for insertion in mounting-hole rows on 300-mil (7,62-mm) centers. The TMS 4014 is designed for operation from 0°C to 70°C. TMS 4014 18-PIN CERAMIC AND PLASTIC DUAL-IN-LINE PACKAGES (TOP VIEW) | A6 | 1 | • | b | 18 | vcc | |------------|---|---|---|----|-----------| | <b>A</b> 5 | 2 | 0 | b | 17 | A7 | | A4 | 3 | 0 | 9 | 16 | <b>A8</b> | | A3 | 4 | 0 | b | 15 | A9 | | A0 | 5 | 0 | 0 | 14 | 1/01 | | <b>A</b> 1 | 6 | 0 | b | 13 | 1/02 | | A2 | 7 | 9 | • | 12 | 1/03 | | s | 8 | 0 | Þ | 11 | 1/04 | | vss | 9 | • | Ŀ | 10 | W | | PIN NAMES | | | | | | |-----------|-------------------|--|--|--|--| | A0-A9 | Addresses | | | | | | 1/01-1/04 | Data input/output | | | | | | ŌĒ | Output Enable | | | | | | Š | Chip Select | | | | | | vcc | +5 V Supply | | | | | | $V_{SS}$ | Ground | | | | | | w | Write Enable | | | | | | | | | | | | PRELIMINARY DATA SHEET: Supplementary data will be published at a later date. TEXAS INSTRUMENTS INCORPORATED POST OFFICE BOX 225012 • DALLAS, TEXAS 75265 #### operation #### addresses (A0-A9) The ten address inputs select one of the 1024 four-bit words stored in the RAM. The address-inputs must be stable for the duration of a write cycle. The address inputs can be driven directly from standard Series 54/74 TTL with no external pull-up resistors. #### chip select (S) The chip-select terminal, which can be driven directly from standard TTL circuits, affects only the data-in/data-out terminals. When chip select and output enable are a logic low, the I/O terminals are enabled. When chip select is a logic high, the I/O terminals are in the floating or high-impedance state and the input is inhibited. #### write enable (W) The read or write mode is selected through the write enable terminal. A logic high selects the read mode; a logic low selects the write mode. W must be a logic high when changing addresses to prevent erroneously writing data into a memory location. The W input can be driven directly from standard TTL circuits. #### data-in/data-out (I/O1-I/O4) Data can be written into a selected device when the write enable input is a logic low. The I/O terminal can be driven directly from standard TTL circuits. The three-state output buffer provides direct TTL compatibility with a fan-out of one Series 74 TTL gate or one Series 74S TTL gate. The I/O terminals are in the high-impedance state when chip select (S) is high or whenever a write operation is being performed. Data-out is the same polarity as data-in. #### standby operation The standby mode, available to retain data while operating the TMS 4014, is attained by reducing VCC from 5 V to 2.4 V. Before, during, and immediately after standby, $\overline{S}$ and $\overline{W}$ must be in the high state. During standby operation, data cannot be read or written into the memory. When resuming normal operation, five cycle times must be allowed after normal power is restored for the memory to resume steady-state operating conditions. #### functional block diagram #### Texas Instruments INCORPORATED POST OFFICE BOX 225012 • DALLAS, TEXAS 75265 # absolute maximum ratings over operating free-air temperature range (unless otherwise noted)\* | Supply voltage, V <sub>CC</sub> (see Note 1) | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Input voltage (any input) (see Note 1) | | Input voltage (any input) (see Note 1) | | Continuous power dissipation | | Operating free-air temperature range | | Stands to mark to make the control of o | | Storage temperature range | "Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. #### recommended operating conditions | PARAMETI | ER . | MIN | NOM MAX | LIMIT | |---------------------------------|-----------|------|---------|---------------------------------------| | Supply voltage, V <sub>CC</sub> | Operating | 4.75 | 5 5.25 | | | | Standby | 2.4 | 5 5.25 | ΙV | | Supply voltage, V <sub>SS</sub> | | 2.7 | 0 0.25 | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | High-level input voltage, VIH | | 2.0 | 5.25 | V | | Low-level input voltage, VIL | | -0.3 | 0.8 | v | | Operating free-air temperature, | TA | 0 | 70 | °C | ### electrical characteristics over recommended operating free-air temperature range (unless otherwise noted) | PARAMETER | | TEST CONDITIONS | | MIN TYPT MAX | UNIT | |----------------|-------------------------------------|-----------------------------------|------------------------------|--------------|------| | Vон | High-level voltage | 1OH = -200 μA, | V <sub>CC</sub> = 4.75 V | 2.4 | V | | VOL | Low-level voltage | I <sub>OL</sub> = 2 mA, | V <sub>CC</sub> = 4.75 V | 0.4 | V | | l <sub>l</sub> | Input current | V <sub>I</sub> = 0 to 5.25 V | | 10 | μА | | loz | Off-state output current | S@ 2 V or<br>W at 0.8 V, | V <sub>O</sub> = 0 to 5.25 V | ±10 | μА | | Icc | Supply current from V <sub>CC</sub> | I <sub>O</sub> = 0 mA, | V <sub>CC</sub> = 5.25 V | 90 100 | mA | | | Toppe, to rem rom vec | T <sub>A</sub> = 0°C (worst case) | V <sub>CC</sub> = 2.4 V | 60 70 | mA | | Ci | Input capacitance | V <sub>1</sub> = 0 V, | f = 1 MHz | 8 | | | Со | Output capacitance | V <sub>O</sub> = 0 V, | f = 1 MHz | 12 | | $<sup>^{\</sup>dagger}$ All typical values are at $V_{CC}$ = 5 V, $T_{A}$ = 25°C. timing requirements over recommended supply voltage range and operating free-air temperature range | | | MIN MAX | UNI | |--------------------|-------------------------|---------|-----| | | PARAMETER | 450 | ns | | t <sub>c(rd)</sub> | Read cycle time | 450 | ns | | c(wr) | Write cycle time | | | | w(W) | Write pulse width | 200 | ns | | su(A) | Address set up time | 200 | ns | | su(S) | Chip select set up time | | 1 | | su(D) | Data set up time | 200 | ns | | | Data hold time | 0 | ns | | th(D) | | 20 | ns | | h(A) | Address hold time | 5 200 | ns | | T(A) | Address transition time | 3 200 | 1 | switching characteristics over recommended voltage range, $T_{\mbox{$A$}}$ = 0°C to 70°C, 1 series 74 TTL load, $C_L$ = 100 pF | | PARAMETER | MI | NOM | | UNIT | |-------------------|---------------------------|----|-----|-----|----------| | t <sub>a(A)</sub> | Access time from address | | | 450 | ns | | -0(A) | Access time from chip | | | 120 | ns | | ta(S) | select (or output | | | 120 | 113 | | J(0) | enable) low | | | | - | | • (141) | Access time from | | | 120 | ns | | t <sub>a(W)</sub> | write enable high | | | | | | | Output data valid after | | 10 | | ns | | tPVX | address change | | | | ļ., | | | Output disable time after | į | | 400 | | | tPVZ,S | chip select (or output | | | 100 | ns | | | enable) high | | | | | | | Output disable time after | | | 100 | ns | | tP∨Z,W | write enable high | | | | <u> </u> | #### read cycle timing\*\* All timing reference points are 0.8 V and 2.0V on inputs and 0.6 V and 2.2 V on outputs (90% points). Input rise and fall times equal 10 nanoseconds. \*\*Write enable is high for a read cycle. #### early write cycle timing # TEXAS INSTRUMENTS POST OFFICE BOX 225012 • DALLAS, TEXAS 75265 #### read-write cycle timing #### applications data Early write cycle avoids I/O conflicts by controlling the write time with $\overline{S}$ . In the diagram above the write operation will be controlled by the leading edge of $\overline{S}$ , not $\overline{W}$ . Data can only be written when both $\overline{S}$ and $\overline{W}$ are logic low. Either $\overline{S}$ or $\overline{W}$ being logic high inhibits the write operation, and data stored will not be affected by the address. To prevent erroneous data from being written into the array, the addresses must be stable during the write cycle as defined by $t_{SW}(A)$ , $t_{W}(W)$ , and $t_{N}(A)$ . | | | • | | |--|--|---|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### **APPENDIX C** #### **ASCII CODE** TABLE C-1. \*ASCII CONTROL CODES | CONTROL | BINARY | HEXADECIMAL<br>CODE | |---------------------------------|----------|---------------------| | NUL - Null | 000 0000 | 00 | | SOH - Start of heading | 000 0001 | 01 | | STX - Start of text | 000 0010 | 02 | | ETX — End of text | 000 0011 | 03 | | EOT — End of transmission | 000 0100 | 04 | | ENQ - Enquiry | 000 0101 | 05 | | ACK - Acknowledge | 000 0110 | 06 | | BEL - Bell | 000 0111 | 07 | | BS - Backspace | 000 1000 | 08 | | HT - Horizontal tabulation | 000 1001 | 09 | | LF - Line feed | 000 1010 | OA | | VT - Vertical tab | 000 1011 | OB | | FF — Form feed | 000 1100 | OC | | CR - Carriage return | 000 1101 | OD | | SO - Shift out | 000 1110 | OE | | SI - Shift in | 000 1111 | OF | | DLE - Data link escape | 001 0000 | 10 | | DC1 - Device control 1 | 001 0001 | 11 | | DC2 — Device control 2 | 001 0010 | 12 | | DC3 - Device control 3 | 001 0011 | 13 | | DC4 - Device control 4 (stop) | 001 0100 | 14 | | NAK - Negative acknowledge | 001 0101 | 15 | | SYN - Synchronous idle | 001 0110 | 16 | | ETB - End of transmission block | 001 0111 | 17 | | CAN - Cancel | 001 1000 | 18 | | EM — End of medium | 001 1001 | 19 | | SUB - Substitute | 001 1010 | 1A | | ESC - Escape | 001 1011 | 18 | | FS - File separator | 001 1100 | 1C | | GS - Group separator | 001 1101 | 1 <u>D</u> | | RS - Record separator | 001 1110 | 1E | | US - Unit separator | 001 1111 | 1F | | DEL - Delete, rubout | 111 1111 | 7F | <sup>\*</sup>American Standards Institute Publication X3.4-1968 ### NOTE Hexadecimal codes 01 to 1F can be generated using most keyboard devices with the CONTROL (SHIFT) key pressed prior to pressing another keyboard key. For example, hexadecimal codes 01 to 19 can be generated on the TM 990/189 using the SHIFT key and keys A through Y respectively with the exception of keys V and X which have shift functions dedicated to display right and cancel respectively. TABLE C-2. \*ASCII CHARACTER CODE | CHARACTER | BINARY | HEXADECIMAL<br>CODE | CHARACTER | BINARY | HEXADECIMAL<br>CODE | |----------------|----------|---------------------|---------------|----------|---------------------| | Space | 010 0000 | 20 | Р | 101 0000 | | | ! | 010 0001 | 21 | 1 1 | 101 0000 | 50 | | " (dbl. quote) | 010 0010 | 22 | Q<br>R | 101 0001 | 51 | | # | 010 0011 | 23 | ll s | 101 0010 | 52 | | \$ | 010 0100 | 24 | T T | 101 0011 | 53 | | % | 010 0101 | 25 | | 101 0100 | 54 | | & | 010 0110 | 26 | | 101 0101 | 55 | | '(sgl. quote) | 010 0111 | 27 | ll w | 101 0110 | 56 | | ( | 010 1000 | 28 | vv<br> x | 101 0111 | 57 | | <u>`</u> | 010 1001 | 29 | ll ŷ | 101 1000 | 58 | | * (asterisk) | 010 1010 | 29<br>2A | Z | 101 1001 | 59 | | + | 010 1011 | 2B | [ | 101 1010 | 5A | | , (comma) | 010 1100 | 2C | | 101 1011 | 58 | | - (minus) | 010 1101 | 2D | | 101 1100 | 5C | | . (period) | 010 1110 | 2E | J | 101 1101 | 5D | | / | 010 1111 | 2F | 1 | 101 1110 | 5E | | | | 21 | _ (underline) | 101 1111 | 5F | | 0 | 011 0000 | 30 | | 110 0000 | 60 | | 1 | 011 0001 | 31 | a | 110 0001 | 61 | | 2 | 011 0010 | 32 | b | 110 0010 | 62 | | 3 | 011 0011 | 33 | С | 110 0011 | 63 | | 4 | 011 0100 | 34 | d | 110 0100 | 64 | | 5 | 011 0101 | 35 | e | 110 0101 | 65 | | 6 | 011 0110 | 36 | f | 110 0110 | 66 | | 7 | 011 0111 | 37 | g | 110 0111 | 67 | | 8 | 011 1000 | 38 | h | 110 1000 | 68 | | 9 | 011 1001 | 39 | i | 110 1001 | 69 | | : | 011 1010 | 3A | j | 110 1010 | 6A | | ; | 011 1011 | 3B | k | 110 1011 | 6B | | < | 011 1100 | 3C | ı | 110 1100 | 6C | | | 011 1101 | 3D | m | 110 1101 | 6D | | > | 011 1110 | 3E | n | 110 1110 | 6E | | ? | 011 1111 | 3F | 0 | 110 1111 | 6F | | @ | 100 0000 | 40 | р | 111 0000 | 70 | | Α | 100 0001 | 41 | q | 111 0001 | 70<br>71 | | В | 100 0010 | 42 | , , | 111 0010 | 72 | | С | 100 0011 | 43 | s | 111 0011 | 72 | | D | 100 0100 | 44 | t | 111 0100 | 73<br>74 | | E | 100 0101 | 45 | u | 111 0100 | 74<br>75 | | F | 100 0110 | 46 | v | 111 0110 | 75<br>76 | | G | 100 0111 | 47 | w | 111 0111 | 76<br>77 | | Н | 100 1000 | 48 | x | 111 1000 | 77<br>78 | | 1 | 100 1001 | 49 | y | 111 1000 | 78<br>79 | | J | 100 1010 | 4A | z | 111 1010 | | | Κ | 100 1011 | 4B | -{ | 111 1010 | 7A<br>7B | | L | 100 1100 | 4C | | 111 1100 | 7B<br>7C | | М | 100 1101 | 4D | } | 111 1101 | | | N | 100 1110 | 4E | | 111 1110 | 7D<br>7E | | 0 | 100 1111 | 4F | | 0 | / [ | <sup>\*</sup>American Standards Institute Publication X3 4-1968 #### APPENDIX D # BINARY, DECIMAL AND HEXADECIMAL NUMBERING #### **D-1 GENERAL** This appendix covers numbering systems to three bases (2, 10, and 16) which are used throughout this manual. #### **D-2 POSITIVE NUMBERS** D-2.1 **DECIMAL** (**BASE** 10). When a numerical quantity is viewed from right to left, the rightmost digit represents the base number to the exponent 0. The next digit represents the base number to the exponent 1, the next to the exponent 2, then exponent 3, etc. For example, using the base 10 (decimal): or For example, 75,264 can be broken down as follows: D-2.2 BINARY (BASE 2). As base 10 numbers use ten digits, base 2 numbers use only 0 and 1. When viewed from right to left, they each represent the number 2 to the powers 0, 1, 2, etc., respectively as shown below: For example, 11011<sub>2</sub> can be translated into base 10 as follows: 2710 or 11011<sub>2</sub> equals 27<sub>10</sub>. Binary is the language of the digital computer. For example, to place the decimal quantity 23 $(23_1)$ into a 16-bit memory cell, set the bits to the following: which is $1 + 2 + 4 + 16 = 23_{10}$ D-2.3 **HEXADECIMAL** (BASE 16). Whereas binary uses two digits and decimal uses ten digits, hexadecimal uses 16 (0 to 9, A, B, C, D, E, and F). The letters A through F are used to represent the decimal numbers 10 through 15 as shown on the following page. | N <sub>10</sub> | N <sub>16</sub> | N <sub>10</sub> | N <sub>16</sub> | |-----------------|-----------------|-----------------|-----------------| | 0 | 0 | 8 | 8 | | 1 | -1 | 9 | 9 | | 2 | 2 | 10 | Α | | 3 | 3 | 11 | В | | 4 | 4 | 12 | С | | 5 | 5 | 13 | D | | 6 | 6 | 14 | Ε | | 7 | 7 | 15 | F | When viewed from right to left, each digit in a hexadecimal number is a multiplier of 16 to the powers 0, 1, 2, 3, etc., as shown below: For example, 7 B A $5_{16}$ can be translated into base 10 as follows: or 7 B A $5_{16}$ equals $31,653_{10}$ . Because it would be awkward to write out 16-digit binary numbers to show the contents of a 16-bit memory word, hexadecimal is used instead. Thus $$003E_{16}$$ or $> 003E$ ( $>$ indicates hexadecimal) is used instead of 0000 0000 0011 11102 to represent 62<sub>10</sub> as computed below: Note that separating the 16 binary bits into four-bit parts facilitates recognition and translation into hexadecimal. Table D-1 is a conversion chart for converting decimal to hexadecimal and vice versa. Table D-2 shows binary, decimal and hexadecimal equivalents for numbers 0 to 15. Note that Table D-1 is divided into four parts, each part representing four of the 16-bits of a memory cell or word (bits 0 to 15) with bit 0 being the most significant bit (MSB) and bit 15 being the least significant bit (LSB). Note that the MSB is on the left and represents the highest power of 2 and the LSB on the right represents the 0 power of 2 ( $2^0 = 1$ ). As explained later, the MSB can also be used to signify number polarity (+ or -). #### **NOTE** To convert a binary number to decimal or hexadecimal, convert the *positive* binary value as described in Section D-4. TABLE D-1 HEXADECIMAL/DECIMAL CONVERSION CHART MSB LSB | | | 16 <sup>3</sup> | 1 | 6 <sup>2</sup> | 16 <sup>1</sup> | l I | 16 | 0 | |------|-----|-----------------|-----|----------------|-----------------|------|-------|-------| | вітѕ | 0 1 | 2 3 | 4 5 | 6 7 | 8 7 | 8 11 | 12 13 | 14 15 | | | HEX | DEC | HEX | DEC | HEX I | DEC | HEX | DEC | | | o | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 1 | 4 096 | . 1 | 256 | 1 | 16 | 1 | 1 | | | 2 | 8 192 | 2 | 512 | 2 | 32 | 2 | 2 | | | 3 | 12 288 | 3 | 768 | 3 | 48 | 3 | 3 | | | 4 | 16 384 | 4 | 1 024 | 4 | 64 | 4 | 4 | | | 5 | 20 480 | 5 | 1 280 | 5 | 80 | 5 | 5 | | | 6 | 24 576 | 6 | 1 536 | 6 | 96 | 6 | 6 | | | 7 | 28 672 | 7 | 1 792 | 7 | 112 | 7 | 7 | | | 8 | 32 768 | 8 | 2 048 | 8 | 128 | 8 | 8 | | | 9 | 36 864 | 9 | 2 304 | 9 | 144 | 9 | 9 | | | Α | 40 960 | A | 2 560 | A | 160 | A | 10 | | | В | 45 056 | В | 2 816 | В | 176 | В | 11 | | | С | 49 152 | С | 3 072 | C | 192 | C | 12 | | | D | 53 248 | D | 3 328 | D | 208 | D | 13 | | | E | 57 344 | E | 3 584 | E | 224 | E | 14 | | | F | 61 440 | F | 3 840 | F | 240 | F | 15 | To convert a number from hexadecimal, add the decimal equivalents for each hexadecimal digit. For example, $7A82_{16}$ would equal in decimal $28,672 \pm 2,560 \pm 128 \pm 2$ . To convert hexadecimal to decimal, find the nearest decimal number in the above table less than or equal to the number being converted. Set down the hexadecimal equivalent then subtract this number from the nearest decimal number. Using the remainder(s), repeat this process. For example: TABLE D-2. BINARY, DECIMAL, AND HEXADECIMAL EQUIVALENTS | BINARY | DECIMAL | HEXADECIMAL | | |---------------------------|----------------------------|----------------------------|--| | ( <b>N</b> <sub>2</sub> ) | ( <b>N</b> <sub>10</sub> ) | ( <b>N</b> <sub>16</sub> ) | | | 0000 | 0 | 0 | | | 0001 | 1 | 1 | | | 0010 | 2 | 2 | | | 0011 | 3 | 3 | | | 0100 | 4 | 4 | | | 0101 | 5 | 5 | | | 0110 | 6 | 6 | | | 0111 | 7 | 7 | | | 1000 | 8 | 8 | | | 1001 | 9 | 9 | | | 1010 | 10 | Ä | | | 1011 | 11 | В | | | 1100 | 12 | C | | | 1101 | 13 | D | | | 1110 | 14 | Ē | | | 1111 | 15 | F | | | 10000 | 16 | 10 | | | 10001 | 17 | 11 | | | 10010 | 18 | 12 | | | 10011 | 19 | 13 | | | 10100 | 20 | 14 | | | 10101 | 21 | 15 | | | 10110 | 22 | 16 | | | 10111 | 23 | 17 | | | 11000 | 24 | 18 | | | 11001 | 25 | 19 | | | 11010 | 26 | 1A | | | 11011 | 27 | 1B | | | 11100 | 28 | 1C | | | 11101 | 29 | 1D | | | 11110 | 30 | 1E | | | 11111 | 31 | 1F | | | 100000 | 32 | 20 | | # D-3 ADDING AND SUBTRACTING BINARY Adding and subtracting in binary uses the same conventions for decimal: carrying over in addition and borrowing in subtraction. Basically, D-4 POSITIVE/NEGATIVE CONVERSION (BINARY). To compute the negative equivalent of a positive binary or hexadecimal number, or interpret a binary or hexadecimal negative number (determine its positive equivalent) use the two's complement of the binary number. #### NOTE To convert a binary number to decimal, convert the *positive* binary value (*not* the negative binary value) and add the sign. Two's complementing a binary number includes two simple steps: - a. Obtain one's complement of the number (1's become 0's, 0's becomes 1's) (invert bits). - b. Add 1 to the one's complement. For example, with the MSB (left-most bit) being a sign bit: This can be expanded to 16-bit positive numbers: And to 16-bit negative numbers: # APPENDIX E The Engineering Staff of TEXAS INSTRUMENTS INCORPORATED Semiconductor Group # TMS 9901 PROGRAMMABLE SYSTEMS INTERFACE **JULY 1978** TEXAS INSTRUMENTS # TABLE OF CONTENTS | 1. | NTF | RODUCTION | | |--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----| | 1 | 1.1 | Description | 1 | | 1 | 1.2 | Key Features | | | 1 | 1.3 | Application Overview | 1 | | 2. | ARC | HITECTURE | | | 2 | 2.1 | CRU Interface | 2 | | 2 | 2.2 | Interrupt Interface | | | 2 | 2.3 | Input/Output Interface | | | | 2.4 | Programmable Ports | | | | 2.6 | Power-Up Considerations | | | | 2.7 | Pin Descriptions | | | 3. | APP | LICATIONS | | | | 3.1 | Hardware Interface | 12 | | | 3.2 | Software Interface | | | | 3.3 | Interval Timer Application | | | | J. O | The rate of ra | | | 4. 1 | TMS | 9901 ELECTRICAL SPECIFICATIONS | | | | 4.1 | Absolute Maximum Ratings Over Operating Free Air | | | | | Temperature Range (Unless Otherwise Noted) | 10 | | _ | 4.2 | Recommended Operating Conditions | | | | 1.3 | Electrical Characteristics Over Full Range of Recommended | 19 | | | | Oper iting Conditions (Unless Otherwise Noted) | 10 | | _ | 1.4 | Timing Requirements Over Full Range of Operating Conditions | 10 | | | 4.5 | Switching Characteristics Over Full Range of Recommended | 19 | | - | Ŧ.J | Operating Conditions | 20 | | 5. 1 | MEC | HANICAL DATA | | | | 5.1 | TMS 9901 — 40 Pin Ceramic Package | 24 | | | 5.2 | TMS 9901 — 40 Pin Plastic Package | | | | J. Z | TIMO 9901 — 40 FIII Flastic Fackage | 22 | | | | LIST OF ILLUSTRATIONS | | | Figure | | Typical TMS 9901 Programmable System Interface (PSI) Application | | | Figure | | TMS 9901 PSI Block Diagram | 3 | | Figure | 3 | TMS 9901 PSI Interrupt Control Block Diagram | 6 | | Figure | 4 | TMS 9901 I/O Interface Section | | | Figure | 5 | Input and Output Equivalents | 8 | | Figure | 6 | TMS 9901 Interval Timer Section | | | Figure | 7 | TMS 9900/TMS 9901 Interface | 12 | | Figure | 8 | TMS 9981/TMS 9901 Interface | | | Figure | 9 | TMS 9900 Sample Software To Control The TMS 9901 | | | Figure | 10 | TMS 9901 Interval Timer Application Flowchart | 16 | | Figure | 11 | Interval Timer | | | Figure | | Switching Characteristics | | | | | LIST OF TABLES | | | Table | 1 | CRU Bit Assignments | | | Table | | Interrupt Code Generation | | | Table | _ | TMS 9980A or TMS 9981 Interrupt Level Data | | | Table | - | TMS 9901 Pin Assignments and Functions | | # 1. INTRODUCTION # 1.1 DESCRIPTION The TMS 9901 Programmable Systems Interface (PSI) is a multifunctional component designed to provide low cost interrupt and I/O ports and an interval timer for TMS 9900-family microprocessor systems. The TMS 9901 is fabricated using N-channel silicon-gate MOS technology. The TMS 9901 is TTL-compatible on all inputs and outputs, including the power supply (+5 V) and single-phase clock. # 1.2 KEY FEATURES - Low Cost - 9900-Family Peripheral - Performs Interrupt and I/O Interface functions: - Six Dedicated Interrupt Lines - Seven Dedicated I/O Lines - Nine Programmable Lines as I/O or Interrupt - Up to 15 Interrupt Lines - Up to 22 Input Lines - Up to 16 Output Lines - Easily Cascaded for Expansion - Interval or Event Timer - Single 5 V Power Supply - All Inputs and Outputs TTL-Compatible - Standard 40-Pin Plastic or Ceramic Package - N-Channel Silicon-Gate MOS Technology. # 1.3 APPLICATION OVERVIEW The following example of a typical application may help introduce the user to the TMS 9901 PSI. Figure 1 is a block diagram of a typical application. Each of the ideas presented below is described in more detail in later sections of this manual. The TMS 9901 PSI interfaces to the CPU through the Communications Register Unit (CRU) and the interrupt control lines as shown in Figure 1. The TMS 9901 occupies 32 bits of CRU input and output space. The five least significant bits of address bus are connected to the S lines of the PSI to address one of the 32 CRU bits of the TMS 9901. The most significant bits of the address bus are decoded on CRU cycles to select the PSI by taking its chip enable $(\overline{CE})$ line active (LOW). Interrupt inputs to the TMS 9901 PSI are synchronized with $\overline{\phi}$ , inverted, and then ANDed with the appropriate mask bit. Once every $\overline{\phi}$ clock time, the prioritizer looks at the 15 interrupt input AND gates and generates the interrupt control code. The interrupt control code and the interrupt request line constitute the interrupt interface to the CPU. After reset all I/O ports are programmed as inputs. By writing to any I/O port, that port will be programmed as an output port until another reset occurs, either software or hardware. Data at the input pins is buffered on to the TMS 9901. Data to the output ports is latched and then buffered off-chip by the PSI's MOS-to-TTL buffers. The interval timer on the TMS 9901 is accessed by writing a ONE to select bit zero (control bit), which puts the PSI CRU interface in the clock mode. Once in the clock mode the 14-bit clock contents can be read or written. Writing to the clock register will reinitialize the clock and cause it to start decrementing. When the clock counts to zero, it will cause an interrupt and reload to its initial value. Reading the clock contents permits the user to see the decrementer contents at that point in time just before entering the clock mode. The clock read register is not updated when the PSI is in the clock mode. FIGURE 1— TYPICAL TMS 9901 PROGRAMMABLE SYSTEM INTERFACE (PSI) APPLICATION # 2. ARCHITECTURE The architecture of the TMS 9901 Programmable Systems Interface (PSI) is designed to provide the user maximum flexibility when designating system I/O ports and interrupts. The TMS 9901 can be divided into four subsystems: CRU interface, interrupt interface, input/output interface, and interval timer. Figure 2 is a general block diagram of the TMS 9901 internal architecture. Each of the subsystems of the PSI is discussed in detail in subsequent paragraphs. ## 2.1 CRU Interface The CPU communicates with the TMS 9901 PSI via the CRU. The TMS 9901 occupies 32 bits in CRU read space and 32 bits in CRU write space. Table 1 shows the mapping for CRU bit addresses to TMS 9901 functions, The CRU interface consists of five address select lines (S0-S4), chip enable ( $\overline{CE}$ ), and the three CRU lines (CRUIN, CRUOUT, CRUCLK). The select lines (S0-S4) are connected to the five least significant bits of the address bus; for a TMS 9900 system S0-S4 are connected to A10-A14, respectively. Chip enable ( $\overline{CE}$ ) is generated by decoding the most significant bits of the address bus on CRU cycles; for a 9900 based system address bits 0-9 would be decoded. When $\overline{CE}$ goes active (LOW), the five select lines point to the CRU bit being accessed. When $\overline{CE}$ is inactive (HIGH), the PSI's CRU interface is disabled. # NOTE When $\overline{CE}$ is inactive (HIGH) the 9901 sets its CRUIN pin to high impedance and disables CRUCLK from coming on chip. This means that CRUIN can be used as an OR tied bus. When $\overline{CE}$ is high the 9901 will still see the select lines, but no command action is taken. In the case of a write operation, the TMS 9901 strobes data off the CRUOUT line with CRUCLK. For a read operation, the data is sent to the CPU on the CRUIN line. FIGURE 2-TMS 9901 PSI BLOCK DIAGRAM Several TMS 9901 devices may be cascaded to expand I/O and interrupt handling capability simply by connecting all CRU and address select lines in parallel and providing each device with a unique chip enable signal: the chip enable $(\overline{CE})$ is generated by decoding the high-order address bits (A0-A9) on CRU cycles. For those unfamiliar with the CRU concept, the following is a discussion of how to build a CRU interface. The CRU is a bit addressable (4096 bits), synchronous, serial interface over which a single instruction can transfer between one and 16 bits serially. Each one of the 4096 bits of the CRU space has a unique address and can be read and written to. During multi-bit CRU transfers, the CRU address is incremented at the beginning of each CRU cycle to point to the next consecutive CRU bit. TABLE 1 CRU SELECT BIT ASSIGNMENTS | CRU Bit | S <sub>0</sub> S <sub>1</sub> S <sub>2</sub> S <sub>3</sub> S <sub>4</sub> | CRU Read Data | CRU Write Data | |---------|----------------------------------------------------------------------------|-------------------------|-----------------------------| | 0 | 0 0 0 0 0 | CONTROL BIT(1) | CONTROL BIT(1 | | 1 | 0 0 0 0 1 | INT1/CLK1(2) | Mask 1/CLK1(3) | | 2 | 0 0 0 1 0 | INT2/CLK2 | Mask 2/CLK2 | | 3 | 0 0 0 1 1 | INT3/CLK3 | Mask 3/CLK3 | | 4 | 0 0 1 0 0 | INT4/CLK4 | Mask 4/CLK4 | | 5 | 0 0 1 0 1 | INT5/CLK5 | Mask 5/CLK5 | | 6 | 0 0 1 1 0 | INT6/CLK6 | Mask 6/CLK6 | | 7 | 0 0 1 1 1 | INT7/CLK7 | Mask 7/CLK7 | | 8 | 0 1 0 0 0 | INT8/CLK8 | Mask 8/CLK8 | | 9 | 0 1 0 0 1 | INT9/CLK9 | Mask 9/CLK9 | | 10 | 0 1 0 1 0 | INT10/CLK10 | Mask 10/CLK10 | | 11 | 0 1 0 1 1 | INT11/CLK11 | Mask 11/CLK11 | | 12 | 0 1 1 0 0 | INT12/CLK12 | Mask 12/CLK12 | | 13 | 0 1 1 0 1 | INT13/CLK13 | Mask 13/CLK13 | | 14 | 0 1 1 1 0 | INT14/CLK14 | Mask 14/CLK14 | | 15 | 0 1 1 1 1 | INT 15/INTREQ (7) | Mask 15/RST2 <sup>(4)</sup> | | 16 | 1 0 0 0 0 | PO Input <sup>(5)</sup> | PO Output(6) | | 17 | 1 0 0 0 1 | P1 Input | P1 Output | | 18 | 1 0 0 1 0 | P2 Input | P2 Output | | 19 | 1 0 0 1 1 | P3 Input | P3 Output | | 20 | 1 0 1 0 0 | P4 Input | P4 Output | | 21 | 1 0 1 0 1 | P5 Input | P5 Output | | 22 | 1 0 1 1 0 | P6 Input | P6 Output | | 23 | 1 0 1 1 1 | P7 Input | P7 Output | | 24 | 1 1 0 0 0 | P8 Input | P8 Output | | 25 | 1 1 0 0 1 | P9 Input | P9 Output | | 26 | 1 1 0 1 0 | P10 Input | P10 Output | | 27 | 1 1 0 1 1 | P11 Input | P11 Output | | 28 | 1 1 1 0 0 | P12 Input | P12 Output | | 29 | 1 1 1 0 1 | P13 Input | P13 Output | | 30 | 1 1 1 1 0 | P14 Input | P14 Output | | 31 | 1 1 1 1 1 | P15 Input | P15 Output | # NOTES: - O = Interrupt Mode 1 = Clock Mode (2) Data present on INT input pin (or clock value) will be read regardless of mask value. (3) While in the Interrupt Mode (Control Bit = 0) writing a "1" into mask will enable interrupt; a "0" will disable. (4) Writing a zero to bit 15 while in the clock mode (Control Bit = 1) executes a software reset of the I/O pins. (5) Data present on the pin will be read. Output data can be read without affecting the data. (6) Writing data to the port will program the port to the output mode and output the data. (7) INTREQ is the inverted status of the INTREQ pin. When a 99XX CPU executes a CRU Instruction, the processor uses the contents of workspace register 12 as a base address. (Refer to the 9900 Microprocessor Data Manual for a complete discussion on how CRU addresses are derived.) The CRU address is brought out on the 15-bit address bus; this means that the least significant bit of R12 is not brought out of the CPU. During CRU cycles, the memory control lines (MEMEN, WE, and DBIN) are all inactive; MEMEN being inactive (HIGH) indicates the address is not a memory address and therefore is a CRU address or external instruction code. Also, when MEMEN is inactive (HIGH) and a valid address is present, address bits A0-A2 must all be zero to constitute a valid CRU address; if address bits A0-A2 are other than all zeros, they are indicating an external instruction code. In summary, address bits A3-A14 contain the CRU address to be decoded, address bits A0-A2 must be zero and MEMEN must be inactive (HIGH) to indicate a CRU cycle. # 2.2 Interrupt Interface A block diagram of the interrupt control section is shown in Figure 3. The interrupt inputs (six dedicated, $\overline{\text{INT1-INT6}}$ , and nine programmable) are sampled on the falling edge of $\overline{\phi}$ and latched onto the chip for one $\overline{\phi}$ time by the SYNC LATCH, each $\overline{\phi}$ time. The output of the sync latch is inverted (interrupts are LOW active) and ANDed with its respective mask bit (MASK = 1, INTERRUPT ENABLED). On the rising edge of $\overline{\phi}$ , the prioritizer and encoder senses the masked interrupts and produces a four-bit encoding of the highest priority interrupt present (see Tables 2 and 3). The four-bit prioritized code and $\overline{\text{INTREQ}}$ are latched off-chip with a sync latch on the falling edge of the next $\overline{\phi}$ , which ensures proper synchronization to the processor. Once an interrupt goes active (LOW), it should stay active until the appropriate interrupt service routine explicitly turns off the interrupt. If an interrupt is allowed to go inactive before the interrupt service routine is entered, an erroneous interrupt code could be sent to the processor. A total of five clock cycles occur between the time the CPU samples the INTREQ line and the time it samples the ICO-IC3 lines. For example, if an interrupt is active and the CPU recognizes that an interrupt is pending, but before the CPU can sample the interrupt control lines the interrupt goes inactive, the interrupt control lines will contain an incorrect code. The interrupt mask bits on the TMS 9901 PSI are individually set or reset under software control. Any unused interrupt line should have its associated mask disabled to avoid false interrupts: To do this, the control bit (CRU bit zero), is first set to a zero for interrupt mode operation. Writing to TMS 9901 CRU bits 1-15 will enable or disable interrupts 1-15, respectively. Writing a one to an interrupt mask will *enable* that interrupt; writing a zero will *disable* that interrupt. Upon application of RST1 (power-up reset), all mask bits are reset (LOW), the interrupt code is forced to all zeros, and INTREQ is held HIGH. Reading TMS 9901 CRU bits 1-15 indicates the status of the respective interrupt inputs; thus, the designer can employ the unused (disabled) interrupt input lines as data inputs (true data in). # 2.3 Input/Output Interface A block diagram of the TMS 9901 I/O interface is shown in Figure 4. Up to 16 individually controlled, I/O ports are available (seven dedicated, P0-P6, and nine programmable) and, as discussed above, the unused dedicated interrupt lines also can be used as input lines (true data in). Thus the 9901 can be configured to have more than 16 inputs. RST1 (power-up reset) will program all I/O ports to input mode. Writing data to a port will automatically switch that port to the output mode. Once programmed as an output, a port will remain in output mode until RST1 or RST2 (command bit) is executed. An output port can be read and indicates the present state of the pin. A pin programmed to the output mode cannot be used as an input pin: Applying an input current to an output pin may cause damage to the TMS 9901. The TMS 9901 outputs are latched and buffered off-chip, and inputs are buffered onto the chip. The output buffers are MOS-to-TTL buffers and can drive two standard TTL loads. FIGURE 3- TMS 9901 PSI INTERRUPT CONTROL SECTION BLOCK DIAGRAM TABLE 2 INTERRUPT CODE GENERATION | INTERRUPT/STATE | PRIORITY | l <sub>C0</sub> | l <sub>C1</sub> | I <sub>C2</sub> | I <sub>C3</sub> | INTREQ | |-----------------|-------------|-----------------|-----------------|-----------------|-----------------|--------| | RST 1 | - | 0 | 0 | 0 | 0 | 1 | | INT 1 | 1 (HIGHEST) | 0 | 0 | 0 | 1 | 0 | | INT 2 | 2 | 0 | 0 | 1 | 0 | 0 | | INT 3/CLOCK | 3 | 0 | 0 | 1 | 1 | 0 | | ĪNT 4 | 4 | 0 | 1 | 0 | 0 | 0 | | INT 5 | 5 | 0 | 1 | 0 | 1 | 0 | | INT 6 | 6 | 0 | 1 | 1 | 0 | 0 | | INT 7 | 7 | 0 | 1 | 1 | 1 | 0 | | INT 8 | 8 | 1 | 0 | 0 | 0 | 0 | | INT 9 | 9 | 1 | 0 | 0 | 1 | 0 | | INT 10 | 10 | 1 | 0 | 1 | 0 | 0 | | INT 11 | 11 | 1 | 0 | 1 | 1 | 0 | | INT 12 | 12 | 1 | 1 | 0 | 0 | 0 | | INT 13 | 13 | 1 | 1 | 0 | 1 | 0 | | INT 14 | 14 | 1 | 1 | 1 | 0 | 0 | | INT 15 | 15 (LOWEST) | 1 | 1 | 1 | 1 | 0 | | NO INTERRUPT | _ | 1 | 1 | 1 | 1 | 1 | TABLE 3 TMS 9980A OR TMS 9981 INTERRUPT LEVEL DATA | CODE<br>(ICO-IC2) | FUNCTION | VECTOR LOCATION<br>(MEMORY ADDRESS<br>IN HEX) | DEVICE ASSIGNMENT | INTERRUPT MASK VALUE<br>TO ENABLE<br>(ST12 THROUGH ST15) | | |-------------------|----------|-----------------------------------------------|-------------------|----------------------------------------------------------|--| | 1 1 0 | Level 4 | 0 0 1 0 | External Device | 4 Through F | | | 1 0 1 | Level 3 | 0 0 0 C | External Device | 3 Through F | | | 1 0 0 | Level 2 | 0 0 0 8 | External Device | 2 Through F | | | 0 1 1 | Level 1 | 0 0 0 4 | External Device | 1 Through F | | | 0 0 1 | Reset | 0 0 0 0 | Reset Stimulus | Don't Care | | | 0 1 0 | Load | 3 F F C | Load Stimulus | Don't Care | | | 0 0 0 | Reset | 0 0 0 0 | Reset Stimulus | Don't Care | | | 1 1 1 | No-Op | | | | | FIGURE 4-TMS 9901 I/O INTERFACE SECTION FIGURE 5 - INPUT AND OUTPUT EQUIVALENTS # 2.4 Programmable Ports A total of nine pins (INT7/P15-INT15/P7) on the TMS 9901 are user-programmable as either I/O ports or interrupts. These pins will assume all characteristics of the type pin they are programmed to be (as described in Sections 2.2 and 2.3). Any pin which is not being used for interrupt should have the appropriate interrupt mask disabled (mask = 0) to avoid erroneous interrupts to the CPU. To program one of the pins as an interrupt, its interrupt mask simply is enabled and the line may be used as if it were one of the dedicated interrupt lines. To program a pin as an I/O port, disable the interrupt mask and use that pin as if it were one of the dedicated I/O ports. # 2.5 Interval Timer Figure 6 is a block diagram of the TMS 9901 interval timer section. The clock consists of a 14-bit counter that decrements at a rate of $f(\bar{\phi})/64$ (at 3 MHz this results in a maximum interval of 349 milliseconds with a resolution of 21.3 microseconds). The clock can be used as either an interval timer or an event timer. To access the clock, select bit zero (control bit) must be set to a one. The clock is enabled to cause interrupts by writing a nonzero value to it and is then disabled from interrupting by writing zero to it or by a $\overline{\rm RST}1$ . The clock starts operating at no more than two $\phi$ times after it is loaded. When the clock decrementer is running, it will decrement down to zero and issue a level-3 interrupt. The decrementer, when it becomes zero, will also be reloaded from the clock register and decrementing will start again. (The zero state is counted as any other decrementer state.) The decrementer always runs, but it will not issue interrupts unless enabled; of course, the contents of the unenabled clock read register are meaningless. FIGURE 6-TMS 9901 INTERVAL TIMER SECTION The clock is accessed by writing a one into the control bit (TMS 9901 CRU bit zero) to force CRU bits 1-15 to clock mode. Writing a nonzero value into the clock register then enables the clock and sets its time period. When the clock is enabled, it interrupts on level 3 and external level-3 interrupts are disabled. The mask for level 3 in the PSI must be set to a one so that the processor will see the clock interrupt. When the clock interrupt is active, the clock mask (mask bit 3) must be written into with either a one or zero to clear the interrupt; writing a zero also disables further interrupts. If a new clock value is required, a new 14-bit clock start value can be programmed by executing a CRU write operation to the clock register. During programming, the decrementer is restarted with the current start value after each start value bit is written. A timer restart is easily implemented by writing a single bit to any of the clock bits. The clock is disabled by $\overline{RST}1$ (power up reset) or by writing a zero value into the clock register; $\overline{RST}2$ does not affect the clock. The clock read register is updated every time the decrementer decrements when the TMS 9901 is not in clock mode. There are two methods to leave the clock mode: first, a zero is written to the control bit; or second, a TMS 9901 select bit greater than 15 is accessed. Note that when $\overline{CE}$ is inactive(HIGH), the PSI is not disabled from seeing the select lines. As the CPU is addressing memory, A10-A14 could very easily have a value of 15 or greater — A10-A14 are connected to the select lines; therefore, the TMS 9901 interval timer section can "think" it is out of clock mode and update the clock read register. Very simply, this means that a value cannot be locked into the clock read register by writing a one to CRU select bit zero (the control bit). The 9901 must be out of clock mode for at least one timer period to ensure that the contents of the clock read register has been updated. This means that to read the most recent contents of the decrementer, just before reading, the TMS 9901 must not be in the clock mode. The only sure way to manipulate clock mode is to use the control bit (select bit zero). When clock mode is reentered to access the clock read register, updating of the read register will cease. This is done so that the contents of the clock read register will not change while it is being accessed. # 2.6 Power-Up Considerations During hardware reset, $\overline{\text{RST}}$ 1 must be active (LOW) for a minimum of two clock cycles to force the TMS 9901 into a known state. $\overline{\text{RST}}$ 1 will disable all interrupts, disable the clock, program all I/O ports to the input mode, and force ICO-IC3 to all zeros with $\overline{\text{INTREQ}}$ held HIGH. The system software must enable the appropriate interrupts, program the clock, and configure the I/O ports as required. After initial power-up the TMS 9901 is accessed only as needed to service the clock, enable (disable) interrupts, or read (write) data to the I/O ports. The I/O ports can be reconfigured by use of the $\overline{\text{RST}}$ 2 software reset command bit. # 2.7 Pin Descriptions Table 4 defines the TMS 9901 pin assignments and describes the function of each pin. TABLE 4 TMS 9901 PIN ASSIGNMENTS AND FUNCTIONS | | | | TMS 9901 PIN ASSIGNMENTS AN | PUNCTIONS | | | | | | |-----------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------|--------------|------------|-------------|---------------------|--| | SIGNATURE | PIN | 1/0 | DESCRIPTION | | | | | | | | | | | INTERRUPT Request. When active (low) | | <del>ا</del> | 11 | <b>I</b> L | | | | INTREO | 11 | OUT | INTREQ indicates that an enabled interrupt | RST1 | 1 | U | 40 | Vcc | | | | - 1 | - | has been received. INTREQ will stay active | CRUOUT | 2 | | 39 | S0 | | | i | | - 1 | | CRUCLK | 3 🗓 | | 38 | PO | | | | 1 | - 1 | until all enabled interrupt inputs are re- | CRUIN | 4 🗓 | | 37 | P1 | | | | | | moved. | CE | 5 🖫 | | 36 | <b>S1</b> | | | ICO (MSB) | 15 | OUT | Interrupt Code lines, ICO-IC3 output the | ĪNT6 | 6 🗍 | | 35 | S2_ | | | IC1 | 14 | OUT | binary code corresponding to the highest | INTS | 7 🗍 | | . 34 | INT7/P15 | | | IC2 | 13 | OUT | priority enabled interrupt. If no enabled | īNT4 | 8 | | 33 | INT8/P14 | | | IC3 (LSB) | 12 | OUT | | ĪÑŦ3 | 9 🗍 | | 32 | INT9/P13 | | | CE | 5 | IN | Chip Enable. When active (low) data may be | $\overline{\phi}$ | 10 | | 31 | INT10/P12 | | | - | | | transferred through the CRU interface to | INTREO | 11 🗇 | | 30 | INT 11/P11 | | | | l | | the CPU. CE has no effect on the interrupt | IC3 | | | 29 | INT 12/P10 | | | | Ì | } | control section. | IC2 | -41 | | 28 | INT 13/P9 | | | | 39 | IN | Address select lines. The data bit being | IC1 | ~l | | 27 | INT 14/P8 | | | SO | 36 | IN | accessed by the CRU interface is specified | | 15 | | 26 | P2 | | | S1 | 35 | IN | by the 5-bit code appearing on S0-S4. | Vss | | | 25 | S3 | | | S2 | 25 | IN | by the 3-bit cods appearing | VSS<br>INT1 | | | 24 | S4 | | | S3 | | IN | | īNT2 | - di | | 23 | INT 15/P7 | | | S4 | 24 | 1 | CDUN Does especified by | | -11 | | 22 | P3 | | | CRUIN | 4 | דטס | CRU data in (to CPU). Data specified by | P6 | - 1 | | 21 | P4 | | | | 1 | | S0-S4 is transmitted to the CPU by CRUIN. | P5 | 20 | | _P | | | | | | | When CE is not active CRUIN is in a high- | | | | | | | | | 1 | 1 | impedance state. | | aha CB | UOUT in | النبعب جييد | he sampled durin | | | CRUOUT | 1 2 | IN | CRU data out (from CPU). When CE is active, | data present or | i the Ch | 0001 111 | JUL **** | DC 00.11.p.10- | | | 0 | | İ | COLICI K and written into the command bit spec | tied by 50-54. | | | | | | | CRUCLK | 3 | IN | CRUCION (from CRUI) CRUCI K specifies that | alid data is prese | ent on the | CRUOU | line. | | | | | 1 | 1 | 1 DOT1 | m all interrupt r | macke to | "O". reset | s ICO - | - IC3 = (0, 0, 0, 0 | | | AST1 | 1 | 1 IN Power Up Reset. When active (Iow) RST1 resets all interrupt masks to "0", resets ICO – IC3 = (0, 0, 0, 0, 0) INTERO = 1, disables the clock, and programs all I/O ports to inputs. RST1 has a Schmitt-triger input | | | | | | | | | | | | allow implementation with an RC circuit as show | n in Figure 7. | | | | | | | | 1 | 1 | Supply Voltage. +5 V nominal. | | | | | | | | Vcc | 40 | 1 | 1 | | | | | | | | ٧ <sub>SS</sub> | 16 | 1 | Ground Reference | - TARE 0000 ever | tem) | | | | | | ō | 10 | IN | System clock (\$\overline{\phi}\$3 in TMS 9900 system, \$\overline{\color}\$CKOUT | U LINIO BEOD 3931 | terry. | | | | | | INT1 | 17 | IN | h | | | | | | | | INT2 | 18 | IN | Group 1, interrupt inputs. | | | | | | | | īNT3 | 9 | | Il when active (I ow) the signal is ANDed with its | corresponding | | | | | | | INT4 | 8 | • | mask bit and if enabled sent to the interrupt con | ntrol section. | | | | | | | INT5 | 7 | 1 | INT1 has highest priority. | | | | | | | | INT6 | é | 1 | tiet i viss ingress pro- | | | | | | | | INT7/ P15 | 34 | l l | , K | | | | | | | | INT8/ P14 | 33 | 1 | 11 | | | | | | | | INT9/ P13 | 32 | | ı <b>II</b> | | | | | | | | INT10/P12 | 31 | | 11 | or I/O pine (true | Indic) F | ch pin is | individu | ally programmable | | | INT11/P11 | 30 | | Group 2, programmable interrupt (active low) | or 1/O pins (tide | Jugici. | p | | | | | | 25 | | Il se interrupt an innut port, of an output port. | | | | | | | | INT12/P10 | 28 | | 11 | | | | | | | | INT 13/P9 | 2 | | 1) | | | | | | | | INT14/P8 | 2 | 1 | 11 | | | | | | | | INT 15/P7 | - 1 | · | K | | | | | | | | PO | 3 | | 13 | | | | | | | | P1 | 3 | | 11 | | | | | | | | P2 | 2 | · . | 1 | idually program | mable as | an input p | ort or a | n output port. | | | 00 | 2 | | | nasan, program | | | | | | | Р3 | | | 5 II | | | | | | | | P3<br>P4 | 2 | 1 . | 17 | | | | | | | | | 2 2 | 1 | o | | | | | | | # 3. APPLICATIONS # 3.1 Hardware Interface Figure 7 illustrates the use of a TMS 9901 PSI in a TMS 9900 system. The TIM 9904 clock generator/driver syncs the RESET for both the TMS 9901 and the CPU. The RC circuit on the TIM 9904 provides the power-up and pushbutton RESET input to the clock chip. Address lines A0-A9 are decoded on CRU cycles to select the TMS 9901. Address lines A10-A14 are sent directly to PSI select lines S0-S4, respectively, to select which TMS 9901 CRU bit is to be accessed. Figure 8 illustrates the use of a TMS 9901 with a TMS 9981 CPU. No TIM 9904 is needed with the TMS 9981, so the reset circuitry is connected directly to the system reset line. The clock $(\overline{\phi})$ then comes from the TMS 9981. All other circuitry is identical to the TMS 9900 system. FIGURE 7-TMS 9900/TMS 9901 INTERFACE FIGURE 8-TMS 9981/TMS 9901 INTERFACE # 3.2 Software Interface Figure 9 lists the TMS 9900 code needed to control the TMS 9901 PSI. The code initializes the PSI to an eight-bit input port, an eight-bit output port, and enables interrupt levels 1-6. The six dedicated interrupt pins are all used for interrupts; their mask bits are set ON. The nine programmable pins are all used as I/O ports; mask bits 7-15 remain reset. P0-P7 are programmed as an eight-bit output port, and P8-P15 are programmed as an eight-bit input port. Some code is added to read the contents of the clock read-register. The SBZ instruction takes the TMS 9901 out of clock mode long enough for the clock read register to be updated with the most recent decrementer value. When clock mode is reentered, the decrementer will cease updating the clock read-register so that the contents of the register will not be changing during a read operation. The second section of code is typical code found in a clock interrupt service routine. All interrupts initially are disabled by the routine. These functions are not necessary, but are usually done to ensure system integrity. The interrupt mask should be restored as soon as the sensitive processing is complete. The interrupt is counted in the variable COUNT and is then cleared by writing a one to mask bit 3. If a zero is written to mask bit 3 to clear the interrupt, clock interrupt will be disabled from that point onward, but the clock will continue to run. # ASSUMPTION: - System uses clock at maximum interval (349 msec @ 3MHz) - Interrupts 1-6 are used - Eight bits are used as an output port , P0 -P7 - ullet Eight bits are used as an input port , P8 P15 - RST1 (power-up reset) has been applied - The most significant byte of R1 contains data to be output. | | LI<br>LDCR | R12, PSIBAS<br>@CLKSET, 0 | Set up CRU base to point to 9901<br>16-bit transfer, set clock to max interval | |------------------|---------------------------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | LDCR | @INTSET, 7 | Enter interrupt mode and enable interrupts $1 - 6$ | | | LI<br>LDCR | R12, PSIBAS+32<br>R1, 8 | Set CRU base to I/O ports — output Output byte from R1, program ports $0-7$ as output | | | LI<br>STCR | R12, PSIBAS+48<br>R2, 8 | Set CRU base to I/O ports — input<br>Store a byte from input port into MSBT of R2 | | | LI<br>SBZ<br>INCT<br>SBO<br>STCR | R12, PSIBAS<br>0<br>R12<br>-1<br>R3, 14 | Set CRU base to 9901 Leave clock mode so decremented contents can be latched Set CRU base to clock read register Enter clock mode Read 14-bit clock read register contents into R3 | | CLKSET<br>INTSET | DATA<br>BYTE | >FFFF<br>>7E | | | CLKINT | \$<br>LIMI<br>INC<br>LI<br>SBZ<br>SBO | 0<br>@COUNT<br>R12, PSIBAS<br>0<br>3 | Clock interrupt service routine — level 3 Disable interrupts at CPU Count the clock interrupt Set CRU base to point to 9901 Enter interrupt mode Clear clock interrupt | FIGURE 9 - TMS 9900 SAMPLE SOFTWARE TO CONTROL THE TMS 9901 # 3.3 Interval Timer Application A TM 990/100M microcomputer board application in which every 10 seconds a specific task must be performed is described below. The TMS 9901 clock is set to interrupt every 333.33 milliseconds. This is accomplished by programming the 14-bit clock register to 3D09<sub>16</sub> (15,625<sub>10</sub>). The TM 990/100M microcomputer board system clock runs at 3 MHz, giving a clock resolution of 21.33 microseconds. A decrementer period of 21.33 microseconds multiplied by 15,625 periods until interrupt gives 333.33 milliseconds between interrupts. The interrupt service routine must count 30 interrupts before 10 seconds elapses: $$f(DEC) = \frac{f(\phi)}{64}$$ , $T(DEC) = \frac{1}{f(DEC)} = \frac{64}{3,000,000} = 21.3333 \,\mu s$ Figure 10 is a flowchart of the software required to perform the above application, and Figure 11 is a listing of the code. Following the flowchart, the main routine sets up all initial conditions for the 9901 and clock service routine. The interrupt service routine decrements a counter in R2 which was initialized to 30. When the counter in R2 decrements to zero, 10 seconds have elapsed, and the work portion of the service routine is entered. Note carefully that the work portion of the service routine takes longer than 333.33 ms which is the time between clock interrupts from the 9901. Therefore, recursive interrupts are going to occur and some facility must be provided to handle them. Loading a new workspace pointer and transferring the saved WP, PC, and ST (R13-R15) from the interrupt workspace to the new workspace allows one level of recursion. FIGURE 10-TMS 9901 INTERVAL TIMER APPLICATION FLOWCHART # DEVICE INITIALIZATION | A800 02E0 LWPI >FF20 | | |------------------------|----------------------------| | FE02 FF20 | | | FE04 0200 LI R12∙>100 | 9901 CRU BASE ADDRESS | | FE06 U100 | | | FE08 02E0 LWPI >FF68 | INTERRUPT 3 WORKSPACE | | FEOA FF68 | | | FEOC 0201 LI R1,>7813 | DATA FOR 333.33MS CLOCK | | FE0E 7A13 | | | FE10 0202 LI R2•30 | 30 K 333.33MS = 10SEC | | FE12 001E | | | FE14 0200 LI R12•>100 | 3301 CBO BHZE HTDME22 | | FE16 0100 | | | FE18 3301 LDCR R1•15 . | | | FE1A 1E00 3BZ 0 | SET 9901 TO INTERRUPT MODE | | FE1C 1D03 SBB 3 | UMMASK INTERRUPT 3 | | | | # MAIN PROGRAM | FD00 02E0 LWPI >FF00 | MAIN PROGRAM WORKSPACE | |----------------------|------------------------| | FDU2 FF00 | | | FD04 0300 L1MI 3 | EMABLE INT 0-3 | | FD06 0003 | | NOTE: This code was assembled using the TM 990/402 line-by-line assembler. FIGURE 11-INTERVAL TIMER # INTERRUPT 3 SERVICE ROUTINE (WP = FF68) # ROUTINE TO BE PERFORMED EVERY 10 SECONDS, IT TAKES LONGER THAN 333.33 MS WHICH IS 9901 CLOCK PERIOD' ``` FC80 02E0 LWPI >FF20 WORKSPACE FOR SUBPOUTINE FC82 FF20 FC84 C360 MOV @>FF82,R13 TRANSFER SAVED WP.PC.ST FROM FC86 FF82 FC88 C3A0 MOV @>FF84,R14 INT 3 WORKSPACE FC8A FF84 FC8C C3E0 MOV @>FF86,R15 FC8E FF86 FC90 1D03 SBO 3 CLEAR 9901 ULOCK INTERRUPT FC92 0300 LIMI 3 ENABLE INT 0-3 FC94 0003 ``` ₱€00 RTWP FIGURE 11-(CONCLUDED) # 4. TMS 9901 ELECTRICAL SPECIFICATIONS # 4.1 Absolute Maximum Ratings Over Operating Free Air Temperature Range (Unless Otherwise Noted)\* | Supply voltage, VCC | 0.3 V to 10 V | |--------------------------------------|---------------| | All inputs and output voltages | 0.3 V to 10 V | | All inputs and output voltages | 0.85 W | | Continuous power dissipation | 0.00 to 7000 | | Operating free-air temperature range | 0 6 10 70 6 | | Storage temperature range | 65°C to 150°C | <sup>&</sup>quot;Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute maximum rated conditions for extended periods may affect device reliability. # 4.2 Recommended Operating Conditions\* | PARAMETER | MIN | NOM | MAX | UNIT | |---------------------------------------------------|-------------------|-----|------|------| | | 4.75 | 5.0 | 5.25 | ٧ | | Supply voltage, VCC | | 0 | | ٧ | | Supply voltage, VSS High-level input voltage, VIH | 2.0 | | Vcc | ٧ | | Low-level input voltage, V <sub>IL</sub> | V <sub>SS</sub> 3 | | 0.8 | ٧ | | Operating free-air temperature, T <sub>A</sub> | 0 | | 70 | °C | # 4.3 Electrical Characteristics Over Full Range of Recommended Operating Conditions (Unless Otherwise Noted) \* | | PARAMETER | TEST CONDITIONS | MIN | TYP MAX | UNIT | |---------|---------------------------------------------|-------------------------------------------------------------|-----|---------|------| | | | I <sub>OH</sub> = -100 μA | 2.4 | Vcc | V | | Vон | High level output voltage | I <sub>OH</sub> = -200 μA | 2.2 | VCC | ٧ | | VOL | Low level output voltage | I <sub>OL</sub> = 3.2 mA | VSS | 0.4 | V | | li li | Input current (any input) | V <sub>I</sub> = 0 V to V <sub>CC</sub> | | ±100 | μA | | ICC(av) | Average supply current from V <sub>CC</sub> | $t_{c}(\phi) = 330 \text{ ns.} T_{A} = 70^{\circ}\text{C}$ | | 150 | mA | | Cı | Small signal input capacitance, any input | f = 1 MHz | | 15 | pF | # 4.4 Timing Requirements Over Full Range of Operating Conditions | | PARAMETER | MIN | TYP | MAX | UNIT | |----------------------------------------|---------------------------------------------------|-----|-----|------|------| | terr | Clock cycle time | 300 | 333 | 2000 | ns | | <sup>t</sup> c(φ) | Clock rise time | 5 | | 40 | ns | | t <sub>r(φ)</sub> t <sub>f(φ)</sub> | Clock fall time | 10 | | 40 | ns | | <sup>1</sup> (φ)<br><sup>t</sup> w(φH) | Clock pulse width (high level) | 225 | | | ns | | tw(φΠ) | Clock pulse width (low level) | 45 | | 300 | ns | | tw(CC) | CRUCLK pulse width | 100 | 185 | | ns | | t <sub>su1</sub> | Setup time for CE, S0-S4, or CRUOUT before CRUCLK | 100 | | | ns | | tsu2 | Setup time for interrupt before $ar{\phi}$ low | 60 | | | ns | | t <sub>su3</sub> | Setup time for inputs before valid CRUIN | 200 | | | ns | | th | Hold time for CE, S0-S4, or CRUOUT after CRUCLK | 60 | | | ns | <sup>\*</sup>NOTE: All voltage values are referenced to V<sub>SS</sub>. # 4.5 Switching Characteristics Over Full Range of Recommended Operating Conditions | | PARAMETER | TEST CONDITION | MIN | TYP | MAX | UNIT | |------------------|------------------------------------------------------|-------------------------|--------------------------------------------------|-----|-----|------| | <sup>t</sup> pd1 | Propagation delay, CE to valid CRUIN | C <sub>I</sub> = 100 pF | <del> </del> | | 300 | ns | | tpd2 | Propagation delay, S0-S4 to valid CRUIN | C <sub>I</sub> = 100 pF | | | 320 | ns | | tpd3 | Propagation delay, | C <sub>1</sub> = 100 pF | | | 110 | ns | | <sup>t</sup> pd | Propagation delay, CRUCLK to valid data out (P0-P15) | C <sub>L</sub> = 100 pF | | | 300 | ns | NOTE 1. ALL TIMING MEASUREMENTS ARE FROM 10%, and 90% POINTS FIGURE 12-SWITCHING CHARACTERISTICS # 5. MECHANICAL DATA # 5.1 TMS 9901 JL — 40 Pin Ceramic Package ceramic packages with side-brazed leads and metal or epoxy or glass lid seal # 5.2 TMS 9901 NL - 40 Pin Plastic Package #### plastic packages 2.090 (53,1) MAX **40** ◆ EITHER-()———( 20) \_0.600 · 0.010 \_(15,24 · 0,26) 0.020 (0,51) MIN 0.200 (5,08) MAX 0.125 (3,17) MIN 0.011 - 0.003 0.018 ± 0.003 <u></u> (0,457 ± 0,076) (0,279 · 0,076) 0.033 (0,84) MIN PIN SPACING 0.100 (2,54) T.P. -- 0.095 (2,42) 0.055 (1,39) (See Note) 0.060 (1,52) NOM NOTE: Each pin centerline is located within 0.010 (2,54) of its true longitudinal position. PINS 8 DIM 16 18 20 A · 0.010 (0,26) 0.300 (7,62) 0.300 (7,62) 0.300 (7,62) 0.300 (7,62) 0.600 (15,24) | 0.600 (15,24) | 0.600 (10,24) 0.400 (10,16) B MAX 0.390 (9,9) 0.870 (22,1) 0.920 (23,4) 1 070 (27,2) 1 100 (28.0) 1.290 (32.8) 1 440 (36,6) 2 090 (53.1) C NOM 0.250 (6,4) 0.250 (6,4) 0.250 (6,4) 0.265 (6,7) 0.350 (8.9) 0.550 (14,0) 0.550 (14,0) 0.550 (14.0) # APPENDIX F The Engineering Staff of TEXAS INSTRUMENTS INCORPORATED Semiconductor Group # TMS 9902 ASYNCHRONOUS COMMUNICATIONS CONTROLLER DATA MANUAL **JULY 1978** TEXAS INSTRUMENTS # TABLE OF CONTENTS | 1. | INTE | RODUCTION | | 1 | |----|------|---------------|---------------------------------------------------------|----| | | 1.1 | Description | | 1 | | | 1.2 | Key Features | · · · · · · · · · · · · · · · · · · · | 1 | | | 1.3 | Typical Appli | cation | ' | | 2. | ARC | HITECTURE | | 2 | | | 2.1 | CRU Interfac | | 5 | | | | 2.1.1 | CPU Output for CRU | 8 | | | | 2.1.2 | Registers | 8 | | | | 2.1.2.1 | Control Register | 10 | | | | 2.1.2.2 | Interval Register | 10 | | | | 2.1.2.3 | December 1 1919 Hate Register | - | | | | 2.1.2.4 | Transmit Data Rate Register | 11 | | | | 2.1.2.5 | Transmit Buffer Register | 13 | | | | 2.1.3 | Input to CPU for CRU | 16 | | | 2.2 | | Oneration | 16 | | | | 2.2.1 | | 16 | | | | 2.2.2 | | 16 | | | | 2.2.3 | | 18 | | | 2.3 | | eration | 18 | | | | 2.3.1 | | 18 | | | | 2.3.2 | Start Bit Detection Data Reception Data Reception | 18 | | | | 2.3.3 | er Operation | 20 | | | 2.4 | Interval I im | er Operation | 21 | | | 2.5 | Interrupts | erminal Assignments and Functions | 22 | | | 2.6 | IMS 9902 I | erminal Assignments and Functions | | | 3. | DE | VICE APPLIC | ATION | 23 | | | 3.1 | | alization | 23 | | | | 3.1.1 | Initialization Program | 24 | | | | 3.1.2 | Control Register | 24 | | | | 3.1.3 | Interval Register Receive Data Rate Register | 24 | | | | 3.1.4 | Receive Data Hate Hegister Transmit Data Rate Register | 25 | | | | 3.1.5 | Transmit Data Rate Register | 25 | | | 3.2 | Data Transi | mission | 26 | | | 3.3 | Data Recep | otion | 26 | | | 3.4 | Register Lo | ading After Initialization | 27 | | | 3.5 | | a Data Terminal | 27 | | | | 3.5.1 | | 27 | | | | 3.5.2 | Software | | | 4.1<br>4.2<br>4.3<br>4.4<br>4.5 | 9902 ELECTRICAL SPECIFICATIONS Absolute Maximum Ratings Over Operating Free Air Temperature Range (Unless Otherwise Noted) Recommended Operating Conditions 31 Electrical Characteristics Over Full Range of Recommended Operating Conditions (Unless Otherwise Noted) 31 Timing Requirements Over Full Range of Operating Conditions 31 Switching Characteristics Over Full Range of Recommended Operating Conditions 32 HANICAL SPECIFICATIONS | |----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | LIST OF ILLUSTRATIONS | | Figure 1 Figure 2 Figure 3 Figure 4 Figure 5 Figure 6 Figure 7 Figure 8 Figure 9 | Typical Application, TMS 9902 Asynchronous 2 Communication Controller (ACC) 2 TMS 9902 Asynchronous Communications Controller (ACC) Block Diagram 3 TMS 9902 — TMS 9900 CRU Interface 4 TMS 9902 — TMS 9981 CRU Interface 4 TMS 9902 Transmitter Operation 17 TMS 9902 Receiver Operation 19 TMS 9902 Interval Timer Operation 20 INT Output Generation 21 Interface to a 733 Data Terminal 28 | | | LIST OF TABLES | | Table 1 Table 2 Table 3 Table 4 Table 5 Table 6 Table 7 | TMS 9902 ACC Output Bit Address Assignments 5 TMS 9902 ACC Register Load Selection 7 Control Register Bit Address Assignments 8 CRU Output Bit Address Assignments 12 TMS 9902 ACC Input Bit Address Assignments 13 TMS 9902 Interrupt Clearing 13 TMS 9902 Software 20 | # 1. INTRODUCTION ## 1.1 DESCRIPTION The TMS 9902 Asynchronous Communications Controller (ACC) is a peripheral device designed for use with the Texas Instruments 9900 family of microprocessors. The TMS 9902 is fabricated using N-channel, silicon gate, MOS technology. The TMS 9902 is TTL-compatible on all inputs and outputs, including the power supply (+5 V) and single-phase clock. The TMS 9902 ACC provides an interface between a microprocessor and a serial, asynchronous, communications channel. The ACC performs the timing and data serialization and deserialization functions, facilitating microprocessor control of the asynchronous channel. The TMS 9902 ACC accepts *EIA Standard RS-232-C* protocol. # 1.2 KEY FEATURES - Low Cost, Serial, Asynchronous Interface - Programmable, Five- to Eight-Bit, I/O Character Length - Programmable 1, 1½, and 2 Stop Bits - Even, Odd, or No Parity - Fully Programmable Data Rate Generation - Interval Timer with Resolution from 64 to 16,320 Microseconds - TTL-Compatibility, Including Power Supply - Standard 18-Pin Plastic or Ceramic Package - N-Channel, Silicon Gate Technology # 1.3 TYPICAL APPLICATION Figure 1 shows a general block diagram of a system incorporating a TMS 9902 ACC. Following is a tutorial discussion of this application. Subsequent sections of this Data Manual detail most aspects of TMS 9902 use. The TMS 9902 interfaces with the CPU through the *communications register unit* (CRU). The CRU interface consists of five address select lines (S0-S4), chip enable (CE), and three CRU lines (CRUIN, CRUOUT, CRUCLK). An additional input to the CPU is the ACC interrupt line (INT). The TMS 9902 occupies 32 bits of CRU space; each of the 32 bits are selected individually by processor address lines A10-A14 which are connected to the ACC select lines S0-S4, respectively. Chip enable (CE) is generated by decoding address lines A0-A9 for CRU cycles. Under certain conditions the TMS 9902 causes interrupts. The interrupt logic shown in Figure 1 can be a TMS 9901. The ACC interfaces to the asynchronous communications channel on five lines: request to send $(\overline{RTS})$ , data set ready $(\overline{DSR})$ , clear to send $(\overline{CTS})$ , serial transmit data (XOUT), and serial receive data (RIN). The request to send $(\overline{RTS})$ goes active (LOW) whenever the transmitter is activated. However, before data transmission begins, the clear to send $(\overline{CTS})$ input must be active. The data set ready $(\overline{DSR})$ input does not affect the receiver or transmitter. When $\overline{DSR}$ or $\overline{CTS}$ changes level, an interrupt is generated. FIGURE 1. TYPICAL APPLICATION, TMS 9902 ASYNCHRONOUS COMMUNICATION CONTROLLER (ACC) # 2. ARCHITECTURE The TMS 9902 asynchronous communications controller (ACC) is designed to provide a low cost, serial, asynchronous interface to the 9900 family of microprocessors. The TMS 9902 ACC is diagrammed in Figure 2. The ACC has five main subsections: CRU interface, transmitter section, receiver section, interval timer, and interrupt section. # 2.1 CRU INTERFACE The communications register unit (CRU) is the means by which the CPU communicates with the TMS 9902 ACC. The ACC occupies 32 bits of CRU read and write space. Figure 3 illustrates the CRU interface between a TMS 9902 and a TMS 9900 CPU; Figure 4 illustrates the CRU Interface for a TMS 9980A or 9981 CPU. The CRU lines are tied directly to each other as shown in Figures 3 and 4. The least significant bits of the address bus are connected to the select lines. In a TMS 9900 CPU system A14-A10 are connected to S4-S0 respectively. The most significant address bits are decoded to select the TMS 9902 via the chip enable $\overline{(CE)}$ signal. When $\overline{CE}$ is inactive (HIGH), the CRU interface of the 9902 is disabled. # NOTE When $\overline{\text{CE}}$ is inactive (HIGH) the 9902 sets its CRUIN pin to high impedance and disables CRUCLK from coming on chip. This means the CRUIN line can be used as an OR-tied bus. The 9902 is still able to see the select lines even when $\overline{\text{CE}}$ is high. For those unfamiliar with the CRU concept, the following is a discussion of how to build a CRU interface. The CRU is a bit addressable (4096 bits), synchronous, serial interface over which a single instruction can transfer between one and 16 bits serially. Each one of the 4096 bits of the CRU space has a unique address and can be read and written to. During multi-bit CRU transfers, the CRU address is incremented at the beginning of each CRU cycle to point to the next consecutive CRU bit. FIGURE 2. TMS 9902 ASYNCHRONOUS COMMUNICATIONS CONTROLLER (ACC) BLOCK DIAGRAM FIGURE 3. TMS 9902 - TMS 9900 CRU INTERFACE FIGURE 4. TMS 9902 - TMS 9980A OR 9981 CRU INTERFACE When a 99XX CPU executes a CRU Instruction, the processor uses the contents of workspace register 12 as a base address. (Refer to the 9900 Microprocessor Data Manual for a complete discussion on how CRU addresses are derived.) The CRU address is brought out on the 15-bit address bus; this means that the least significant bit of R12 is not brought out of the CPU. During CRU cycles, the memory control lines (MEMEN, WE, and DBIN) are all inactive; MEMEN being inactive (HIGH) indicates the address is not a memory address and therefore is a CRU address or external instruction code. Also, when MEMEN is inactive (HIGH) and a valid address is present, address bits A0-A2 must all be zero to constitute a valid CRU address; if address bits A0-A2 are other than all zeros, they are indicating an external instruction code. In summary, address bits A3-A14 contain the CRU address to be decoded, address bits A0-A2 must be zero and MEMEN must be inactive (HIGH) to indicate a CRU cycle. # 2.1.1 CPU OUTPUT FOR CRU The TMS 9902 ACC occupies 32 bits of output CRU space, of which 23 bits are used: 31 and 21-0. These 23 bits are employed by the CPU to communicate command and control information to the TMS 9902. Table 1 shows the mapping between CRU address select (S lines) and ACC functions. Each CRU addressable output bit on the TMS 9902 is described in detail following Table 1. TABLE 1 TMS 9902 ACC OUTPUT SELECT BIT ASSIGNMENTS | ADDRESS <sub>2</sub><br>S0 S1 S2 S3 S4 | ADDRESS <sub>10</sub> | NAME | DESCRIPTION | |----------------------------------------|-----------------------|--------|-----------------------------------------------------------| | 1 1 1 1 1 | 31 | RESET | Reset device. | | | 30-22 | | Not used. | | 1 0 1 0 1 | 21 | DSCENB | Data Set Status Change Interrupt Enable. | | 1 0 1 0 0 | 20 | TIMENB | Timer Interrupt Enable | | 1 0 0 1 1 | 19 | XBIENB | Transmitter Interrupt Enable | | 1 0 0 1 0 | 18 | RIENB | Receiver Interrupt Enable | | 1 0 0 0 1 | 17 | BRKON | Break On | | 1 0 0 0 0 | 16 | RTSON | Request to Send On | | 0 1 1 1 1 | 15 | TSTMD | Test Mode | | 0 1 1 1 0 | 14 | LDCTRL | Load Control Register | | 0 1 1 0 1 | 13 | LDIR | Load Interval Register | | 0 1 1 0 0 | 12 | LRDR | Load Receiver Data Rate Register | | 0 1 0 1 1 | 11 | LXDR | Load Transmit Data Rate Register | | | 10-0 | | Control, Interval, Receive Data Rate, Transmit Data Rate, | | | | | and Transmit Buffer Registers | Bit 31 (RESET) - **Reset.** Writing a one or zero to bit 31 causes the device to reset, consequently disabling all interrupts, initializing the transmitter and receiver, setting $\overline{\text{RTS}}$ inactive (HIGH), setting all register load control flags (LDCTRL, LDIR, LRDR, and LXDR) to a logic one level, and resetting the BREAK flag. No other input or output operations should be performed for 11 $\overline{\phi}$ clock cycles after issuing the RESET command. Bit 30-Bit 22 --- Not used. | INTERRUPT<br>ENABLE | SELECT<br>BIT | INTERRUPT<br>FLAG | INTERRUPT<br>ENABLED | |---------------------|---------------|-------------------|----------------------| | DSCENB | 21 | DSCH | DSCINT | | TIMENB | 20 | TIMELP | TIMINT | | XIENB | 19 | XBRE | XINT | | RIENB | 18 | RBRL | RINT | | Bit 21 | (DSCENB) | | |--------|----------|--| |--------|----------|--| Data Set Change Interrupt Enable. Writing a one to bit 21 causes the INT output to be active (LOW) whenever DSCH (Data Set Status Change) is a logic one. Writing a zero to bit 21 causes DSCH interrupts to be disabled. Writing either a one or zero to bit 21 causes DSCH to reset. (Refer also to Section 2.5). # Bit 20 (TIMENB) --- **Timer Interrupt Enable.** Writing a one to bit 20 causes the $\overline{\text{INT}}$ output to be active whenever TIMELP (Timer Elapsed) is a logic one. Writing a zero to bit 20 causes TIMELP interrupts to be disabled. Writing either a one or zero to bit 20 causes TIMELP and TIMERR (Timer Error) to reset. (Refer also to Sections 2.4 and 2.5.) # Bit 19 (XBIENB) - **Transmit Buffer Interrupt Enable.** Writing a one to bit 19 causes the INT output to be active whenever XBRE (Transmit Buffer Register Empty) is a logic one. Writing a zero to bit 19 causes XBRE interrupts to be disabled. The state of XBRE is not affected by writing to bit 19. (Refer also to Sections 2.2 and 2.5.) ## Bit 18 (RIENB) - Receiver Interrupt Enable. Writing a one to bit 18 causes the INT output to be active whenever RBRL (Receiver Buffer Register Loaded) is a logic one. Writing a zero to bit 18 disables RBRL interrupts. Writing either a one or zero to bit 18 causes RBRL to reset. (Refer also to Sections 2.3 and 2.5.) ## Bit 17 (BRKON) - **Break On.** Writing a one to bit 17 causes the XOUT (Transmitter Serial Data Output) to go to a logic zero whenever the transmitter is active and the Transmit Buffer Register (XBR) and the Transmit Shift Register (XSR) are empty. While BRKON is set, loading of characters into the XBR is inhibited. Writing a zero to bit 17 causes BRKON to reset and the transmitter to resume normal operation. # Bit 16 (RTSON) --- **Request To Send On.** Writing a one to bit 16 causes the $\overline{\text{RTS}}$ output to be active (LOW). Writing a zero to bit 16 causes $\overline{\text{RTS}}$ to go to a logic one after the XSR (Transmit Shift Register) and XBR (Transmit Buffer Register) are empty, and BRKON is reset. Thus, the $\overline{\text{RTS}}$ output does not become inactive (HIGH) until after character transmission is completed. # Bit 15 (TSTMD) --- Test Mode. Writing a one to bit 15 causes $\overline{RTS}$ to be internally connected to $\overline{CTS}$ , XOUT to be internally connected to RIN, $\overline{DSR}$ to be internally held LOW, and the Interval Timer to operate 32 times its normal rate. Writing a zero to bit 15 re-enables normal device operation. There seldom is reason to enter the test mode under normal circumstances, but this function is useful for diagnostic and inspection purposes. # Bits 14-11 --- Register Load Control Flags. Output bits 14-11 control which of the five registers are loaded when writing to bits 10-0. The flags are prioritized as shown in Table 2. TABLE 2 TMS 9902 ACC REGISTER LOAD SELECTION | | REGI | CONTROL FL | REGISTER ENABLED | | |------|--------|------------|------------------|-------------------------------| | LDIR | LDCTRL | LRDR | LXDR | | | × | 1 | × | X | Control Register | | 1 | 0 | l x | × | Interval Register | | 0 | 0 | 1 1 | x | Receive Data Rate Register * | | 0 | 0 | l x | 1 1 | Transmit Data Rate Register * | | 0 | 0 | 0 | 0 | Transmit Buffer Register | <sup>&</sup>quot;If both LRDR and LXDR bits are set, both registers are loaded, assuming LDCTRL and LDIR are disabled; if only one of these registers is to be loaded, only that register bit is set, and the other register bit reset. Bit 14 (LDCTRL) - Load Control Register. Writing a one to bit 14 causes LDCTRL to be set to a logic one. When LDCTRL = 1, any data written to bits 0-7 is directed to the Control Register. Note that LDCTRL is also set to a logic one when a one or zero is written to bit 31 (RESET). Writing a zero to bit 14 causes LDCTRL to reset to a logic zero, disabling loading of the Control Register. LDCTRL is also automatically reset to logic zero when a datum is written to bit 7 of the Control Register, reset normally occurs as the last bit is written when loading the Control Register with a LDCR instruction. Bit 13 (LDIR) --- Load Interval Register. Writing a one to bit 13 causes LDIR to set to a logic one. When LDIR = 1 and LDCTRL = 0, any data written to bits 0-7 is directed to the Interval Register. Note that LDIR is also set to a logic one when a datum is written to bit 31 (RESET); however, Interval Register loading is not enabled until LDCTRL is set to a logic zero. Writing a zero to bit 13 causes LDIR to be reset to logic zero, disabling loading of the Interval Register. LDIR is also automatically reset to logic zero when a datum is written to bit 7 of the Interval Register; reset normally occurs as the last bit is written when loading the Interval Register with a LDCR instruction. Bit 12 (LRDR) --- **Load Receive Data Rate Register.** Writing a one to bit 12 causes LRDR to set to a logic one. When LRDR = 1, LDIR = 0, and LDCTRL = 0, any data written to bits 0-10 is directed to the Receive Data Rate Register. Note that LRDR is also set to a logic one when a datum is written to bit 31 (RESET); however, Receive Data Rate Register loading is not enabled until LDCTRL and LDIR are set to a logic zero. Writing a zero bit to 12 causes LRDR to reset to a logic zero, disabling loading of the Receive Data Rate Register. LRDR is also automatically reset to logic zero when a datum is written to bit 10 of the Receive Data Rate Register; reset normally occurs as the last bit is written when loading the Receive Data Rate Register with a LDCR instruction. Bit 11 (LXDR) -- Load Transmit Data Rate Register. Writing a one to bit 11 causes LXDR to set to a logic one. When LXDR = 1, LDIR = 0, and LDCTRL = 0, any data written to bits 0-10 is directed to the Transmit Data Rate Register. Note that loading of both the Receive and Transmit Data Rate Registers is enabled when LDCTRL = 0, LDIR = 0, LRDR = 1, and LXDR = 1; thus these two registers may be loaded simultaneously when data is received and transmitted at the same rate. LXDR is also set to a logic one when a datum is written to bit 31 (RESET); however, Transmit Data Rate Register loading is not enabled until LDCTRL and LDIR are to logic zero. Writing a zero to bit 11 causes LXDR to reset to logic zero, consequently disabling loading of the Transmit Data Rate Register. Since bit 11 is the next bit addressed after loading the Transmit Data Rate Register, the register may be loaded and the LXDR flag reset with a single LDCR instruction where 12 bits (Bits 0-11) are written and a zero is written to Bit 11. Bits 14-11 (All Zeros) — Load Transmit Buffer Register. See Section 2.1.2.5. Bits 10-0 (Data) — Data. Information written to bits 10-0 is loaded into the controlling registers as indicated by LDCTRL, LDIR, LRDR, and LXDR (see Table 2). The different register bits are described in Section 2.1.2 below. # 2.1.2 REGISTERS # 2.1.2.1 Control Register The Control Register is loaded to select character length, device clock operation, parity, and the number of stop bits for the transmitter; control register loading occurs when LDCTRL is active (see Table 2). Table 3 shows the bit address assignments for the Control Register. TABLE 3 CONTROL REGISTER BIT ADDRESS ASSIGNMENTS | 7 | SBS1 | <del></del> | | |---|-------|-------------------------|--| | | 3531 | 0. 0.01 | | | 6 | SBS2 | Stop Bit Select | | | 5 | PENB | Parity Enable | | | 4 | PODD | Odd Parity Select | | | 3 | CLK4M | ₱ Input Divide Select | | | 2 | | Not Used | | | 1 | RCL1 | | | | 0 | RCL0 | Character Length Select | | 7 6 5 4 3 2 1 0 SBSI SBS2 PENB PODD CLK4M NOT USED RCL1 RCL0 MSB LSB Bits 7 and 6 (SBS1 and SBS2) — **Stop Bit Selection.** The number of stop bits to be appended to each transmitter character is selected by bits 7 and 6 of the Control Register as shown below. The receiver only tests for a single stop bit, regardless of the status of bits 7 and 6. STOP BIT SELECTION | SBS1<br>BIT 7 | SBS2<br>BIT 6 | NUMBER OF TRANSMITTED<br>STOP BITS | |---------------|---------------|------------------------------------| | 0 | 0 | 1% | | 0 | 1 | 2 | | 1 | 0 | 1 | | 1 | 1 | 1 | Bits 5 and 4 (PENB and PODD) — Parity Selection. The type of parity generated for transmission and detected for reception is selected by bits 5 and 4 of the Control Register as shown below. When parity is enabled (PENB = 1), the parity bit is transmitted and received in addition to the number of bits selected for the character length. Odd parity is such that the total number of ones in the character and parity bit, exclusive of stop bit(s), will be odd. For even parity, the total number of ones will be even. PARITY SELECTION | PENB<br>BIT 5 | PODD<br>BIT 4 | PARITY | |---------------|---------------|--------| | 0 | 0 | None | | 0 | 1 | None | | 1 | 0 | Even | | 1 | 1 | Odd | Bit 3 (CLK4M) --- $\overline{\phi}$ Input Divide Select. The $\overline{\phi}$ input to the TMS 9902 ACC is used to generate internal dynamic logic clocking and to establish the time base for the Interval Timer, Transmitter, and Receiver. The $\overline{\phi}$ input is internally divided by either 3 or 4 to generate the two-phase internal clocks required for MOS logic, and to establish the basic internal operating frequency ( $f_{int}$ ) and internal clock period ( $t_{int}$ ). When bit 3 of the Control Register is set to a logic one (CLK4M = 1), $\overline{\phi}$ is internally divided by 4, and when CLK4M = 0, $\overline{\phi}$ is divided by 3. For example, when $f\overline{\phi}=3$ MHz, as in a standard 3 MHz TMS 9900 system, and CLK4M = 0, $\overline{\phi}$ is internally divided by 3 to generate an internal clock period $t_{int}$ of 1 $\mu$ s. The figure below shows the operation of the internal clock divider circuitry. The internal clock frequency should be no greater than 1.1 MHz; thus, when $f\overline{\phi}>$ 3.3 MHz, CLK4M should be set to a logic one. Bits 1 and 0 (RCL1 and RCL0) — Character Length Select. The number of data bits in each transmitted and received character is determined by bits 1 and 0 of the Control Register as shown below: CHARACTER LENGTH SELECTION | RCL1 | RCL0 | CHARACTER | |-------|-------|-----------| | BIT 1 | BIT 0 | LENGTH | | 0 | 0 | 5 Bits | | 0 | 1 | 6 Bits | | 1 | 0 | 7 Bits | | 1 | 1 | 8 Bits | NOTE: $f\phi$ denotes frequency of $\phi$ #### 2.1.2.2 Interval Register The Interval Register is enabled for loading when LDCTRL = 0 and LDIR = 1 (see Table 2). The Interval Register is used to select the rate at which interrupts are generated by the TMS 9902 Interval Timer. The figure below shows the bit assignments for the Interval Register when enabling for loading. INTERVAL REGISTER BIT ADDRESS ASSIGNMENTS The figure below illustrates the establishment of the interval for the Interval Timer. For example, if the Interval Register is loaded with a value of $80_{16}$ (128<sub>10</sub>) the interval at which Timer Interrupts are generated is $t_{itvl} = t_{int} \cdot 64 \cdot M = (1 \ \mu s)$ (64) (128) = 8.192 ms when $t_{int} = 1 \ \mu s$ . $t_{int} = n/f \overline{\phi}$ where n = 4 if CLK4M = 1, 3 if CLK4M = 0. #### 2.1.2.3 Receive Data Rate Register The Receive Data Rate Register (RDR) is enabled for loading when LDCTRL = 0, LDIR = 0, and LRDR = 1 (see Table 2). The Receive Data Rate Register is used to select the bit rate at which data is received. The diagram shows the bit address assignments for the Receive Data Rate Register when enabled for loading. RECEIVE DATA RATE REGISTER BIT ADDRESS ASSIGNMENTS The diagram below illustrates the manner in which the receive data rate is established. Basically, two programmable counters are used to determine the interval for half the bit period of receive data. The first counter divides the internal system clock frequency ( $f_{int}$ ) by either 8 (RDV8 = 1) or 1 (RDV8 = 0). The second counter has ten stages and may be programmed to divide its input signal by any value from 1 (RDR9 – RDR0 = 0000000001) to 1023 (RDR9 – RDR0 = 11111111111). The frequency of the output of the second counter ( $f_{rhbt}$ ) is double the receive-data rate. For example, assume the Receive Data Rate Register is loaded with a value of 11000111000; RDV8 = 1, and RDR9 – RDR0 = 1000111000 = 23816 = 56810. Thus, for $f_{int}$ = 1 MHz, (see Control Register, bit 3) the receive data rate = $f_{rcv}$ = [(1 × 106 ÷ 8) ÷ 568] ÷ 2 = 110.04 bits per second. RECEIVE DATA RATE SELECTION Quantitatively, the receive-data rate fRCV is described by the following algebraic expression: $$f_{\text{rcv}} = \frac{f_{\text{RHBT}}}{2} = \frac{f_{\text{int}}}{(2) \text{ (m) (n)}} = \frac{f_{\text{int}}}{(2) \text{ (8RDV8) (RDR9 - RDR0)}}$$ #### 2.1.2.4 Transmit Data Rate Register The Transmit Data Rate Register (XDR) is enabled for loading when LDCTRL = 0, LDIR = 0, and LXDR = 1 (see Table 2). The Transmit Data Rate Register is used to select the data for the transmitter. The figure below shows the bit address assignments for the Transmit Data Rate Register when enabled for loading. | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------|------|------|------| | XDV8 | XDR9 | XDR8 | XDR7 | XDR6 | XDR5 | XDR4 | XDR3 | XDR2 | XDR1 | XDR0 | | MSB | | L | | | | • | | | | LSB | The transmit data rate is selected with the Transmit Data Rate Register in the same manner the receive data rate is selected with the Receive Data Rate Register. The algebraic Expression for the Transmit Data Rate $f_{xmt}$ is $$f_{XMt} = \frac{f_{XHBT}}{2} = \frac{f_{int}}{(2) (8XDV8) (XDR9-XDR0)}$$ For example, if the Transmit Data Rate Register is loaded with a value of 00110100001; XDV8 = 0, and XDR9 - XDR0 = 1A116 = 41710, if fint = 1 MHz the transmit data rate = $f_{xmt} = [(1 \times 10^6 \div 1) \div 417] \div 2 = 1199.0$ bits per second. #### 2.1.2.5 Transmit Buffer Register The Transmit Buffer Register (XBR) is enabled for loading when LDCTRL = 0, LDIR = 0, LRDR = 0, LXDR = 0, and BRKON = 0 (see Table 2). The Transmit Buffer Register is used to store the next character to be transmitted. When the transmitter is active, the contents of the Transmit Buffer Register are transferred to the Transmit Shift Register (XSR) each time the previous character has been completely transmitted (XSR becomes empty). The bit address assignments for the Transmit Buffer Register are shown below: TRANSMIT BUFFER REGISTER BIT ADDRESS ASSIGNMENTS #### TABLE 4. CRU OUTPUT BIT ADDRESS ASSIGNMENTS NOTE 1 LOADING OF THE BIT INDICATED BY CAUSES THE LOAD CONTROL FLAG FOR THAT REGISTER TO RESET AUTOMATICALLY. All eight bits should be transferred into the register, regardless of the selected character length. The extraneous high order bits will be ignored for transmission purposes; however, loading of bit 7 is internally detected which causes the Transmit Buffer Register Empty (XBRE) status flag to reset. ## 2.1.3 INPUT TO CPU FOR CRU The TMS 9902 ACC occupies 32 bits of input CRU space. The CPU reads the 32 bits from the ACC to sense the status of the device. Table 5 shows the mapping between CRU bit address and TMS 9902 read data. Each CRU addressable read bit is described following Table 5. Status and data information is read from the ACC using $\overline{\text{CE}}$ , S0-S4, and CRUIN. The following figure illustrates the relationship of the signals used to access four bits of data from the ACC. ACC DATA ACCESS SIGNAL TIMING TABLE 5 TMS 9902 ACC INPUT SELECT BIT ASSIGNMENTS | ADDRESS <sub>2</sub> | | ADDRESS <sub>10</sub> | NAME | DESCRIPTION | | | | |----------------------|----|-----------------------|------|-------------|-----|-------------|--------------------------------------------------| | S0 | S1 | S2 | S3 | S4 | | | | | 1 | 1 | 1 | 1 | 1 | 31 | INT | Interrupt | | 1 | 1 | 1 | 1 | 0 | 30 | FLAG | Register Load Control Flag Set | | 1 | 1 | 1 | 0 | 1 | 29 | DSCH | Data Set Status Change | | 1 | 1 | 1 | 0 | 0 | 28 | CTS | Clear to Send | | 1 | 1 | 0 | 1 | 1 | 27 | DSR | Data Set Ready | | 1 | 1 | 0 | 1 | 0 | 26 | RTS | Request to Send | | 1 | 1 | 0 | 0 | 1 | 25 | TIMELP | Timer Elapsed | | 1 | 1 | 0 | 0 | 0 | 24 | TIMERR | Timer Error | | 1 | 0 | 1 | 1 | 1 | 23 | XSRE | Transmit Shift Register Empty | | 1 | ō | 1 | 1 | 0 | 22 | XBRE | Transmit Buffer Register Empty | | 1 | ō | 1 | 0 | 1 | 21 | RBRL | Receive Buffer Register Loaded | | 1 | ō | 1 | 0 | 0 | 20 | DSCINT | Data Set Status Change Interrupt (DSCH - DSCENB) | | 1 | ō | 0 | 1 | 1 | 19 | TIMINT | Timer Interrupt (TIMELP • TIMENB) | | 1 | 0 | 0 | 1 | Ó | 18 | - | Not Used (always = 0) | | 1 | ō | ō | | 1 | 17 | XBINT | Transmitter Interrupt (XBRE • XBIENB) | | 1 | ō | a | - | 0 | 16 | RBINT | Receiver Interrupt (RBRL •RIENB) | | 0 | 1 | 1 | 1 | 1 | 15 | RIN | Receive Input | | 0 | 1 | 1 | 1 | | 14 | RSBD | Receive Start Bit Detect | | ٥ | 1 | 1 | | - | 13 | RFBD | Receive Full Bit Detect | | o | | 1 | - | | 12 | RFER | Receive Framing Error | | o | | | - | - | 11 | ROVER | Receive Overrun Error | | ٥ | | - | - | | 10 | RPER | Receive Parity Error | | 0 | | - | | - | 9 | RCVERR | Receive Error | | 0 | | 0 | - | • | 8 | _ | Not Used (always = 0) | | ľ | • | · | Ĭ | · | 7-0 | RBR7 - RBR0 | Receive Buffer Register (Received Data) | | Bit 17 (XBINT) — | <b>Transmitter Interrupt.</b> XBINT = XBRE (Transmit Buffer Register Empty) AND XBIENB (Transmit Buffer Interrupt Enable). XBINT indicates the presence of an enabled interrupt caused by the transmitter. | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit 16 (RBINT) — | <b>Receiver Interrupt.</b> RBINT = RBRL (Receive Buffer Register Loaded) AND RIENB (Receiver Interrupt Enable). RBINT indicates the presence of an enabled interrupt caused by the receiver. | | Bit 15 (RIN) — | Receive Input. RIN indicates the status of the RIN input to the device. | | Bit 14 (RSBD) — | <b>Receive Start Bit Detect.</b> RSBD is set a half bit time after the 1-to-0 transition of RIN, indicating the start bit of a character. If RIN is not still 0 at such time, RSBD is reset. Otherwise, RSBD remains true until the complete character has been received. This bit is normally used only for testing purposes. | | Bit 13 (RFBD) — | <b>Receive Full Bit Detect.</b> RFBD is set one bit time after RSBD is set to indicate the sample point for the first data bit of the received character. RSBD is reset when the character has been completely received. This bit is normally used only for testing purposes. | | Bit 12 (RFER) — | Receive Framing Error. RFER is set when a character is received in which the stop bit, which should be a logic one, is a logic zero. RFER should only be read when RBRL (Receive Buffer Register Loaded) is a one. RFER is reset when a character with the correct stop bit is received. | | Bit 11 (ROVER) — | Receive Overrun Error. ROVER is set when a new character is received before the RBRL (Receive Buffer Register Loaded) flag is reset, indicating that the CPU failed to read the previous character and reset RBRL before the present character is completely received. ROVER is reset when a character is received and RBRL is 0 when the character is transferred to the receive buffer register. | | Bit 10 (RPER) — | <b>Receive Parity Error.</b> RPER is set when a character is received in which the parity is incorrect. RPER is reset when a character with correct parity is received. | | Bit 9 (RCVERR) — | <b>Receive Error.</b> RCVERR = RFER (Receive Framing Error) + ROVER (Receiver Overrun Error) + RPER (Receive Parity Error). The RCVERR signal indicates the presence of an error in the most recently received character. | (Receive Buffer Register Loaded) is a logic one. Receive Buffer Register. The Receive Buffer Register contains the most recently received character. For character lengths of fewer than eight bits, the character is right-justified, with unused most significant bit(s) all zero(es). The presence of valid data in the Receive Buffer Register is indicated when RBRL Bit 7-Bit 0 (RBR7-RBR0) — #### 2.2 TRANSMITTER OPERATION The operation of the transmitter is diagrammed in Figure 5. The transmitter is initialized by issuing the RESET command (output to bit 31), which causes the internal signals XSRE (Transmit Shift Register Empty) and XBRE (Transmit Buffer Register Empty) to set, and BRKON to reset. Device outputs $\overline{\text{RTS}}$ and XOUT are set, placing the transmitter in its idle state. When RTSON (Request-to-Send On) is set by the CPU, the $\overline{\text{RTS}}$ output becomes active (LOW) and the transmitter becomes active when the $\overline{\text{CTS}}$ input goes LOW. #### 2.2.1 Data Transmission If the Transmit Buffer Register contains a character, transmission begins. The contents of the Transmit Buffer Register are transferred to the Transmit Shift Register, causing XSRE to reset and XBRE to set. The first bit transmitted (start bit) is always a logic zero. Subsequently, the character is shifted out, LSB first. Only the number of bits specified by RCL1 and RCL0 (character length select) of the Control Register are shifted. If parity is enabled, the correct parity bit is next transmitted. Finally the stop bit(s) selected by SBS1 and SBS0 of the Control Register are transmitted. Stop bits are always logic one. XSRE is set to indicate that no transmission is in progress, and the transmitter again tests XBRE to determine if the CPU has yet loaded the next character. The timing for a transmitted character is shown below. 2.2.2 BREAK Transmission The BREAK message is transmitted only if XBRE = 1, $\overline{\text{CTS}}$ = 0, and BRKON = 1. After transmission of the BREAK message begins, loading of the Transmit Buffer Register is inhibited and XOUT is reset. When BRKON is reset by the CPU, XOUT is set and normal operation continues. It is important to note that characters loaded into the Transmit Buffer Register are transmitted prior to the BREAK message, regardless of whether or not the character has been loaded into the Transmit Shift Register before BRKON is set. Any character to be transmitted subsequent to transmission of the BREAK message may not be loaded into the Transmit Buffer Register until after BRKON is reset. #### 2.2.3 Transmission Termination Whenever $\underline{XSRE} = 1$ and $\underline{BRKON} = 0$ the transmitter is idle, with XOUT set to one. If RTSON is reset at this time, the $\overline{RTS}$ device output will go inactive (HIGH), disabling further data transmission until RTSON is again set. $\overline{RTS}$ will not go inactive, however, until any characters loaded into the Transmit Buffer Register prior to resetting RTSON are transmitted and $\underline{BRKON} = 0$ . FIGURE 5. TMS 9902 TRANSMITTER OPERATION #### 2.3 RECEIVER OPERATION #### 2.3.1 Receiver Initialization Operation of the TMS 9902 receiver is diagrammed in Figure 6. The receiver is initialized whenever the CPU issues the RESET command. The RBRL (Receive Buffer Register Loaded) flag is reset to indicate that no character is currently in the Receive Buffer Register, and the RSBD (Receive Start Bit Detect) and RFBD (Receive Full Bit Detect) flags are reset. The receiver remains in the inactive state until a one to zero transition is detected on the RIN device input. #### 2.3.2 Start Bit Detection The receiver delays a half bit time and again samples RIN to ensure that a valid start bit has been detected. If RIN = 0 after the half-bit delay, RSBD is set and data reception begins. If RIN = 1, no data reception occurs. #### 2.3.3 Data Reception In addition to verifying the valid start bit, the half-bit delay after the one-to-zero transition also establishes the sample point for all subsequent data bits in a valid received character. Theoretically, the sample point is in the center of each bit cell, thus maximizing the limits of acceptable distortion of data cells. After the first full bit delay the least significant data bit is received and RFBD is set. The receiver continues to delay one-bit intervals and sample RIN until the selected number of bits are received. If parity is enabled, one additional bit is read for parity. After an additional bit delay, the received character is transferred to the Receive Buffer Register, RBRL is set, ROVER (Receive Overrun Error) and RPER (Receive Parity Error) are loaded with appropriate values, and RIN is tested for a valid stop bit. If RIN = 1, the stop bit is valid. RFER (Receive Framing Error), RSBD, and RFBD are reset, and the receiver waits for the next start bit to begin reception of the next character. If RIN = 0 when the stop bit is sampled, RFER is set to indicate the occurrence of a framing error. RSBD and RFBD are reset, but sampling for the start bit of the next character does not begin until RIN = 1. The timing for a received character is depicted below. RECEIVED CHARACTER TIMING FIGURE 6. TMS 9902 RECEIVER OPERATION #### 2.4 INTERVAL TIMER OPERATION A flowchart of the operation of the Interval Timer is shown in Figure 7. Execution of the RESET command by the CPU causes TIMELP (Timer Elapsed) and TIMERR (Timer Error) to reset and LDIR (Load Interval Register) to set. Resetting LDIR causes the contents of the Interval Register to be loaded into the Interval Timer, thus beginning the selected time interval. The timer is decremented every 64 internal clock cycles (every two internal clock cycles when in Test Mode) until it reaches zero, at which time the Interval Timer is reloaded by the Interval Register and TIMELP is set. If TIMELP was already set, TIMERR is set to indicate that TIMELP was not cleared by the CPU before the next time period elapsed. Each time LDIR is reset, the contents of the Interval Register are loaded into the Interval Timer, thus restarting the timer (refer also to Section 2.1.2.2). FIGURE 7. TMS 9902 INTERVAL TIMER OPERATION INTERVAL TIMER SELECTION #### 2.5 INTERRUPTS The interrupt output (INT) is active (LOW) when any of the following conditions occurs and the corresponding interrupt has been enabled on the TMS 9902 by the CPU: - (1) DSR or CTS changes levels (DSCH = 1); - (2) a character has been received and stored in the Receive Buffer Register (RBRL = 1); - (3) the Transmit Buffer Register is empty (XBRE = 1); or - (4) the selected time interval has elapsed (TIMELP = 1). FIGURE 8. INT OUTPUT GENERATION Figure 8 illustrates the logical equivalent of the ACC interrupt section. Table 6 lists the actions necessary to clear those conditions of the TMS 9902 that cause interrupts. TABLE 6 TMS 9902 INTERRUPT CLEARING | MNEMONIC | CAUSE | ACTION TO RESET | |----------|--------------------------------|---------------------------------| | DSCINT | CTS or DSR change state | Write a bit to DSCENB (bit 21)* | | RINT | Recieve Buffer Full | Write a bit to RIENB (bit 18)* | | XINT | Transmit Buffer Register Empty | Load Transmit Buffer | | TIMINT | Timer Elapsed | Write a bit to TIMENB (bit 20)* | <sup>\*</sup>Writing a zero to clear the interrupt will clear the interrupt and disable further interrupts. ## 2.6 TMS 9902 TERMINAL ASSIGNMENTS AND FUNCTIONS | SIGNATURE | PIN | 1/0 | DESCRIPTION | | |----------------------------------|----------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------| | INT | 1 | 0 | Interrupt — when active (LOW), the INT output indicates that at least one of the interrupt conditions has occurred. | TMS 9902<br>18-PIN PACKAGE | | XOUT | 2 | o | Transmitter Serial Data Output line — XOUT, remains inactive (HIGH) when TMS 9902 is not transmitting. | INT 0 1 180 VCC | | RIN | 3 | i | Receiver Serial Data Input Line — RCV must be held in the inactive (HIGH) state when not receiving data. A transition from HIGH to LOW activates the receiver circuitry. | RIN 0 3 16 0 \$\phi\$ CRUIN 0 4 15 0 CRUCLK | | CRUIN | 4 | 0 | Serial data output pin from TMS 9902 to CRUIN input pin of the CPU. | RTS 0 5 14 0 S0 | | ŔŢŚ | 5 | 0 | Request-to-Send output from TMS 9902 to modern. RTS is enabled by the CPU and remains active (LOW) during transmission from the TMS 9902. | DSR 0 7 12 0 52 CRUOUT 0 8 11 0 53 | | <del>CTS</del> | 6 | 1 | Clear-to-Send input from modern to TMS 9902.<br>When active (LOW), it enables the transmitter<br>section of TMS 9902. | VSS 0 9 10 0 S4 | | DSR | 7 | 1 | Data Set Ready input from modern to TMS 9902. DSR | generates an interrupt when it changes state. | | CRUOUT | 8 | ı | Serial data input line to TMS 9902 from CRUOUT line o | f the CPU. | | VSS | 9 | 1 | Ground reference voltage. | | | S4 (LSB)<br>S3<br>S2<br>S1<br>S0 | 10<br>11<br>12<br>13<br>14 | <br> | Address Select Lines. The data bit being accessed appearing on S0-S4. | by the CPU interface is specified by the 5-bit code | | CRUCLK | 15 | ı | CRU Clock. When active (HIGH), indicates valid data or | n the CRUOUT line for the 9902. | | $\overline{\phi}$ | 16 | ı | TTL Clock. | | | CE | 17 | ı | Chip Enable — when $\overline{\text{CE}}$ is inactive (HIGH), TMS 990 at high-impedance when $\overline{\text{CE}}$ is inactive (HIGH). | 2 CRU interface is disabled. CRUIN remains | | vcc | 18 | ı | Supply voltage (+5 V nominal). | | #### 3. DEVICE APPLICATION This section describes the software interface between the CPU and the TMS 9902 ACC and discusses some of the design considerations in the use of this device for asynchronous communications applications. ## 3.1 DEVICE INITIALIZATION The ACC is initialized by the RESET command from the CPU (output bit 31), followed by loading the Control, Interval, Receive Data Rate, and Transmit Data Rate registers. Assume that the value to be loaded into the CRU Base Register (register 12) in order to point to bit 0 is 004016. In this application characters have seven bits of data plus even parity and one stop bit. The $\overline{\phi}$ input to the ACC is a 3 MHz signal. The ACC divides this signal frequency by three to generate an internal clock frequency of 1 MHz. An interrupt is generated by the Interval Timer every 1.6 milliseconds when timer interrupts are enabled. The transmitter operates at a data rate of 300 bits per second, and the receiver operates at 1200 bits per second. #### NOTE To operate both the transmitter and receiver at 300 bits per second, delete the "LDCR @RDR,11" instruction (see below), and the "LDCR @XDR,12" instruction will cause both data rate registers to be loaded and LRDR and LXDR to reset. #### 3.1.1 Initialization Program The initialization program for the configuration described above is shown below. The RESET command disables all interrupts, initializes all controllers, and sets the four register load control flags (LDCTRL, LDIR, LRDR, and LXDR). Loading the last bit of each of the registers causes the load control flag to reset automatically. | | LI<br>SBO<br>LDCR<br>LDCR<br>LDCR<br>LDCR | R12,>40<br>31<br>@ CNTRL,8<br>@ INTVL,8<br>@ RDR,11<br>@ XDR,12 | INITIALIZE CRU BASE RESET COMMAND LOAD CONTROL AND RESET LDCTRL LOAD INTERVAL AND RESET LDIR LOAD RDR AND RESET LRDR LOAD XDR AND RESET LXDR | |-------|-------------------------------------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------| | CNTRL | BYTE | >A2 | | | INTVL | BYTE | 1600/64 | | | RDR | DATA | >1A1 | | | XDR | DATA | >4D0 | | The RESET command initializes all subcontrollers, disables interrupts, and sets LDCTRL, LDIR, LRDR, and LXDR, enabling loading of the control register. ## 3.1:2 Control Register The options listed in Table 3 in Section 2.1.2.1 are selected by loading the value shown below. #### 3.1.3 Interval Register To set up the interval register to generate an interrupt every 1.6 milliseconds, load the value into the interval register to specify the number of 64-microsecond increments in the total interval desired. 25 X 64 MICROSECONDS = 1.6 MILLISECONDS #### 3.1.4 Receive Data Rate Register To set the data rate for the receiver to 1200 bits per second, load the value into the Receive Data Rate register as shown below: 106 ÷ 1 ÷ 417 ÷ 2 = 1199.04 BITS PER SECOND ### 3.1.5 Transmit Data Rate Register To program the data rate for the transmitter for 300 bits per second, load the following value into the Transmit Data Rate register: 1 X 106 ÷ 8 ÷ 208 ÷ 2 = 300.48 BITS PER SECOND #### 3.2 DATA TRANSMISSION The subroutine shown below demonstrates a simple loop for transmitting a block of data. | | LI | R0, LISTAD | INITIALIZE LIST POINTER | |-------|------|-------------|----------------------------------| | | LI | R1, COUNT | INITIALIZE BLOCK COUNT | | | LI | R12, CRUBAS | INITIALIZE CRU BASE | | | SBO | 16 | TURN ON TRANSMITTER | | XMTLP | TB | 22 | WAIT FOR XBRE = 1 | | | JNE | XMTLP | | | | LDCR | *R0+,8 | LOAD CHARACTER INCREMENT POINTER | | | | | RESET XBRE | | | DEC | R1 | DECREMENT COUNT | | | JNE | XMTLP | LOOP IF NOT COMPLETE | | | SBZ | 16 | TURN OFF TRANSMITTER | After initializing the list pointer, block count, and CRU base address, RTSON is set to cause the transmitter and the RTS output to become active. Data transmission does not begin, however, until the CTS input becomes active. After the final character is loaded into the Transmit Buffer register, RTSON is reset. The transmitter and the RTS output do not become inactive until the final character is transmitted. #### 3.3 DATA RECEPTION The following software will cause a block of data to be received and stored in memory. | CARRET<br>RCVBLK | BYTE<br>Li | >0D<br>R2, RCVLST | INITIALIZE LIST COUNT | |------------------|------------|-------------------|---------------------------------------------| | | Li | R3, MXRCNT | INITIALIZE LIST COUNT | | | LI | R4, CARRET | SET UP END OF BLOCK CHARACTER | | RCVLP | TB | 21 | WAIT FOR RBRL = 1 | | | JNE | RCVLP | | | | STCR | *R2,8 | STORE CHARACTER | | | SBZ | 18 | RESET RBRL | | | DEC | R3 | DECREMENT COUNT | | | JEQ | RCVEND | END IF COUNT = 0 | | | CB | *R2+,R4 | COMPARE TO EOB CHARACTER, INCREMENT POINTER | | | JNE | RCVLP | LOOP IF NOT COMPLETE | | RCVEND | RT | | END OF SUBROUTINE | ## 3.4 REGISTER LOADING AFTER INITIALIZATION The Control, Interval, and Data Rate registers may be reloaded after initialization. For example, it may be desirable to change the interval of the timer. Assume that the interval is to be changed to 10.24 milliseconds; the instruction sequence is: | | SBO<br>LDCR | 13<br>@ INTVL2,8 | SET LOAD CONTROL FLAG<br>LOAD REGISTER, RESET FLAG | |--------|-------------|------------------|----------------------------------------------------| | | • | | | | | • | | | | INTVL2 | BYTE | 10240/64 | | When transmitter interrupts are enabled, caution should be exercised to ensure that a transmitter interrupt does not occur while the load control flag is set. For example, if a transmitter interrupt occurs between execution of the "SBO 13" and the next instruction, the transmit buffer is not enabled for loading when the Transmitter Interrupt service routine is entered because the LDIR flag is set. This situation may be avoided by the following sequence: | | BLWP | @ITVCHG | CALL SUBROUTINE | |------------------|------------------------------------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------| | ITVCPC | LIMI<br>MOV<br>SBO<br>LDCR<br>RTWP | 0<br>@ 24(R13),R12<br>13<br>@ INTVL2,8 | MASK ALL INTERRUPTS<br>LOAD CRU BASE ADDRESS<br>SET FLAG<br>LOAD REGISTER AND RESET FLAG<br>RESTORE MASK AND RETURN | | | • | | | | ITVCHG<br>INTVL2 | DATA<br>BYTE | ACCWP, ITVCPC<br>10240/64 | | In this case all interrupts are masked, ensuring that all interrupts are disabled while the load control flag is set. ## 3.5 INTERFACE TO A DATA TERMINAL Following is a discussion of the TMS 9902 interface to a TI Model 733 data terminal as implemented on the TM 990/100M microcomputer module. Figure 9 diagrams the hardware interface, and Table 7 lists the software interface. The 733 data terminal is an ASCII-code, serial, asynchronous, EIA device equipped with a keyboard, thermal printer, and digital cassette tape. #### 3.5.1 Hardware Interface The hardware interface between the TMS 9902 and the 733 data terminal is shown in Figure 9. The asynchronous communication conforms to *EIA Standard RS-232-C*. The 75188 and 75189 performs the necessary level shifting between TTL levels and RS-232-C levels. The ACC chip enable ( $\overline{9902SEL}$ ) signal comes from decode circuitry which looks at A0-A9 on CRU cycles. The interrupt output ( $\overline{INT}$ ) of the TMS 9902 is sent to the TMS 9901 for prioritization and encoding. When the 9902 is communicating with a terminal, the $\overline{RTS}$ pin can be connected to the $\overline{CTS}$ pin because the terminal will always be in the clear-to-send ( $\overline{CTS}$ ) condition. #### 3.5.2 Software The software required to initialize, read from, and write to the TMS 9902 ACC is listed in Table 7. These routines are taken directly from TiBUG (TM 990/402-1) which is the monitor that runs on the TM 990/100M boards. The coding shown is part of a routine entered because of a power-up reset. Before this section of code was entered, not shown, R12 is set to the correct value of the TMS 9902 CRU base address. The baud rate is detected by measuring the start bit length when an "A" is entered via the keyboard. The variable COUNT is incremented every time the SPLOOP loop is executed. When a zero is seen at 9902 bit 15 (RIN) the start bits are finished being received. The value of COUNT is then compared against a table of known values in TABLE to determine the baud rate. TIBUG assumes that all 1200-baud data terminals are TI Model 733 data terminals. The TI Model 733 communicates at 1200 baud, but prints at 300 baud; this means that bits travel the communications line at 1200 baud, but the spacing between characters is 300 baud. A wait loop is included in the write character routine to handle this spacing requirement. The TIBUG T command is used to indicate that a 1200 baud terminal is true 1200 baud; i.e., not a TI 733. This code is taken from the middle of TIBUG; thus constructs and symbols are used which are not defined here. Lines 261 and 262 of the code contain XOP calls. The READ opcode is really a call to XOP 13 and the MESG opcode is a call to XOP 14, which in turn calls XOP 12. This can be figured out if the assembled code for these opcodes is examined. Following is a list of EQU statements that appear at the beginning of TIBUG, but are not shown here: | COUNT | EQU | 3 | |--------|-----|----| | POINT | EQU | 7 | | INK | EQU | 11 | | CRUBAS | EQU | 12 | Once again, these values could easily be obtained by looking at the assembled code for the statement in which the symbol is used. FIGURE 9. INTERFACE TO A 733 DATA TERMINAL # TABLE 7 TMS 9902 SOFTWARE TIBUG \*\*\*COMMAND SEARCH AND SYSTEM INZ\*\*\* ``` TABLE 7 (Continued) *** WRITE CHARACTER *** 0290 0291 * WRITE CHARACTER -- XOP R.12 0292 NORMAL RETURN 0293 * TRANSMIT THE CHARACTER IN THE LEFT BYTE OF * USER REGISTER R. IF THE CHARACTER IS A * CARRIAGE RETURN, THE ROUTINE WAITS 200 MSEC FOR 0294 0295 0296 0297 * THE CARRIAGE TO RETURN. IF THE TERMINAL IS * A 733ASR AS DENOTED IN THE T COMMAND, EACH 0298 0299 * CHARACTER IS PADDED WITH 25 MSEC TO REDUCE 0300 * THE TRANSFER RATE TO 300 BAUD. 0301 *********************** 0302 01B6 020A WENTRY LI R10,3750 0188 0EA6 0303 01BA 020C LI CRUBAS,>80 SET ORU BASE REG. 0180 0080 0304 01BE 1D10 0305 01C0 1F16 SBO 16 SET RTSON TB TRANSMIT BUFFER REG. EMPTY? 22 0306 010Z 16F9 JNE WENTRY NO, WAIT UNTIL IT IS 0307 0104 321B LDCR *LINK,8 CHARACTER TO WART 0308 0106 D2DB MOVB *LINK, LINK 0309 0108 1E10 SBZ 16 RESET RISON 0310 01CA 098B SRL LINK,8 0311 01CC 028B LINK, SOOOD CARRIAGE RETURN 01CE 000D 0312 01D0 1608 JNE ASR733 NO, SKIP 0313 01D2 0A3A SLA R10,3 0314 01D4 1F16 0315 01D6 16FE WLOOP1 TB 22 WAIT FOR XMISSION TO END JNE WL00P1 0316 01D8 1F17 TB 23 0317 01DA 16FC JNE WL00P1 0318 01DC 060A WLOOP2 DEC R10 WAIT LOOP 0319 01DE 16FE JNE WL00P2 0320 01E0 0380 RITHE 0321 01E2 C2E0 ASR733 MOV @DUMPEG,LINK IN DUMP ROUTINE ? 01E4 FFF6 0322 01E6 1303 JEQ WEXIT YES, IGNORE ASR FLAG 0323 01E8 C2E0 MOV @ASR,LINK ASR733 2 01EA FFF4 0324 01EC 16F3 JNE WLOOP1 YES, WAIT 3 NULLS 0325 01EE 0380 WEXIT RTWP TIBUG *** READ CHARACTER *** 0272 * READ CHARACTER -- XOP R.13 0273 NORMAL RETURN 0274 0275 * READ WAITS FOR A CHARACTER TO BE ASSEMBLED IN 0276 * THE WART. THE CHARACTER IS PLACED IN THE LEFT 0277 * BYTE OF USER REGISTER R. THE RIGHT BYTE IS 0278 * ZEROED. ALL ERRORS ARE IGNORED. 0279 ****** 0280 0281 01A6 020C RENTRY LI CRUBAS,>80 SET ORU BASE REG. 0188 0080 0282 01AA 1F15 TB 21 RECEIVE BUFFER REG. FULL? 0283 01AC 16FC JNE RENTRY NO, LOOP 0284 01AE 04DB CLR *LINK 0285 01B0 361B STOR #LINK,8 0286 01B2 1E12 0287 01B4 0380 SBZ 18 RTWP ``` TIBLIG # 4. TMS 9902 ELECTRICAL SPECIFICATIONS # 4.1 Absolute Maximum Ratings Over Operating Free Air Temperature Range (Unless Otherwise Noted) \* | Supply voltage, VCC | | -0.3 V to 10 V | |--------------------------------|---------|----------------| | All inputs and output voltages | | 0.55 W | | Continuous power dissipation | l | 0°C to 70°C | | Operating free-air temperatur | e range | -65°C to 150°C | | Storage temperature range | e range | | <sup>&</sup>quot;Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute maximum rated conditions for extended periods may affect device reliability. # 4.2 Recommended Operating Conditions \* | MIN | NOM | MAX | UNIT | |---------|-----|---------------|---------------------------------------------------| | 4.75 | 5.0 | 5.25 | V | | | 0 | | V | | 20 | | Vcc | V | | | | 0.8 | V | | 1.33 10 | | 70 | °C | | | | | <del></del> | | | | 4.75 5.0<br>0 | 4.75 5.0 5.25<br>0 VCC<br>VSS <sup>-</sup> .3 0.8 | # 4.3 Electrical Characteristics Over Full Range of Recommended Operating Conditions (Unless Otherwise Noted) \* | | 0.000 | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |---------|---------------------------------------------|------------------------------------------------------------|-----|-----|------|------| | | PARAMETER | 100.44 | 2.4 | | VCC | ٧ | | Vон | High level output voltage | I <sub>OH</sub> = -100 μA<br>I <sub>OH</sub> = -200 μA | 2.2 | | VCC | V | | | | I <sub>OL</sub> = 3.2 mA | VSS | | 0.4 | V | | VOL | Low level output voltage | V <sub>I</sub> = 0 V to V <sub>CC</sub> | | | ± 10 | μΑ | | lį . | Input current (any input) | | | | 100 | mA | | ICC(av) | Average supply current from V <sub>CC</sub> | $^{\dagger}c(\phi) = 330 \text{ ns}, T_{A} = 70^{\circ}C$ | | | 15 | pF | | Ci | Small signal input capacitance, any input | f = 1 MHz | | | | 1- | | · | | | | | | | # 4.4 Timing Requirements Over Full Range of Operating Conditions | | | MIN | TYP | MAX | UNIT | |-------|-------------------------------------------------|-----|-----|-----|------| | | PARAMETER | 300 | 333 | 667 | ns | | (φ) | Clock cycle time | 5 | | 40 | ns | | (φ) | Clock rise time | 10 | | 40 | ns | | (φ) | Clock fall time | 225 | | | ns | | ν(φH) | Clock pulse width (high level) | 45 | | | ns | | ν(φL) | Clock pulse width (low level) | 100 | 185 | | ns | | v(CC) | CRUCLK pulse width | | | | ns | | su1 | Setup time for CE before CRUCLK | 150 | | | ns | | su2 | Setup time for S0-S4, or CRUOUT before CRUCLK | 180 | | | ns | | h | Hold time for CE, S0-S4, or CRUOUT after CRUCLK | | | | 1 | <sup>\*</sup>NOTE: All voltage values are referenced to V<sub>SS</sub>. # 4.5 Switching Characteristics Over Full Range of Recommended Operating Conditions | D.D | TECT | | | | | |-----------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------| | | CONDITION | MIN | TYP | MAX | UNIT | | | CL = 100pF | | | 200 | | | Propagation delay, S0-S4 to valid CRUIN | CL = 100 pF | | | | ns | | | PARAMETER Propagation delay, CE to valid CRUIN Propagation delay, S0-S4 to valid CRUIN | Propagation delay, CE to valid CRUIN Propagation delay, SO SA to wild ORUIN CL = 100pF | Propagation delay, CE to valid CRUIN Propagation delay, SO SA to wild CRUIN CL = 100pF | Propagation delay, SO SA to wild CRUIN Propagation delay, SO SA to wild CRUIN CL = 100 pF | Propagation delay, SO S to wild CRUIN Propagation delay, SO S to wild CRUIN CL = 100pF 300 | SWITCHING CHARACTERISTICS NOTE: ALL SWITCHING TIMES ARE ASSUMED TO BE AT 10% OR 90% VALUES. # EQUIVALENT OF I/O INPUTS $v_{\text{CC}}$ # EQUIVALENT OF I/O OUTPUTS INPUT AND OUTPUT EQUIVALENTS #### **MECHANICAL SPECIFICATIONS** 5. INPUT 0- #### TMS 9902 NL vcc # 18 pin plastic packages 18-300 PDIP 0.300±0.010 (7,62±0,26) 0.020 (0,51) MIN 0.050 ± 0.051 0.060 (1,52) NOM 0.018±0.003 (0,457±0,076) NOTES: A. Each pin centerline is located within 0.010 (0,26) 0f its true longitudinal position. B. All linear dimensions are in inches and parenthetically in millimeters. Inch dimensions TMS 9902 JL 18-pin ceramic packages with side-brazed leads and metal or epoxy or glass lid seal #### APPENDIX G The Engineering Staff of TEXAS INSTRUMENTS INCORPORATED Semiconductor Group # TMS 9980A/ TMS 9981 Microprocessor Data Manual **NOVEMBER 1977** TEXAS INSTRUMENTS ### TABLE OF CONTENTS | 1. | INT | RODUC | | | |----|------|----------|---------------------------------------------------------------------------------------------|-----| | | 1.1 | Descript | ion | . 1 | | | 1.2 | | tures | | | | 1.3 | TMS 998 | 30A/TMS 9981 Differences | . 1 | | 2. | ARC | HITEC | | | | | 2.1 | Register | s and Memory | .3 | | | 2.2 | | ts | | | | 2.3 | | utput | | | | 2.4 | | it CRU Operations | | | | 2.5 | | -Bit CRU Operations | | | | 2.6 | | I Instructions | | | | 2.7 | Non-Mas | skable Interrupts | | | | | 2.7.1 | LOAD Function | | | | | 2.7.2 | RESET | | | | 2.8 | | 80A Pin Description | | | | 2.9 | | 81 Pin Description | | | | 2.10 | | | | | | | 2.10.1 | Memory | | | | | | HOLD | | | | | 2.10.3 | CRU | | | | | 2.10.4 | Interrupt Code (ICO-IC2) | 19 | | 3. | TMS | 9980A | /TMS 9981 INSTRUCTION SET | | | | 3.1 | | on | | | | 3.2 | Address | ing Modes | | | | | 3.2.1 | Workspace Register Addressing R | 23 | | | | 3.2.2 | Workspace Register Indirect Addressing *R | | | | | 3.2.3 | Workspace Register Indirect Auto Increment Addressing *R+ | | | | | 3.2.4 | Symbolic (Direct) Addressing @ LABEL | | | | | 3.2.5 | Indexed Addressing @ TABLE (R) | | | | | 3.2.6 | Immediate Addressing | | | | | 3.2.7 | Program Counter Relative Addressing | | | | | 3.2.8 | CRU Relative Addressing | | | | 3.3 | | nd Definitions | | | | 3.4 | | Register , | | | | 3.5 | | ions | 26 | | | | 3.5.1 | Dual Operand Instructions with Multiple Addressing Modes for Source and Destination Operand | 26 | | | | 3.5.2 | Dual Operand Instructions with Multiple Addressing Modes for the Source | 20 | | | | | Operand and Workspace Register Addressing for the Destination | 27 | | | | 3.5.3 | Extended Operation (XOP) Instruction | | | | | 3.5.4 | Single Operand Instructions. | 28 | | | | 3.5.5 | CRU Multiple-Bit Instructions | 29 | | | | 3.5.6 | CRU Single-Bit Instructions. | 29 | | | | 3.5.7 | Jump Instructions | 29 | | | | 3.5.8 | Shift Instructions | | | | | 3.5.9 | Immediate Register Instructions | 30 | | | | 3.5.10 | Internal Register Instruction | | | | | 3.5.11 | Internal Register Store Instructions | 31 | | | | 3.5.12 | Return Workspace Pointer (RTWP) Instruction | 31 | | | | 3 5 13 | External Instructions | | ## **TABLE OF CONTENTS (Continued)** | | 3.6 | TMS 9980A/TMS 9981 Instruction Execution Times | |--------|------------|-------------------------------------------------------------------------------------------------------------------------------| | 4. | TMS<br>4.1 | \$ 9980A/TMS 9981 ELECTRICAL AND MECHANICAL SPECIFICATIONS Absolute Maximum Ratings Over Operating Free-Air Temperature Range | | | 4.2 | Recommended Operating Conditions | | | 4.3 | Electrical Characteristics Over Full Range of Recommended Operating Conditions | | | 4.4 | Clock Characteristics | | | | 4.4.1 Internal Clock Option | | | | 4.4.2 External Clock Option | | | 4.5 | Switching Characteristics Over Full Range of Recommended Operating Conditions | | _ | | | | 5. | | PROTOTYPING SYSTEM | | | 5.1 | Hardware | | | 5.2 | System Console | | | 5.3<br>5.4 | Software | | | 5.4 | Options | | 6. | SUP | PORT CIRCUITS | | _ | | | | 7. | SYS | TEM DESIGN EXAMPLES40 | | 8. | MEC | CHANICAL DATA | | | 8.1 | TMS 9980A/TMS 9981 – 40-Pin Ceramic Package | | | 8.2 | TMS 9980A/TMS 9981 – 40-Pin Plastic Package | | | | | | | | LIST OF ILLUSTRATIONS | | Figur | o 1 | Architecture | | Figur | | Mampy Man | | Figur | | Memory Map | | Figur | | TMS 9980A/TMS 9981 Interrupt Interface 7 TMS 9980A/TMS 9981 Single-Bit CRU Address Development 8 | | Figur | | TMS 9980A/TMS 9981 LDCR/STCR Data Transfers | | Figure | | TMS 9980A/TMS 9981 16-Bit Input/Output Interface | | Figure | | External Instruction Decode Logic | | Figure | | TMS 9980A/TMS 9981 CPU Flow Chart | | Figure | 9a | TMS 9980A/TMS 9981 Memory Bus Timing (No Wait States) | | Figure | 9b | TMS 9980A/TMS 9981 Memory Bus Timing (One Wait State) | | Figure | 10 | TMS 9980A/TMS 9981 HOLD Timing | | Figure | 11 | TMS 9980A/TMS 9981 CRU Interface Timing | | Figure | 12 | Interrupt Code Timing | | Figure | 13 | Crystal Oscilator Circuit | | Figure | 14 | External Signal Timing Diagram | | Figure | 15 | Minimum TMS 9981 System | | Figure | 16 | Maximum TMS 9980A/TMS 9981 System | | | | LIST OF TABLES | | r., | | | | Table | 1 | Interrupt Level Data | | Fable | 2 | TMS 9980A Pin Assignments and Functions | | Table | 3 | TMS 9981 Pin Assignments and Functions | | Γable | 4 | Instruction Execution Times | #### 1. INTRODUCTION #### 1.1 DESCRIPTION The TMS 9980A/TMS 9981 is a software-compatible member of TI's 9900 family of microprocessors. Designed to minimize the system cost for smaller systems, the TMS 9980A/TMS 9981 is a single-chip 16-bit central processing unit (CPU) which has an 8-bit data bus, on-chip clock, and is packaged in a 40-pin package (see Figure 1). The instruction set of the TMS 9980A/TMS 9981 includes the capabilities offered by full minicomputers and is exactly the same as the 9900's. The unique memory-to-memory architecture features multiple register files, resident in memory, which allow faster response to interrupts and increased programming flexibility. The separate bus structure simplifies the system design effort. Texas Instruments provides a compatible set of MOS and TTL memory and logic function circuits to be used with a TMS 9980A/TMS 9981 system. #### 1.2 KEY FEATURES - 16-Bit Instruction Word - Full Minicomputer Instruction Set Capability Including Multiply and Divide - Up to 16,384 Bytes of Memory - 8-Bit Memory Data Bus - Advanced Memory-to-Memory Architecture - Separate Memory, I/O, and Interrupt-Bus Structures - 16 General Registers - 4 Prioritized Interrupts - Programmed and DMA I/O Capability - On-Chip 4-Phase Clock Generator - 40-Pin Package - N-Channel Silicon-Gate Technology #### 1.3 TMS 9980A/TMS 9981 DIFFERENCES The TMS 9980A and the TMS 9981 although very similar, have several differences which user should be aware. - The TMS 9980A requires a VBB supply (pin 21) while the TMS 9981 has an internal charge pump to generate VBB from VCC and VDD. - The TMS 9981 has an optional on-chip crystal oscillator in addition to the external clock mode of the TMS 9980A. - 3. The pin-outs are not compatible for D0-D7, INT0-INT2, and $\overline{\phi}3$ . FIGURE 1 - ARCHITECTURE #### 2. ARCHITECTURE The memory for the TMS 9980A/TMS 9981 is addressable in 8-bit bytes. A word is defined as 16 bits or 2 consecutive bytes in memory. The words are restricted to be on even address boundaries, i.e., the most-significant half (8 bits) resides at even address and the least-significant half resides at the subsequent odd address. A byte can reside at even or odd address. The word and byte formats are shown below. #### 2.1 REGISTERS AND MEMORY The TMS 9980A/TMS 9981 employs an advanced memory-to-memory architecture. Blocks of memory designated as workspace replace internal hardware registers with program-data registers. The TMS 9980A/TMS 9981 memory map is shown in Figure 2. The first two words (4 bytes) are used for RESET trap vector. Addresses 000416 through 001316 are used for interrupt vectors. Addresses 0040 through 007F are used for the extended operation (XOP) instruction trap vectors. The last four bytes at address 3FFC16 to 3FFF are used for trap vector for the LOAD function. The remaining memory is available for programs, data, and workspace registers. If desired, any of the special areas may also be used as general memory. Three internal registers are accessible to the user. The program counter (PC) contains the address of the instruction following the current instruction being executed. This address is referenced by the processor to fetch the next instruction from memory and is then automatically incremented. The status register (ST) contains the present state of the processor and will be further defined in Section 3.4. The workspace pointer (WP) contains the address of the first word in the currently active set of workspace registers. FIGURE 2 - MEMORY MAP A workspace-register file occupies 16 contiguous memory words in the general memory area. Each workspace register may hold data or addresses and function as operand registers, accumulators, address registers, or index registers. During instruction execution, the processor addresses any register in the workspace by adding the register number to the contents of the workspace pointer and initiating a memory request for the word. The relationship between the workspace pointer and its corresponding workspace is shown below. The workspace concept is particularly valuable during operations that require a context switch, which is a change from one program environment to another (as in the case of an interrupt or call to a subroutine). Such an operation, using a conventional multi-register arrangement, requires that at least part of the contents of the register file be stored and reloaded. A memory cycle is required to store or fetch each word. By exchanging the program counter, status register, and workspace pointer, the TMS 9980A/TMS 9981 accomplishes a complete context switch with only six store cycles and six fetch cycles. After the switch the workspace pointer contains the starting address of a new 16-word workspace in memory for use in the new routine. A corresponding time saving occurs when the original context is restored. Instructions in the TMS 9980A/TMS 9981 that result in a context switch include: - 1. Branch and Load Workspace Pointer (BLWP) - 2. Return from Subroutine (RTWP) - 3. Extended Operation (XOP) Device interrupts, RESET, and LOAD also cause a context switch by forcing the processor to trap to a service subroutine: #### 2.2 INTERRUPTS The architecture of the 9900 family allows vectoring of 16 interrupts. These interrupts are assigned levels from 0 to 15. The interrupt at level 0 has the highest priority and the interrupt at level 15 has the lowest priority. The TMS 9900 implements all 16 interrupt levels. The TMS 9980A/TMS 9981 implements only 5 levels (level 0 and levels 1 through 4). Level 0 is reserved for RESET function. Levels 1 through 4 may be used for external devices. The external levels may also be shared by several device interrupts, depending upon system requirements. The TMS 9980A/TMS 9981 continuously compares the interrupt code (ICO through IC2) with the interrupt mask contained in status-register bits 12 through 15. When the level of the pending interrupt is less than or equal to the enabling mask level (higher or equal priority interrupt), the processor recognizes the interrupt and initiates a context switch following completion of the currently executing instruction. The processor fetches the new context WP and PC from the interrupt vector locations. Then, the previous context WP, PC, and ST are stored in workspace registers 13, 14, and 15, respectively, of the new workspace. The TMS 9980A/TMS 9981 then forces the interrupt mask to a value that is one less than the level of the interrupt being serviced. This allows only interrupts of higher priority to interrupt a service routine. The processor also inhibits interrupts until the first instruction of the service routine has been executed to allow modification of interrupt mask if needed (to mask out certain interrupts). All interrupt requests should remain active until recognized by the processor in the device-service routine. The individual service routines must reset the interrupt requests before the routine is complete. The interrupt code (ICO-IC2) may change asynchronously within the constraints specified in Section 2.10.4. If a higher priority interrupt occurs, a second context switch occurs to service the higher-priority interrupt. When that routine is complete, a return instruction (RTWP) restores the first service routine parameters to the processor to complete processing of the lower-priority interrupt. All interrupt subroutines should terminate with the return instruction to restore original program parameters. The interrupt-vector locations, device assignment, enabling mask value and the interrupt code are shown in Table 1. TABLE 1 INTERRUPT LEVEL DATA | INTERRUPT<br>CODE<br>(ICO—IC2) | FUNCTION | VECTOR LOCATION<br>(MEMORY ADDRESS<br>IN HEX) | DEVICE ASSIGNMENT | INTERRUPT MASK VALUES TO ENABLE (ST12 THROUGH ST15) | |--------------------------------|----------|-----------------------------------------------|-------------------|-----------------------------------------------------| | 1 1 0 | Level 4 | 0 0 1 0 | External Device | 4 Through F | | 101 | Level 3 | 000C | External Device | 3 Through F | | 100 | Level 2 | 0008 | External Device | 2 Through F | | 0 1 1 | Level 1 | 0004 | External Device | 1 Through F | | 0 0 1 | Reset | 0000 | Reset Stimulus | Don't Care | | 010 | Load | 3 F F C | Load Stimulus | Don't Care | | 000 | Reset | 0000 | Reset Stimulus | Don't Care | | 1 1 1 | No-Op | | ***** | | | | | 1 | | 1 | Note that $\overline{\text{RESET}}$ and $\overline{\text{LOAD}}$ functions are also encoded on the interrupt code input lines. Figure 3 illustrates some of the possible configurations. To realize $\overline{\text{RESET}}$ and one interrupt no external component is needed. If $\overline{\text{LOAD}}$ is also needed, a three input AND gate is wired as shown. If the system requires more than one interrupt, a single SN74148 (TIM 9907) is required. FIGURE 3 - TMS 9980A/TMS 9981 INTERRUPT INTERFACE #### 2.3 INPUT/OUTPUT The TMS 9980A/TMS 9981 utilizes a versatile direct command-driven I/O interface designated as the communications-register unit (CRU). The CRU provides up to 2,048 directly addressable output bits. Both input and output bits can be addressed individually or in fields of from 1 to 16 bits. The TMS 9980A/TMS 9981 employs CRUIN, CRUCLK, and A13 (for CRUOUT) and 11 bits (A2-A12) of the address bus to interface with the CRU system. The processor instructions that drive the CRU interface can set, reset, or test any bit in the CRU array or move between memory and CRU data fields. ## 2.4 SINGLE-BIT CRU OPERATIONS The TMS 9980A/TMS 9981 performs three single-bit CRU functions: test bit (TB), set bit to one (SBO), and set bit to zero (SBZ). To identify the bit to be operated upon, the TMS 9980A/TMS 9981 develops a CRU-bit address and places it on the address bus, A2 to A12. For the two output operations (SBO and SBZ), the processor also generates a CRUCLK pulse, indicating an output operation to the CRU device and places bit 7 of the instruction word on the A13 line to accomplish the specified operation (bit 7 is a one for SBO and a zero for SBZ). A test-bit instruction transfers the addressed CRU bit from the CRUIN input line to bit 2 of the status register (EQUAL). The TMS 9980A/TMS 9981 develops a CRU-bit address for the single-bit operations from the CRU-base address contained in workspace register 12 and the signed displacement count contained in bits 8 through 15 of the instruction. The displacement allows two's complement addressing from base minus 128 bits through base plus 127 bits. The base address from W12 is added to the signed displacement specified in the instruction and the result is loaded into the address bus. Figure 4 illustrates the development of a single-bit CRU address. FIGURE 4 - TMS 9980A/TMS 9981 SINGLE-BIT CRU ADDRESS DEVELOPMENT #### 2.5 MULTIPLE-BIT CRU OPERATIONS The TMS 9980A/TMS 9981 performs two multiple-bit CRU operations: store communications register (STCR) and load communications register (LDCR). Both operations perform a data transfer from the CRU-to-memory or from memory-to-CRU as illustrated in Figure 5. Although the figure illustrates a full 16-bit transfer operation, any number of bits from 1 through 16 may be involved. The LDCR instruction fetches a word from memory and right-shifts it to serially transfer it to CRU output bits. If the LDCR involves eight or fewer bits, those bits come from the right-justified field within the addressed byte of the memory word. If the LDCR involves nine or more bits, those bits come from the right-justified field within the whole memory word. When transferred to the CRU interface, each successive bit receives an address that is sequentially greater than the address for the previous bit. This addressing mechanism results in an order reversal of the bits; that is, bit 15 of the memory word (or bit 7) becomes the lowest addressed bit in the CRU and bit 0 becomes the highest addressed bit in the CRU field. An STCR instruction transfers data from the CRU to memory. If the operation involves a byte or less transfer, the transferred data will be stored right-justified in the memory byte with leading bits set to zero. If the operation involves from nine to 16 bits, the transferred data is stored right-justified in the memory word with leading bits set to zero. When the input from the CRU device is complete, the first bit from the CRU is the least-significant-bit position in the memory word or byte. N = BIT SPECIFIED BY CRU BASE REGISTER FIGURE 5 -- TMS 9980A/TMS 9981 LDCR/STCR DATA TRANSFERS Figure 6 illustrates how to implement a 16-bit input and a 16-bit output register in the CRU interface. CRU addresses are decoded as needed to implement up to 128 such 16-bit interface registers. In system application, however, only the exact number of interface bits needed to interface specific peripheral devices are implemented. It is not necessary to have a 16-bit interface register to interface an 8-bit device. #### 2.6 EXTERNAL INSTRUCTIONS The TMS 9980A/TMS 9981 has five external instructions that allow user-defined external functions to be initiated under program control. These instructions are CKON, CKOF, RSET, IDLE, and LREX. These mnemonics, except for IDLE, relate to functions implemented in the 990 minicomputer and do not restrict use of the instructions to initiate various user-defined functions. IDLE also causes the TMS 9980A/TMS 9981 to enter the idle state and remain until an interrupt, RESET, or LOAD occurs. When any of these five instructions are executed by the TMS 9980A/TMS 9981, a unique 3-bit code appears on the address bus, bits A13, A0, and A1, along with a CRUCLK pulse. When the TMS 9980A/TMS 9981 is in an idle state, the 3-bit code and CRUCLK pulses occur repeatedly until the idle state is terminated. The codes are: | EXTERNAL INSTRUCTION | A13 | Α0 | A1 | |----------------------|-----|----|----| | LREX | Н | н | н | | CKOF | н | н | L | | CKON | н | L | н | | RSET | L | н | н | | IDLE | L | н | L | | CRU INSTRUCTIONS | H/L | L | L | FIGURE 6 - TMS 9980A/9981 16-BIT INPUT/OUTPUT INTERFACE Note that during external instructions bits (A2-A12) of the address bus may have any of the possible binary patterns. Since these bits (A2-A12) are used as CRU addresses, CRUCLK to the CRU must be gated with a decode of 0 on A0 and A1 to avoid erroneous strobe to CRU bits during external instruction execution. Figure 7 illustrates typical external decode logic to implement these instructions. Note CRUCLK to the CRU is inhibited during external instructions. FIGURE 7 - EXTERNAL INSTRUCTION DECODE LOGIC #### 2.7 NON-MASKABLE INTERRUPTS ## 2.7.1 LOAD Function The LOAD stimulus is an unmaskable interrupt that allows cold-start ROM loaders and front panels to be implemented for the TMS 9980A/TMS 9981. When the TMS 9980A/TMS 9981 decodes LOAD on ICO-IC2 lines, it initiates an interrupt sequence immediately following the instruction being executed. Memory location 3FFC is used to obtain the vector (WP and PC). The old PC, WP, and ST are loaded into the new workspace and the interrupt mask is set to 0000. Then the program execution resumes using the new PC and WP. Recognition of LOAD by the processor will also terminate the idle condition. External stimulus for LOAD must be held active (on ICO-IC2) for one instruction period by using IAQ signal. #### 2.7.2 **RESET** When the TMS 9980A/TMS 9981 recognizes a RESET on ICO-IC2, it resets and inhibits WE and CRUCLK. Upon removal of the RESET code, the TMS 9980A/TMS 9981 initiates a level-zero interrupt sequence that acquires WP and PC from location 0000 and 0002, sets all status register bits to zero and starts execution. Recognition of RESET by the processor will also terminate an idle state. External stimulus for RESET must be held active for a minimum of three clock cycles. FIGURE 8 - TMS 9980A/TMS 9981 CPU FLOW CHART ## 2.8 TMS 9980A PIN DESCRIPTION Table 2 defines the TMS 9980A pin assignments and describes the function of each pin. TABLE 2 TMS 9980A PIN ASSIGNMENTS AND FUNCTIONS | SIGNATURE | PIN | 1/0 | DESCRIPTION | Ti | MS 9980 | A PIN ASSIG | NMENT | 5 | |-------------------------------|----------|------|------------------------------------------------------------------------------------------|----------------------|------------|-----------------|-------------|---------------| | A0 (MSB) | 17 | OUT | ADDRESS BUS | | m- | | n | | | A1 | 16 | OUT | A0 through A13 comprise the address bus. | HOLD | 1 | 1 1 | 40 | MEMEN | | A2 | 15 | OUT | This 3-state bus provides the memory-<br>address vector to the external-memory sys- | HOLDA | 2 | | 39 | READY | | A3<br>A4 | 14<br>13 | OUT | tem when MEMEN is active and I/O-bit | IAQ | 3 | | 38 | WE | | A4<br>A5 | 12 | OUT | addresses and external-instruction addresses | | - 1 | | 37 | CRUCLK | | A6 | 11 | OUT | to the I/O system when MEMEN is inactive. | A13/CRUOUT | 4 | | F | | | A7 | 10 | OUT | The address bus assumes the high-impedance | A12 | 5 | | <b>⊒36</b> | VDD | | A8 | 9 | OUT | state when HOLDA is active. | A11 | 6 📙 | | <b>⊒35</b> | VSS | | A9 | 8 | OUT | | A10 | 7 🕌 | | <b>∐</b> 34 | CKIN | | A10 | 7 | OUT | | A9 | 8 🗌 | | 33 | D7 | | A11 | 6 | OUT | | A8 | 9 🗍 | | 32 | D6 | | A12 | 5<br>4 | OUT | CRUOUT | A7 | 10 | | 31 | D5 | | A13/CRUOUT | 7 | 001 | Serial I/O data appears on A13 when an | | 11 | | 30 | D4 | | | | | LDCR, SBZ and SBO instruction is execu- | A6 | - 1 | | - F | | | | | | ted. This data should be sampled by the I/O | A5 | 12 | | 29 | D3 | | | | | interface logic when CRUCLK goes active | A4 | 13 | | 28 | D2 | | | | | (high). One bit of the external instruction | A3 | 14 📋 | | 27 | D1 | | | | | code appears on A13 during external in- | A2 | 15 | | 26 | D0 | | | | | struction execution. | A1 | 16 🗌 | | 25 | INT 0 | | D0 (MSB) | 26 | 1/0 | DATA BUS | A0 | 17 | | 24 | INT 1 | | DU (MISB) | 27 | 1/0 | D0 through D7 comprise the bidirectional | DBIN | 18 | | 23 | INT 2 | | D2 | 28 | 1/0 | 3-state data bus. This bus transfers memory | CRUIN | 19 | | 22 | <b>ø</b> 3 | | D3 | 29 | 1/0 | data to (when writing) and from (when | | - I | | 521 | • | | D4 | 30 | 1/0 | reading) the external-memory system when | vcc | 20 4 | | 121 | VBB | | D5 | 31 | 1/0 | MEMEN is active. The data bus assumes the | | | | | | | D6 | 32 | 1/0 | high-impedance state when HOLDA is | | | | | | | D7 (LSB) | 33 | 1/0 | active. | | | | | | | | | | POWER SUPPLIES | | | | | | | V <sub>BB</sub> | 21 | | Supply voltage (-5V NOM) | | | | | | | VCC | 20 | | Supply voltage (5 V NOM) | | | | | | | VDD | 36 | | Supply voltage (12 V NOM) | | | | | | | VSS | 35 | | Ground reference | | | | | | | | | l | | CLOCKS | | | | | | CKIN | 34 | IN | Clock In. A TTL compatible input used to gen | | -nhase clo | ck CKIN fre | auency i | s 4 times th | | | | | desired system frequency. | erate the interner 4 | pridac ord | | ,, | | | | | | desired system requests. | | | | | | | $\overline{\phi}\overline{3}$ | 22 | ОПТ | Clock phase 3 $(\phi 3)$ inverted; used as a timing re | eference. | | | | | | | 40 | 0.17 | | SUS CONTROL | | | | | | DBIN | 18 | OUT | Data bus in. When active (high), DBIN indicat | es that the TMS 99 | 80A has c | lisabled its ou | tput buf | fers to allow | | | | | the memory to place memory-read data on the except when HOLDA is active at which time in | e data bus during N | IEMEN. L | BIN remains | low in a | II other case | ## TABLE 2 (CONTINUED) | SIGNATURE | PIN | 1/0 | DESCRIPTION | |----------------------|----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MEMEN | 40 | ОПТ | Memory enable. When active (low), MEMEN indicates that the address bus contains a memory address. When HOLDA is active, MEMEN is in the high impedance state. | | WE | 38 | OUT | Write enable. When active (low), $\overline{\text{WE}}$ indicates that memory-write data is available from the TMS 9980 to be written into memory. When HOLDA is active, $\overline{\text{WE}}$ is in the high-impedance state. | | CRUCLK | 37 | оит | CRU clock. When active (high), CRUCLK indicates that external interface logic should sample the output data on CRUOUT or should decode external instructions on A0, A1, A13. | | CRUIN | 19 | IN | CRU data in. CRUIN, normally driven by 3-state or open-collector devices, receives input data from external interface logic. When the processor executes a STCR or TB instruction, it samples CRUIN for the level of the CRU input bit specified by the address bus (A2 through A12). | | INT2<br>INT1<br>INTO | 23<br>24<br>25 | IN<br>IN | Interrupt code. Refer to Section 2.2 for detailed description. | | | | | MEMORY CONTROL | | HOLD | 1 | IN | Hold. When active (low), HOLD indicates to the processor that an external controller (e.g., DMA device) desires to utilize the address and data buses to transfer data to or from memory. The TMS 9980A enters the hold state following a hold signal when it has completed its present memory cycle.* The processor then places the address and data buses in the high-impedance state (along with WE, MEMEN, and DBIN) and responds with a hold-acknowledge signal (HOLDA). When HOLD is removed, the processor returns to normal operation. | | HOLDA | 2 | OUT | Hold acknowledge. When active (high), HOLDA indicates that the processor is in the hold state and the address and data buses and memory control outputs (WE, MEMEN, and DBIN) are in the high-impedance state. | | READY | 39 | IN | Ready. When active (high), READY indicates that memory will be ready to read or write during the next clock cycle. When not-ready is indicated during a memory operation, the TMS 9980A enters a wait state and suspends internal operation until the memory systems indicated ready. | | | | | TIMING AND CONTROL | | IAQ | 3 | OUT | Instruction acquisition. IAQ is active (high) during any memory cycle when the TMS 9980A is acquiring an instruction. IAQ can be used to detect illegal op codes. It may also be used to synchronize LOAD stimulus. | <sup>\*</sup> If the cycle following the present memory cycle is also a memory cycle it, too, is completed before TMS 9980 enters hold state. ## 2.9 TMS 9981 PIN DESCRIPTION Table 3 defines the TMS 9981 pin assignments and describes the function of each pin. TABLE 3 TMS 9981 PIN ASSIGNMENTS AND FUNCTIONS | SIGNATURE | PIN | 1/0 | DESCRIPTION | Т | MS 9981 F | PIN ASSIGNM | IENTS | | |-----------------|-----|-----|--------------------------------------------------------------------------------------------------|--------------------------------|-------------|-----------------|-------------|--------------| | A0(MSB) | 17 | OUT | ADDRESS BUS | HOLD | 1 T | | 40 | MEMEN | | A1 | 16 | OUT | A0 through A13 comprise the address bus. | HOLDA | 2 | | 39 | READY | | A2 | 15 | OUT | This 3-state bus provides the memory- | | 7 | | E | | | A3 | 14 | OUT | address vector to the external-memory sys- | IAQ | 3 📙 | | 38 | WE | | A4 | 13 | OUT | tem when MEMEN is active and I/O-bit | A13/CRUOUT | 4 📙 | | 37 | CRUCLK | | A5 | 12 | OUT | addresses and external-instruction addresses to the I/O system when MEMEN is inactive. | A12 | 5 🗌 | | □ 36 | $v_{DD}$ | | A6 | 11 | OUT | The address bus assumes the high-impedance | A11 | 6 🗍 | : | 35 | VSS | | A7<br>A8 | 10 | OUT | state when HOLDA is active. | A10 | 7 🗍 | | 34 | CKIN | | A8<br>A9 | 8 | OUT | State Wileli (10 EDA 18 doctro) | | 8 | | E | OSCOUT | | A10 | 7 | OUT | | А9 | 71 | | 33 | | | A11 | 6 | OUT | | A8 | 9 📗 | | 32 | D7 | | A12 | 5 | OUT | | A7 | 10 🔲 | | <b>_</b> 31 | D6 | | A13/CRUOUT | 4 | OUT | CRUOUT | A6 | 11 | | 30 | D5 | | | | | Serial I/O data appears on A13 when an | A5 | 12 | | 29 | D4 | | | | | LDCR, SBZ and SBO instruction is execu- | | - 7 | | 5 | | | | | | ted. This data should be sampled by the I/O | A4 | 13 | | 28 | D3 | | | | | interface logic when CRUCLK goes active | A3 | 14 📙 | | 27 | D2 | | | | | (high). One bit of the external instruction | A2 | 15 | | 26 | D1 | | | | | code appears on A13 during external in- | A1 | 16 | | 25 | D0 0 | | | l | | struction execution. | AO | 17 | | 24 | INT 0 | | | | | DATA BUS | | 18 | | 23 | INT 1 | | D0 (MSB) | 25 | 1/0 | DO through D7 comprise the bidirectional | DBIN | 긤 | | iF3 | | | D1 | 26 | 1/0 | 3-state data bus. This bus transfers memory | CRUIN | 19 | | 22 | INT 2 | | D2 | 27 | 1/0 | data to (when writing) and from (when | Vcc | 20 🔲 | | 21 | <b>φ3</b> | | D3<br>D4 | 28 | 1/0 | reading) the external-memory system when | • | <u></u> | - | | | | D5 | 30 | 1/0 | MEMEN is active. The data bus assumes the | | | | | | | D6 | 31 | 1/0 | high-impedance state when HOLDA is | | | | | | | D7 (LSB) | 32 | 1/0 | active. | | | | | | | D7 (200) | " | '' | | | | | | | | | | | POWER SUPPLIES | | | | | | | V <sub>CC</sub> | 20 | | Supply voltage (5 V NOM) | | | | | | | V <sub>DD</sub> | 36 | | Supply voltage (12 V NOM) | | | | | | | VSS | 35 | | Ground reference | | | | | | | | 1 | | | | | | | | | CKIN | 34 | IN | | CLOCKS | | to concrete | tha inta | rnal 4.nhas | | OSCOUT | 33 | OUT | Clock In and Oscillator Out. These pins may | be used in either of | Lic connec | sted between i | CKIN at | nd OSCOU | | | | | clock. In mode 1 a crystal of 4 times the desire<br>(see Figure 13). In mode 2 OSCOUT is left fl | ed system trequency | y is connec | va TTI comm | atible S | ource whos | | | | | | | S CHIVEH D | y a 112 comp | u | | | | 1 | | frequency is 4 times the desired system frequen | icy. | | | | | | φ3 | 21 | ОИТ | Clock phase 3 ( $\phi$ 3) inverted; used as a timing r | eference. | | | | | | DBIN | 18 | OUT | | BUS CONTROL | | | | | | | | | Data bus in. When active (high), DBIN indica | tes that the TMS $\frac{9}{2}$ | 981 has d | isabled its out | put buf | ters to allo | | | 1 | 1 | the memory to place memory-read data on th | e data bus during N | IEMEN. D | BIN remains I | ow in al | i other case | | | 1 | 1 | except when HOLDA is active at which time in | t is in the high-impe | dance stat | te. | | | ## TABLE 3 (CONTINUED) | SIGNATURE | PIN | 1/0 | | |-----------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | DESCRIPTION | | MEMEN | 40 | ООТ | Memory enable. When active (low), MEMEN indicates that the address bus contains a memory address. When HOLDA is active, MEMEN is in the high-impedance state. | | WE | 38 | OUT | Write enable. When active (low), WE indicates that memory-write data is available from the TMS 9981 to be written into memory. When HOLDA is active, WE is in the high-impedance state. | | CRUCLK | 37 | OUT | CRU clock. When active (high), CRUCLK indicates that external interface logic should sample the output data on CRUOUT or should decode external instructions on A0, A1, A13. | | CRUIN | 19 | IN | CRU data in. CRUIN, normally driven by 3-state or open-collector devices, receives input data from external interface logic. When the processor executes a STCR or TB instruction, it samples CRUIN for the level of the CRU input bit specified by the address bus (A2 through A12). | | INT2 | 22 | IN | Interrupt code. Refer to Section 2.2 for detailed description. | | INT1 | 23 | IN | | | INTO | 24 | IN | | | HOLD | 1 | IN | MEMORY CONTROL | | | | | Hold. When active (low), HOLD indicates to the processor that an external controller (e.g., DMA device) desires to utilize the address and data buses to transfer data to or from memory. The TMS 9981 enters the hold state following a hold signal when it has completed its present memory cycle.* The processor then places the address and data buses in the high-impedance state (along with WE, MEMEN, and DBIN) and responds with a hold-acknowledge signal (HOLDA). When HOLD is removed, the processor returns to normal operation. | | HOLDA | 2 | OUT | Hold acknowledge. When active (high), HOLDA indicates that the processor is in the hold state and the address and data buses and memory control outputs (WE, MEMEN, and DBIN) are in the high-impedance state. | | READY | 39 | IN | Ready. When active (high), READY indicates that memory will be ready to read or write during the next clock cycle. When not-ready is indicated during a memory operation, the TMS 9981 enters a wait state and suspends internal operation until the memory systems indicated ready. | | IAQ | 3 | OUT | TIMING AND CONTROL | | 1 | | | Instruction acquisition. IAQ is active (high) during any memory cycle when the TMS 9981 is acquiring an instruction IAQ can be used as all with the second control of | | • | • | • | instruction. IAQ can be used to detect illegal op codes. It may also be used to synchronize LOAD stimulus | op codes. It may also be used to synchronize LOAD stimulus. #### 2.10 TIMING #### 2.10.1 Memory Basic memory read and write cycles are shown in Figures 9a and 9b. Figure 9a shows a read and a write cycle with no wait states while Figure 9b shows a read and a write cycle for a memory requiring one wait state. MEMEN goes active (low) during each memory cycle. At the same time that MEMEN is active, the memory address appears on the address bits A0 through A13. Since the TMS 9980A/TMS 9981 has an 8-bit data bus, every memory operation consists of two consecutive memory cycles. Address bit A13 is 0 for the first of the two cycles and goes to 1 for the second. If the cycle is a memory-read cycle, DBIN will go active (high) at the same time MEMEN and A0 through A13 become valid. The memory-write ( $\overline{WE}$ ) signal remains inactive during a read cycle. The READY signal allows extended memory cycle as shown in Figure 9b. <sup>\*</sup>If the cycle following the present memory cycle is also a memory cycle it, too, is completed before TMS 9981 enters hold state. FIGURE 9a - TMS 9980A/TMS 9981 MEMORY BUS TIMING (NO WAIT STATES) FIGURE 9b - TMS 9980A/TMS 9981 MEMORY BUS TIMING (ONE WAIT STATE) At the end of the read cycle, MEMEN and DBIN go inactive (high and low respectively). The address bus also changes at this time, however, the data bus remains in the input mode for one clock cycle after the read cycle. A write cycle is similar to read cycle except that $\overline{\text{WE}}$ goes active (low) as shown and valid write data appears on the data bus at the same time the address appears. #### 2.10.2 HOLD Other interfaces may utilize the TMS 9980A/TMS 9981 memory bus by using the hold operation (illustrated in Figure 10) of the TMS 9980A/TMS 9981. When $\overline{\text{HOLD}}$ is active (low), the TMS 9980A/TMS 9981 enters the hold state at the next available non-memory cycle clock period. When the TMS 9980A/TMS 9981 has entered the hold state HOLDA goes active (high), A0 through A13, D0 through D7, DBIN, $\overline{\text{MEMEN}}$ , and $\overline{\text{WE}}$ go into high-impedance state to allow other devices to use the memory buses. When $\overline{\text{HOLD}}$ goes inactive, TMS 9980A/TMS 9981 resumes processing as shown. Considering that there can be a maximum of 6 consecutive memory operations, the maximum delay between $\overline{\text{HOLD}}$ going active to HOLDA going active (high) could be $t_{\text{C}}(\phi)$ (for set up) + (12 + 6 W) $t_{\text{C}}(\phi)$ (delay for HOLDA), where W is the number of wait states per memory cycle and $t_{\text{C}}(\phi)$ is the clock cycle time. If hold occurs during a CRU operation, the TMS 9980A/TMS 9981 uses an extra clock cycle (after the removal of the $\overline{\text{HOLD}}$ signal) to reassert the CRU address providing the normal setup times for the CRU bit transfer that was interrupted. #### 2.10.3 CRU CRU interface timing is shown in Figure 11. The timing for transferring two bits out and one bit in is shown. These transfers would occur during the execution of a CRU instruction. The other cycles of the instruction execution are not illustrated. To output a CRU bit, the CRU-bit address is placed on the address bus A2 through A12 and the actual bit data on A13. During the second clock cycle a CRU pulse is supplied by CRUCLK. This process is repeated until the number of bits specified by the instruction are completed. The CRU input operation is similar in that the bit address appears on A2 through A12. During the subsequent cycle, the TMS 9980A/TMS 9981 accepts the bit input data as shown. No CRUCLK pulses occur during a CRU input operation. #### 2.10.4 Interrupt Code (ICO-IC2) The TMS 9980A/TMS 9981 uses 4 phase clock ( $\phi$ 1, $\phi$ 2, $\phi$ 3, and $\phi$ 4) for timing and control of the internal operations. ICO-IC2 are sampled during $\phi$ 4 and then during $\phi$ 2. If these two successive samples are equal, the code is accepted and latched for internal use on the subsequent $\phi1$ . In systems with simple interrupt structures this allows the interrupt code to change asynchronously without the TMS 9980A/TMS 9981 accepting erroneous codes. Figure 3 shows systems with a single level of external interrupt implemented that would require no external timing. When implementing multiple external interrupts, as in the bottom diagram of Figure 3, external synchronization of interrupt requests is required. See Figure 12 for a timing diagram. In systems with more than one external interrupt, the interrupts should be synchronized with the $\overline{\phi3}$ output of the TMS 9980A/TMS 9981 to avoid code transitions on successive sample cycles. This synchronization ensures that the TMS 9980A/TMS 9981 will service only the proper active interrupt level. FIGURE 10 - TMS 9980A/TMS 9981 HOLD TIMING FIGURE 11 - TMS 9980A/TMS 9981 CRU INTERFACE TIMING FIGURE 12 - INTERRUPT CODE TIMING # 3. TMS 9980A/TMS 9981 INSTRUCTION SET #### 3.1 DEFINITION The instruction set of the TMS 9980A/TMS 9981 is identical to that of TMS 9900. Each instruction of this set performs one of the following operations: - Arithmetic, logical, comparison, or manipulation operations on data - Loading or storage of internal registers (program counter, workspace pointer, or status) - Data transfer between memory and external devices via the CRU - Control functions. #### 3.2 ADDRESSING MODES TMS 9980A/TMS 9981 instructions contain a variety of available modes for addressing random-memory data (e.g., program parameters and flags), or formatted memory data (character strings, data lists, etc.). The following figures graphically describe the derivation of the effective address for each addressing mode. The applicability of addressing modes to particular instructions is described in Section 3.5 along with the description of the operations performed by the instruction. The symbols following the names of the addressing modes [R, \*R, \*R+, @ LABEL, or @ TABLE (R)] are the general forms used by TMS 9980A/TMS 9981 assemblers to select the addressing mode for register R. Note that the TMS 9980A/TMS 9981 users use the same assembler and other software support packages as the ones used by the TMS 9900 users. ## 3.2.1 WORKSPACE REGISTER ADDRESSING R Workspace Register R contains the operand. # 3.2.2 WORKSPACE REGISTER INDIRECT ADDRESSING \*R Workspace Register R contains the address of the operand. # 3.2.3 WORKSPACE REGISTER INDIRECT AUTO INCREMENT ADDRESSING \*R+ Workspace Register R contains the address of the operand. After acquiring the operand, the contents of workspace register R are incremented. # 3.2.4 SYMBOLIC (DIRECT) ADDRESSING @LABEL The word following the instruction contains the address of the operand. ## 3.2.5 INDEXED ADDRESSING @ TABLE (R) The word following the instruction contains the base address. Workspace register R contains the index value. The sum of the base address and the index value results in the effective address of the operand. #### 3.2.6 IMMEDIATE ADDRESSING The word following the instruction contains the operand. # 3.2.7 PROGRAM COUNTER RELATIVE ADDRESSING The 8-bit signed displacement in the right byte (bits 8 through 15) of the instruction is multiplied by 2 and added to the updated contents of the program counter. The result is placed in the PC. #### 3.2.8 CRU RELATIVE ADDRESSING The 8-bit signed displacement in the right byte of the instruction is added to the CRU base address (bits 3 through 14 of the workspace register 12). The result is the CRU address of the selected CRU bit. ## 3.3 TERMS AND DEFINITIONS The following terms are used in describing the instructions of the TMS $9980A/TMS\ 9981$ . | TERM | DEFINITION | |----------------|----------------------------------------------| | В | Byte indicator (1=byte, 0 = word) | | c | Bit count | | D | Destination address register | | DΑ | Destination address | | IOP | Immediate operand | | LSB(n) | Least significant (right most) bit of (n) | | MSB(n) | Most significant (left most) bit of (n) | | N | Don't care | | PC | Program counter | | Result | Result of operation performed by instruction | | S | Source address register | | SA | Source address | | ST | Status register | | STn | Bit n of status register | | = | Destination address modifier | | ⊤ <sub>D</sub> | Source address modifier | | | Workspace register | | w<br>WRn | Workspace register n | | **** | Contents of n | | (n) | a is transferred to b | | a→b | Absolute value of n | | In I | Arithmetic addition | | <b>†</b> | Arithmetic subtraction | | - | Logical AND | | AND | Logical OR | | OR | Logical exclusive OR | | <b>⊕</b><br>_ | Logical complement of n | | n . | Logical completion | # 3.4 STATUS REGISTER The status register contains the interrupt mask level and information pertaining to the instruction operation. | | 9.000 | - | | | | | | | | | | | | 4.0 | | 15 | | |--------|-------|-----|-----|-----|-----|-----|-----|---|-----|------|------|------|-------|---------|---------|-------|---| | 0 | | | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | - 11 | 12 | 13 | 14 | 15 | | | | | | | | | | | | | | | | 1 | | | | | | ST | o s | T 1 | ST2 | ST3 | ST4 | ST5 | ST6 | | not | used | (=0) | | ST 12 | ST13 | ST14 | ST 15 | | | 1. | ۳, | . | 0.2 | | | | ¥ | ĺ | | | | | 1 | nterrup | ot Mask | | ĺ | | - 1 L2 | > A | .> | . = | · | U | F | ^ | 1 | | | | | | | | | | | BIT | NAME | INSTRUCTION | | | | | | | | | |------|------------|-------------|---------------------------------------------------------|--|--|--|--|--|--|--| | STO. | LOGICAL | C.CB | If MSB(SA) = 1 and MSB(DA) = 0, or if MSB(SA) = MSB(DA) | | | | | | | | | 310 | GREATER | • | and MSB of [(DA) - (SA)] = 1 | | | | | | | | | | THAN | CI | If MSB(W) = 1 and MSB of IOP = 0, or if MSB(W) = MSB of | | | | | | | | | | 11101 | 0. | IOP and MSB of [IOP - (W)] = 1 | | | | | | | | | | | ABS | If (SA) ≠ 0 | | | | | | | | | | | All Others | If result ≠ 0 | | | | | | | | | ST1 | ARITHMETIC | C.CB | If MSB(SA) = 0 and MSB(DA) = 1, or if MSB(SA) = MSB(DA) | | | | | | | | | 311 | GREATER | | and MSB of [(DA) - (SA)] = 1 | | | | | | | | | | THAN | CI | If MSB(W) = 0 and MSB of IOP = 1, or if MSB(W) = MSB of | | | | | | | | | | IDAN | " | IOP and MSB of [IOP - (W)] = 1 | | | | | | | | | | | ABS | If MSB(SA) = 0 and (SA) $\neq$ 0 | | | | | | | | | | | All Others | If MSB of result = 0 and result ≠ 0 | | | | | | | | - Continued | BIT | NAME | INSTRUCTION | CONDITION TO SET BIT TO 1 | | | | | |-----------|-----------|----------------------|---------------------------------------------------------|--|--|--|--| | ST2 | EQUAL | C, CB | If (SA) = (DA) | | | | | | | | CI | If (W) = IOP | | | | | | | | coc | If (SA) and $\overline{(DA)} = 0$ | | | | | | | | czc | If (SA) and (DA) = 0 | | | | | | | | ТВ | If CRUIN = 1 | | | | | | | | ABS | If (SA) = 0 | | | | | | | | All others | If result = 0 | | | | | | ST3 | CARRY | A, AB, ABS, AI, DEC, | | | | | | | | | DECT, INC, INCT, | If CARRY OUT = 1 | | | | | | | | NEG, S, SB | | | | | | | | | SLA, SRA, SRC, SRL | If last bit shifted out = 1 | | | | | | ST4 | OVERFLOW | A, AB | If MSB(SA) = MSB(DA) and MSB of result = MSB(DA) | | | | | | | | AI | If MSB(W) = MSB of IOP and MSB of result = MSB(W) | | | | | | | | S, SB | If MSB(SA) + MSB(DA) and MSB of result + MSB(DA) | | | | | | | | DEC, DECT | If MSB(SA) = 1 and MSB of result = 0 | | | | | | | | INC, INCT | If MSB(SA) = 0 and MSB of result - 1 | | | | | | | | SLA | If MSB changes during shift | | | | | | | | DIV | If MSB(SA) = 0 and MSB(DA) = 1, or if MSB(SA) = MSB(DA) | | | | | | | | | and MSB of $[(DA) - (SA)] = 0$ | | | | | | | | ABS, NEG | If (SA) = 8000 <sub>16</sub> | | | | | | ST5 | PARITY | CB, MOVB | If (SA) has odd number of 1's | | | | | | | | LDCR, STCR | If 1 ≤ C ≤ 8 and (SA) has odd number of 1's | | | | | | | | AB, SB, SOCB, SZCB | If result has odd number of 1's | | | | | | ST6 | XOP | XOP | If XOP instruction is executed | | | | | | ST12-ST15 | INTERRUPT | LIMI | If corresponding bit of !OP is 1 | | | | | | | MASK | RTWP | If corresponding bit of WR15 is 1 | | | | | #### 3.5 INSTRUCTIONS # 3.5.1 Dual Operand Instructions with Multiple Addressing Modes for Source and Destination Operand | | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|---|-------|---|---|---|---|---|---|---|---|----|----|----|----|----|----| | General format: | c | P COE | E | В | Т | D | | D | | | Т | s | | S | | | If B = 1 the operands are bytes and the operand addresses are byte addresses. If B = 0 the operands are words and the operand addresses are word addresses. The addressing mode for each operand is determined by the T field of that operand. | T <sub>S</sub> OR T <sub>D</sub> | S OR D | ADDRESSING MODE | NOTES | |----------------------------------|----------|--------------------------------------------|-------| | 00 | 0, 1, 15 | Workspace register | 1 | | 01 | 0, 1, 15 | Workspace register indirect | ' | | 10 | 0 | Symbolic | 4 | | 10 | 1, 2, 15 | Indexed | 2,4 | | 11 | 0, 1, 15 | Workspace register indirect auto-increment | 2,4 | NOTES 1. When a workspace register is the operand of a byte instruction (bit 3 = 1), the left byte (bits 0 through 7) is the operand and the right byte (bits 8 through 15) is unchanged. <sup>2.</sup> Workspace register 0 may not be used for indexing. <sup>3.</sup> The workspace register is incremented by 1 for byte instructions (bit 3 = 1) and is incremented by 2 for word instructions (bit 3 = 0). <sup>4.</sup> When $T_S = T_D = 10$ , two words are required in addition to the instruction word. The first word is the source operand base address and the second word is the destination operand base address, | AMIENOMIC | ОР | OP CODE | | В | MEANING | RESULT<br>COMPARED | STATUS<br>BITS | DESCRIPTION | |-------------|----|---------|---|---|--------------------------------|--------------------|----------------|-------------------------------------------------------------------------------| | MNEMONIC | 0 | 1 | 2 | 3 | MEANING | то 0 | AFFECTED | | | A | 1 | 0 | 1 | 0 | Add | Yes | 0-4 | (SA)+(DA) → (DA) | | AB | 1 | 0 | 1 | 1 | Add bytes | Yes | 0-5 | (SA)+(DA) -+ (DA) | | C | ' | 0 | 0 | 0 | Compare | No | 0-2 | Compare (SA) to (DA) and set | | СВ | 1 | 0 | - | 1 | Compare bytes | No | 0-2,5 | appropriate status bits Compare (SA) to (DA) and set appropriate status bits | | S | n | 1 | 1 | 0 | Subtract | Yes | 0-4 | (DA) - (SA) → (DA) | | SB | 0 | | 1 | 1 | Subtract bytes | Yes | 0-5 | (DA) - (SA) → (DA) | | SOC | 1 | 1 | 1 | 0 | Set ones corresponding | Yes | 0.2 | (DA) OR (SA) → (DA) | | SOCB | 1 | 1 | 1 | 1 | Set ones corresponding bytes | Yes | 0-2,5 | (DA) OR (SA) → (DA) | | SZC | 0 | 1 | Ċ | 0 | Set zeroes corresponding | Yes | 0-2 | (DA) AND (SA) → (DA) | | SZCB | 0 | | - | 1 | Set zeroes corresponding bytes | Yes | 0-2,5 | (DA) AND (SA) → (DA) | | | 1 | 1 | 0 | 0 | Move | Yes | 0-2 | (SA) → (DA) | | MOV<br>MOVB | 1 | 1 | 0 | 1 | Move bytes | Yes | 0-2,5 | (SA) → (DA) | # 3.5.2 Dual Operand Instructions with Multiple Addressing Modes for the Source Operand and Workspace Register Addressing for the Destination | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|---|---|-------|-----|---|---|---|---|---|---|----|----|----|----|----|----| | General format: | | | OP CC | DDE | | | | D | | | 1 | s | | | S | | The addressing mode for the source operand is determined by the Ts field. | To | s | ADDRESSING MODE | NOTES | |----|----------|--------------------------------------------|-------| | 00 | 0, 1, 15 | Workspace register | | | 01 | 0, 1, 15 | Workspace register indirect | | | 10 | 0 | Symbolic | | | 10 | 1, 2, 15 | Indexed | 1 | | 11 | 0, 1, 15 | Workspace register indirect auto increment | 2 | NOTES: 1, Workspace register 0 may not be used for indexing. <sup>2.</sup> The workspace register is incremented by 2. | MNEMONIC | OP CODE<br>0 1 2 3 4 5 | MEANING | RESULT<br>COMPARED<br>TO 0 | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|------------------------|---------------|----------------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | coc | 001000 | Compare ones | No | 2 | Test (D) to determine if 1's are in each bit position where 1's are in (SA). If so, set ST2. | | czc | 001001 | Compare zeros | No | 2 | Test (D) to determine if 0's are in each bit position where 1's are in (SA). If so, set ST2. | | XOR | 001010 | Exclusive OR | Yes | 0-2 | (D) $\bigoplus$ (SA) $\rightarrow$ (D) Multiply unsigned (D) by unsigned (SA) and | | MPY | 001110 | Multiply | No No | | place unsigned 32-bit product in D (most significant) and D+1 (least significant). If WR15 is D, the next word in memory after WR15 will be used for the least significant half of the product. | | DIV | 001111 | Divide | No | 4 | If unsigned (SA) is less than or equal to unsigned (D), perform no operation and set ST4. Otherwis divide unsigned (D) and (D+1) by unsigned (SA). Quotient + (D), remainder + (D+1). If D = 15, the next word in memory after WR 15 will be used for the remainder. | ## 3.5.3 Extended Operation (XOP) Instruction General format: 1 D $\mathsf{T}_\mathsf{S}$ The $T_S$ and S fields provide multiple mode addressing capability for the source operand. When the XOP is executed, ST6 is set and the following transfers occur: $(40_{16} + 4D) \rightarrow (WP)$ (42<sub>16</sub> + 4D) → (PC) SA → (new WR11) (old WP) → (new WR13) (old PC) $\rightarrow$ (new WR14) (old ST) $\rightarrow$ (new WR15) The TMS 9980A/TMS 9981 tests for reset and load but does not test for interrupt requests (INTREQ) upon completion of the XOP instruction. ## 3.5.4 Single Operand Instructions 5 11 13 General format: OP CODE тs s The $\mathsf{T}_{\mathsf{S}}$ and $\mathsf{S}$ fields provide multiple mode addressing capability for the source operand. | MNEMONIC | OP CODE | MEANING | RESULT | STATUS | | |----------------|------------|-------------------|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------| | | 0123456789 | MEANING | COMPARED | BITS | DESCRIPTION | | В | 0000010001 | 15 . | TO 0 | AFFECTED | | | BL | | Branch | No | - | SA (PC) | | BLWP | 0000011010 | Branch and link | No | - | (PC) → (WR11); SA → (PC) | | BLVVP | 0000010000 | Branch and load | No | - | (SA) →(WP); (SA+2) →(PC); | | | | workspace pointer | | | (old WP) → (new WR 13); | | | | | | | (old PC) → (new WR14); | | | | | | | (old ST) → (new WR15); The TMS 9980A/TMS 9981 tests for reset and load, but does not test for interrupts upon completion of the BLWP instruction. | | CLR | 0000010011 | Clear operand | No | | 0 → (SA) | | SETO | 0000011100 | Set to ones | No | _ | FFFF16 → (SA) | | INV | 0000010101 | Invert | Yes | 0-2 | (SA) → (SA) | | NEG | 0000010100 | Negate | Yes | 0-4 | -(SA) → (SA) | | ABS | 0000011101 | Absolute value* | No | 0-4 | (SA) → (SA) | | SWPB | 0000011011 | Swap bytes | No | _ | (SA), bits 0 thru 7 → (SA), bits<br>8 thru 15; (SA), bits 8 thru 15 →<br>(SA), bits 0 thru 7. | | INC | 0000010110 | Increment | Yes | 0-4 | (SA) + 1 → (SA) | | INCT | 0000010111 | Increment by two | Yes | 0-4 | (SA) + 2 → (SA) | | DEC | 0000011000 | Decrement | Yes | 0-4 | (SA) - 1 → (SA) | | DECT | 0000011001 | Decrement by two | Yes | 0-4 | (SA) - 2 → (SA) | | χ <sup>†</sup> | 0000010010 | Execute | No | - | Execute the instruction at SA. | Operand is compared to zero for status bit. If additional memory words for the execute instruction are required to define the operands of the instruction located at SA, these words will be accessed from PC and the PC will be updated accordingly. The instruction acquisition signal (IAQ) will not be true when the TMS 9900 accesses the instruction at SA. Status bits are affected in the normal manner for the instruction executed. #### 3.5.5 CRU Multiple-Bit Instructions | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|---|---|------|-----|---|---|---|---|---|---|----|----|----|----|----|----| | General format: | | | OP C | ODE | | | | | : | | т | s | | | 3 | | | | | | | | | | | | | | | | | | | | The C field specifies the number of bits to be transferred. If C = 0, 16 bits will be transferred. The CRU base registr (WR12, bits 4 through 14) defines the starting CRU bit address. The bits are transferred serially and the CRU address is incremented with each bit transfer, although the contents of WR12 is not affected. Ts and S provide multiple mode addressing capability for the source operand. If 8 or fewer bits are transferred (C = 1 through 8), the source address is a byte address. If 9 or more bits are transferred (C = 0, 9 through 15), the source address is a word address. If the source is addressed in the workspace register indirect auto increment mode, the workspace register is incremented by 1 if C = 1 through 8, and is incremented by 2 otherwise. | MNEMONIC | OP CODE - | MEANING | RESULT<br>COMPARED<br>TO 0 | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|-----------|------------------------------|----------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------| | LDCR | 001100 | Load communication register | Yes | 0-2,5 <sup>†</sup> | Beginning with LSB of (SA), transfer the<br>specified number of bits from (SA) to<br>the CRU. | | STCR | 001101 | Store communication register | Yes | 0-2,5 <sup>†</sup> | Beginning with LSB of (SA), transfer the specified number of bits from the CRU to (SA). Load unfilled bit positions with 0. | <sup>&</sup>lt;sup>†</sup>ST5 is affected only if $1 \le C \le 8$ . #### 3.5.6 CRU Single-Bit Instructions CRU relative addressing is used to address the selected CRU bit. | MNEMONIC | OP CODE<br>0 1 2 3 4 5 6 7 | MEANING | STATUS<br>BITS<br>AFFECTED | DESCRIPTION | |----------|----------------------------|-----------------|----------------------------|---------------------------------------------| | SBO | 00011101 | Set bit to one | T - | Set the selected CRU output bit to 1. | | 1 | 00011110 | Set bit to zero | _ | Set the selected CRU output bit to 0. | | SBZ | | | , | If the selected CRU input bit = 1, set ST2. | | TB | 00011111 | Test bit | <del></del> | | #### 3.5.7 Jump Instructions Jump instructions cause the PC to be loaded with the value selected by PC relative addressing if the bits of ST are at specified values. Otherwise, no operation occurs and the next instruction is executed since PC points to the next instruction. The displacement field is a word count to be added to PC. Thus, the jump instruction has a range of -128 to 127 words from memory-word address following the jump instruction. No ST bits are affected by jump instructions. | MNEMONIC | OP CODE | | | | |-----------|---------------|---|--------------------|-------------------------| | MINEMONIC | 0 1 2 3 4 5 6 | 7 | MEANING | ST CONDITION TO LOAD PC | | JEØ. | 0001001 | 1 | Jump equal | ST2 = 1 | | JGT | 0001010 | 1 | Jump greater than | ST1 = 1 | | JH | 0 0 0 1 1 0 1 | 1 | Jump high | ST0 = 1 and ST2 = 0 | | JHE | 0001010 | 0 | Jump high or equal | ST0 = 1 or ST2 = 1 | | JL | 0001101 | 0 | Jump low | ST0 = 0 and ST2 = 0 | | JLE | 0001001 | 0 | Jump low or equal | ST0 = 0 or ST2 = 1 | | JLT | 0001000 | 1 | Jump less than | ST1 = 0 and ST2 = 0 | | JMP | 0001000 | 0 | Jump unconditional | unconditional | | JNC | 0001011 | 1 | Jump no carry | ST3 = 0 | | JNE | 0001011 | 0 | Jump not equal | ST2 = 0 | | JNO | 0001100 | 1 | Jump no overflow | ST4 = 0 | | JOC | 0001100 | 0 | Jump on carry | ST3 = 1 | | JOP | 0001110 | 0 | Jump odd parity | ST5 = 1 | #### 3.5.8 Shift Instructions | | <br>1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|-------|---|-------|-----|---|---|---|---|---|----|----|----|----|----|----| | General format: | <br> | | OP CC | DDE | | | | | | 5 | | | V | v | | If C = 0, bits 12 through 15 of WR0 contain the shift count. If C = 0 and bits 12 through 15 of WR0 = 0, the shift count is 16. | MNEMONIC OP CODE | | | | | | | | | RESULT | STATUS | | |------------------|---|-----|-------------------------|---------|-------------------------------------|-------------------------------------------|------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | MEANING | TO 0 | BITS<br>AFFECTED | DESCRIPTION | | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | Shift left arithmetic | Yes | 0-4 | Shift (W) left. Fill vacated bit | | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | Shift right arithmetic | Yes | 0-3 | positions with 0. Shift (W) right. Fill vacated bit | | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | Shift right circular | Yes | 0-3 | positions with original MSB of (W).<br>Shift (W) right, Shift previous LSB | | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | Shift right logical | Yes | 0-3 | into MSB. Shift (W) right, Fill vacated bit positions with 0's. | | | 0 | 0 0 | 0 1 2<br>0 0 0<br>0 0 0 | 0 1 2 3 | 0 1 2 3 4<br>0 0 0 0 1<br>0 0 0 0 1 | 0 1 2 3 4 5<br>0 0 0 0 1 0<br>0 0 0 0 1 0 | 0 1 2 3 4 5 6<br>0 0 0 0 1 0 1<br>0 0 0 0 1 0 0<br>0 0 0 0 1 0 1 | OP CODE 0 1 2 3 4 5 6 7 0 0 0 0 1 0 1 0 0 0 0 0 0 1 0 1 1 0 0 0 0 | 0 1 2 3 4 5 6 7 0 0 0 0 1 0 1 0 Shift left arithmetic 0 0 0 0 1 0 0 Shift right arithmetic 0 0 0 0 1 0 1 1 Shift right circular | MEANING COMPARED TO 0 0 0 0 1 0 0 0 0 1 0 0 | O 1 2 3 4 5 6 7 MEANING COMPARED TO 0 BITS AFFECTED 0 0 0 0 1 0 1 0 1 0 Shift left arithmetic Yes 0.4 0 0 0 0 1 0 1 0 1 1 Shift right arithmetic Yes 0.3 0 0 0 0 0 1 0 1 1 Shift right circular Yes 0.3 | # 3.5.9 Immediate Register Instructions | MNEMONIC | INEMONIC OP CODE | | RESULT | STATUS | | |-----------|------------------------|----------------|--------|------------------|----------------------------| | MITEMORIC | 0 1 2 3 4 5 6 7 8 9 10 | MEANING | TO 0 | BITS<br>AFFECTED | DESCRIPTION | | ΑI | 00000010001 | Add immediate | Yes | 0-4 | (W) + IOP → (W) | | ANDI | 00000010010 | AND immediate | Yes | 0-2 | (W) AND IOP → (W) | | CI | 00000010100 | Compare | Yes | 0.2 | Compare (W) to IOP and set | | | | immediate | | | appropriate status bits | | LI | 00000010000 | Load immediate | Yes | 0-2 | IOP → (W) | | ORI | 00000010011 | OR immediate | Yes | 0-2 | (W) OR IOP → (W) | #### 3.5.10 Internal Register Instruction | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|---|---|---|---|---|-------|-----|-----|---|---|----|----|----|----|----|----| | General format: | | | | | | OP CC | DDE | | | | | | | N | | | | | | | | | | | | IOP | | | | | | | | | | | | | | - ( | OP. | co | DE | | | | | MEANING | DESCRIPTION | |----------|---|---|---|-----|-----|----|----|---|---|---|----|----------------------------------|----------------------------------------------| | MNEMONIC | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | MEANING | DESCRIPTION | | LWPI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | Load workspace pointer immediate | $IOP \rightarrow (WP)$ , no ST bits affected | | LIMI | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | Load interrupt mask | IOP, bits 12 thru 15 → ST12 | | | i | | | | | | | | | | | | thru ST15 | ## 3.5.11 Internal Register Store Instructions | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | |-----------------|---|---|---|---|---|-------|-----|---|---|---|----|----|----|----|----|----| | General format: | | | | | | OP CO | DDE | | | | | N | | V | ٧ | | No ST bits are affected. | MNEMONIC | OP CODE | MEANING DESCRIPTION | |-----------|---------------------------------|--------------------------------------| | MINEMONIC | 0 1 2 3 4 5 6 7 8 9 10 | MEANING SCOOM (101 | | STST | 0 0 0 0 0 0 1 0 1 1 0 Store sta | itus register $(ST) \rightarrow (W)$ | | STWP | 0 0 0 0 0 0 1 0 1 0 1 Store wo | orkspace pointer (WP) → (W) | #### 3.5.12 Return Workspace Pointer (RTWP) Instruction | | 0 | | | | | | | | | | | | | <br>15 | |-----------------|---|---|---|---|---|---|---|---|---|---|---|--|---|--------| | General format: | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | | N | | The RTWP instruction causes the following transfers to occur: (WR15) → (ST) (WR14) → (PC) $(WR13) \rightarrow (WP)$ #### 3.5.13 External Instructions External instructions cause the three address lines (A13; A0, A1) to be set to the below-described levels and the CRUCLK line to be pulsed, allowing external control functions to be initiated. | | | | | | c | )P | C | 00 | E | | | | | MEANING | STATUS<br>BITS | DESCRIPTION | | DDRESS<br>BUS | | | |----------|---|-----|-----|---|---|----|---|----|---|-----|-----|---|---|--------------|----------------|-----------------------------|-----|---------------|----|--| | MNEMONIC | | 0 | 1 : | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 1 | 0 | III CANTO | AFFECTED | | A13 | A0 | A1 | | | IDLE | t | 0 ( | ) ( | 0 | 0 | 0 | 0 | 1 | 1 | . 0 | 1 | ( | 0 | idie | _ | Suspend TMS 9980/9981 | L | Н | L | | | | | | | | | | | | | | | | | | | instruction execution until | | | | | | | | | | | | | | | | | | | | | | an interrupt, LOAD, or | | | | | | | | | | | | | | | | | | | | | | RESET occurs | | | | | | RSET | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | ( | ) 1 | | 1 | Reset | 12-15 | 0 → ST12 thru ST15 | L | Н | Н | | | CKOF | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 1 | 1 | i | 0 | User defined | | | н | Η. | L | | | CKON | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 1 | ( | ) | 1 | User defined | | | н | L | н | | | LREX | | o | | | | | | | | | | | 1 | User defined | | | H | Н | Н | | #### 3.6 TMS 9980A/TMS 9981 INSTRUCTION EXECUTION TIMES Instruction execution times for the TMS 9980A/TMS 9981 are a function of: - Clock cycle time, t<sub>C</sub>(φ) - 2) Addressing mode used where operands have multiple addressing mode capability - 3) Number of wait states required per memory access. Table 4 lists the number of clock cycles and memory accesses required to execute each TMS 9980A/TMS 9981 instruction. For instructions with multiple addressing modes for either or both operands, Table 4 lists the number of clock cycles and memory accesses with all operands addressed in the workspace-register mode. To determine the additional number of clock cycles and memory accesses required for modified addressing, add the appropriate values from the referenced tables. The total instruction-execution time for an instruction is: $$T = t_{C(\phi)} (C+W \cdot M)$$ where: T = total instruction time; $t_{c(\phi)} = clock cycle time;$ C = number of clock cycles for instruction execution plus address modification; W = number of required wait states per memory access for instruction execution plus address modification; M = number of memory accesses. As an example, the instruction MOVB is used in a system with $t_{c(\phi)} = 0.400 \mu s$ and no wait states are required to access memory. Both operands are addressed in the workspace register mode: T = $$t_{C(\phi)}$$ (C+W•M) = 0.400 (22+0•8) = 8.8 $\mu$ s. If two wait states per memory access were required, the execution time is: T = 0.400 (22 + 2.8) $$\mu$$ s = 15.2 $\mu$ s. If the source operand was addressed in the symbolic mode and two wait states were required: $$T = t_{C(\phi)} (C+W \cdot M)$$ $$C = 22 + 10 = 32$$ $$M = 8 + 2 = 10$$ $T = 0.400 (32 + 2 \cdot 10) = 20.8 \,\mu s.$ TABLE 4 INSTRUCTION EXECUTION TIMES | · | | | 1 | | |------------------------------------------------------------------------|--------------|---------------|--------|----------------| | INSTRUCTION | CLOCK CYCLES | MEMORY ACCESS | | ODIFICATION*** | | | С | M | SOURCE | DESTINATION | | A | 22 | 8 | A | A | | AB | 22 | 8 | В | B<br>— | | ABS (MSB = 0) | 16 | 4 | A | 1 | | (MSB = 1) | 20 | 6 | A | - | | Al | 22 | 8 | - | - | | ANDI | 22 | 8 | 1 - | - | | В | 12 | 4 | Α | _ | | BL | 18 | 6 | A | - | | BLWP | 38 | 12 | A | <del>-</del> | | С | 20 | 6 | Α | A | | СВ | 20 | 6 | В | В | | CI | 20 | 6 | - | _ | | CKOF | 14 | 2 | - | _ | | CKON | 14 | 2 | _ | - | | CLR | 16 | 6 | A | - | | COC | 20 | 6 | A | _ | | | 20 | 6 | A | _ | | CZC | 16 | 6 | A | _ | | DEC | 16 | 6 | A | l _ | | DECT | 1 | 6 | A | _ | | DIV (ST4 is set) | 22 | 12 | Â | _ | | DIV (ST4 is reset)* | 104-136 | | _ | _ | | IDLE | 14 | 2 | Ā | _ | | INC | 16 | 6 | t | _ | | INCT | 16 | 6 | A | _ | | INV | 16 | 6 | -A | _ | | Jump (PC is changed) | 12 | 2 | - | _ | | (PC is not changed) | 10 | 2 | - | _ | | LDCR (C = 0) | 58 | 6 | Α | - | | (1 <c<8)< td=""><td>26+2C</td><td>6</td><td>В</td><td>_</td></c<8)<> | 26+2C | 6 | В | _ | | (9 <c<15)< td=""><td>26+2C</td><td>6</td><td>A</td><td>-</td></c<15)<> | 26+2C | 6 | A | - | | LI | 18 | 6 | - | 1 - | | LIMI | 22 | 6 | - | i – | | LREX | 14 | 2 | - | - | | LWPI | 14 | 4 | _ | _ | | MOV | 22 | 8 | Α ' | Α | | MOVB | 22 | 8 | В | В | | MPY | 62 | 10 | Α | <b>!</b> – | | | 18 | 6 | A | _ | | NEG | 22 | 8 | _ | _ | | ORI | | 2 | | _ | | RSET | 14 | 8 | | _ | | RTWP | 22 | 8 | A | Α | | S | 22 | | B | B | | SB | 22 | 8 | В _ | _ | | SBO | 16 | 4 | _ | I _ | | SBZ | 16 | 4 | | Ī . | | SETO | 16 | 6 | A | _ | | Shift (C ≠ 0) | 18+2C | 6 | _ | | | (C ≠0, Bits 12-15 | 1 | | | | | of WRO = 0) | 60 | 8 | - | _ | | (C = 0, Bits 12-15 | | 1 | 1 | | | of WRP = N ≠ 0) | 28+2N | 8 | - | - | | SOC | 22 | 8 | Α | A | | SOCB | 22 | 8 | В | В | | STCR (C = 0) | 68 | 8 | A | _ | | | 50 | 8 | В | _ | | (1≤C≤7) | 1 | 8 | В | _ | | (C = 8) | 52 | 8 | A | _ | | (9≤C≤15) | 66 | 8 | 1 | 1 | <sup>\*</sup>Execution time is dependent upon the partial quotient after each clock cycle during execution. \*\*\* The letters A and B refer to the respective tables that follow. -CONTINUED- TABLE 4 (CONTINUED) | M<br>4<br>6<br>8<br>8<br>4<br>4<br>16 | SOURCE A A B - A A A | DESTINATION | |---------------------------------------|-----------------------|------------------| | 4<br>6<br>8<br>8<br>4<br>4<br>16 | A<br>B<br>—<br>A<br>A | -<br>-<br>-<br>A | | 8<br>8<br>4<br>4<br>16 | A<br>B<br>—<br>A<br>A | | | 8<br>8<br>4<br>4<br>16 | A<br>B<br>—<br>A<br>A | | | 8<br>4<br>4<br>16 | A<br>B<br>—<br>A<br>A | | | 4<br>4<br>16 | B<br>-<br>A<br>A | | | 4<br>4<br>16 | _<br>A<br>A | -<br>-<br>- | | - | Α | | | - | Α | _ | | - | | 1 | | | A | | | 10 | _ | _ | | | | | | | | _ | | | _ | _ | | 2 | _ | - | | | 10<br>10<br>2 | 10 – | <sup>\*\*</sup>Execution time is added to the execution time of the instruction located at the source address. \*\*\*The letters A and B refer to the respective tables that follow. #### ADDRESS MODIFICATION - TABLE A | ADDRESSING MODE | CLOCK CYCLES<br>C | MEMORY ACCESSES | |------------------------------------------------------------------|-------------------|-----------------| | WR (T <sub>S</sub> or T <sub>D</sub> = 00) | 0 | 0 | | WR indirect (T <sub>S</sub> or T <sub>D</sub> ≈ 01) | 6 | 2 | | WR indirect auto-increment (Ts or Tp = 11) | 12 | 4 | | Symbolic ( $T_S$ or $T_D = 10$ , $S$ or $D = 0$ ) | 10 | , | | Indexed (T <sub>S</sub> or T <sub>D</sub> = 10, S or D $\neq$ 0) | 12 | 4 | #### ADDRESS MODIFICATION - TABLE B | ADDRESSING MODE | CLOCK CYCLES<br>C | MEMORY ACCESSES<br>M | |--------------------------------------------------------------------|-------------------|----------------------| | WR ( $T_S$ or $T_D = 00$ ) | 0 | 0 | | WR indirect (T <sub>S</sub> or T <sub>D</sub> = 01) | 6 | 2 | | WR indirect auto-increment (T <sub>S</sub> or T <sub>D</sub> = 11) | 10 | 4 | | Symbolic ( $T_S$ or $T_D = 10$ , $S$ or $D = 0$ ) | 10 | 2 | | Indexed (T <sub>S</sub> or T <sub>D</sub> = 10, S or D $\neq$ 0) | 12 | 1 | # 4. TMS 9980A/TMS 9981 ELECTRICAL AND MECHANICAL SPECIFICATIONS # 4.1 ABSOLUTE MAXIMUM RATINGS OVER OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED)\* | Supply voltage, VCC (see Note 1) | | | | | | | | | | | | | | | -0.3 to 15 V | |----------------------------------------------|------|------|------|------|---|--|--|--|--|--|--|--|--|---|---------------| | Supply voltage, VDD (see Note 1) | | | | | | | | | | | | | | | -0.3 to 15 V | | Supply voltage, V <sub>BB</sub> (see Note 1) | 1998 | RO A | . ni | nlv' | ١ | | | | | | | | | | -5.25 to 0 V | | All input voltages (see Note 1) | ,500 | | | , | | | | | | | | | | | -0.3 to 15 V | | Output voltage (see Note 1) | | | | | | | | | | | | | | | −2 V to 7 V | | Continuous power dissipation . | | Ċ | Ċ | | | | | | | | | | | | 1.4 W | | Operating free-air temperature rar | nge | • | i | Ĭ. | | | | | | | | | | | 0°C to 70°C | | Storage temperature range | . 90 | | | | | | | | | | | | | _ | 55°C to 150°C | <sup>\*</sup>Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. NOTE 1: Under absolute maximum ratings voltage values are with respect to VSS. ## 4.2 RECOMMENDED OPERATING CONDITIONS | ALCOHIMICADED OF LINEAR OF LANDING | MIN | NOM | MAX | UNIT | |------------------------------------|-------|-----|--------------------|------| | Supply voltage, VBB (9980A only) | -5.25 | -5 | -4.75 | V | | Supply voltage, V <sub>CC</sub> | 4.75 | 5 | 5.25 | V | | Supply voltage, VDD | 11.4 | 12 | 12.6 | V | | Supply voltage, VSS | | 0 | | V | | High-level input voltage, VIH | 2.2 | 2.4 | V <sub>CC</sub> +1 | V | | Low-level input voltage, VIL | -1 | 0.4 | 8.0 | V | | Operating free-air temperature, TA | 0 | 20 | 70 | °c | # 4.3 ELECTRICAL CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS (UNLESS OTHERWISE NOTED) | | PARAM | ETER | TEST CONDITIONS | MIN | TYP* | MAX | UNIT | |-----------------|---------------------------------|--------------------------|-----------------------------------------------------|-----|------|------|-----------------| | | FARAIVI | Data bus during DBIN | V <sub>I</sub> = V <sub>SS</sub> to V <sub>CC</sub> | | | ±75 | | | 11 | Input current | WE, MEMEN, DBIN | V <sub>I</sub> = V <sub>SS</sub> to V <sub>CC</sub> | | | ±75 | μА | | | | Any other inputs | V <sub>I</sub> = V <sub>SS</sub> to V <sub>CC</sub> | | | ±10 | | | Vон | High-level outp | out voltage | I <sub>O</sub> = -0.4 mA | 2.4 | | | V | | - 011 | | | I <sub>O</sub> = 2 mA | | | 0,5 | _ v | | $v_{OL}$ | Low-level outp | ut voltage | IO = 3.2 mA | | | 0.65 | | | 1 | Supply current | from VBB (9980A Only) | | | | 1 | mA | | <sup>I</sup> BB | Supply current | THOM - BB 10-1- | 0°C | | 50 | 60 | → <sub>mA</sub> | | Icc | Supply current | t from V <sub>CC</sub> | 70°C | | 40 | 50 | lii A | | | | | 0°C | | 70 | 80 | — mA | | $I_{DD}$ | Supply curren | t from V <sub>DD</sub> | 70°C | | 65 | 75 | IIIA | | CI | Input capacita | nce (any inputs | f = 1 MHz, unmeasured pins at VSS | | 15 | | pF | | CDB | Data bus capa | | f = 1 MHz, unmeasured pins at VSS | | 25 | | ρF | | co | Output capaci<br>except data bu | tance (any output<br>us) | f = 1 MHz, unmeasured pins at VSS | | 15 | | pF | <sup>\*</sup>All typical values are at $T_A$ = 25°C and nominal voltages. #### 4.4 CLOCK CHARACTERISTICS The TMS 9980A and TMS 9981 have an internal 4-phase clock generator/driver. This is driven by an external TTL compatible signal to control the phase generation. In addition, the TMS 9981 provides an output (OSCOUT) that in conjunction with CKIN forms an on-chip crystal oscillator. This oscillator requires an external crystal and two capacitors as shown in Figure 13. The external signal or crystal must be 4 times the desired system frequency. FIGURE 13 - CRYSTAL OSCILATOR CIRCUIT #### 4.4.1 Internal Crystal Oscillator (9981 Only) The internal crystal oscillator is used as shown in Figure 13. The crystal should be a fundamental series resonant type. C<sub>1</sub> and C<sub>2</sub> represent the total capacitance on these pins including strays and parasitics. | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |---------------------------------|-----------------|-----|-----|-----|------| | Crystal frequency | 0°C-70°C | 6 | | 10 | MHZ | | C <sub>1</sub> , C <sub>2</sub> | 0°C-70°C | 10 | 15 | 25 | ρţ | #### 4.4.2 External Clock The external clock on the TMS 9980A and optional on the TMS 9981, uses the CKIN pin. In this mode the OSCOUT pin of the TMS 9981 must be left floating. The external clock source must conform to the following specifications. | | PARAMETER | MIN | TYP | MAX | UNIT | |--------------------------------|----------------------------------------|-----|-----|-----|------| | f <sub>ext</sub> | External source frequency* | 6 | | 10 | MHz | | ٧H | External source high level | 2.2 | | | T v | | ٧L | External source low level | | | 0.8 | V | | T <sub>r</sub> /T <sub>f</sub> | External source rise/fall time | | 10 | | ns | | TWH | External source high level pulse width | 40 | | | ns | | TWL | External source low level pulse width | 40 | | | ns | <sup>\*</sup>This allows a system speed of 1.5 MHz to 2 MHz. ## 4.5 SWITCHING CHARACTERISTICS OVER FULL RANGE OF RECOMMENDED OPERATING CONDITIONS The timing of all the inputs and outputs are controlled by the internal 4 phase clock; thus all timings are based on the width of one phase of the internal clock. This is $1/f_{\{CKIN\}}$ (whether driven or from a crystal). This is also $\%f_{system}$ . In the following table this phase time is denoted $t_W$ . All external signals are with reference to $\phi 3$ (see Figure 14). | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |---------------------|--------------------------------------------------|------------------------|----------------------|--------------------|---------------------|------| | t <sub>r</sub> (φ3) | Rise time of $\phi 3$ | | 3 | 5 | 10 | ns | | t <sub>f</sub> (φ3) | Fall time of φ3 | | 5 | 7.5 | 15 | ns | | t <sub>w</sub> (φ3) | Pulse width of φ3 | tw=1/f(CKIN) | t <sub>w</sub> -15 | tw-10 | t <sub>w</sub> +10 | ns | | t <sub>SU</sub> | Data or control setup time* | =¼fsystem | t <sub>w</sub> -30 | | | ns | | th | Data hold time* | | 2t <sub>tw</sub> +10 | | | ns | | tpHL (WE) | Propagation delay time WE high to low | C <sub>L</sub> = 200pf | t <sub>w</sub> -10 | tw | t <sub>w</sub> +20 | ns | | tPLH (WE) | Propagation delay time WE low to high | | tw | t <sub>w</sub> +10 | t <sub>w</sub> +30 | ns | | tPHL(CRUCLK) | Propagation delay time, CRUCLK high to low | | -20 | -10 | +10 | ns | | tpLH(CRUCLK) | Propagation delay time, CRUCLK low to high | | 2tw-10 | 2t <sub>w</sub> | 2t <sub>w</sub> +20 | ns | | tov | Delay time from output valid to φ3 low | | t <sub>w</sub> -50 | t <sub>w</sub> -30 | | ns | | tox | Delay time from output invalid to \$\phi 3\$ low | | | t <sub>w</sub> -20 | tw | ns | <sup>\*</sup>All inputs except ICO-IC2 must be synchronized to meet these requirements. ICO-IC2 may change asynchronously. See section 2.10.4. FIGURE 14 - EXTERNAL SIGNAL TIMING DIAGRAM #### 5. THE PROTOTYPING SYSTEM #### 5.1 HARDWARE Because of the software compatibility, the users of TMS 9980A/TMS 9981 uses the TMS 9900 prototyping system to generate and debug software and to debug I/O controller interfaces. The prototyping system consists of: - 990/4 computer with TMS 9900 microprocessor - 1024 bytes of ROM containing the bootstrap loader for loading prototyping system software, the front-panel and maintenance utility, and the CPU self-testing feature - 16,896 bytes of RAM with provisions for expansion up to 57,334 bytes of RAM - Programmable-write-protect feature for RAM - Interface for Texas Instruments Model 733 ASR\* Electronic Data Terminal with provisions for up to five additional interface modules - Available with Texas Instruments 733 ASR Electronic Data Terminal - 7-inch-high table-top chassis - Programmer's front panel with controls for run, halt, single-instruction execute, and entering and displaying memory or register contents - Power supply with the following voltages: 5 V dc @ 20 A 12 V dc @ 2 A -12 V dc @ 1 A -5 V dc @ 0.1 A Complete hardware and software documentation. #### 5.2 SYSTEM CONSOLE The system console for the prototyping system is the 733 ASR, which provides keyboard entry, 30-character-persecond thermal printer, and dual cassette drives for program loading and storage. #### 5.3 SOFTWARE The following software is provided on cassette for loading into the prototyping system: - Debug Monitor Provides full control of the prototyping system during program development and includes single instruction, multiple breakpoints, and entry and display capability for register and memory contents for debugging user software user 733 ASR console control. - One-Pass Assembler Converts source code stored on cassette to relocatable object on cassette and generates program listing. (Object is upward compatible with other 990 series assemblers.) - Linking Loader Allows loading of absolute and relocatable object modules and links object modules as they are loaded. <sup>\*</sup>Requires remote device control and 1200 baud EIA interface option on 733 ASR. - Source Editor Enables user modifications of both source and object from cassette with resultant storage on cassette. - Trace Routine Allows user to monitor status of computer at completion of each instruction. - PROM Programming/Documentation Facility Provides documentation for ROM mask generation, or communicates directly with the optional PROM Programmer Unit. #### 5.4 OPTIONS The following optional equipment is offered for the prototyping system: - Battery-pack/standby-power supply - PROM programming unit and adapter boards - Universal wire-wrap modules - Expansion RAM modules - Expansion EPROM modules - I/O modules and other interfaces - Rack-mounted version - International ac voltage option #### 6. SUPPORT CIRCUITS | DEVICE | ORGANIZATION/<br>FUNCTION | I/O STRUCTURE | PACKAGE | ACCESS TIME | |----------------------|---------------------------|-----------------------|---------|------------------------| | | | RAMS | | | | TMS 4036-2 | 64 x 8 Static | Common bus | 20 Pin | 450 ns MAX | | TMS 4033 | 1024 x 1 Static | Dedicated bus | 16 Pin | 450 ns MAX | | TMS 4039-2 | 256 x 4 Static | Dedicated bus | 22 Pin | 450 ns MAX | | TMS 4042-2 | 256 x 4 Static | Common bus | 18 Pin | 450 ns MAX | | TMS 4043-2 | 256 x 4 Static | Common bus | 16 Pin | 450 ns MAX | | TMS 4050 | 4096 x 1 Dynamic | Common bus | 18 Pin | 300 ns MAX | | TMS 4051 | 4096 x 1 Dynamic | Dedicated bus | 18 Pin | 300 ns MAX | | TMS 4060 | 4096 x 1 Dynamic | Dedicated bus | 22 Pin | 300 ns MAX | | | | ROMS/PROMS | | | | TMS 2708 | 1024 x 8 EROM | - | 24 Pin | 450 . 444.4 | | TMS 4700 | 1024 × 8 ROM | | 24 Pin | 450 ns MAX | | SN74S371 | 256 x 8 ROM | | 20 Pin | 450 ns MAX | | SN74S471 | 256 x 8 ROM | | 20 Pin | 70 ns MAX | | SN74S472 | 512 x 8 PROM | | 20 Pin | 70 ns MAX<br>55 ns TYP | | | | | | 33.10 | | TMS 9901 | 001.0 | PERIPHERALS | | | | TMS 9902 | PSI, Programmable Syste | | 40 Pin | | | TMS 9902<br>TMS 9903 | ACC, Asynchronous Com | munication Controller | 18 Pin | | | TIM 9905 | SCC, Synchronous Comm | | 20 Pin | | | | Data multiplexer (SN74L | | 16 Pin | | | TIM 9906 | Addressable latch (SN74 | | 16 Pin | | | TIM 9907 | Priority encoder (SN7414 | 18) | 16 Pin | | | SN74S412 | 8-bit I/O port | | 24 Pin | | | TMS 6011 | UART | | 40 Pin | | | SN74S241 | Bidirectional bus driver | | 20 Pin | | # 7. SYSTEM DESIGN EXAMPLES Figure 15 illustrates a typical minimum TMS 9981 system. Eight bits of input and output interface are implemented. No interface circuits are used for interrupt code thus providing for reset and one interrupt only. CKIN and OSCOUT are tied to a 10 MHz crystal to use the on-chip crystal oscillator. The memory system contains $1024 \times 8$ ROM and $256 \times 8$ RAM. The package count for this system is 6 packages. A maximum TMS 9980A/TMS 9981 system is illustrated in Figure 16. ROM and RAM are both shown for a total of 16,284 bytes of memory. The I/O interface support 2048 output bits and 2048 input bits. RESET, LOAD, and 4 interrupts are implemented on the interrupt interface lines. Optional external clock may be supplied on CKIN. Buss buffers, required for this maximally configured system, are indicated on the system buses. FIGURE 15 - MINIMUM TMS 9980 SYSTEM ## 8. MECHANICAL DATA # 8.1 TMS 9980A/TMS 9981 - 40-PIN CERAMIC PACKAGE NOTES: A. Each pin centerline is located within 0.010 of its true longitudinal position. B. All linear dimensions are in inches. # 8.2 TMS 9980A/TMS 9981 - 40-PIN PLASTIC PACKAGE NOTES: A. Each pin centerline is located within 0.010 of its true longitudinal position. B. All linear dimensions are in inches. #### APPENDIX H #### TMS 9900 FAMILY MACHINE CYCLES ## H.1 General Description of Machine Cycles The TMS 9900 family of microprocessors execute a series of steps to perform an instruction or other operation. This basic step common to all operations is the machine cycle, which requires two clock cycles to execute. (Note: These machine cycles apply equally to the TMS 9980A/81 microprocessor, with the exception of the memory cycle as detailed below.) The TMS 9900 family machine cycles are divided into three categories described in the following paragraphs. #### H.1.1 ALU Cycle The ALU cycle performs an internal operation of the microprocessor. The memory interface control signals and CRU interface control signals are not affected by the execution of an ALU cycle, which takes two clock cycles to execute. #### H.1.2 Memory Cycle The memory cycle primarily performs a data transfer between the microprocessor and the external memory device. Appropriate memory bus control signals are generated by the microprocessor as a result of a memory cycle execution. The memory cycle takes 2+W (where W is the number of wait states) clock cycles to execute. In the TMS 9980A/81, which has an 8-bit data bus, the memory cycle is composed of two data transfers to move a complete 16-bit word. The TMS 9980A/81 memory cycle takes 4+2W (where W is the number of wait states) clock cycles to execute. For the TMS 9980A/81 the following machine cycle sequences replace the memory sequences used in the instruction discussion. #### **CYCLE** 1 Memory Read/Write AB = Address of most significant by te (A13 = 0) DB = Most significant by te 2 Memory Read/Write AB = Address of least significant byte (A13 = 1) DB = Least significant byte #### H.1.3 CRU Cycle The CRU cycle performs a bit transfer between the microprocessor and I/O devices. It takes two clock cycles to execute. The address of the CRU bit is set up during the first clock cycle. For an input operation the CRUIN line is sampled by the microprocessor during the second clock cycle. For an output operation the data bit is set up on the CRUOUT line at the same time the address is set up. The CRUCLK line is pulsed during the second clock cycle of the CRU output cycle. Please refer to the specific TMS 99XX microprocessor data manual for timing diagrams. The TMS 9900 executes its operations under the control of a microprogrammed control ROM. Each microinstruction specifies a machine cycle. A microprogram specifies a sequence of machine cycles. The TMS 9900 executes a specific sequence of machine cycles for a specific operation. These sequences are detailed on the following pages. The information can be used by the systems designers to determine the bus contents and other interface behavior at various instants during a certain TMS 9900 operation. This description is maintained at the address bus (AD) and data bus (DB) levels. #### H.2 TMS 9900 Machine Cycle Sequences Most TMS 9900 instructions execution consists of two parts: 1) the data derivation and 2) operation execution. The data derivation sequence depends on the addressing mode for the data. Since the addressing modes are common to all instructions, the data derivation sequence is the same for the same addressing mode, regardless of the instruction. Therefore, the data derivation sequences are described first. These are then referred to in appropriate sequence in the instruction execution description. #### **H.3 Terms and Definitions** The following terms are used in describing the instructions of the TMS 9900: | TERM | DEFINITION | |--------|---------------------------------------------------------------| | В | Byte Indicator (1 = byte, 0 = word) | | С | Bit count | | D | Destination address register | | DA | Destination address | | IOP | Immediate operand | | PC | Program counter | | Result | Result of operation performed by instruction | | S | Source address register | | SA | Source address | | ST | Status register | | STn | Bit n of status register | | SD | Source data register internal to the TMS 9900 microprocessor* | | W | Workspace register | | SRn | Workspace register n | | (n) | Contents of n | | Ns | Number of machine cycles to derive source operand | | Nd | Number of machine cycles to derive destination operand | | AB | Address Bus of the TMS 9900 | | DB | Data Bus of the TMS 9900 | | NC | No change from previous cycle | | | | <sup>\*</sup>NOTE: The contents of the SD register remain latched at the last value written by the processor unless changed by the ALU. Therefore, during all memory read or ALU machine cycles the SD register and hence the data bus will contain the operand last written to the data bus by the CPU or the results of the last ALU cycle to have loaded the SD register. # **H.4 Data Derivation Sequences** # H.4.1 Workspace Register | CYCLE | TYPE | DESCRIPTION | |-------|-------------|---------------------------------| | 1 | Memory Read | AB = Workspace register address | | ı | memory read | DB = Operand | # H.4.2 Workspace Register Indirect | CYCLE | TYPE | DESCRIPTION | |--------|-------------|----------------------------------| | 1 ICEL | Memory Read | AB = Workspace register address | | ı | Memory Road | DB = Workspace register contents | | 2 | ALU | AB = NC | | 4 | ALC | DB = SD | | 2 | Memory Read | AB = Workspace register content | | 3 | Memory Read | DB = Operand | # H.4.3 Workspace Register Indirect Auto-Increment (Byte Operand) | CYCLE | TYPE<br>Memory Read | DESCRIPTION AB = Workspace register address | |-------|---------------------|----------------------------------------------| | 1 | memory read | DB = Workspace register contents | | 2 | ALU | AB = NC | | 2 | NEO | DB = SD | | 3 | Memory write | AB = Workspace register address | | 3 | Memory with | DB = (WRn) + 1 | | 4 | Memory Read | AB = Workspace register contents | | 7 | Memory Tead | DB = Operand | # H.4.4 Workspace Register Indirect Auto-Increment (Work Operand) | CYCLE | TYPE | DESCRIPTION | |-------|--------------|----------------------------------| | 1 | Memory read | AB = Workspace register address | | 1 | Meshely 1011 | DB = Workspace register contents | | 2 | ALU | AB = NC | | 4 | | DB = SD | | 3 | ALU | AB = NC | | 3 | | DB = SD | | 4 | Memory write | AB = Workspace register address | | | | DB = (WRn) + 2 | | 5 | Memory read | AB = Workspace register contents | | | | DB = Operand | # H.4.5 Symbolic | CYCLE<br>1 | TYPE<br>ALU | DESCRIPTION AB = NC DB = SD | |------------|-------------|-------------------------------| | 2 | ALU | AB = NC<br>DB = SD | | CYCLE<br>3 | TYPE<br>Memory read | DESCRIPTION AB = PC+2 | |------------|---------------------|-----------------------| | | • | DB = Symbolic address | | 4 | ALU | AB = NC | | _ | | $DB = 0000_{16}$ | | 5 | Memory read | AB = Symbolic address | | | | DB = Operand | ## H.4.6 Indexed | CYCLE<br>1 | TYPE<br>Memory read | DESCRIPTION AB = Workspace register address | |------------|---------------------|-----------------------------------------------------------------------------| | 2 | ALU | DB = Workspace register contents AB = NC | | 3 | Memory read | DB = SD $AB = PC+2$ | | 4 | ALU | DB = Symbolic address AB = PC+2 | | 5 | Memory read | DB = Workspace register contents AB = Symbolic address + (WRn) DB = Operand | # H.5 Instruction Execution Sequences # H.5.1 A, AB, C, CB, S, SB, SOC, SOCB, SZC, SZCB, MOV, MOVB, COC, CZC, XOR | CYCLE<br>1 | TYPE<br>Memory read | DESCRIPTION<br>AB = PC | |------------|-----------------------------------------------------------------------------------------------------|----------------------------------| | 2 | ALU | DB = Instruction AB = NC DB = SD | | Ns | Insert appropriate sequence for source data addressing mode, from the data derivation sequences | | | 3+Ns | ALU | AB = NC<br>DB = SD | | Nd | Insert appropriate sequence for destination data addressing mode from the data derivation sequences | | | 3+Ns+Nd | ALU | AB = NC | | 4+Ns+Nd | Memory write | DB = SD (Note 4) DB = Result | ## NOTES: Since the memory operations of the TMS 9900 microprocessor family fetch or store 16-bit words, the source and the destination data fetched for byte operations are 16-bit words. The ALU operates on the specified bytes of these words and modifies the appropriate byte in the destination word. The adjacent byte in the destination word remains unaltered. At the completion of the instruction, the destination word, consisting of the modified byte and the adjacent unmodified byte, is stored in a single-memory write operation. - 2) For MOVB instruction the destination data word (16 bits) is fetched. The specified byte in the destination word is replaced with the specified byte of the source-data word. The resultant destination word is then stored at the destination address. - 3) For MOV instruction the destination data word (16 bits) is fetched although not used. - 4) For C, CB, COC, CZC instructions cycle $4+N_s+N_d$ above is an ALU cycle with AB = DA and DB = SD. ### H.5.2 MPY (Multiply) | CYCLE | ТҮРЕ | DESCRIPTION<br>AB = PC | |-------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | 1 | Memory read | DB = Instruction | | 2 | ALU | AB = NC<br>DB = SD | | Ns | Insert appropriate data derivation sequence according to the source data (multiplier) addressing mode | | | 3+Ns | ALU | AB = NC<br>DB = SD | | 4+Ns | Memory read | AB = Workspace register address DB = Workspace register contents | | 5+Ns | ALU | AB = NC<br>DB = SD | | 6+Ns | ALU | AB = NC<br>DB = Multiplier | | 7+Ns | 16 ALU | Multiply the two operands AB = NC | | | 16 ALC | DB = MSH of partial product | | 22+Ns | Memory write | AB = Workspace register address DB = MSH of the product | | 23+Ns | ALU | AB = DA+2 DB = MSH of product | | 24+Ns | Memory write | AB = DA+2<br>DB = LSH of the product | ### H.5.3 DIV (Divide) | CYCLE | TYPE | DESCRIPTION | |-------|-------------|------------------| | 1 | Memory read | AB = PC | | _ | • | DB = Instruction | | 2 | ALU | AB = NC | | _ | | DB = SD | | | | | | CYCLE | ТҮРЕ | DESCRIPTION | |------------------|----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------| | Ns | Insert appropriate data derivation sequence according to the source data (divisor) addressing mode | | | 3+Ns | ALU | AB = NC | | 4+Ns | Memory read | DB = SD<br>AB = Address of workspace register | | 5+Ns | ALU | DB = Contents of workspace register (Check overflow) AB = NC | | 6+Ns | ALU | DB = Divisor<br>(Skip if overflow to next instruction fetch)<br>AB = NC | | 7+Ns | Memory read | DB = SD $AB = DA+2$ | | 8+Ns | ALU | DB = Contents of DA+2 AB = NC | | 9+N <sub>S</sub> | ALU | DB = SD<br>AB = NC<br>DB = SD | | | Divide sequence consisting of Ni cycles where $48 \le Ni \le 32$ . Ni is data dependent | AB = NC<br>DB = SD | | 10+Ns+Ni | ALU | AB = NC | | H+Ns+Ni | Memory write | DB = SD AB = Workspace register address | | 12+Ns+Ni | ALU | DB = Quotient AB = DA+2 | | 13+Ns+Ni | Memory write | DB = Quotient AB = DA+2 DB = Remainder | | H.5.4 XOP | | | | CYCLE | ТҮРЕ | | | 1 | Memory read | DESCRIPTION<br>AB = PC | | 2 | ALU | DB = Instruction Instruction decode AB = NC DB = SD | | Ns | Insert appropriate data derivation sequence according to the source data addressing mode | | | 3+Ns | ALU | AB = NC | | 4+Ns | ALU | DB = SD<br>AB = NC | | 5+Ns | ALU | DB = SA<br>AB = NC<br>DB = SD | | CYCLE | TYPE | DESCRIPTION | |-------|--------------|---------------------------------------| | 6+Ns | Memory read | $AB = 40_{16} + 4 \times D$ | | 0.110 | , | DB = New workspace pointer | | 7+Ns | ALU | AB = NC | | | | DB = SA | | 8+Ns | Memory write | AB = Address of WR11 | | | , | DB = SA | | 9+Ns | ALU | AB = Address of WR15 | | | | DB = SA | | 10+Ns | Memory write | AB = Address of workspace register 15 | | | Ž | DB = Status register contents | | 11+Ns | ALU | AB = NC | | | | DB = PC+2 | | 12+Ns | Memory write | AB = Address of workspace register 14 | | | • | DB = PC+2 | | 13+Ns | ALU | AB = Address of WR13 | | | | DB = SD | | 14+Ns | Memory write | AB = Address of workspace register 13 | | | • | DB = WP | | 15+Ns | ALU | AB = NC | | | | DB = SD | | 16+Ns | Memory read | $AB = 42_{16} + 4 \times D$ | | | <b>,</b> | DB = New PC | | 17+Ns | ALU | AB = NC | | 2 | | DB = SD | # H.5.5 CLR, SETO, INV, NEG, INC, INCT, DEC, DECT | CYCLE<br>1<br>2 | TYPE Memory read ALU | DESCRIPTION AB = PC DB = Instruction AB = NC DB = SD | |-----------------|------------------------------------------------------------------------------------------|------------------------------------------------------------| | Ns | Insert appropriate data derivation sequence according to the source data addressing mode | | | 3+Ns | ALU | AB = NC | | 4+Ns | Memory write | DB = SD AB = Source data address DB = Modified source data | NOTE: The operand is fetched for CLR and SETO although not used. # H.5.6 ABS | TYPE | DESCRIPTION | | |-------------|----------------------|--| | Memory read | AB = PC | | | , | DB = Instruction | | | ALU | AB = NC | | | | DB = SD | | | | TYPE Memory read ALU | | | CYCLE | ТҮРЕ | DESCRIPTION | |------------------|----------------------------------------------------------------------------------------------|--------------------------------------------------| | Ns | Insert appropriate data derivation sequence according to the source data addressing mode | | | 3+N <sub>s</sub> | ALU | Test source data AB = NC | | 4+Ns | ALU | DB = SD Jump to 5'+Ns if data positive AB = NC | | 5+ns | ALU | DB = SD Negate source AB = NC | | 6+Ns | Memory write | DB = SD AB = Source data address | | 5'+Ns | ALU ' | DB = Modified source data AB = NC DB = SD | | H.5.7 X | | | | CYCLE<br>1 | TYPE<br>Memory read | DESCRIPTION<br>AB = PC | | 2 | ALU | DB = Instruction AB = NC DB = SD | | Ns | Insert the appropriate data derivation sequence according to the source data addressing mode | | | 3+Ns | ALU | AB = NC<br>DB = SD | NOTE: Add sequence for the instruction specified by the operand. # H.5.8 B | CYCLE<br>1 | TYPE<br>Memory read | DESCRIPTION<br>AB = PC | |------------|------------------------------------------------------------------------------------------|----------------------------------| | 2 | ALU | DB = Instruction AB = NC DB = SD | | Ns | Insert appropriate data derivation sequence according to the source data addressing mode | | | 3+Ns | ALU | AB = NC $DB = SD$ | NOTE: The source data is fetched, although it is not used. # H.5.9 BL | CYCLE | TYPE | DESCRIPTION | |-------|------------------------------------|----------------------| | 1 | Memory read | AB = PC | | | | DB = Instruction | | 2 | ALU | AB = NC | | | | DB = SD | | | | | | | Insert appropriate data derivation | | | Ns | sequence according to the source | | | | data addressing mode | | | 3+Ns | ALU | AB = NC | | STINS | ALO | DB = SD | | | | | | 4+Ns | ALU | AB = Address of WR11 | | | | DB = SD | | 5+Ns | Memory write | AB = Address of WR11 | | | - | DB = PC+2 | NOTE: The source data is fetched although it is not used. # H.5.10 BLWP | CY | CLE | ТҮРЕ | DES | CR | IPTION | |----|-------|------------------------------------|----------|----|----------------------------------| | | 1 | Memory read | AB | | PC | | | | | DB | | Instruction | | | 2 | ALU | AB<br>DB | | NC | | | | | DR | = | SD | | | | Insert appropriate data derivation | | | | | | Ns | sequence according to the source | | | | | | | data addressing mode | | | | | | | - | | | | | | 3+Ns | ALU | ΑB | | NC | | | | | DB | | SD | | | 4+Ns | ALU | AB | | Address of WR15 | | | | | DB | | NC | | | 5+Ns | Memory write | ΑB | = | Address of workspace register 15 | | | | | DB | = | Status register contents | | | 6+Ns | ALU | AB | = | NC | | | | | DB | = | PC+2 | | | 7+Ns | Memory write | AB | = | Address of workspace register 14 | | | | | DB | = | PC+2 | | | 8+Ns | ALU | AB | = | Address or workspace register 13 | | | | | DB | = | SD | | | 9+Ns | Memory write | AB | = | Address of workspace register 13 | | | | • | DB | = | WP | | | 10+Ns | ALU | AB | = | NC | | | | | DB | = | SD | | | 11+Ns | Memory read | AB | = | Address of new PC | | | | • | DB | = | New PC | | | 12+Ns | ALU | ΑB | = | NC | | | | | DB | = | SD | # H.5.11 LDCR | CYCLE<br>1 | TYPE<br>Memory read | DESCRIPTION AB = PC | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------| | 2 | ALU | DB = Instruction AB = NC DB = SD | | Ns | Insert appropriate data derivation sequence | | | 3+Ns | ALU | AB = NC | | 4+Ns | ALU | DB = SD $AB = NC$ | | 5+Ns | ALU | DB = SD AB = Address of WR12 | | 6+Ns | ALU | DB = SD AB = Address of WR12 | | 7+Ns | Memory read | DB = SD AB = Address of WR12 | | 8+Ns | ALU | DB = Contents of WR12 AB = NC DB = SD | | c | Enable CRUCLK. Shift next bit onto CRUOUT line. Increment CRU bit address on AB. Iterate this sequence C times, where C is number of bits to be transferred. | AB = Address + 2<br>Increments C Times<br>DB = SD | | 9+Ns+C | ALU | AB = NC $DB = SD$ | | H.5.12 STCR | | | | CYCLE<br>1 | TYPE<br>Memory read | DESCRIPTION AB = PC | | 2 | ALU | DB = Instruction AB = NC DB = SD | | Ns | Insert appropriate data derivation sequence according to the source data addressing mode | | | 3+Ns | ALU | AB = NC | | 4+Ns | Memory read | DB = SD $AB = Address of WR12$ | | 5+Ns | ALU | DB = Contents of WR12 AB = NC | DB = SD | CYCLE | ТҮРЕ | DES | CR | IPTION | |------------|----------------------------------------|-----|----|----------------| | 6+Ns | ALU | AB | = | NC | | | | DB | = | SD | | | Input selected CRU bit. | | | | | | Increment CRU bit address. | AB | = | Address + 2 | | C | Iterate this sequence C | | | C times | | | times where C is the number | DB | = | SD | | | of CRU bits to be input. | | | | | 7+Ns+C | ALU | AB | = | NC | | 7.113.0 | | DB | | SD | | 8+Ns+C | ALU | AB | | NC | | 0.110.0 | | DB | = | SD | | | | | | | | | Right adjust (with zero | AB | = | NC | | C' | fill) byte (if $C < 8$ ) | DB | | SD | | | or word (if $8 < C < 16$ ). | | | | | C' | = 8-C-1 if C ≤ 8 | | | | | - | = $16 \cdot C \cdot 1$ if $< C \le 16$ | | | | | 9+Ns+C+C' | ALU | AB | = | NC | | | | DB | = | SD | | 10+Ns+C+C' | ALU | AB | = | NC | | | | DB | = | SD | | 11+Ns+C+C' | ALU | AB | = | Source address | | | | DB | = | SD | | 12+Ns+C+C' | Memory write | AB | | Source address | | | | DB | = | I/O data | NOTE: For STCR instruction the 16-bit word at the source address is fetched. If the number of CRU bits to be transferred is $\leq 8$ , the CRU data is right justified (with zero fill) in the specified byte of the source word and source data word thus modified is then stored back in memory. If the bits to be transferred is > 8 then the source data fetched is not used. The CRU data in this case is right justified in 16-bit word which is then stored at the source address. ### H.5.13 SBZ, SBO | CYCLE | TYPE | DESCRIPTION | |-------|-------------|----------------------------| | 1 | Memory read | AB = PC | | | | DB = Instruction | | 2 | ALU | AB = NC | | | | DB = SD | | 3 | ALU | AB = NC | | | | DB = SD | | 4 | Memory read | .AB = Address of WR12 | | | · | DB = Contents of WR12 | | 5 | ALU | AB = NC | | | | DB = SD | | 6 | CRU | Set $CRUOUT = 0$ for $SBZ$ | | | | = 1 for SBO | | | | Enable CRUCLK | | CYCLE | ТҮРЕ | DESCRIPTION AB = CRU bit address DB = SD | |-------------|-------------------|--------------------------------------------------------------------------------| | H.5.14 TB | | | | CYCLE | ТҮРЕ | D.P.C.O. D.P.C. | | 1 | Memory read | DESCRIPTION AB = PC | | 2 | ALU | DB = Instruction AB = NC | | 3 | ALU | DB = SD | | 3 | ALO | AB = NC<br>DB = SD | | 4 | Memory read | AB = Address of WR12 | | 5 | ALU | DB = Contents of WR12 AB = NC | | | <b></b> | DB = SD | | 6 | CRU | Set $ST(2) = CRUIN$ | | | | AB = Address of CRU bit | | | | DB = SD | | H.5.15 JEQ, | JGT, JH, JHE, JL, | JLE, JLT, JMP, JNC, JNE, JNO, JOC, JOP | | CYCLE | TYPE | DESCRIPTION | | 1 | Memory read | AB = PC | | | | DB = Instruction | | 2 | ALU | AB = NC | | 3 | ALU | DB = SD | | J | ALU | Skip to cycle #5 if TMS 9900 status | | | | satisfies the specified jump condition AB = NC | | | | DB = SD | | 4 | ALU | AB = NC | | 5 | ALU | DB = Displacement value | | 3 | ALU | AB = NC | | | | DB = SD | | H.5.16 SRA, | SLA, SRL, SRC | | | CYCLE | TYPE | DESCRIPTION | | 1 | Memory read | AB = PC | | 2 | | DB = Instruction | | 2 | ALU | AB = NC | | 3 | Memory read | DB = SD AB = Address of the workspace register | | | | AB = Address of the workspace register DB = Contents of the workspace register | | 4 | ALU | Skip to cycle #9 if $C \neq 0$ | | | | C = Shift count | | | | AB = NC | | 5 | ALU | DB = SD | | <b>.</b> . | ALU | AB = NC<br>DB = SD | | | | DB = SD | | CYCLE TYPE | DESCRIPTION | |-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | 6 Memory read | AB = Address of WRO | | ( Memory temp | DB = Contents of WRO | | 7 ALU | AB = Source address | | / ALO | DB = SD | | 8 ALU | AB = NC | | 8 ALU | DB = SD | | O) | AB = NC | | 9 | DB = SD | | Shift the contents of the specified workspace register in the specified direction by the specified number of bits. Set appropriate status bits. | | | 9+C Memory write | AB = Address of the workspace register DB = Result | | 10+C ALU | Increment PC | | • • | AB = NC | | | DB = SD | # H.5.17 AI, ANDI, ORI | CYCLE | TYPE | DESCRIPTION | |-------|--------------|-------------------------------------| | 1 | Memory read | AB = PC | | • | | DB = Instruction | | 2 | ALU | AB = NC | | ÷ | <i>NEO</i> | DB = SD | | 3 | ALU | AB = NC | | 3 | | DB = SD | | 4 | Memory read | AB = Address of workspace register | | 4 | | DB = Contents of workspace register | | • | Memory read | AB = PC+2 | | 5 | | DB = Immediate operand | | | ALU | AB = NC | | 6 | | DB = SD | | 7 | NA | AB = Address of workspace register | | | Memory write | DB = Result of instruction | | | | | # H.5.18 CI | CYCLE | TYPE | DESCRIPTION | |-------|-------------|-------------------------------------| | 1 | Memory read | AB = PC | | • | memory vers | DB = Instruction | | 2 | ALU | AB = NC | | - | | DB = NC | | 3 | Memory read | AB = Address of workspace register | | | , | DB = Contents of workspace register | | 4 | ALU | AB = NC | | · | | DB = SD | | 5 | Memory read | AB = PC+2 | | • | | DB = Immediate operand | | CYCLE | TVDU | | |----------------|---------------------------------------|-----------------------------------------------------------| | 6 | TYPE<br>ALU | DESCRIPTION | | v | ALU | AB = NC | | 7 | ALU | DB = SD | | , | ALU | AB = NC | | | | DB = SD | | H.5.19 LI | | | | CYCLE | TVDD | | | 1 | TYPE | DESCRIPTION | | • | Memory read | AB = PC | | 2 | ALU | DB = Instruction | | _ | ALO | AB = NC | | 3 | ALU | DB = SD | | | | AB = NC | | 4 | Memory read | DB = SD | | | i i i i i i i i i i i i i i i i i i i | AB = PC + 2 | | 5 | ALU | DB = Immediate operand | | | | AB = Address of workspace register DB = SD | | 6 | Memory write | | | | · | | | | | DB = Immediate operand | | H.5.20 LWPI | Ţ | | | CYCLE | TYPE | | | 1 | Memory read | DESCRIPTION | | - | Memory read | AB = PC | | 2 | ALU | DB = Instruction | | | | AB = NC | | 3 | ALU | DB = SD | | | | AB = NC | | 4 | Memory read | DB = SD | | | | AB = PC+2 | | 5 | ALU | DB = Immediate operand AB = NC | | | | DB = SD | | ** * | • | DB - 3D | | H.5.21 LIMI | | | | CYCLE | TYPE | Disconnection | | 1 | Memory read | DESCRIPTION | | | memory read | AB = PC | | 2 | ALU | DB = Instruction | | | | AB = NC | | 3 | ALU | $ \begin{array}{rcl} DB &= SD \\ AB &= NC \end{array} $ | | | | AB = NC | | 4 | Memory read | DB = SD | | | • | AB = PC+2<br>DB = immediate data | | 5 | ALU | | | | | $ \begin{array}{rcl} AB &=& NC \\ DB &=& SD \end{array} $ | | 6 | ALU | AB = NC | | • | | DB = SD | | 7 <sup>.</sup> | ALU | AB = NC | | | | DB = SD | | | | - JU | # H.5.22 STWP, STST | CYCLE<br>1 | TYPE<br>Memory read | DESCRIPTION AB = PC DB = Instruction | |------------|---------------------|--------------------------------------------------------------------------------------------| | 2 | ALU | AB = NC DB = SD AB = Address of workspace register | | 3 | ALU | DB = SD | | 4 | Memory write | AB = Address of the workspace register DB = TMS 9900 internal register contents (WP or ST) | # H.5.23 CKON, CKOF, LREX, RSET | CYCLE<br>1 | TYPE<br>Memory read | DESCRIPTION AB = PC DB = Instruction | |------------|---------------------|-----------------------------------------------| | 2 | ALU | AB = NC<br>DB = SD | | 3 | ALU | AB = NC<br>DB = SD | | 4 | CRU | Enable CRUCLK AB = External instruction code | | | | DB = SD $AB = NC$ | | 5 | ALU | DB = SD | | 6 | ALU | AB = NC<br>DB = SD | # H.5.24 IDLE | 11.0.2 | | | |------------|---------------------|---------------------------------------------------------------| | CYCLE<br>1 | TYPE<br>Memory read | DESCRIPTION AB = PC DB = Instruction | | 2 | ALU | AB = NC $DB = SD$ | | 3 | ALU | AB = NC $DB = SD$ | | 4 | CRU | Enable CRUCLK AB = Idle code | | | | DB = SD | | 5 | ALU | AB = NC $DB = SD$ | | 6 | ALU | $ \begin{array}{rcl} AB & = & NC \\ DB & = & NC \end{array} $ | | | | | # H.6 Machine-Cycle Sequences in Response to External Stimuli # H.6.1 RESET | CYCL | E TYPE | DESCRIPTION | |------|----------------|-----------------------------------------------| | 1* | ALU | AB = NC | | | | DB = SD | | 2 | ALU | AB = NC | | | | DB = SD | | 3 | ALU | AB = 0 | | | | DB = 0 | | 4 | Memory read | AB = 0 | | - | **** | DB = Workspace pointer | | 5 | ALU | AB = NC | | | | DB = Status | | 6 | Memory write | AB = Address of WR15 | | 7 | A 7 7 7 | DB = Contents of Status register | | , | ALU | AB = NC | | 8 | Mamagar milita | DB = PC | | 0 | Memory write | AB = Address of workspace register 14 | | 9 | ALU | DB = PC+2 | | | ALO | AB = Address of WR13 | | 10 | Memory write | DB = SD | | | Monory write | AB = Address of workspace register 13 DB = WP | | 11 | ALU | DB = WP<br>AB = NC | | | | DB = SD | | 12 | Memory read | AB = 2 | | | · | DB = New PC | | 13 | ALU | AB = NC | | | | DB = SD | | | | | # H.6.2 LOAD | CYCLE | TYPE | P. P. G. G. L. | |-------|--------------|----------------------------------------------------| | | | DESCRIPTION | | 1** | ALU | AB = NC | | _ | | DB = SD | | 2 | Memory read | $AB = FFFC_{16}$ | | _ | | DB = Contents of FFFC <sub>16</sub> | | 3 | ALU | AB = NC | | | | DB = Status | | 4 | Memory write | AB = Address WR15 | | _ | | DB = Contents of status register | | 5 | ALU | AB = NC | | _ | | DB = PC | | 6 | Memory write | AB = Address of workspace | | | | DB = PC+2 | | 7 | ALU | AB = Address of WR13 | | _ | | DB = SD | | 8 | Memory write | AB = Address of workspace register 13 | | | | DB = WP | <sup>\*</sup>Occurs immediately after RESET is released. \*\*Occurs immediately after last clock cycle of preceding instruction. | CYCLE | TYPE | DESCRIPTION | |-------|-------------|-------------| | 9 | ALU | AB = NC | | , | ne. | DB = SD | | 10 | Memory Read | AB = FFFE | | | | DB = New PC | | 11 | ALU | AB = NC | | 11 | 1120 | DB = SD | # H.6.3 Interrupts | CYCLE | ТҮРЕ | DESCRIPTION | |-------|--------------|---------------------------------------| | | ALU | AB = NC | | 1* | ALO | DB = SD | | 2 | Memory read | AB = Address of interrupt vector | | 2 | money | DB = WP | | 3 | ALU | AB = NC | | J | | DB = Status | | 4 | Memory write | AB = Address of WR15 | | - | , | DB = Status | | 5 | ALU | AB = NC | | 3 | | DB = PC | | 6 | Memory write | AB = Address of workspace register 14 | | Ū | Memory was | DB = PC+2 | | 7 | ALU | AB = Address of WR13 | | , | | DB = SD | | 8 | Memory write | AB = Address of workspace register 13 | | O | | DB = WP | | 9 | ALU | AB = NC | | | ALC | DB = SD | | 10 | Memory read | AB = Address of second word of | | 10 | Momory Trad | interrupt vector | | | | DB = New PC | | 11 | ALU | AB = NC | | 11 | 1 | DB = SD | | | | | <sup>\*</sup>Occurs immediately after last clock cycle of preceding instruction Figure H-1. ALU Cycle Figure H-2. CRU Cycle Figure H-3. TMS 9900 Memory Cycle (No Wait States) Figure H-4. TMS 9980A/81 Memory Cycle (No Wait States) ## APPENDIX I ## **DATA TERMINAL HOOKUP** - I.1 TELETYPEWRITER TERMINAL STRIP CONNECTIONS - I.2 EIA RS-232-C CABLING FOR 733 DATA TERMINAL Figure I-1. Teletypewriter Terminal Strip Connections Figure I-2. EIA RS-232-C Cabling for 733 Data Terminal ### APPENDIX J # I/O CABLES AND CONNECTORS | Connector | Description | Part Number | |-----------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | J1 | 4 contact plug | AMP 1-480702-0 | | | Contacts (take 18-24<br>AWG wire) | AMP 350689-1 | | J2 | 6 contact plug | AMP 1-480704-0 | | | Contacts (take 18-24<br>AWG wire) | AMP 350689-1 | | J3 | 25 contact cable connector | ITT Cannon or TRW Cinch DB-25P | | J4 & J5 | 40-pin connectors for flat ribbon cable Individual conductors (Use #22 to #26 wires | <ol> <li>Berg 65484-017 (Has strain relief)</li> <li>Berg 65485-017 (No strain relief)</li> <li>3M 3417-5000 (Has strain relief)</li> <li>Berg 65043-017</li> </ol> | | | and Berg 47743, 47747,<br>or 75691-013 pins) | | | J4 & J5 | 40 conductor cable assemblies with connectors. | <ol> <li>AP Products 924015-36-R 36", connector at one end</li> <li>AP Products 924005-06-R 6", connectors at both ends</li> <li>AP Products 924005-18-R 18", connectors at both ends</li> <li>AP Products 924005-36-R 36", connectors at both ends</li> </ol> | Amp Incorporated Harrisburg, PA 17105 AP Products INC Box 110-Q Plainesville, Ohio 44077 3M Company Electronic Products Division Saint Paul, MN 55101 E. I. du Pont de Nemours & Co. INC. Berg Electronics Division New Cumberland, PA 17070 # APPENDIX K # PARTS LIST FOR TM 990/189 MICROCOMPUTER # TM 990/189 PARTS LIST (Sheet 1 of 2) | Symbol | Description | Qty | |-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------| | CO1, CO2<br>CO3, CO4<br>CO5 | Capacitor, fixed, tantilum, 150 uFd, 10%, 15 V<br>Capacitor, fixed, tantilum, 100 uFd, 10%, 20 V<br>Capacitor, fixed, tantilum, 39 uFd, 10%, 10 V | 2<br>2<br>1 | | C06, C07, C10<br>C12 to C37<br>C08, C09<br>C11 | Capacitor, fixed, axial lead, 0.047 uFd, +80%, -20%<br>Capacitor, fixed, ceramic, 0.100 uFd, 10%, 50 V<br>Capacitor, fixed, tantilum, 56 uFd, 10%, 6 V | 29<br>2 | | CR08 | Optoelectronic device, TIL 220<br>Diode, 1N4001, rectifier, 1 A, 50 PIV<br>Diode, 1N914B, switching, 75 PIV, 75 mA<br>Diode, 1N758A, 10.0 V, 5%, voltage regulator | 7<br>1<br>2<br>1 | | P1<br>P2<br>P4, P5 | Connector, universal PWB mounting, 4 circuit (AMP 350430-1)<br>Connector, universal PWB mounting, 6 circuit (AMP 350431-1)<br>Header, 20 pin. straight double row | 1<br>1<br>2 | | Q01 to Q09<br>Q10, Q11<br>Q13 | Transistor, TI A5T2207, PNP, silicon<br>Transistor, TI A5T2222, NPN, silicon<br>Transistor, TI 2N2219A, NPN, general purpose, SW TO5 | 9<br>2<br>1 | | | Resistor, fixed, 120 ohm, 5%, 0.25 W | 7 | | R05, R06, R1<br>R25, R41<br>R09, R10, R2 | Resistor, fixed, 1.0 Kilohm, 5%, 0.25 W | 7 | | R46, R47 R14 R15 to R22 R23,R27,R43 R26 R29, R45 R30, R31 R40 R42 R44 R48 R50 R51 | Resistor, fixed, 470 ohm, 5%, 0.25 W Resistor, fixed, 100 kilohm, 5%, 0.25 W Resistor, fixed, 430 ohm, 5%, 0.25 W Resistor, fixed, 10 kilohm, 5%, 0.25 W Resistor, fixed, 2.2 kilohm, 5%, 0.25 W Resistor, fixed, 4.7 kilohm, 5%, 0.25 W Resistor, fixed, 15 kilohm, 5%, 0.25 W Resistor, fixed, 12 kilohm, 5%, 0.25 W Resistor, fixed, 1.5 kilohm, 5%, 0.25 W Resistor, fixed, 1.5 kilohm, 5%, 0.25 W Resistor, fixed, 220 ohm, 5%, 0.25 W Resistor, fixed, 330 kilohm, 5%, 0.25 W Resistor, fixed, 330 kilohm, 5%, 0.25 W Resistor, fixed, 2.2 megohm, 5%, 0.25 W | 5<br>1<br>8<br>3<br>1<br>2<br>2<br>1<br>1<br>1<br>1 | | S1 | Toggle switch (Cutler-Hammer SF6TGX392) | 1 | # TM 990/189 PARTS LIST (Sheet 2 of 2) | Symbol | Description | <u>Qty</u> | |-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------| | U01, U07<br>U02<br>U03<br>U04<br>U05, U08<br>U06, U13<br>U09, U12<br>U10, U11<br>U14, U28<br>U15<br>U16<br>U17<br>U19<br>U20, U22<br>U24<br>U25 | Network, SN7416N IC, SN74LS2987N, quad 2-input multiplexer Network, SN74LS109N Network, SN74LS112N Network, 74LS145 Network SN74LS00N Resistor, 10.0 Kilohm, pullup, 16 pins, DIL TMS 9901 Programmable system interface Network, SN74LS04N Network, SN74LS08N Resistor, 1.0 kilohm, pullup, 16 pins, DIL Resistor network, 2.2 Kilohm, 2% Microprocessor, MP 9529 IC, 2114 1024 x 4-bit static RAM Network, SN74LS1 Network, SN74LS27N IC, SN74LS123N, monostable multivibrator | 2 1 1 1 2 2 2 2 1 1 1 1 1 1 1 1 1 1 1 1 | | U29<br>U33<br>U34<br>U35<br>U36<br>U38 | ROM with UNIBUG monitor Network, SN74LS139N Network, SN74LS32N Network, SN75189AN, quad line receiver (MC1489AL) IC, RC4558P operational amplifier | 1<br>1<br>1<br>1 | | VR1 | IC, voltage regulator (UA7905C, MC7905CP) | 1 | | Y1 | Crystal, 8.000 MHz, quartz (No. Eng. HC18/uNE-18) | 1 | | | Sound disk: (P/N SK160: Gulton Indst., Box 4300, Fullerton, Cal. 92634 P/N 60993: Vernitron, 232 Forbes Rd, Redford Ohio, 44146 | 1<br>4 or<br>) | # TM 990/189 MICROCOMPUTER USER RESPONSE SHEET It is our desire to provide our customers with the best documentation possible. After using this manual, please complete this sheet and mail it, postpaid, to us. Your comments will be given every consideration. | 1. | Is the manual well organized? ` | /es No | Comments: | | | | |--------------------------------------------|-----------------------------------|------------------------|------------|-----|-------------|--| | 2. | Is text clearly presented and ad- | | | | | | | Com | ments: | | | | | | | 3. | What subject matter could be e | kpanded or clarified? | | | | | | 4. | Is the instruction set adequately | covered? Yes | No | | | | | Com | ments: | | | | | | | <b>5</b> . | Do you wish more data that wo | uld clarify an instruc | tion? Yes | _No | <del></del> | | | Com | ments: | | | | | | | 6. | Please explain the application in | tended for your boa | rd: | | | | | | | | | | | | | Scho | ool Course | Home | Evaluation | | Other | | | Scho | Other comments concerning the | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 7.<br>———————————————————————————————————— | | TM 990/189 and th | is manual: | | | | | 7<br><br>Nam | Other comments concerning the | TM 990/189 and th | is manual: | | | | **FOLD** BUSINESS REPLY MAIL FIRST CLASS PERMIT NO. 6189 HOUSTON, TX POSTAGE WILL BE PAID BY ADDRESSEE TEXAS INSTRUMENTS INCORPORATED MOS MICROCOMPUTER PRODUCTS BOX 1443 HOUSTON, TEXAS 77001 ATTENTION: M/S 6750 NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES