

# **TMS370C16 Central Processing Unit,** System, and Instruction Set

**PRISM Module Library** 





cMCU370<sup>™</sup> Products

### TMS370C16 Central Processing Unit, System, and Instruction Set Reference Guide

**PRISM Module Library** 

March 1994



#### **IMPORTANT NOTICE**

Texas Instruments Incorporated (TI) reserves the right to make changes to its products or to discontinue any semiconductor product or service without notice, and advises its customers to obtain the latest version of relevant information to verify, before placing orders, that the information being relied on is current.

TI warrants performance of its semiconductor products and related software to current specifications in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems necessary to support this warranty. Specific testing of all parameters of each device is not necessarily performed, except those mandated by government requirements.

Please be aware that TI products are not intended for use in life-support appliances, devices, or systems. Use of TI product in such applications requires the written approval of the appropriate TI officer. Certain applications using semiconductor devices may involve potential risks of personal injury, property damage, or loss of life. In order to minimize these risks, adequate design and operating safeguards should be provided by the customer to minimize inherent or procedural hazards. Inclusion of TI products in such applications is understood to be fully at the risk of the customer using TI devices or systems.

TI assumes no liability for applications assistance, customer product design, software performance, or infringement of patents or services described herein. Nor does TI warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor products or services might be or are used.

Copyright © 1994, Texas Instruments Incorporated

### Preface

### **Read This First**

#### Overview

Texas Instruments uses PRISM methodology, with its modular fabrication processes, to integrate analog and digital functions on a single chip. The process technologies currently include VLSI CMOS, nonvolatile memories (EPROM/EEPROM), lateral DMOS, high-voltage analog CMOS, and high-density analog CMOS

The 16-bit TMS370C16 CPU is part of the cMCU370<sup>™</sup> family of microcontroller devices. This manual provides information about the TMS370C16 CPU architecture, features, operation, and assembly language instruction set; it also includes helpful information about implementing a TMS370C16-based microcontroller design.

Related documentation is listed on page v.

#### Manual Organization

- Chapter 1 gives a brief overview of the TMS370C16 microcontroller device.
- Chapter 2 describes the components and operation of the TMS370C16 CPU architecture, including CPU registers and memory organization.
- Chapter 3 describes the TMS370C16 system configuration, registers, device interrupts, and reset.
- Chapter 4 describes the different addressing modes used by the instruction set.
- □ Chapter 5 lists and describes the TMS370C16 assembly language instructions, execution sequence, effects, and examples.
- Appendix A, Glossary, explains and defines terms and abbreviations used in this manual.

#### Style, Symbols, and Definitions

This document uses the following conventions.

- Abbreviations:
  - 'C16: TMS370C16 CPU-based devices
  - **LSB, MSB**: Least significant and most significant *bits*
  - **LSbyte, MSbyte**: Least and most significant *bytes*
  - Register and bit names: SCR1.7, for example

The register name (located to the left of the period) is an alpha abbreviation (e.g., SSR = system status register, and SCR1 = system control register 1). The bit number is to the right of the period (e.g., SCR1.7 is bit 7 of register SCR1 as shown in Figure 3–3 on page 3-7).

Definitions of *device* and *module* as used in this manual:

- Device: The cMCU370 microcontroller; includes the TMS370C16 CPU along with all selected modules integrated on a single chip.
- Module: An element that provides a specific function (such as a serial interface, memory, analog-to-digital conversion, timing, I/0, etc.). A list of modules is provided in the documentation-title list on page v (in this preface).

Program listings and program examples are shown in a special typeface similar to a typewriter's.

#### Note: Assembler Statements Are Not Case Sensitive

TMS370C16 assembly language statements are not case sensitive. You can enter them in lowercase, uppercase, or a combination. To emphasize this, assembly language statements are shown throughout this user's guide in both uppercase and lowercase.

| Related Docur | mentation From Texas Instruments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Literature<br>Number |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
|               | TMS370C8 CPU, System, and Instruction Set Reference Guide                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SPNU042              |
|               | TMS370C16 CPU, System, and Instruction Set Reference Guide<br>PRISM Module Library Reference Set, Volume 1<br>Volume 1 includes the following module reference guides.                                                                                                                                                                                                                                                                                                                                            | SPNU043<br>SPNU031   |
|               | <ul> <li>cMCU370 Microcontroller Products Introduction</li> <li>Clock Modules Reference Guide</li> <li>Watchdog and Real-Time Interrupt Module Reference Guide</li> <li>EEPROM/EPROM Modules Reference Guide</li> <li>TMS370C8 Timer Modules Reference Guide</li> <li>Serial Communications Interface Module Reference Guide</li> <li>Serial Peripheral Interface Module Reference Guide</li> <li>Analog-to-Digital Converter Module Reference Guide</li> </ul>                                                   |                      |
|               | <ul> <li>PRISM Module Library Reference Set, Volume 2</li> <li>Volume 2 includes the following module reference guides.</li> <li>TMS370C16 Timer Modules Reference Guide</li> <li>Voltage Regulator Modules Reference Guide</li> <li>Gage Driver Modules Reference Guide</li> <li>Power Driver Modules Reference Guide</li> <li>Switch Interface Module Reference Guide</li> <li>Variable Reluctance Sensor Module Reference Guide</li> <li>Some books on this list will be available at a later date.</li> </ul> | SPNU032              |

#### If You Need Assistance. . .

| If you want to                                                            | Do this                                                                                                                                          |
|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Ask questions about product<br>operation, or report suspected<br>problems | Call the TI microcontroller hotline:<br>(713) 274–2370<br>FAX: (713) 274–4203                                                                    |
| Request more information about<br>Texas Instruments products              | Write to:<br>Texas Instruments Incorporated<br>Market Communications Manager, MS 6101<br>P.O. Box 1443<br>Houston, Texas 77251–1443              |
| Order Texas Instruments<br>documentation                                  | Call the TI Literature Response Center: (800) 477-8924                                                                                           |
| Bulletin board number                                                     | (713) 274–3700                                                                                                                                   |
| Report mistakes in this document<br>or any other TI documentation         | Send your comments to:<br>Texas Instruments Incorporated<br>Technical Publications Manager, MS 702<br>P.O. Box 1443<br>Houston, Texas 77251–1443 |
|                                                                           | or call the TI microcontroller hotline (phone number at top of this table)                                                                       |

#### Information About Cautions

The information in a caution is provided for your protection. Please read each caution carefully.



#### Trademarks

cMCU370 is a registered trademark of Texas Instruments Incorporated.

# Contents

| - |      |          |                                                                 |
|---|------|----------|-----------------------------------------------------------------|
| 1 |      |          |                                                                 |
|   | 1.1  |          | 70C16 CPU — Device-Specific Operation 1-2                       |
|   | 1.2  |          | System, and Instruction Set Features 1-3                        |
|   | 1.3  | TMS37    | 70C16 Control Registers 1-4                                     |
| 2 | Arch | itecture |                                                                 |
|   | 2.1  | -        | mmer's Model                                                    |
|   | 2.2  | CPU R    | legister File (R0 – R15) 2-4                                    |
|   |      | 2.2.1    | Frame Pointer, FP (R0) 2-5                                      |
|   |      | 2.2.2    | Implied Register, IM (R1) 2-5                                   |
|   |      | 2.2.3    | Stack Pointer, SP (R13) 2-6                                     |
|   |      | 2.2.4    | Status Register, ST (R14) 2-6                                   |
|   |      | 2.2.5    | Zero Register, ZR (R15) 2-7                                     |
|   | 2.3  | Progra   | m Counter (PC) and Address Bus 2-8                              |
|   | 2.4  | Instruc  | tion Organization                                               |
|   | 2.5  | System   | n Stack                                                         |
|   |      | 2.5.1    | Stack Operation During Interrupts 2-12                          |
|   |      | 2.5.2    | Stack Use with a Call                                           |
|   | 2.6  | Data O   | Organization and Memory Mapping 2-14                            |
| 3 | TMS  | 370C16   | System Configuration                                            |
|   | 3.1  | System   | n Configuration Overview                                        |
|   | 3.2  | System   | n Reset Operation                                               |
|   | 3.3  | CLKOU    | JT Pin Function Selection                                       |
|   | 3.4  | Paralle  | I Signature Analysis Operation (CRC Generator)                  |
|   | 3.5  | System   | n Configuration Registers                                       |
|   |      | 3.5.1    | System Control Register 0 (SCR0) 3-8                            |
|   |      | 3.5.2    | System Control Register 1 (SCR1) 3-9                            |
|   |      | 3.5.3    | System Reset Status Register (SRSR) 3-10                        |
|   |      | 3.5.4    | System Status Register (SSR) 3-12                               |
|   |      | 3.5.5    | Parallel Signature Analysis Registers (PSARn)                   |
|   | 3.6  | Genera   | al-Purpose Digital Pin Functions                                |
|   |      | 3.6.1    | Digital Output/Control Registers (OCRn)                         |
|   |      | 3.6.2    | Digital Input/Status Registers (ISRn)                           |
|   |      | 3.6.3    | Digital Port Direction and Port Data Registers (xDIR and xDATA) |
|   | 3.7  | Interru  | pt and Exception Handling                                       |

|   |       | 3.7.1    | Interrupt/Exception Sources                               | 9 |
|---|-------|----------|-----------------------------------------------------------|---|
|   |       | 3.7.2    | Vector Table                                              | 1 |
|   |       | 3.7.3    | Reset and Interrupt Operation 3-2                         | 1 |
|   |       | 3.7.4    | Nonmaskable Interrupt (NMI) Processing 3-2                | 3 |
|   |       | 3.7.5    | Peripheral Module Interrupt Processing 3-24               | 4 |
|   |       | 3.7.6    | Software Exception (TRAPs, etc.) Processing 3-24          | 4 |
|   | 3.8   | Externa  | al and Power Module Interrupts 3-2                        | 5 |
|   |       | 3.8.1    | External Interrupt Pins 3-2                               | 5 |
|   |       | 3.8.2    | Power Module Interrupts 3-3                               | 5 |
|   |       | 3.8.3    | Phantom Interrupt Vector                                  | 7 |
|   | 3.9   | Multiple | e Interrupt Servicing                                     | B |
|   | 3.10  | TMS37    | 0C16 Interrupt Configurability Options                    | 9 |
|   | 3.11  | Low-Po   | ower and Idle Modes                                       | D |
|   |       | 3.11.1   | Overview                                                  | 0 |
|   |       | 3.11.2   | Low-Power Wakeup Interrupt 3-4                            | 0 |
| 4 | ۵ddr  | eeina I  | Aodes                                                     | 1 |
| • | 4.1   | -        | Summary                                                   |   |
|   | 4.2   |          | Addressing                                                |   |
|   | 4.3   | •        | ative Addressing                                          |   |
|   | 4.4   |          | y-Direct Addressing                                       |   |
|   | 4.5   |          | iate Values                                               |   |
|   | 4.6   |          | er-Direct Addressing                                      |   |
|   | 4.7   | -        | er-Indirect Addressing                                    |   |
|   |       | 4.7.1    | Register-Indirect Addressing, No Displacement             |   |
|   |       |          | (Register Contents = Effective Address) 4-1               | 0 |
|   |       | 4.7.2    | Register Indirect With Displacement (Offset) 4-13         | 3 |
|   | 4.8   | Setting  | the Word Address for CALL, JMP, and FMOV Instructions 4-1 | 6 |
| 5 | Asse  | mbiv La  | nguage instructions                                       | 1 |
| - | 5.1   | -        | tion Set Summary                                          |   |
|   | 5.2   |          | tion Set Summary Table                                    |   |
|   | 5.3   |          | tion Descriptions in Alphabetical Order                   |   |
| Α | Glose | arv      |                                                           | 1 |
|   |       |          |                                                           |   |

# Figures

| 2–1  | Programmer's Model                                                                    | 2-3  |
|------|---------------------------------------------------------------------------------------|------|
| 2–2  | Registers R0 to R15                                                                   | 2-4  |
| 2–3  | Program Counter to Address Bus Transition                                             | 2-8  |
| 2–4  | Relationship Between the PC and Memory Address                                        | 2-9  |
| 2–5  | One-, Two-, and Three-Word Instruction Examples                                       | 2-10 |
| 2–6  | Example of Stack Use to and From a Subroutine                                         | 2-13 |
| 2–7  | Bit and Byte Numbering for Instructions, Registers, and Words                         | 2-14 |
| 2–8  | Differences in Memory and Register Byte Destinations                                  | 2-16 |
| 2–9  | Data Organization Examples in Registers and Memory                                    | 2-17 |
| 2–10 | Typical 16-Bit Memory Map 2                                                           | 2-18 |
| 2–11 | Location and Names of Control Registers 2                                             | 2-19 |
| 3–1  | System Block Diagram                                                                  | 3-2  |
| 3–2  | Reset State Diagram — Normal Run Mode                                                 | 3-4  |
| 3–3  | System Configuration Registers                                                        | 3-7  |
| 34   | Digital I/O Control and Status Registers                                              | -15  |
| 35   | Vector Table Organization in Memory                                                   | -20  |
| 36   | Summary of Reset, NMI, Peripheral Interrupts, and Software Exception Operations 3     | 3-22 |
| 3–7  | Interrupt-Frame Typical Configurations                                                | 8-27 |
| 38   | Typical Interrupt Frame                                                               | 8-28 |
| 4–1  | Implied Addressing                                                                    | 4-3  |
| 4–2  | PC-Relative Addressing                                                                |      |
| 4–3  | Memory-Direct Addressing (& Operator)                                                 | 4-5  |
| 44   | Operand Is Immediate Value (# Operator)                                               |      |
| 45   | Register-Direct Addressing                                                            |      |
| 46   | Register Direct With CALL or JMP Instructions Addresses 128K Bytes                    | 4-8  |
| 4–7  | Register Indirect (Operand: *Rn) 4                                                    | -10  |
| 48   | Register Indirect With Predecrement (Operand: *-Rn)                                   | I-11 |
| 49   | Register Indirect with Postincrement (Operand: *Rn+) and Predecrement (Operand: *–Rn) | -12  |
| 4–10 | Offset + Register in Word Format (Operand: *disp16[Rn]) 4                             |      |
| 4–11 | Offset + Register in Byte Format (Operand: *disp16[Rn]) 4                             | -14  |
| 4–12 | Offset + Register for JMP and CALL Instructions (Operand: *disp16[Rn]) 4              | -15  |
| 4–13 | Using the ? Operator to Set the Word Address for a CALL or JMP, Direct Register 4     |      |
| 4–14 | Use the ? Operator to Set the Word Address for an FMOV, Indirect Register 4           |      |
| 5–1  | Interpreting the Instruction Execution Detail                                         | 5-16 |
| 5–2  | B{COND} Instruction Displacements                                                     | 5-29 |

| 5–3 | BRBIT0 and BRBIT1 Instruction Displacements | 5-31  |
|-----|---------------------------------------------|-------|
| 5-4 | CALL and RTS Instruction Example            | 5-35  |
|     | DBNZ Displacement Computation               |       |
| 56  | Vector Table for TRAP Instruction           | 5-113 |

# **Tables**

| 1—1 | TMS370C16 System Configuration Control Registers | 1-4  |
|-----|--------------------------------------------------|------|
| 1–2 | TMS370C16 Digital Pin Function Control Registers | 1-4  |
| 1–3 | TMS370C16 Typical Interrupt Control Registers    | 1-5  |
| 2–1 | Status Register (ST) Bits                        | 2-6  |
| 2–2 | Instructions That Use a 17-Bit Address           | 2-9  |
| 2–3 | Instructions That Use The Stack                  | 2-11 |
| 3–1 | CLKOUT Pin Function Options                      | 3-6  |
| 3–2 | External Interrupt Types                         | 3-26 |
| 3–3 | External Interrupt Pin Functions                 | 3-26 |
| 34  | Type A Interrupt Control Bit Freeze Options      | 3-39 |
| 4–1 | Addressing Mode Summary                          | 4-2  |
| 4–2 | Register Indirect Addressing Summary             | 4-9  |
| 5–1 | Abbreviations Used to Describe Instructions      | 5-2  |
| 5–2 | Symbols Used to Describe Instructions            | 5-3  |
| 5–3 | Branches Listed by Opcode 5                      | 5-28 |
|     |                                                  |      |

# **Notes and Cautions**

| Definitions of Device and Module Used In This Manual               | 1-2  |
|--------------------------------------------------------------------|------|
| Register Considerations                                            | 2-7  |
| Word Address Definition                                            | 2-8  |
| The SP Must Contain an Even Value                                  | 2-12 |
| Word Address Definition                                            | 2-14 |
| Avoid Interrupting a Reset With an NMI                             |      |
| INTx Used to Represent INT1 – INT6                                 |      |
| Derivation of Memory-Direct Format (& Operator)                    | 4-6  |
| *Rn Can Be Used If *disp[Rn] Is Assembled                          |      |
| Decrement/Increment Considerations                                 |      |
| Assembler Statements Are Not Case Sensitive                        | 5-16 |
| The wbfd Column Values                                             | 5-18 |
| PC's 16-Bit Word Address Translates to 17-Bit Address Bus          |      |
| Do Not Use Operand Rs,IM:Rs                                        |      |
| 16-Bit Word Address Translates to 17-Bit Address Bus               |      |
| Use FMOV to Address 0–1FFFFh (Up to 128K Bytes)                    |      |
| Considerations for >64K Bytes and Effect of Byte Size on Registers |      |
| Five Trap Words Are Reserved                                       |      |
| TRAP Enumerator Source                                             |      |
|                                                                    |      |

### Chapter 1

### Introduction

The TMS370C16 microcontroller core is part of the PRISM Modular Library. With reusable engineering techniques, it can be combined with other building blocks from the modular library to generate a diversified family of highly integrated devices.

This chapter gives a brief overview of the 'C16 CPU — its device-specific operation, its features, and its registers.

This chapter covers the following topics:

#### Topic

### Page

|   |                                               | 8   |
|---|-----------------------------------------------|-----|
|   | 1.1 TMS370C16 CPU — Device-Specific Operation | 8   |
|   | 11 TMS370C16 CPI — Device-Specific Operation  | 8   |
|   |                                               | 8   |
|   |                                               | 8   |
|   |                                               | 8   |
|   | 1.2 CPU, System, and instruction Set Features | 8   |
|   | 12 LPU System and instruction Set Features    | 8 - |
|   |                                               | 8   |
|   |                                               | 8   |
|   |                                               | 8   |
|   | 1.3 TMS370C16 Control Registers 1-4           | 8   |
| 1 |                                               | 8   |
| 1 | 110                                           | 8   |
| 1 |                                               | 8   |
|   |                                               |     |

#### 1.1 TMS370C16 CPU — Device-Specific Operation

The total integration concept of the cMCU microcontroller family makes multiple configurations possible. Because of this flexibility, certain module features are device specific and therefore cannot be presented as an absolute in this document. You should refer to the specific device data sheet to determine the features and functions available on your particular device. Here is a partial list of these indefinable areas:

- Memory array size and memory map location for RAM, ROM/EPROM, EEPROM, and peripheral file
- System clock (SYSCLK) operation
- Digital I/O pin functionality
- Interrupts (The number of available external and internal interrupts and their associated vectors.)
- Low-power mode availability and interrupt exit capability.

#### Note: Definitions of Device and Module Used In This Manual

**Device:** The core microcontroller. It includes the CPU (TMS370C16), along with all selected modules, integrated on a single chip.

**Module:** An element that provides a specific function (such as a serial interface, memory, analog-to-digital conversion, timing, I/0, etc.) A list of modules is provided on page v of the preface.

#### 1.2 CPU, System, and Instruction Set Features

The TMS370C16 CPU module consists of the following:

- □ 16-bit CPU containing the associated registers:
  - Frame pointer
  - Implied register
  - Stack pointer
  - Status register
  - Zero register
  - 16-bit program counter
- 17-bit address space
- □ Various memory types supported by the 'C16 architecture
  - RAM
  - Peripheral file control registers
  - Data EEPROM
  - Program memory (ROM or EPROM)
- Seven possible reset sources
- Interrupt structure
  - Software-selectable priority levels
  - Nonmaskable Interrupt (NMI) options
  - Variable number of interrupts, depending on the device configurations
  - Individual interrupt vectors
- Two low-power modes
- Set of 126 instructions including byte, word, and long-word formats.

#### 1.3 TMS370C16 Control Registers

The CPU and system functions are controlled by registers in three separate frames as illustrated in the following three tables.

Table 1–1. TMS370C16 System Configuration Control Registers

|         | Register | Register                                            |         | oed in |
|---------|----------|-----------------------------------------------------|---------|--------|
| Address | Symbol   | Register Name                                       | Section | Page   |
| 0010h   |          | Reserved                                            |         |        |
|         |          |                                                     |         |        |
| to      |          | State of the state of the state of the state of the |         |        |
|         |          | •                                                   |         |        |
| 0017h   |          | Reserved                                            |         |        |
| 0018h   | SCR0     | System Control Register 0                           | 3.5.1   | 3-8    |
| 0019h   | SCR1     | System Control Register 1                           | 3.5.2   | 3-9    |
| 001Ah   | SRSR     | System Reset Status Register                        | 3.5.3   | 3-10   |
| 001Bh   | SSR      | System Status Register                              | 3.5.4   | 3-12   |
| 001Ch   |          | Reserved                                            |         |        |
| 001Dh   |          | Reserved                                            |         |        |
| 001Eh   | PSAR1    | Parallel Signature Analysis Register 1              | 3.5.5   | 3-13   |
| 001Fh   | PSAR2    | Parallel Signature Analysis Register 2              | 3.5.5   | 3-13   |

Table 1–2. TMS370C16 Digital Pin Function Control Registers

| Register |        | Register                      |         | Described in |  |
|----------|--------|-------------------------------|---------|--------------|--|
| Address  | Symbol | Register Name                 | Section | Page         |  |
| 0060h    | OCR1   | Output/Control Register 1     | 3.6.1   | 3-16         |  |
| 0061h    | OCR2   | Output/Control Register 2     | 3.6.1   | 3-16         |  |
| 0062h    | OCR3   | Output/Control Register 3     | 3.6.1   | 3-16         |  |
| 0063h    | OCR4   | Output/Control Register 4     | 3.6.1   | 3-16         |  |
| 0064h    | ISR1   | Input/Status Register 1       | 3.6.2   | 3-16         |  |
| 0065h    | ISR2   | Input/Status Register 2       | 3.6.2   | 3-16         |  |
| 0066h    | ISR3   | Input/Status Register 2       | 3.6.2   | 3-16         |  |
| 0067h    | ISR4   | Input/Status Register 2       | 3.6.2   | 3-16         |  |
| 0068h    | ADIR   | I/O Port A Direction Register | 3.6.3   | 3-17         |  |
| 0069h    | ADATA  | I/O Port A Data Register      | 3.6.3   | 3-17         |  |
| 006Ah    | BDIR   | I/O Port B Direction Register | 3.6.3   | 3-17         |  |
| 006Bh    | BDATA  | I/O Port B Data Register      | 3.6.3   | 3-17         |  |
| 006Ch    | CDIR   | I/O Port C Direction Register | 3.6.3   | 3-17         |  |
| 006Dh    | CDATA  | I/O Port C Data Register      | 3.6.3   | 3-17         |  |
| 006Eh    | DDIR   | I/O Port D Direction Register | 3.6.3   | 3-17         |  |
| 006Fh    | DDATA  | I/O Port D Data Register      | 3.6.3   | 3-17         |  |

|         | Register   |                                          | Described in |      |
|---------|------------|------------------------------------------|--------------|------|
| Address | Symbol     | Register Name                            | Section      | Page |
| 0070h   | INT1       | Type A Interrupt                         | 3.8.1.1      | 3-29 |
| 0071h   | INT1 FLG   | Type A Interrupt Flag                    | 3.8.1.1      | 3-29 |
| 0072h   | INT2       | Type B Interrupt                         | 3.8.1.3      | 3-31 |
| 0073h   | INT2 FLG   | Type B Interrupt Flag                    | 3.8.1.3      | 3-31 |
| 0074h   | INT3       | Type C Interrupt                         | 3.8.1.5      | 3-33 |
| 0075h   | INT3 FLG   | Type C Interrupt Flag                    | 3.8.1.5      | 3-33 |
| 0076h   |            | Reserved                                 |              |      |
| 0077h   |            | Reserved                                 |              |      |
| 0078h   |            | Reserved                                 |              |      |
| 0079h   |            | Reserved                                 |              |      |
| 007Ah   |            | Reserved                                 |              |      |
| 007Bh   |            | Reserved                                 |              |      |
| 007Ch   | PM2 ENABLE | Power Module Interrupt Enable Register 2 | 3.8.2.1      | 3-35 |
| 007Dh   | PM2 FLAGS  | Power Module Interrupt Flag Register 2   | 3.8.2.2      | 3-36 |
| 007Eh   | PM1 ENABLE | Power Module Interrupt Enable Register 1 | 3.8.2.1      | 3-35 |
| 007Fh   | PM1 FLAGS  | Power Module Interrupt Flag Register 1   | 3.8.2.2      | 3-36 |

#### Table 1–3. TMS370C16 Typical Interrupt Control Registers

1-6 TMS370C16 CPU

### Chapter 2

### Architecture

This chapter describes the programmer's model registers and how the 128Kbyte memory is organized and addressed. Topics in this chapter include:

#### Topic

#### Page

| 2.1 | Programmer's Model                      |
|-----|-----------------------------------------|
| 2.2 | CPU Register File (R0–R15)              |
|     | 2.2.1 Frame Pointer (FP, R0) 2-5        |
|     | 2.2.2 Implied Register (IM, R1) 2-5     |
|     | 2.2.3 Stack Pointer (SP, R13) 2-6       |
|     | 2.2.4 Status Register (ST, R14) 2-6     |
|     | 2.2.5 Zero Register (ZR, R15)           |
| 2.3 | Program Counter (PC) and Address Bus    |
| 2.4 | instruction Organization 2-10           |
| 2.5 | System Stack                            |
|     | 2.5.1 Stack Operation During Interrupts |
|     | 2.5.2 Stack Use with a Call 2-12        |
| 2.6 | Data Organization and Memory Mapping    |

#### 2.1 Programmer's Model

The TMS370C16 programmer's model consists of a 16-bit program counter and a 16-register file, which contains 11 general-purpose registers as well as the frame pointer, implied register, stack pointer, status register, and zero register. These are shown in Figure 2–1. The 'C16 may access RAM, EEPROM, EPROM, or ROM modules internally, depending on your device configuration. The 'C16 may also access the system module (further described in Section 3.1) that controls device operations such as stack location, reset, interrupts, I/O configurations, and the CLKOUT pin initialization. The 'C16 CPU and system module interface through the system address, data, and control buses to other modules such as the SPI, SCI, ADC, and gage drivers, depending upon your specific device configuration.

Figure 2–1 shows the register file and the memory accessible by the TMS370C16 CPU. The 16-register file is located in the CPU and includes five preassigned registers (R0, R1, R13, R14, and R15). This register file is discussed in further detail in Section 2.2, starting on page 2-4, and the status register (R14) and its bits, shown in the bottom of Figure 2–1, are described in more detail in subsection 2.2.4, page 2-6.

The program counter (PC), not part of the register file, contains the *word address* of an opcode or operand. The word address is applied to address lines A16–A1, with line A0 set to 0 (effectively multiplying the actual byte address by 2). This allows accessing data and executing code in a full 128K bytes of memory. The word address is further described in Section 2.3 on page 2-8, which includes a list of instructions using a 17-bit address (see Table 2–2 on page 2-9).

2-2



#### 2.2 CPU Register File (R0 - R15)

The TMS370C16 CPU contains 16 registers, R0 - R15, that are not part of the memory map. Of the 16 registers, five can be used for the specialized functions listed in Figure 2–2 (registers R0, R1, R13, R14, and R15) or for general purposes.

R2-R12, the 11 nonspecialized registers of the CPU register file, can be used for data manipulation for bit, byte (least significant byte), or word values. Take care when attempting to use any of the five specialized registers as generalpurpose registers. The zero register (R15) reads as a zero value at all times, *and write values will be ignored.* Of the other specialized registers, R0 and R1 can be used conditionally, but R13 (stack pointer) and R14 (status) should not be used as general purpose at any time.

The values of the register file *are not* initialized by a reset. Your system software should initialize these registers during a startup procedure.

Figure 2–2. Registers R0 to R15



#### 2.2.1 Frame Pointer, FP (R0)

The frame pointer can be used by high-level languages to allocate and deallocate procedure stack frames from the system stack. This register is implicitly used in the following instructions:

- LINK Link the FP to the current frame of the current SP (stack pointer) by pushing the FP onto the stack, setting the FP to the SP value, and then allocating designated words of stack.
- **UNLINK** Deallocate the current system stack frame by placing the FP contents in the SP and then retrieving the previous FP value from the system stack.
- **RTDU** Unlink and deallocate the current system stack frame by placing the FP value in the SP, retrieving the previous FP and PC contents from the stack (to return from a subroutine), and then subtracting a displacement from the SP.

#### 2.2.2 Implied Register, IM (R1)

The implied register assists in dealing with 32-bit objects by serving as the most significant word of the two-word value. Also, in division operations, the IM holds the remainder.

The IM is used implicitly by the following instructions:

- ASRL Arithmetic shift right, longword (32-bit value)
- ASR0L Arithmetic shift right and round to 0, longword (32-bit value); add 1 if N[[ST]] and C[[ST]] are both 1
- SHLL Arithmetic shift left, longword (32-bit value)
- DIVS Division, signed (16- and 32-bit)
- **DIVU** Division, unsigned (16- and 32-bit)
- EXTS Sign-extend word to 32 bits
- LSRL Logically right-shift, longword (32-bit value)
- MPYS Signed word multiplication
- MPYU Unsigned word multiplication
- **TRUNCSL** Test to see if register can be truncated from 32 to 16 bits

#### 2.2.3 Stack Pointer, SP (R13)

The stack pointer identifies the top of the stack — the location within the system stack to be used next (e.g., for storage of the current environment during interrupt processing). The stack also holds the return address for subroutine calls and provides a means of allocating procedure stack frames.

The SP is implicitly declared by the following instructions:

| CALL   | Jump to subroutine (return address on stack)                                                                                                                          |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| LINK   | Link to current stack frame (FP to stack, SP to FP, and allo-<br>cate requested words of space to the stack)                                                          |  |
| POP    | Pull values from top of stack to register(s)                                                                                                                          |  |
| PUSH   | Push values on top of stack from register(s)                                                                                                                          |  |
| RTDU   | Unlink and deallocate current stack frame (return to former PC and new stack address)                                                                                 |  |
| RTI    | Return from interrupt (retrieve PC and ST values from stack)                                                                                                          |  |
| RTS    | Return from subroutine (retrieve PC from stack)                                                                                                                       |  |
| TRAP   | Generate one of 256 trap exceptions (push ST and PC + 1<br>onto stack, use vector offset and TRAP vector table to set PC,<br>and set interrupt level at ST to all 1s) |  |
| UNLINK | Deallocate current stack frame (retrieve previous SP contents from FP register and retrieve old FP contents from stack)                                               |  |

Section 2.5 on page 2-11 contains a detailed discussion of the system stack.

#### 2.2.4 Status Register, ST (R14)

The status register contains CPU status information from operations performed by the Arithmetic Logical Unit (ALU). The condition code bits Z (zero), N (negative), C (carry), and V (overflow) are typically altered during instruction execution. Status is based on the data object size — byte (8), word (16), or longword (32 bits) — of the just-executed instruction. The ST also contains the interrupt mask level bits L2 - L0.



ST bit definitions:

- Reserved (r): Bits reserved for future use. Data written to them are not retained.
- Z: Zero bit. Set to 1 when an instruction generates a zero-value byte, word, or longword.
- N: Negative bit. Generally set to the value of the most significant bit (e.g., sign bit) of an instruction's result. This is bit b7 for byte, b15 for word, and b31 for longword operations.
- C: Carry bit. Set to 1 to indicate whether an unsigned overflow or underflow (carry/borrow) occurred during an arithmetic operation. Testing occurs as appropriate for the size of the data being operated on (byte, word, or longword). Some shift instructions use the C bit as a destination for the bit shifted. Bit load/store instructions treat the C bit as a bit accumulator.
- V: Overflow bit. Generally set to 1 if a signed twos-complement overflow or underflow occurred during an arithmetic operation. Testing occurs as appropriate for the size of the data being operated on (byte, word, or longword).
- L<sub>n</sub>: *Interrupt-mask level bits (L2–L0)*. Coded to specify interrupt levels of 000<sub>2</sub> 111<sub>2</sub> (0-7) with level **7 the highest** priority and level **0 the lowest**. Chapter 3 covers interrupt handling in detail (see Sections 3.7, 3.8, 3.9, and 3.10, beginning on page 3-19).

#### 2.2.5 Zero Register, ZR (R15)

The zero register's contents are *always* 0000h. Thus, it is useful when a zero constant value is required.

This register can be used with indexed addressing (format \*disp[Rn]) to generate a direct address. When Rn is declared to be ZR (disp[ZR]), displacement disp becomes the operand's address (disp + 0). Thus, operands \*disp[ZR] and &disp are equivalent; use of the ampersand (&) operator for direct addressing is further explained in Section 4.4 on page 4-5.

#### Note: Register Considerations

- 1. Do not use R14 (status register) as a general-purpose register.
- 2. R15 (zero register) will always be read as a zero value; writing operations are ignored.

#### 2.3 Program Counter (PC) and Address Bus

The PC is a 16-bit register, *not* included in the register file, that contains the *word* address of the instruction or instruction extension word that the CPU will fetch next. Because the PC uses the word-address data type, the instruction and the instruction extension words can be located at any **even** address in the entire 128K-byte memory address space of the 'C16. The term *word address* is defined in the note below.

#### Note: Word Address Definition

A **word address** is a 16-bit pointer that maps into a 128K-byte address space. Note that 17 bits are needed to fully address a 128K-byte space. Because the 'C16 requires that words begin on an even-byte boundary, the least significant bit of the word's address must be 0 with only the upper 16 bits of an address are required to access the word. A *word address* contains these 16 bits.

The PC holds the 16 *most significant bits* of the 17-bit memory address space. All instructions are word aligned; thus, *the least significant address bit* (bit 0) of all program references **always contains the value 0** (illustrated in Figure 2–3).





Because of a pipeline architecture, the PC typically points to a memory address *two words beyond the currently executing instruction or to its extension word.* This relationship is graphically shown in Figure 2–4.



#### Figure 2-4. Relationship Between the PC and Memory Address

Figure 2–6 on page 2-13 describes execution flow during a jump to a subroutine. It also shows PC values and their corresponding address bus values. The note at the bottom of the figure explains the relationships.

The instructions in Table 2–2 use the PC register (thus generating a 17-bit address).

Table 2–2. Instructions That Use a 17-Bit Address

| Instruction   | Description                                                                          |
|---------------|--------------------------------------------------------------------------------------|
| Bcond         | Branch conditionally                                                                 |
| <b>BRBIT0</b> | Branch if bit equals 0                                                               |
| BRBIT1        | Branch if bit is a 1                                                                 |
| CALL          | Jump to (call) a subroutine (linkage provided)                                       |
| DBNZ          | Decrement register; branch only if result is 0                                       |
| FMOV          | Move (far) data to or from an address of up to 128K bytes                            |
| JMP           | Jump unconditionally                                                                 |
| RTDU          | Return from subroutine and deallocate                                                |
| RTI           | Return from interrupt                                                                |
| RTS           | Return from subroutine                                                               |
| TRAP          | Generate one of 256 trap software interrupts; trap locations begin at address 08000h |

The PC is also involved in the processing of reset, peripheral interrupts, and illegal opcode exceptions.

#### 2.4 Instruction Organization

Bits are organized as shown in Figure 2–7. Instructions utilize one-, two-, or three-word formats as illustrated in Figure 2–5 for three different move instructions.





#### (c) Three-Word Instruction

MOV #1000h,\*LABEL[R6] ; Move 1000h to LABEL + R6



#### 2.5 System Stack

The stack is a dedicated area of last-in/first-out RAM that is:

- Located in the first 64K bytes of memory
- Used for the storage of data that can describe an operating environment about to be exited or re-entered (such as the PC and ST values)
- Accessed by instructions that place data (PUSH instruction) into it from registers or retrieve data (POP instruction) from it into registers
- Used during a peripheral interrupt to store the operating environment that is to be exited (current ST and PC contents) before the address of the interrupt service routine is fetched
- Pointed to by the stack pointer (SP)

Table 2–3 lists instructions that use the stack:

Table 2-3. Instructions That Use The Stack

| Instruction | Description                                                                                                                                                  | Detail                                                                                                                       |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| CALL        | Jump to subroutine; provide return<br>linkage                                                                                                                | Push address of next instruction onto stack,<br>then place destination value in PC (shown in<br>Figure 2–6, page 2-13)       |
| LINK        | Link frame pointer (FP) to current stack; allocate stack space                                                                                               | Push FP onto stack, copy SP (old) to FP, then<br>add displacement to SP for <i>new</i> SP value                              |
| POP         | Copy stack words into specified reg-<br>isters                                                                                                               | Specify range of registers affected                                                                                          |
| PUSH        | Copy specified register words onto the stack                                                                                                                 | Specify range of registers affected                                                                                          |
| RTI         | Return from interrupt                                                                                                                                        | Pop PC and ST values from stack                                                                                              |
| RTS         | Return from subroutine                                                                                                                                       | Pop PC from stack (shown in Figure 2–6,<br>page 2-13; RTS is at step 3 in the figure)                                        |
| RTDU        | Return from subroutine and deallocate current stack space                                                                                                    | Can be a return from a CALL <i>but only if</i> sub-<br>routine executed a LINK instruction without an<br>UNLINK instruction  |
| TRAP        | Generate one of 256 trap exceptions                                                                                                                          | Push ST and address of next instruction onto stack. Retrieve trap subroutine address from trap vector table and place in PC. |
| UNLINK      | Unlink and deallocate stack frame                                                                                                                            | Place FP value in SP, then pop previous FP value from stack                                                                  |
| ILLEGAL     | Generate trap exception; this is<br>caused when the instruction's illegal<br>code of 0000h is decoded (one of<br>several illegal opcodes that cause<br>this) | Push ST and address of next instruction onto stack; place subroutine address from first trap location in PC                  |

#### 2.5.1 Stack Operation During Interrupts

A major use of the stack is to provide return linkage for a context switch. Steps of a typical context switch are as follows:

- 1) Context switch (e.g., interrupt) is recognized. Complete presently executing instruction.
- 2) Store present status register (ST) contents on the stack. Increment the stack pointer (SP) by two to the next memory address.
- Store the present program counter value (PC) at the SP value (next address after the location where the ST is stored). Increment the SP by two.
- 4) Enter and execute the service routine for the context switch. When the routine is complete, reverse the process in steps 1 through 3 above to return to the environment present when the context switch was requested. This return is usually through an RTI (return from interrupt) instruction.
- Decrement the SP by two. Retrieve the previous PC value at that address, and place it in the PC. Decrement the PC by two (this is explained in the RTI instruction description).
- 6) Decrement the SP by two. Retrieve the previous ST value at that address, and place it in the ST.

#### 2.5.2 Stack Use with a Call

Figure 2–6 depicts how a stack is used when calling a subroutine with the CALL (jump to subroutine) instruction and then later returning to the calling environment. Numbered steps at the bottom of the figure correspond to circled numbers in the figure to explain execution sequence.

The stack increments by two after each *push* of a word value onto the stack. Conversely, the stack is decremented by two before each word is *pulled* (*popped*) from a stack.

#### Note: The SP Must Contain an Even Value

Make sure that the value stored in the SP (R13) is an *even* value (a 0 in address line A0). An odd value causes an illegal-access reset when the stack is addressed.

All implicit stack references by these instructions generate *word* read/write cycles to memory and thus are restricted to **even** addresses. The SP contents are used for address lines A0 - A15; thus, they should always be an even value. A nonaligned memory access generates a reset.



Figure 2-6. Example of Stack Use to and From a Subroutine

The CALL sequence:

- ① The CALL SUBR instruction causes a branch to subroutine SUBR with return values stored in the stack. Before the entry address of SUBR is placed in the PC:
  - 1) The present PC value (now pointing four bytes past the address containing the CALL opcode) is stored at the present contents in the stack pointer (SP).
  - 2) The SP is incremented by two.
- ② The value of SUBR is placed in the PC. Execution begins at address C000h and continuesdown to address C0A4h, which contains the last instruction in the subroutine — RTS (return from subroutine).
- ③ RTS returns the program back to the environment at the time of the CALL instruction by:
  - 1) Decrementing the SP by two to point to the address containing the PC value at the time of the CALL instruction.
  - 2) Placing the contents at the SP value into the PC. Execution begins at the next instruction after CALL.

#### 2.6 Data Organization and Memory Mapping

Data resides in memory and on-chip registers with the most significant bit in the left-most position. Figure 2–7 shows the significance of bits and bytes.

Figure 2–7. Bit and Byte Numbering for Instructions, Registers, and Words



A word comprises two bytes:

- the most significant byte is on an even boundary, and
- the *least significant* byte occupies the next higher (*odd*) byte address.

#### Note: Word Address Definition

A word address is a 16-bit pointer that maps into a 128K-byte address space. Note that 17 bits are needed to fully address a 128K-byte space. Because the 'C16 requires that words begin on an even-byte boundary, the least significant bit of the word's address must be a 0; only the upper 16 bits of an address are required to access the word. A *word address* contains these 16 bits.

All word data in memory must be aligned on an even address.

For **byte** operations, the byte operand values are zero-extended to word length, are operated on as words, and produce a word result. *Register destinations* receive the entire word (the MSbyte zero-extended), but *memory destinations* receive only the LSbyte of the result. Thus, a byte moved to a register via the MOVB instruction zeroes the MSbyte of the register with the moved byte in the LSbyte. The same byte moved to a memory address affects only the destination byte addressed. This is illustrated in Figure 2–8 on page 2-16.

Figure 2–9 on page 2-17 shows how bits, bytes, and words are organized in memory and in the register file. Shown in the figure are the least and most significant bits and bytes. The accompanying explanations below the figure complete the description.

Figure 2–10 on page 2-18 shows a *typical* memory configuration and how the first and second 64K bytes of memory are divided into blocks for 1) **byte and word** access in the lower 64K bytes of memory and 2) **word-only** access in the higher 64K bytes.

For purposes of this manual, these symbols have these meanings:

| Symbol | Meaning                                              | Example                                                                                                        |
|--------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| (x)    | Contents of register x or of memory at address x     | (Rn) = the contents of Rn                                                                                      |
| ((×))  | Contents of memory<br>designated by contents<br>of x | (disp + (Rn)) = the contents within the value found by adding the contents of Rn with the displacement amount. |

#### Figure 2–8. Differences in Memory and Register ByteDestinations









#### Figure 2–9. Data Organization Examples in Registers and Memory

Data restrictions depend upon their location in a register or in memory (as shown in Figure 2–9 above):

| Data Size              | Register                                                                                                   | Memory                                                                                                                                                                     |
|------------------------|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Single Bit             | Can be any bit in any register in the register file.                                                       | Can be any bit in any byte in the first 64K bytes of memory.                                                                                                               |
| Byte<br>(8 bits)       | The least significant byte of any register in the register file.                                           | Can be any byte in the first<br>64K bytes of memory. Any<br>adjacent byte is not affected.                                                                                 |
| Word<br>(16 bits)      | Can be any register in the register file.                                                                  | Can be any byte pair where<br>the most significant byte of<br>the word is at an even<br>address and the least signifi-<br>cant byte is at the next<br>higher byte address. |
| Long Word<br>(32 bits) | Uses a register pair in the register file with the most significant word in the IM (implied register, R1). | Not applicable.                                                                                                                                                            |





As shown in Figure 2–10, two 64K-byte areas concatenate to form 128K bytes of addressable memory. The generic view on the left shows that the lower-address half can be accessed as either byte or word, and the higher-address half is accessible as word-only by such instructions as FMOV and CALL. The right side of the figure is an *example* of possible code and data utilization. The actual size of the memory module is device specific. See your specific device data sheet to determine the size of the memory modules for your particular device. The lowest memory addresses contain the control registers, which are expanded in Figure 2–11 (next page).



Figure 2–11. Location and Names of Control Registers

Figure 2–11 lists the 16 control-register groups in the lowest 1K bytes of memory. Each register group is 16 bytes and contains the working registers for each module or for the system configuration. These registers are further described in Section 3.5 on page 3-7.



# **TMS370C16 System Configuration**

This chapter discusses system configuration requirements, I/O, interrupts, reset, and low-power modes of the TMS370C16 CPU. Features and options are described, including the registers that control the configuration. This chapter covers the following topics:

#### Topic

#### Page

| 3.1  | System Configuration Overview                         |
|------|-------------------------------------------------------|
| 3.2  | System Reset Operation 3-3                            |
| 3.3  | CLKOUT Pin Function Selection 3-6                     |
| 3.4  | Parallel Signature Analysis Operation (CRC Generator) |
| 3.5  | System Configuration Registers 3-7                    |
| 3.6  | General-Purpose Digital Functions                     |
| 3.7  | Interrupt and Exception Handling                      |
| 3.8  | External and Power Module Interrupts 3-25             |
| 3.9  | Multiple Interrupt Servicing                          |
| 3.10 | TMS370C16 Interrupt Configurability Options           |
| 3.11 | Low-Power and Idle Modes 3-40                         |

# 3.1 System Configuration Overview

The system module controls device operations such as clock source, stack location, reset, interrupts, and I/O. The actual number of external interrupts and I/O pins is device specific; consult the data sheet for a particular device. Certain device status information is also contained within the system module. The system module block diagram is shown in Figure 3–1.

Figure 3–1. System Block Diagram



 Notes:
 1. See the Clock Modules Reference Guide.
 2. See the EEPROM/EPROM Modules Reference Guide.

## 3.2 System Reset Operation

The system reset operation ensures an orderly start-up sequence for the TMS370C16 CPU-based device. Seven actions can cause a system reset to the device; six of these are internally generated, while the RESET-pin interrupt is controlled externally.

- RESET Pin. A negative edge can trigger a signal on this external pin.
- Watchdog (WD) Timer Overflow. A watchdog-generated reset occurs if the WD timer overflows or an improper value is written to either the WD key register or the WD control register. (See your Watchdog Timer and Real-Time Interrupt Reference Guide for details on these registers.)
- Software-Generated Reset. Writing a 0 to the RESET0 bit (SCR0.6) or a 1 to the RESET1 bit (SCR0.7) causes a reset (SCR0 is the system control register 0, as shown in Figure 3–3 on page 3-7.)
- Illegal Address Access. Attempting to access a nonmemory (not implemented) address causes a reset. (This action is device specific, relative to the memory configuration.)
- Oscillator Reset. Operation of the oscillator outside of the recommended operating range, as indicated by the OSCRST bit of the system reset status register (subsection 3.5.3, page 3-10), causes the clock module to issue a reset. See the *Clock Modules Reference Guide* for more information.
- □ V<sub>CC</sub> Out-of-Range. Operation with V<sub>CC</sub> outside of the recommended operating range may also act as a brownout indicator in addition to ensuring proper operation on power-up sequences.
- Illegal Access. Attempting to access a word by using an odd address causes a reset.

Once a reset source is activated, the external  $\overrightarrow{\text{RESET}}$  pin is driven active low for a minimum of eight SYSCLK cycles. This allows the 'C16 CPU-based device to reset any external devices connected to the  $\overrightarrow{\text{RESET}}$  pin. Normally, the reset logic holds the 'C16 device in a reset state for eight SYSCLK cycles; however, if a V<sub>CC</sub> out-of-range condition or oscillator failure occurs (or the  $\overrightarrow{\text{RESET}}$  external pin is held low), then the reset logic holds the device in a reset state for as long as these conditions exist. Figure 3–2 shows the reset state diagram for the 'C16 device in the normal run mode.



Figure 3–2. Reset State Diagram — Normal Run Mode

After a reset, the program determines the source of the reset by reading the contents of the system reset status register (SRSR, shown in Figure 3–3 on page 3-7). There is one status bit for each of the seven sources that can cause a reset.

Once a reset is activated, the following sequence of events occurs in the 'C16:

- The CPU registers and module control registers are initialized to their reset state. The ST interrupt mask bits are set to all 1s to prevent any interrupt request, including nonmaskable interrupts (NMIs).
- 2) The correct index value to the trap table base address is computed.
- 3) The service-routine address is read from address 8002h.
- 4) The prefetch pipeline is reloaded.

The reset sequence takes six cycles from the time the reset is released until the first opcode fetch begins. During a reset, RAM contents remain unchanged, and the module control register bits are initialized to their reset state.

To generate an external reset pulse on the  $\overrightarrow{\text{RESET}}$  pin, a low-level pulse duration of as little as a few nanoseconds is usually effective; however, pulses of one SYSCLK cycle are recommended to guarantee that the device acknowledges the reset. A typical reset circuit required for the 'C16 CPU-based device consists of a 10-kilohm pullup resistor from the  $\overrightarrow{\text{RESET}}$  pin to V<sub>CC</sub>. Only this single resistor is needed if a primary voltage regulator or brownout detection circuit is on your device. See the specific device data sheet to determine whether additional circuitry is required.

# 3.3 CLKOUT Pin Function Selection

You can select the CLKOUT pin to operate as one of four different functions:

- Digital I/O
- Watchdog clock (WDCLK) output
- External clock (ECLK) output
- System clock (SYSCLK) output

The function is determined by two clock source control bits, CLKSRC1 and CLKSRC0 (SCR1.7 and SCR1.6 respectively, shown in Figure 3–3 on page 3-7). Table 3–1 illustrates the CLKOUT pin function selection options.

Table 3–1. CLKOUT Pin Function Options

|             | CLKSRC1 | CLKSRC0 |
|-------------|---------|---------|
| Digital I/O | 0       | 0       |
| WDCLK       | 0       | 1       |
| ECLK        | 1       | 0       |
| SYSCLK      | 1       | 1       |

For more information, see subsection 3.5.2 on system control register 1 on page 3-9, the specific device data sheet, or the *Clock Modules Reference Guide*.

# 3.4 Parallel Signature Analysis Operation (CRC Generator)

The TMS370C16 device contains an internal 16-bit parallel signature analysis (PSA) circuit that provides a continuous cyclic redundancy check (CRC) function. Two associated registers, PSAR1 and PSAR2 (located at addresses 0001Eh and 0001Fh in the system configuration register), determine a unique 16-bit signature. (The system configuration register is further described in Section 3.5 and in Figure 3–3 on the next page.)

When any memory location (RAM, EEPROM, ROM, EPROM, or control register) is read, the contents of the PSA registers are updated (register bits are described in subsection 3.5.5 on page 3-13). You can create a predetermined signature by initializing the PSA registers to a known value and then reading all memory locations. It is suggested that you read both PSA registers as a single word (*avoid multiple reads such as reading each byte individually*).

# 3.5 System Configuration Registers

The TMS370C16 system configuration registers are shown in Figure 3–3 and are discussed in detail in the following sections. These registers can be accessed in either byte or word mode.





# 3.5.1 System Control Register 0 (SCR0)

The system control register 0 (SCR0) controls the software reset capability of TMS370C16 CPU-based devices.



#### Bits 7 & 6 RESET1/RESET0. Software Reset.

These bits, which control the software reset function of the device, must be written to at the same time. Writing a 1 to RESET1 *or* a 0 to RESET0 causes a global reset to occur as shown in the following table:

| RESET1 | RESET0 | <b>Resulting Action</b> |
|--------|--------|-------------------------|
| 0      | 0      | Global reset            |
| 0      | 1      |                         |
| 1      | 0      | Global reset            |
| 1      | 1      | Global reset            |

#### Bits 5 – 0 Reserved.

Writing to these bits has no effect, and reads are undefined.

# 3.5.2 System Control Register 1 (SCR1)

The system control register 1 (SCR1) controls the CLKOUT pin function and the analog power supply enable.



#### Bit 3 VCCAON. V<sub>CCA</sub> (Analog Power Supply) Enable.

This bit controls the ability of the primary voltage regulator or the brown-out detect circuit to turn the analog power supply ( $V_{CCA}$ ) on and off.

- 0 = Analog power supply is disabled.
- 1 = Analog power supply is enabled.

#### Bits 2–0 Reserved.

Writing to these bits has no effect, and reads are undefined.

## 3.5.3 System Reset Status Register (SRSR)

The system reset status register (SRSR) contains system-reset history status information. These bits should be cleared after being read.



#### Bit 1 WDRST. Watchdog Reset Status.

See your *Watchdog Timer and Real-Time Interrupt Module Reference Guide* to determine whether this bit applies to your device.

0 = No reset.

1 = Reset due to watchdog timer overflow.

#### Bit 0 EXTRST. External Reset Status.

0 = No reset.

1 = This bit is set when the external RESET pin is pulled low by any source, including an internal reset.

# 3.5.4 System Status Register (SSR)

The system status register (SSR) contains status information about the operational modes of the device.



R = Read, C = Clear only, -n = Value after reset (0, 1, x = indeterminate)

Bits 7 & 6 Reserved.

Writing to these bits has no effect, and reads are undefined.

#### Bit 5 HPO. Hardware Protect Override.

The hardware protect override function allows protected EEPROM bits to be written to and enables EPROM programming. To set this bit, external pin INT1 must be at 12 V on the rising edge of RESET. If INT1 is less than 12 V, the bit is a 0. You can disable this function by writing a 0 to it.

- 0 = Normal mode.
- 1 = HPO mode.

#### Bits 4 Reserved.

Writing to this bit has no effect, and reads are undefined.

# Bit 3VCCAOR. V<sub>CCA</sub> (Analog Power Supply) Out of Regulation.This bit shows the status of the internal V<sub>CCA</sub> signal.

 $0 = V_{CCA}$  is within regulated range.

 $1 = V_{CCA}$  is out of regulated range.

#### Bits 2–0 Reserved.

Writing to these bits has no effect, and reads are undefined.

# 3.5.5 Parallel Signature Analysis Registers (PSARn)

The parallel signature analysis register 1 (PSAR1) contains the MSbyte of the PSA, and the parallel signature analysis register 2 (PSAR2) contains the LSbyte of the PSA.



Bits 7 – 0 PSA15–PSA8. Parallel Signature Analysis Data Bits 15 – 8. The value read from this register is the MSbyte of the most recent PSA routine.



**Bits 7 – 0 PSA7–PSA0.** Parallel Signature Analysis Data Bits 7 – 0. The value read from this register is the LSbyte of the most recent PSA routine.

# 3.6 General-Purpose Digital Pin Functions

Device pins can be configured for general-purpose digital pin functions *except* for those pins:

- That are device operation pins (V<sub>CC</sub>, V<sub>SS</sub>, RESET, INT1, etc.).
- That are *required* for module-specific operation (for the SPI, ADC, gage drivers, etc.)

The total number of digital pins available is device specific. Refer to the specific device data sheet to determine the exact number of digital pins available, pin locations, naming conventions, and control registers. This section describes the different types of digital pin functions available and how they are controlled.

The digital I/O control and status register (Figure 3–4) allows a maximum of 32 output/control functions, 32 input/status functions, and 32 bidirectional I/O pin functions. The output pin functions are also referred to as *control* pins — they can be used to turn particular internal modules on or off and are not actually tied to an external pin. The input pin functions are also referred to as *status* pins because they can be used to determine the status of internal signals on the device as well as to serve as general-purpose input pins. For example, you could use these configurations to tie an input/status function to the low-side driver over-current detection circuitry, or to tie an output/control function internally to the V<sub>CCA</sub> analog voltage output to control the primary voltage regulator during on and off V<sub>CCA</sub>.

The control registers for digital I/O (DIO) pins are located at addresses 0060h to 006Fh and are shown in Figure 3-4.

| Address       | Ports             | Functions                                                                                                                |
|---------------|-------------------|--------------------------------------------------------------------------------------------------------------------------|
| 0060h - 0063h | Output 1, 2, 3, 4 | Output/control only. Pins for output/control ports 1, 2, 3, and 4                                                        |
| 0064h – 0067h | Input 1, 2, 3, 4  | Input/status only. Pins for Input/status ports 1, 2, 3, and 4                                                            |
| 0068h 006Fh   | I/O A, B, C, D    | Pins for I/O ports A, B, C, and D, with each<br>port using one byte for I/O configuration and<br>one byte for pin value. |

The following sections explain the operation of the DIO control registers. The number of DIO control registers available depends on the 'C16 device. Usually, all digital pins available are configured as bidirectional I/O pins, and not output or input only. This configuration selection is determined during the manufacture cycle and cannot be changed by software. See the specific device data sheet for more information.

| •               | -           |        |        |        | •      |        |        |        |        |                                     |
|-----------------|-------------|--------|--------|--------|--------|--------|--------|--------|--------|-------------------------------------|
| Addr            | Reg<br>Mnem | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      | Reg<br>Name                         |
| 0 <b>006</b> 0h | OCR1        | 10UT7  | 10UT6  | 10UT5  | 10UT4  | 10UT3  | 10UT2  | 10UT1  | 10UT0  | Output/<br>Control<br>Register 1    |
| 00061h          | OCR2        | 20UT7  | 2OUT6  | 20UT5  | 20UT4  | 20UT3  | 20UT2  | 20UT1  | 20UT0  | Output/<br>Control<br>Register 2    |
| 00062h          | OCR3        | 30UT7  | 3OUT6  | 30UT5  | 3OUT4  | 30UT3  | 30UT2  | 30UT1  | 3OUT0  | Output/<br>Control<br>Register 3    |
| 00063h          | OCR4        | 40UT7  | 4OUT6  | 40UT5  | 40UT4  | 4OUT3  | 40UT2  | 40UT1  | 4OUT0  | Output/<br>Control<br>Register 4    |
| 00064h          | ISR1        | 11NS7  | 1INS6  | 1INS5  | 1INS4  | 11NS3  | 1INS2  | 1INS1  | 1INS0  | Input/<br>Status<br>Register 1      |
| 00065h          | ISR2        | 2INS7  | 2INS6  | 21NS5  | 2INS4  | 2INS3  | 2INS2  | 2INS1  | 2INS0  | Input/<br>Status<br>Register 2      |
| 00066h          | ISR3        | 3INS7  | 3INS6  | 3INS5  | 3INS4  | 3INS3  | 3INS2  | 3INS1  | 3INS0  | Input/<br>Status<br>Register 3      |
| 00067h          | ISR4        | 4INS7  | 4INS6  | 4INS5  | 4INS4  | 4INS3  | 4INS2  | 4INS1  | 4INS0  | Input/<br>Status<br>Register 4      |
| 00 <b>068</b> h | ADIR        | ADIR7  | ADIR6  | ADIR5  | ADIR4  | ADIR3  | ADIR2  | ADIR1  | ADIR0  | I/O Port A<br>Direction<br>Register |
| 00069h          | ADATA       | ADATA7 | ADATA6 | ADATA5 | ADATA4 | ADATA3 | ADATA2 | ADATA1 | ADATA0 | I/O Port A<br>Data<br>Register      |
| 0006Ah          | BDIR        | BDIR7  | BDIR6  | BDIR5  | BDIR4  | BDIR3  | BDIR2  | BDIR1  | BDIR0  | I/O Port B<br>Direction<br>Register |
| 0006Bh          | BDATA       | BDATA7 | BDATA6 | BDATA5 | BDATA4 | BDATA3 | BDATA2 | BDATA1 | BDATA0 | I/O Port B<br>Data<br>Register      |
| 0006Ch          | CDIR        | CDIR7  | CDIR6  | CDIR5  | CDIR4  | CDIR3  | CDIR2  | CDIR1  | CDIR0  | I/O Port C<br>Direction<br>Register |
| 00 <b>06Dh</b>  | CDATA       | CDATA7 | CDATA6 | CDATA5 | CDATA4 | CDATA3 | CDATA2 | CDATA1 | CDATA0 | I/O Port C<br>Data<br>Register      |
| 00 <b>06</b> Eh | DDIR        | DDIR7  | DDIR6  | DDIR5  | DDIR4  | DDIR3  | DDIR2  | DDIR1  | DDIR0  | I/O Port D<br>Direction<br>Register |
| 0006Fh          | DDATA       | DDATA7 | DDATA6 | DDATA5 | DDATA4 | DDATA3 | DDATA2 | DDATA1 | DDATA0 | I/O Port D<br>Data<br>Register      |
|                 |             |        |        |        |        |        |        |        |        |                                     |

Figure 3–4. Digital I/O Control and Status Registers

Note: See the specific device data sheet for the actual digital pin implementation.

# 3.6.1 Digital Output/Control Registers (OCRn)

Writing to bit(s) in the digital output/control registers (OCR1, OCR2, OCR3, and OCR4) outputs values to the bit's corresponding function(s) — such as communication to an internal module or an external pin. OCR1 is illustrated below. OCR2. OCR3, and OCR4 operate identically to OCR1 but are not shown.



- Bits 7–0 10UT7 10UT0. Digital outputs to corresponding functions. The values written to any of selected bit(s) 10UT7 to 10UT0 control the state output of the corresponding function(s).
  - 0 =Output a 0 (V<sub>OL</sub>) value to the selected function.
  - 1 =Output a 1 (V<sub>OH</sub>) value to the selected function.

#### 3.6.2 Digital Input/Status Registers (ISRn)

Reading a bit in one of the four digital input/status registers (ISR1, ISR2, ISR3, and ISR4) reads the bit value at the corresponding input function. Functions could be values from such points as a module flag, external pin, etc. ISR1 is illustrated below. ISR2, ISR3, and ISR4 operate identically to ISR1 but are not shown.



# Bits 7–0 1INS7–1INS0. Digital input/status at corresponding functions. The values read at any selected bit(s) 1INS7–1INS0 show values at their corresponding functions:

- $0 = \text{Read V}_{IL}$  on the corresponding function.
- $1 = \text{Read V}_{\text{IH}}$  on the corresponding function.

# 3.6.3 Digital Port Direction and Port Data Registers (*x*DIR and xDATA)

The TMS370C16 CPU has four digital ports — A, B, C, and D. Each port has a pair of registers that work together. The direction register for the port designates each bit in the corresponding data register as either an input or output.

- ☐ The **port direction register** (ADIR, BDIR, CDIR, and DDIR for ports A to D respectively) bit values designate a corresponding pin in the data register as an input (clear bit to 0) or an output (set bit to 1).
- The port data register (ADATA, BDATA, CDATA, and DDATA for ports A to D respectively) bits can be read from or written to, depending upon their status as set in the port direction register.

For example, to read bit A7, clear bit ADIR7 to 0 (to become an input); then read bit ADATA7. To write to A7, set ADIR7 to 1 (becomes an output) and write a value to ADATA7. This applies to the other ports also (BDIR/BDATA, CDIR/CDATA, and DDIR/DDATA).

Registers ADIR and ADATA are shown on the next page. The combinations of BDIR/BDATA, CDIR/CDATA, and DDIR/DDATA operate identically to ADIR/ADATA but are not shown.



#### Bits 7–0 ADIR7–ADIR0. Control direction of pins A7–A0.

The value written to any one of these bits controls the direction of this bidirectional pin.

0 = The pin is an input.

1 = The pin is an output.



#### **Bits 7–0** ADATA7 – ADATA0. Data Value for pins A7 – A0.

If the pin has been selected as an **input** (xDIRn = 0), then the value read from the corresponding bit is the value seen on the pin.

- $0 = Value of selected bit is a 0 (V_{IL}).$
- $1 = Value of selected bit is a 1 (V_{IH}).$

If the pin has been selected as an **output**, then the value written to the bit is the value output on the corresponding pin.

- 0 = Value of selected bit is a 0 (V<sub>OL</sub>).
- 1 = Value of selected bit is a 1 (V<sub>OH</sub>).

# 3.7 Interrupt and Exception Handling

TMS370C16 recognizes four interrupt/exception sources, summarized below. The actual number of interrupt sources, as well as their associated interrupt vector(s), is device specific. This reference guide provides general information for the entire product range of 'C16-based devices. Refer to the specific device data sheet and module reference guide for more information.

# 3.7.1 Interrupt/Exception Sources

- □ Resets (hardware initiated) are unarbitrated by the CPU and take immediate priority over any other executing functions. All interrupts and the NMI (discussed below) are disabled until being enabled by the reset's service routine (at 08002h in the vector table). Resets are described in further detail in Section 3.2 on page 3-3.
- Nonmaskable interrupts (NMIs) (discussed in subsection 3.7.4 on page 3-23) are generated at an external interrupt pin. An NMI takes priority over peripheral interrupts and software exceptions. It can be locked out by an already executing NMI or a reset. Its service routine start address is located in the vector table at 08006h. See the specific device data sheet for more information on devices having more than one NMI.
- Peripheral interrupts (discussed in subsection 3.7.5 on page 3-24) are initiated by any of the peripheral modules attached to the CPU. They can be masked off by the L2–L0 interrupt level bits of the ST. Figure 3–5 on page 3-20 illustrates the vector configuration.
- Software exceptions (discussed in subsection 3.7.6 on page 3-24) are not arbitrated by the CPU. When these are executing, the ST L2–L0 interrupt level bits are set to all ones (111<sub>2</sub>) to mask out peripheral interrupts.
  - A TRAP instruction's vector location corresponds to the trap number in its opcode (0–255). Thus, vector locations range from 08000h for trap 0 up to address 081FEh for trap 255.
  - The other software exceptions (unimplemented opcodes and the ILLEGAL instruction) trap to the address at 08000h.

Whenever an enabled interrupt/exception source requests service, the CPU transfers program flow through a vector that points to the starting address (PC value) of an interrupt/exception subroutine. This context switching transfer is implemented as shown in Figure 3–5:



Figure 3–5. Vector Table Organization in Memory

#### 3.7.2 Vector Table

The vector table (shown in Figure 3–5) contains up to 256 entries, each of which is the starting PC address of an interrupt service routine. The table begins at address 08000h.

When an interrupt is acknowledged, the CPU acquires a vector offset value, which is added to 08000h to locate the corresponding service-routine start address. Each interrupt source is responsible for supplying this offset either through hardware (NMIs and peripheral interrupts) or software (resets, traps, and illegal opcodes).

The single vector table contains the service-routine start addresses for all exceptions and interrupts. Thus, resets, NMIs, and peripheral interrupt vectors are shared with software exception vectors.

The vector table grows upwards (to higher addresses). The table is only as large as required (but no larger than 512 bytes). The final size of the table is determined by the peripheral module requirements of the device and the application's software use of traps (see your specific device data sheet for size).

The 16-bit address of the first executable instruction in the interrupt handler is a word address that is loaded into the PC and transformed into a 17-bit physical memory address by overlaying bits b15-b0 onto address lines A16-A1 and forcing A0 to 0.

## 3.7.3 Reset and Interrupt Operation

Figure 3-6 describes the step-by-step sequencing of resets and interrupts.





\*Peripheral interrupts must be a level *higher* than the level in the ST interrupt-level bits (L2 - L0) in order to execute. Thus, a level of  $111_2$  locks out any peripheral interrupt.

# 3.7.4 Nonmaskable Interrupt (NMI) Processing

The NMI is nonmaskable in that it cannot be masked out by the L2 - L0 interrupt-level bits of the status register. However, **NMIs** *are* **disabled** and will be ignored if:

- An NMI is already executing, or
- A reset occurs.

Unless pre-empted by a reset, the NMI will occur on the next instruction boundary if it is internally enabled and a valid external NMI signal is received.

During these two situations, all the ST interrupt-level bits are set to 1, locking out recognition of a pending NMI. Any pending NMI cannot be activated unless one of the following occurs to **(re-)enable NMIs**:

- Execution of an RTI instruction,
- Execution of a TRAP instruction, or
- The clearing to 0 of one or more of the ST register interrupt-level bits (e.g., by an STRI instruction or any other instruction that changes these bits in the ST register—R14).

Also, because ST register interrupt level bits (L2, L1, and L0) are all 1s after an NMI occurs, all interrupt requests are ignored by the CPU until these bits are cleared to zero (changed from their all-1s status).

To summarize, the occurrence of an NMI locks out a pending NMI until the present one is serviced. The RTI instruction is a simple method of re-enabling NMIs, and a pending NMI will be taken following the re-enabling by one of the specified methods.

#### Avoid Interrupting a Reset With an NMI

It is *imperative* that an NMI not interrupt the CPU during a reset *until* the stack pointer is initialized to a valid value. A valid NMI won't occur as long as an RTI instruction is not executed or none of the ST register interrupt-level bits are cleared.

NMI processing takes several steps:

- 1) ST  $\rightarrow$  (SP).
- 2) SP + 2 → SP.
- 3) PC  $\rightarrow$  (SP).
- 4) SP + 2 → SP.
- 5) Look up the vector offset for the NMI trap address (08006h or as specified in the specific device data sheet).
- 6) Execute NMI interrupt handler at that address.

NMI processing begins with the CPU pushing first its ST register value and then the current PC value onto the stack. The PC points to the word address of the next executable instruction plus two words (four bytes). This is equal to:

## 17-bit word address bus value +4 2 = PC value

The PC-value 4-byte offset is due to pipelining prefetch, which leaves the PC pointing four bytes beyond the next opcode, at an instruction boundary.

## 3.7.5 Peripheral Module Interrupt Processing

Peripheral interrupt requests are maskable by the CPU via the ST register's interrupt-level bits (L2 - L0). During any exception/interrupt processing, these bits are set to 1s, masking off all interrupt requests (except an NMI that was previously enabled; this is explained in subsection 3.7.4).

A request whose level is *greater than* the interrupt-level mask value in the ST register is acknowledged at the next instruction boundary. A request of the *same or lower level* will not be acknowledged.

Execution of an unmasked peripheral interrupt is shown in Figure 3–6, starting on the upper right (page 3-22).

## 3.7.6 Software Exception (TRAPs, etc.) Processing

A software exception is not arbitrated by the CPU. It occurs when one of the following is executed:

- An illegal opcode
- A TRAP instruction
- An ILLEGAL instruction

During any software exception, the ST register's interrupt-level bits (L2 - L0) are set to 1s, masking off all interrupt requests (except an NMI if NMIs are enabled; this is explained in subsection 3.7.4).

Software exceptions generate their own vector offset value:

- TRAPs use the 8-bit vector offset value (to be added to the vector base address) assembled in the LSbyte of the instruction's opcode.
- ☐ The other software exceptions use a vector offset value of 00<sub>16</sub> the same as a TRAP #0 instruction.

See descriptions for the TRAP and ILLEGAL instructions in Chapter 5 for further vector information.

# 3.8 External and Power Module Interrupts

There are three types of external interrupts:

- 1) External interrupt pins (subsection 3.8.1)
- 2) Power module fault condition (subsection 3.8.2 on page 3-35)
- 3) Phantom interrupt controlled exit from an improper interrupt acknowledge sequence (subsection 3.8.3 on page 3-37)

## 3.8.1 External Interrupt Pins

The 16-byte interrupt frame (shown in Figure 3–7 and Figure 3–8 on the following pages) controls *up* to eight external interrupt pins and *up* to 49 power module interrupts. Pin interrupts can be any of three types: A, B, and C (these are described in Table 3–2 on page 3-26). At least one type A interrupt in INT1 *is required* in any configuration. The actual makeup of the interrupt frame is device specific; *see the device-specific data sheet to determine the interrupt types and control register addresses.* 

Rules concerning the 16-byte interrupt frame:

- The first two bytes (addresses 0070h and 0071h) are a type A interrupt (required for *all* interrupt frames).
- The next (higher addressed) 14 bytes can be *any* combination of:
  - Two-byte sets of pin interrupt control/status bits, and/or
  - Two-byte sets that contain power-module control/status bits that start at the highest address in the interrupt frame (0007Fh) and are placed contiguously from that address to lower addresses in the frame. Figure 3–7 and Figure 3–8 contain several *examples*.
- The additional Interrupt control/flag bytes are contiguous and follow the type A interrupt bytes that start in addresses 00070h and 00071h, growing to the higher addresses. The first interrupt bytes are INT1 and INT1 FLG bytes, the second are INT2 and INT2 FLG, etc.
- Power module (PM) control and flag bytes start with PM1 at the highest two addresses in the frame (0007Eh and 0007Fh). A second power module (PM2) would be immediately before those for PM1, located at 0007Ch and 0007Dh. PM3 would precede PM2, etc.

Thus, the interrupt frame could contain merely the required single pair of type A interrupt bytes only, as shown in example (a) of Figure 3–7, or a combination of pin interrupts and power module interrupts as shown in examples (b) and (c) in the figure. Example (d) in Figure 3–7 shows pin interrupts in all locations. The mix and position of interrupt pin types and number of power module pins depends upon device-specific design considerations.

Figure 3–8 is also a *typical example* of an interrupt frame with all three pin types and their bit names. It also contains two power module control and flag bytes with bit names.

Table 3–2 describes the different external interrupt pin types. All types can be configured for high or low priority, and all interrupt pins are configured to digital inputs on reset. Descriptions of the different types of pins are given in the subsections that follow.

Table 3–2. External Interrupt Types

| Pin<br>Type | Configurable<br>as NMI? | Minimum<br>Required | Digital<br>I/O | Freeze<br>Bits <sup>1</sup> | Alternate<br>Functions |
|-------------|-------------------------|---------------------|----------------|-----------------------------|------------------------|
| Туре А      | Yes                     | 1                   | Input only     | Yes                         | V <sub>PP</sub> /HPO   |
| Type B      | Yes                     | 0                   | 1/0            | No                          |                        |
| Туре С      | No                      | 0                   | I/O            | No                          |                        |

<sup>1</sup> Freeze bits are further explained in Section 3.10 on page 3-39.

Table 3–3. External Interrupt Pin Functions

|                         | NMI Bit <sup>†</sup> | Data Out | Data Dir <sup>‡</sup> | Polarity§ | Priority | Int Enable |
|-------------------------|----------------------|----------|-----------------------|-----------|----------|------------|
| nonmaskable Interrupt   | 1                    | N/A      | N/A                   | 0, 1      | N/A      | N/A        |
| Interrupt High Priority | 0                    | N/A      | N/A                   | 0, 1      | 0        | 1          |
| Interrupt Low Priority  | 0                    | N/A      | N/A                   | 0, 1      | 1        | 1          |
| Digital Output '0'      | 0                    | 0        | 1                     | N/A       | N/A      | 0          |
| Digital Output '1'      | 0                    | 1        | 1                     | N/A       | N/A      | 0          |
| Digital Input           | 0                    | N/A      | 0                     | N/A       | N/A      | 0          |

<sup>†</sup> Type C interrupts do not have an NMI bit. Assume a value of 0.

<sup>‡</sup> Type A interrupts do not have a data direction bit. Assume a value of 0.

§ Polarity values of 1 and 0 indicate rising and falling edges, respectively.

N/A = Not applicable

#### Note: INTx Used to Represent INT1-INT6

In the discussion of interrupt types A, B, and C (subsections 3.8.1.1 through 3.8.1.6 on pages 3-29 to 3-34), the term INTx represents any of the possible interrupt locations (INT1–INT6) as shown in Figure 3–7 and Figure 3–8. Any of of these interrupt locations can contain any of the three pin-interrupt types (A, B, or C) with one restriction: INT1 in address 00070h must *always* contain a type A.

| 70h | INT1     | Type A Pin Interrupt                          |
|-----|----------|-----------------------------------------------|
| 71h | INT1 FLG | Type A Pin Interrupt Flags                    |
| 72h |          | Reserved //////                               |
| 73h |          | Reserved                                      |
| 74h |          | Fieserved                                     |
| 75h |          | Reserved /////                                |
| 76h |          | Reserved //////////////////////////////////// |
| 77h |          | Résérved //////////////////////////////////// |
| 78h |          | Résérved                                      |
| 79h |          | Reserved                                      |
| 7Ah |          | Reserved /////                                |
| 7Bh |          | Reserved                                      |
| 7Ch |          | Reserved                                      |
| 7Dh |          | Reserved //////////////////////////////////// |
| 7Eh |          | /////Reserved///////                          |
| 7Fh |          | Réserved                                      |

Figure 3–7. Interrupt-Frame Typical Configurations

(a) Single Interrupt (Minimum Configuration)

| 70h | INT1      | Type A Pin Interrupt       |
|-----|-----------|----------------------------|
| 71h | INT1 FLG  | Type A Pin Interrupt Flags |
| 72h | INT2      | Type A Pin Interrupt       |
| 73h | INT2 FLG  | Type A Pin Interrupt Flags |
| 74h |           | /////Reserved///////       |
| 75h |           | //////Reserved///////      |
| 76h |           |                            |
| 77h |           | Reserved                   |
| 78h | PM4       | Power Module 4 Enable      |
| 79h | PM4 FLG   | Power Module 4 Flags       |
| 7Ah | PM3       | Power Module 3 Enable      |
| 7Bh | PM3 FLAGS | Power Module 3 Flags       |
| 7Ch | PM2       | Power Module 2 Enable      |
| 7Dh | PM2 FLAGS | Power Module 2 Flags       |
| 7Eh | PM1       | Power Module 1 Enable      |
| 7Fh | PM1 FLAGS | Power Module 1 Flags       |
|     |           |                            |

(c) Interrupts and Power Modules

| 70h | INT1      | Type A Pin Interrupt                          |
|-----|-----------|-----------------------------------------------|
| 71h | INT1 FLG  | Type A Pin Interrupt Flags                    |
| 72h | INT2      | Type C Pin Interrupt                          |
| 73h | INT2 FLG  | Type C Pin Interrupt Flags                    |
| 74h | INT3      | Type C Pin Interrupt                          |
| 75h | INT3 FLG  | Type C Pin Interrupt Flags                    |
| 76h |           | Reserved /////                                |
| 77h |           | Reserved //////////////////////////////////// |
| 78h |           | Reserved                                      |
| 79h |           | Reserved ////                                 |
| 7Ah |           | Reserved                                      |
| 7Bh |           | Fleserved                                     |
| 7Ch | PM2       | Power Module 2 Enable                         |
| 7Dh | PM2 FLAGS | Power Module 2 Flags                          |
| 7Eh | PM1       | Power Module 1 Enable                         |
| 7Fh | PM1 FLAGS | Power Module 1 Flags                          |
|     |           |                                               |

(b) Interrupts and Power Modules

| 70h        | INT1             | Type A Pin Interrupt       |
|------------|------------------|----------------------------|
| 71h        | INT1 FLG         | Type A Pin Interrupt Flags |
| 72h        | INT2             | Type C Pin Interrupt       |
| 73h        | INT2 FLG         | Type C Pin Interrupt Flags |
| 74h        | INT3             | Type A Pin Interrupt       |
| 75h        | INT3 FLG         | Type A Pin Interrupt Flags |
| 76h        | INT4             | Type B Pin Interrupt       |
| 77h        | INT4 FLG         | Type B Pin Interrupt Flags |
| 78h        | INT5             | Type C Pin Interrupt       |
| 79h        | INT5 FLG         | Type C Pin Interrupt Flags |
| 7Ah        | INT6             | Type B Pin Interrupt       |
| 7Bh        | INT6 FLG         | Type B Pin Interrupt Flags |
| 7Ch        | INT7             | Type C Pin Interrupt       |
| 7Dh        | INT7 FLG         | Type C Pin Interrupt Flags |
|            |                  |                            |
| 7Eh        | INT8             | Type C Pin Interrupt       |
| 7Eh<br>7Fh | INT8<br>INT8 FLG | Type C Pin Interrupt Flags |

(d) All Interrupts, Mix of All Three Types

| Addr   | Reg<br>Mnem   | 7                 | 6                 | 5                 | 4                   | 3                   | 2                | 1                | 0                | Register<br>Shown           |
|--------|---------------|-------------------|-------------------|-------------------|---------------------|---------------------|------------------|------------------|------------------|-----------------------------|
| 00070h | INT1          | Reserved          | INT1 PIN<br>DATA  | INT1<br>NMI       | Rese                | prved               | INT1<br>POLARITY | INT1<br>PRIORITY | INT1<br>ENABLE   | Type A<br>Interrupt         |
| 00071h | INT1 FLG      | INT1<br>FLAG      |                   |                   |                     | Reserve             | <b>1</b>         |                  |                  | Type A<br>Interrupt<br>Flag |
| 00072h | INT2          | Reserved          | INT2 PIN<br>DATA  | INT2<br>NMI       | INT2<br>DATA<br>DIR | INT2<br>DATA<br>OUT | INT2<br>POLARITY | INT2<br>PRIORITY | INT2<br>ENABLE   | Type B<br>Interrupt         |
| 00073h | INT2 FLG      | INT2<br>FLAG      |                   |                   |                     | Reserve             | <b>s</b>         |                  |                  | Type B<br>Interrupt<br>Flag |
| 00074h | INT3          | Reserved          | INT3 PIN<br>DATA  | Reserved          | INT3<br>DATA<br>DIR | INT3<br>DATA<br>OUT | INT3<br>POLARITY | INT3<br>PRIORITY | INT3<br>ENABLE   | Type C<br>Interrupt         |
| 00075h | INT3 FLG      | INT3<br>FLAG      |                   |                   |                     | Reserve             | d                |                  |                  | Type C<br>Interrupt<br>Flag |
| 00076h |               |                   |                   |                   | Re                  | served              |                  |                  |                  |                             |
| 00077h |               |                   |                   |                   | Rei                 | served              |                  |                  |                  |                             |
| 00078h |               |                   |                   |                   | Re                  | served              |                  |                  |                  |                             |
| 00079h |               |                   |                   |                   | Re                  | served              |                  |                  |                  |                             |
| 0007Ah |               |                   |                   |                   | Pier                | served              |                  |                  |                  |                             |
| 0007Bh |               |                   |                   |                   | Re                  | served              |                  |                  |                  |                             |
| 0007Ch | PM2<br>ENABLE | PM INT<br>ENA 2   | PM STS<br>ENAB 13 | PM STS<br>ENAB 12 | PM STS<br>ENAB 11   | PM STS<br>ENAB 10   | PM STS<br>ENAB 9 | PM STS<br>ENAB 8 | PM STS<br>ENAB 7 | Power<br>Module 2<br>Enable |
| 0007Dh | PM2<br>FLAGS  | PM2 INT<br>FLAG 2 | PM INT<br>FLAG 13 | PM INT<br>FLAG 12 | PM INT<br>FLAG 11   | PM INT<br>FLAG 10   | PM INT<br>FLAG 9 | PM INT<br>FLAG 8 | PM INT<br>FLAG 7 | Power<br>Module 2<br>Flags  |
| 0007Eh | PM1<br>ENABLE | PM INT<br>ENA 1   | PM STS<br>ENAB 6  | PM STS<br>ENAB 5  | PM STS<br>ENAB 4    | PM STS<br>ENAB 3    | PM STS<br>ENAB 2 | PM STS<br>ENAB 1 | PM STS<br>ENAB 0 | Power<br>Module 1<br>Enable |
| 0007Fh | PM1<br>FLAGS  | PM INT<br>FLAG 1  | PM INT<br>FLAG 6  | PM INT<br>FLAG 5  | PM INT<br>FLAG 4    | PM INT<br>FLAG 3    | PM INT<br>FLAG 2 | PM INT<br>FLAG 1 | PM INT<br>FLAG 0 | Power<br>Module 1<br>Flags  |

# Figure 3–8. Typical Interrupt Frame

#### Type A Interrupt Pins 3.8.1.1

Type A interrupt pins can be used as nonmaskable interrupts, normal interrupts, or digital input pins. At least one type A interrupt pin is required on each device and must be located in address 00070h (the first byte — INT1 — in the interrupt frame). A corresponding Type A flag bit is contained in the second byte (described in subsection 3.8.1.2). Additional type A interrupts can be implemented on a device's interrupt frame, their location specified by device design (see applicable device data sheet). The example below shows the type A interrupt at INT1. Bits take the name of the interrupt level (INT2, INT3, etc.).



#### Type A Interrupt (shown in INT1 location)

#### Bit 7 Reserved.

Writing to this bit has no effect, and a read is undefined.

Bit 6 **INT1 PIN DATA.** Interrupt Pin Data.

> This bit reflects the current level on the interrupt pin, regardless of how the interrupt pin is configured.

- 0 = The pin is a low input.
- 1 = The pin is a high input.

Bit 5 **INT1 NMI.** Nonmaskable Interrupt Enable. This bit determines whether or not this pin can generate a nonmaskable interrupt. A freeze bit can be configured to a 1 or 0 on ROM devices at the time of device fabrication (see Section 3.10 on page 3-39).

> 0 = The pin is a regular interrupt or a digital input.

1 = The pin is a nonmaskable interrupt.

#### Bits 4 & 3 **Reserved.**

Writing to these bits has no effect, and reads are undefined.

#### Bit 2 **INT1 POLARITY.** Interrupt Polarity.

This bit determines whether interrupts are generated on the rising or falling edge. A freeze bit can be configured to a 1 or 0 on ROM devices at the time of device fabrication (see Section 3.10 on page 3-39).

- 0 = The interrupt is generated on a falling edge (high-to-low transition).
- 1 = The interrupt is generated on a rising edge (low-to-high transition).

- Bit 1 **INT1 PRIORITY.** Interrupt Priority. This bit determines which level interrupt is requested. The bit is ignored if the NMI bit is set.
  - 0 = High-level interrupt. See the specific device data sheet.
  - 1 = Low-level interrupt. See the specific device data sheet.

Bit 0 INT1 ENABLE. Interrupt Enable. This bit enables or disables the maskable interrupt. The bit is ignored if the NMI bit is set.

- 0 = Disable interrupt (use pin as a digital input).
- 1 = Enable interrupt.

## 3.8.1.2 Type A External Interrupt Flag Bit

The Type A external interrupt flag bit is the MSB of the byte that accompanies and follows the Type A interrupt pin byte (described in subsection 3.8.1.1). The example below shows INT1 FLAG bit.



R = Read, W = Write, C = Clear only, -n = Value after reset (0, 1, x = indeterminate)

#### Bit 7 **INT1 FLAG.** Interrupt Flag.

This bit indicates that the selected transition has been detected. It is set, whether the interrupt is enabled or not. The bit can be used for software polling to see whether the selected edge has occurred. It can be cleared by software or a system reset. If used as an interrupt, the bit does not have to be cleared. The interrupt occurs once for each selected edge on the interrupt pin, even though the bit is already set. However, clearing the bit will clear a pending interrupt request from this interrupt pin. The interrupt flag bit is located in a separate register from the interrupt control bits to prevent inadvertent clearing of the flag bit when the control bits are changed with read/modify, write-type instructions such as SBIT0 and SBIT1 (set bit to 0, set bit to 1 instructions).

- 0 = No transition is detected.
- 1 = A transition is detected.

#### Bits 6-0 Reserved.

Writing to these bits has no effect, and reads are undefined.

## 3.8.1.3 Type B Interrupt Pins

Type B interrupt pins can be used as nonmaskable interrupts, normal interrupts, digital input, or digital output pins. Any combination of Type B (as well as Types A or C) interrupt-pin bytes can follow the two Type A interrupt bytes in addresses 00070h and 00071h, as specified by device design (see applicable device data sheet). This Type B interrupt pin byte is followed by a second byte containing the Type B interrupt flag bit (shown in subsection 3.8.1.4).

#### Type B Interrupt Pin Byte Bit # 7 6 5 4 3 2 1 0 INTx INTx INTx INTx INTx 0007xh Reserved INT<sub>X</sub> PIN INT<sub>X</sub> NMI DATA DIR DATA OUT POLARITY PRIORITY ENABLE R-0 RW-0 RW-0 RW-0 RW-0 RW-0 RW-0 R = Read, W = Write, C = Clear only, -n = Value after reset (0, 1, x = indeterminate) Bit 7 **Reserved.** Writing to this bit has no effect, and a read is undefined. Bit 6 **INTx PIN.** Interrupt x Pin Data. This bit reflects the current level on the interrupt pin, regardless of how the interrupt pin is configured. 0 = The pin is a low input. 1 = The pin is a high input. Bit 5 **INTX NMI.** Nonmaskable Interrupt x Enable. This bit determines whether or not this pin can generate a nonmaskable interrupt. 0 = The pin is a regular interrupt or a digital I/O. 1 = The pin is a nonmaskable interrupt. Bit 4 **INTX DATA DIR.** Interrupt x Pin Data Direction.

When this interrupt pin is not enabled as an interrupt, the bit determines whether the pin is a digital input or a digital output.

- 0 = The pin is an input.
- 1 = The pin is an output.

# Bit 3 INTx DATA OUT. Interrupt x Pin Output Data. When used as a digital output pin, this read/write bit determines whether or not this pin is a 1 or 0.

- 0 = The pin is a zero if used as a digital output.
- 1 = The pin is a one if used as a digital output.

- Bit 2 INTx POLARITY. Interrupt x Polarity. This bit determines whether interrupts are generated on the rising or falling edge.
  - 0 = The interrupt is generated on a falling edge (high-to-low transition).
  - 1 = The interrupt is generated on a rising edge (low-to-high transition).

#### Bit 1 INTx PRIORITY. Interrupt x Priority.

This bit determines which level interrupt is requested. The bit is ignored if the NMI bit is set.

- 0 = High-level interrupt. See the specific device data sheet.
- 1 = Low-level interrupt. See the specific device data sheet.

#### Bit 0 INTx ENABLE. Interrupt x Enable.

This bit enables or disables the maskable interrupt. This bit is ignored if the NMI bit is set.

- 0 = Disable interrupt (Use pin as a digital input or output).
- 1 = Enable interrupt.

#### 3.8.1.4 Type B External Interrupt Flag Bit

This bit is the MSB of the byte following the Type B external interrupt pin byte described in subsection 3.8.1.3.





R = Read, W = Write, C = Clear only, -n = Value after reset (0, 1, x = indeterminate)

Bit 7

**INTx FLAG.** Interrupt x Flag.

This bit indicates that the selected transition has been detected. It is set, whether or not the interrupt is enabled. This bit can be used for software polling to see whether the selected edge has occurred. It can be cleared only by software or a system reset. If used as an interrupt, the bit does not have to be cleared. The interrupt occurs once for each selected edge on the interrupt pin, even though the bit is already set. Clearing the bit will, however, clear a pending interrupt request from this interrupt pin. The interrupt flag bit is located in a separate register from the interrupt control bits to prevent inadvertent clearing of the flag bit when the control bits are changed with read/modify/write-type instructions such as SBIT0 and SBIT1 (set bit to 0, set bit to 1 instructions).

- 0 = No transition is detected.
- 1 = A transition is detected.

#### Bits 6-0 Reserved.

Writing to these bits has no effect, and reads are undefined.

# 3.8.1.5 Type C Interrupt Pins

Type C interrupt pins can be used as normal interrupts, digital input, or digital output pins. Any combination of Type C (as well as Types A or B) interrupt-pin bytes can follow the two Type A interrupt bytes in addresses 00070h and 00071h, as specified by device design (see applicable device data sheet). This Type C interrupt pin byte is followed by a second byte containing the Type C interrupt flag bit (shown in subsection 3.8.1.6).



- Bit 1 INTx PRIORITY. Interrupt x Priority. This bit determines which level interrupt is requested.
  - 0 = High-level interrupt. See the specific device data sheet.
  - 1 = Low-level interrupt. See the specific device data sheet.

#### Bit 0 INTx ENABLE. Interrupt x Enable. This bit enables or disables the maskable interrupt.

- 0 = Disable interrupt (use pin as a digital input or output).
- 1 = Enable interrupt.

#### 3.8.1.6 Type C Interrupt Flag

This bit is the MSB of the byte following the Type C external-interrupt pin byte described in subsection 3.8.1.5.





#### Bit 7 INTx FLAG. Interrupt x Flag.

This bit indicates that the selected transition has been detected. It is set, whether or not the interrupt is enabled. The bit can be used for softwars polling to see whether the selected edge has occurred. It can be cleared only by software or a system reset. If used as an interrupt, the bit does not have to be cleared. The interrupt will occur once for each selected edge on the interrupt pin, even though this bit is already set. Clearing this bit will, however, clear a pending interrupt request from this interrupt pin. The interrupt flag bit is located in a separate register from the interrupt control bits to prevent inadvertent clearing of the flag bit when the control bits are changed with read/modify/ write-type instructions such as SBIT0 and SBIT1 (set bit to 0, set bit to 1 instructions).

0 = No transition is detected.

1 = A transition is detected.

#### Bits 6–0 Reserved.

Writing to these bits has no effect, and reads are undefined.

## 3.8.2 Power Module Interrupts

Power modules sometimes have fault condition signals that generate interrupts. These signals are routed to the interrupt module. Each interrupt signal has one enable bit and one status flag. Each set of seven internal interrupts has a single interrupt vector. The interrupt level is determined at device fabrication; it cannot be programmed. The power module interrupt registers reside in the same frame as the external interrupt registers.

#### 3.8.2.1 Power Module Interrupt Enable Register

The power module interrupt enable registers contain interrupt enable bits associated with any power modules that are available. See the specific device data sheet to determine availability and naming conventions. Power Module Enable 1 at address 0007Eh is shown as an example. Power Modules 2 and 3, etc., operate identically at their own addresses but are not shown (they follow the numbering scheme shown in Figure 3–8 on page 3-28).



#### Power Module 1 Enable Interrupt Register (PM1 ENABLE)

#### Bit 7 PM INT ENA 1. Power Module Interrupt Enable 1.

This bit designates whether or not the seven power module interrupt inputs are able to generate an interrupt request. Note that if this bit is cleared, none of the related seven interrupts in bits 6-0 can cause an interrupt. If this bit is set, then an active and enabled interrupt in bits 6-0 can cause an interrupt and set the corresponding bit in the power module flag register (described in subsection 3.8.2.2). The PM INT ENA 1 bit provides a quick means to temporarily disable all power module interrupts from a group and then re-enable them using the bit clear (SBIT0) and bit set (SBIT1) instructions. The wakeup signal associated with this interrupt is also disabled when the interrupt is disabled.

- 0 = Power module interrupt is disabled.
- 1 = Power module interrupt is enabled.

#### Bits 6 – 0 PM STS ENA 6–0. Power Module Status Interrupt Enable.

These bits specify whether or not the power module interrupt sources are enabled to set the PM INT FLAG 1 bit (subsection 3.8.2.2). To allow an interrupt from a particular power module input, the corresponding PM STS ENA x bit must be set, as well as the PM INT ENA 1 bit.

- 0 = Power module interrupt is disabled.
- 1 = Power module interrupt is enabled.

#### 3.8.2.2 Power Module Interrupt Flag Register

The power module interrupt flag registers contain the interrupt status flags associated with the power modules that are used. See the specific device data sheet to determine module availability and naming conventions. Power Module Flag 1 is shown as an example. Power Modules 2 and 3, etc., operate identically at their own addresses but are not shown (they follow the numbering scheme shown in Figure 3–8 on page 3-28).



#### Power Module 1 Flag Register (PM1 FLAGS)

Bit 7 PM1 INT FLAG. Power Module Interrupt Flag.

This bit is set any time one of the power module interrupt status bits is active and its corresponding PM STS ENA x bit is also set. This flag can be cleared only by writing a 0 (writing a 1 has no effect). Values read at this bit:

- 0 = Power module interrupt has not occurred since flag last cleared.
- 1 = Power module interrupt has occurred since flag last cleared.

#### Bits 6 – 0 PM INT STS 6–0. Power Module Interrupt Status Flags.

These read-only bits reflect the status of the input source signal to the power module interrupts. If the source is in its active state causing an interrupt, this bit will read a 1; otherwise, it will read a 0.

0 = Power module interrupt is inactive.

1 = Power module interrupt is active.

## 3.8.3 Phantom Interrupt Vector

The phantom interrupt vector (shown at address 08004h in Figure 3–5 on page 3-20) is a system interrupt integrity feature that allows a controlled exit from an improper interrupt acknowledge sequence. For example, if the CPU receives an interrupt request from a device module, the CPU then reads the priority chain of the device modules to determine which module has a pending interrupt. If the CPU finds no module with a pending interrupt, even though the CPU received an interrupt request, the phantom interrupt vector is accessed. Because this condition is considered to be an invalid operation, it is suggested that the phantom interrupt vector point to a reset generating routine (software reset) so that the device will resume operating from a known condition.

## 3.9 Multiple Interrupt Servicing

When multiple interrupts are pending simultaneously, the interrupt with the highest level priority is serviced first. This order of service is established through the physical daisy chain connections on the interrupts and by the interrupt mask level in the ST, bits L2-L0.

When servicing an interrupt, the processor automatically sets the interrupt mask bits L2–L0 to 1. This prevents all other interrupts (except an NMI) from being recognized during the execution of the interrupt service routine. If an NMI causes its interrupt service routine to be entered, then even subsequent NMIs are disabled until the NMI interrupt service routine is exited with an RTI (return from interrupt) instruction. Once the service routine is exited, the old status register contents are popped from the stack. This returns the ST interrupt mask bits to their original conditions, thus allowing pending interrupts to be recognized.

An interrupt service routine can allow nested interrupts by modifying the ST interrupt mask bits during interrupt service routine execution. This permits other interrupts to be recognized during the service routine execution. When a nested interrupt service routine completes, it returns to the previous interrupt service routine when the RTI instruction executes. Too many nested interrupts could overflow the stack, causing program failure.

## 3.10 TMS370C16 Interrupt Configurability Options

The Type A interrupt (described in subsection 3.8.1.1 on page 3-29) allows a *freeze* option regarding:

- Nonmaskable interrupt functionality
- Active edge polarity of the interrupt

You can configure your device with freezable control bit mask options during the final stages of the manufacturing process. This freeze option allows you to configure the function of any available Type A interrupt on the device to meet your system requirements. Freezable control bits can be frozen in either a 1 or 0 value. If a control bit is frozen, software control over that bit is disabled, and the Type A interrupt will always operate relative to the frozen state of the bit.

To configure your device with freezable control bit mask options at the time of manufacture, complete a New Code Release Form (NCRF) indicating the desired options. The NCRF is available through any local TI field sales office.

The two control bits in the Type A interrupt control register that can be individually frozen during the manufacturing process are the INT1 NMI (INTx.5) bit and the INT1 POLARITY (INTx.2) bit. Table 3–4 illustrates the possible freeze options available and how Type A interrupt operation is affected.

| INT1 NMI<br>(INTx.5) | INT1 POLARITY<br>(INTx.2) | Type A Interrupt Functionality                                                                               |
|----------------------|---------------------------|--------------------------------------------------------------------------------------------------------------|
| Writeable            | Writeable                 | Fully software selectable.                                                                                   |
| 0 (Frozen)           | Writeable                 | Type A interrupt can never be configured as an NMI. Polarity is software selectable.                         |
| 1 (Frozen)           | Writeable                 | Type A interrupt will always be configured as an NMI. Polarity is software selectable.                       |
| Writeable            | 0 (Frozen)                | Type A interrupt NMI functionality is software selectable. Polar-<br>ity is always on the falling edge only. |
| Writeable            | 1 (Frozen)                | Type A interrupt NMI functionality is software selectable. Polar-<br>ity is always on the rising edge only.  |

Table 3–4. Type A Interrupt Control Bit Freeze Options

## 3.11 Low-Power and Idle Modes

#### 3.11.1 Overview

Low-power modes reduce the operating power by reducing or stopping the internal clock signals used by various modules in the device. There are two types of low-power modes: the *halt* and *standby* modes (see the *Clock Modules Reference Guide* for implementation information.) A third mode, *idle*, is not actually a low-power mode, but a wait state.

The TMS370C16 low-power (powerdown) modes are defined as follows:

- Halt mode provides the lowest level of power reduction by stopping all system clocks.
- Standby mode provides an intermediate level of power reduction by stopping the system clocks to the CPU. The oscillator and watchdog (if available) clocks are still active in the standby mode.
- Idle mode provides no power reduction at all. The CPU in effect, goes into an infinite loop and executes the IDLE instruction until a reset occurs or an enabled interrupt causes another operation to occur.

These modes can be permanently enabled or disabled through mask options for ROM-based devices. If the device has the low-power mode disabled through this mask option, writing to the low-power selection control bits in the oscillator module has no effect. Once the low-power selection control bits are initialized, executing an IDLE instruction causes the device to enter one of the two low-power modes or the *idle* mode.

#### Note: Low-Power Modes Depend on Oscillator Module

The low-power modes for 'C16 CPU-based devices and the methods of selection depend a great deal on the oscillator module used on the device. See the specific device data sheet and the oscillator module user's guide for more information on the availability and implementation of low-power modes.

#### 3.11.2 Low-Power Wakeup Interrupt

The TMS370C16 CPU-based architecture enables the device to be pulled out of low-power modes through a maximum of 24 selectable actions, as well as any power module interrupt that is present on the device. The actual number and selection of the 24 wakeup actions is device specific. Typically, reset or any enabled external interrupt, as well as any other enabled module interrupt (SCI, RXD, RTI, etc.), pulls the device out of a low-power mode. See the specific device data sheet to determine exactly which actions allow the low-power modes to be exited.

Remember that even though an interrupt is designed to allow an exit from the low-power mode, that particular interrupt still must be enabled locally and globally to actually bring the device out of the low-power mode. For example, a device can have an SCI available and the SCI RXD interrupt selected to allow low-power mode exit. If the SCI RXD interrupt is disabled locally or if global interrupts are disabled, the low-power mode will not be exited. You must ensure a low-power mode exit path is available before entering a low-power mode.



# Chapter 4

# **Addressing Modes**

This chapter describes the addressing modes supported by the TMS370C16 microcontroller instruction set and covers the following topics:

### Topic

### Page

| 4.1 | Mode Summary                                                                                   | . 4-2 |
|-----|------------------------------------------------------------------------------------------------|-------|
| 4.2 | Implied Addressing                                                                             | 4-3   |
| 4.3 | PC-Relative Addressing                                                                         | 4-4   |
| 4.4 | Memory–Direct Addressing                                                                       | 4-5   |
| 4.5 | Immediate Values                                                                               | . 4-7 |
| 4.6 | Register-Direct Addressing                                                                     | 4-8   |
| 4.7 | Register-Indirect Addressing                                                                   | 4-9   |
|     | 4.7.1 Register-Indirect Addressing, No Displacement<br>(Register Contents = Effective Address) | 4-10  |
|     | 4.7.2 Register Indirect With Displacement (Offset)                                             | 4-13  |
| 4.8 | Setting the Word Address for CALL, JMP, and FMOV Instructions                                  | 4-16  |

## 4.1 Mode Summary

The various addressing modes of the TMS370C16 CPU and their syntax are described in the pages listed in Table 4–1 below. To find which modes apply to a specific instruction, consult the instruction-set summary table in Section 5.2, beginning on page 5-4.

Table 4–1. Addressing Mode Summary

| Addressing Mode                | Description                                                                                                      | Section | Page |
|--------------------------------|------------------------------------------------------------------------------------------------------------------|---------|------|
| Implied                        | Operand is not required. Instruction operation is implied in the mnemonic.                                       | 4.2     | 4-3  |
| PC Relative                    | Operation is relative to the PC contents.                                                                        | 4.3     | 4-4  |
| Memory Direct                  | Operation is on a specified memory address.                                                                      | 4.4     | 4-5  |
| Immediate                      | Operate on a value specified in the operand.                                                                     | 4.5     | 4-7  |
| <b>Register Direct</b>         | Operate on the value in a register.                                                                              | 4.6     | 4-8  |
| Register indirect <sup>†</sup> | Operate on a value at an address in a register.                                                                  | 4.7     | 4-9  |
| No Displacement                | Register contents = effective address<br>(includes both predecrement and<br>postincrement modes)                 | 4.7.1   | 4-10 |
| With Displacement              | Offset + register contents = effective<br>address (includes extra indirection with<br>CALL and JMP instructions) | 4.7.2   | 4-13 |

<sup>†</sup>Section 4.8 (page 4-16) describes how to set the word address in a register for using indirect addressing with the CALL, JMP, and FMOV instructions.

| Symbol        | Meaning                                          | Example         |
|---------------|--------------------------------------------------|-----------------|
| (Rx) or ( x ) | Contents of register x or of memory at address x | (R4) or (LABEL) |
| ((×))         | Contents of memory designated by contents of x   | (disp + (Rn))   |

To designate contents, the following apply:

## 4.2 Implied Addressing

This class of instructions does not require you to specify an operand. The operands to be used are predetermined. For example, the implied instruction RTS has two implied operands: the stack pointer (SP) and the program counter (PC). Other instructions using this form of address are RTI (return from interrupt) and UNLINK (unlink and deallocate stack frame).





Note: A dashed line denotes the path of the value moved or copied. A solid line denotes a location pointer.

## 4.3 PC-Relative Addressing

This format adds or subtracts a value from the PC to derive the effective address of the next instruction. Instructions using this format are Bcond, BRBIT0, BRBIT1, and DBNZ.

#### Figure 4–2. PC-Relative Addressing



For Bcond, BRBIT0, and BRBIT1, a signed 8-bit value is added to the PC as address lines A8–A1 to redirect execution flow from the executing instruction's 17-bit *physical memory address*. For the DBNZ instruction, a *fourbit unsigned* value in bits 7–4 of the instruction word is *subtracted* from the PC's corresponding value for address lines A4–A1. The following table shows the displacement from the *physical address* of the PC.

| Instruction                                          | Maximum Displacement                                                       |
|------------------------------------------------------|----------------------------------------------------------------------------|
| Bcond (where cond represents the condition mnemonic) | +129 words after and -126 words be-<br>fore the physical address of the PC |
| BRBIT0 and BRBIT1                                    | +130 words after and -125 words be-<br>fore the physical address of the PC |
| DBNZ                                                 | Up to -15 words before the PC                                              |

The 8-bit displacement is contained in the LSB:

| 15     | 8 | 7 | 4           | 3    | 0   |
|--------|---|---|-------------|------|-----|
| Opcode |   |   | 8-Bit Displ | acem | ent |

## 4.4 Memory-Direct Addressing

This addressing mode provides an easy way to deal directly with absolute addresses or labeled addresses. It is available *only* for instruction formats in which the indirect register with offset format (\**disp<sub>16</sub> [Rn]*) is used (as explained in the note on the next page).

### Figure 4–3. Memory-Direct Addressing (& Operator)

MOV &TABL1,&TABL2

Execution: (TABL1) → (TABL2)



Move (copy) the entire contents (word value) at address TABL1 to address TABL2. Leave the source-address contents unchanged. Consider TABL1 and TABL2 to be on *even address boundaries* in order to work correctly with a move-word instruction.



MOVB &TABL3, &TABL2+1

Execution: (TABL3<sub>bvte</sub>) → (TABL2+1<sub>bvte</sub>) Move (copy) the byte contents at address TABL3 to the byte at address TABL2+1. Leave the source-address contents unchanged. TABL2 and TABL3 are on *even address boundaries* in this example.



#### Note: Derivation of Memory-Direct Format (& Operator)

The &LABEL-format instruction is derived by transforming the &LABEL operand into the \**displacement16*[*ZR*] format (ZR = R15, the zero register). Thus the zero register value does not change the source or destination address, leaving it equal to the *displacement16* value of LABEL.

For example:

MOV &LABEL,R10

is assembled as if written as:

MOV \*LABEL[ZR],R10

and its timing is the same as for the *\*disp[Rn]* format.

The second instruction example above moves the contents at LABEL (zero offset) to R10. The corresponding opcode value in this example is 22h, and the instruction needs three cycles to execute, as shown for the formats for the MOV instruction, beginning on page 5-70.

The &LABEL format can be used with *any* instruction that uses the *\*disp[Rn]* operand (e.g., ADD, ADC, AND, CALL, CLR, etc.).

## 4.5 Immediate Values

This format contains a signed immediate number that will be operated on by the instruction. The immediate value is preceded by an identifying pound sign (#). The different types of immediate instructions are described below.

### Figure 4-4. Operand Is Immediate Value (# Operator)

```
MOV #3,R3
```

Move (copy) the immediate value 3 to R3. The immediate value operand is signified by a # prefix.

Execution: Immediate operand  $\rightarrow$  (R3)



| Extension Word (Up to 16<br>Bits) | A 16-bit extension word following the instruction word con-<br>tains the immediate value:                         |  |  |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------|--|--|
|                                   | Opcode                                                                                                            |  |  |
|                                   | Up to 16-Bit Value                                                                                                |  |  |
| Embedded 8-Bit Immediate          | The immediate value is in the LSbyte of the instruction word:                                                     |  |  |
|                                   | Opcode 8-Bit Value                                                                                                |  |  |
|                                   | Instructions using this format include TBIT0, TBIT1, LINK, RTDU, and TRAP.                                        |  |  |
| Embedded 4-Bit Immediate          | The immediate value is in the four MSBs of the instruction word's LSbyte:                                         |  |  |
|                                   | Opcode 4-Bit Value                                                                                                |  |  |
|                                   | Instructions using this format include ADQ, ADQB, MOVQ, SUBQ, SUBQB, STRI, and the shift instructions (SHL, SHLL, |  |  |

ASR, ASRL, ASR0, ASR0L, LSR, and LSRL).

#### **Register-Direct Addressing** 4.6

Values within registers are operated upon. The effective address is within the first 64K bytes except for the CALL and JMP instructions, which address 128K bytes.

#### Figure 4–5. Register-Direct Addressing

Move (copy) the entire contents (word value) of R1 to R3. Leave the ➀ MOV R1,R3

```
2
    MOVB R3, R5
```

source register (R1) unchanged. Later, move the LSbyte of R3 to the LSbyte of R5; zero-extend the MSbyte of R5.

Execution: መ

2



Register Direct With CALL or JMP Instructions Addresses 128K Bytes Figure 4–6.

> When used with the CALL or JMP instructions, this mode addresses 128K bytes (as shown above, address line A16 = 0). For JMP or CALL, place the new 16-bit value into the PC, then overlay the PC value onto address lines A16-A1 with A0 set to 0. Since this essentially multiplies the register contents by two, the register's contents must be half the absolute memory address value. You can use the question mark operator (?) to fill the register with this value (as shown in Section 4.8 on page 4-16).



4-8

## 4.7 Register-Indirect Addressing

The forms of indirect addressing are listed in Table 4-2 below:

Table 4–2. Register-Indirect Addressing Summary

| Indirect Addressing Mode       | Exam       | ple Using MOV | Description                                                                                                                                                                                                 | See                                         | On Page              |  |
|--------------------------------|------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|----------------------|--|
| No Displacement                | MOV *R1,R2 |               | The effective address of the source is the value in R1. Move (copy) contents at that address to R2.                                                                                                         | Figure 4–7                                  | 4-10                 |  |
| Predecrement, no displacement  | MOV        | *R1,R2        | Before the move, decrement<br>the contents of R1 by 2 (for<br>word instructions — by 1 for<br>byte instructions). Then move<br>(indirect) the contents at the<br>address in R1 into register R2.            | Figure 4–7<br>Figure 4–8                    | 4-10<br>4-11         |  |
| Postincrement, no displacement | MOV        | *R1+,R2       | First move (indirect) the con-<br>tents at the address in R1 into<br>register R2. Then increment the<br>contents of R1 (by 2 for word<br>instructions — by 1 for byte<br>instructions).                     | Figure 4–9                                  | 4-12                 |  |
| With Displacement              | MOV        | *DISP[R1],R2  | DISP = amount added to R1 to<br>compute the effective address<br>of the source. Move contents at<br>this effective address to R2.<br>Neither predecrement nor post-<br>increment is used with this<br>form. | Section 4.7.2<br>Figure 4–10<br>Figure 4–11 | 4-13<br>4-13<br>4-14 |  |

#### Note: \*Rn Can Be Used If \*disp[Rn] is Assembled

Several instructions do not provide an indirect register without displacement (\**Rn*), but provide an indirect register with displacement (offset) (\**disp[Rn]*). However, with such instructions, the assembler accepts \**Rn* by assembling the \**Rn* format into a \*0[*Rn*] format.

| For example, the assembler statement | ADD | *R1,R2    |
|--------------------------------------|-----|-----------|
| is assembled as if written           | ADD | *0[R1],R2 |

Thus, the requested instruction becomes a two-word instruction with a zero offset in the second word. In this case, timing is 3 cycles — the cycle count for ADD \**disp[Rs]*,*Rd.* (Note that an ADD \**Rs*,\**Rd* operand cannot be used, because there is no ADD \**disp[Rs]*,\**disp[Rd]* instruction.)

## 4.7.1 Register Indirect Addressing, No Displacement (Register Contents = Effective Address)

Register contents point to a memory address that contains the value to be operated on. The register value is treated as a 16-bit memory address (address line A16 = 0) by all instructions except CALL, FMOV, and JMP (which use the value as a *word address* and apply it to the PC, where it is shifted to a 17-bit word address). A method to derive the word address for indirect addressing is shown in Section 4.8 on page 4-16.

Two other forms of indirect addressing are predecrement and postincrement:

- In postincrement, the register containing the address is first accessed and incremented *afterwards* (see Figure 4–9). This is used with instructions such as MOV, CLR, CMP, STEA, and TST.
- In predecrement, the register containing the address is decremented before the address is accessed (see Figure 4–8). This is used with the MOV \*–Rs,Rd format.

#### Note: Decrement/Increment Considerations

- 1. The value incremented or decremented depends upon the size of the instruction. This value is 2 for word instructions and 1 for byte instructions.
- 2. When initializing the stack pointer (SP or R14), always write an *even* value to the SP register. An odd value can cause an error.

Figure 4–7. Register Indirect (Operand: \*Rn)







Note: A dashed line denotes the path of the value moved or copied. A solid line denotes a location pointer.

## Figure 4–9. Register Indirect with Postincrement (Operand: \*Rn+) and Predecrement (Operand: \*–Rn)

MOV \*SP+,R11
 MOV \*-SP,R11

This example demonstrates the execution of both postincrement addressing and predecrement addressing. The two instructions, executed one after the other as shown, repeat exactly the same function: they both move the value at address 8002h to R11.

MOV \*SP+,R11 first implements the move, then increments the SP by 2. Then, MOV \*–SP,R11 first decrements the SP by two and then repeats the same function. Note that the form of the predecrement instruction shown here (MOV \*–Rn,Rn) is the *only* form of the predecrement instruction.



## **Note:** A dashed line denotes the path of the value moved or copied. A solid line denotes a location pointer.

## 4.7.2 Register Indirect With Displacement (Offset)

These examples show a displacement added to a register's contents to derive the location of the effective address. Figure 4–10 uses **word** format. Figure 4–11 uses **byte** format. Except when used with the JMP or CALL instructions (see Figure 4–12 on page 4-15), indirect addressing is *restricted* to the **first 64K** bytes of memory.

Note that the register to be added to the displacement is contained in **square brackets** (not parentheses).

With some instructions (e.g., JMP and CALL), access is to the *full 128K* bytes of memory. As shown in Figure 4–13 (page 4-16), these instructions place the value at the resulting effective address into the PC (where it is shifted to create a 17-bit memory address in order to access the full 128K-byte address range).

Figure 4–10. Offset + Register in Word Format (Operand: \*disp16[Rn])



Note: A dashed line denotes the path of the value moved or copied. A solid line denotes a location pointer.

Execution:

#### Figure 4–11. Offset + Register in Byte Format (Operand: \*disp16[Rn])

#### MOVB \*103h[R4],R6

 $(103h + (R4)) \rightarrow (R6)$ 

This example is similar to Figure 4–10, except that a byte move is requested (note that the byte is at an uneven address). The source value is found at the address derived by adding the 0103h immediate value and the contents of R4, which contains

the 8402h offset. Thus, move the value at address 8505h, which is the LSbyte. However, byte operations extend the byte to a zero-filled word and operate on the word. With a register destination, the entire word is moved to fill the register (a move to a *memory address* changes only the destination byte — see second example below).



MOVB \*103h[R4],\*R6

(103h + (R4)) → ((R6))

Execution:

The above example is repeated, except that the destination is changed to a memory address because the destination register holds an indirect address. This example shows that the move affects only the designated byte in the destination acent byte upchanged (no zero-filling occurs as it would

memory address, leaving any adjacent byte unchanged (*no* zero-filling occurs as it would with a register).



**Note:** A dashed line denotes the path of the value moved or copied. A solid line denotes a location pointer.

Figure 4–12. Offset + Register for JMP and CALL Instructions (Operand: \*disp16[Rn])

JMP \*200h[R5]

Execution: (200h + (R5)) → (PC)) The destination *word* address (new PC value) is found in a memory address derived by adding the register contents and the offset (displacement) in the operand. This sum (8700h in this example) is a memory address that *contains* the word address (F000h), which is placed in the PC and applied to address lines A16–A1 with A0 held to 0.



**Note:** A dashed line denotes the path of the value moved or copied. A solid line denotes a location pointer.

The format in Figure 4–12 has an extra level of indirection when used by either the JMP or CALL instruction. The sum of the displacement and register value is a memory address that contains a word address. This word address is placed in the PC and then overlayed on address lines A16–A1 with A0 set to 0 (effectively multiplying the PC value by 2). A method to set the word address for this operation is shown in Section 4.8 on the next page.

Note that with JMP and CALL, indirect register with offset goes to an address to get the final word address. Compare this with the MOV instruction using indirect register with offset for source: the sum of the offset and register is the actual memory address that contains the value to be moved (not the value of another memory address containing the source).

## 4.8 Setting the Word Address for CALL, JMP, and FMOV Instructions

The CALL, JMP, and FMOV instructions address the full 128K-byte address space. They apply their effective operand to address lines A16–A1 with A0 cleared to 0. If you know the 17-bit memory address and want to set up a corresponding word address in a register or memory location, use the questionmark (?) operator, which translates the 17-bit **labeled** memory address into a 16-bit word address (divides the memory address by 2). For example, use the ? operator with a MOV instruction to place the word address into a register. Then use a CALL, JMP, or FMOV instruction to that register or memory location. This is shown in Figure 4–13. This form uses a label representation of the memory address, *not an immediate value*.

# Figure 4–13. Using the ? Operator to Set the Word Address for a Direct-Register CALL or JMP

MOV#?LABEL, R5This example shows how the address can be set up for the jump<br/>shown in Figure 4–7 on page 4-10. The jump is to a 17-bit<br/>memory address; this means that the value brought into the PCJMPR5shown in Figure 4–7 on page 4-10. The jump is to a 17-bit<br/>memory address; this means that the value brought into the PC<br/>is shifted left one bit (multiplied by 2). Thus, the value brought to<br/>the PC must be a 16-bit word address that is one-half the des-<br/>tination 17-bit memory address. In this example, the word

address is brought in from R5. To get the correct value in R5, use the question-mark (?) operator when loading R5 with the destination address. This operator divides the value by 2, setting up the correct address for the jump destination (as also needed in Figure 4–6). A CALL direct to a register is treated like a JMP.



This method can also be used to set up the indirection register for the FMOV instruction. The bits in the indirection register (either the source or destination) are a word address to be applied to address bits A16—A1.

Figure 4–14. Use the ? Operator to Set the Word Address for an Indirect-Register FMOV





# **Assembly Language Instructions**

This chapter describes the mnemonics and operation of the TMS370C16 instruction set, organized in alphabetical order. The chapter begins with a table that summarizes each instruction and auxiliary tables that list the format protocol for the descriptions. Following these are full descriptions of each instruction.

| Торіс                                              | Page |
|----------------------------------------------------|------|
| 5.1 Instruction Set Summary                        | 5-2  |
| 5.2 Instruction Set Summary Table                  | 5-4  |
| 5.3 Instruction Descriptions in Alphabetical Order | 5-16 |

## 5.1 Instruction Set Summary

Section 5.2, starting on page 5-4, summarizes the TMS370C16's instructions. Table 5–1 and Table 5–2 list the abbreviations and symbols used in Section 5.2.

Table 5–1. Abbreviations Used to Describe Instructions

| Abbreviation       | Meaning                                                                                                                                                          |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| addr16             | address; 16 bits in this example                                                                                                                                 |
| &addr              | variant to synthesize direct addressing in memory (assembles as *addr[ZR])                                                                                       |
| В                  | byte opcode                                                                                                                                                      |
| C[[ST]]            | carry flag in ST                                                                                                                                                 |
| const4, const8     | constant (4-bit, 8-bit, etc.)                                                                                                                                    |
| d, dest            | destination                                                                                                                                                      |
| disp8, disp16      | displacement (8-bit, 16-bit values shown)                                                                                                                        |
| (disp[Rn])         | contents at the effective address of displacement + value in Rn                                                                                                  |
| enumerator8        | member of a list                                                                                                                                                 |
| IEW                | instruction extension word                                                                                                                                       |
| imm                | unsigned immediate value; in operand syntax it is preceded by a <b>#</b> symbol; if followd by a number<br>( <i>imm4</i> ), number = size in bits (compare simm) |
| IM                 | implied register (R1)                                                                                                                                            |
| IW                 | instruction word                                                                                                                                                 |
| IM:Rd              | 32-bit concatenation of IM and Rd                                                                                                                                |
| FP                 | frame pointer register (R0)                                                                                                                                      |
| L                  | longword opcode                                                                                                                                                  |
| LSB                | least significant bit(s)                                                                                                                                         |
| LSbyte             | least significant byte                                                                                                                                           |
| LSword             | least significant word                                                                                                                                           |
| MSB                | most significant bit(s)                                                                                                                                          |
| MSbyte             | most significant byte                                                                                                                                            |
| MSword             | least significant word                                                                                                                                           |
| N[ST]              | sign flag in ST                                                                                                                                                  |
| NOTx               | ones complement of x                                                                                                                                             |
| Ор                 | opcode                                                                                                                                                           |
| ОрА                | 17-bit opcode address (address-bus location)                                                                                                                     |
| PC                 | program counter register                                                                                                                                         |
| prevA, (prevA)     | previous-cycle address bus value; (prevA) = <i>contents</i> of previous-cycle address bus value                                                                  |
| Rn                 | register (n = register number, R0-R15)                                                                                                                           |
| Rd, Rs, (Rs), (Rd) | registers, destination and source; (Rd) = <i>contents</i> of destination register; Rd7 = bit 7 of Rd, etc.                                                       |
| ((Rs)), ((Rd))     | contents of address contained in Rs or Rd, respectively                                                                                                          |
| R FIRST, R LAST    | range of registers                                                                                                                                               |

| Abbreviation           | Meaning                                                                                                                                              |  |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| *Rn, *Rn+, *–Rn–       | indirection, contents of. * <i>Rn</i> = address value is in <i>Rn</i> ; *– <i>Rn</i> = predecrement;<br>* <i>Rn</i> + = postincrement                |  |
| Rn (0-7)               | bit range within a register (register bits 0-7 in this example)                                                                                      |  |
| rtnA                   | return address                                                                                                                                       |  |
| S                      | S = size of transfer with 1 = byte and 0 = word; see explanation of "b" column for functional logic states in Figure 5–1 on page 5-16.               |  |
| s, src                 | source                                                                                                                                               |  |
| simm 4, simm 8         | signed immediate value (4-, 8-bits, etc.)                                                                                                            |  |
| SP                     | stack pointer register (R13)                                                                                                                         |  |
| ST                     | status register (R14)                                                                                                                                |  |
| synth. inst            | synthetic instruction (synthesized using another assembler format)                                                                                   |  |
| vector base<br>address | starting (low) address of the interrupt vectors (an offset is added to this address to determine the address containing the vector of the interrupt) |  |
| V[[ST]]                | overflow/borrow flag in ST                                                                                                                           |  |
| w                      | word opcode                                                                                                                                          |  |
| ZR                     | zero register (R15)                                                                                                                                  |  |
| Z[[ST]]                | zero flag in ST                                                                                                                                      |  |

Table 5–1. Abbreviations Used to Describe Instructions (concluded)

Table 5–2. Symbols Used to Describe Instructions

| Symbol | Meaning                                                                                                                                                                                                               |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| { }    | option to select a value in brackets; for example, $\{x, y\}$ = enter either x or y, or ADD{B} = ADDB is an option-<br>al form of the ADD instruction (add byte vs. add word).                                        |
| •      | bitwise EXCLUSIVE OR $(x^{A}y = true$ where corresponding bits are different)                                                                                                                                         |
| ~      | ones complement (unary): toggle/invert bit values: (0 $\leftrightarrow$ 1)                                                                                                                                            |
| -      | negate (twos complement)                                                                                                                                                                                              |
| ~~     | left shift (e.g., $(y) << 6 =$ shift y 6 bit positions to the left)                                                                                                                                                   |
| >>     | right shift (e.g., $(x) >> 4$ = shift x 4 bit positions to the right)                                                                                                                                                 |
| →      | copied to or assigned to                                                                                                                                                                                              |
| #      | immediate operand                                                                                                                                                                                                     |
| ()     | contents of. For example, (SP) = contents of stack pointer; (Rd) = contents of Rd.                                                                                                                                    |
|        | bit selection ( <i>s.bit4</i> = bit 4 in <i>s</i> )                                                                                                                                                                   |
| , +    | bitwise OR $(x y = 0$ if either x and $y = 0$ )                                                                                                                                                                       |
| #?     | when a prefix to a label in assembly language, indicates word address (one half absolute address)                                                                                                                     |
| &      | bitwise AND ( $x \& y = 0$ if either x or $y = 0$ , but = 1 if both x and $y = 1$ ). If used before a label or address value in assembly language syntax, it indicates direct addressing (synthesizes as *Label[ZR]). |
| ſ      | Synthetic instruction                                                                                                                                                                                                 |

## 5.2 Instruction Set Summary Table

The following table summarizes each of the TMS370C16's assembly language instructions: mnemonics, operands, opcodes, execution cycles, affect on the status register, and a short description. Included under the Mnemonic column are operands called variants. These are derived by assembling another form of the instruction, usually using a form of the *\*disp16,[Rn]* operand (explained in the note on page 4-6). Variants can be convenient, but may require more cycles than another format.

|                                      | 0  | ocode† | Cycles            | Status‡ |                                                                          |
|--------------------------------------|----|--------|-------------------|---------|--------------------------------------------------------------------------|
| Mnemonic                             | В  | WL     | (t <sub>c</sub> ) | ZNCV    | Operation Description                                                    |
| ADC                                  |    |        |                   | * * * * | Add source plus carry to destination                                     |
| Rs,Rd                                |    | 8A     | 1                 |         | $(s) + (d) + (C[ST]) \rightarrow (d)$                                    |
| *disp16[Rs],Rd<br>variant:           |    | 8B     | 3                 |         | (an ADD/ADC sequence can be used for 32-bit addition)                    |
| &address,Rd                          |    | 8B     | 3                 |         |                                                                          |
| ADD, ADDB                            |    |        |                   | ** * *  | Add source to destination                                                |
| Rs,Rd                                | 31 | 30     | 1                 |         | $(s) + (d) \rightarrow (d)$                                              |
| Rs,*disp16[Rd]                       | 33 |        | 5<br>2<br>3       |         |                                                                          |
| #imm16,Rd                            | 35 | •••    | 2                 |         |                                                                          |
| *disp16[Rs],Rd                       | 37 | 36     | 3                 |         |                                                                          |
| variants:                            |    |        | _                 |         |                                                                          |
| Rs,&address                          | 33 | 32     | 5                 |         |                                                                          |
| &address,Rd                          | 37 | 36     | 3                 |         |                                                                          |
| ADQ, ADQB                            |    |        |                   | ** * *  | Add quick immediate to destination                                       |
| #imm4,Rd                             | 83 | 82     | 1                 |         | $(s) + (d) \rightarrow (d)$                                              |
| #imm4,*disp16[Rd]<br><i>variant:</i> | 85 | 84     | 5                 |         | (add short constant — source is 4-bit<br>immediate value in opcode word) |
| #imm4,&address                       | 85 | 84     | 5                 |         |                                                                          |
| AND, ANDB                            |    |        | 1                 | **-0    | Logical AND source with destination                                      |
| Rs,Rd                                | 41 | 40     | 1                 |         | (s) & (d) $\rightarrow$ (d)                                              |
| Rs,*disp16[Rd]                       | 43 | 42     | 5                 |         |                                                                          |
| #imm16,Rd                            | 45 | 44     | 5<br>2<br>5       |         |                                                                          |
| #imm16,*disp16[Rd]                   | 47 | 46     | 5                 |         |                                                                          |
| variants:                            |    |        |                   |         |                                                                          |
| Rs,&address                          | 43 | 42     | 5                 |         |                                                                          |
| #imm16,&address                      | 47 | 46     | 5                 |         |                                                                          |

Legend: † Data Size: B = affects byte W = affects word ‡ Status Register Values:

0 = status bit always cleared

- = status bit unchanged by execution

L = affects long word

1 = status bit always set

\* = other effect on status bit (see instruction description)

| Mnemonic                                                                                                                                                                                                                                                                                                                                                                                                                         | Opcode <sup>†</sup><br>B W L                                                                                                                           | Cycles<br>(t <sub>c</sub> )                                     | Status <sup>‡</sup><br>Z N C V | Operation Description                                                                                                                                                                                                                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ASR, ASRL<br>ASR #imm4,Rd<br>ASRL #imm4,IM:Rd<br>ASR Rs,Rd<br>ASRL Rs,IM:Rd<br>ASRL Rs,IM:Rd where<br>Rs=xxx0h                                                                                                                                                                                                                                                                                                                   | B4 B5<br>B6 B7<br>B7                                                                                                                                   | n+1<br>2n<br>n+3<br>2n+2<br>3                                   | * * * 0                        | Arithmetic shift register right<br>(d) >> $n \rightarrow$ (d)<br>(arithmetic right shift — source contains<br>shift count $n$ )                                                                                                                                                                                                |
| ASR0, ASR0L<br>ASR0 #imm4,Rd<br>ASR0L #imm4,IM:Rd<br>N[ST] = 0<br>N[ST] = 1<br>ASR0 Rs,Rd<br>ASR0L Rs,IM:Rd                                                                                                                                                                                                                                                                                                                      | B8<br>B9<br>B9<br>BA<br>BA                                                                                                                             | n+2<br>2n+3<br>2n+2<br>n+4                                      | * * * 0                        | Arithmetic right shift, round to 0:<br>(d) >> n → (d)<br>IF N[[ST]] = 1 and a 1 is shifted out<br>of LSB,<br>THEN Rd + 1 → Rd.<br>(arithmetic right shift — source contains                                                                                                                                                    |
| N[ST] = 0<br>N[ST] = 0 (Rs = 0)<br>N[ST] = 1<br>N[ST] = 1 where<br>(Rs = xxx0h)                                                                                                                                                                                                                                                                                                                                                  | BB<br>BB<br>BB<br>BB                                                                                                                                   | 2n+3<br>3<br>2n+4<br>3                                          |                                | shift count n — round to 0)                                                                                                                                                                                                                                                                                                    |
| B{COND} disp8<br>BCOND Branch Condition<br>BC if carry set<br>BEQ if equal<br>BGE if greater than or<br>equal<br>BGT if greater than<br>BHI if higher<br>BHS if higher or same<br>BLE if less than or equal<br>BLO if lower<br>BLS if lower or the same<br>BLT if less than<br>BN if negative<br>BNC if carry clear<br>BNE if not equal<br>BNV if overflow clear<br>BP if positive<br>BPZ if plus (not<br>negative)<br>BB always | C2 <sup>§</sup><br>C3<br>C9<br>C7<br>C5<br>S<br>C1 <sup>§</sup><br>C8<br>C2 <sup>§</sup><br>C6<br>CA<br>CF<br>C1 <sup>§</sup><br>C4<br>CCD<br>CE<br>C0 | 3<br>if<br>branch<br>taken<br>2<br>if<br>branch<br>not<br>taken |                                | IF cond = true, branch to PC + disp8;.<br>otherwise, execute next instruction.<br>Branch conditions; ST bit combinations:<br>C = 1<br>Z = 1<br>N^V = 0<br>Z   (N^V) = 0<br>C   Z = 0<br>C = 0<br>Z   (N^V) = 1 [Z OR (N XOR V) = 1]<br>C = 1<br>C   Z = 1<br>N^V = 1<br>N = 1<br>C = 0<br>Z = 0<br>V = 0<br>N   Z = 0<br>N = 0 |
| BR always<br>BV if overflow set                                                                                                                                                                                                                                                                                                                                                                                                  | C0<br>CB                                                                                                                                               |                                                                 |                                | <br>V = 1                                                                                                                                                                                                                                                                                                                      |

Legend: † Data Size:

B = affects byte W = affects word **‡** Status Register Values:

L = affects long word

 0 = status bit always cleared
 1 = status bit always set

 - = status bit unchanged by execution
 \* = other effect on status bit (see instruction description)

 § Two pairs of branch instructions have the same opcodes: BHS and BNC are C1h, and BC and BLO are C2h.

| <b>[</b>                                                                           |                                                     | Onesdat                                      | Cycles                                                  | Status‡ |                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------------------------------------------------|-----------------------------------------------------|----------------------------------------------|---------------------------------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mnemonic                                                                           |                                                     | Opcode <sup>†</sup><br>B W L                 | (t <sub>c</sub> )                                       | ZNCV    | Operation Description                                                                                                                                                                                                                                                                                                                         |
| BRBIT0<br>#imm3,&addr,disp8                                                        | <i>imm3</i><br>0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | D0<br>D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7 | 5<br>(branch<br>taken)<br>4<br>(branch<br>not<br>taken) |         | Branch if bit is 0.<br>Test bit <i>imm3</i> in byte <i>addr</i> .<br>IF bit = 0, branch to PC + <i>disp8</i> ;<br>THEN (PC) + disp8 → (PC)<br>ELSE, execute next sequential<br>instruction.<br>(The <i>imm3</i> value is contained in the 3<br>LSBs of the opcode.)                                                                           |
| BRBIT1<br>#imm3,&addr,disp8                                                        | <i>imm3</i><br>0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | D8<br>D9<br>DA<br>DB<br>DC<br>DD<br>DE<br>DF | 5<br>(branch<br>taken)<br>4<br>(branch<br>not<br>taken) |         | Branch if bit is 1.<br>Test bit <i>imm3</i> in byte <i>addr</i> .<br>IF bit = 1, branch to PC + <i>disp8;</i><br>THEN (PC) + disp8 → (PC)<br>ELSE, execute next sequential<br>instruction.<br>(The <i>imm3</i> value is contained in the 3<br>LSBs of the opcode.)                                                                            |
| CALL<br>Rd<br>addr<br>*disp 16[Rd]<br>variants:<br>*Rd<br>&address                 | <u> </u>                                            | EB<br>EC<br>ED<br>ED<br>ED                   | 5<br>4<br>5<br>5<br>5                                   |         | Jump to subroutine, with linkage<br>CALL $Rd$ :<br>Next Instruction Address $\rightarrow$ (SP)<br>(SP) + 2 $\rightarrow$ (SP)<br>( $Rd$ ) $\rightarrow$ (PC)<br>CALL * $Rd$ is assembled as CALL *0[ $Rd$ ].<br>CALL & address is assembled as<br>CALL *address[ $RZ$ ].<br>(Both variant forms expect a word address<br>at the destination.) |
| CLR, CLRB <sup>¶</sup><br>Rd<br>*Rd<br>*Rd+<br>*disp16[Rd]<br>variant:<br>&address |                                                     | 03 02<br>05 04<br>07 06<br>09 08<br>09 08    | 1<br>2<br>3<br>3                                        | 10-0    | Clear destination:<br>$0 \rightarrow (d)$<br>Synthesized as MOV <i>ZR</i> , <i>d</i> .                                                                                                                                                                                                                                                        |

Legend: † Data Size: B = affects byte W = affects \$ Status Register Values: 0 = status bit always cleared --= status bit unchanged by execution B = affects byte W = affects word

**1** Synthetic instruction

L = affects long word

1 = status bit always set \* = other effect on status bit (see instruction description)

| Mnemonic                                                                                                                                                                                    |                                              | code <sup>*</sup><br>W                       | t<br>L | Cycles<br>(t <sub>c</sub> )                             | Status <sup>‡</sup><br>Z N C V | Operation Description                                                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------|--------|---------------------------------------------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMP, CMPB<br>Rs,Rd<br>#imm16,Rd<br>*disp16[Rs],Rd<br>*Rs+,Rd<br>*disp16[Rs],*disp16[Rd]<br>variants:<br>&address,Rd<br>&address,*disp16[Rd]<br>*disp16,[Rs],&address<br>&address1,&address2 | 61<br>63<br>65<br>67<br>69<br>65<br>69<br>69 | 60<br>62<br>64<br>66<br>68<br>68<br>64<br>68 |        | 1<br>2<br>3<br>5<br>5<br>5<br>5<br>5<br>5               | ****                           | Compare source to destination:<br>(d) - (s)<br>and set ST bits accordingly.                                                                                                         |
| CMPC<br>Rs,Rd<br>*disp16[Rs],Rd<br>variant:<br>&address,Rd                                                                                                                                  |                                              | 8E<br>8F<br>8F                               |        | 1<br>3<br>3                                             | ***                            | Compare source to destination:<br>(d) - ((s - C[ST]))<br>and set ST bits accordingly.                                                                                               |
| COMPL, COMPLB <sup>¶</sup><br>Rn                                                                                                                                                            | 2F                                           | 2E                                           |        | 1                                                       | ** * *                         | Twos-complement (negate) destination (ZR) – (Rn) $\rightarrow$ (Rn) Synthesized as SUBR Rn,ZR.                                                                                      |
| DBNZ Rs,disp4                                                                                                                                                                               |                                              | A8                                           |        | 4<br>(branch<br>taken)<br>3<br>(branch<br>not<br>taken) |                                | Decrement register; branch if not 0:<br>(Rs) – 1 $\rightarrow$ (Rs)<br>IF Rs $\neq$ 0, branch to PC – disp4<br>IF Rs = 0, execute next sequential<br>instruction without branching. |
| DEC, DECB <sup>¶</sup><br>Rd<br>*disp16[Rd]<br>variant:<br>&address                                                                                                                         | 87<br>89<br>89                               | 86<br>88<br>88                               |        | 1<br>5<br>5                                             | ****                           | Decrement destination<br>$(d) - 1 \rightarrow (d)$ .<br>Synthesized as SUBQ #1, destination.                                                                                        |
| DIVS, DIVSL<br>DIVS <i>Rs,Rd</i><br>DIVSL <i>Rs,IM:Rd</i>                                                                                                                                   |                                              | A2<br>A                                      | 3      | 2–27▲<br>2–29                                           | **0*                           | Signed division:<br>$(d) \div (Rs) \rightarrow (Rd)$ (quotient),<br>remainder $\rightarrow (IM)$ .                                                                                  |
| DIVU, DIVUL<br>DIVU <i>Rs,Rd</i><br>DIVUL <i>Rs,IM:Rd</i>                                                                                                                                   |                                              | A0<br>A                                      | 1      | 3–21♦                                                   | * * * 0                        | Unsigned division:<br>$(d) \div (Rs) \rightarrow (Rd)$ (quotient),<br>remainder $\rightarrow (IM)$ .                                                                                |

Legend: <sup>†</sup> Data Size: B = affects byte W = affects word L = affects long word

‡ Status Register Values:

0 = status bit always cleared

- = status bit unchanged by execution
- 1 = status bit always set
- \* = other effect on status bit (see instruction description)

Synthetic instruction

S Two pairs of branch instructions have the same opcodes: BHS and BNC are C1h, and BC and BLO are C2h.

▲ DIVS takes 2–27 cycles, with two exceptions explained in the instruction's detailed description. DIVSL takes 2-29 cycles, with eight exceptions explained in the instruction's detailed description.

DIVU and DIVUL take 3-21 cycles, with the exceptions explained in the instruction's detailed description.

5-7

| Mnemonic                                                                                                                      | Opcode <sup>†</sup><br>B W L     | Cycles<br>(t <sub>c</sub> ) | Status‡<br>Z N C V | Operation Description                                                                                                                                                               |
|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EXTS, EXTSB<br>EXTS IM:Rd<br>EXTSB Rd                                                                                         | AAAB                             | 2<br>1                      | ***0               | Extend sign of register value:<br>bit 15 value → bits 16 to 31 (word)<br>bit 7 value → bits 8 to 15 (byte)                                                                          |
| EXTZ, EXTZB¶<br>EXTZ IM:Rd<br>EXTZB Rd                                                                                        | 02<br>03                         | 1                           | **-0               | Extend (zero fill) register to next larger data<br>size (byte → word <i>or</i> word → double word).<br>Synthesized as MOV <i>ZR,IM</i> (word) and<br>MOVB <i>Rd,Rd</i> (byte).      |
| FMOV<br>Rs,*Rd<br>*Rs,Rd                                                                                                      | F2<br>F3                         | 5<br>5                      | * * - 0            | Move far, indirect register accesses 128K bytes: $(Rs) \rightarrow ((Rd))$<br>$((Rs)) \rightarrow (Rd)$                                                                             |
| IDLE                                                                                                                          | FE                               | 2                           |                    | Idle CPU (reaches idle state in 2 cycles).                                                                                                                                          |
| ILLEGAL                                                                                                                       | 00                               | 7                           |                    | Generate trap #0 exception. (ST) and<br>(PC) of next instruction $\rightarrow$ stack;<br>ones $\rightarrow$ (L2–L0[[ST]])                                                           |
| INC, INCB ¶<br>Rd<br>*disp16[Rd]<br>variant:<br>&address                                                                      | 83 82<br>85 84<br>85 84          | 1<br>5<br>5                 | ****               | Increment destination<br>(d) + 1 $\rightarrow$ (d)<br>Synthesized as ADQ #1,destination                                                                                             |
| INTPU $Rs, IM: Rd$<br>if $IM \leq Rd$<br>if $IM > Rd$                                                                         | 7D                               | 9<br>10                     | **00               | Perform a rounded straight-line interpola-<br>tion between values in IM and Rd using<br>interpolation fraction in Rs.                                                               |
| JMP<br>Rd<br>addr<br>*disp 16[Rd]<br>variant:<br>*Rd<br>&address                                                              | E8<br>E9<br>EA<br>EA<br>EA       | 3<br>3<br>4<br>4<br>4       |                    | Jump to destination:<br>(d) → (PC).<br>JMP *Rd is assembled as JMP *0[Rd].<br>JMP &address is assembled as<br>JMP *address[RZ]. (Both expect a word<br>address as the destination.) |
| LDBIT, LDBITB<br>#imm4, Rd<br>#imm4, *disp16[Rd]<br>Rs, Rd<br>Rs, *disp16[Rd]<br>variants:<br>#imm4, &address<br>Rs, &address | 94<br>95<br>E4<br>E5<br>95<br>E5 | 2<br>4<br>3<br>5<br>4<br>5  | *-                 | Read bit number <i>s</i> in <i>d</i> :<br>(Bit in <i>d</i> ) → (C[[ST]]).                                                                                                           |
| LDEA<br>*disp16[Rs],Rd<br>variant:                                                                                            | F0                               | 2                           |                    | Load effective address:<br>((disp1 + (Rs)) → (Rd).                                                                                                                                  |
| &address,Rd                                                                                                                   | F0                               | 2                           |                    |                                                                                                                                                                                     |

Legend: † Data Size: B = affects byte W = affects word ‡ Status Register Values:

0 = status bit always cleared

- = status bit unchanged by execution

**¶** Synthetic instruction

L = affects long word

1 = status bit always set

\* = other effect on status bit (see instruction description)

5-8

| Mnemonic                                                                                                                             | Opcode <sup>†</sup><br>B W L | Cycles<br>(t <sub>c</sub> ) | Status <sup>‡</sup><br>Z N C V | Operation Description                                                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-----------------------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LIMHS, LIMHSB<br>*disp 16[Rs],Rd<br>If V[[ST]] = 1<br>If V[[ST]] = 0<br>variants:<br>&address,Rd<br>If V[[ST]] = 1<br>If V[[ST]] = 0 | 59 58<br>59 58               | 5<br>6<br>5<br>6            | ****                           | Limit <i>Rd</i> to highest signed <i>legal</i> value (in <i>s</i> ):<br>IF (V[[ST]]) = 1 and (N[[ST]]) = 1 or<br>IF (V[[ST]]) = 0 and (s) < ( <i>Rd</i> ),<br>THEN (s) $\rightarrow$ ( <i>Rd</i> ), 0 $\rightarrow$ (V[[ST]]) and<br>1 $\rightarrow$ (C[[ST]]).                                                                               |
| LIMHU, LIMHUB<br>*disp16[Rs],Rd<br>If C[[ST]] = 1<br>If C[[ST]] = 0<br>variants:<br>&address,Rd<br>If C[[ST]] = 1<br>If C[[ST]] = 0  | 5B 5A<br>5B 5A               | 4<br>5<br>4<br>5            | **0*                           | Limit <i>Rd</i> to highest <i>un</i> signed <i>legal</i> value<br>(in <i>s</i> ):<br>IF (C[[ST]]) = 1 or<br>IF ( <i>s</i> ) < ( <i>Rd</i> ),<br>THEN ( <i>s</i> ) $\rightarrow$ ( <i>Rd</i> ) and 1 $\rightarrow$ (V[[ST]])<br>ENDIF<br>0 $\rightarrow$ (C[[ST]])<br>IF an LIMHUB instruction (byte),<br>THEN 0 $\rightarrow$ <i>Rd</i> 8–15. |
| LIMLS, LIMLSB<br>*disp 16[Rs],Rd<br>If V[[ST]] = 1<br>If V[[ST]] = 0<br>variants:<br>&address,Rd<br>If V[[ST]] = 1<br>If V[[ST]] = 0 | 5D 5C<br>5D 5C               | 5<br>6<br>5<br>6            | ****                           | Limit <i>Rd</i> to lowest signed value:<br>IF (V[[ST]]) = 1 and (N[[ST]]) = 0, or<br>IF (V[[ST]]) = 0 and(s) > ( <i>Rd</i> ),<br>THEN $(s) \rightarrow (Rd), 0 \rightarrow (V[[ST]])$ and<br>$1 \rightarrow (C[[ST]]).$                                                                                                                       |
| LIMLU, LIMLUB<br>*disp 16[Rs],Rd<br>If C[[ST]] = 1<br>If C[[ST]] = 0<br>variants:<br>&address,Rd<br>If C[[ST]] = 1<br>If C[[ST]] = 0 | 5F 5E<br>5F 5E               | 5<br>6<br>5<br>6            | ****                           | Limit <i>Rd</i> to lowest unsigned value:<br>IF (C[[ST]]) = 1 <i>or</i> (source) > (Rd),<br>THEN $(s) \rightarrow (Rd)$ and $1 \rightarrow (V[[ST]])$<br>ENDIF<br>$0 \rightarrow (C[[ST]])$ .                                                                                                                                                 |
| LINK<br>disp8                                                                                                                        | F7                           | 4                           |                                | Link frame pointer to stack pointer:<br>(FP) $\rightarrow$ ((SP))<br>(SP) $\rightarrow$ (FP)<br>(SP) + 2 $\rightarrow$ (SP)<br>(SP) + 2 x disp8 $\rightarrow$ (SP)                                                                                                                                                                            |

Legend: † Data Size: B = affects byte W = affects word ‡ Status Register Values:

0 = status bit always cleared

- = status bit unchanged by execution

L = affects long word

1 = status bit always set

\* = other effect on status bit (see instruction description)

| Mnemonic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Opcode <sup>†</sup><br>B W L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Cycles<br>(t <sub>c</sub> )     | Status‡<br>Z N C V | Operation Description                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| LSR, LSRL<br>LSR #imm4,Rd<br>LSRL #imm4,IM:Rd<br>LSR Rs,Rd<br>LSRL Rs,IM:Rd<br>LSRL Rs,IM:Rd (where<br>Rs=xxx0h)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | BC<br>BD<br>BE<br>BF<br>BF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | n+1<br>2n<br>n+3<br>2n+2<br>3   | ** *0              | Logically right shift <i>(Rd)</i> by the count<br><i>n</i> in <i>s:</i><br><i>(Rd)</i> >> $n \rightarrow (Rd)$ |
| MOV, MOVB<br><i>Rs</i> , <i>Rd</i><br><i>Rs</i> , <i>Rd</i><br><i>Rs</i> , <i>*Rd</i><br><i>Rs</i> , <i>*Rd</i> +<br><i>Rs</i> , <i>*Rd</i><br><i>*Rs</i> , <i>Rd</i><br><i>*Rs</i> , <i>Rd</i><br><i>*Rs</i> , <i>*Rd</i> +<br><i>*Rs</i> , <i>*Rd</i> +<br><i>*Rs</i> +, <i>rRd</i><br><i>*Rs</i> +, <i>*Rd</i><br><i>*Rs</i> +, <i>*Rd</i> +<br><i>*Rs</i> +, <i>*disp16</i> [ <i>Rd</i> ]<br><i>#imm</i> , <i>*Rd16</i> +<br><i>#imm</i> , <i>*d16</i> [ <i>Rd</i> ]<br><i>*disp16</i> [ <i>Rs</i> ], <i>*Rd</i><br><i>*disp16</i> [ <i>Rs</i> ], <i>*Rd</i><br><i>*disp16</i> [ <i>Rs</i> ], <i>*Rd</i> +<br><i>*disp16</i> [ <i>Rs</i> ], <i>*disp16</i> [ <i>Rd</i> ]<br><i>*</i> - <i>Rs</i> , <i>Rd</i><br><i>variants:</i><br><i>Rs</i> .&address<br><i>*Rs</i> +,&address<br><i>*Rs</i> +,&address<br><i>*disp16</i> [ <i>Rs</i> ],&address<br><i>#imm</i> ,&address<br><i>&amp;address</i> , <i>Rd</i><br>&address, <i>Rd</i> +<br>&address, <i>*disp16</i> [ <i>Rd</i> ]<br>&address1,&address2 | 03       02         05       04         07       06         09       08         0B       0A         0D       0C         0F       0E         11       10         13       12         15       14         17       16         19       18         1B       1A         1D       1C         1F       1E         21       20         23       22         25       24         27       26         29       28         21       20         23       22         25       24         27       26         29       28         21       20         23       22         25       24         27       26         29       28         21       20         23       22         25       24         27       26         29       28         29       28         29       28 | 1223233433442334453 3445 434455 | * * - 0            | Copy the source; place copy in destination:<br>(s) $\rightarrow$ (d)                                           |
| MOVQ<br>#imm₄,Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 80                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1                               | *0-0               | $imm4 \rightarrow (Rd)$                                                                                        |

Legend: † Data Size: B = affects byte W = affects word

**‡** Status Register Values:

L = affects long word

0 = status bit always cleared

1 = status bit always set

- = status bit unchanged by execution

\* = other effect on status bit (see instruction description)

**¶** Synthetic instruction

| Mnemonic                                                                                                                     | Opcode <sup>†</sup><br>B W L             | Cycles<br>(t <sub>c</sub> )                              | Status‡<br>Z N C V | Operation Description                                                                                                                                                                      |
|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|----------------------------------------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MPYBWU<br><i>Rs,Rd</i>                                                                                                       | AC                                       | 7                                                        | **00               | Unsigned 8-bit x 16-bit multiply with rounding:<br>[( $RsLSbyte$ ) × ( $Rd$ ) + 80h] ÷ 256 → ( $Rd$ ).                                                                                     |
| $\begin{array}{l} MPYS, MPYSB \\ MPYSB  Rs, Rd \\ Rd \geq 0 \\ Rd < 0 \\ MPYS  Rs, IM:Rd \\ Rd \geq 0 \\ Rd < 0 \end{array}$ | A7<br>A6                                 | 10<br>11<br>13<br>14                                     | **00               | Multiply signed:<br>$(Rs) \times (d) \rightarrow (d).$                                                                                                                                     |
| MPYU, MPYUB<br>MPYUB <i>Rs,Rd</i><br>MPYU <i>Rs,IM:Rd</i>                                                                    | A5<br>A4                                 | 8<br>13                                                  | **00               | Multiply <i>un</i> signed:<br>(Rs) $\times$ (d) $\rightarrow$ (d).                                                                                                                         |
| NOP¶                                                                                                                         | 92                                       | 1                                                        |                    | No operation<br>0 → (ZR)<br>Synthesized as SBIT0 <i>#15,ZR</i>                                                                                                                             |
| NOT, NOTB¶<br>Rd                                                                                                             | 2D 2C                                    | 1                                                        | * * - 0            | Ones complement the destination<br>~( <i>Rd</i> )<br>Synthesized as XNOR <i>ZR,Rd</i>                                                                                                      |
| OR, ORB<br>Rs,Rd<br>Rs,*disp <sub>16</sub> [Rd]<br>#imm16,Rd<br>#imm16,*disp <sub>16</sub> [Rd]<br>variants:<br>Rs,&address  | 49 48<br>4B 4A<br>4D 4C<br>4F 4E<br>4B4A | 1<br>5<br>2<br>5<br>5                                    | **-0               | Logical inclusive OR source with dest:<br>(s)   (d) $\rightarrow$ (d).                                                                                                                     |
| #imm16,&address<br>POP<br>R Last,R First                                                                                     | 4F4E<br>FA                               | 5<br>1 + 2 <i>n</i><br>( <i>n</i> =<br>repeat<br>cycles) |                    | Pop registers from the stack:<br>FOR <i>index</i> = Register_Last<br>TO Register_First BY -1,<br>DO (SP) - 2 $\rightarrow$ (SP)<br>((SP)) $\rightarrow$ (register( <i>index</i> )).        |
| PUSH<br>Rfirst,Rlast                                                                                                         | F9                                       | 1 + n<br>(n =<br>repeat<br>cycles)                       |                    | Push register values onto the stack:<br>FOR <i>index</i> = Register_First<br>TO Register_Last BY +1,<br>DO (register( <i>index</i> )) $\rightarrow$ ((SP))<br>(SP) + 2 $\rightarrow$ (SP). |

Legend: † Data Size: B = affect ‡ Status Register Values: B = affects byte W = affects word

0 = status bit always cleared - = status bit unchanged by execution

**¶** Synthetic instruction

L = affects long word

1 = status bit always set

\* = other effect on status bit (see instruction description)

| Mnemonic                                                                                                         | Opcode <sup>†</sup><br>B W L | Cycles<br>(t <sub>c</sub> ) | Status‡<br>Z N C V | Operation Description                                                                                                                                                                   |
|------------------------------------------------------------------------------------------------------------------|------------------------------|-----------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RTDU<br>disp <sub>8</sub>                                                                                        | F8                           | 5                           |                    | Return from subroutine, unlink stack:<br>(FP) - 2 $\rightarrow$ (SP)<br>((FP)) $\rightarrow$ (FP)<br>((SP)) $\rightarrow$ (PC)<br>((SP) - 2 $\times$ disp $\beta$ ) $\rightarrow$ (SP). |
| RTI                                                                                                              | FC                           | 6                           | ****               | Return from interrupt:<br>$(SP) - 2 \rightarrow (SP)$<br>$((SP)) \rightarrow (PC)$<br>$(PC) - 2 \rightarrow (PC)$<br>$(SP) - 2 \rightarrow (SP)$<br>$((SP)) \rightarrow (ST).$          |
| RTS                                                                                                              | FB                           | 4                           |                    | Return from subroutine:<br>(SP) $-2 \rightarrow$ (SP)<br>((SP)) $\rightarrow$ (PC).                                                                                                     |
| SBB<br>Rs,Rd<br>*disp16[Rs],Rd<br>variant:                                                                       | 8C<br>8D                     | 1<br>3                      | * * * *            | Destination minus source and carry:<br>$(d) - (s) - (C[ST]) \rightarrow (d).$<br>Subtract <i>s</i> and carry bit from <i>d</i> .                                                        |
| &address,Rd                                                                                                      | 8D                           | 3                           |                    | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                   |
| SBIT0, SBIT0B<br>SBIT0 #imm4,Rd<br>SBIT0B #imm4,*disp16[Rd]<br>SBIT0 Rs,Rd<br>SBIT0B Rs,*disp16[Rd]<br>variants: | 92<br>93<br>E2<br>E3         | 1<br>5<br>2<br>6            |                    | Set bit to 0:<br>0 → bit in <i>d</i> .<br>(Value in s designates bit to clear.)                                                                                                         |
| SBIT0B #imm4,&address<br>SBIT0B Rs,&address                                                                      | 93<br>E3                     | 5<br>6                      |                    |                                                                                                                                                                                         |
| SBIT1, SBIT1B<br>SBIT1 #imm4,Rd<br>SBIT1B #imm4 *disp16[Rd]<br>SBIT1 Rs,Rd<br>SBIT1B Rs,*disp16[Rd]              | 90<br>91<br>E0<br>E1         | 1<br>5<br>2<br>6            |                    | Set bit to 1:<br>1 → bit in <i>d.</i><br>(Value in s designates bit to set.)                                                                                                            |
| variants:<br>SBIT1B #imm4,&address<br>SBIT1B Rs,&address                                                         | 91<br>E1                     | 5<br>6                      |                    |                                                                                                                                                                                         |
| SHL, SHLL<br>SHL <i>#imm4,Rd</i><br>SHLL <i>#imm4,IM:Rd</i><br>SHL <i>Rs,Rd</i><br>SHLL <i>Rs,IM:Rd</i>          | B0<br>B1<br>B2<br>B3         | n+2<br>2n+2<br>n+3<br>2n+3  | ****               | Shift left register arithmetic:<br>(d) $<< n \rightarrow$ (d).<br>(arithmetic left shift — source contains<br>shift count <i>n</i> ).                                                   |

Legend: † Data Size:

B = affects byte W = affects word

L = affects long word

Status Register Values:
 0 = status bit always cleared

- = status bit unchanged by execution

1 = status bit always set

\* = other effect on status bit (see instruction description)

| Mnemonic                                                                                                                                                        | Opcode <sup>†</sup><br>B W L                       | Cycles<br>(t <sub>c</sub> ) | Status‡<br>Z N C V | Operation Description                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SHL4<br>Rs,Rd                                                                                                                                                   | 7A                                                 | 2                           | **                 | Shift left logical 4 bits:<br>$Rs << 4 \rightarrow Rd.$                                                                                                          |
| SHL8<br>Rs,Rd                                                                                                                                                   | 7B                                                 | 2                           | **                 | Shift left logical 8 bits:<br>$Rs << 8 \rightarrow Rd.$                                                                                                          |
| SHR8<br>Rs,Rd                                                                                                                                                   | 7C                                                 | 2                           | *0                 | Shift right 8 bits:<br>Rs >> 8 $\rightarrow$ Rd.                                                                                                                 |
| STBIT, STBITB<br>STBIT #imm4,Rd<br>STBITB #imm4,*disp16[Rd]<br>STBIT Rs,Rd<br>STBITB Rs,*disp16[Rd]<br>variants:<br>STBITB #imm4,&address<br>STBITB Rs,&address | 96<br>97<br>E6<br>E7<br>97<br>E7                   | 2<br>6<br>3<br>7<br>6<br>7  | *                  | Store bit in ST, set to carry value:<br>$\sim$ (bit in $d$ ) $\rightarrow$ (Z[[ST]])<br>(C[[ST]]) $\rightarrow$ (bit in $d$ ).<br>(s designates which bit in d.) |
| STEA<br>*disp <sub>16</sub> [Rs],*Rd+<br>variant:<br>&address,*Rd+                                                                                              | F1<br>F1                                           | 3<br>3                      |                    | Store effective address:<br>$disp16 + (Rs) \rightarrow (Rd)$<br>$(Rd) + 2 \rightarrow (Rd)$ .                                                                    |
| STRI<br>#imm4,Rd                                                                                                                                                | A9                                                 | 2                           | 0000               | Store ST, set interrupt level:<br>(ST) $\rightarrow$ ( <i>Rd</i> ).<br><i>imm4</i> $\rightarrow$ bits L2–L0 of ST<br>Os $\rightarrow$ bits Z, N, C, V of ST      |
| SUB, SUBB<br>Rs,Rd<br>Rs,*disp16[Rd]<br>#imm16,Rd<br>*disp16[Rs],Rd<br>variants<br>Rs,&address<br>&address,Rd                                                   | 39 38<br>3B 3A<br>3D 3C<br>3F 3E<br>3B 3A<br>3F 3E | 1<br>5<br>2<br>3<br>5<br>3  | * * * *            | Subtract source from destination:<br>$(d) - (s) \rightarrow (d)$ .                                                                                               |
| SUBQ, SUBQB<br>#imm4,Rd<br>#imm4,*disp16[Rd]<br>variant<br>#imm4,&address                                                                                       | 87 86<br>89 88<br>89 88                            | 1<br>5                      | ****               | Subtract quick immediate value from dest:<br>(d) $-imm4 \rightarrow (d)$ .                                                                                       |
| SUBR, SUBRB<br><i>RA,RB</i>                                                                                                                                     | 2F 2E                                              | 1                           | ****               | Subtract with reverse destination:<br>$(RB) - (RA) \rightarrow (RA).$                                                                                            |
| SWAPB<br>Rs,Rd                                                                                                                                                  | FD                                                 | 3                           | * * - 0            | Swap bytes, Rs to Rd:<br>Rs (LSbyte) → Rd (MSbyte)<br>Rs (MSbyte) → Rd (LSbyte)                                                                                  |

Legend: † Data Size: B = affects byte W = affects word ‡ Status Register Values: 0 = status bit always cleared - = status bit unchanged by execution

L = affects long word

1 = status bit always set \* = other effect on status bit (see instruction description)

| Mnemonic                                                                                                                                               | Opcode <sup>†</sup><br>B W L | Cycles<br>(t <sub>c</sub> ) | Status‡<br>Z N C V | Operation Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-----------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TBIT0<br>#imm8,&addr                                                                                                                                   | F4                           | 3                           | *                  | Test for multiple bits clear:<br>IF $imm 8 \neq 0$ and $imm 8 \& addr = 0$ ,<br>THEN 1 $\rightarrow$ (Z[[ST]])<br>ELSE 0 $\rightarrow$ (Z[[ST]])<br>(test for bit(s) cleared in d;<br>s = mask specifying bits to check.)                                                                                                                                                                                                                  |
| TBIT1<br>#imm8,&addr                                                                                                                                   | F5                           | 3                           | *                  | Test for multiple bits set:<br>IF $imm8 \neq 0$ and $imm16$ & (~addr) = 0<br>THEN 1 $\rightarrow$ (Z[[ST]])<br>ELSE 0 $\rightarrow$ (Z[[ST]])<br>(test for bit(s) set in d;<br>s = mask specifying bits to check.)                                                                                                                                                                                                                         |
| TBLU, TBLUB<br>TBLUB $Rs, IM, :Rd$<br>Value $1 \le Value 2$<br>Value $1 > Value 2$<br>TBLU $Rs, IM:Rd$<br>Value $1 \le Value 2$<br>Value $1 > Value 2$ | 7F<br>7E                     | 14<br>15<br>15<br>16        | **00               | Look up two consecutive values in a table of<br>unsigned data; perform a rounded<br>straight-line interpolation between the two<br>values according to an interpolation fraction.                                                                                                                                                                                                                                                          |
| TRAP<br>imm8                                                                                                                                           | FF                           | 7                           |                    | $(ST) \rightarrow ((SP))$<br>$(SP) + 2 \rightarrow (SP)$<br>Next inst. addr $\rightarrow ((SP))$<br>$(SP) + 2 \rightarrow (SP)$<br>$2 \times -enumerator8 + trap_base_addr \rightarrow (PC)$<br>1112 $\rightarrow (ST bits L2-L0)$ .<br><i>imm8</i> value = trap number; ones-complement<br>of trap number becomes <i>enumerator8</i> which<br>resides in LSbyte of opcode.<br><i>trap_base_addr</i> = base address of interrupt<br>traps. |
| TRUNCS, TRUNCSL<br>TRUNCS <i>Rd</i><br><i>bits 15–7 equal</i><br><i>bits 15–7 not equal</i><br>TRUNCSL <i>IM:Rd</i>                                    | AE<br>AF                     | 3<br>4<br>4                 | **0*               | Test whether signed data can be truncated (represented in next smaller size — word or byte). If not possible, $1 \rightarrow (V[ST])$ .                                                                                                                                                                                                                                                                                                    |
| TRUNCU<br>Rd                                                                                                                                           | AD                           | 2                           | ***0               | Test whether an unsigned <i>word</i> can be trun-<br>cated and represented as a <i>byte</i> value.<br>If not possible, $1 \rightarrow (C[ST])$ .                                                                                                                                                                                                                                                                                           |

Legend: † Data Size: B = affects byte W = affects word ‡ Status Register Values:

L = affects long word

0 = status bit always cleared - = status bit unchanged by execution

1 = status bit always set \* = other effect on status bit (see instruction description)

| Mnemonic                                                                                                               | Opcode <sup>†</sup><br>B W L                                | Cycles<br>(t <sub>c</sub> )          | Status‡<br>Z N C V | Operation Description                                                                                  |
|------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|--------------------------------------|--------------------|--------------------------------------------------------------------------------------------------------|
| TST, TSTB <sup>¶</sup><br>Rs<br>*Rs<br>*Rs+<br>#imm16<br>*disp16[Rs]<br>*–Rs<br>variant:<br>&address                   | 03 02<br>0B 0A<br>13 12<br>1B 1A<br>23 22<br>2B 2A<br>23 22 | 1<br>2<br>3<br>2<br>3<br>3<br>3<br>3 | **-0               | Test source:<br>(s) → (ZR)<br>set Z[[ST]] and N[[ST]] accordingly.<br>Synthesized as MOV <i>s,ZR</i> . |
| UNLINK                                                                                                                 | F6                                                          | 3                                    |                    | Unlink and deallocate stack frame:<br>(FP) $\rightarrow$ (SP)<br>((SP)) $\rightarrow$ (FP).            |
| XNOR, XNORB<br>Rs,Rd                                                                                                   | 2D 2C                                                       | 1                                    | **-0               | Exclusive NOR source with destination: $\sim (s \land d) \rightarrow (Rd)$ .                           |
| XOR, XORB<br>Rs,Rd<br>Rs,*disp16[Rd]<br>#imm16,Rd<br>#imm16,*disp16[Rd]<br>variants:<br>Rs,&address<br>#imm16,&address | 51 50<br>53 52<br>55 54<br>57 56<br>53 52<br>57 56          | 1<br>5<br>2<br>5<br>5<br>5           | **-0               | Exclusive OR source with destination:<br>(s) $(d) \rightarrow (d)$ .                                   |

Legend: † Data Size:

B = affects byte W = affects word

‡ Status Register Values:

0 = status bit always cleared

- = status bit unchanged by execution

**¶** Synthetic instruction

L = affects long word

1 = status bit always set

\* = other effect on status bit (see instruction description)

# 5.3 Instruction Descriptions in Alphabetical Order

This section contains detailed descriptions of each TMS370C16 instruction, Including bus and signal-line content during each cycle. Variants on an instruction are not covered in this section, but are noted throughout the table in Section 5.2 (starting on page 5-4) and explained in the paragraph on page 5-4.





### Note: Assembler Statements Are Not Case Sensitive

TMS370C16 assembly language statements are not case sensitive. You can enter them in lowercase, uppercase, or a combination. To emphasize this, assembly language statements are shown throughout this user's guide in both uppercase and lowercase.

| Syntax          | ADC                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution       | (source16) + (destination16) + carry bit $\rightarrow$ (destination16)                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| Modes Supported | Rs,Rd<br>*disp16[Rs],Rd                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| Status Bits     | <ul> <li>Cleared if the result is nonzero; unchanged otherwise</li> <li>equals bit 15 of the result</li> <li>set if an unsigned overflow occurred; cleared otherwise</li> <li>set if a twos-complement overflow occurred, cleared otherwise</li> </ul>                                                                                              |  |  |  |  |  |
| Description     | Add the contents of the source operand and the value of the carry bit of the status register to the destination-register contents (sum remains in the destination register). Source and destination are 16-bit words.                                                                                                                               |  |  |  |  |  |
|                 | The operation facilitates 32-bit addition. Use an ADD instruction to add the least significant words; then follow with an ADC instruction, adding the most significant words as well as the carry-bit value (the $C[ST] = 1$ if the just-executed ADD instruction included a carry). Thus, the ADD and ADC instructions <b>must be sequential</b> . |  |  |  |  |  |
|                 | The Z[[ST]] bit correctly reflects the result of 32-bit addition. The bit is set <i>only if</i> the previous operation (like the ADD instruction) set it. Thus, all status bits reflect a 32-bit result <i>after</i> an ADD/ADC sequence.                                                                                                           |  |  |  |  |  |
| Examples        | LABEL ADC zr,rll ; Add contents of ZR, Rll,<br>; and carry bit. Store sum<br>; in Rll. Effectively a<br>; continuous increment of<br>; Rll depending on carry<br>; bit contents.                                                                                                                                                                    |  |  |  |  |  |
|                 | LOAD_BUF ADC *1000h[r6],r7 ; Add contents at (R6) +<br>; 1000h plus carry-bit<br>; value to R7 contents.<br>; Result to R7.                                                                                                                                                                                                                         |  |  |  |  |  |

|    | A       | DC Rs, P | Rd   | ADC       | *disp16[R       | ls],Rd |
|----|---------|----------|------|-----------|-----------------|--------|
|    | 8A(w)   | F        | s Rd | 8B(v      | v) Rs<br>disp16 | s Rd   |
| Су | Address | Data     | wbfd | Address   | Data            | wbfd   |
| 1  | OpA + 4 | IEW      | 1000 | OpA + 4   | īW              | 1001   |
| 2  |         |          |      | disp + Rs | (disp + Rs)     | 1011   |
| 3  |         |          |      | OpA + 6   | IEW             | 1000   |

| Syntax          | ADD{B}                                                                                                                                                                                                                                                                                                                                                                                                    |        |                       |                                                                                                                |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------|----------------------------------------------------------------------------------------------------------------|--|--|
| Execution       | (source) + (d                                                                                                                                                                                                                                                                                                                                                                                             | estina | tion) → (destinatior  | )                                                                                                              |  |  |
| Modes Supported | Rs,Rd<br>*disp16[Rs],Rd<br>Rs,*disp16[Rd]<br>#imm16,Rd                                                                                                                                                                                                                                                                                                                                                    |        |                       |                                                                                                                |  |  |
| Status Bits     | <ul> <li>Z set if the result is zero, cleared otherwise</li> <li>N equals bit 7 of the result (byte) or bit 15 of the result (word operation)</li> <li>C set if an unsigned overflow occurred; cleared otherwise</li> <li>V set if a twos-complement overflow occurred, cleared otherwise</li> </ul>                                                                                                      |        |                       |                                                                                                                |  |  |
| Description     | Add the cont                                                                                                                                                                                                                                                                                                                                                                                              | ents o | f the source to the o | contents of the destination.                                                                                   |  |  |
|                 | <ul> <li>For byte operations, sign extend the byte operands to word length, t ate on the word to produce a word result. The most significant byte of becomes either 00h for C[[ST]] = 0, or 01h for C[[ST]] = 1. Registers reentire word; nonregister destinations receive the least significant b result.</li> <li>Status bits are set with respect to the size (byte/word) of the requested.</li> </ul> |        |                       |                                                                                                                |  |  |
| Examples        | LABEL                                                                                                                                                                                                                                                                                                                                                                                                     | ADD    | R5,R10                | ; Add the contents of R5 &<br>; R10; store sum in R10.<br>:                                                    |  |  |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                           | ADD    | *201h[ZR],R12         | ; Add contents of location<br>; 201h and ZR to contents<br>; of R12, store sum in R12.                         |  |  |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                           | ADDB   | *10[r8],r9            | <pre>; Add byte contents at 10 + ; (R8) to R9.Sum goes to ; LSbyte of R9 with MSbyte ; of R9 zeroed out.</pre> |  |  |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                           | ADD    | #BUFFER,r11           | ;<br>; Add immediate value of<br>; BUFFER and R11. Store<br>; results in R11.                                  |  |  |

|    | ADI                  | D{B} Rs | ,Rd  | ADD{E              | 3} #imm | n16,Rd |  |  |
|----|----------------------|---------|------|--------------------|---------|--------|--|--|
|    | 30(w) 3 <sup>-</sup> | I(b) Fi | s Rd | 34(w) 35(b) /// Rd |         |        |  |  |
|    |                      |         |      |                    | imm16   |        |  |  |
| Су | Address              | Data    | wbfd | Address            | Data    | wbfd   |  |  |
| 1  | OpA + 4              | IEW     | 1000 | OpA + 4            | IW      | 1001   |  |  |
| 5  |                      |         |      | Opa+6              | IEW     | 1000   |  |  |

|    | ADD{B     | *disp16[    | Rs],Rd | ADD{B     | Rs,*disp       | 16[Rd] |
|----|-----------|-------------|--------|-----------|----------------|--------|
|    | 36(w) 3   | 7(b) Rs     | Rd     | 32(w) 3   | 3(b) <i>Rs</i> | Rd     |
|    |           | disp16      |        |           | disp16         |        |
| Су | Address   | Data        | wbfd   | Address   | Data           | wbfd   |
| 1  | OpA + 4   | IW          | 1001   | OpA + 4   | IW             | 1001   |
| 2  | disp + Rs | (disp + Rs) | 1511   | disp + Rd | (disp + Rd)    | 1511   |
| 3  | OpA + 6   | IEW         | 1000   | prevA     | (prevA)        | 1011   |
| 4  |           |             |        | disp + Rd | result         | 0511   |
| 5  |           |             |        | OpA+6     | IEW            | 1000   |

## Note: The wbfd Column Values

Values for the wbfd column are listed in Figure 5-1 on page 5-16.

| Syntax          | ADQ{B}                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution       | immediate data + (destination) $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| Modes Supported | #imm4,Rd<br>#imm4,*disp16[Rd]                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| Status Bits     | <ul> <li>Set if the result is zero, cleared otherwise</li> <li>equals MSB in result: bit 7 (byte operation) or bit 15 (word operation)</li> <li>set if an unsigned overflow occurred; cleared otherwise</li> <li>set if a twos-complement overflow occurred; cleared otherwise</li> </ul>                                                                     |  |  |  |  |  |
| Description     | Add quick immediate data to the contents of the destination operand. ( <i>Quick immediate</i> data is a 4-bit value contained in the instruction word). The value of $0-15$ is zero-extended to a word for addition. ADQ, with its 4-bit immediate operand, operates in only one cycle; whereas, ADD, with a 16-bit immediate operand, uses two cycles.)      |  |  |  |  |  |
|                 | For <b>byte operations</b> , the byte operands are extended to word length, then operated on as words to produce a word result. The most significant byte of the result will be either 00h when $C[[ST]] = 0$ or 01h when $C[[ST]] = 1$ . Registers receive the entire word, while nonregister destinations receive the least significant byte of the result. |  |  |  |  |  |
|                 | Status bits are set with respect to the size (byte/word) of the operation requested.                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| Examples        | LABEL ADQ #BITS,R4 ; Add value 'BITS' to R4.<br>; Store sum in R4.                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|                 | ADD_4 ADQ #4,&BUFFER ; Add immediate value 4<br>; to 'BUFFER'.                                                                                                                                                                                                                                                                                                |  |  |  |  |  |

|    | ADQ{     | B} #imr        | n4,Rd | ADQ{B}    | #imm4,*di        | sp16[Rd] |
|----|----------|----------------|-------|-----------|------------------|----------|
|    | 82(w) 83 | 3(b) <i>im</i> | m Rd  | 84(w) 8   | 35(b) <i>imn</i> | n Rd     |
|    |          |                |       |           | disp16           |          |
| Су | Address  | Data           | wbfd  | Address   | Data             | wbfd     |
| 1  | OpA + 4  | IEW            | 1000  | prevA     | (prevA)          | 1011     |
| 2  |          |                |       | disp + Rd | (disp + Rd)      | 1 \$ 1 1 |
| 3  |          |                |       | OpA + 4   | IW               | 1001     |
| 4  |          |                |       | disp + Rd | result           | 0511     |
| 5  | 1. A. A. |                |       | OpA+6     | IEW              | 1000     |

| Syntax          | AND{B}                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution       | (source) & with (destination) $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| Modes Supported | Rs,Rd<br>Rs,*disp16[Rd]<br>#imm16,Rd<br>#imm16,*disp16[Rd]                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| Status Bits     | <ul> <li>Z set if the result is zero, cleared otherwise</li> <li>N equals bit in result: bit 7 (byte operation) or bit 15 (word operation)</li> <li>C unchanged</li> <li>V cleared</li> </ul>                                                                                                                                                                                          |  |  |  |  |  |
| Description     | Logically AND the contents of the source with the contents of the destination.<br>For <b>byte operations</b> , byte operands are zero-extended to words, operated on words, and produce a word result. The most significant byte of the result will always be 00h. Registers receive the entire word; while nonregister destinations receive the least significant byte of the result. |  |  |  |  |  |
|                 | Status bits are set according to size (byte/word) of the operation.                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| Examples        | LABEL AND R5,R10 ; AND the contents of R5<br>; and R10. Store result<br>; in R10.                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|                 | ready andb #clear8,r6 ; AND byte value of CLEAR<br>; with R6. Store LSbyte of<br>; result in R6, and clear<br>; MSbyte of R6.                                                                                                                                                                                                                                                          |  |  |  |  |  |
|                 | AND #55AAh,R7 ; ADD value of 55AAh with<br>; contents of R7. Store<br>; result in R7.                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |

|    | AND      | 0{B} <i>Rs</i> | ,Rd   | AND{B     | } Rs,*disp        | 16[Rd] |
|----|----------|----------------|-------|-----------|-------------------|--------|
|    | 40(w) 41 | I(b) 🛛 🛛       | ls Rd | 42(w) 4   | 3(b) Rs<br>disp16 | Rd     |
| Су | Address  | Data           | wbfd  | Address   | Data              | wbfd   |
| 1  | OpA + 4  | IEW            | 1000  | OpA + 4   | IW                | 1001   |
| 2  |          |                |       | disp + Rd | (disp + Rd)       | 1S11   |
| 3  |          |                |       | prevA     | (prevA)           | 1011   |
| 4  |          |                |       | disp + Rd | result            | 0511   |
| 5  |          |                |       | OpA + 6   | IEW               | 1000   |

|    | AND{     | B} #imm | 16,Rd | AND{B} #imm16,*disp16[Rd] |             |      |  |  |
|----|----------|---------|-------|---------------------------|-------------|------|--|--|
|    | 44(w) 48 | 5(b)    | // Rd | 46(w) 4                   | 7(b)        | Rd   |  |  |
|    |          | imm16   |       |                           | disp16      |      |  |  |
|    |          | ,       |       |                           | imm16       |      |  |  |
| Су | Address  | Data    | wbfd  | Address                   | Data        | wbfd |  |  |
| 1  | OpA + 4  | IW      | 1000  | OpA + 4                   | data        | 1001 |  |  |
| 2  | OpA + 6  | IEW     | 1000  | disp + Rd                 | (disp + Rd) | 1511 |  |  |
| 3  |          |         |       | OpA+6                     | IW          | 1001 |  |  |
| 4  |          |         |       | disp + Rd                 | result      | 0511 |  |  |
| 5  |          |         |       | OpA + 8                   | IEW         | 1000 |  |  |

| Syntax          | ASR{L}                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution       | right-shift (destination) by source count $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| Modes Supported | #imm4,Rd (word)<br>#imm4,IM:Rd (longword)<br>Rs,Rd (word)<br>Rs,IM:Rd (longword)                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| Status Bits     | <ul> <li>Z set if the result is zero, cleared otherwise</li> <li>N equals MSB in result: bit 15 of Rd (word operation) or bit 15 of IM (longword operation)</li> <li>C equals the last bit shifted out of the register; cleared if the shift count in <i>Rs</i> is zero</li> <li>V cleared</li> </ul>                                                                                                                                                            |  |  |  |  |  |
| Description     | Arithmetically right shift the destination register's contents by the number of bit positions $(0-15)$ specified in the source operand. Leave unchanged the preshift value of the most significant bit constant. If the shift count is in a register, the count range $(0-15)$ is defined by the 4 LSBs of the source register ( <i>Rs</i> bits $15 - 4$ are ignored).<br>The following illustrates a right shift of the most significant bit into the register: |  |  |  |  |  |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |



<sup>†</sup> The value of the last bit shifted out goes to the carry bit; this bit is cleared if the shift count in Rs is zero.

Status bits are set with respect to the size of the word shifted (16 or 32 bits). Longword shifts always use register IM as the most significant word of the 32-bit object. The result of ASR (source),IM:IM is undefined.



Note that if the shift count was changed to 15, R3 would be all ones.

| Label | ASR  | #3,r3 | ; Shift R3 three bits right                                            |
|-------|------|-------|------------------------------------------------------------------------|
| shift | asrl | ·     | ;<br>; Shift the long word in<br>; registers IM:R9 right<br>; two bits |

### **Instruction Execution Detail**

|                   | AS      | R #imm  | 4,Rd  |                   | A           | SR Rs                        | Rd         |
|-------------------|---------|---------|-------|-------------------|-------------|------------------------------|------------|
|                   | B4 (v   | v) imi  | m4 Rd |                   | B6 (        | w)   I                       | Rs Rd      |
| Cycle/<br>Period† | Address | Data    | wbfd  | Cycle/<br>Period† | Address     | Data                         | ₩ b f d    |
| n<br>(repeat)     | prevA   | (prevA) | 1011  | 1, 2              | prevA       | (prevA)                      | 1011       |
| n+1               | OpA+4   | IEW     | 1000  | n<br>(repeat)     | prevA       | (prevA)                      | 1011       |
|                   |         |         |       | n+1               | OpA+4<br>To | IEW<br>otal cycles: <i>n</i> | 1000<br>+3 |

|                   | ASRL    | . <i>#imm</i> 4, | IM:Rd | ]                 | AS      | rl <i>Rs,II</i>                               | M:Rd  |
|-------------------|---------|------------------|-------|-------------------|---------|-----------------------------------------------|-------|
|                   | B5 (    | L) im            | m4 Rd | ]                 | B7 (    | L) F                                          | Rs Rd |
| Cycle/<br>Period† | Address | Data             | wbfd  | Cycle/<br>Period† | Address | Data                                          | wbfd  |
| 1                 | prevA   | (prevA)          | 1011  | 1, 2, 3           | prevA   | (prevA)                                       | 1011  |
| 2n-2<br>(repeat)  | prevA   | (prevA)          | 1011  | 2n-2<br>(repeat)  | prevA   | (prevA)                                       | 1011  |
| <b>2</b> n        | OpA+4   | IEW              | 1000  | 2n                | OpA+4   | IEW                                           | 1000  |
|                   |         |                  |       |                   | Tota    | l cycles: 2 <i>n</i> -<br>3 if <i>Rs</i> = 0h |       |

<sup>†</sup> A single number represents a *given cycle*. An expression of *n* represents the cycle count *after the previous cycles*, depending on the *n* th number of shifts or repeats. Bus and signal values shown are present during these intervals.

| Syntax          | ASR0{L}                                                                                                                                                          | (Fourth character is a numerical 0.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Execution       | •                                                                                                                                                                | tion) by source count $\rightarrow$ (destination)<br>(C[ST]] = 1, THEN (destination) + 1 $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| Modes Supported | Rs,Rd<br>Rs,IM:Rd<br>#imm4,Rd<br>#imm4,IM:Rd                                                                                                                     | (word)<br>(longword)<br>(word)<br>(longword)                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| Status Bits     | N equals the n<br>C ASR0: c<br>ASR0L: s                                                                                                                          | sult is zero, cleared otherwise<br>nost significant bit of the result<br>leared<br>et if an FFFF FFFFh result is rounded (incremented) to<br>000 0000h; cleared otherwise                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| Description     | number of bit posi<br>significant bit of the<br>a number of times<br>from the 4 LSBs of<br>If, after shifting, the<br>the result (destinal<br>signed division by | arithmetic) destination register's contents to the right by the tions in the source operand while holding constant the most e destination. Thus, the MSB is extended into the destination equal to the source value. The shift count of $1-15$ is derived of the source contents ( <i>Rs</i> bits $15 - 4$ are ignored). The result is negative <i>and</i> a 1 was shifted out of the register, tion) is incremented. This performs a mathematically correct of a power of 2 (exponent of $2 = $ number of bits shifted). |  |  |  |
|                 | destination register:                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |



The shift count is contained in the source (4 LSBs of Rs or bits 7–4 of the instruction when *#imm4* is specified). A shift value of 0001<sub>2</sub> to 1111<sub>2</sub> corresponds to a shift of 1 to 15; a shift value of 0000<sub>2</sub> indicates 16.

Status bits are set with respect to the size (word/longword) of the operation. Longword shifts always use the IM as the implied most significant word of the 32-bit result. The result of ASR0L (source),IM:IM is undefined.

#### ASR0L #4,IM:R2 ; right shift R1/R2 4 bits IM(R1) 1000 0000 0000 001 1 ZNCV Before **R2** 0000 0 0 0 0 0 0 0 0 0 0 1 0 100 ST= 0 4 bits to be shifted out h IM (R1) 0000000 00 1 1 1 0 After ZNCV R2 0100 0000 0010 10002 ST= 0 n 0 0 n n Last bit to exit (1)-

### **Instruction Execution Detail**

Example

|                      | ASR           | 0 <i>#imm</i> | 4,Rd  |                   | ASR0 Rs Rd |              |      |  |
|----------------------|---------------|---------------|-------|-------------------|------------|--------------|------|--|
|                      | <b>B8 (</b> w | () imi        | n4 Rd |                   | BA (       | N)   F       | s Rd |  |
| Cycle/<br>Period †   | Address       | Data          | wbfd  | Cycle/<br>Period† | Address    | Data         | wbfd |  |
| 1                    | prevA         | (prevA)       | 1011  | 1, 2              | prevA      | (prevA)      | 1011 |  |
| <i>n</i><br>(repeat) | prevA         | (prevA)       | 1011  | 3                 | prevA      | (prevA)      | 1011 |  |
| n+2                  | OpA + 4       | IEW           | 1000  | n<br>(repeat)     | prevA      | (prevA)      | 1011 |  |
|                      |               |               |       | n+2               | OpA+4      | IEW          | 1000 |  |
|                      |               |               |       |                   | Tot        | al cycles: n | + 4  |  |

|                            | #in                                                   | ASR0L<br>hm4,IM: |      |         |         |         |                           |                         | 0L <i>Rs,I</i> |                 | ]             |              |                 |
|----------------------------|-------------------------------------------------------|------------------|------|---------|---------|---------|---------------------------|-------------------------|----------------|-----------------|---------------|--------------|-----------------|
| Cycle/                     | B9 (L)   Imm4   Rd<br>If N[[ST]] = 0   If N[[ST]] = 1 |                  |      |         |         | Cycle/. | BB (                      | L)   F<br>f N[[ST]] = ( |                | ອ<br>           | N[[ST]] = 1   | I            |                 |
| Cycle/<br>Period †         | Address                                               | Data             | wbfd | Address | Data    | wbfd    | Period †                  | Address                 | Data           | wbfd            | Address       | Data         | wbfd            |
| 1                          | prevA                                                 | (prevA)          | 1011 | prevA   | (prevA) | 1011    | 1, 2                      | prevA                   | (prevA)        | 1011            | prevA         | (prevA)      | 1011            |
| 2 <i>n</i> – 1<br>(repeat) | prevA                                                 | (prevA)          | 1011 | prevA   | (prevA) | 1011    | 3                         | prevA                   | (prevA)        | 1011            | prevA         | (prevA)      | 1011            |
| 2 <i>n</i> + 1             | OpA+4                                                 | IEW              | 1000 | prevA   | (prevA) | 1011    | 2 <i>n</i> −1<br>(repeat) | prevA                   | (prevA)        | 1011            | prevA         | (prevA)      | 1011            |
| 2n + 2                     |                                                       |                  |      | OpA+4   | IEW     | 1000    | 2n+1                      | OpA+4                   | IEW            | 1000            | prevA         | (prevA)      | 1011            |
|                            |                                                       |                  |      |         |         |         | 2n + 2                    |                         |                |                 | OpA+4         | IEW          | 1000            |
|                            |                                                       |                  |      |         |         |         |                           | Total cycles:           | 2n+3; or 3 if  | <i>R</i> s = 0h | Total cycles: | 2n+4; or 3 i | <i>R</i> s = 0h |

<sup>†</sup> A single number represents a *given cycle*; an expression of *n* represents a *cycle* or *a period of cycles* depending on the *n*<sup>th</sup> number of shifts or repeats. Bus and signal values shown are present during these intervals.

| Syntax                                        | B{COND}<br>(where {COND} = condition option; see below)                                                                                                                                        |                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Execution                                     | (where PC = (BCOND_OpA                                                                                                                                                                         | If condition is true: (PC) + displacement → (PC)<br>(where PC = (BCOND_OpA + 4) ÷ 2)<br>If condition is not true: continue at next instruction in succession                                                                                                  |  |  |  |  |  |  |
| Mode Supported                                | <displacement8></displacement8>                                                                                                                                                                | <displacement8></displacement8>                                                                                                                                                                                                                               |  |  |  |  |  |  |
| Status Bits                                   | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                 |                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| Options                                       |                                                                                                                                                                                                |                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| Mnemonic<br><u>B{COND}</u>                    | Condition for Branch                                                                                                                                                                           | Mnemonic <u>B{COND}</u> Condition for Branch                                                                                                                                                                                                                  |  |  |  |  |  |  |
| BEQ<br>BGE<br>BGT<br>BHI<br>BHS<br>BLE<br>BLO | Carry Set<br>Equal or Zero<br>Greater Than or Equal <sup>†</sup><br>Greater Than <sup>†</sup><br>Higher<br>Higher or the Same<br>Less Than or Equal <sup>†</sup><br>Lower<br>Lower or the Same | BLTLess Than <sup>†</sup> BNNegative (Minus) <sup>†</sup> BNCCarry Is ClearBNENot Equal or Not ZeroBNVOverflow Is Clear <sup>†</sup> BPPositive <sup>†</sup> BPZPlus (Not Negative) <sup>†</sup> BRBranch always (no condition)BVOverflow Is Set <sup>†</sup> |  |  |  |  |  |  |

† Signed operations (others are logical operations)

Description

If the condition (in ST) is true (one), branch to the address specified. If the condition is not true, go to the next instruction in succession. Table 5–3 explains the conditions for each branch.

The following explains the instruction's branch mechanics, considering the effect of the prefetch pipeline. A maximum *signed* displacement of +127 and -128 words (+254/-256 bytes) can be indicated in the 8-bit signed displacement opcode field. However, this displacement value is figured from the PC value, which points two words past the16-bit word address of the BCOND instruction. This is graphically illustrated in Figure 5-2 (page 5-29) and explained below.

When viewed from the 16-bit PC value, displacement can be figured as +129 words (forward) or -126 words (backward) from the location of the instruction. Actually, a +127 or -128 value (translatable to *words* in displacement) is added to the PC value *when the displacement is figured*. Multiply this sum by 2 to determine the 17-bit BCOND\_OpA address. See Figure 5–2 (page 5-29).

To derive the 16-bit PC word address value from the 17-bit BCOND\_OpA address, add 4 (the additional 4 bytes beyond the currently executing opcode) and divide by 2. Two methods of destination address calculations:

starting with the 17-bit memory bus address: destination address = BCOND\_OpA<sub>17</sub> + 4 + (disp8\_in\_bytes × 2)

starting with the 16-bit PC word value: destination address = (PC + disp8\_in\_words) × 2

where PC =  $(BCOND_OpA + 4) \div 2$ .

When a branch is *not* taken (condition false), a clock cycle is saved because the prefetch pipeline does not need to be completely refilled.

Table 5–3. Branches Listed by Opcode

|   | Mnemonic | Opcode | Description                          | ST Condition<br>for Branch |
|---|----------|--------|--------------------------------------|----------------------------|
|   | BR       | C0h    | Branch (unconditional, always)       |                            |
| ſ | BNC      | C1h    | Branch if <b>carry clear</b>         | C = 0                      |
|   | BHS      | C1h    | Branch if higher or the same         | C = 0                      |
|   | BC       | C2h    | Branch if <b>carry set</b>           | C = 1                      |
| Ţ | BLO      | C2h    | Branch if <b>lower</b>               | C = 1                      |
|   | BEQ      | C3h    | Branch if equal or zero              | Z = 1                      |
|   | BNE      | C4h    | Branch if not equal or not zero      | Z = 0                      |
|   | BHI      | C5h    | Branch if <b>higher</b>              | C   Z = 0                  |
| l | BLS      | C6h    | Branch if lower or the same          | C   Z = 1                  |
| ( | BGT      | C7h    | Branch if greater than               | Z   (N ^ V) = 0            |
|   | BLE      | C8h    | Branch if less than or equal         | Z   (N ^ V) = 1            |
|   | BGE      | C9h    | Branch if greater than or equal      | N ^ V = 0                  |
|   | BLT      | CAh    | Branch if <b>less than</b>           | N ^ V = 1                  |
| 1 | BV       | CBh    | Branch if overflow set               | V = 1                      |
|   | BNV      | CCh    | Branch if overflow clear             | V = 0                      |
|   | BP       | CDh    | Branch if <b>positive</b>            | N   Z = 0                  |
|   | BPZ      | CEh    | Branch if <b>plus (not negative)</b> | N = 0                      |
| l | BN       | CFh    | Branch if <b>negative (minus)</b>    | N = 1                      |

Note: ^ = XOR, | = OR

Example

5-28

LABEL MOV \*R4+,R2 ; Bring in value to R2 ; Compare values CMP R2,R3 BNE FAIL\_MSG ; If not = R3, send fail message LABEL ; If higher, go back 3 words and BHI ; get next value Ž FAIL\_MSG MOV R2,\*R7 ; Store value

TMS370C16 CPU

|    | B{C     | OND} dis    | sp <b>8</b> |                 |          |      |
|----|---------|-------------|-------------|-----------------|----------|------|
| I  | Cx (b   | )           | disp8       |                 |          |      |
|    | Bra     | nch Not Tak | en          | Bran            | ch Taken |      |
| Cy | Address | Data        | wbfd        | Address         | Data     | wbfd |
| 1  | prevA   | (prevA)     | 1011        | prevA           | (prevA)  | 1011 |
| 2  | OpA + 4 | IEW         | 1000        | OpA +4+2disp    | w        | 1001 |
| 3  |         |             |             | OpA + 6 + 2disp | IEW      | 1000 |

Note: For definitions, see Figure 5-1 on page 5-16.

Figure 5–2. B{COND} Instruction Displacements



| Syntax         | BRBITO (Last character is a numerical 0.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution      | IF bit number <i>imm3</i> at byte addr = 0, then (PC) + disp8 → (PC)<br>where PC = (BRBIT0 OpA + 6) ÷ 2] <sup>†</sup> ELSE go to next instruction                                                                                                                                                                                                                                                                                                                                                                                           |
| Mode Supported | #imm3,&addr,disp8 (where: #imm3 is a number from 0–7,<br>identifying the bit position)                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Status Bits    | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Description    | Test a bit ( <i>imm3</i> = bit number) at a <i>byte</i> destination address ( <i>addr</i> ). If <b>bit</b> = 0, branch to the specified location by adding the displacement to the PC (add <i>byte</i> value — see Figure 5–3 for details). If <b>bit</b> = 1, continue to the next instruction following the BRBITO. If no branch is taken, a clock cycle is saved because the prefetch pipeline does not have to be completely refilled. The destination value addresses only the <i>first</i> 64K bytes of memory (address line A0 = 0). |
|                | The bit syntax field <b>must be</b> in the range $0-7$ . It is located in the opcode byte (bits $10-8$ ) specifying which bit to test in <i>addr16</i> (the byte address). The <i>imm3</i> bit value identifies the byte bit according to the following format:                                                                                                                                                                                                                                                                             |
|                | 7 6 5 4 3 2 1 0<br>Bit numbering of destination                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                | The instruction accesses bytes only, and it branches only if the bit tested is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                | The <i>imm3</i> value is assembled into the three least significant bits of the opcode.<br>This variable value accounts for the D8h–DFh opcode value that specifies the bit number checked in the destination. Opcode format:<br>15 14 13 12 11 10 9 8                                                                                                                                                                                                                                                                                      |
|                | 1 1 0 1 1 0-7 value = Bit values of BRBIT0 opcode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                | Because the instruction optimally prefetches another word into the pipeline before calculating the destination address, execution flow can be redirected (branched to) by +130 words or $-125$ words (+260/ $-250$ bytes) as shown in Figure 5–3. This is similar to the BCOND instructions, except that the PC is pointing <i>six</i> bytes from the address of the BRBIT0 instruction (instead of <i>four</i> bytes from the address of BCOND). (Compare Figure 5–2 and Figure 5–3.)                                                      |
| Example        | Check the most significant bit at byte address 201. If a 0, go to location TEST; otherwise, continue at the next instruction:                                                                                                                                                                                                                                                                                                                                                                                                               |
|                | Label BRBITO 7,&0201,TEST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                | <sup>†</sup> In the <b>Execution</b> entry at the top of the page, the 6 in the OpA + 6 address value is larger than that used for the BCOND or DBNZ instructions because this instruction optimally prefetches another word into the pipeline before calculating a destination address.                                                                                                                                                                                                                                                    |



Figure 5-3. BRBIT0 and BRBIT1 Instruction Displacements

| BRBITO | #imm3,&addr,disp8 |
|--------|-------------------|
| 110112 | imm3 disp8        |
|        | addr              |

| $\square$ | Branc   | ch Not Ta | ken  | Branch               | Taken  |      |
|-----------|---------|-----------|------|----------------------|--------|------|
| Cy        | Address | Data      | wbfd | Address              | Data   | wbfd |
| 1         | addr    | (addr)    | 1111 | addr                 | (addr) | 1111 |
| 2         | OpA + 4 | iW        | 1001 | OpA + 4              | IW     | 1001 |
| 3         | prev    | (prev)    | 1011 | prev                 | (prev) | 1011 |
| 4         | OpA + 6 | IEW       | 1000 | OpA + 4 + (2 x disp) | IW     | 1001 |
| 5         |         |           |      | OpA + 6 + (2 x disp) | IEW    | 1000 |
| Ľ         |         |           |      |                      |        | 1000 |



7

Note: The immediate value designating the bit to set is contained in the three least significant bits of the opcode's left-hand byte. Values are shown in the table on the right.

DF

| Syntax         | BRBIT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution      | IF bit number <i>imm3</i> in address <i>addr</i> = 1,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                | THEN (PC) + $disp 8 \rightarrow$ (PC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                | [where PC = (BRBIT1 OpA + 6) $\div$ 2] <sup>†</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                | ELSE go to next instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Mode Supported | <i>#imm3,&amp;addr,disp8</i> (where <i>#imm3</i> is a number from 0-7,<br>identifying the bit position)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Status Bits    | Z unchanged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                | N unchanged<br>C unchanged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                | V unchanged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Description    | Test a bit ( <i>imm3</i> = bit number) in the <i>byte</i> destination address ( <i>add</i> ). If <b>bit</b> = 1, branch to the specified location by adding the displacement to the PC (add <i>byte</i> value — see Figure 5–3 for details). If the <b>bit</b> = 0, continue to the next instruction after BRBIT1. If no branch is taken, a clock cycle is saved because the prefetch pipeline does not have to be completely refilled. The destination value addresses only the <i>first 64K bytes</i> of memory (address line A0 = 0).<br>The bit syntax field is a 0–7 value in bits 0–2 of the opcode byte specifying which bit to test at <i>addr16</i> (byte address). The <i>imm3</i> bit value identifies the byte bit according to the following format:<br>$\frac{7 \ 6 \ 5 \ 4 \ 3 \ 2 \ 1 \ 0}{=} = Bit numbering of destination$ The instruction accesses <i>bytes only</i> , and it branches <i>only</i> if the bit tested is a 1.<br>The <i>imm3</i> value is assembled into the three least significant bits of the opcode. This variable value accounts for the D0h–D7h opcode value that specifies the bit number checked in the destination. Opcode format:<br>$\frac{15 \ 14 \ 13 \ 12 \ 11 \ 10 \ 9 \ 8}{1 \ 1 \ 0 \ 1 \ 0 \ 0 \ -7 \ value} = Bit values of BRBIT1 opcode$ Because the instruction optimally prefetches another word into the pipeline before calculating the destination address, execution flow can be redirected to (branched to) a maximum distance of +130 words or -125 words (+260/–250 bytes) as shown in Figure 5–3. This is similar to the BRBIT0 instruction explanation immediately precedes these pages.) |

<sup>†</sup> In the **Execution** entry at the top of the page, the 6 in OpA + 6 value is larger than that used for the BCOND or DBNZ instructions because this instruction optimally prefetches another word into the pipeline before calculating a destination address.

# **Example** Check the least significant bit (0) in byte address 100. If it is a 1, go to location RECOUNT; otherwise, continue at the next instruction:

LABEL brbit1 0,&100,RECOUNT

### **Instruction Execution Detail**

|    | BRBIT1 # | imm3,&a      | ddr,disp8 | ]                    |        |      |
|----|----------|--------------|-----------|----------------------|--------|------|
|    | 110102   | imm3<br>addr | disp8     | ]                    |        |      |
|    | Bran     | ch Not Tak   | en        | Branch               | Taken  |      |
| Су | Address  | Data         | wbfd      | Address              | Data   | wbfd |
| 1  | addr     | (addr)       | 1111      | addr                 | (addr) | 1111 |
| 2  | OpA + 4  | IW           | 1001      | OpA + 4              | IW     | 1001 |
| 3  | prev     | (prev)       | 1011      | prev                 | (prev) | 1011 |
| 4  | OpA + 6  | IEW          | 1000      | OpA + 4 + (2 x disp) | IW     | 1001 |
| 5  |          |              |           | OpA + 6 + (2 x disp) | IEW    | 1000 |

Note: The immediate value designating the bit to set is contained in the three least significant bits of the opcode's left-hand byte, as shown in the table below.

| Bit to          | o Check               |
|-----------------|-----------------------|
| Opcode<br>(Hex) | Dest. Bit to<br>Check |
| D0              | 0                     |
| D1              | 1                     |
| D2              | 2                     |
| D3              | 3                     |
| D4              | 4                     |
| D5              | 5                     |
| D6              | 6                     |
| D7              | 77                    |

### Opcode and Destination Bit to Check

| Syntax          | CALL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | CALL addr or CALL Rd:<br>$(PC) - 2 \rightarrow ((SP))$<br>$(SP) + 2 \rightarrow (SP)$<br>$(destination) \rightarrow (PC)$ CALL *disp16[Rd] or CALL *Rd:<br>$(PC) \rightarrow ((SP))$<br>$(SP) + 2 \rightarrow (SP)$<br>$(disp + (Rd)) \rightarrow (PC)$                                                                                                                                                                                                                                                                                                                   |
| Modes Supported | Rd<br>*Rd (assembles same as CALL *0000h[Rd])<br>addr<br>*disp16[Rd]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Status Bits     | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Description     | <ul> <li>Jump to the subroutine pointed to by the destination operand. Provide linkage back to the next instruction after CALL by pushing the 16-bit word address (PC contents) of the next executable instruction onto the system stack. This returnlinkage word address (explained in note below) is derived from the memory opcode address (OpA) by these equations: <ul> <li>(CALL_OpA + 2) ÷ 2 for the 16-bit word address of CALL Rd</li> <li>(CALL_OpA + 4) ÷ 2 for the 16-bit word addresses of CALL addr16, CALL *disp[Rd], and CALL *Rd.</li> </ul> </li> </ul> |
|                 | <b>CALL</b> addr contains a 16-bit word address (see note below) to specify the destination. These 16 bits are applied to bits A16–A1 of the address bus (as if shifted left one bit). Note: addr17 must be an even value. See Figure 5–4 and Figure 4–12 on page 4-15.                                                                                                                                                                                                                                                                                                   |
|                 | <b>CALL</b> <i>Rd</i> jumps to the subroutine at the <i>word address</i> in Rd (i.e., <i>Rd</i> contents $\rightarrow$ PC). (Note that <b>CALL SP</b> , <b>CALL</b> * <i>disp16</i> [SP], and <b>CALL</b> *SP are undefined because SP is incremented before execution.)                                                                                                                                                                                                                                                                                                  |
|                 | <ul> <li>CALL *disp16[Rd] and *Rd use two levels of indirection to arrive at the destination (see Figure 4–12, page 4-15):</li> <li>1) Add displacement disp and the contents of Rd to compute a memory (not word) address (disp can be 0–FFFFh). This also applies to CALL *Rd, which assembles as if written CALL *0h[Rd]. (If Rd is ZR, then disp16 is the destination address.)</li> <li>2) At this address, retrieve the word address of the destination, which through the PC, is applied to address bus lines A15–A1 with A0 set to 0.</li> </ul>                  |
|                 | <b>Note:</b> PC's 16-Bit <i>Word Address</i> Translates to 17-Bit Address Bus<br>The program counter's 16-bit <i>word address</i> is transformed into a 17-bit<br>physical memory address by overlaying PC data bits 15–0 onto address<br>lines A16–A1 and forcing A0 to 0. See Section 2.3 and Figure 5–4.                                                                                                                                                                                                                                                               |

Use the RTS instruction to return from the CALL subroutine and continue with the execution of the instruction following the CALL. Use the RTDU instruction to return *if and only if* the subroutine executed a LINK instruction and did not execute an UNLINK instruction.

### Example





<sup>†</sup> A dashed line denotes the path of the value moved or copied. A solid line denotes a location pointer.

<sup>‡</sup>The PC value placed on the stack is *one half the 17-bit memory address value*. This is equal to (address of CALL + 4) + 2. On the return, the RTS instruction overlays this stored quotient onto the address bus (essentially multiplying it by 2). This value of one half the address bus value applies to all uses of the PC. This feature is more obvious with addresses above 64K bytes (which require the full 17 address bits).

|    | C       | ALL Rd   |      | CAL       | L addr16 | 6    | CALL       | *disp16[  | Rd]  |
|----|---------|----------|------|-----------|----------|------|------------|-----------|------|
|    | EB      |          | Rd   | EC        |          |      | ED         |           | Rd   |
|    |         |          |      |           | addr16   |      |            | disp16    |      |
| Су | Address | Data     | wbfd | Address   | Data     | wbfd | Address    | Data      | wbfd |
| 1  | prevA   | (prevA)  | 1011 | SP        | rtnA + 2 | 0011 | SP         | rtnA + 2  | 0011 |
| 2  | SP      | rtnA + 2 | 1001 | prevA     | (prevA)  | 1011 | prevA      | (prevA)   | 1011 |
| 3  | prevA   | IEW      | 1000 | 2caddr    | w        | 1001 | caddr      | disp + Rd | 1011 |
| 4  | 2Rd     | IW       | 1001 | 2caddr +2 | IEW      | 1000 | 2 caddr    | iW        | 1001 |
| 5  | 2Rd + 2 | IEW      | 1000 |           |          |      | 2caddr + 2 | IEW       | 1000 |

| Syntax          | CLR{B}                                      | Synthetic                  | c Instruction:               | Executes as MOV{B} ZR, destination                                                                                                                  |
|-----------------|---------------------------------------------|----------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | (Zero Regist                                | er) → (des                 | stination)                   |                                                                                                                                                     |
| Modes Supported | Rd<br>*Rd<br>*Rd+<br>*disp16[Rd]            |                            |                              |                                                                                                                                                     |
| Status Bits     | Z set<br>N cleared<br>C unchar<br>V cleared | iged                       |                              |                                                                                                                                                     |
| Description     | register) to tl                             | ne destina<br>stinations a | tion.<br>are <i>complete</i> | by copying the contents of the R15 (zero                                                                                                            |
| Example         | The following                               | g demonst<br>CLRB          | rates various                | s applications:<br>; Clear R12 to all zeroes                                                                                                        |
|                 |                                             | CLR<br>CLRB<br>CLR         | R12<br>*R11+<br>*R11+        | ; Clear R12 to all zeroes<br>; Clear byte at address<br>; in R11; increment R11 by 1<br>; Clear contents at address<br>; in R11; increment R11 by 2 |

|         | С                  | LR{B} A     | ld           | CL            | .R{B} */  | Rd           |
|---------|--------------------|-------------|--------------|---------------|-----------|--------------|
|         | 02(w) 03           | l(b) 111    | 12 Rd        | 04(w) 05      | 5(b) 11   | 112 Rd       |
|         |                    |             |              |               |           |              |
| Cy      | Address            | Data        | wbfd         | Address       | Data      | wbfd         |
| Cy<br>1 | Address<br>OpA + 4 | Data<br>IEW | wbfd<br>1000 | Address<br>Rd | Data<br>0 | wbfd<br>0S11 |

|    | CL      | Rd+      | CLR{B} *disp16[Rd] |           |          |          |
|----|---------|----------|--------------------|-----------|----------|----------|
|    | 06(w) 0 | 7(b) 111 | 12 Rd              | 08(w) 09  | 9(b) 111 | 12 Rd    |
| Су | Address | Data     | wbfd               | Address   | disp16   | wbła     |
| 1  | Rd      | 0        | 0\$11              | OpA + 4   | IW       | 1001     |
| 2  | OpA + 4 | IEW      | 1000               | disp + Rd | 0        | 0 \$ 1 1 |
| 3  |         |          |                    | OpA + 6   | IEW      | 1000     |

| Syntax                | CMP{B}                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Execution             | compute (destination) – (source); set ST bits according to results                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
| Modes Supported       | Rs,Rd *Rs+,Rd<br>#imm16,Rd *disp1[Rs],*disp2[Rd]<br>*disp16[Rs],Rd                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
| Status Bits           | <ul> <li>Z set if result is zero; cleared otherwise</li> <li>N equals bit in result: bit 7 (byte operation) or bit 15 (word operation)</li> <li>C set if an unsigned underflow occurred; cleared otherwise</li> <li>V set if a twos-complement underflow occurred; cleared otherwise</li> </ul> |  |  |  |  |  |  |  |
| Description           | Compare the contents of the source operand to the destination operand and set the ST status bits accordingly.                                                                                                                                                                                   |  |  |  |  |  |  |  |
|                       | The <i>compare is performed</i> by subtracting the source contents from the des-<br>tination contents. Results of the operation are reflected in the ST status bits.                                                                                                                            |  |  |  |  |  |  |  |
|                       | For byte operations, only the least significant bytes of the <i>register</i> operands are compared. Status bits are set with respect to the size (byte or word) of the operation.                                                                                                               |  |  |  |  |  |  |  |
|                       | <b>CMP{B} *Rn+,Rn</b> is a special-case operand combination where both parts<br>of the operand use the same register. The compare of <b>*Rn</b> and <b>Rn</b> occurs<br><b>before</b> Rn is postincremented.                                                                                    |  |  |  |  |  |  |  |
| Example               | LABEL CMP R12,R4 ; Is R12 equal to R4?                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|                       | BEQ YES_EQ ; Yes, go to equal subroutine                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|                       | CALL NOT_EQ ; No, go to not-equal subroutine                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| Instruction Execution | n Detail                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|                       |                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |

|    | CMP{B} Rs,Rd |           |         | CMP{B} #imm16,Rd |                 |                    | CMP{B} *disp[Rs],Rd |             |              |
|----|--------------|-----------|---------|------------------|-----------------|--------------------|---------------------|-------------|--------------|
|    | 60 (w) 6     | 1 (b) 🛛 R | s Rd    | 62 (w) 6         | 3 (b)           | Rd                 | 64 (w) 6            | 5 (b) Rs    | Rd           |
|    |              |           |         |                  | imm16           |                    |                     | disp        |              |
| Су | Address      | Data      | wbfd    | Address          | Data            | wbfd               | Address             | Data        | wbfd         |
| 1  | OpA + 4      | IEW       | 1000    | OpA + 4          | IW              | 1001               | OpA + 4             | IW          | 1001         |
| 2  |              |           |         | OpA + 6          | IEW             | 1000               | disp + Rs           | (disp + Rs) | 1811         |
| 3  |              |           |         |                  |                 |                    | OpA + 6             | IEW         | 1000         |
|    |              |           |         | 00 (W) 0         |                 |                    | 00 (W) (            |             |              |
|    |              |           |         | 66 (w) 6         | 37 (b) F        | is Rd              | 68 (w) (            | 59 (b) R    | s Ra         |
|    |              |           |         |                  |                 |                    |                     | disp1       |              |
|    |              |           |         |                  |                 |                    |                     | disp2       |              |
|    |              |           | <b></b> | Address          | Data            | wbfd               | Address             | Data        | wbfd         |
|    |              |           | Cy      | AUG1033          |                 |                    |                     |             |              |
|    |              |           | Cy<br>1 | Rs               | (Rs)            | 1511               | OpA + 4             | disp2       | 1001         |
|    |              |           |         |                  |                 | 1 S 1 1<br>1 0 1 1 | OpA + 4<br>OpA + 6  | disp2<br>IW | 1001<br>1001 |
|    |              |           | 1       | Rs               | (Rs)            |                    |                     | •           |              |
|    |              |           | 1       | Rs<br>prevA      | (Rs)<br>(prevA) | 1011               | OpA + 6             | w           | 1001         |

| Syntax          | CMPC                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | (destination) – (source) – C[[ST]] bit; set ST codes accordingly                                                                                                                                                                                                                                                                                                     |
| Modes Supported | Rs,Rd<br>*disp16[Rs],Rd                                                                                                                                                                                                                                                                                                                                              |
| Status Bits     | <ul> <li>Cleared if the result is non-zero; otherwise, unchanged</li> <li>equals the most significant bit of the result</li> <li>set if an unsigned underflow/borrow occurred; otherwise, cleared</li> <li>set if a twos-complement underflow occurred; otherwise, cleared</li> </ul>                                                                                |
| Description     | Compare the source value, minus the carry bit value, to the destination. Then set the ST codes according to the comparison.<br>The comparison is done in the following steps: (1) subtract the carry bit value from the source, and then (2) subtract this result from the destination:<br>(1) source (2) destination<br>- C [ST] - source'<br>source compare_result |

The ST codes reflect the operation, and the result is discarded (source, destination not changed).

This instruction is designed for 32-bit compares with the first words (LSwords) compared using the CMP instruction. The CMPC *immediately follows* the CMP instruction to compare the most significant words. If the CMPC comparison of the MSwords is true, the Z[ST] bit remains unchanged, reflecting the earlier comparison of the LSwords by the CMP. However, if an underflow/borrow occurred in the earlier LSword/CMP comparison, this will be included in the subtraction of the two MSwords during the CMPC comparison. Thus, two alike most significant values will show a zero Z[ST] bit because of the carry over from the least significant comparison.

Therefore, all ST condition codes will reflect a 32-bit compare after a CMP/ CMPC sequence of compares is executed. Example Compare two 32-bit values -- contents of R6/R7 with R8/R9 (two MSword/ LSword combinations). If equal, branch to subroutine EQUAL:

|       |      |       |                    | (MSword) | (LSword) |
|-------|------|-------|--------------------|----------|----------|
| LABEL | CMP  | R7,R9 | ; Compare LS words | R6       | E7       |
|       | CMPC | R6,R8 | ; Compare MS words |          |          |
|       | BEQ  | EQUAL | ; If equal, branch | R8       | R9       |

|    | CMPC Rs,Rd |      |      | CMPC *disp16[Rs],Rd |                |          |  |
|----|------------|------|------|---------------------|----------------|----------|--|
|    | 8E (w      | ) F  | s Rd | 8F ()               | N) F<br>disp16 | Rs Rd    |  |
| Су | Address    | Data | wbfd | Address             | Data           | wbfd     |  |
| 1  | OpA + 4    | IEW  | 1000 | OpA + 4             | IW             | 1001     |  |
| 2  |            |      |      | disp + Rs           | (disp + Rs)    | 1 \$ 1 1 |  |
| 3  |            |      |      | OpA + 6             | IEW            | 1000     |  |

| Syntax         | COMPL{B} Synthetic Instruction: Executes as SUBR{B} Rn,ZR                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Execution      | (ZR) – (Rn) (effectively SUBR{B} <i>Rn,ZR)</i><br><i>result</i> → (Rn)                                                                                                                                                                                        |  |  |  |  |  |  |  |
| Mode Supported | Rn                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
| Status Bits    | <ul> <li>Z set if the result is zero; cleared otherwise</li> <li>N equals the most significant bit of the result</li> <li>C cleared if the result is zero; set otherwise</li> <li>V set if a twos-complement underflow occurred; cleared otherwise</li> </ul> |  |  |  |  |  |  |  |
| Description    | Compute the negative value (perform a twos-complement negation) of the destination register's contents by subtracting its contents from zero and placing the result in the destination register.                                                              |  |  |  |  |  |  |  |
|                | For byte operations, the byte operands are zero-extended to words, are operated on as words, and produce a word result. The <i>most significant byte</i> of the result will be either 00h for C[ST]=0 or FFh for C[ST]=1.                                     |  |  |  |  |  |  |  |
|                | Status bits are set with respect to the size (byte or word) of the operation.                                                                                                                                                                                 |  |  |  |  |  |  |  |
| Examples       | Label compl R11 ; Negate R11 (twos complement)<br>COMPLB r4 ; Negate LS byte of R4. MS byte<br>; value depends on carry bit of<br>; ST as described above.                                                                                                    |  |  |  |  |  |  |  |

|    | COMPL{B} Rn<br>(SUBR Rd,ZR) |          |       |  |  |  |  |  |
|----|-----------------------------|----------|-------|--|--|--|--|--|
|    | 2E (w) 2                    | = (b) Rd | 11112 |  |  |  |  |  |
| Су | Address                     | Data     | wbfd  |  |  |  |  |  |
| 1  | prevA                       | (prevA)  | 1011  |  |  |  |  |  |

| Syntax         | DBNZ                                                                                                                                                                                                                                                       |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution      | ( <i>Rs</i> ) – 1 → ( <i>Rs</i> )<br>IF <i>Rs</i> ≠ 0<br>THEN (PC – <i>disp4</i> ) → (PC)<br>(where PC = [(DBNZ address + 4) ÷ 2]<br>ELSE go to instruction following DBNZ                                                                                 |
| Mode Supported | Rs,disp4                                                                                                                                                                                                                                                   |
| Option         | DBNZ Rs, <displacement4></displacement4>                                                                                                                                                                                                                   |
| Status Bits    | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                             |
| Description    | First, decrement the <i>Rs</i> word by one.                                                                                                                                                                                                                |
|                | Then, If the result is <b>nonzero</b> , branch to the location pointed to by <i>subtracting</i> the 4-bit displacement from the PC value. Note that this subtraction takes place when the PC is pointing to the four bytes following the DBNZ instruction; |

Figure 5–5. DBNZ Displacement Computation



thus, the displacement can redirect execution +2 words (a 0000<sub>2</sub> displacement) or -13 words (1111<sub>2</sub>) from the 17-bit address of the DBNZ instruction (see Figure 5–5). *In any case, the branch must be negative* — *to a previous address (lower memory address)*.

But, if the result is **zero**, do not branch; go to the next instruction.

**Example** This instruction provides a loop counter with the source register containing the number of loops desired. This is graphically shown in the left side of Figure 5–5.

MOV #100,R11 ; Set up to check 100 bytes ; \*\*\*\*\*\* Start of subroutine \*\*\*\* ; ; \*R3+,\*R5+ SUB STRT MOVB ; Bring in byte (next byte) ; Subroutine manipulates byte, stores it ; ; ; Now check if 100th byte read ; ; R11,SUB\_STRT ; If R11  $\neq$  0, go to SUB\_STRT, dbnz ; get next byte and repeat; ; otherwise, exit.

### Instruction Execution Detail

DBNZ Rs, disp4 A8 (w) disp4 Rs Branch Not Taken Branch Taken wbfd Су Data Data wbfd Address Address 1 1011 1011 prevA (prevA) prevA (prevA) 2  $OpA + 4 + (2 \times disp)$ W 1001 1011 prevA (prevA) 3  $OpA + 6 + (2 \times disp)$ IEW 1000 prevA (prevA) 1011 OpA + 4 IEW 1000

5-44 TMS370C16 CPU

| Syntax          | <b>DEC{B}</b> Synthetic Instruction: Executes as SUBQ{B} #1,dest                                                                                                                                                                                                                                       |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | (destination) – 1 $\rightarrow$ destination                                                                                                                                                                                                                                                            |
| Modes Supported | Rd<br>*disp16[Rd]                                                                                                                                                                                                                                                                                      |
| Status Bits     | <ul> <li>Z set if the result is zero; otherwise, cleared</li> <li>N equals bit in result: bit 7 (byte operation) or bit 15 (word operation)</li> <li>C set if an unsigned underflow occurred; otherwise, cleared</li> <li>V set if a twos-complement underflow occurred; otherwise, cleared</li> </ul> |
| Description     | Subtract one from the destination register or the destination address. Set the status bits with respect to the byte/word size of the result.                                                                                                                                                           |
|                 | For byte operations, the operand is zero-extended to word size, operated on<br>as a word, and produces a word result. The most significant byte of the result<br>is either:<br>00h for C[[ST]] = 0 or<br>FFh for C[[ST]] = 1.                                                                          |
|                 | Nonregister destinations receive the least significant byte of the result; registers receive the entire word.                                                                                                                                                                                          |
| Example         | 611 LABEL DEC Pl • Subtract 1 from Pl                                                                                                                                                                                                                                                                  |

| Example | 8611 | LABEL | DEC | R1       | ; | Subtract 1 from R1       |
|---------|------|-------|-----|----------|---|--------------------------|
|         | 8811 |       | DEC | *100[R1] | ; | Subtract 1 from value at |
|         | 0064 |       |     |          | ; | address computed as the  |
|         |      |       |     |          | ; | sum of R1 contents and   |
|         | 100  |       |     |          |   |                          |

|                                    | DEC{B} Rd<br>(SUBQ{B} #1,Rd) |      |      | DEC<br>(SUBQ{ | [B} *disp10<br>B} #1,*disp | 6[Rd]<br>16,[Rd]) |
|------------------------------------|------------------------------|------|------|---------------|----------------------------|-------------------|
| 86 (w) 87 (b) 0001 <sub>2</sub> Rd |                              |      |      | 88 (w) 8      | 39 (b) 000<br>disp16       | 1 <sub>2</sub> Rd |
| Су                                 | Address                      | Data | wbfd | Address       | Data                       | wbfd              |
| 1                                  | OpA + 4                      | IEW  | 1000 | prevA         | (prevA)                    | 1011              |
| 2                                  |                              |      |      | disp + Rd     | (disp + Rd)                | 1511              |
| 3                                  |                              |      |      | OpA + 4       | IW                         | 1001              |
| 4                                  |                              |      |      | disp + Rd     | result                     | 0511              |
| 5                                  |                              |      |      | OpA + 6       | IEW                        | 1000              |

| Syntax          | DIVS{L}                                            |                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | (dest) ÷ (src)<br>quotient → (R<br>remainder →     |                                                                                                                                                                                                                                                                                                                                                      |
| Modes Supported | Rs,Rd<br>Rs,IM:Rd                                  | (word format only — divide 16-bit Rd by 16-bit Rs)<br>(long format only — divide 32-bit IM:Rd by 16-bit Rs)                                                                                                                                                                                                                                          |
| Status Bits     | <b>Z</b> if V[[ST]]                                | = 1: bit Z[[ST]] is set if the 16-bit <i>divisor</i> is zero; cleared otherwise.                                                                                                                                                                                                                                                                     |
|                 | if V[[ST]]                                         | = 0: bit Z[ST] is set if the 16-bit <i>quotient</i> is zero; cleared otherwise.                                                                                                                                                                                                                                                                      |
|                 | •                                                  | [ST]] bit value XORed with the theoretical sign of the quotient paragraph of <b>Description</b> , on page 5-47).                                                                                                                                                                                                                                     |
|                 | C cleared                                          |                                                                                                                                                                                                                                                                                                                                                      |
|                 |                                                    | vos-complement overflow of the 16-bit quotient occurs;<br>otherwise (see third paragraph and table in <b>Description</b> ).                                                                                                                                                                                                                          |
| Description     | Place the quo register (IM).                       | ned values) the source register into the destination register(s).<br>tient in the destination register and the remainder in the implied<br>The destination value to be divided is in one or two registers:<br>ord (16-bit) by 16-bit) division: Rd + Rs                                                                                              |
|                 |                                                    | ng (32-bit by 16-bit) division: IM:Rd ÷ Rs(IM and Rd concate-<br>I <b>IM the most significant word</b> )                                                                                                                                                                                                                                             |
|                 | dividend (des<br>following sequ<br>the destination | sign of the remainder is <i>the same</i> as the sign of the original tination register contents). Also, the result is assigned in the ence: the remainder goes to IM first; then, the quotient goes to n. Thus, if IM is <i>also</i> the Rd in the destination of a long operation s, DIVS Rs,IM:IM), then the remainder in the IM is overwritten t. |
|                 | •                                                  | nent (signed) <b>overflow</b> occurs when the quotient does not fit nis occurs under the following conditions:                                                                                                                                                                                                                                       |
|                 | Operatio                                           | n Where                                                                                                                                                                                                                                                                                                                                              |
|                 | DIVS and DIV                                       | SL Rs contains 0000h                                                                                                                                                                                                                                                                                                                                 |
|                 | DIVS                                               | Rs contains FFFFh (i.e., -1)                                                                                                                                                                                                                                                                                                                         |
|                 |                                                    | and<br>Rd contains 8000h (i.e., –32,768)                                                                                                                                                                                                                                                                                                             |

Rs bit 15 = IM bit 15 (|Rs × 32768| ≤ |IM:Rd|)

Rs bit 15 ≠ IM bit 15 (|Rs × 32769| ≤ |IM:Rd|)

or

DIVSL

When such overflows occur, Rs, IM, and Rd will be left unchanged.

The *theoretical sign* of the quotient is the XOR of the most significant bits of the dividend and divisor prior to division. In other words:

For DIVS, this is Rs bit 15 XORed with Rd bit 15

For DIVSL, this is Rs bit 15 XORed with IM bit 15

#### Note: Do Not Use Operand Rs,IM:Rs

Using the operand Rs,IM:Rs can produce an undefined result. Depending on the size of the instruction and the contents of IM and Rs, it is possible to get a correct or incorrect result or an overflow.

| Examples | Label | divs  | R8,R9    | ; Signed divide of R9 by R8.<br>; Result to R9; remainder to IM.<br>:                 |
|----------|-------|-------|----------|---------------------------------------------------------------------------------------|
|          | LONGL | DIVSL | R8,IM:R2 | ; Signed divide of concatenated<br>; IM:R2 by R8. Result to R2;<br>; remainder to IM. |

#### Instruction Execution Detail

|      | DIVS Rs,Rd |         | 1d   |            | DIVSL <i>Rs,II</i> |
|------|------------|---------|------|------------|--------------------|
|      | A2 (w)     | Rs      | Rd   | A          | 3 (L) R            |
| Су   | Address    | Data    | wbfd | Cy Addre   | ess Data           |
| 1    | prevA      | (prevA) | 1011 | 1 prev     | A (prevA)          |
| 226  | prevA      | (prevA) | 1011 | 2-28 prev  | A (prevA)          |
| E-EO |            |         | 1000 | ‡final OpA | +4 IEW             |

<sup>†</sup> Word division (DIVS) takes 27 cycles, with the following two exceptions:

| Dividend | Divisor | <b>Cycles</b> | Comment  |
|----------|---------|---------------|----------|
| any      | 0000h   | 4             | overflow |
| 8000h    | FFFFh   | 26            | overflow |

The last line in the boxed table shows the logic values for the final cycle.

\* Longword division (DIVSL) takes 29 cycles, with the following eight exceptions:

| Dividend                           | Divisor | <b>Cycles</b> | Comment  |
|------------------------------------|---------|---------------|----------|
| 8000 0000h                         | pos     | 6             | overflow |
| 8000 0000h                         | neg     | 7             | overflow |
| $ IM:Rd  \ge  Rs  \times 65536$    | pos     | 8             | overflow |
| $ IM:Rd  \ge  Rs  \times 65536$    | neg     | 9             | overflow |
| $IM:Rd \ge Rs \times 32768$        | pos     | 28            | overflow |
| <i>IM:Rd</i> ≤ <i>Rs</i> × 32768   | neg     | 28            | overflow |
| <i>IM:Rd</i> ≥ – <i>Rs</i> × 32768 | pos     | 28            | overflow |
| $IM:Rd \leq -Rs \times 32768$      | neg     | 28            | overflow |

The last line in the boxed table shows the logic values for the final cycle.

| Syntax          | DIVU{L}                                                                                                                                                                                                                                                |  |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Execution       | (dest) $\div$ (src)<br>quotient $\rightarrow$ (Rd)<br>remainder $\rightarrow$ (IM)                                                                                                                                                                     |  |  |  |  |
| Modes Supported | DIVU Rs,Rd (word format only — divide 16-bit Rd by 16-bit Rs)<br>DIVUL Rs,IM:Rd (long format only — divide 32-bit IM:Rd by 16-bit Rs)                                                                                                                  |  |  |  |  |
| Status Bits     | Z if C[[ST]] = 1: set if the 16-bit divisor is zero; cleared otherwise<br>if C[[ST]] = 0: set if the 16-bit quotient is zero; cleared otherwise                                                                                                        |  |  |  |  |
|                 | N if C[ST] = 1: equals the most significant bit of the 16-bit divisor<br>if C[ST] = 0: equals the most significant bit of the 16-bit quotient                                                                                                          |  |  |  |  |
|                 | <ul> <li>Set if an unsigned overflow of the 16-bit quotient occurred;</li> <li>cleared otherwise</li> <li>V cleared</li> </ul>                                                                                                                         |  |  |  |  |
| Description     | Divide (as unsigned values) the source register into the destination register(s).<br>Place the quotient in the destination register and the remainder in the implied<br>register (IM). The destination value to be divided is in one or two registers: |  |  |  |  |
|                 | one for word (16-bit by 16-bit) division: Rd ÷ Rs                                                                                                                                                                                                      |  |  |  |  |
|                 | two for long (32-bit by 16-bit) division: IM:Rd ÷ Rs (IM and Rd concate-<br>nated, with IM the most significant word)                                                                                                                                  |  |  |  |  |
|                 | The result assignment sequence is the remainder to IM first and then the quotient to Rd. If Rd is also IM (for example, DIVU Rs,IM:IM), then the remainder in the IM is overwritten by the quotient.                                                   |  |  |  |  |
|                 | Unsigned overflow occurs when the quotient does not fit in a 16-bit data object.<br>This occurs for the following conditions:                                                                                                                          |  |  |  |  |
|                 | $\begin{tabular}{lllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                  |  |  |  |  |
|                 | When such overflows occur, Rs, IM, and Rd will be left unchanged.                                                                                                                                                                                      |  |  |  |  |
| Examples        | LABEL DIVU R2,R3 ; Signed divide of R3 by R2.<br>; Result to R3; remainder<br>; to IM.                                                                                                                                                                 |  |  |  |  |
|                 | Long2 divul R4,IM:R2 ; Signed divide of concatenated<br>; IM and R2 by R4. Quotient to<br>; R2, remainder to IM.                                                                                                                                       |  |  |  |  |

|         | DIVU Rs,Rd |         |      | DIV     | JL <i>Rs,IN</i> | 1:Rd |
|---------|------------|---------|------|---------|-----------------|------|
|         | A0 (w)     | Rs      | Rd   | A1 (L)  | Rs              | Rd   |
| Су      | Address    | Data    | wbfd | Address | Data            | wbfd |
| 1       | prevA      | (prevA) | 1011 | prevA   | (prevA)         | 1011 |
| 220     | prevA      | (prevA) | 1011 | prevA   | (prevA)         | 1011 |
| final † | OpA + 4    | IEW     | 1000 | OpA + 4 | IEW             | 1000 |

<sup>†</sup> Word division (DIVU) takes 21 cycles unless the divisor is 0000h; in which case, it takes only 5 cycles with an overflow occurring. The third line in the table shows final-cycle logic values. Longword division (DIVUL) takes 21 cycles unless the divisor is 0000h or unless IM:Rd  $\geq$  Rs  $\times$  65536. These two DUVUL exceptions take only 4 cycles with an overflow occurring. The third line in the table shows the final-cycle logic values.

| Syntax          | EXTS{B}                                                   |                                |                                                                      |                     |
|-----------------|-----------------------------------------------------------|--------------------------------|----------------------------------------------------------------------|---------------------|
| Execution       | value of ( <i>Rd7</i> ) →<br>or<br>value of <i>Rd15</i> → |                                |                                                                      | (byte)<br>(word)    |
| Modes Supported | EXTSB Rd<br>EXTS IM:Rd                                    | •                              | or EXTSB only — <i>byte oper</i><br>or EXTS only — <i>word opera</i> | -                   |
| Status Bits     |                                                           | nost significa<br>quals N[[ST] | eleared otherwise<br>ant bit of the result<br>]                      |                     |
| Description     | example, extend                                           | byte to word                   | stination register to the next<br>or word to 32-bit longword         | ).                  |
|                 | For word to long significant word o                       |                                | ed register IM is the desti<br>result.                               | nation for the most |
| Examples        | label exts                                                | im:r3                          | ; (sign) extend bit ;<br>; through the IM (R<br>;                    |                     |
|                 | extsb                                                     | r3                             | ; (sign) extend the v<br>; bit 7 through R3'                         |                     |

|    | E>      | (TSB / | Rd    | E>      | CTS IM: | Rd    |
|----|---------|--------|-------|---------|---------|-------|
|    | AB (b)  |        | Rd Rd | AA (v   | ) //    | // Rd |
| Су | Address | Data   | wbfd  | Address | Data    | wbfd  |
| 1  | OpA + 4 | IEW    | 1000  | prevA   | (prevA) | 1011  |
|    |         |        |       | 11      |         |       |

| Syntax          | EXTZ{B} Sy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ynthetic Instruction:                               | Executes as a MOV Instruction                                                                                          |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--|
| Execution       | $(Rd) \rightarrow (Rd)$<br>$(ZR) \rightarrow (IM)$                                                                                                                                                                                                                                                                                                                                                                                                                                                               | •                                                   | •                                                                                                                      |  |
| Modes Supported | Rd<br>IM:Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                     | <i>te operation.)<br/>d operation.</i> No matter what register is specified,<br><i>s</i> clears the IM register only.) |  |
| Status Bits     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | result is zero; clear<br>it 7 of Rd for EXTZE<br>ed |                                                                                                                        |  |
| Description     | <ul> <li>Extend the unsigned data in the destination register to the next larger data size. This extends byte to word by zeroing the destination register's most significant byte and extends word to longword by clearing the concatenated IM register. In other words:</li> <li>For the byte instruction (EXTZB) execution clears the MSbyte of the destination register.</li> <li>For the word instruction (EXTZ), execution clears only the IM register (R1), no matter which register specified.</li> </ul> |                                                     |                                                                                                                        |  |
| Examples        | Label                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | EXTZB R5                                            | ; Clear MSbyte of R5<br>;                                                                                              |  |
|                 | Clear_IM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Ext IM:r5                                           | ; Clear IM register                                                                                                    |  |

|    | E><br>(MC | Rd<br>Rd) |      | TZ <i>IM</i> :<br>OV ZR, |      |         |
|----|-----------|-----------|------|--------------------------|------|---------|
|    | 03 (b)    | R         | d Rd | 02 (w)                   | 1111 | 2 00012 |
| Су | Address   | Data      | wbfd | Address                  | Data | wbfd    |
| 1  | OpA + 4   | IEW       | 1000 | OpA+4                    | IEW  | 1000    |

| Syntax          | FMOV                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Execution       | (source) $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| Modes Supported | Rs,*Rd (where *Rs and *Rd mean indirect address)<br>*Rs,Rd                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| Status Bits     | <ul> <li>Set if the transferred data was zero; cleared otherwise</li> <li>equals the most significant bit of the transferred data</li> <li>unchanged</li> <li>cleared</li> </ul>                                                                                                                                                                                                                 |  |  |  |  |
| Description     | This instruction moves data to or from the upper half of the memory space.<br>The <i>indirection</i> register <i>*Rn</i> accesses the full 128K bytes of memory and<br>contains a <i>word</i> address. The other register addresses the first 64K bytes of<br>memory and contains the specified memory address.                                                                                  |  |  |  |  |
|                 | The content of the indirection register forms a 17-bit physical memory address<br>by overlaying register bits 15–0 onto address lines A16–A1, then forcing A0<br>to 0. Because the indirection-register contents are one half the address bus<br>value, the example below (and in Section 4.8, page 4-16) illustrates the use<br>of the ? operator to load this address value into the register. |  |  |  |  |
| Example         | Move the contents of R2 into address 1C400h:                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
|                 | MOV #?1C400h,R4 ; place addr 1C400h/2 in R4.<br>FMOV R2,*R4 ; move contents of R2 to 1C400h                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|                 | The first instruction places E200h (1C400h $\div$ 2) into R4. During the FMOV instruction, the E200h is applied to address bus lines A15–A1 with A0 a 0, deriving the destination address 1C400h. Note that the instruction:                                                                                                                                                                     |  |  |  |  |
|                 | MOV #1C400h/2,R4                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |

would perform the same function as MOV #?1C400h,R4.

|    | FM      | 0V <i>Rs</i> ,* | Rd   | FMOV *Rs,Rd |         |      |
|----|---------|-----------------|------|-------------|---------|------|
|    | F2 (w)  | Rs              | Rd   | F3 (w)      | Rs      | Rd   |
| Су | Address | Data            | wbfd | Address     | Data    | wbfd |
| 1  | prevA   | (prevA)         | 1011 | prevA       | (prevA) | 1011 |
| 2  | prevA   | (prevA)         | 1011 | prevA       | (prevA) | 1011 |
| 3  | 2Rd     | (2Rd)           | 1511 | 2Rs         | (2Rs)   | 1511 |
| 4  | prevA   | (prevA)         | 1011 | prevA       | (prevA) | 1011 |
| 5  | OpA + 4 | IEW             | 1000 | OpA+4       | IEW     | 1000 |

| Syntax          | IDLE                                                                                                                                                                                    |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Execution       | assert IDLE signal;<br>while in idle state, do nothing                                                                                                                                  |  |  |  |  |
| Modes Supported | Operand not necessary for IDLE                                                                                                                                                          |  |  |  |  |
| Status Bits     | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                          |  |  |  |  |
| Description     | Idle the CPU by entering an internal endless "do nothing" loop. The system module then enters the idle, standby, or halt mode (these modes are discussed in Section 3.11 on page 3-40). |  |  |  |  |
|                 | Methods of exiting the idle state depend upon device configuration and the idle low-power mode that was entered.                                                                        |  |  |  |  |
| Examples        | Label IDLE ; Enter the idle state or the ; designated low power mode.                                                                                                                   |  |  |  |  |

|               | IDLE    |         |        |  |  |
|---------------|---------|---------|--------|--|--|
|               |         | FE (w)  |        |  |  |
| Су            | Address | Data    | wbfd   |  |  |
| 1             | prevA   | (prevA) | 1011   |  |  |
| 2             | prevA   | (prevA) | 1011   |  |  |
| while<br>idle | high-z  | high-z  | high-z |  |  |

As shown, it takes two cycles to enter the idle state. Once in that state, signals shown at the top of the table (Address, Data,  $\overline{w}$ , b,  $\overline{f}$ ,  $\overline{d}$ ) remain in the high-impedance state.

| Syntax          | ILLEGAL                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | $(ST) \rightarrow ((SP))$ $(SP) + 2 \rightarrow (SP)$ $(PC) + 1 \rightarrow ((SP))$ $(SP) + 2 \rightarrow (SP)$ $((TRAP 0)) \rightarrow (PC)$ $ones \rightarrow L2-L0[[ST]]$                                                                                                                                                                            |
| Modes Supported | Operand not necessary for ILLEGAL                                                                                                                                                                                                                                                                                                                       |
| Status Bits     | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                          |
| Description     | Generate a trap exception by pushing the current ST contents and the <i>word address</i> of the next executable instruction plus 2 onto the system stack. Then load the PC with the contents of the vector for TRAP 0 (traps are further described in subsection 3.7.6 on page 3-24). It is preferred that the trap 0 vector point to a reset sequence. |
|                 | An RTI instruction returns execution to the interrupted execution flow.                                                                                                                                                                                                                                                                                 |
|                 | While ILLEGAL has an explicit opcode of 0000h, the following opcodes will<br>generate the same result and are also considered illegal:6Ah through 6Fh70h through 79h81h98h through 9FhEEh and EFh                                                                                                                                                       |
| Example         | Label Illegal ; Load the PC with the Trap 0<br>; 'illegal' vector, usually placed<br>; in code somewhere that should<br>; probably not be used during<br>; normal operation. It is suggested<br>; to have the Trap 0 routine contain<br>; a reset sequence.                                                                                             |

|    | ILLEGAL                  |                      |      |  |  |  |  |
|----|--------------------------|----------------------|------|--|--|--|--|
|    | 0000 0000 00             | 00 0000 <sub>2</sub> |      |  |  |  |  |
| Су | Address                  | Data                 | wbfd |  |  |  |  |
| 1  | OpA + 4                  | IEW                  | 1001 |  |  |  |  |
| 2  | SP                       | SR                   | 0011 |  |  |  |  |
| 3  | SP + 2                   | (rtnA + 4) ÷ 2       | 0011 |  |  |  |  |
| 4  | prevA                    | (prevA)              | 1011 |  |  |  |  |
| 5  | Trap 0 addr              | (Trap 0 addr)        | 1011 |  |  |  |  |
| 6  | Trap 0 vector $\times$ 2 | IW                   | 1001 |  |  |  |  |
| 7  | (Trap 0 vector × 2) + 2  | IEW                  | 1000 |  |  |  |  |

| Syntax          | INC{B}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Synthetic Instruction: Executes as<br>ADQ{B} #1,dest (destination + 1 → destination)                                         |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Execution       | ADQ{B} #1,de                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | st                                                                                                                           |  |  |  |
| Modes Supported | Rd<br>*disp16[Rd]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                              |  |  |  |
| Status Bits     | <ul> <li>Z set if the result is zero; cleared otherwise</li> <li>N equals the most significant bit of the result</li> <li>C set if an unsigned underflow occurred; cleared otherwise</li> <li>V set if a twos-complement underflow occurred; cleared otherwise</li> </ul>                                                                                                                                                                                                                                 |                                                                                                                              |  |  |  |
| Description     | <ul> <li>Add one to the destination operand. Status bits are set with respect to the size (byte or word) of the operation.</li> <li>For byte operations: <ul> <li>Bit C[[ST]] = 0 when the MSbyte is 00h,</li> <li>= 1 when the MSbyte is 01h.</li> </ul> </li> <li>Byte operands are zero-extended to words, are operated on as words, and produce a word result.</li> <li>Nonregister destinations receive the least significant byte of the result while registers receive the entire word.</li> </ul> |                                                                                                                              |  |  |  |
|                 | For word operations, bit C[[ST]] = 1 when the destination increments from FFFFh to 0000h.                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                              |  |  |  |
| Example         | INCB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <pre>R7 ; Increase contents of register 7 ; by 1 *101h[ZR]; Increase the contents of byte ; address 101h by 1 (ZR = 0)</pre> |  |  |  |

|    |           | IC{B} Fi<br>Q{B} #1 | ìd<br>,Rd) | INC{B} *disp16[Rd]<br>(ADQ{B} #1,*disp16[Rd]) |             |      |
|----|-----------|---------------------|------------|-----------------------------------------------|-------------|------|
|    | 82 (w) 8: | 3 (b) 000           | 012 Rd     | 84 (w) 85 (b) 00012 Rd<br>disp18              |             |      |
| Су | Address   | Data                | wbfd       | Address                                       | Data        | wbfd |
| 1  | OpA + 4   | IEW                 | 1000       | prevA                                         | (prevA)     | 1011 |
| 2  |           |                     |            | disp + Rd                                     | (disp + Rd) | 1511 |
| 3  |           |                     |            | OpA + 4                                       | W           | 1001 |
| 4  |           |                     |            | disp + Rd                                     | result      | 0S11 |
| 5  |           |                     |            | OpA+6                                         | IEW         | 1000 |

| Syntax         | INTPU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Execution      | $ \begin{array}{ll} IF & (IM) > (Rd) \\ THEN \\ LSbyte of  Rs \times (IM - Rd) + 80h \rightarrow temp & (8 \ bits \times 16 \ bits \rightarrow 24 \ bits + 80h) \\ temp \div 256 \rightarrow Rd \\ (IM) - (Rd) \rightarrow (Rd) \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\$                                                                                                                                                                                               |  |  |  |  |
| Mode Supported | Rs,IM:Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| Status Bits    | <ul> <li>Set if the result is zero; cleared otherwise</li> <li>equals the most significant bit of the result</li> <li>cleared</li> <li>cleared</li> </ul>                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| Description    | Perform a rounded straight line interpolation between the values contained in registers IM and Rd according to the interpolation fraction in Rs. (Note that a <i>colon</i> (:) separates IM and Rd in the destination's syntax shown in the <i>Mode Supported</i> section.)                                                                                                                                                                                                             |  |  |  |  |
|                | The interpolation fraction is held in the least significant byte of Rs and has its radix point between bits 7 and 8. The most significant byte of Rs is ignored, and the contents of Rs are left unchanged.                                                                                                                                                                                                                                                                             |  |  |  |  |
|                | The contents of IM and Rd are treated as words, with all arithmetic operations being word size. Bytes can be used in these registers if the register's most sig-<br>nificant byte is zero.                                                                                                                                                                                                                                                                                              |  |  |  |  |
|                | The internal multiply is $8 \times 16$ bits, where the 8-bit value is the fraction and the 16-bit value is the difference between IM and Rd. The product is a fixed-point value with the integer portion in bits 8–23 and the fraction in bits 0–7. Round up the product to word size by adding 80h, yielding a word value in bits 8–23. The most significant word of the rounded product is then combined with IM, yielding the final interpolated result, which is then placed in Rd. |  |  |  |  |
|                | The fractional portion of the temporary result is lost. The operand combination:<br>INTPU Rs, IM: IM<br>will always generate a result of 0000h in IM.<br>Status bits are set with respect to a word result in Rd.                                                                                                                                                                                                                                                                       |  |  |  |  |
|                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |

**Example** This example performs a rounded interpolation between the 0000h value in the IM register and 1000h in R6. The interpolation fraction of 256/2 is contained in R5. The result goes to R6, the destination register.

| LABEL | MOV<br>MOV<br>MOV<br>INTPU | ZR,IM<br>#1000h,R6<br>#(256/2),R5<br>R5,IR:R6 | <pre>; 0000h to the IM register<br/>; 1000h to R6<br/>; Interpolation fraction to R5<br/>; Interpolate between values in<br/>; in IM and R6, with rounding;<br/>; result is in R6</pre> |
|-------|----------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|-------|----------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### **Instruction Execution Detail**

INTPU Rs,IM:Rd

7D (w) Rs Rd disp16

|     | IM ≤ Rd |         |      | IM > Rd |         |      |
|-----|---------|---------|------|---------|---------|------|
| Су  | Address | Data    | wbfd | Address | Data    | wbfd |
| 1   | prevA   | (prevA) | 1011 | prevA   | (prevA) | 1011 |
| 2-8 | prevA   | (prevA) | 1011 | prevA   | (prevA) | 1011 |
| 9   | OpA + 4 | IEW     | 1000 | prevA   | (prevA) | 1011 |
| 10  |         |         |      | OpA + 4 | IEW     | 1000 |

| Syntax          | JMP                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution       | JMP $Rd$ destination $\rightarrow$ (PC)JMP $add$ destination $\rightarrow$ (PC)JMP*disp[Rd]disp + (Rd) $\rightarrow$ (PC)JMP*Rddisp + (Rd) $\rightarrow$ (PC) with disp = 0000h                                                                                                                                                                                                                                                                |  |  |  |  |  |
| Modes Supported | Rd<br>addr<br>*disp16[Rd]<br>*Rd (assembles as JMP <i>*0000h[Rd]</i> )                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| Status Bits     | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| Description     | Jump to the destination operand. <i>(For jump to a <b>subroutine</b>, see the CALL instruction, page 5-34.)</i>                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|                 | <b>JMP <i>Rd</i></b> jumps to the <i>word address</i> value (see note below) contained in register Rd (i.e., $Rd$ contents $\rightarrow$ (PC)).                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|                 | <b>JMP</b> <i>addr</i> jumps to the 17-bit <i>address</i> location (one half its value stored in the extension word as a 16-bit <i>word address</i> ).                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|                 | JMP *disp16[Rd] and JMP *Rd (the latter is assembled as if written JMP *0h[Rd]) use the following steps to derive the destination:                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|                 | <ol> <li>For *disp16[Rd], add the displacement (disp) and the contents of Rd to<br/>compute a memory address (displacement value can be 0–FFFFh).</li> </ol>                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|                 | 2) At this memory address, obtain a <i>word</i> address and apply this to the PC.<br>In turn, this value is applied to the address bus as a 17-bit address. Note<br>that this word address must be half the destination address-bus value. A<br>graphic explanation of this instruction is shown in Figure 4–12 on page<br>4-15.                                                                                                               |  |  |  |  |  |
|                 | <b>Note:</b> 16-Bit <i>Word Address</i> Translates to 17-Bit Address Bus<br>The <i>word address</i> is a 16-bit value transformed to a 17-bit memory address,<br>via the program counter, by overlaying data bits 0–15 onto address lines<br>A16–A1 and forcing A0 to 0. This is further explained in Section 2.2 and its<br>associated figures (page 2-4). Figure 4–13 (page 4-16) shows how to set the<br>word address using the ? operator. |  |  |  |  |  |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |

| Examples | LABEL | JMP | *R8        | ; Jump to the address of |
|----------|-------|-----|------------|--------------------------|
|          |       |     |            | ; ((R8)) * 2.            |
|          |       | jmp | &code7     | ; Jump to the address of |
|          |       |     |            | ; code7.                 |
|          |       | JMP | *extra[R7] | ; Jump to the address of |
|          |       |     |            | ; (extra + (R7)) * 2     |

| [  | JMP Rd    |         |      | JMP addr16   |         |      | JMP * <i>disp16[Rd</i> ] or * <i>Rd</i> |         |      |
|----|-----------|---------|------|--------------|---------|------|-----------------------------------------|---------|------|
| I  | E8        | _///    | Fld  | E9           | ddr16   | //// | EA                                      | disp16  | Rd   |
| Cy | Address   | Data    | wbfd | Address      | Data    | wbfd | Address                                 | Data    | wbfd |
| 1  | prevA     | (prevA) | 1011 | prevA        | (prevA) | 1011 | prevA                                   | (prevA) | 1011 |
| 2  | 2Rd       | łW      | 1001 | 2caddr       | IW      | 1001 | disp + Rd                               | caddr   | 1011 |
| 3  | (2Rd) + 2 | IEW     | 1000 | (2caddr) + 2 | IEW     | 1000 | 2caddr                                  | iw      | 1001 |
| 4  |           |         |      |              |         |      | (2caddr) + 2                            | IEW     | 1000 |

| Syntax          | LDBIT{B}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | value of bit in destination (specified by source mask) $\rightarrow C[ST]$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Modes Supported | #imm4,*disp16[Rd] (byte only)<br>Rs,*disp16[Rd] (byte only)<br>Rs,Rd (word only)<br>#imm4 <sub>,</sub> Rd (word only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Status Bits     | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C equals value of loaded bit</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Description     | The value of a bit in the destination, specified by the source operand, is placed<br>in the carry bit of the status register. The <b>source operand</b> is a value in the<br>range 0–15 contained either in the four least significant bits of a register or as<br>an immediate value. Bit numbers correspond to the following formats:<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0<br>= word bit numbering<br>$\frac{7 6 5 4 3 2 1 0}{1}$ = byte bit numbering<br>When the destination is a memory address, <i>only byte memory accesses</i> are<br>performed. Useful values for <b>byte operations</b> are 0–7, which select one of the<br>eight bits. When a value in the range 8–15 is used in byte operations, the<br>addressed byte is read, but the C[[ST]] bit is left equal to 0. Useful values for<br><b>word operations</b> are 0–15.<br>LDBIT is intended to be used with a BNC ( <i>branch if carry clear</i> — C[[ST]]<br>equals 0) or a BC ( <i>branch if carry set</i> — C[[ST]] equals 1) instruction. |
| Example         | Check if the most significant bit of byte (or word) address A000h is a 1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                 | LDBITB #15,*A000h[ZR] ; Place MSB of addr A000h<br>; in C bit of status reg.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                 | BC A_ONE ; Branch if MSB = 1<br>; (C bit = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

|    | LDBIT # imm4,Rd |         |       | LD      | LDBIT Rs,Rd |      |           | LDBITB<br>#imm4,*disp16[Rd] |      |  |
|----|-----------------|---------|-------|---------|-------------|------|-----------|-----------------------------|------|--|
|    | 94 (w)          | imn     | n4 Rd | E4 (w)  | Rs          | Rd   | 95 (l     | o) imn<br>disp16            | H Rd |  |
| Су | Address         | Data    | wbfd  | Address | Data        | wbfd | Address   | Data                        | wbfd |  |
| 1  | prevA           | (prevA) | 1011  | prevA   | (prevA)     | 1011 | OpA + 4   | IW                          | 1001 |  |
| 2  | OpA + 4         | IEW     | 1000  | prevA   | (prevA)     | 1011 | disp + Rd | (disp + Rd)                 | 1111 |  |
|    |                 |         |       | OpA + 4 | IEW         | 1000 | prevA     | (prevA)                     | 1011 |  |
| 3  |                 |         |       |         |             |      |           |                             |      |  |

### LDBITB Rs,\*disp16[Rd]

| E5 | (D)  | I HS I Rd |  |
|----|------|-----------|--|
|    | • •  |           |  |
|    | dico | 16        |  |
|    | uisp | Ū         |  |

| Су | Address   | Data        | wbfd |
|----|-----------|-------------|------|
| 1  | prevA     | (prevA)     | 1011 |
| 2  | OpA + 4   | IW          | 1001 |
| 3  | disp + Rd | (disp + Rd) | 1111 |
| 4  | prevA     | (prevA)     | 1011 |
| 5  | OpA + 6   | IEW         | 1000 |

### LDEA Load Effective Address

| Syntax         | LDEA                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution      | displacement value + (Rs) $\rightarrow$ (Rd)                                                                                                                                                                                                                                                                                                                                                                                   |
| Mode Supported | *disp16[Rs],Rd                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Status Bits    | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                                                                                                 |
| Description    | <ul> <li>Load the destination register with the sum of the source-register contents plus the 16-bit displacement (offset) value. Note the following:</li> <li>If <i>disp16</i> is a label, its value is the memory address value of <i>disp16</i> (not the contents of <i>disp16</i>).</li> <li>If <i>Rs</i> is the ZR (zero register), then execution loads <i>only</i> the value of <i>disp16</i> into <i>Rd</i>.</li> </ul> |
| Examples       | <pre>LABEL1 LDEA *BUFF7[r2],R8 ; Load value of BUFF7 plus<br/>; the contents of R2 into<br/>; register R8.<br/>LABEL2 LDEA *BUFF7[zr],R8 ; Load value of BUFF7 into<br/>; register R8.<br/>LABEL3 LDEA &amp;BUFF7,R8 ; Load value of BUFF7 into<br/>; register R8 (assembles<br/>; to same code as shown<br/>; for LABEL2 instruction).</pre>                                                                                  |

|    | LDEA               | *disp16[      | Rs],Rd |
|----|--------------------|---------------|--------|
|    | F0 (w              | ) F<br>disp16 | Rs Rd  |
| Су | Address            | Data          | wbīđ   |
| 1  | OpA + 4<br>OpA + 6 | IW            | 1001   |
| 2  | OpA + 6            | IEW           | 1000   |

| Syntax         | LIMHS{B}                                                                                                                                                                                                                                                                                                                                               |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution      | <pre>IF [ {V[ST] = 1 and N[ST] = 1 } or {V[ST] = 0 and (source) &lt; (Rd)}],     THEN         (source) → (Rd)         zero → V[ST]         one → C[ST] ELSE no change to Rd</pre>                                                                                                                                                                      |
| Mode Supported | *disp16[Rs],Rd                                                                                                                                                                                                                                                                                                                                         |
| Status Bits    | <ul> <li>Unchanged if Rd is not modified; otherwise, set if the contents of Rd are zero, and cleared if the contents of Rd are nonzero</li> <li>equals the most significant bit of Rd if Rd is modified; otherwise, unchanged</li> <li>set if Rd is modified; otherwise, unchanged</li> <li>cleared if Rd is modified; otherwise, unchanged</li> </ul> |
| Description    | This instruction ensures that a register variable remains less than or equal to its maximum legal value.                                                                                                                                                                                                                                               |
|                | This instruction leaves the destination register with either its original contents<br>or the value given by the contents of the source operand. The C[[ST]] bit de-<br>clares that the contents of Rd has been modified. Two conditions warrant set-<br>ting the register to the contents of the source operand:                                       |
|                | <ul> <li>Upon entry, V[ST] = 1 and N[ST] = 1, which indicates that an unsigned overflow occurred before this instruction.</li> <li>The signed data value at the source operand is less than the signed contents of Rd.</li> </ul>                                                                                                                      |
|                | Byte operations test only the least significant byte of a register. If a byte in Rd                                                                                                                                                                                                                                                                    |

is modified, the most significant byte of Rd is cleared. Status bits are set with respect to the size (byte or word) of the operation.

#### **Instruction Execution Detail**

LIMHS{B} \*disp16[Rs],Rd 58 (w) 59 (b) Rs Rd disp16

|    |           | V[[ST]] = 1 |      |           | V[[ST]] = 0 |      |
|----|-----------|-------------|------|-----------|-------------|------|
| Су | Address   | Data        | wbfd | Address   | Data        | wbfd |
| 1  | OpA + 4   | IW          | 1001 | OpA + 4   | IW          | 1001 |
| 2  | disp + Rs | (disp + Rs) | 1511 | disp + Rs | (disp + Rs) | 1511 |
| 3  | prevA     | (prevA)     | 1011 | prevA     | (prevA)     | 1011 |
| 4  | prevA     | (prevA)     | 1011 | prevA     | (prevA)     | 1011 |
| 5  | OpA + 6   | IEW         | 1000 | prevA     | (prevA)     | 1011 |
| 6  |           |             |      | OpA + 6   | IEW         | 1000 |

| Syntax         | LIMHU{B}                                                                                                                                                                                                                                                                                            |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution      | IF $[C[ST] = 1 \text{ or } (\text{source}) < (\text{Rd})]$ ,<br>THEN<br>source $\rightarrow$ (Rd)<br>one $\rightarrow V[ST]]$<br>ENDIF<br>zero $\rightarrow C[ST]]$<br>IF a <i>byte</i> instruction (LIMHUB),<br>THEN<br>zeroes $\rightarrow$ Rd bits 8–15<br>ENDIF<br>ELSE (Rd) remains unchanged  |
| Mode Supported | *disp16[Rs],Rd                                                                                                                                                                                                                                                                                      |
| Status Bits    | <ul> <li>Z set if the contents of Rd are zero; otherwise, cleared</li> <li>N equals the most significant bit of Rd</li> <li>C cleared</li> <li>V set if Rd is modified; otherwise, unchanged</li> <li>Use this instruction to ensure that a register variable remains less than or equal</li> </ul> |
|                | to its maximum legal value.                                                                                                                                                                                                                                                                         |
|                | This instruction leaves a register with either its original contents or the value given by the contents of the source operand. The $V[ST]$ bit declares that the contents of Rd have been modified. Two conditions warrant setting the register to the contents of the source operand:              |
|                | Upon entry, C[ST] = 1, indicating that an unsigned overflow occurred<br>before this instruction.                                                                                                                                                                                                    |
|                | The unsigned data value at the source operand is less than the unsigned contents of Rd.                                                                                                                                                                                                             |
|                | Byte operations test only the least significant byte of a register and <i>always clear</i> the most significant byte of Rd. Status bits are set with respect to the size (byte or word) of the operation.                                                                                           |

| LIMHU{B} *disp16[Rs],Rd |
|-------------------------|
| 5A (w) 5B (b) Rs Rd     |
| disp16                  |

|    |           | C[[ST]] = 1 |      |           | C[[ST]] = 0 |      |
|----|-----------|-------------|------|-----------|-------------|------|
| Су | Address   | Data        | wbfd | Address   | Data        | wbfd |
| 1  | OpA + 4   | IW          | 1001 | OpA + 4   | IW          | 1001 |
| 2  | disp + Rs | (disp + Rs) | 1811 | disp + Rs | (disp + Rs) | 1511 |
| 3  | prevA     | (prevA)     | 1011 | prevA     | (prevA)     | 1011 |
| 4  | OpA + 6   | IEW         | 1000 | prevA     | (prevA)     | 1011 |
| 5  |           |             |      | OpA + 6   | IEW         | 1000 |

| Syntax         | LIMLS{B}                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution      | $ \begin{array}{l} IF ~ [\{V[ST]] = 1 ~ and ~ N[ST]] = 0\} ~ or ~ \{V[ST]] = 0 ~ and (source) > (Rd) \}], \\ THEN \\ (source) \rightarrow (Rd) \\ zero \rightarrow \lor [RJ] \\ one \rightarrow C[ST]] \\ ELSE ~ (Rd) ~ remains unchanged \end{array} $                                                                                                                        |
| Mode Supported | *disp16[Rs],Rd                                                                                                                                                                                                                                                                                                                                                                 |
| Status Bits    | <ul> <li>Unchanged if Rd is not modified; otherwise, set if the contents of Rd are zero, and cleared if the contents of Rd are nonzero</li> <li>equals the most significant bit Rd if Rd is modified; otherwise, unchanged</li> <li>set if Rd is modified; otherwise, unchanged</li> <li>cleared if Rd is modified; otherwise, unchanged</li> </ul>                            |
| Description    | This instruction leaves the destination register with either its original contents or the value given by the contents of the source operand. The C[[ST]] bit declares that the contents of Rd has been modified. Either of two conditions set the register to the contents of the source operand:<br>Upon entry, $V[[ST]] = 1$ and $N[[ST]] = 0$ , indicating that an unsigned |
|                | overflow occurred before this instruction.                                                                                                                                                                                                                                                                                                                                     |
|                | Or when V[ST] = 0, and the signed data value at the source operand is greater than the signed contents of Rd.                                                                                                                                                                                                                                                                  |
|                | Use this instruction to ensure that a register variable remains greater than or equal to its minimum legal value.                                                                                                                                                                                                                                                              |
|                |                                                                                                                                                                                                                                                                                                                                                                                |

Byte operations test only the least significant byte of a register. If a byte in Rd is modified, the most significant byte of Rd is cleared. Status bits are set with respect to the size (byte or word) of the operation.

| LIMLS{B}  | *disp16[Rs],Rd |
|-----------|----------------|
| 5C (w) 5D | (b) Rs Rd      |
|           | disp16         |

|    |           | V[[ST]] = 1 |      |           | V[[ST]] = 0 |      |
|----|-----------|-------------|------|-----------|-------------|------|
| Су | Address   | Data        | wbfd | Address   | Data        | wbfd |
| 1  | OpA + 4   | w           | 1001 | OpA + 4   | IW          | 1001 |
| 2  | disp + Rs | (disp + Rs) | 1511 | disp + Rs | (disp + Rs) | 1511 |
| 3  | prevA     | (prevA)     | 1011 | prevA     | (prevA)     | 1011 |
| 4  | prevA     | (prevA)     | 1011 | prevA     | (prevA)     | 1011 |
| 5  | OpA + 6   | IEW         | 1000 | prevA     | (prevA)     | 1011 |
| 6  |           |             |      | OpA + 6   | IEW         | 1000 |

| Syntax                | LIMLU{B}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Execution             | IF $[C[ST]=1 \text{ or } (source) > (Rd)],$<br>THEN<br>(source) $\rightarrow$ (Rd)<br>1 (one) $\rightarrow$ V[ST]<br>ENDIF<br>$0 \rightarrow C[ST]$<br>IF a byte instruction (LIMLUB),<br>THEN $0 \rightarrow$ (Rd8-Rd15)<br>ENDIF                                                                                                                                                                                                                                                                                                               |  |  |  |
| Mode Supported        | *disp16[Rs],Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| Status Bits           | <ul> <li>Z set if the contents of Rd are zero; otherwise, cleared</li> <li>N equals the most significant bit of Rd</li> <li>C cleared</li> <li>V set if Rd is modified; otherwise, unchanged</li> </ul>                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| Description           | <ul> <li>This instruction will leave the destination register with either its original contents or the value given by the contents of the source operand. The V[[ST]] bit declares that the contents of Rd have been modified. Two conditions warrant setting the register to the contents of the source operand:</li> <li>Upon entry, C[[ST]] = 1, which indicates that an unsigned overflow occurred prior to this instruction.</li> <li>The unsigned data value at the source operand is greater than the unsigned contents of Rd.</li> </ul> |  |  |  |
|                       | Use this instruction to ensure that a register variable remains greater than or equal to its minimum legal value.                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                       | Byte operations test only the least significant byte of a register. If a byte in Rd is modified, the most significant byte of Rd is cleared. Status bits are set with respect to the size (byte or word) of the operation.                                                                                                                                                                                                                                                                                                                       |  |  |  |
| Instruction Execution | n Detail                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |

LIMLU{B} \*disp16[Rs],Rd

| 5E (4        | A 5E                                          | (h)      | Re | Bd  |
|--------------|-----------------------------------------------|----------|----|-----|
| <u>or (r</u> | <u>, , , , , , , , , , , , , , , , , , , </u> | <u> </u> | 10 | 114 |
|              |                                               | diso16   |    |     |

...........

|    |           | C[[ST]] = 1 |      |           | C[[ST]] = 0 |      |
|----|-----------|-------------|------|-----------|-------------|------|
| Су | Address   | Data        | wbfd | Address   | Data        | wbfd |
| 1  | OpA + 4   | IW          | 1001 | OpA + 4   | IW          | 1001 |
| 2  | disp + Rs | (disp + Rs) | 1511 | disp + Rs | (disp + Rs) | 1811 |
| 3  | prevA     | (prevA)     | 1011 | prevA     | (prevA)     | 1011 |
| 4  | OpA + 6   | IEW         | 1000 | prevA     | (prevA)     | 1011 |
| 5  |           |             |      | OpA + 6   | IEW         | 1000 |

| Syntax         | LINK                                                                                                                                                                       |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Execution      | $\begin{array}{l} (FP) \rightarrow ((SP)) \\ (SP) \rightarrow (FP) \\ (SP) + 2 \rightarrow (SP) \\ (SP) + (2 \times displacement) \rightarrow (SP) \end{array}$            |  |
| Mode Supported | disp8                                                                                                                                                                      |  |
| Status Bits    | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                             |  |
| Description    | This instruction links the frame pointer (FP) to the current system stack frame by executing these steps:                                                                  |  |
|                | <ol> <li>Push the FP contents onto the system stack.</li> <li>Set the FP to the SP value.</li> <li>Allocate a <i>displacement</i> amount of words on the stack.</li> </ol> |  |
|                | The 8-bit, unsigned, immediate displacement value is multiplied by 2 before being added to the SP, in order to keep the value of SP even.                                  |  |

A stack frame of 0 to 255 words can be allocated.

|    | L       | NK dis  | 08    |
|----|---------|---------|-------|
|    | F7      |         | disp8 |
| Су | Address | Data    | wbfd  |
| 1  | SP      | FP      | 0011  |
| 2  | prevA   | (prevA) | 1011  |
| 3  | prevA   | (prevA) | 1011  |
| 4  | OpA + 4 | IEW     | 1000  |

| Syntax          | LSR{L}                                                                                                                                                                                                                                                                                                       |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Execution       | Shift destination register to the right by a source-count amount of bits                                                                                                                                                                                                                                     |  |  |  |
| Modes Supported | Rs,Rd (word)<br>#imm4,Rd (word)<br>Rs,IM:Rd (longword)<br>#imm4,IM:Rd (longword)                                                                                                                                                                                                                             |  |  |  |
| Status Bits     | <ul> <li>Set if the result is zero; cleared otherwise</li> <li>equals the most significant bit of the result</li> <li>equals the last bit shifted out of the register; cleared if the shift count in Rs is zero</li> <li>V cleared</li> </ul>                                                                |  |  |  |
| Description     | Logically right-shift the destination register's contents by the number of the bit count in the source operand. At the same time, shift (the same number of) zero(es) into the most significant bit(s). A four-bit field in the source operand contains the shift count of 0–15.                             |  |  |  |
|                 | Zero(es)                                                                                                                                                                                                                                                                                                     |  |  |  |
|                 | 15 0<br>(MSB of Rd or IM) Bit 0 of Rd                                                                                                                                                                                                                                                                        |  |  |  |
|                 | For shifts using <b>immediate values</b> , <i>source-operand immediate values</i> of $0001_2$ to $1111_2$ correspond to shift counts of 1–15, with a field value of $0000_2$ representing a shift of 16. For shift values <b>in Rs</b> , the four LSBs of $0000_2$ to $1111_2$ represent a shift of 0 to 15. |  |  |  |
|                 | Status bits are set with respect to the size (word or longword) of the operation.<br>Longword shifts imply the use of register IM as the most significant word of the<br>32-bit object. The result of LSRL s,IM:IM is undefined.                                                                             |  |  |  |
| Examples        | LABEL MOV #6,R12 ; Place value of 6 in R12<br>LSR R12,R3 ; Shift R3 to the right 6 bits<br>; and fill the 6 MSBs with<br>; zeroes.                                                                                                                                                                           |  |  |  |
|                 | SHIFT_2 LSR #2,R8 ; Logically shift R8 by 2 bits.                                                                                                                                                                                                                                                            |  |  |  |
|                 | ;<br>SHIFT_12 LSRL #12,IM:R5 ; Logically right-shift the<br>; concatenated values in IM:R5<br>; by 12.                                                                                                                                                                                                       |  |  |  |
|                 | LSRL R3,IM:R2 ; The count value of the 4 LSBs<br>; of R3 are used to logically<br>; right-shift the IM:R2<br>; register pair.                                                                                                                                                                                |  |  |  |

|                               | LSR #imm4,Rd |         |      | LS                            | SR <i>Rs,F</i> | d                               |       |
|-------------------------------|--------------|---------|------|-------------------------------|----------------|---------------------------------|-------|
|                               | BC (w)       | imme    | Rd   |                               | BE (w)         | Rs                              | Rd    |
| Cycle/<br>Period <sup>†</sup> | Address      | Data    | wbłd | Cycle/<br>Period <sup>†</sup> | Address        | Data                            | wbfd  |
| л<br>(repeat)                 | prevA        | (prevA) | 1011 | 1                             | prevA          | (prevA)                         | 1011  |
| n+1                           | OpA+4        | IEW     | 1000 | 2                             | prevA          | (prevA)                         | 1011  |
|                               |              |         |      | n<br>(repeat)                 | prevA          | (prevA)                         | 1011  |
|                               |              |         |      | n+1                           | OpA+4          | IEW                             | 1000  |
|                               |              |         |      |                               | Tota           | al cycles: n +                  | 3     |
|                               |              | Himama  |      |                               |                |                                 |       |
|                               | LSRL         | #imm4,I | м:на |                               | LSI            | RL <i>Rs,ll</i>                 | и:на  |
|                               | BD (L)       | imm     | 4 Rd |                               | BF (I          | .) F                            | ls Rd |
| Cycle/<br>Period <sup>†</sup> | Address      | Data    | wbłd | Cycle/<br>Period <sup>†</sup> | Address        | Data                            | wbfd  |
| 1                             | prevA        | (prevA) | 1011 | 1                             | prevA          | (prevA)                         | 1011  |
| 2 <i>n</i> 2<br>(repeat)      | prevA        | (prevA) | 1011 | 2                             | prevA          | (prevA)                         | 1011  |
| 2n                            | OpA+4        | IEW     | 1000 | 3                             | prevA          | (prevA)                         | 1011  |
|                               |              |         |      | 2n-2<br>(repeat)              | prevA          | (prevA)                         | 1011  |
|                               |              |         |      | 2n                            | OpA+4          | IEW                             | 1000  |
|                               |              |         |      |                               |                | l cycles: 2 +<br>3 if Rs = xxxx |       |

<sup>†</sup> A single number represents a *given cycle*; an expression of *n* represents a *cycle* or *period of cycles*, depending on the *n*<sup>th</sup> number of shifts or repeats.

| Syntax          | MOV{B}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Execution       | (source) $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| Modes Supported | Rs,Rd<br>Rs,*Rd<br>Rs,*Rd+<br>Rs,*disp16[Rd]<br>*Rs,Rd<br>*Rs,Rd<br>*Rs,Rd<br>*Rs,*Rd<br>*Rs,*Rd<br>*Rs+,Rd<br>*Rs+,Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rs+,*Rd<br>*Rd<br>*disp16[Rd]<br>*disp16[Rd]<br>*disp16[Rs],*Rd<br>*disp16[Rs],*Rd<br>*disp16[Rs],*Rd<br>*disp16[Rs],*Rd<br>*disp16[Rs],*Rd<br>*disp16[Rs],*Rd<br>*disp16[Rs],*Rd<br>*disp16[Rs],*Rd<br>*disp16[Rs],*Rd |  |  |  |
| Status Bits     | <ul> <li>Z set if the transferred data was zero; otherwise, cleared</li> <li>N equals the most significant bit of the transferred data</li> <li>C unchanged</li> <li>V cleared</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| Description     | Transfer data from the source operand to the destination operand.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|                 | When byte data is moved to a register, the least significant byte receives the data, while the most significant byte is cleared. When data is moved from a register, only the least significant byte of the register is moved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|                 | Status bits are set with respect to the size (byte or word) of the operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                 | Note: Use FMOV to Address 0 – 1FFFFh (Up to 128K Bytes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                 | The MOV instruction moves (copies) between registers or from/to an address space within the first 64K bytes. Use the FMOV instruction to move data in the address space from 0 to 128K bytes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |

| Instruction Operation (se |             | Operation (see Note)                      |
|---------------------------|-------------|-------------------------------------------|
| MOV                       | *Rn+,Rn     | ((Rn)) + size → (Rn)                      |
| MOV                       | *Rn+,*Rn    | ((Rn)) → ((Rn));<br>(Rn) + size → (Rn)    |
| MOV                       | *Rn+,*Rn+   | (Rn) → (Rn + size);<br>Rn + 2 × size → Rn |
| MOV                       | *Rn+,*d[Rn] | (Rn) → (d + (Rn));<br>Rn + size → Rn      |

Four special cases exist when the source operand is \*(Rn) + and the destination operand is a mode using *the same register*.

Note: The "size" is the increment size (1 for byte, 2 for word).

| Examples | Label  | mov    | r2,r3      | ;                     | Move contents of R2 to R3.                                                                                                                        |
|----------|--------|--------|------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
|          | clr_R5 | mov    | zr,r5      | ;                     | Clear contents of R5                                                                                                                              |
|          |        | mov    | zr,*r9+    | ,<br>;<br>;<br>;      | Clear the contents at the<br>address in R9 then incre-<br>ment R9.                                                                                |
|          |        | MOV *5 | 0h[r1],r2  | ;;;;;                 | Compute the source address<br>by adding 50h and the contents<br>of R1. Move the contents at<br>this address to R2.                                |
|          |        | movb # | 1234h,*r10 | ;;;;;                 | Move the value 34h into the<br>indirect contents of r10.<br>Force MS byte of r10 to<br>all zeroes.                                                |
|          |        | mov &B | UF1,&BUF2  | ;;                    | Move the word at location BUF1 to word location BUF2.                                                                                             |
|          |        | MOVB & | LOC1,&LOC2 | ,<br>;<br>;           | Move the byte value at LOC1<br>to byte address LOC2.                                                                                              |
|          |        | movb * | -r7,im     | ;<br>;<br>;<br>;<br>; | Decrement value in R7; the<br>result is the source add-<br>ress. Move the LS byte at<br>this address to the IM with<br>the MS byte of the IM = 0. |

| MOV{B} Rs, Rd              | 10V{B} <i>Rs, *Rd</i> | MOV{B} Rs,*Rd+ |
|----------------------------|-----------------------|----------------|
| 02 (w) 03 (b) Rs Rd 04 (w) | 05 (b) Rs Rd 06       |                |

| Су | Address | Data | wbfd | Address | Data | wbfd    | Address | Data | wbfd    |
|----|---------|------|------|---------|------|---------|---------|------|---------|
| 1  | OpA + 4 | IEW  | 1000 | Rd      | Rs   | 0 S 1 1 | Rd      | Rs   | 0 8 1 1 |
| 2  |         |      |      | OpA + 4 | IEW  | 1000    | OpA + 4 | IEW  | 1000    |

| MOV{B} Rs,*disp16[Rd] | MOV{B} *Rs,Rd       | MOV{B} *Rs,*Rd      |
|-----------------------|---------------------|---------------------|
| 08 (w) 09 (b) Rs Rd   | 0B (w) 0A (b) Rs Rd | 0C (w) 0D (b) Rs Rd |
| disp18                |                     |                     |

| Су | Address   | Data | wbfd | Address | Data | wbfd | Address | Data | wbfd     |
|----|-----------|------|------|---------|------|------|---------|------|----------|
| 1  | OpA + 4   | IW   | 1001 | RS      | (Rs) | 1811 | Rs      | (Rs) | 1811     |
| 2  | disp + Rd | Rs   | 1011 | OpA + 4 | IEW  | 1000 | Rd      | (Rs) | 0 \$ 1 1 |
| 3  | OpA + 6   | IEW  | 1000 |         |      |      | OpA + 4 | IEW  | 1000     |

| MOV{B} *Rs,*Rd+ | MOV{B} *Rs,*disp16[Rd] | MOV{B} *Rs+,Rd |
|-----------------|------------------------|----------------|
|                 |                        |                |
|                 |                        |                |

| 0E (w) 0F (b) Rs Rd | 10 (w) 11 (b) Rs Rd | 12 (w) 13 (b) Rs Rd |
|---------------------|---------------------|---------------------|
|                     | disp16              |                     |

| Су | Address | Data | wbfd     | Address   | Data | wbfd     | Address | Data   | wbfd     |
|----|---------|------|----------|-----------|------|----------|---------|--------|----------|
| 1  | Rs      | (Rs) | 1 \$ 1 1 | OpA + 4   | IW   | 1001     | Rs      | (Rs)   | 1 \$ 1 1 |
| 2  | Rd      | (Rs) | 0 \$ 1 1 | Rs        | (Rs) | 1 \$ 1 1 | prev    | (prev) | 1011     |
| 3  | OpA + 4 | IEW  | 1000     | disp + Rd | (Rs) | 0511     | OpA + 4 | IEW    | 1000     |
| 4  |         |      |          | OpA + 6   | IEW  | 1000     |         |        |          |

| MOV{B} *Rs+,*Rd     | MOV{B} *Rs+,*Rd+    | MOV{B} *Rs+,*disp16[Rd]    |
|---------------------|---------------------|----------------------------|
| 14 (w) 15 (b) Rs Rd | 16 (w) 17 (b) Rs Rd | 18 (w) 19 (b) <i>Rs</i> Rd |
|                     |                     | disp16                     |

| Су | Address | Data | wbfd | Address | Data   | wbfd     | Address   | Data | wbfd    |
|----|---------|------|------|---------|--------|----------|-----------|------|---------|
| 1  | Rs      | (Rs) | 1811 | Rs      | (Rs)   | 1811     | Rs        | (Rs) | 1511    |
| 2  | Rd      | (Rs) | 0511 | prev    | (prev) | 1011     | OpA + 4   | IW   | 1001    |
| 3  | OpA + 4 | IEW  | 1000 | Rd      | (Rs)   | 0 \$ 1 1 | disp + Rd | (Rs) | 0 8 1 1 |
| 4  |         |      |      | OpA + 4 | IEW    | 1000     | OpA + 6   | IEW  | 1000    |

| MOV{B} #imm16,Rd | MOV{B} #imm16,*Rd | MOV{B} <i>#imm16</i> ,*Rd+ |  |  |
|------------------|-------------------|----------------------------|--|--|
| 1A (w) 1B (b) Rd | 1C (w) 1D (b) Rd  | 1E (w) 1F (b) Rd           |  |  |
| imm16            | imm16             | imm18                      |  |  |

| Су | Address | Data | wbīd | Address | Data | wbfd | Address | Data | wbłd     |
|----|---------|------|------|---------|------|------|---------|------|----------|
| 1  | OpA + 4 | w    | 1001 | Rd      | data | 0511 | Rd      | data | 0 \$ 1 1 |
| 2  | OpA + 6 | IEW  | 1000 | OpA + 4 | IW   | 1001 | OpA + 4 | IW   | 1001     |
| 3  |         |      |      | OpA + 6 | IEW  | 1000 | OpA + 6 | IEW  | 1000     |

| MOV{B} #imm16,*disp16[Rd] | MOV{B} *disp16[Rs],Rd | MOV{B} *disp16[Rs],*Rd |  |  |  |  |
|---------------------------|-----------------------|------------------------|--|--|--|--|
| 20 (w) 21 (b)             | 22 (w) 23 (b) Rs Rd   | 24 (w) 25 (b) Rs Rd    |  |  |  |  |
| disp16                    | disp18                | disp16                 |  |  |  |  |
| imm16                     |                       |                        |  |  |  |  |

| Су | Address   | Data | wbfd    | Address   | Data        | wbfd | Address   | Data        | wbfd     |
|----|-----------|------|---------|-----------|-------------|------|-----------|-------------|----------|
| 1  | OpA + 4   | data | 1001    | OpA + 4   | IW          | 1001 | OpA + 4   | IW          | 1001     |
| 2  | disp + Rd | data | 0 S 1 1 | disp + Rs | (disp + Rs) | 1511 | disp + Rd | (disp + Rs) | 1 \$ 1 1 |
| 3  | OpA + 6   | w    | 1001    | OpA + 6   | IEW         | 1000 | Rd        | (disp + Rs) | 0 S 1 1  |
| 4  | OpA + 8   | IEW  | 1000    | 1         |             |      | OpA + 6   | IEW         | 1000     |

| MOV{B} *disp16[Rs],*Rd+ | MOV{B}*disp_s16[Rs],*disp_d16[Rd] | MOV{B} *–Rs,Rd |  |  |
|-------------------------|-----------------------------------|----------------|--|--|
| 26 (w) 27 (b) Re Rd     | 28 (w) 29 (b) Rs Rd               |                |  |  |
| disp16                  | disp116                           |                |  |  |

disp216

| Су | Address   | Data        | wbfd     | Address    | Data         | wbfd | Address | Data     | wbfd     |
|----|-----------|-------------|----------|------------|--------------|------|---------|----------|----------|
| 1  | OpA + 4   | IW          | 1001     | OpA + 4    | disp2        | 1001 | prev    | (prev)   | 1011     |
| 2  | disp + Rs | (disp + Rs) | 1 \$ 1 1 | OpA + 6    | w            | 1001 | Rs - S  | (Rs - S) | 1 \$ 1 1 |
| 3  | Rd        | (disp + Rs) | 0 \$ 1 1 | disp1 + Rs | (disp1 + Rs) | 1811 | OpA + 4 | IEW      | 1000     |
| 4  | OpA + 6   | IEW         | 1000     | disp2 + Rd | (disp1 + Rd) | 0511 |         |          |          |
| 5  |           |             |          | OpA + 8    | IEW          | 1000 |         |          |          |

| Syntax         | MOVQ                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Execution      | immediate data value $\rightarrow$ (destination)                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
| Mode Supported | #imm4,Rd (4-bit value entered, zero extended; 16-bit word moved)                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
| Status Bits    | <ul> <li>Set if the transferred data was zero; cleared otherwise</li> <li>N cleared</li> <li>C unchanged</li> <li>V cleared</li> </ul>                                                                                                                                                                   |  |  |  |  |  |  |  |
| Description    | Transfer quick immediate data to the destination operand. Quick immediate data is a <i>4-bit</i> value of 0–15, that has been <i>zero-extended to word</i> . This instruction requires <b>one</b> word and operates in one cycle; whereas, MOV <i>#data,Rd</i> takes up <b>two</b> words and two cycles. |  |  |  |  |  |  |  |
|                | result in destination register <i>Rd</i> with the register's MSbyte cleared to zeroes.                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
| Example        | LABEL MOVQ #3,R12 ; Load the value 3 into R12.                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |

| [  | MOVQ    | #imm4 ,Rd |      |  |  |  |
|----|---------|-----------|------|--|--|--|
|    | 80 (w)  | imm4      | Rd   |  |  |  |
| Cy | Address | Data      | wbfd |  |  |  |
| 1  | OpA + 4 | IEW       | 1000 |  |  |  |

| Syntax                | MPYBWU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Execution             | (LSbyte of Rs × Rd) + 80h $\rightarrow$ (Temp) (8 × 16 $\rightarrow$ 24 + 000080h)<br>(Temp) $\div$ 256 $\rightarrow$ (Rd)                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| Mode Supported        | Rs,Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| Status Bits           | <ul> <li>Z set if the result is zero; cleared otherwise</li> <li>N equals the most significant bit of the result</li> <li>C cleared</li> <li>V cleared</li> </ul>                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Description           | Multiply the 8-bit value in the least significant byte of Rs <i>by</i> the 16-bit value in Rd. Add 000080h to the 24-bit intermediate product, and place the most significant word of the sum in Rd.                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                       | During the multiply, the most significant byte of Rs is ignored, and the contents of Rs are left unchanged.                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                       | The internal multiply is 8 bits x 16 bits, which generates a 24-bit intermediate result. Typically, this instruction is used when the 8-bit value in Rs is a fraction and Rd holds an integer. Hence, the product is a fixed point value with the integer portion in bits 8–23 and the fraction in bits 0–7. The value 000080h is added to this temporary product to round it back to an integer, yielding a rounded integer value in bits 8–23. This rounded result is then placed in Rd. |  |  |  |  |  |  |
| Examples              | <pre>label MPYBWU R7,R8 ; Multiply the LS byte of R7<br/>; by R8, then add 80h to the<br/>; product. Place the MS word<br/>; of this result in R8.</pre>                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| Instruction Execution | Detail                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|                       | MPYBWU       Rs, Rd         AC (w)       Rs       Rd         Cy       Address       Data       w b f d         1-6       prevA       (prevA)       1 0 1 1         7       OpA + 4       IEW       1 0 0 0                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |

| Syntax          | MPYS{B}                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Execution       | Rs value $\times$ (destination) $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| Modes Supported | Rs,Rd[byte only (8 × 8 $\rightarrow$ 16):Rs × Rd $\rightarrow$ Rd]Rs,IM:Rd[word only (16 × 16 $\rightarrow$ 32):Rs × Rd $\rightarrow$ IM:Rd]                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| Status Bits     | <ul> <li>Z set if the product is zero; cleared otherwise</li> <li>N equals the most significant bit of the product</li> <li>C cleared</li> <li>V cleared</li> </ul>                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
| Description     | Perform a multiply of the signed contents of the destination register by the signed contents of the source register. The product of byte multiplication is placed in the destination register. The most significant word of the product of word multiplication is placed in the <i>IM</i> register, and the least significant word is placed in the destination register.                                                                             |  |  |  |  |  |  |  |
|                 | The result assignment sequence places the most significant word of the prod-<br>uct in the <i>IM</i> first and the least significant word to <i>Rd</i> second. If <i>Rd</i> is <i>also IM</i><br>(for example, <b>MPYS</b> <i>Rs</i> , <i>IM:IM</i> ), then the most significant word in <i>IM</i> is overwrit-<br>ten by the least significant word.                                                                                                 |  |  |  |  |  |  |  |
|                 | Signed overflow on a multiple occurs when the product cannot be successfully truncated to the size of the operands without data loss. For <b>MPYSB</b> , this occurs when bits 15–7 of the product are not equal, and for <b>MPYS</b> when bits 31–15 of the product are not equal. To detect this condition, follow an MPYS instruction with a TRUNCS instruction. This sequence will leave V[ST] and N[ST] correctly set for such signed overflows. |  |  |  |  |  |  |  |
|                 | Status bits are set with respect to the size (word or longword) of the product.                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
| Examples        | LABEL MPYSB R3,R4 ; Multiply (signed) the LS bytes<br>; of R3 and R4. Store result in<br>; R4.<br>MULT MPYS R8,IM:R9 ; Multiply (signed) R8 by R9.<br>; Place result in the concat-<br>; tenated IM:R9 register pair.                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |

## MPYS Rs,IM:Rd

A6 (w) Rs Rd

MPYSB Rs,Rd

A7 (w) Rs Rd

|      | I       | $Rd \ge 0$ |      |         | Rd < 0  |      |    |         | $Rd \ge 0$           |      |         | Rd < 0                 |      |
|------|---------|------------|------|---------|---------|------|----|---------|----------------------|------|---------|------------------------|------|
| Су   | Address | Data       | wbfd | Address | Data    | wbfd | Су | Address | Data                 | wbfd | Address | Data                   | wbfd |
| 1-12 | prevA   | (prevA)    | 1011 | prevA   | (prevA) | 1011 | 1  | prevA   | (prevA)              | 1011 | prevA   | (prevA)                | 1011 |
| 13   | OpA + 4 | IEW        | 1000 | prevA   | (prevA) | 1011 | 2  | prevA   | $Rd_{LSB} 	imes 256$ | 0011 | prevA   | Rd <sub>LSB</sub> x256 | 0011 |
| 14   |         |            |      | OpA + 4 | IEW     | 1000 | 38 | prevA   | (prevA)              | 1011 | prevA   | (prevA)                | 1011 |
|      |         |            |      |         |         |      | 10 | OpA + 4 | IEW                  | 1000 | prevA   | $Rd_{LSB} 	imes 256$   | 1011 |
|      |         |            |      |         |         |      | 11 |         |                      |      | OpA + 4 | IEW                    | 1000 |

# MPYU Multiply, Unsigned

| Syntax          | MPYU{B}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Execution       | Rs value $\times$ (destination) $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
| Modes Supported | $Rs,Rd$ [byte only (8 × 8 $\rightarrow$ 16): $Rs × Rd \rightarrow Rd$ ] $Rs,IM:Rd$ [word only (16 × 16 $\rightarrow$ 32): $Rs × Rd \rightarrow IM:Rd$ ]                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| Status Bits     | <ul> <li>Z set if the product is zero; cleared otherwise</li> <li>N equals the most significant bit of the product</li> <li>C cleared</li> <li>V cleared</li> </ul>                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
| Description     | Perform an unsigned multiply of the unsigned contents of the destination register by the unsigned contents of the source register. The product of <i>byte</i> multiplication is placed in the destination register. The most significant word of the product of <i>word</i> multiplication is placed in the <i>IM</i> register, and the least significant word in the destination register.                                                                                                |  |  |  |  |  |  |  |
|                 | The result assignment sequence places the most significant word of the product in register <i>IM</i> first and then the least significant word to <i>Rd</i> second. If <i>Rd</i> is also the <i>IM</i> (for example, <b>MPYU</b> <i>Rs</i> , <i>IM:IM</i> ), then the most significant word in <i>IM</i> is overwritten by the least significant word.                                                                                                                                     |  |  |  |  |  |  |  |
|                 | Unsigned overflow on a multiply occurs when the product cannot be successfully truncated to the size of its operands without data loss. For <b>MPYUB</b> , this occurs when bits 15–8 of the product are not zero and for <b>MPYU</b> when bits 31–16 of the product are not zero. To detect this condition, follow an MPYUB instruction with a TRUNCU instruction, or follow an MPYU instruction with a CMP <i>IM,ZR</i> . These sequences will leave C[[ST]]=1 for the signed overflows. |  |  |  |  |  |  |  |
|                 | Status bits are set with respect to the size (word or longword) of the product.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
| Examples        | <pre>label mpyub r3,r4 ; Multiply (unsigned) the LS ; bytes of R3 and R4. Store ; the result in R4. ;</pre>                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
|                 | <pre>mult mpyu r8,IM:r9 ; Multiply (unsigned) R8 by R9. ; Store results in the IM:r9 ; concatenated register pair.</pre>                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |

|      | MPYU    | Rs,Rd   |      | MP | /UB <i>Rs</i> , | IM:Rd                |      |
|------|---------|---------|------|----|-----------------|----------------------|------|
|      | A4 (w)  | Rs      | ٩d   | A5 | (b) <i>R</i> e  | Rd                   |      |
| Су   | Address | Data    | wbfd | Су | Address         | Data                 | wbfd |
| 1–12 | prevA   | (prevA) | 1011 | 1  | prevA           | (prevA)              | 1011 |
| 13   | OpA + 4 | IEW     | 1000 | 2  | prevA           | $Rd_{LSB} 	imes 256$ | 0011 |
|      |         |         |      | 38 | prevA           | (prevA)              | 1011 |
|      |         |         |      | 8  | OpA + 4         | IEW                  | 1000 |

| Syntax         | NOP                                                                                       | Synthetic Instruction                     | on: Executes as | SBIT0 | #15,ZR |  |  |  |
|----------------|-------------------------------------------------------------------------------------------|-------------------------------------------|-----------------|-------|--------|--|--|--|
| Execution      | zero → bit 15 of ZR<br>(same as SBIT0 <i>#15,ZR</i> )                                     |                                           |                 |       |        |  |  |  |
| Mode Supported | Operand not necessary for NOP                                                             |                                           |                 |       |        |  |  |  |
| Status Bits    | <ul><li>Z unchanged</li><li>N unchanged</li><li>C unchanged</li><li>V unchanged</li></ul> |                                           |                 |       |        |  |  |  |
| Description    | •                                                                                         | ration; CPU state is instruction address. | • •             |       |        |  |  |  |
| Example        | DEL                                                                                       | AY NOP                                    | ; Causes one    | cycle | delay  |  |  |  |

| NOP<br>(SBIT0 #15,ZR) |         |      |         |  |  |  |
|-----------------------|---------|------|---------|--|--|--|
| [                     | 92      | 1111 | 2 11112 |  |  |  |
| Су                    | Address | Data | wbfd    |  |  |  |
| 1                     | opA + 4 | IEW  | 1000    |  |  |  |

| Syntax         | NOT{B}                                                      | Synthet                                                                                                                                                                                     | ic Instruction | : Executes as                      | XNOR{B] | ZR,Rd  |
|----------------|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------------------------|---------|--------|
| Execution      | NOT((source) XOR (destination)) $\rightarrow$ (destination) |                                                                                                                                                                                             |                |                                    |         |        |
|                | (executes                                                   | s same as                                                                                                                                                                                   | SXNOR{B}       | ZR,Rd)                             |         |        |
| Mode Supported | Rd                                                          |                                                                                                                                                                                             |                |                                    |         |        |
| Status Bits    | N equa                                                      | s the mos<br>anged                                                                                                                                                                          |                | red otherwise<br>bit of the result |         |        |
| Description    | XOR (ex                                                     | form a ones complement on the destination register's contents. Effectively,<br>R (exclusively OR) the Rd with the all-zero ZR, then take a ones<br>nplement of the result (XNOR the Rd).    |                |                                    |         |        |
|                | ated on a                                                   | For byte operations, the byte operands are zero-extended to words, are oper-<br>ated on as words, and produce a word result. The most significant byte of the<br>result will always be FFh. |                |                                    |         |        |
|                | Status bit                                                  | us bits are set with respect to the size (byte or word) of the operation.                                                                                                                   |                |                                    |         |        |
| Examples       | label<br>Invert                                             | NOTB<br>NOT                                                                                                                                                                                 | IM<br>R12      | ; Invert LS<br>;<br>: Invert R1    | -       | the IM |
|                | Invert                                                      | NOT                                                                                                                                                                                         | R12            | ; Invert R1                        | .2      |        |

| NOT{B} Rd<br>(XNOR{B} ZR,Rd) |           |          |      |  |  |  |
|------------------------------|-----------|----------|------|--|--|--|
| [                            | 2C (w) 2D | (b) 1111 | 2 Rd |  |  |  |
| Су                           | Address   | Data     | wbfd |  |  |  |
| 1                            | OpA + 4   | IEW      | 1000 |  |  |  |

| Syntax          | OR{B}                                                                                                                                                                                                                                                                                                            |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | (source) OR (destination) $\rightarrow$ (destination)                                                                                                                                                                                                                                                            |
| Modes Supported | Rs,Rd<br>Rs,*disp16[Rd]<br>#imm16,Rd<br>#imm16,*disp16[Rd]                                                                                                                                                                                                                                                       |
| Status Bits     | <ul> <li>Z set if the result is zero; cleared otherwise</li> <li>N equals the most significant bit of the result</li> <li>C unchanged</li> <li>V cleared</li> </ul>                                                                                                                                              |
| Description     | Logically inclusive OR the contents of the source operand with the contents of the destination operand.                                                                                                                                                                                                          |
|                 | For byte operations, the byte operands are zero-extended to words, are<br>operated on as words, and produce a word result. The most significant byte<br>of the result will always be 00h. Nonregister destinations receive the least<br>significant byte of the result, while registers receive the entire word. |
|                 | Status bits are set with respect to the size (byte or word) of the operation.                                                                                                                                                                                                                                    |
| Examples        | Label OR R5,R6 ; Logically OR the contents of<br>; R5 and R6. Store the value<br>; in R6.<br>;                                                                                                                                                                                                                   |
|                 | Set_2 ORB #4h,&FLAG Set bit 2 of location FLAG.                                                                                                                                                                                                                                                                  |
|                 | ;<br>Set_8 OR #EIGHT,&Flag ; OR mask value EIGHT with<br>; location Flag.                                                                                                                                                                                                                                        |

|   | OR{       | B}    | Rs,Rd | OR{B               | Rs,*disp          | 016[Rd]      | OR{B      | } #imm  | 16,Rd      | OR{B}                | timm16,*dis | p16[Rd]      |
|---|-----------|-------|-------|--------------------|-------------------|--------------|-----------|---------|------------|----------------------|-------------|--------------|
|   | 48 (w) 49 | 9 (b) | Rs Rd | 4A (w)             | 4B (b) R          | s Rd         | 4C (w) 4[ | ) (b) V | / Rd       | 4E (w)               | 4F (b)      | 🖊 Rd         |
| • |           |       |       |                    | disp16            |              |           | imm16   | <i>i</i> a |                      | disp16      |              |
|   |           |       |       |                    |                   |              |           |         |            |                      | imm16       |              |
| 7 | Address   | Data  | wbīd  | Address            | Data              | wbfd         | Address   | Data    | wbfd       | Address              | Data        | wbfd         |
| 1 | OpA + 4   | IEW   | 1000  | OpA+4              | IW                | 1001         | OpA + 4   | w       | 1001       | OpA + 4              | data        | 1001         |
|   |           |       |       | disp + Rd          | (disp + Rd)       | 1511         | OpA + 6   | IEW     | 1000       | disp + Rd            | (disp + Rd) | 1511         |
|   |           |       |       |                    |                   |              |           |         |            |                      |             |              |
|   |           |       |       | prevA              | (prevA)           | 1011         | 1         |         |            | OpA+6                | IW          | 1001         |
|   |           |       |       | prevA<br>disp + Rd | (prevA)<br>result | 1011<br>0S11 |           |         |            | OpA + 6<br>disp + Rd | result      | 1001<br>0511 |

| Syntax         | POP                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution      | FOR INDEX = Register_Last to Register_First BY –1,<br>DO (SP) – 2 $\rightarrow$ (SP)<br>((SP)) $\rightarrow$ (register <sub>(index)</sub> )                                                                                                                                                                                                                                                                                                                    |
| Mode Supported | RL, RF (Register_Last and Register_First; Required: $RL \ge RF$ )                                                                                                                                                                                                                                                                                                                                                                                              |
| Status Bits    | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                                                                                                                                 |
| Description    | Starting at the SP value, pull words from the system stack into the register(s) starting with $R_L$ (Register_Last) through and including $R_F$ (Register_First). The enumerator of $R_L$ must be arithmetically greater than or equal to the enumerator of $R_F$ (for example, POP R7,R5 is valid because $7 \ge 5$ ).<br>This instruction is most efficiently used for minimizing code space and                                                             |
|                | execution time when restoring CPU context. It is faster than multiple MOV *-SP,Rd instructions and consumes only two bytes of program memory.                                                                                                                                                                                                                                                                                                                  |
|                | If the SP (R13) is included in the <i>RL</i> - <i>RF</i> range, the value retrieved and placed<br>into the SP will take effect immediately and will direct the retrievals of any<br>remaining registers in the range. Care must be taken to ensure that the SP<br>value on the system stack will not corrupt the current context. A matched pair<br>of instructions, PUSH RF,RL and POP RL,RF, executes correctly when the SP<br>is included within the range. |
| Example        | Label POP R12,R2 ; Pop the contents of the Stack<br>; into registers R12 to R2                                                                                                                                                                                                                                                                                                                                                                                 |

|                          | P       | op <i>rl,r</i> | F    |
|--------------------------|---------|----------------|------|
|                          | FA      | R              | RF   |
| Cyt                      | Address | Data           | wbfd |
| n <sub>1</sub>           | prevA   | (prevA)        | 1011 |
| n2                       | SP - 2n | (SP - 2n)      | 1011 |
| n <sub>2</sub><br>2n + 1 | OpA + 4 | IEW            | 1000 |

<sup>†</sup> Both n<sub>1</sub> and n<sub>2</sub> are repeated during the exchange of one stack register to memory. The total number of exchanges (stack words stored) is multiplied by 2 and incremented for the cycle total (last line).

| Syntax         | PUSH                                                                                                                                                                                                                                                                                                                               |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Execution      | FOR <i>index</i> = Register_First to Register_Last BY +1,<br>DO (register <sub>(index)</sub> ) → ((SP))<br>(SP) + 2 → (SP)                                                                                                                                                                                                         |  |  |
| Mode Supported | $R_F, R_L$ (Register_First and Register_Last; Required: $R_L \ge R_F$ )                                                                                                                                                                                                                                                            |  |  |
| Status Bits    | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                     |  |  |
| Description    | Push register contents onto the system, stack starting at the SP value.<br>Registers to push are from $R_F$ (register_first) through and including $R_L$ (register_last). The enumerator of $R_L$ must be arithmetically greater than or equal to the enumerator of $R_F$ (for example, PUSH $R5,R7$ is valid because $7 \ge 5$ ). |  |  |
|                | This instruction is most efficiently used for minimizing code space and execution time when saving CPU contexts. It is always faster than multiple MOV Rs,*SP+ instructions and consumes only two bytes of program memory.                                                                                                         |  |  |
| Example        | SAVE PUSH R6,R3 ; Push the contents of R6, R5,<br>; R4, and R3 onto the Stack                                                                                                                                                                                                                                                      |  |  |

| [                 | PUS         | H <i>RF,R</i> | Ľ    |
|-------------------|-------------|---------------|------|
|                   | F9          | RF            | RL   |
| Cyt               | Address     | Data          | wbfd |
| n<br>(repeat)     | SP + 2(n-1) | (reg)         | 0011 |
| (repeat)<br>n + 1 | OpA + 4     | IEW           | 1000 |

†The n is the number of register-to-stack exchanges.

| Syntax         | RTDU                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution      | $(FP) - 2 \rightarrow (SP)$<br>$((FP)) \rightarrow (FP)$<br>$((SP)) \rightarrow (PC)$<br>$(SP) - 2displacement \rightarrow (SP)$                                                                                                                                                                                                                                                                                  |
| Mode Supported | disp8                                                                                                                                                                                                                                                                                                                                                                                                             |
| Status Bits    | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                                                                                    |
| Description    | <ol> <li>Unlink and deallocate the current system stack frame:</li> <li>Load SP with the contents of the frame pointer (FP),</li> <li>Retrieve the previous value of FP from the system stack,</li> <li>Pull the return address from the system stack and place it in the PC, and</li> <li>Deallocate additional stack space by subtracting the 8-bit unsigned word displacement from the value of SP.</li> </ol> |
|                | Note that since the 8-bit value is a word displacement, it is internally multiplied by two to generate an even value and to keep the SP word aligned.                                                                                                                                                                                                                                                             |
|                | The return address is a <i>word address</i> that is transformed to a 17-bit physical memory address, via the program counter, by overlaying data bits 15–0 onto address lines A16–A1 and forcing A0 to 0. This instruction can be a return mechanism for a CALL subroutine <i>if and only if</i> the subroutine executed a LINK instruction and did not execute an UNLINK instruction.                            |

|    | RT        | DU dis    | p8    |
|----|-----------|-----------|-------|
|    | F8        |           | disp8 |
| Су | Address   | Data      | wbfd  |
| 1  | prevA     | (prevA)   | 1011  |
| 2  | FP        | old FP    | 1011  |
| 3  | FP - 2    | Rtn A ÷ 2 | 1011  |
| 4  | Rtn A     | IW        | 1001  |
| 5  | Rtn A + 2 | IEW       | 1000  |

| Syntax          | RTI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | $\begin{array}{l} (SP) - 2 \rightarrow (SP) \\ ((SP)) \rightarrow \langle PC \rangle \\ (PC) - 2 \rightarrow (PC) \\ (SP) - 2 \rightarrow (SP) \\ ((SP)) \rightarrow (ST) \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Modes Supported | Operand not necessary for RTI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Status Bits     | <ul> <li>reflects the status data pulled from the system stack</li> <li>reflects the status data pulled from the system stack</li> <li>reflects the status data pulled from the system stack</li> <li>reflects the status data pulled from the system stack</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                |
| Description     | Return from interrupts/exceptions by pulling the return address off the system stack into the PC, then pulling the previous status data off the system stack into the ST, and then enabling nonmaskable interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                 | This instruction is designed to be the return mechanism for peripheral interrupts, TRAPs, or illegal opcodes and their associated exception handling software. The PC must be decremented because interrupts/exceptions leave on the stack a PC value that points two words (four bytes) beyond the address of the next executable instruction in the interrupted stream. This effect is due to the pipeline prefetch of the CPU. The return address is a <i>word address</i> that is transformed to a 17-bit physical memory address, via the program counter, by overlaying data bits 0 to 15 onto address lines A16–A1 and forcing line A0 to a 0. |
| Example         | RETURN RTI ; Return to point of program<br>; flow when the interrupt<br>; occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

|        |           | RTI          |      |
|--------|-----------|--------------|------|
|        | FC        | > ///        |      |
| Су     | Address   | Data         | wbfd |
| 1      | prevA     | (prevA)      | 1011 |
| 2      | SP - 2    | (RtnA+4) ÷ 2 | 1011 |
| 3      | prevA     | (prevA)      | 1011 |
| 4<br>5 | Rtn A     | IW           | 1001 |
| 5      | SP - 4    | old ST       | 1011 |
| 6      | Rtn A + 2 | IEW          | 1000 |

| Syntax                | RTS                                                                                                                                                                                                                                                                                                                        |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution             | (SP) – 2 → (SP)<br>((SP)) → (PC)                                                                                                                                                                                                                                                                                           |
| Modes Supported       | Operand not necessary for RTS                                                                                                                                                                                                                                                                                              |
| Status Bits           | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                             |
| Description           | Return from a subroutine by pulling the return address off the system stack into the PC. RTS uses the return linkage created by the CALL and normally is the final instruction of a subroutine entered through the CALL instruction.                                                                                       |
|                       | CALL and RTS work together to enter a subroutine and then later return to the instruction following the CALL when the subroutine is exited. The CALL instruction sets up this linkage by placing the PC value (a value that points to the instruction following the CALL) onto the stack before the subroutine is entered. |
|                       | The return address is a <i>word address</i> that is transformed to a 17-bit physical memory address, via the program counter, by overlaying data bits $0 - 15$ onto address lines A1 - A16 and forcing A0 to 0. This is illustrated in the CALL/RTS example in Figure 5-4 on page 5-35.                                    |
| Example               | Return_1 RTS ; Return to the instruction<br>; immediately following the<br>; subroutine call.                                                                                                                                                                                                                              |
| Instruction Execution | Detail                                                                                                                                                                                                                                                                                                                     |

| RTS |
|-----|
| FB  |

| Су | Address | Data      | wbfd |
|----|---------|-----------|------|
| 1  | prevA   | (prevA)   | 1011 |
| 2  | SP - 2  | Rtn A ÷ 2 | 1011 |
| 3  | RtnA    | IW        | 1001 |
| 4  | RtnA+2  | IEW       | 1000 |

| Syntax          | SBB                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution       | (destination) – (source) – carry-bit value $\rightarrow$ (destination)                                                                                                                                                                                                                                 |  |  |  |  |  |
| Modes Supported | Rs,Rd<br>*disp16[Rs],Rd                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| Status Bits     | <ul> <li>Z set if the result is zero; unchanged otherwise</li> <li>N equals the most significant bit of the result</li> <li>C set if an unsigned underflow occurred; cleared otherwise</li> <li>V set if a twos complement underflow occurred; cleared otherwise</li> </ul>                            |  |  |  |  |  |
| Description     | Subtract the contents of the source operand, less the value of C[[ST]], from the destination register.                                                                                                                                                                                                 |  |  |  |  |  |
|                 | This instruction is designed to aid 32-bit subtraction. A SUB will subtract the least significant words, and then a following SBB will subtract the most significant words. Since the SBB instruction recognizes a previous underflow/borrow (C[ST]), the SUB and SBB instructions must be sequential. |  |  |  |  |  |
|                 | SBB handles Z[[ST]] correctly for 32-bit subtraction. The Z[[ST]] bit is set if and only if the previous operation (typically a SUB) set it. Therefore, all status bits will reflect a 32-bit result after a SUB/SBB sequence of instructions is executed.                                             |  |  |  |  |  |
| Example         | <pre>label sbb ZR,R2 ; Subtract the carry bit value<br/>; from R2. This is a conditional<br/>; decrement of R2 depending<br/>; contents of carry bit.</pre>                                                                                                                                            |  |  |  |  |  |
|                 | <pre>sbb R5,R3 ; Subtract R5 value minus carry<br/>; bit from R3. Result to R3.<br/>sbb *10h[ZR],r1 ; Subtract 10h minus the carry<br/>; bit from R1. Result to R1.</pre>                                                                                                                              |  |  |  |  |  |

|    | SI      | 3B <i>Rs</i> ,F | Rd   | SBB                  | *disp16[Rs],Rd     |      |  |
|----|---------|-----------------|------|----------------------|--------------------|------|--|
|    | 8C(w)   | F               | s Rd | 8D(v                 | r) Rs<br>disp16    | i Rd |  |
| Су | Address | Data            | wbfd | Address              | Data               | wbfd |  |
| 1  | OpA + 4 | IEW             | 1000 | OpA + 4              | w                  | 1001 |  |
| 2  |         |                 |      | disp + Rs<br>OpA + 6 | (disp + Rs)<br>IEW | 1011 |  |

| Syntax                | SBIT0{B}                                                                                                                                                                                                                                                                                                                                                |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution             | 0 (zero value) $\rightarrow$ (bit in destination) (bit number specified in source)                                                                                                                                                                                                                                                                      |
| Modes Supported       | #imm4,Rd (word only)<br>#imm4,*disp16[Rd] (byte only)<br>Rs,Rd (word only)<br>Rs,*disp16[Rd] (byte only)                                                                                                                                                                                                                                                |
| Status Bits           | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                          |
| Description           | Clear to 0 a specified bit in the destination. The source value (0–7 for byte,<br>0–15 for word) specifies which bit to clear in the destination, numbered as<br>shown:<br><u>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</u><br><u>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</u><br>Note that a zero (not the letter O) follows SBIT in the mnemonic. The source |
|                       | value is contained in the 4 least significant bits of a register or in bits 4–7 of the instruction word when an immediate value. If the bit designation value for a byte is in the range 8–15, the instruction performs a <i>read, no-modify, write</i> sequence.                                                                                       |
| Examples <b>a</b>     | Clear bit 4 of register R7: the first example demonstrates an immediate value, and the second demonstrates a register as a source.                                                                                                                                                                                                                      |
|                       | LABEL SBITO #4,R7 ; Clear 5th bitfromright<br>;or<br>MOV #4,R6 ; Immediate bit valuetoR6<br>SBITO R6,R7 ; Clear 5th bitfrom right                                                                                                                                                                                                                       |
| Instruction Execution | Detail                                                                                                                                                                                                                                                                                                                                                  |

#### SBITOB ſ SBITO #imm4 Rd SBITO Rs Rd

| SBIT0 #imm4,Rd | SBITO <i>Rs,Rd</i> | SBIT0B<br>#imm4,*disp16[Rd] | SBIT0B Rs,*disp16[Rd] |
|----------------|--------------------|-----------------------------|-----------------------|
| 92 (w) Imm4 Rd | E2 (w) Rs Rd       | 93 (b) imm4 Rd              | E3 (b) Rs Rd          |
|                |                    | disp16                      | disp16                |

| Су | Address | Data | wbfd | Address | Data    | wbfd | Address   | Data        | wbfd | Address   | Data        | wbfd |
|----|---------|------|------|---------|---------|------|-----------|-------------|------|-----------|-------------|------|
| 1  | OpA + 4 | IEW  | 1000 | prevA   | (prevA) | 1011 | prevA     | (prevA)     | 1011 | prevA     | (prevA)     | 1011 |
| 2  |         |      |      | OpA + 4 | IEW     | 1000 | disp + Rd | (disp + Rd) | 1111 | prevA     | (prevA)     | 1011 |
| 3  |         |      |      |         |         |      | OpA + 6   | IW          | 1010 | disp + Rd | (disp + Rd) | 1111 |
| 4  |         |      |      |         |         |      | disp + Rd | result      | 0111 | OpA + 4   | w           | 1001 |
| 5  | [       |      |      |         |         | 1    | OpA + 6   | IEW         | 1000 | disp + Rd | result      | 0111 |
| 6  |         |      |      |         |         |      |           |             |      | OpA + 6   | IEW         | 1000 |

#### SBIT1 Set Bit to One

| Syntax          | SBIT1{B}                                                                                  |                                                                                                                                                                          |
|-----------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | 1 $\rightarrow$ (bit in destination)                                                      | (bit number specified by source)                                                                                                                                         |
| Modes Supported | #imm4,Rd<br>#imm4,*disp16[Rd]<br>Rs,Rd<br>Rs,*disp16[Rd]                                  | (word only)<br>(byte only)<br>(word only)<br>(byte only)                                                                                                                 |
| Status Bits     | <ul><li>Z unchanged</li><li>N unchanged</li><li>C unchanged</li><li>V unchanged</li></ul> |                                                                                                                                                                          |
| Description     | -                                                                                         | e destination. The source value (0–7 for byte, 0–15<br>it to set in the destination, numbered the same as<br>n.                                                          |
|                 | bits 4–7 of the instruction w                                                             | ned in the 4 least significant bits of a register or in<br>ord when an immediate value. If the bit designation<br>a range 8–15, the instruction performs a <i>read</i> , |
| Examples        | Set to 1 the sign bit for the                                                             | (word) value in register R7:                                                                                                                                             |
|                 | LABEL SBIT1                                                                               | #15,R7                                                                                                                                                                   |
|                 | Set to 1 the sign bit for the                                                             | (byte) value in address 0701h:                                                                                                                                           |
|                 | LABEL SBIT1B                                                                              | #7,&701h                                                                                                                                                                 |

## **Instruction Execution Detail**

| SBIT1 # imm4,Rd | SBIT1 <i>Rs,Rd</i> | SBIT1B<br>#imm4,*disp16[Rd] | SBIT1B Rs,*disp16[Rd] |
|-----------------|--------------------|-----------------------------|-----------------------|
| 90 (w) imm4 Rd  | E0 (w) Rs Rd       | 91 (b) imm4 Rd              | E1 (b) Rs Rd          |

dis + Rd

OpA + 6

result

IEW

0111

1000

|    |         |      |      |         |         | disp16 |           |           | disp16 |           |                 |      |
|----|---------|------|------|---------|---------|--------|-----------|-----------|--------|-----------|-----------------|------|
| Су | Address | Data | wbfd | Address | Data    | wbfd   | Address   | Data      | wbfd   | Address   | Data            | wbfd |
| 1  | OpA + 4 | IEW  | 1000 | prevA   | (prevA) | 1011   | prevA     | (prevA)   | 1011   | prevA     | (prevA)         | 1011 |
| 2  |         |      |      | OpA + 4 | IEW     | 1000   | disp + Rd | (disp+Rd) | 1111   | prevA     | (prevA)         | 1011 |
| 3  |         |      |      |         |         |        | OpA + 4   | IW        | 1001   | disp + Rd | (disp + Rd<br>) | 1111 |
| 4  |         |      |      |         |         |        | disp + Rd | result    | 0111   | OpA + 4   | w               | 1001 |

OpA + 6

IEW

1000

5

6

| Syntax          | SHL{L}                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | shift left the destination register(                                                                                                                                                                                                                                                   | s) by source count $\rightarrow$ (destination register(s))                                                                                                                                                                                                                                                                                                                                                                  |
| Modes Supported | #imm4,Rd<br>#imm4,IM:Rd<br>Rs,Rd<br>Rs,IM:Rd                                                                                                                                                                                                                                           | (word)<br>(longword)<br>(word)<br>(longword)                                                                                                                                                                                                                                                                                                                                                                                |
| Status Bits     | destination's most significa<br>C set if a one is <i>ever</i> shifted                                                                                                                                                                                                                  | OR) of the V $[ST]$ bit after a shift with the                                                                                                                                                                                                                                                                                                                                                                              |
| Description     | number of bit positions specified<br>vacated least significant bit(s).<br>operand contain the shift count<br>For <b>immediate</b> shifts, a source<br>shift count of 1 to 15; a source o<br>of 16. If an immediate shift cou<br>specified, the least-significant for<br>are assembled. | stination register's signed contents by the<br>I in the source operand. Shift zero(es) into the<br>The four least significant bits of the source<br>(range of $0-15$ ).<br>operand value of $0001_2$ to $1111_2$ indicates a<br>operand value of $0000_2$ indicates a shift count<br>unt of more than four bits (more than 15) is<br>our hexadecimal bits (of the value specified)<br>ment within the destination register: |



The illustration below depicts a longword shift using the concatenation of IM and Rd:



This instruction performs a mathematically correct multiply of the destination contents by a power of 2 ( $2^{1}-2^{16}$ ). Another way to view execution is as a series of identical additions of the destination contents to itself — one addition (or doubling of itself) for each bit shifted. All of the status bits are "sticky" (the value remains the same after each shift). If any normal ADD operation overflow conditions occur during the ADD repetitions, this will be reflected in the C[[ST]] or V[[ST]] condition code bits. The N[[ST]] bit is correct for a repetitive add and will always be cleared if a twos-complement overflow occurs on a negative number.

Status bits are set with respect to the size of the word shifted (16 or 32 bits). Longword shifts always use the IM as the most significant word of the 32-bit object. The result of SHL (source),IM:IM is undefined.



The N[ST] bit reflects an XOR of the sign bit before execution (a 1) and the V[ST] after execution (a 1 because the sign changed at least once).

| Word Instructions | (2 + <i>n</i> cycles) |
|-------------------|-----------------------|
|-------------------|-----------------------|

|                               | SH      | IL #imm- | 4,Rd | ]                 | SHL Rs,Rd |                |      |  |
|-------------------------------|---------|----------|------|-------------------|-----------|----------------|------|--|
|                               | B0 (w)  | limm     | 4 Rd | ]                 | B2 (v     | v) A           | s Rd |  |
| Cycle/<br>Period <sup>†</sup> | Address | Data     | wbfd | Cycle/<br>Period† | Address   | Data           | wbfd |  |
| 1                             | prevA   | (prevA)  | 1011 | 1,2               | prevA     | (prevA)        | 1011 |  |
| <i>n</i><br>(repeat)          | prevA   | (prevA)  | 1011 | n<br>(repeat)     | prevA     | (prevA)        | 1011 |  |
| n + 2                         | OpA+4   | IEW      | 1000 | n+2               | OpA+4     | IEW            | 1000 |  |
|                               |         |          |      |                   | To        | otal cycles: n | + 3  |  |

Longword Instructions (2 + 2n cycles)

| SHLL #imm4,IM:Rd | SHLL Rs,IM:Rd |
|------------------|---------------|
| B1 (L) Imm4 Rd   | B3 (L) Rs Rd  |

| Cycle/<br>Period†      | Address | Data    | wbfd | Cycle/<br>Period†      | Address | Data          | wbfd |
|------------------------|---------|---------|------|------------------------|---------|---------------|------|
| 1                      | prevA   | (prevA) | 1011 | 1, 2                   | prevA   | (prevA)       | 1011 |
| 2 <i>n</i><br>(repeat) | prevA   | (prevA) | 1011 | 2 <i>n</i><br>(repeat) | prevA   | (prevA)       | 1011 |
| 2 + 2n                 | OpA+4   | IEW     | 1000 | 2 + 2n                 | OpA+4   | IEW           | 1000 |
|                        |         |         |      |                        | Tot     | al cycles: 2n | + 3  |

<sup>†</sup> A single number represents a *given cycle*; an expression of *n* represents a *cycle* or *period of cycles*, depending on the *n*<sup>th</sup> number of shifts or repeats.

#### SHL4 Shift Left Logical Four Bits

| Syntax         | SHL4                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution      | source shifted four bits to left $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| Mode Supported | Rs,Rd                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| Status Bits    | <ul> <li>Set if the result is zero; otherwise cleared</li> <li>equals the result's most significant bit</li> <li>unchanged</li> <li>unchanged</li> </ul>                                                                                                                                                                                         |  |  |  |  |  |
| Description    | Logically left-shift the source register's contents four bit positions. Shift zero(es) into the four least significant bits. Place the results of the shift into the destination register. Execution changes <i>only Rd's contents</i> . This instruction effectively multiplies the contents of Rs by 16 and places the unsigned product in Rd. |  |  |  |  |  |

This can also be represented as shifting four zeroes into Rd and copying bits 11 – 0 of Rs into bits 15 – 4 of Rd as shown below:



|    | Sł      | IL4 Rs,I | Rd   |
|----|---------|----------|------|
| ÷  | 7A      | R        | s Ra |
| Су | Address | Data     | wbfd |
| 1  | prevA   | (prevA)  | 1011 |
| 2  | OpA + 4 | IEW      | 1000 |

| Syntax         | SHL8                                                                                                                                                 |  |  |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Execution      | source shifted eight bits to left $\rightarrow$ (destination)                                                                                        |  |  |  |  |
| Mode Supported | Rs,Rd                                                                                                                                                |  |  |  |  |
| Status Bits    | <ul> <li>Z set if the result is zero; otherwise, cleared</li> <li>N cleared</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                     |  |  |  |  |
| Description    | Logically left-shift the source register's cont<br>zero(es) into the eight least significant bits. Pla<br>the destination register. Execution change |  |  |  |  |

Logically left-shift the source register's contents eight bit positions. Shift zero(es) into the eight least significant bits. Place the results of the shift into the destination register. Execution changes *only Rd's contents*. This instruction effectively multiplies the contents of Rs by 256 and places the unsigned product in Rd.

This can also be represented as shifting eight zeroes into Rd and copying the LSbyte of the Rs into the MSbyte of Rd as shown below:



Essentially, the least significant byte of Rs (before shift) is placed in the most significant byte of Rd with the least significant byte of Rd cleared.

Example

LABEL SHL8 R6,R5

- ; Logically shift R6 left 8 bits
- ; then load the result into R5.
- ; Effectively this is a
- ; multiply of R6 by 256 with
- ; the result placed in R5.

|         | Sł                          | HL8 Rs,F        | Rd           |
|---------|-----------------------------|-----------------|--------------|
|         | 7B                          | R               | s Rd         |
|         |                             |                 |              |
| Су      | Address                     | Data            | wbfd         |
| Cy<br>1 | Address<br>prevA<br>OpA + 4 | Data<br>(prevA) | wbfd<br>1011 |

| Syntax         | SHR8                                                                                                                             |  |  |  |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Execution      | source shifted eight bits to right $\rightarrow$ (destination)                                                                   |  |  |  |  |
| Mode Supported | Rs,Rd                                                                                                                            |  |  |  |  |
| Status Bits    | <ul> <li>Z set if the result is zero; otherwise, cleared</li> <li>N cleared</li> <li>C unchanged</li> <li>V unchanged</li> </ul> |  |  |  |  |
| Description    | Logically right shift the source register's contant                                                                              |  |  |  |  |

**Description** Logically right-shift the source register's contents eight bit positions. Shift zero(es) into the register's most significant eight bits. Place the results of the shift into the destination register. Execution changes *only Rd's contents*. This instruction effectively divides the contents of Rs by 256 and places the unsigned quotient in Rd.

This can also be represented as shifting eight zeroes into Rd and copying the MSbyte of the Rs into the LSbyte of Rd as shown below:



Note that the most significant byte of Rs (before shift) is placed in the least significant byte of Rd with the least significant byte of Rd cleared.

Example

- ; Logically shift R6 right 8 bits
- ; then load the result into R5.
- ; Effectively this is a
- ; divide of R6 by 256 with
- ; result placed in R5.

#### Instruction Execution Detail

LABEL

|    | SF      | IR8 <i>Rs,I</i> | Rd   |
|----|---------|-----------------|------|
|    | 70      | R               | s Rd |
| Су | Address | Data            | wbfd |
| 1  | prevA   | (prevA)         | 1011 |
| 2  | OpA + 4 | IEW             | 1000 |

SHR8

R6,R5

| Syntax          | STBIT{B}                                                                                                               |                                                                                                                                                                                                                                                                   |  |  |  |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Execution       | ones complement the selected destination bit $\rightarrow$ (Z[ST])<br>(C[ST]) $\rightarrow$ (selected destination bit) |                                                                                                                                                                                                                                                                   |  |  |  |  |
| Modes Supported | #imm4,*disp16[Rd]<br>Rs,Rd<br>Rs,*disp16[Rd]<br>#imm4,Rd                                                               | (byte only)<br>(word only)<br>(byte only)<br>(word only)                                                                                                                                                                                                          |  |  |  |  |
| Status Bits     | <ul> <li>Z set if bit tested is 0; o</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>         | cleared if bit is 1                                                                                                                                                                                                                                               |  |  |  |  |
| Description     | manipulated (bit-number i                                                                                              | alue is the number of the <i>destination bit</i> to be<br>range of 0–7 or 0–15, depending on byte or word<br>bered as shown for the SBITO instruction on page<br>the is as follows:                                                                               |  |  |  |  |
|                 |                                                                                                                        | selected destination bit and store the ones comple-<br>the Z bit of the status register.                                                                                                                                                                          |  |  |  |  |
|                 |                                                                                                                        | ster's C bit value into the selected bit position in the                                                                                                                                                                                                          |  |  |  |  |
|                 | "available" indication is fou<br>in order to gain control of a                                                         | means to check a semaphore in memory. And, if an<br>und, the semaphore is then set to the needed value<br>a function (such as a bus, as shown in examples on<br>T1 and SBIT0 to set up the Z[ST] value).                                                          |  |  |  |  |
|                 |                                                                                                                        | eives the ones complement of the bit value, a zero use a branch by the instruction BEQ.                                                                                                                                                                           |  |  |  |  |
|                 | The source value is stored of a register.                                                                              | in bits 7–4 of the opcode or the least significant bits                                                                                                                                                                                                           |  |  |  |  |
|                 | and 0–15 for word with de<br>for <i>byte is 8–15</i> , a <i>read, n</i>                                                | e 0–7 for byte (destination a memory address <i>only</i> )<br>stination in a register. When the bit-selection value<br><i>o modify, write</i> sequence executes and the Z[[ST]]<br>re numbered as shown for the SBITO instruction on                              |  |  |  |  |
| Example         | STBIT instruction with a S<br>the following examples, ad<br>A 1 at bit 2 of the address in                             | ssible a semaphore test operation by preceding the<br>BIT1 or SBIT0 that sets or clears the C[[ST]] bit. In<br>dress 1000h is a dedicated word of 16 semaphores.<br>Indicates that a bus is busy. The following code polls<br>dicating that the bus is available: |  |  |  |  |

Wait for Zero at Semaphore (Loop Until a Zero Is Found at Bit 2 of 1000h):

LOOP SBIT1 #CARRY,ST ; Set CARRY bit = 1 #2,\*1000h[ZR] ; Is semaphore 0 yet? STBITB LOOP ; Loop until bit #2=0BNZ . . when bit #2 of 1000h = zero, STBIT sets ; . . the bit to one to hold the bus; now enter ; bus service routine and clear semaphore ; upon exit. ; . SBIT0 #2,\*1000h[ZR] ; Exit, clear semaphore

When the semaphore becomes a 0 (bus available), the STBIT instruction automatically sets it to a 1 (transfers the set C[ST] bit to the semaphore) to maintain bus possession by the new owner. When the bus is needed no longer, set the semaphore to 0 before exiting.

The bus-busy indicator could be the opposite of that above: a 0, with a loop needed to find a 1. In this case, the C[ST] bit is cleared (SBIT0), and the conditional branch loops on finding a 1 (inverted semaphore value).

Wait for One at a Semaphore (Loop Until a One Is Found at Bit 2 of 1000h):

| LOOP        | SBITO     | #CARRY,ST                        | ; Set CARRY bit = 0                                                       |
|-------------|-----------|----------------------------------|---------------------------------------------------------------------------|
|             | STBITB    | #2,#1000h[ZR]                    | ; Is semaphore 1 yet?                                                     |
|             | BEQ       | LOOP                             | Loop until bit #2=1                                                       |
| ;<br>;<br>; | obtained; | enter bus serv<br>ore upon exit. | <pre>= one, the bus can be ice routine then ; ; Exit, set semaphore</pre> |

|    | STBI    | T #imm  | 4,Rd | ST      | BIT <i>Rs</i> | ,Rd  | #imi      | STBITB<br>m4,*disp1 | 6[Rd] | STBITE    | 3 Rs,*disp  | 16[Rd] |
|----|---------|---------|------|---------|---------------|------|-----------|---------------------|-------|-----------|-------------|--------|
|    | 96 (w)  | imm     | 4 Rd | E6 (w   | i) Re         | Rd   | 97 (l     | •                   | m4 Rd | E7 (t     | I           | Rd     |
|    |         |         |      |         |               |      |           | disp16              |       |           | disp16      |        |
| Су | Address | Data    | wbfd | Address | Data          | wbfd | Address   | Data                | wbfd  | Address   | Data        | wbfd   |
| 1  | prevA   | (prevA) | 1011 | prevA   | (prevA)       | 1011 | prevA     | (prevA)             | 1011  | prevA     | (prevA)     | 1011   |
| 2  | OpA + 4 | IEW     | 1000 | prevA   | (prevA)       | 1011 | disp + Rd | (disp + Rd)         | 1111  | prevA     | (prevA)     | 1011   |
| 3  |         |         |      | OpA + 4 | IEW           | 1000 | prevA     | (prevA)             | 1011  | disp + Rd | (disp + Rd) | 1111   |
| 4  |         |         |      |         |               |      | OpA + 4   | iW                  | 1001  | prevA     | (prevA)     | 1011   |
| 5  |         |         |      |         |               |      | disp + Rd | result              | 0111  | OpA + 4   | w           | 1001   |
| 6  |         |         |      |         |               |      | OpA + 6   | IEW                 | 1000  | disp + Rd | result      | 0111   |
| 7  |         |         |      |         |               |      |           |                     |       | OpA + 6   | IEW         | 1000   |

| Syntax         | STEA                                                                                                                                                                                                           |  |  |  |  |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution      | $disp16 + (Rs) \rightarrow (Rd)$ $(Rd) + 2 \rightarrow (Rd)$                                                                                                                                                   |  |  |  |  |  |
| Mode Supported | *disp16[Rs],*Rd+                                                                                                                                                                                               |  |  |  |  |  |
| Status Bits    | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                 |  |  |  |  |  |
| Description    | Sum the <i>disp<sub>16</sub></i> value and the contents of <i>Rs</i> , and indirectly store this in the address pointed to by the destination register. Then increment the destination register contents by 2. |  |  |  |  |  |
| Example        | Given: $R4 = 0002h$ and $R5 = 8000h$ . The following code moves the value 6002h (the sum of the 6000h displacement and (R4)) into memory address 8000h and increments R5 to the value 8002h.                   |  |  |  |  |  |

Label STEA \*6000h[r4],\*r5+

|       | Before | After         |
|-------|--------|---------------|
| R4    | 0002   | R4 0 0 0 2    |
| R5    | 8000   | R5 8002       |
| 8000h | N/A    | 8000h 6 0 0 2 |

|    | STEA * disp16[Rs],*Rd+ |          |       |  |  |  |  |  |
|----|------------------------|----------|-------|--|--|--|--|--|
|    | F1                     | <u> </u> | is Rd |  |  |  |  |  |
|    |                        | disp16   |       |  |  |  |  |  |
| Ъy | Address                | Data     | wbfd  |  |  |  |  |  |
| 1  | OnA + 4                | IW       | 1001  |  |  |  |  |  |

| Су | Address | Data      | wbfd |
|----|---------|-----------|------|
| 1  | OpA + 4 | IW        | 1001 |
| 2  | Rd      | disp + Rs | 0011 |
| 3  | OpA + 6 | IEW       | 1000 |

| Syntax         | STRI                                                                                                                                                                                                                                                          |  |  |  |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution      | (ST) → ( <i>Rd</i> )<br><i>imm4</i> → (4 LS bits of the ST)                                                                                                                                                                                                   |  |  |  |  |  |
| Mode Supported | #imm4,Rd                                                                                                                                                                                                                                                      |  |  |  |  |  |
| Status Bits    | ZclearedNclearedCclearedVcleared                                                                                                                                                                                                                              |  |  |  |  |  |
| Description    | Store the contents of the ST into <i>Rd</i> . Then copy the three LSBs of <i>imm4</i> into the <b>three interrupt-level bits</b> of the ST and clear its Z, N, C, and V bits.<br>The most significant byte of the ST is undefined because of ST reserved bits |  |  |  |  |  |
|                | (these bits are undefined when read and don't retain data when written to).                                                                                                                                                                                   |  |  |  |  |  |
| Example        | Label STRI #01h,R2 ; Store the ST into R2, then<br>; set the 2 LS bits of the<br>; ST to 01b (01 binary).                                                                                                                                                     |  |  |  |  |  |

|    | STRI             | #imm4,I | Rd   |
|----|------------------|---------|------|
|    | A9               | imm4    | Rd   |
| Су | Address          | Data    | wbfd |
| 1  | prevA<br>OpA + 4 | (prevA) | 1011 |
| 2  | OpA + 4          | IEW     | 1000 |

## SUB Subtract Source From Destiniation

| Syntax          | SUB{B}                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution       | (destination) – (source) $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| Modes Supported | Rs,Rd<br>#imm16,Rd<br>*disp16[Rs],Rd<br>Rs,*disp16[Rd]                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| Status Bits     | <ul> <li>Z set if the result is zero; cleared otherwise</li> <li>N equals the most significant bit of the result</li> <li>C set if an unsigned underflow occurred; cleared otherwise</li> <li>V set if a twos complement underflow occurred; cleared otherwise</li> </ul>                                                                  |  |  |  |  |  |
| Description     | Subtract the contents of the source operand from the destination operand.<br>Source contents are left unchanged.                                                                                                                                                                                                                           |  |  |  |  |  |
|                 | For byte operations, the byte operands are zero-extended to words, are operated on as words, and produce a word result. The most significant byte of the result will be either 00h for C[[ST]]=0 or FFh for C[[ST]]=1. Nonregister destinations receive the least significant byte of the result, while registers receive the entire word. |  |  |  |  |  |
|                 | Status bits are set with respect to the size (byte or word) of the operation.                                                                                                                                                                                                                                                              |  |  |  |  |  |
| Example         | label SUB R5,R8 ; Subtract contents of R5 from ; R8. Store result in R8.                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|                 | <pre>sbtrct SUB R10,&amp;LAST Subtract contents of R10 from ; the value in location LAST. ; Leave results in LAST.</pre>                                                                                                                                                                                                                   |  |  |  |  |  |
|                 | SUBB #5,R2 ; Subtract 5 from R2 contents,<br>; and set MSbyte of R2 = 00h.                                                                                                                                                                                                                                                                 |  |  |  |  |  |

|    | SUB{B} Rs,Rd |               |       | SUB{B   | JB{B} #imm <sub>16</sub> ,Rd SUB{B} *disp <sub>16</sub> [Rs] |       | 'Rs],Rd   | d SUB{B} Rs,*disp <sub>16</sub> [Rd] |      |           |                    |          |
|----|--------------|---------------|-------|---------|--------------------------------------------------------------|-------|-----------|--------------------------------------|------|-----------|--------------------|----------|
|    | 38(w) 3      | 9(b) <i>F</i> | ls Rd | 3C(w) 3 | D(b)                                                         | // Rd | 3E(w)     | 3F(b) R                              | s Rd | 3A(w) 3   | B(b) Rs            | Rd       |
|    |              |               |       |         | imm <sub>16</sub>                                            |       |           | disp <sub>16</sub>                   |      |           | disp <sub>16</sub> |          |
| Су | Address      | Data          | wbfd  | Address | Data                                                         | wbfd  | Address   | Data                                 | wbfd | Address   | Data               | wbfd     |
| 1  | OpA + 4      | IEW           | 1000  | OpA + 4 | IW                                                           | 1001  | OpA + 4   | IW                                   | 1001 | OpA + 4   | IW                 | 1001     |
| 2  |              |               |       | OpA + 6 | IEW                                                          | 1000  | disp + Rs | (disp + Rs)                          | 1511 | disp + Rd | (disp + Rd)        | 1511     |
| 3  |              |               |       |         |                                                              |       | OpA + 6   | IEW                                  | 1000 | prevA     | (prevA)            | 1011     |
| 4  |              |               |       |         |                                                              |       |           |                                      |      | disp + Rd | result             | 0 \$ 1 1 |
| 5  |              |               |       | 1.1     |                                                              |       |           |                                      |      | OpA + 6   | IEW                | 1000     |

| <b>D</b> umbour |                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax          | SUBQ{B}                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| Execution       | (destination) – immediate data $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| Modes Supported | #imm4,Rd<br>#imm4,*disp16[Rd]                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| Status Bits     | <ul> <li>Z set if the result is zero; cleared otherwise</li> <li>N equals the most significant bit of the result</li> <li>C set if an unsigned underflow occurred; cleared otherwise</li> <li>V set if a twos complement underflow occurred; cleared otherwise</li> </ul>                                                                                |  |  |  |  |  |
| Description     | Subtract the quick immediate data from the contents of the destination operand. Quick immediate data consists of a 4-bit value of 0–15, contained within the instruction word, which has been zero-extended to the correct data object size. The SUBQ <i>#data,Rd</i> instruction takes one cycle to execute, while the SUB equivalent takes two cycles. |  |  |  |  |  |
|                 | For byte operations, the byte operands are zero-extended to words, are operated on as words, and produce a word result. The most significant byte of the result will be either 00h for C[[ST]]=0 or FFh for C[[ST]]=1. Nonregister destinations receive the least significant byte of the result, while registers receive the entire word.               |  |  |  |  |  |
|                 | Status bits are set with respect to the size (byte or word) of the operation.                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| Example         | <pre>label SUBQB #7,IM ; Subtract 7 from the IM. ; SUBQ #FIVE,&amp;FINISH ; Subtract FIVE's value ; from location FINISH</pre>                                                                                                                                                                                                                           |  |  |  |  |  |

|    | SUBQ{B} #imm4,Rd |        |       | SUBQ{B    | #imm4,*di         | sp16[Rd |
|----|------------------|--------|-------|-----------|-------------------|---------|
|    | 86(w) 87(l       | o) Imm | 4 Fid | 88(w) 89  | 9(b) <i>imm</i> - | 1 Rd    |
| •  |                  |        |       |           | disp16            |         |
| Cy | Address          | Data   | wbfd  | Address   | Data              | wbfd    |
| 1  | OpA + 4          | IEW    | 1000  | prevA     | (prevA)           | 1011    |
| 2  |                  |        |       | disp + Rd | (disp + Rd)       | 1511    |
| 3  |                  |        |       | OpA + 4   | IW                | 1001    |
| 4  |                  |        |       | disp + Rd | result            | 0S11    |
| 5  |                  |        |       | OpA + 6   | IEW               | 1000    |

| Syntax         | SUBR{B}                                                                                                                                                                                                                                                                   |  |  |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Execution      | (Register B) – (Register A) → (Register A)                                                                                                                                                                                                                                |  |  |  |  |
| Mode Supported | RA, RB                                                                                                                                                                                                                                                                    |  |  |  |  |
| Status Bits    | <ul> <li>Z set if the result is zero; cleared otherwise</li> <li>N equals the most significant bit of the result</li> <li>C set if an unsigned underflow occurred; cleared otherwise</li> <li>V set if a twos complement underflow occurred; cleared otherwise</li> </ul> |  |  |  |  |
| Description    | Subtract the contents of register A from the contents of register B and place<br>the result back into register A. (Subtract source from destination, but place re-<br>sult back into source.)                                                                             |  |  |  |  |
|                | Note that when $R_B$ is the ZR, the instruction is equivalent to the instruction COMPL $R_A$ .                                                                                                                                                                            |  |  |  |  |
|                | For byte operations, the byte operands are zero-extended to words, are operated on as words, and produce a word result. The most significant byte of the result will be either 00h for C[ST]=0 or FFh for C[ST]=1.                                                        |  |  |  |  |
|                | Status bits are set with respect to the size (byte or word) of the operation.                                                                                                                                                                                             |  |  |  |  |
| Example        | label SUBR R3,R7 ; Subtract R3 from R7,<br>; Store result in R3.                                                                                                                                                                                                          |  |  |  |  |

| [  | SUB         | R{B} RA | ,RB  |
|----|-------------|---------|------|
|    | 2E (w) 2F ( | b) RA   | RB   |
| Су | Address     | Data    | wbid |
| 1  | OpA + 4     | IEW     | 1000 |

| Syntax              | SWAPB                                                                                                                                                                              |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution           | $(Rs (LSbyte)) \rightarrow (Rd (MSbyte))$<br>$(Rs (MSbyte)) \rightarrow (Rd (LSbyte))$                                                                                             |
| Mode Supported      | Rs,Rd                                                                                                                                                                              |
| Status Bits         | <ul> <li>Set if the result is zero; cleared otherwise</li> <li>equals the most significant bit of the result</li> <li>unchanged</li> <li>Cleared</li> </ul>                        |
| Description         | Copy (swap) the source register's most significant byte and its least significant byte with the opposite bytes of the destination register. The source register remains unchanged. |
| Example             | LABEL SWAPB R1,R2                                                                                                                                                                  |
| R1 = 1<br><i>15</i> |                                                                                                                                                                                    |



|   | SWAPB Rs,Rd |           |      |  |  |
|---|-------------|-----------|------|--|--|
|   | FD          | Rs        | Rd   |  |  |
| С | Address     | Data      | wbfd |  |  |
| 1 | prevA       | Rs_LSbyte | 0111 |  |  |
| 2 | prevA       | Rs_MSbyte | 0111 |  |  |
| 3 | OpA + 4     | IEW       | 1000 |  |  |

| Syntax                | твіто                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution             | IF [(mask ≠ 0) <b>and</b> (mask ANDed to destination = 0)],<br>THEN 1 → (Z[[ST]])<br>ELSE 0 → (Z[[ST]])                                                                                                                                                                                                                                                                                                                   |
| Mode Supported        | #imm8(mask),&addr16 (The & operator <b>must</b> be included as shown.<br>The # operator in front of <i>imm</i> is optional.)                                                                                                                                                                                                                                                                                              |
| Status Bits           | <ul> <li>Z set if tested bits are cleared; otherwise, a zero</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                                                    |
| Description           | This is a byte instruction only.                                                                                                                                                                                                                                                                                                                                                                                          |
|                       | For each logical 1 bit in the source mask, test the corresponding bit in the des-<br>tination-address <i>byte</i> . If <i>all</i> specified destination bits are 0s, place a 1 in the<br>Z bit of the status register. Otherwise, set the Z bit to 0. <i>Only the 1 bits in the</i><br><i>mask are ANDed to set the Z bit</i> . If the source mask is all zeroes (00h), no bits<br>are tested and bit $Z[ST]$ is cleared. |
|                       | The destination byte is always in the first 64K bytes of memory and is addressed by a 16-bit value ( address line A16 = 0).                                                                                                                                                                                                                                                                                               |
|                       | This instruction is designed to be followed by a BEQ (branch if equal) or BNE (branch not equal) instruction to form, respectively, a <i>branch on multiple bits clear</i> or <i>branch on multiple bits not clear</i> operation.                                                                                                                                                                                         |
| Example               | While moving a block of bytes from one memory area to another, check each byte for all zeroes in bits 0, 1, 2, and 4. If all are zeroes, move the next byte and continue. If not all ones, do a bit check routine before moving the next byte.                                                                                                                                                                            |
|                       | STARTMOVB*R7,*R8;Bring in (next) byte to checkMOVB*R8+,4000h ;Place in memory for bit checkTBIT00Bh,&4000h ;Are bits 0, 1, 3 cleared?BEQSTART ; If bits are clear, move next byte; If not clear, do bit checkBIT_CHK. ; Start of bit checking                                                                                                                                                                             |
| Instruction Execution | JMP START ; After check, get next byte Detail                                                                                                                                                                                                                                                                                                                                                                             |
|                       | TBITO     immg       F4 (b)     immg       addr       Cy     Address       Data     w b f d                                                                                                                                                                                                                                                                                                                               |

5-106 TMS370C16 CPU

1

2

3

addr

OpA + 4

OpA + 6

(addr)

IW

IEW

1111

1001

1000

| Syntax                                                                                                                                                                               | TBIT1                                                                                                                                                                                       |                                                                                                                                                                           |                                                                                                                                            |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Execution                                                                                                                                                                            | IF [(mask ≠ 0) <i>and</i> (mask_ones ANDed to inverted destination = 0)],<br>THEN 1 → (Z[[ST]])<br>ELSE 0 → (Z[[ST]])                                                                       |                                                                                                                                                                           |                                                                                                                                            |  |  |
| Mode Supported                                                                                                                                                                       | #imm8(mask),&add                                                                                                                                                                            | //16 (The & op<br>The # d                                                                                                                                                 | perator <b>must</b> be included as shown.<br>Operator in front of <i>imm</i> is optional.)                                                 |  |  |
| Status Bits                                                                                                                                                                          | <ul> <li>Z set if tested bi</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                       | ts are set (ones); oth                                                                                                                                                    | nerwise, a zero                                                                                                                            |  |  |
| Description                                                                                                                                                                          | This is a byte instru                                                                                                                                                                       | iction only.                                                                                                                                                              |                                                                                                                                            |  |  |
|                                                                                                                                                                                      | tination-address by<br>Z bit of the status reg<br>to the 1 bits in the r<br>zeroes (00h), no bit<br>The destination by<br>addressed by a 16-<br>This instruction is d<br>(branch not equal) | te. If all specified de<br>gister. Otherwise, set<br>mask are tested to s<br>is are tested and bit<br>its always in the<br>bit value (address li<br>esigned to be followe | first 64K bytes of memory and is<br>ine A16 = 0).<br>ed by a BEQ (branch if equal) or BNE<br>espectively, a <i>branch on multiple bits</i> |  |  |
| Example                                                                                                                                                                              | byte for all 1s in bits                                                                                                                                                                     | •                                                                                                                                                                         | memory area to another, check each<br>hove next byte and continue. If not all<br>g the next byte.                                          |  |  |
| START MOVB *R7+,*R8 ; Bring in (next) by<br>MOVB *R8+,4000h ; Byte to memory<br>TBIT1 0F0h,&4000h ; Are bits 4-7 set?<br>BEQ START ; If bits set, move no<br>; If not set, do bitche |                                                                                                                                                                                             |                                                                                                                                                                           |                                                                                                                                            |  |  |
|                                                                                                                                                                                      | BIT_CHK . ; Start of bit check .                                                                                                                                                            |                                                                                                                                                                           |                                                                                                                                            |  |  |
|                                                                                                                                                                                      | JMP                                                                                                                                                                                         | START                                                                                                                                                                     | ; After check, get next byte                                                                                                               |  |  |
| Instruction Execution                                                                                                                                                                | Detail                                                                                                                                                                                      |                                                                                                                                                                           |                                                                                                                                            |  |  |
|                                                                                                                                                                                      | TBIT1 imm <sub>8</sub> ,8                                                                                                                                                                   | &addr                                                                                                                                                                     |                                                                                                                                            |  |  |
|                                                                                                                                                                                      | EF (b)                                                                                                                                                                                      | limma                                                                                                                                                                     |                                                                                                                                            |  |  |

|    | F5 (b)  | )      | uimmg |  |  |
|----|---------|--------|-------|--|--|
|    |         | addr   |       |  |  |
| Су | Address | Data   | wbfd  |  |  |
| 1  | addr    | (addr) | 1111  |  |  |
| 2  | OpA + 4 | IW     | 1001  |  |  |
| 3  | OpA + 6 | IEW    | 1000  |  |  |

| Syntax              | TBLU{B}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Execution           | $\begin{array}{l} (Rs(MSbyte)) + (Rd) \rightarrow (IM) \\ (Rs(MSbyte)) + (Rd) + size \rightarrow (Rd) \\ IF IM > RD \\ THEN \\ Rs(LSbyte) \times (IM - Rd) + 80h \rightarrow TEMP \\ TEMP \div 256 \rightarrow Rd \\ IM - Rd \rightarrow Rd \\ \\ ELSE \\ Rs(LSbyte) \times (IM - Rd) + 80h \rightarrow TEMP \\ TEMP \div 256 \rightarrow Rd \\ IM + Rd \rightarrow Rd \end{array} \qquad (8 \text{ bits } \times 16 \text{ bits } \rightarrow 24 \text{ bits } + 80h) \\ \end{array}$ |  |  |  |  |
| Mode Supported      | Rs,IM:Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| Status Bits         | <ul> <li>Set if the result is zero; cleared otherwise</li> <li>equals the most significant bit of the result</li> <li>cleared</li> <li>cleared</li> </ul>                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| Description         | Look up two consecutive values in a table of unsigned data, referenced by Rd,<br>and perform a rounded straight-line interpolation between them, according to<br>the interpolation fraction in Rs. The result is rounded to fit the byte/word size<br>of the instruction and then placed in Rd.                                                                                                                                                                                        |  |  |  |  |
|                     | The 16-bit address in Rd points to the first entry of the data table. This table<br>is indexed by normalizing the most significant byte of Rs and adding it to Rd.<br>This sum yields the address of the first of two consecutive entries in the table<br>for which interpolation is to be computed. The two table entries are then<br>read into IM and Rd respectively, as illustrated below.                                                                                         |  |  |  |  |
| Index to Entry n (F | Fraction) Rs                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |



Note: Dotted line shows value moved; solid line indicates location pointed to.

#### Notes: Considerations for >64K Bytes and Effect of Byte Size on Registers

1. The calculated table pointer in Rd is a 16-bit value that can address only the first 64K bytes of memory (A16 = 0). Attempts to generate a result that points beyond the first 64K bytes of memory will wrap around to the beginning of the first 64K bytes of memory.

2. If the instruction size is byte, the most significant bytes of IM and Rd will be cleared when the table entries are read.

The interpolation fraction is held in the least significant byte of Rs and has its radix point between bits 7 and 8. The most significant byte of Rs is ignored during multiplication. The contents of Rs are left unchanged.

The internal multiply is  $8 \times 16$  where the 8-bit value is the fraction and the 16-bit value is the appropriate difference between the two table entries read into IM and Rd. The product is a 24-bit fixed-point value with the integer portion in bits 8–23 and the fraction in bits 0–7. This intermediate product is rounded up to word value in bits 8–23 by adding 000080h. This rounded result is then combined with IM, yielding the final interpolated result, which is placed into Rd.

The fractional portion of the intermediate product is lost. The operand combination TBLU{B} Rs,IM:IM will always generate a result of 0000h in IM. **Undefined execution** results in the combination TBLU{B} Rs,IM:ZR; thus, it must be avoided.

Status bits are set with respect to the size (byte/word) of the operation.

| <br>TBLU | Rs,IM:Rd |    |
|----------|----------|----|
|          |          |    |
| 7E (w)   | Rs       | ٦d |

|      | Er                  | ntry 1 $\leq$ Entry 2 |      | Entry 1 > Entry 2   |                       |      |
|------|---------------------|-----------------------|------|---------------------|-----------------------|------|
| Су   | Address             | Data                  | wbfd | Address             | Data                  | wbfd |
| 1,2  | prevA               | (prevA)               | 0011 | prevA               | (prevA)               | 0011 |
| 3    | prevA               | (prevA)               | 1011 | prevA               | (prevA)               | 1011 |
| 4    | Rd + Rs_MS_byte     | (Rd + Rs_MS_byte)     | 1011 | Rd + Rs_MS_byte     | (Rd + Rs_MS_byte)     | 1011 |
| 5    | prevA               | (prevA)               | 1011 | prevA               | (prevA)               | 1011 |
| 6    | Rd + Rs_MS_byte + 2 | (Rd + Rs_MS_byte + 2) | 1011 | Rd + Rs_MS_byte + 2 | (Rd + Rs_MS_byte + 2) | 1011 |
| 7–13 | prevA               | (prevA)               | 1011 | prevA               | (prevA)               | 1011 |
| 14   | prevA               | (prevA)               | 1011 | prevA               | (prevA)               | 1011 |
| 15   | OpA + 4             | IEW                   | 1000 | prevA               | (prevA)               | 1011 |
| 16   |                     |                       |      | OpA + 4             | IEW                   | 1000 |

## Instruction Execution Detail (Concluded)

TBLUB Rs,IM:Rd

7F (b) Rs Rd

|      | Er                  | Entry 1 $\leq$ Entry 2 |      |                     | Entry 1 > Entry 2     |      |
|------|---------------------|------------------------|------|---------------------|-----------------------|------|
| Су   | Address             | Data                   | wbfd | Address             | Data                  | wbfd |
| 1, 2 | prevA               | (prevA)                | 0011 | prevA               | (prevA)               | 0011 |
| 3    | Rd + Rs_MS_byte     | (Rd + Rs_MS_byte)      | 1111 | Rd + Rs_MS_byte     | (Rd + Rs_MS_byte)     | 1111 |
| 4    | prevA               | (prevA)                | 1011 | prevA               | (prevA)               | 1011 |
| 5    | Rd + Rs_MS_byte + 1 | (Rd + Rs_MS_byte + 1)  | 1111 | Rd + Rs_MS_byte + 1 | (Rd + Rs_MS_byte + 1) | 1111 |
| 6    | prevA               | (prevA)                | 1011 | prevA               | (prevA)               | 1011 |
| 7–13 | prevA               | (prevA)                | 1011 | prevA               | (prevA)               | 1011 |
| 14   | OpA + 4             | IEW                    | 1000 | prevA               | (prevA)               | 1011 |
| 15   |                     |                        |      | OpA + 4             | IEW                   | 1000 |

| Syntax         | TRAP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Execution      | $\begin{array}{l} (\text{ST}) \rightarrow ((\text{SP})) \\ (\text{SP}) + 2 \rightarrow (\text{SP}) \\ (\text{PC}) + 1 \rightarrow ((\text{SP})) \\ (\text{SP}) + 2 \rightarrow (\text{SP}) \\ \text{ones complement of enumerator } \times 2 \rightarrow \text{vector offset} \\ \text{vector table base addr + vector offset} \rightarrow (\text{PC})  (\textit{subroutine address} \rightarrow \textit{PC}) \\ 1\text{s} \rightarrow \text{L2}-\text{L0}[[\text{ST}]] \end{array}$ |  |  |  |  |  |
| Mode Supported | imm8 [#imm8 = trap number (0–255);<br>enumerator8 = ones complement of trap number]                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| Status Bits    | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| Description    | The TRAP instruction operates as a software interrupt or exception. A 256-word trap vector table, located at a vector-table base address, contains the start addresses of each trap subroutine (TRAP 0 being at the lowest address in the table). This is shown graphically in Figure 5–6 on page 5-113.                                                                                                                                                                             |  |  |  |  |  |
|                | Note: Five Trap Words Are Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|                | The 'C16 trap vector table contains mask ROM space reserved for <b>TI use</b><br><b>only</b> —addresses 08036h—08040h, as shown in Figure 5—6 on page 5-113.<br>This reserved area should not be used in your software algorithm, nor should<br>it be used during mask ROM/firmware development.                                                                                                                                                                                     |  |  |  |  |  |
|                | A summary of the trap exception steps:                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|                | <ol> <li>Push the current ST contents on to the stack; then increment the SP by 2.</li> <li>Add 1 to the PC value and place the result on the system stack (this will point two words beyond the next instruction). Increment the SP by 2.</li> </ol>                                                                                                                                                                                                                                |  |  |  |  |  |
|                | <ol> <li>Calculate the vector offset (from the trap vector-table base address) by<br/>multiplying a ones complement of the instruction's enumerator by 2. (The<br/>enumerator is stored in the LSbyte of opcode as the ones complement of<br/>the trap number.)</li> </ol>                                                                                                                                                                                                           |  |  |  |  |  |
|                | <ol> <li>Load the PC with the trap vector-table base address + vector offset (ad-<br/>dress containing the trap-subroutine start address).</li> </ol>                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|                | <ul><li>5) Load the PC with the subroutine start address.</li><li>6) Load all 1s into the ST's three interrupt level bits (L2–L0)</li></ul>                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|                | This instruction replicates a peripheral interrupt. In this manner, it is a software interrupt and requires you to provide an interrupt/exception handler in software. Use an RTI instruction to return to the interrupted execution flow.                                                                                                                                                                                                                                           |  |  |  |  |  |

#### Note: TRAP Enumerator Source

Note that the enumerator value as assembled in the LSbyte of the opcode is the inverse (ones-complement) trap value. For example, TRAP 0 is the instruction word FFFFh (FFh is the enumerator value), TRAP 1 is FFFEh (FEh the enumerator value), and TRAP 255 is FF00h (00h is the enumerator value). (This explains the ones-complement computation in the Execution equation above.) **Traps are further explained** in subsection 3.7.6 on page 3-24.

Label TRAP

; Call TRAP 32 vector. Begin ; execution at the address ; stored at that location.

#### Instruction Execution Detail

TRAP imm8

32

FF enumerator

| Су | Address                                   | Data                     | wbfd |
|----|-------------------------------------------|--------------------------|------|
| 1  | OpA + 4                                   | IEW                      | 1001 |
| 2  | SP                                        | ST                       | 0011 |
| 3  | SP + 2                                    | (Rtn A + 4) ÷ 2          | 0011 |
| 4  | prevA                                     | (prevA)                  | 1011 |
| 5  | (NOT enum) $\times$ 2 + vector base_addr  | subroutine start address | 1011 |
| 6  | subroutine start address $\times 2$       | IW                       | 1001 |
| 7  | (subroutine start address $\times$ 2) + 2 | IEW                      | 1000 |



Figure 5–6. Vector Table for TRAP Instruction



| Syntax                                                                                                                                                                     | TRU                                                                                                                                 | TRUNCS{L}                                                              |                                                       |                                          |                         |          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------|------------------------------------------|-------------------------|----------|
| Execution                                                                                                                                                                  | Ť                                                                                                                                   | IF [valid truncation <i>not</i> possible]<br>THEN one → V[ST]<br>ENDIF |                                                       |                                          |                         |          |
| Modes Supported                                                                                                                                                            | Rd<br>IM:l                                                                                                                          | Rd                                                                     | (word only)<br>(longword only)                        |                                          |                         |          |
| Status Bits                                                                                                                                                                | Z                                                                                                                                   | TRUNCS:<br>TRUNCSL:                                                    | otherwise                                             | st significant byte<br>ero; cleared othe |                         | cleared  |
|                                                                                                                                                                            | N equals V[ST]<br>object                                                                                                            |                                                                        | ] XORed with the most significant bit of the original |                                          | ginal data              |          |
|                                                                                                                                                                            | С                                                                                                                                   | cleared                                                                |                                                       |                                          |                         |          |
|                                                                                                                                                                            | V                                                                                                                                   | TRUNCS:                                                                |                                                       | to 7 of <i>Rd</i> are no                 | ot the same; cle        | ared     |
|                                                                                                                                                                            |                                                                                                                                     | TRUNCSL:                                                               | otherwise<br>set if all bits<br>cleared othe          | in I <b>M and</b> bit 15<br>prwise       | of <i>Rd</i> are not th | ne same; |
| DescriptionTest the signed data in the register(s) to determine if it<br>represent the data in the next smaller data object size<br>V bit in the status register to a one. |                                                                                                                                     |                                                                        |                                                       |                                          | •                       |          |
|                                                                                                                                                                            | Use the BV (branch if overflow set with $V[ST] = 1$ ) or BNV (branch if overflow not set with $V[ST] = 0$ ) instructions to decide. |                                                                        |                                                       |                                          |                         |          |

|                | TRUNCS Rd |                |         |          | TRU                    | NCSL //                               | M:Rd             |                 |              |
|----------------|-----------|----------------|---------|----------|------------------------|---------------------------------------|------------------|-----------------|--------------|
|                | AE (w     |                | Rd      | ]        |                        |                                       | AF (L            |                 | / Rd         |
|                | L 14      |                |         |          |                        | · · · · · · · · · · · · · · · · · · · | π                |                 |              |
|                | Dits /    | - 15 are the a | same    | Dits 7 - | 15 are not the         | e same                                |                  |                 |              |
| Су             | Address   | Data           | w b f d | Address  | 15 are not the<br>Data | e same<br>w b f d                     | Address          | Data            | wbfd         |
|                |           |                |         |          |                        |                                       | Address<br>prevA | Data<br>(prevA) | wbfd<br>1011 |
| Cy<br>1–2<br>3 | Address   | Data           | wbfd    | Address  | Data                   | wbfd                                  |                  |                 |              |

| Syntax         | TRUNCU                                                                                                                                                                                                                                                                       |  |  |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Execution      | IF [valid truncation <i>not</i> possible],<br>THEN, one → C[[ST]]<br>ENDIF                                                                                                                                                                                                   |  |  |  |  |
| Mode Supported | Rd                                                                                                                                                                                                                                                                           |  |  |  |  |
| Status Bits    | <ul> <li>Z set if the least significant byte of <i>Rd</i> is zero; cleared otherwise</li> <li>N equals the value of bit 7 (most significant bit of the byte result)</li> <li>C set if bits 8 – 15 of <i>Rd are not</i> zero; cleared otherwise</li> <li>V cleared</li> </ul> |  |  |  |  |
| Description    | Test the unsigned data word in the destination register to determine if it can be accurately represented as a byte data object. If <i>not</i> possible, set the C bit in the status register to a 1.                                                                         |  |  |  |  |
|                | Use the BC (branch if carry set with $C[ST] = 1$ ) or BNC (branch if carry clear with $C[ST] = 0$ ) instructions to decide.                                                                                                                                                  |  |  |  |  |
| Example        | LABEL TRUNCU R2 ; DOES MS BYTE OF R2 = 0?<br>BNC Byte_Val; YES, JUMP TO BYTE ROUTINE:<br>; OTHERWISE, CONTINUE                                                                                                                                                               |  |  |  |  |

|    | TRUNCU Rd |         |      |  |  |  |  |
|----|-----------|---------|------|--|--|--|--|
|    | AD (w     |         | Rd   |  |  |  |  |
| Су | Address   | Data    | wbfd |  |  |  |  |
| 1  | prevA     | (prevA) | 1011 |  |  |  |  |
| 2  | OpA + 4   | IEW     | 1000 |  |  |  |  |

| Syntax          | TST{B}                                            | Synthetic Insti                                                    | ruction: Executes as MOV s,ZR                                                      |
|-----------------|---------------------------------------------------|--------------------------------------------------------------------|------------------------------------------------------------------------------------|
| Execution       | MOV                                               | s,ZR                                                               |                                                                                    |
| Modes Supported | Rs<br>*Rs<br>*Rs+<br>#imm16<br>*dips16[Rs<br>*–Rs | s]                                                                 |                                                                                    |
| Status Bits     | N equa                                            | i the source is zero; o<br>als the most significa<br>aanged<br>red |                                                                                    |
| Description     |                                                   | •                                                                  | berand by moving (copying) it to the ZR (R15).<br>The source value is not changed. |
|                 | • •                                               | -                                                                  | ast significant byte of a register. Status bits are rte or word) of the operation. |
| Example         | TSTB                                              | *0A1h[ZR]                                                          | ; Check byte address 0A1h.<br>; Set status bits on result.                         |
|                 | Check                                             | TST &VALUE                                                         | ; Check word location VALUE.<br>; Set status bits on result.                       |

|    | TST{B} <i>Rs</i><br>(MOV{B} <i>Rs,ZR</i> ) |               |                   | TST{B} <i>*Rs</i><br>(MOV{B} *Rs,ZR) |         |       | TST{B} <b>*Rs+</b><br>(MOV{B} <b>*Rs+</b> ,ZR) |          |       |
|----|--------------------------------------------|---------------|-------------------|--------------------------------------|---------|-------|------------------------------------------------|----------|-------|
|    | 02(w) 03                                   | (b) <i>Rs</i> | 1111 <sub>2</sub> | OA(w) OE                             | i(b) Rs | 11112 | 12 (w) 1:                                      | 3 (b) Rs | 11112 |
| Су | Address                                    | Data          | wbfd              | Address                              | Data    | wbfd  | Address                                        | Data     | wbfd  |
| 1  | OpA + 4                                    | IEW           | 1000              | Rs                                   | (Rs)    | 0511  | Rs                                             | (Rs)     | 0811  |
| 2  |                                            |               |                   | OpA + 4                              | IEW     | 1000  | prevA                                          | (prevA)  | 1011  |
| 3  |                                            |               |                   |                                      |         |       | OpA+4                                          | IEW      | 1000  |

| TST{B} #imm16      | TST{B} *disp16[Rs]        | TST{B} *– <b>Rs</b>        |
|--------------------|---------------------------|----------------------------|
| (MOV{B} #imm16,ZR) | (MOV{B} *disp16[Rs],[ZR]) | (MOV{B} *– <b>Rs</b> , ZR) |
|                    |                           |                            |

| 1A (w) 1B (b) |    |      |    | 2A (w) 2B (b) Rs 11112 |
|---------------|----|------|----|------------------------|
| imm           | 16 | disp | 18 |                        |

| Су | Address | Data | wbfd | Address   | Data        | wbfd    | Address | Data     | wbfd     |
|----|---------|------|------|-----------|-------------|---------|---------|----------|----------|
| 1  | OpA + 4 | IW   |      | OpA + 4   | W           | 1001    | prevA   | (prevA)  | 1011     |
| 2  | OpA + 6 | IEW  | 1000 | disp + Rs | (disp + Rs) | 0 S 1 1 | Rs - S  | (Rs - S) | 1 \$ 1 1 |
| 3  |         |      |      | OpA + 6   | IEW         | 1000    | OpA + 4 | IEW      | 1000     |

| Syntax          | UNLINK                                                                                                                                          |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Execution       | (FP) → (SP)<br>((SP)) → (FP)                                                                                                                    |
| Modes Supported | Operand not necessary for UNLINK                                                                                                                |
| Status Bits     | <ul> <li>Z unchanged</li> <li>N unchanged</li> <li>C unchanged</li> <li>V unchanged</li> </ul>                                                  |
| Description     | Unlink and deallocate the current system stack frame:                                                                                           |
|                 | <ol> <li>Load the SP (R13) with the contents of the FP (R0).</li> <li>Reload the FP with its previous value (from the system stack).</li> </ol> |

|    | UNLINK  |         |      |  |  |  |  |  |
|----|---------|---------|------|--|--|--|--|--|
|    | F6      |         |      |  |  |  |  |  |
| Су | Address | Data    | wbfd |  |  |  |  |  |
| 1  | prevA   | (prevA) | 1011 |  |  |  |  |  |
| 2  | FP      | old FP  | 1011 |  |  |  |  |  |
| 3  | OpA + 4 | IEW     | 1000 |  |  |  |  |  |

| Syntax         | XNOR{B}                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Execution      | NOT (source XOR destination) $\rightarrow$ destination                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
| Mode Supported | Rs,Rd                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
| Status Bits    | <ul> <li>Set if the result is zero; cleared otherwise</li> <li>equals the most significant bit of the result</li> <li>unchanged</li> <li>cleared</li> </ul>                                                                                                                             |  |  |  |  |  |  |  |
| Description    | Logically exclusive OR the contents of the source register with the contents of the destination register and return the ones complement of the result.                                                                                                                                  |  |  |  |  |  |  |  |
|                | For byte operations, the byte operands are zero-extended to words, are oper-<br>ated on as words, and produce a word result. The most significant byte of the<br>result will always be FFh. Note that when <i>Rs</i> is <i>ZR</i> , the instruction is equivalent<br>to NOT <i>Rd</i> . |  |  |  |  |  |  |  |
|                | Status bits are set with respect to the size (byte or word) of the operation.                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| Example        | Label XNOR R2,R11 ; Exclusive OR the values in<br>; R2 with R11. Store results<br>; in R11.                                                                                                                                                                                             |  |  |  |  |  |  |  |

#### Instruction Execution Detail

|    | XNC       | DR{B} | Rs,Rd |    |
|----|-----------|-------|-------|----|
|    | 2C (w) 21 | ) (b) | Rs l  | Rd |
| Су | Address   | Data  | wb    | fd |
| 1  | OpA + 4   | IEW   | 10    | 00 |

| Syntax          | XOR{B}                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Execution       | (source) XOR (destination) $\rightarrow$ (destination)                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| Modes Supported | Rs,Rd<br>Rs,*disp16[Rd]<br>#imm16,Rd<br>#imm16,*disp16[Rd]                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
| Status Bits     | <ul> <li>Set if the result is zero; cleared otherwise</li> <li>equals the most significant bit of the result</li> <li>unchanged</li> <li>cleared</li> </ul>                                                                                                                                                      |  |  |  |  |  |  |  |
| Description     | Logically exclusive OR the source operand contents with the contents of the destination operand. Place results in the destination.                                                                                                                                                                               |  |  |  |  |  |  |  |
|                 | For byte operations, the byte operands are zero-extended to words, are<br>operated on as words, and produce a word result. The most significant byte<br>of the result will always be 00h. Nonregister destinations receive the least<br>significant byte of the result, while registers receive the entire word. |  |  |  |  |  |  |  |
|                 | Status bits are set with respect to the size (byte or word) of the operation.                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| Example         | LABEL XORB #10110011b,R2 ; Exclusive OR the LS<br>; byte of R2 with the<br>; source binary value.<br>; Place results in R2<br>; with the MS byte all<br>; zeroes.                                                                                                                                                |  |  |  |  |  |  |  |

#### **Instruction Execution Detail**

| XOR{B} Rs,Rd |                     | XOR{B} Rs,*disp16[Rd]                |                                               | XOR{B} #imm16,Rd                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | XOR{B}<br>#imm16,*disp16[Rd]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|---------------------|--------------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 50(w) 51     | (b) F               | is Rd                                | 52(w) 5                                       | 3(b) Rs<br>disp16                                                                                                                                                                                                             | Rd                                                                                                                                                                                                                                                               | 54(w) 55                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | // Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 56(w) 57                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | (b)<br>disp16<br>imm16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Address      | Data                | wbfd                                 | Address                                       | Data                                                                                                                                                                                                                          | wbfd                                                                                                                                                                                                                                                             | Address                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | wbfd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | wbłd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| OpA + 4      | IEW                 | 1000                                 | OpA + 4<br>disp + Rd                          | IW<br>(disp + Rd)                                                                                                                                                                                                             | 1001<br>1811                                                                                                                                                                                                                                                     | OpA + 4<br>OpA + 6                                                                                                                                                                                                                                                                                                                                                                                                                                               | IW<br>IEW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1001<br>1000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | OpA + 4<br>disp + Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | IW<br>(disp + Rd)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1001<br>1811                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|              |                     |                                      | prevA<br>disp + Rd                            | (prevA)<br>result                                                                                                                                                                                                             | 1011<br>0S11<br>1000                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | prevA<br>disp + Rd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | (prevA)<br>result                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1011<br>0S11<br>1000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              | 50(w) 51<br>Address | 50(w) 51(b) <i>F</i><br>Address Data | 50(w) 51(b) <i>Rs Rd</i><br>Address Data wbid | 50(w)         51(b)         Rs         Rd         52(w)         5           Address         Data         w b f d         Address           OpA + 4         IEW         1000         OpA + 4           disp + Rd         prevA | 50(w)     51(b)     Rs     Rd     52(w)     53(b)     Rs       disp16       Address     Data     w b f d     Address     Data       OpA + 4     IEW     1000     OpA + 4     IW       disp + Rd     (disp + Rd)     prevA     (prevA)       disp + Rd     result | 50(w)         51(b)         Rs         Rd         52(w)         53(b)         Rs         Rd           Address         Data         w b f d         Address         Data         w b f d           OpA + 4         IEW         1000         OpA + 4         IW         1001           disp + Rd         (disp + Rd)         1 S 1 1         prevA         (prevA)         1011           disp + Rd         result         0 S 1 1         0 S 1 1         0 S 1 1 | 50(w)         51(b)         Rs         Rd         52(w)         53(b)         Rs         Rd         54(w)         55           disp16         disp16         disp16         disp16         disp16         disp16           Address         Data         w b f d         Address         Data         w b f d         Address           OpA+4         IEW         1000         OpA+4         IW         1001         OpA+4           disp+Rd         (disp+Rd)         1S11         OpA+6         prevA         (prevA)         1011           disp+Rd         result         0S11         OS11         OpA+6 | 50(w)         51(b)         Rs         Rd         52(w)         53(b)         Rs         Rd         54(w)         55(b)           disp16         disp16         imm16           Address         Data         w b f d         Address         Data         w b f d         Address         Data           OpA+4         IEW         1000         OpA+4         IW         1001         OpA+4         IW           disp+Rd         (disp+Rd)         1S11         OpA+6         IEW           prevA         (prevA)         1011         disp+Rd         result         0S11 | 50(w)         51(b)         Rs         Rd         52(w)         53(b)         Rs         Rd         54(w)         55(b)         Rd           Address         Data         w b ī d         Address         Data         w b ī d         Imm 16           Address         Data         w b ī d         Address         Data         w b ī d         Imm 16           OpA + 4         IEW         1000         OpA + 4         IW         1001         OpA + 4         IW         1001           disp + Rd         (disp + Rd)         1 S 1 1         OpA + 6         IEW         1000           prevA         (prevA)         10 1 1         0 5 1 1         0 5 1 1         0 5 1 1 | 50(w)         51(b)         Rs         Rd         52(w)         53(b)         Rs         Rd         54(w)         55(b)         Rd         56(w)         57           disp16         imm16         imm16         imm16         imm16         imm16         Address         Data         w b f d         Address         Data         w b f d | XOR(B)       Rs, Rd       XOR(B)       Rs, ruspro[Rd]       XOR(B)       #imm16, *disp1         50(w)       51(b)       Rs       Rd       54(w)       55(b)       Rd       56(w)       57(b)         60(w)       51(b)       Rs       Rd       54(w)       55(b)       Rd       56(w)       57(b)         60(w)       51(b)       Rs       Rd       54(w)       55(b)       Rd       56(w)       57(b)         60(w)       60(w) |



#### Appendix A

# Glossary

This appendix provides definitions of terms and concepts unique to cMCU<sup>™</sup> devices. Other common terms are included if the use of those terms varies from generally accepted usage.

- **absolute address:** An addressing mode in which code or operands produce the actual address.
- A/D pins: The 18 pins that connect the A/D module to the external world; includes analog inputs AN0–15 and the high and low reference voltages, V<sub>refhi</sub>, and V<sub>reflo</sub>.
- addressing mode: The method by which an instruction calculates the location of its required data.
- **AN0–AN15 pins:** The 16 analog input channels to the A/D converter's digital inputs.
- analog-to-digital (A/D) converter: The cMCU370 A/D Converter, which receives analog data from up to 16 multiplexed inputs.
- **assembly language:** A symbolic language that describes the binary machine code in a more readable form and that can be read by an assembler for conversion into machine code.
- **asynchronous communications mode:** A serial communications format that needs no synchronizing clock. This format begins with a start bit, is followed by data bits and an optional parity bit, and ends with one or two stop bits. This format is commonly used with RS-232-C communications and PC serial ports.



- **BCD:** Binary coded decimal. Each 4-bit nibble expresses a digit from 0–9 and usually packs two digits to a byte, giving a range of 0–99.
- **baud:** The communication speed for serial ports; equivalent to one bit per second.
- **code address:** A value that, when placed in the program counter, is placed on the 16 most significant address lines with the least significant address line set to 0. This effectively multiplies the code value by 2 and makes it possible to address memory of up to 128K bytes.
- **constant:** A value that does not change during execution.
- **CPU:** Central processing unit. The cMCU370 product's CPU is register-oriented with a status register, program counter register, and stack pointer. The CPU uses the register file, accessed in one bus cycle, as working registers. The cMCU370 CPUs are the TMS370C8 (8 bit) and the TMS370C16 (16 bit).
- **device:** The entire microcontroller, consisting of the CPU and the selected modules integrated on a single chip.
- edge detection: A process that senses an active pulse transition on a given timer input and provides appropriate output. The active transition can be configured to be low-to-high or high-to-low.
- **EEPROM:** *Electrically erasable programmable read only memory.* Memory that can be programmed and erased under direct program control.

#### F

D

freeze bit: A bit "frozen" to an unmodifiable 1 or 0 value, according to customer requirements, during manufacturing.

#### 

- **halt mode:** A mode that reduces operating power by stopping the internal clock, which stops processing in all the modules. This is the lowest-power mode in which all register contents are preserved.
- **Idle mode:** A mode in which the CPU stops processing and waits for the next interrupt. This is not a low-power mode.
- **immediate operand:** An operand whose actual constant value is specified in the instruction.
- **instruction:** The basic unit of programming that causes the execution of one operation; consists of an opcode and operands along with optional labels and comments.
- INT1, INT2, and INT3 pins: Pins connected to external devices to allow them to interrupt the CPU. INT1 and INT2 can be software configured as non-maskable interrupts.
- **interrupt:** A signal input to the CPU to stop the flow of a program and force the CPU to execute instructions at an address corresponding to the source of the interrupt. When the interrupt is finished, the CPU resumes execution at the point where it was interrupted.
- **isosynchronous communications mode:** An SCI mode in which data transmission is synchronized by a clock signal (SCICLK) common to both the sender and receiver. The format is identical to the asynchronous mode and consists of a start bit, data bits, an optional parity bit, and a stop bit.

- machine code: The actual binary values read by the CPU for instruction execution; usually organized as hexadecimal bytes in an assembler listing.
- **memory map:** A map of the address space accessed by the TMS370C16 processor, partitioned according to functionality (memory, registers, etc.).
- **mnemonic:** An alphanumeric symbol designed to aid human memory; commonly represents the opcode of an assembly language instruction.

N

0

- **module:** An element that provides a specific function such as a serial interface, memory area, A/D conversion, etc. Such modules are integrated with the CPU to form a device for a specific application.
- **multiprocessor communications:** An SCI format option that enables one processor to efficiently send blocks of data to other processors on the same serial link.
- **nested interrupt:** An interrupt that suspends the service routine of a prior interrupt. An executing interrupt can set the ST register's interrupt mask to prevent being suspended by another interrupt.
- NMI: Nonmaskable interrupt. An interrupt that causes a context switch, once the present instruction finishes execution. When executing, the NMI cannot be interrupted by other NMIs or peripheral interrupts unless an RTI instruction occurs or an ST interrupt bit, L2 – L0, is cleared.
- offset: A signed value that is added to the base operand to give the final address.
- **opcode:** Operation code. In most cases, the first byte of the machine code that describes to the CPU the type of operation and combination of operands. TMS370C16 instructions use 16-bit opcodes.
- **operand:** The part of an instruction designating where the CPU will fetch or store data.

P

- **prescaler:** A circuit that slows the rate of a clocking source to the counter.
- **prototyping device:** A device used before a masked ROM device is available that has identical functions, pinout, size, and timings to the ROM device. Programmable memory such as EEPROM or EPROM is used in place of the masked ROM.
- **PWM:** Pulse width modulation. A serial signal in which the information is contained in the width of a pulse of a constant frequency signal. A cMCU370 device can output a PWM signal with a constant duty cycle without any program intervention by using the timer compare features.

- **ratiometric conversion:** An analog-to-digital conversion in which the conversion value is a ratio of the V<sub>ref</sub> source to the analog input. As V<sub>ref</sub> is increased, the input voltage needed to give a certain conversion value changes, but all conversion values keep the same relationship to V<sub>ref</sub>.
- **register file (RF):** The 16-register file residing in the CPU. Several registers also serve, respectively, as the frame pointer (R0), implied register (R1), stack pointer (R13), status register (R14), and zero register (R15). Each register is 16 bits.
- **RESET pin:** A pin that when held low starts hardware initialization and ensures an orderly software startup.
- serial communications interface (SCI): An optional PRISM library module that provides a serial interface, programmable to be asynchronous or isosynchronous. Many timing, data format, and protocol factors are programmable and controlled by the SCI module in operation.
- SCICLK pin: Serial communications interface clock pin. A pin used as a synchronizing clock input or output in the isosynchronous mode, or as a general-purpose I/O pin.
- serial peripheral interface (SPI): An optional PRISM library module that provides a serial interface to facilitate communication between networked master and slave CPUs. As in the SCI, the SPI is set up by software; from then on, the CPU takes no part in timing, data format, or protocol.
- signed integer: A number system used to express positive and negative integers.
- SPI: See serial peripheral interface.
- **stack:** A designated part of memory used as a last-in, first-out memory for temporary variable storage; used during interrupts and calls to store the current program status. The area occupied by the stack is determined by the stack pointer and the application program.
- stack pointer (SP): A CPU register that points to the last entry or top of the stack. The SP is automatically incremented before data is pushed onto the stack and decremented after data is popped (pulled) from the stack.

U

W

- standby mode: A power reduction mode in which the CPU stops processing, but the on-chip oscillator remains active. Timers remain active and can cause the CPU to exit the standby mode.
- status register (ST): A CPU register that monitors the operation of the instructions and contains the global interrupt enable mask bits.
- **TBA (trap table base address):** The beginning address of the trap vectors. An algorithm value involving the trap enumeration value is added to this address to find the vector corresponding to the trap. See the TRAP instruction description in Chapter 5.
- **TRAP:** A trap-to-subroutine assembly language instruction that is a subroutine call. Its operand is a trap number that identifies a location in the trap vector table, which contains the address of the subroutine.

unsigned integer: A number system used to express positive integers.

watchdog timer: A timer option that can be programmed to generate an interrupt when it times out. This provides a hardware monitor over the software to prevent a "lost" program.

# Index

Note: **Boldface** page numbers identify a primary reference

? assembler operator, 4-16, 5-52& (ampersand) label address format, 4-6

## Α

A/D converter vector, 3-20 abbreviations See also symbols meaning "contents of ", 4-2 used with instructions, 5-2 accessing full 128K bytes, 4-16, 5-52 ADATA register, 3-18 ADC instruction, 5-19 ADD instruction, 5-17 add instructions 32-bit add, 5-19 ADC (add word plus carry), 5-19 ADD (add source, destination), 5-17 ADQ (add quick), 5-20 ADD/ADC sequence, 5-19 ADDB instruction, 5-17 address bus, 2-2, 2-8 example (JMP instruction), 4-8 address modes, 4-2 immediate, 4-7 implied, 4-3 PC relative, 4-4 register direct. 4-8 register indirect, 4-9 decrement/increment, 4-12 displacement, 4-13 no displacement, 4-10 substitution using offset, 4-9 summary, 4-2

address, code. See code address address, illegal, 3-10 addressing modes, summary, 4-2 addressing, indirect. See indirect addressing ADIR register, 3-18 ADQ instruction, 5-20 synthetic use (INC{B}), 5-55 ADQB instruction, 5-20 ampersand (&) label address format, 4-6 analog power supply, out of regulation, 3-12 analog power supply control, 3-9 AND instruction, 5-21 ANDB instruction, 5-21 architecture, 2-1 arithmetic shift, 5-25 ASR (artihmetic shift right), 5-23 SHL (shift left arithmetic), 5-91 ASR instruction, 5-23 ASR0 instruction, 5-25 ASR0L instruction, 5-25 ASRL instruction, 5-23 assembly language, 5-1 to 5-119 abbreviation summary table, 5-2 case sensitivity, iv, 5-16 individual instruction descriptions, 5-17 to 5-119 instruction summary table, 5-4 symbol table, 5-2 assistance (hot line, etc.), vi

## Β

B{COND} instructions BC, carry set, 5-27 BEQ, on equal, 5-27 BGE, greater than or equal, 5-27 B{COND} instructions (continued) BGT, greater than, 5-27 BHI, higher, 5-27 BHS, higher or the same, 5-27 BLE, less than or equal, 5-27 BLO, lower than, 5-27 BLS, lower or the same, 5-27 BLT, less than, 5-27 BN, on negative (minus), 5-27 BNC, carry is clear, 5-27 BNE, on not equal, 5-27 BNV, overflow is clear, 5-27 BP, on positive, 5-27 BPZ, on plus (not negative), 5-27 BR, branch always, 5-27 BV, on overflow set, 5-27 PC relative addressing example, 4-4 bit, 2-17 numbering, 2-14 restrictions, 2-17 value at manufacturing, 3-39 bit set instructions SBITO (set bit to zero), 5-89 SBIT1 (set bit to one), 5-90 branch instructions B{COND} (conditional branch), 5-27 BC, carry set, 5-27 BEQ, on equal, 5-27 BGE, greater than or equal, 5-27 BGT, greater than, 5-27 BHI, higher, 5-27 BHS, higher or the same, 5-27 BLE, less than or equal, 5-27 BLO, lower than, 5-27 BLS, lower or the same, 5-27 BLT, less than, 5-27 BN, on negative (minus), 5-27 BNC, carry is clear, 5-27 BNE, on not equal, 5-27 BNV, overflow is clear, 5-27 BP, on positive, 5-27 BPZ, on plus (not negative), 5-27 BR, branch always, 5-27 BRBITO (branch if bit is zero), 5-30 BRBIT1 (branch if bit is one), 5-32 BV, on overflow set, 5-27 logical, 5-28 signed, 5-28

BRBIT0 instruction, 5-30 execution redirection, 4-4 BRBIT1 instruction, 5-32 execution redirection, 4-4 brownout detector, 3-5 indicator, 3-3 brownout-detector power control, 3-9 byte, 2-14, 2-17 restrictions, 2-17

### С

CALL instruction, 2-18, 5-34 direct memory addressing example, 4-3 example, 2-13 return from CALL (RTS), 5-87 use with stack, 2-12 carry bit (ST), 2-7 loading, 5-60 carry value with add, 5-19 case sensitivity of assembler statements, iv, 5-16 check for ones, 5-107 check for zeroes, 5-106 **CLKOUT** pin control, 3-9 pin functions, options, 3-6 SCR1 register, 3-9 CLKSRC1/0 bits (clockout pin select), 3-9 CLR instruction, 5-37 CLRB instruction, 5-37 cMCU family, iii CMP instruction, 5-39 CMPB instruction, 5-39 CMPC instruction, 5-40 code address, 2-2 creation, 4-16 NMI usage, 3-24 use of ? operator, 4-16 code space, 2-18 compare instructions CMP (compare source to destination), 5-39 CMPC (compare source minus carry), 5-40 COMPL instruction, 5-42 COMPLB instruction, 5-42

complement instructions COMPL (twos complement), 5-42 NOT (ones complement), 5-81 conditions for branching, 5-27 configuration registers, system, 3-7 control pins, 3-14 control register, system, 3-8, 3-9 copy/move instructions FMOV (move far), 5-52 MOV (move within 0–64K bytes), 5-70 MOVQ (move quick, immediate value), 5-74 CRC (cyclic redundancy check) generator, 3-6 CRC generator, 3-6 cyclic redundancy check (CRC), 3-6

#### D

daisy-chain interrupt priority, 3-38 data organization, 2-14, 2-17 bit, byte, word restrictions, 2-17 data registers, port, 3-17 data truncation test **TRUNCS** instruction, 5-114 **TRUNCU** instruction, 5-115 DBNZ instruction, 5-43 DCR register, 3-16 DEC instruction, 5-45 **DECB** instruction, 5-45 decrement instructions DBNZ (decrement, branch if not zero), 5-43 DEC (decrement destination), 5-45 dedicated registers. See registers, specialized definition of words, Iv destinations, word and byte, 2-16 device (definition of), iv digital I/O pins, 3-14 digital I/O registers, 3-15, 3-16 to 3-18 DCR (digital output/control), 3-16 DIR (port direction register), 3-17 DSR (digital input status), 3-16 digital input/status registers, 3-16 digital inputs type A pin use, 3-29 type B pin use, 3-31 type C pin use, 3-33 digital output control registers, 3-16

digital port direction registers, 3-17 digital power status, 3-10 DIO registers. See digital I/O registers DIR register, 3-17 direct memory addressing, 4-5 format derivation, 4-6 direct register addressing, 4-8 direction register, port, 3-17 displacement for branch, 5-27 division by shift, 5-25 **DIVS instruction**, 5-46 **DIVSL** instruction, 5-46 **DIVU instruction**, 5-48 **DIVUL instruction**, 5-48 documentation, ordering, vi double word add, 5-19 DSR register, 3-16

# 

ECLK (external clock), 3-6 EEPROM programming, 3-12 effective address storage, 5-100 effective address store (LDEA instruction), 5-62 emulation slave mode vector, 3-20 emulation trap vectors, 3-20 enabling NMIs, 3-23 exception routine, 3-19 exception, software. See software exception execution steps for interrupts, 3-22 exiting low-power mode, 3-40 extension word (4-, 8-, 16-bit), 4-7 external interrupts, 3-28 See also interrupts, external external pins, 3-26 trap (illustrated), 3-20 vectors (illustrated), 3-20 external pin communication, 3-16 external pins, 3-16 INT1 (HPO application), 3-12 **RESET, 3-3** external reset, 3-11 EXTRST bit (external reset status), 3-11 EXTS instruction, 5-50 **EXTSB** instruction, 5-50

EXTZ instruction, 5-51 EXTZB instruction, 5-51

#### F

failure digital power, 3-10 oscillator, 3-10 fast add, 5-20 FMOV instruction, 2-18, 5-52 set up code address example, 4-17 FP (frame pointer), 2-4, 2-5 frame pointer (FP), 2-4, **2-5** freeze bit, 3-29, **3-39** type A interrupt options, **3-39** 

## G

glossary, A-1 *See also* Appendix A

# Η

halt mode, 3-40 IDLE instruction, 5-53 handling of interrupts, exceptions, 3-19 hardware protect override, 3-12 hot line, vi HPO bit (EEPROM programming), 3-12

I/O port registers, 3-18
IDLE instruction, 5-53
idle mode, 3-40 to 3-42
IDLE instruction, 5-53
ILLACC bit (illegal access reset status), 3-10
ILLADR bit (illegal address reset status), 3-10
illegal

access reset, 3-10
address access, 3-3
address reset, 3-10
opcode trap, 3-20
opcodes, 3-24, 5-54

illegal access, 3-3

reset, 3-10

illegal address access, 3-3 reset, 3-10 **ILLEGAL** instruction, 5-54 as software exception, 3-24 illegal opcode, trap, 3-20 IM (implied register), 2-5 immediate add, quick, 5-20 immediate addressing, 4-7 implied addressing, 4-3 implied register (IM), 2-4, 2-5 INC instruction, 5-55 INCB instruction, 5-55 indirect addressing, register, memory, 2-16 indirect register addressing, 4-9 decrement/increment, 4-12 displacement, 4-13 no displacement, 4-10 substitution using offset, 4-9 INIT1 pin (EEPROM programming), 3-12 instruction modes, 4-2 instructions See also assembly language 1, 2, 3 word types, 2-10 interpretation, 5-16 organization (1, 2, 3 words), 2-10 stack usage, 2-11 use 17-bit address, 2-9 internal module communication, 3-16 interpolation INTPU instruction, 5-56 TBLU instruction (table lookup), 5-108 interrupt mask bits (ST), 2-7 interrupts, 3-19 to 3-38 daisy-chain priority, 3-38 external, 3-25, 3-28 frame, 3-25 INTx pins, 3-28 type A, 3-29, 3-30 type B, 3-31, 3-32 type C, 3-33, 3-34 vectors, 3-20 external pins, 3-26 frame, 3-25 frames, examples, 3-27, 3-28 hardware, 3-21 INTx pins, 3-28 invalid, 3-37

interrupts (continued) multiple, 3-38 nested routines, 3-38 nonmaskable, 3-19 peripheral, 3-19 phantom, 3-37 power module interrupts, 3-35 priority chain, 3-37 resets, 3-19 routine description, 3-19 servicing multiple, 3-38 software, 3-21 software exceptions, 3-19 stack usage, 2-12 steps of execution, 3-22 trap table base address, 3-20, 3-21 type A, 3-29, 3-30 type B, 3-31, 3-32 type C, 3-33, 3-34 **INTPU instruction**, 5-56 INTx pins, 3-28 invalid interrupts, 3-37

### J

JMP instruction, 5-58 code address example, 4-16 offset + register example, 4-15 register direct example, 4-8 jump to destination address (JMP), 5-58 to subroutine (CALL), 5-34

LDBIT instruction, 5-60 LDBITB instruction, 5-60 LDEA instruction, 5-62 LIMHS instruction, 5-63 LIMHSB instruction, 5-63 LIMHU instruction, 5-64 LIMHUB instruction, 5-64 limit register value to highest signed value (LMHS), 5-63 to 5-67 highest unsigned value (LIMHU), 5-64 to 5-68 lowest signed value (LIMLS), 5-65 to 5-69 lowest unsigned value (LIMLU), 5-66 to 5-70

LIMLS instruction, 5-65 LIMLSB instruction, 5-65 LIMLU instruction, 5-66 LIMLUB instruction, 5-66 LINK instruction, 5-67 load effective address, 5-62 load value into carry bit (LDBIT instruction), 5-60 logic instructions AND (logical AND), 5-21 OR (logical OR), 5-82 XNOR (exclusive NOR), 5-118 XOR (exclusive OR), 5-119 logical AND, 5-21 logical branch instructions, 5-28 logical shift instructions SHL4 (shift left logical 4 bits), 5-94 SHL8 (shift left logical 8 bits), 5-95 SHR8 (shift right logical 8 bits), 5-96 low-power modes, 3-40 to 3-42 LSR instruction, 5-68 LSRL instruction, 5-68



memory access, illegal, 3-10 memory addressing, memory direct, 4-5 format derivation, 4-6 memory check, 3-6 memory map, 2-3 code and data space, 2-18 typical, 2-18 modes of address, 4-2 module (definition of), iv MOV instruction, 4-9, 5-70 code address example, 4-16 code address setup example, 4-17 example, memory direct addressing, 4-5 immediate value example, 4-7 offset + register example, 4-13 register decrement/increment example, 4-12 register direct example, 4-8 register indirect, postincrement example, 4-12 register indirect, predecrement example, 4-11 synthetic use, CLR{B} instruction, 5-37 synthetic uses EXTZ{B} instruction, 5-51 TST{B} instruction, 5-116 use of ? operator, 4-17

MOVB example, 2-16 MOVB instruction, 5-70 offset + register example, 4-14 move within 128K bytes, 5-52 move/copy instructions FMOV (move far), 5-52 MOV (move within 64K bytes), 5-70 MOVQ (move quick, immediate value), 5-74 MOVQ instruction, 5-74 MPYBWU instruction, 5-75 MPYS instruction, 5-76 MPYSB instruction, 5-76 MPYU instruction, 5-78 MPYUB instruction, 5-78 multiple interrupt servicing, 3-38 multipl5-bit check for 0s, 5-106 for 1s, 5-107

#### Ν

NCRF (New Code Release Form), 3-39 negative bit (ST), 2-7 New Code Release Form (NCRF), 3-39 NMI (nonmaskable interrupt), 3-23 disabling, 3-23 enabling, 3-23 execution summary, 3-22 processing, 3-23 processing steps, 3-23 status register, 3-23 use of type A interrupt pins, 3-29 use of type B interrupt pins, 3-31 use of type C interrupt pins, 3-33 vector table, 3-21 nonmaskable interrupt. See NMI nonmemory access, 3-3 NOP instruction, 5-80 normal run mode, 3-4 NOT instruction, 5-81 NOTB instruction, 5-81

# 0

ones check, 5-107

opcodes, illegal, 5-54 operator ? (question mark), 4-16 OR instruction, 5-82 ORB instruction, 5-82 oscillator failure, 3-10 reset, 3-3 reset status, 3-10 oscillator module and low-power modes, 3-40 OSCRST bit (osc reset status), 3-10 overflow bit (ST), 2-7

## Ρ

parallel signature analysis (PSA), 3-6 PSAR1/2 registers, 3-13 parallel signature analysis registers (PSAR1/2), 3-6 PC. See program counter; program counter (PC) PC relative addressing, 4-4 peripheral interrupt replication, 5-111 peripheral interrupts description, 3-19 execution summary, 3-22 processing, 3-24 replication, 5-111 vector table, 3-21 phantom interrupts, 3-37 priority chain, 3-37 vectors (illustrated), 3-20 pins configuring, 3-14 control, 3-14 external, 3-16 INT1 (HPO application), 3-12 RESET, 3-3 general-purpose, 3-14 INT1 (HPO application), 3-12 **RESET, 3-3** status, 3-14 pipeline, 5-27 pipeline prefetch, 3-24 PMx ENBL registers, 3-35 PMx FLAGS registers, 3-36

Index-6 TMS370C16 CPU

polling, interrupt occurance type A interrupt, 3-30 type B interrupt, 3-32 type C interrupt, 3-34 POP instruction. 5-83 PORST bit (power on reset), 3-10 port data registers, 3-17 port direction registers, 3-17 postincrement register example, 4-12 power control brown-out detector as controller, 3-9 voltage regulator as controller, 3-9 power module fault condition, 3-25 interrupt enable (register), 3-35 interrupts, 3-35 pins, 3-25 power module vectors, 3-20 power on reset, 3-10 power supply control (analog), 3-9 power-saving mode exiting, 3-40 halt, 3-40 standby, 3-40 predecrement register example, 4-11, 4-12 prefetch pipeline, 5-27 primary voltage regulator, 3-5 priority chain, interrupts, 3-37 PRISM technology, iii products, TI, vi program counter (PC), 2-2, 2-8 address bus, 2-8 addressing relative to PC, 4-4 during interrupt routine, 3-19 memory-address relationship, 2-9 programmer's model, 2-2 programming of EEPROMs, 3-12 PSA, 3-6 PSAR1/PSAR2. 3-6 PSAR1/PSAR2 registers, 3-13 PUSH instruction, 5-84

#### Q

question mark (?) operator, 4-16, 5-52 quick add, 5-20

#### R

reduce power mode exiting, 3-40 halt, 3-40 standby, 3-40 reduced clock cycles halt, 3-40 standby, 3-40 register direct addressing, 4-8 register file. See registers, specialized register indirect addressing, 4-9 decrement/increment, 4-12 displacement, 4-13 no displacement, 4-10 substitution using offset, 4-9 register shift, 5-25 ASR (arithmetic shift right), 5-23 SHL (shift left arithmetic), 5-91 register shift instructions SHL4 (shift left logical 4 bits), 5-94 SHL8 (shift left logical 8 bits), 5-95 SHR8 (shift right logical 8 bits), 5-96 register value limited to highest signed value (LMHS), 5-63 to 5-67 highest unsigned value (LIMHU), 5-64 to 5-68 lowest signed value (LIMLS), 5-65 to 5-69 lowest unsigned value (LIMLU), 5-66 to 5-70 registers, dedicated. See registers, specialized registers, general bit numbering, 2-14 considerations, 2-7 dedicated. 2-4 system configuration, 3-7 registers, port, 3-17 registers, specialized, 2-4 considerations, 2-7 frame pointer, 2-5 implied register, 2-5 stack pointer, 2-6, 2-11 status register, 2-6 zero register, 2-7 registers, system configuration, 3-7 SCR0 (system control 0), 3-8 SCR1 (system control 1), 3-9 SRSR (system reset status), 3-10 regulator, voltage, 3-5 replication of peripheral interrupt, 5-111

reserved trap locations, 5-111 reset cause external, 3-11 illegal access, 3-10 illegal address, 3-10 oscillator fail, 3-10 software, 3-10 watchdog timer, 3-11 description, 3-19 event sequence, 3-5 execution summary, 3-22 external reset, 3-11 illegal access , 3-10 illegal address, 3-10 oscillator fail, 3-10 oscillator reset. 3-3 pin, 3-3 power on reset, 3-10 pulse, 8-count, 3-4 register bits, 3-3, 3-8, 3-10, 3-12 sequence, 3-5 software, 3-10, 3-19, 3-21 state diagram, 3-4 status bits, 3-10 status register, 3-5, 3-10 system, 3-3 system status (SRSR register), 3-10 vector (illustration), 3-20 vector table, 3-21 watchdog timer, 3-11 RESET pin, 3-3 RESET0/1 bits (software reset control), 3-8 return instructions from interrupt (RTI), 5-86 from subroutine (RTS), 5-87 right shift, 5-25 right shift (ASR instruction), 5-23 round to zero, shift instruction, 5-25 rounded interpolation **INTPU**, 5-56 TBLU (table lookup), 5-108 rounding for interpolation, 5-109 **RTDU instruction**, 5-85 **RTI instruction**, 5-86 enabling NMIs, 3-23 function at end of interrupt routine, 3-19

RTS instruction, 5-87 implied addressing example, 4-3 run mode, normal, 3-4

# S

SBB instruction, 5-88 SBIT0 instruction, 5-89 synthetic use (NOP), 5-80 SBIT0B instruction, 5-89 SBIT1 instruction, 5-90 SBIT1B instruction, 5-90 SCI vector, 3-20 SCR0 register, 3-8 SCR1 register, 3-9 set/load a bit (LDBIT instruction), 5-60 shift count, 5-23, 5-25 shift instructions ASR (arithmetic shift right), 5-23 ASR0 (arithmetic right shift, round to zero), 5-25, 5-30 LSR (logically right shift), 5-68 SHL (shift left arithmetic), 5-91 SHL4 (shift left logical 4 bits), 5-94 SHL8 (shift left logical 8 bits), 5-95 SHR8 (shift right logical 8 bits), 5-96 shift, signed, 5-25 ASR (arithmetic shift right), 5-23 SHL (shift left arithmetic), 5-91 SHL instruction, 5-91 example, 5-92 SHL4 instruction, 5-94 SHL8 instruction, 5-95 SHLL instruction, 5-91 SHR8 instruction, 5-96 sign extension EXTS (extend to next larger data size), 5-50 EXTZ (extend unsigned with zeroes), 5-51 signature analysis, 3-6 registers PSAR0/1, 3-13 signed branch instructions, 5-28 signed shift, 5-25 ASR (artihmetic shift right), 5-23 SHL (shift left arithmetic), 5-91 software exception causes, 3-24 description, 3-19

software exception (continued) execution summary, 3-22 **ILLEGAL** instruction, 5-54 illegal instruction, 3-24 processing, 3-24 status register, 3-24 TRAP instruction, 3-24, 5-111 software reset, 3-10 SP, stack pointer. See stack pointer (SP) specialized registers. See registers, specialized SPI vector, 3-20 SRC0, 3-8 SRC1. 3-9 SRSR register, 3-10 SSR register, 3-12 ST, status register. See status register (ST) stack. 2-11 See also stack instructions during interrupt routine, 3-19 example, 2-13 interrupt example, 2-12 stack pointer. See stack pointer (SP) use with CALL, 2-12 stack instructions, 2-11 LINK (link and allocate stack), 5-67 list, 2-11 POP (pull from stack), 5-83 PUSH (push onto stack), 5-84 RTDU (unlink stack, return from subroutine), 5-85 UNLINK (unlink, deallocate stack), 5-117 stack pointer (SP), 2-4, 2-6, 2-11 even-value requirement, 2-12 example (RTS instruction), 4-3 standby mode, 3-40 IDLE instruction, 5-53 status pins, 3-14 status register (ST), 2-3, 2-4, 2-6 during interrupt routine, 3-19 during peripheral module interrupt, 3-24 during software exception, 3-24 enabling of NMIs, 3-23 set interrupt mask, 5-101 store contents, 5-101 status register instructions LDBT (load into carry bit), 5-60 STBIT (store ST bit, set carry), 5-97 STRI (store ST, set interrupt level), 5-101 STBIT instruction, 5-97

STBITB instruction, 5-97 semaphore check examples, 5-98 STEA instruction, 5-100 straight-line interpolation INTPU. 5-56 TBLU (table lookup), 5-108 STRI instruction, 5-101 SUB instruction, 5-102 SUBB instruction, 5-102 SUBQ instruction, 5-45, 5-103 synthetic use (DEC{B}), 5-45 SUBQB instruction, 5-103 SUBR instruction, 5-104 example, 2-13 synthetic use (COMPL{B}), 5-42 SUBRB instruction, 5-104 subroutine return, 5-87 subtract instructions SUB (subtract source from destination), 5-102 SUBQ (subtract quick immediate from destination), 5-103 SUBR (subtract with reverse destination), 5-104 swap byte values, 5-105 SWAPB instruction. 5-105 example, 5-105 SWRST bit (software reset status), 3-10 symbolization, for "contents of", 4-2 symbols meaning "contents of", 4-2 that designate registers, iv used to define instructions, 5-3 SYSCLK, 3-3 system block diagram, 3-2 stack. See stack system clock CLKOUT pin, 3-6 output, 3-6 system configuration external interrupts, 3-25 idle mode, 3-40 interrupts, 3-19 low-power modes, 3-40 overview, 3-2 registers, 3-7 digital input/output (DIO), 3-14 reset operation, 3-3 system considerations. See Chapter 3

system control register 0, 3-8 system control register 1, 3-9 system reset status register, 3-10 system status register, 3-12

### T

TBITO instruction (with example), 5-106 TBIT1 instruction (with example), 5-107 **TBLU instruction**, 5-108 **TBLUB** instruction, 5-108 test for data truncation **TRUNCS instruction**, 5-114 **TRUNCU** instruction, 5-115 timer vectors, 3-20 TMS370C16, system configuration, 3-1 TRAP instruction, 5-111 enabling NMIs, 3-23 enumerator calculation, 5-112 software exception, 3-24 trap locations, reserved, 5-111 trap table, 3-20, 3-21 base address (TBA), 3-21 reserved locations, 5-111 truncation possibility test **TRUNCS** instruction, 5-114 TRUNCU instruction, 5-115 **TRUNCS** instruction, 5-114 **TRUNCSL** instruction, 5-114 **TRUNCU** instruction, 5-115 TST instruction, 5-116 TSTB instruction, 5-116 type A interrupt, 3-29, 3-30 type B interrupt, 3-31, 3-32 type C interrupt, 3-33, 3-34

# U

UNLINK instruction, 5-117

# V

variants (instruction), **5-4**, 5-16  $V_{cc}$ , out of range, 3-3

VCCA status, 3-12 VCCAON bit, 3-9 VCCAOR bit, 3-12 VCCD out of regulation, 3-10 vector table (interrupts, reset, NMI, peripherals), 3-21 vectors, interrupt, description, 3-20 voltage regulator, primary, 3-5 voltag5-regulator power control, 3-9 voltage, EEPROM programming, 3-12

## W

wait state (idle mode), 3-40 exit, 3-40
wakeup interrupt, 3-40
watchdog timer overflow, 3-3 reset, 3-3, 3-11
watchdog/RTI vectors, 3-20
WDCLK (watchdog clock), 3-6
WDRST bit (watchdog reset status), 3-11
word, 2-14, 2-17 restrictions, 2-17
word access, 3-10
word access reset, 3-3
word address, 2-8 with CALL instruction, 5-34

## Χ

XNOR instruction, 5-118 synthetic use (NOT{B}), 5-81 XOP trap, 3-20 XOR instruction, 5-119 XORB instruction, 5-119

# Ζ

zero bit (ST), 2-7 zero register (ZR), 2-4, **2-7** zero rounding, shift instruction, 5-25 zeroes check, 5-106 ZR, zero register, 2-7

