# TMS320C24x DSP Controllers Reference Set

# Volume 1: CPU, System, and Instruction Set

This document contains preliminary data current as of publication date and is subject to change without notice.

> Literature Number: SPRU160B September 1997







#### **IMPORTANT NOTICE**

Texas Instruments (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 the specifications applicable at the time of sale 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.

Certain applications using semiconductor products may involve potential risks of death, personal injury, or severe property or environmental damage ("Critical Applications").

TI SEMICONDUCTOR PRODUCTS ARE NOT DESIGNED, INTENDED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT APPLICATIONS, DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS.

Inclusion of TI products in such applications is understood to be fully at the risk of the customer. Use of TI products in such applications requires the written approval of an appropriate TI officer. Questions concerning potential risk applications should be directed to TI through a local SC sales office.

In order to minimize risks associated with the customer's applications, adequate design and operating safeguards should be provided by the customer to minimize inherent or procedural hazards.

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 expressed 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 © 1997, Texas Instruments Incorporated

# Preface

# **Read This First**

### About This Manual

This manual (volume 1 of a 2-volume set) describes the architecture, central processing unit (CPU), system hardware, assembly language instructions, and general operation of the TMS320C24x digital signal processor (DSP) controllers. In this document, the TMS320C24x is also referred to as the 'C24x.

The *TMS320C24x DSP Controllers Reference Set, Volume 2: Peripheral Library and Specific Devices* (literature number SPRU161) describes the peripherals available in the 'C24x family and their operation. Also described are specific device configurations of the 'C24x family.

For a summary of updates in this book, see Appendix E, *Summary of Updates in This Document.* 

#### How to Use This Manual

The following table summarizes the 'C24x information contained in this manual:

| If you are looking for<br>information about                                       | Turn to                                                           |
|-----------------------------------------------------------------------------------|-------------------------------------------------------------------|
| Addressing modes (for addressing data memory)                                     | Chapter 7, Addressing Modes                                       |
| Assembly language instructions                                                    | Chapter 8, Assembly Language<br>Instructions                      |
| Comparison of assembly language instructions for TMS320C1x, 'C2x, 'C24x, and 'C5x | Appendix A, TMS320C1x/C2x/C24x/C5x<br>Instruction Set Comparisons |
| CPU                                                                               | Chapter 3, Central Processing Unit                                |
| Custom ROM from TI                                                                | Appendix B, Submitting ROM Codes to TI                            |
| Emulator                                                                          | Appendix C, Design Considerations for Using XDS510 Emulator       |
| Features                                                                          | Chapter 1, Introduction<br>Chapter 2, Architectural Overview      |

| If you are looking for                 |                                                    |
|----------------------------------------|----------------------------------------------------|
| information about                      | Turn to                                            |
| Input/output ports                     | Chapter 4, Memory and I/O Spaces                   |
| Interrupts                             | Chapter 6, System Functions                        |
| Memory configuration                   | Chapter 4, Memory and I/O Spaces                   |
| Peripheral interface                   | Chapter 6, System Functions                        |
| Pipeline                               | Chapter 5, Program Control                         |
| Power-down modes                       | Chapter 6, System Functions                        |
| Program control                        | Chapter 5, Program Control                         |
| Program-memory address generation      | Chapter 5, Program Control                         |
| Reset                                  | Chapter 6, System Functions                        |
| Stack                                  | Chapter 5, Program Control                         |
| Status registers                       | Chapter 6, System Functions                        |
| Summary of Changes in This<br>Document | Appendix E, Summary of Updates<br>in This Document |

# Notational Conventions

This document uses the following conventions:

Program listings and program examples are shown in a special typeface.

Here is a segment of a program listing:

OUTPUT LDP #6 ;select data page 6 BLDD #300, 20h ;move data at address 300h to 320h RET

In syntax descriptions, the instruction is in a **bold typeface** and parameters are in an *italic typeface*. Portions of a syntax in **bold** must be entered as shown; portions of a syntax in *italics* describe the type of information that you specify. Here is an example of an instruction syntax:

#### **BLDD** source, destination

**BLDD** is the instruction and has two parameters, *source* and *destination*. When you use **BLDD**, the first parameter must be an actual data memory source address and the second parameter must be a destination address. A comma and a space (optional) must separate the two addresses.

Square brackets, [], identify an optional parameter. If you use an optional parameter, specify the information within the brackets; do not type the brackets themselves. When you specify more than one optional parameter from a list, you separate them with a comma and a space. Here is a sample syntax:

#### BLDD source, destination [, ARn]

**BLDD** is the instruction. The two required operands are *source* and *destination*, and the optional operand is **AR***n*. **AR** is bold and *n* is italic; if you choose to use **AR***n*, you must type the letters A and R and then supply a chosen value for *n* (in this case, a value from 0 to 7). Here is an example:

BLDD \*, #310h, AR3

#### Information About Cautions

This book contains cautions.



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

# **Related Documentation From Texas Instruments**

The following books describe the 'C24x and related support tools. To obtain a copy of any of these TI documents, call the Texas Instruments Literature Response Center at (800) 477–8924. When ordering, please identify the book by its title and literature number.

- TMS320C24x DSP Controllers Reference Set Volume 2: Peripheral Library and Specific Devices (literature number SPRU161) describes the peripherals available on the TMS320C24x digital signal processor controllers and their operation. Also described are specific device configurations of the 'C24x family.
- **TMS320C240, TMS320F240 DSP Controllers** (literature number SPRS042) data sheet contains the electrical and timing specifications for these devices, as well as signal descriptions and pinouts for all of the available packages.
- TMS320C1x/C2x/C2xx/C5x Code Generation Tools Getting Started Guide (literature number SPRU121) describes how to install the TMS320C1x, TMS320C2x, TMS320C2xx, and TMS320C5x assembly language tools and the C compiler for the 'C1x, 'C2x, 'C2xx, and 'C5x devices. The installation for MS-DOS<sup>™</sup>, OS/2<sup>™</sup>, SunOS<sup>™</sup>, and Solaris<sup>™</sup> systems is covered.

- TMS320C1x/C2x/C2xx/C5x Assembly Language Tools User's Guide (literature number SPRU018) describes the assembly language tools (assembler, linker, and other tools used to develop assembly language code), assembler directives, macros, common object file format, and symbolic debugging directives for the 'C1x, 'C2x, 'C2xx, and 'C5x generations of devices.
- TMS320C2x/C2xx/C5x Optimizing C Compiler User's Guide (literature number SPRU024) describes the 'C2x/C2xx/C5x C compiler. This C compiler accepts ANSI standard C source code and produces TMS320 assembly language source code for the 'C2x, 'C2xx, and 'C5x generations of devices.
- TMS320C2xx C Source Debugger User's Guide (literature number SPRU151) tells you how to invoke the 'C2xx emulator and simulator versions of the C source debugger interface. This book discusses various aspects of the debugger interface, including window management, command entry, code execution, data management, and breakpoints. It also includes a tutorial that introduces basic debugger functionality.
- **TMS320C2xx** Simulator Getting Started (literature number SPRU137) describes how to install the TMS320C2xx simulator and the C source debugger for the 'C2xx. The installation for MS-DOS<sup>™</sup>, PC-DOS<sup>™</sup>, SunOS<sup>™</sup>, Solaris<sup>™</sup>, and HP-UX<sup>™</sup> systems is covered.
- **TMS320C2xx Emulator Getting Started Guide** (literature number SPRU209) tells you how to install the Windows<sup>™</sup> 3.1 and Windows<sup>™</sup> 95 versions of the 'C2xx emulator and C source debugger interface.
- **XDS51x Emulator Installation Guide** (literature number SPNU070) describes the installation of the XDS510<sup>™</sup>, XDS510PP<sup>™</sup>, and XDS510WS<sup>™</sup> emulator controllers. The installation of the XDS511<sup>™</sup> emulator is also described.
- XDS522/XDS522A Emulation System Installation Guide (literature number SPRU171) describes the installation of the emulation system. Instructions include how to install the hardware and software for the XDS522™ and XDS522™.
- XDS522A Emulation System User's Guide (literature number SPRU169) tells you how to use the XDS522A<sup>™</sup> emulation system. This book describes the operation of the breakpoint, tracing, and timing functionality in the XDS522A emulation system. This book also discusses BTT software interface and includes a tutorial that uses step-by-step instructions to demonstrate how to use the XDS522A emulation system.

- **XDS522A Emulation System Online Help** (literature number SPRC002) is an online help file that provides descriptions of the BTT software user interface, menus, and dialog boxes.
- JTAG/MPSD Emulation Technical Reference (literature number SPDU079) provides the design requirements of the XDS510<sup>™</sup> emulator controller, discusses JTAG designs (based on the IEEE 1149.1 standard), and modular port scan device (MPSD) designs.
- **TMS320 DSP Development Support Reference Guide** (literature number SPRU011) describes the TMS320 family of digital signal processors and the tools that support these devices. Included are code-generation tools (compilers, assemblers, linkers, etc.) and system integration and debug tools (simulators, emulators, evaluation modules, etc.). Also covered are available documentation, seminars, the university program, and factory repair and exchange.
- *Digital Signal Processing Applications with the TMS320 Family, Volumes 1, 2, and 3* (literature numbers SPRA012, SPRA016, SPRA017) Volumes 1 and 2 cover applications using the 'C10 and 'C20 families of fixed-point processors. Volume 3 documents applications using both fixed-point processors, as well as the 'C30 floating-point processor.
- *TMS320 DSP Designer's Notebook: Volume 1* (literature number SPRT125) presents solutions to common design problems using 'C2x, 'C3x, 'C4x, 'C5x, and other TI DSPs.
- **TMS320** Third-Party Support Reference Guide (literature number SPRU052) alphabetically lists over 100 third parties that provide various products that serve the family of TMS320 digital signal processors. A myriad of products and applications are offered—software and hardware development tools, speech recognition, image processing, noise cancellation, modems, etc.

# **Related Technical Articles**

The following technical articles contain beneficial information regarding designs, operations, and applications for signal-processing systems; all of the documents provide additional references.

"A Greener World Through DSP Controllers", Panos Papamichalis, *DSP & Multimedia Technology*, September 1994.

"A Single-Chip Multiprocessor DSP for Image Processing—TMS320C80", Dr. Ing. Dung Tu, *Industrie Elektronik*, Germany, March 1995.

"Application Guide with DSP Leading-Edge Technology", Y. Nishikori, M. Hattori, T. Fukuhara, R.Tanaka, M. Shimoda, I. Kudo, A.Yanagitani, H. Miyaguchi, et al., *Electronics Engineering*, November 1995.

"Approaching the No-Power Barrier", Jon Bradley and Gene Frantz, *Electronic Design*, January 9, 1995.

"Beware of BAT: DSPs Add Brilliance to New Weapons Systems", Panos Papamichalis, *DSP & Multimedia Technology*, October 1994.

"Choose DSPs for PC Signal Processing", Panos Papamichalis, *DSP & Multimedia Technology*, January/February 1995.

"Developing Nations Take Shine to Wireless", Russell MacDonald, Kara Schmidt and Kim Higden, *EE Times*, October 2, 1995.

"Digital Signal Processing Solutions Target Vertical Application Markets", Ron Wages, *ECN*, September 1995.

"Digital Signal Processors Boost Drive Performance", Tim Adcock, *Data Storage*, September/October 1995.

"DSP and Speech Recognition, An Origin of the Species", Panos Papamichalis, *DSP & Multimedia Technology*, July 1994.

"DSP Design Takes Top-Down Approach", Andy Fritsch and Kim Asal, *DSP Series Part III, EE Times*, July 17, 1995.

"DSPs Advance Low-Cost 'Green' Control", Gregg Bennett, *DSP Series Part II, EE Times*, April 17, 1995.

"DSPs Do Best on Multimedia Applications", Doug Rasor, *Asian Computer World*, October 9–16, 1995.

"DSPs: Speech Recognition Technology Enablers", Gene Frantz and Gregg Bennett, *I&CS*, May 1995.

"Easing JTAG Testing of Parallel-Processor Projects", Tony Coomes, Andy Fritsch, and Reid Tatge, *Asian Electronics Engineer*, Manila, Philippines, November 1995.

"Fixed or Floating? A Pointed Question in DSPs", Jim Larimer and Daniel Chen, *EDN*, August 3, 1995.

"Function-Focused Chipsets: Up the DSP Integration Core", Panos Papamichalis, DSP & Multimedia Technology, March/April 1995.

"GSM: Standard, Strategien und Systemchips", Edgar Auslander, *Elektronik Praxis*, Germany, October 6, 1995.

"High Tech Copiers to Improve Images and Reduce Paperwork", Karl Guttag, *Document Management*, July/August 1995.

"Host-Enabled Multimedia: Brought to You by DSP Solutions", Panos Papamichalis, DSP & Multimedia Technology, September/October 1995.

"Integration Shrinks Digital Cellular Telephone Designs", Fred Cohen and Mike McMahan, Wireless System Design, November 1994.

"On-Chip Multiprocessing Melds DSPs", Karl Guttag and Doug Deao, DSP Series Part III, EE Times, July 18, 1994.

"Real-Time Control", Gregg Bennett, Appliance Manufacturer, May 1995.

"Speech Recognition", P.K. Rajasekaran and Mike McMahan, Wireless Design & Development, May 1995.

"Telecom Future Driven by Reduced Milliwatts per DSP Function", Panos Papamichalis, DSP & Multimedia Technology, May/June 1995.

"The Digital Signal Processor Development Environment", Greg Peake, Embedded System Engineering, United Kingdom, February 1995.

"The Growing Spectrum of Custom DSPs", Gene Frantz and Kun Lin, DSP Series Part II, EE Times, April 18, 1994.

"The Wide World of DSPs, " Jim Larimer, *Design News*, June 27, 1994.

"Third-Party Support Drives DSP Development for Uninitiated and Experts Alike", Panos Papamichalis, DSP & Multimedia Technology, December 1994/January 1995.

"Toward an Era of Economical DSPs", John Cooper, DSP Series Part I, EE *Times*, Jan. 23, 1995.

### Trademarks

HP-UX is a trademark of Hewlett-Packard Company.

MS-DOS and Windows are registered trademarks of Microsoft Corporation.

OS/2, PC, and PC-DOS are trademarks of International Business Machines Corporation.

PAL® is a registered trademark of Advanced Micro Devices, Inc.

Solaris and SunOS are trademarks of Sun Microsystems, Inc.

320 Hotline On-line, TI, XDS510, XDS510PP, XDS510WS, XDS511, XDS522, and XDS522A are trademarks of Texas Instruments Incorporated.

# PRELIMINARY

Read This First

ix

# If You Need Assistance . . .

|          | Warld Wide Web Oites                                                                                                        |                                    |                            |                      |  |
|----------|-----------------------------------------------------------------------------------------------------------------------------|------------------------------------|----------------------------|----------------------|--|
|          | World-Wide Web Sites                                                                                                        |                                    |                            |                      |  |
|          | TI Online                                                                                                                   | http://www.ti.con                  |                            |                      |  |
|          | Semiconductor Product Information Center (PIC)                                                                              |                                    | n/sc/docs/pic/home.htm     |                      |  |
|          | DSP Solutions                                                                                                               | http://www.ti.con                  |                            |                      |  |
|          | 320 Hotline On-line™                                                                                                        | http://www.ti.con                  | n/sc/docs/dsps/support.htm | n                    |  |
|          | North America, South America, Ce                                                                                            | entral America                     |                            |                      |  |
|          | Product Information Center (PIC)                                                                                            | (972) 644-5580                     |                            |                      |  |
|          | TI Literature Response Center U.S.A.                                                                                        | (800) 477-8924                     |                            |                      |  |
|          | Software Registration/Upgrades                                                                                              | (214) 638-0333                     | Fax: (214) 638-7742        |                      |  |
|          | U.S.A. Factory Repair/Hardware Upgrades                                                                                     | (281) 274-2285                     |                            |                      |  |
|          | U.S. Technical Training Organization                                                                                        | (972) 644-5580                     |                            |                      |  |
|          | DSP Hotline                                                                                                                 | (281) 274-2320                     | Fax: (281) 274-2324        | Email: dsph@ti.com   |  |
|          | DSP Modem BBS                                                                                                               | (281) 274-2323                     |                            |                      |  |
|          | DSP Internet BBS via anonymous ftp to ftp://ft                                                                              | tp.ti.com/pub/tms320               | Obbs                       |                      |  |
|          | Europe, Middle East, Africa                                                                                                 |                                    |                            |                      |  |
|          | European Product Information Center (EPIC)                                                                                  | Hotlines:                          |                            |                      |  |
|          | Multi-Language Support                                                                                                      | +33 1 30 70 11 69                  | Fax: +33 1 30 70 10 32     | Email: epic@ti.com   |  |
|          | Deutsch +49 8161 80 33 11 or                                                                                                | +33 1 30 70 11 68                  |                            |                      |  |
|          | 5 -                                                                                                                         | +33 1 30 70 11 65                  |                            |                      |  |
|          |                                                                                                                             | +33 1 30 70 11 64                  |                            |                      |  |
|          |                                                                                                                             | +33 1 30 70 11 67                  |                            |                      |  |
|          |                                                                                                                             | +33 1 30 70 11 99                  |                            |                      |  |
|          | , , ,                                                                                                                       | +33 4 93 22 25 40                  | E 40.04.04.00.40.4         |                      |  |
|          | Europe Customer Training Helpline                                                                                           |                                    | Fax: +49 81 61 80 40 10    | )                    |  |
|          | Asia-Pacific                                                                                                                |                                    |                            |                      |  |
|          | Literature Response Center                                                                                                  | +852 2 956 7288                    | Fax: +852 2 956 2200       |                      |  |
|          | Hong Kong DSP Hotline                                                                                                       | +852 2 956 7268                    | Fax: +852 2 956 1002       |                      |  |
|          | Korea DSP Hotline                                                                                                           | +82 2 551 2804                     | Fax: +82 2 551 2828        |                      |  |
|          | Korea DSP Modem BBS                                                                                                         | +82 2 551 2914                     | E 05 000 7470              |                      |  |
|          | Singapore DSP Hotline                                                                                                       |                                    | Fax: +65 390 7179          |                      |  |
|          | Taiwan DSP Hotline<br>Taiwan DSP Modem BBS                                                                                  | +886 2 377 1450<br>+886 2 376 2592 | Fax: +886 2 377 2718       |                      |  |
|          | Taiwan DSP Internet BBS via anonymous ftp                                                                                   |                                    | ı tw/pub/TI/               |                      |  |
| <u> </u> |                                                                                                                             |                                    |                            |                      |  |
|          | Japan                                                                                                                       |                                    |                            |                      |  |
|          | Product Information Center +0120-8                                                                                          | 1-0026 (in Japan)                  | Fax: +0120-81-0036 (in     | Japan)               |  |
|          | +03-3457-0972 or (INT                                                                                                       |                                    | Fax: +03-3457-1259 or      |                      |  |
|          | DSP Hotline +03-3769-8735 or (INT                                                                                           | L) 813-3769-8735                   | Fax: +03-3457-7071 or      | (INTL) 813-3457-7071 |  |
|          | DSP BBS via Nifty-Serve                                                                                                     | Type "Go TIASP"                    |                            |                      |  |
|          | Documentation                                                                                                               |                                    |                            |                      |  |
|          | When making suggestions or reporting errors in documentation, please include the following information that is on the title |                                    |                            |                      |  |
|          | page: the full title of the book, the publication                                                                           | date, and the literatu             | ure number.                |                      |  |
|          | Mail: Texas Instruments Incorporated                                                                                        |                                    | Email: comments@boo        | ks.sc.ti.com         |  |
|          | Technical Documentation Services,                                                                                           | MS 702                             |                            |                      |  |
|          | P.O. Box 1443                                                                                                               |                                    |                            |                      |  |
|          | Houston, Texas 77251-1443                                                                                                   |                                    |                            |                      |  |
|          | lote: When calling a Literature Response Center to order documentation, please specify the literature number of the         |                                    |                            |                      |  |

**Note:** When calling a Literature Response Center to order documentation, please specify the literature number of the book.

# Contents

| 1 | Sum        | duction                                                                                                                                                                                                                                  |
|---|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | 1.1<br>1.2 | TMS320 Family Overview1-2TMS320C24x Series of DSP Controllers1-4                                                                                                                                                                         |
|   | 1.3        | TMS320C240 Overview         1-6                                                                                                                                                                                                          |
| 2 | Arch       | itectural Overview                                                                                                                                                                                                                       |
|   |            | marizes the TMS320C24x architecture. Provides an overview of the CPU, bus structure,<br>ory, program control logic, and scanning logic.                                                                                                  |
|   | 2.1        | Architecture Summary                                                                                                                                                                                                                     |
|   | 2.2        | Memory 2-5                                                                                                                                                                                                                               |
|   |            | 2.2.1 On-Chip Dual-Access RAM (DARAM) 2-5                                                                                                                                                                                                |
|   |            | 2.2.2 On-Chip Program/Data Single-Access RAM (SARAM) 2-6                                                                                                                                                                                 |
|   |            | 2.2.3 Flash EEPROM                                                                                                                                                                                                                       |
|   |            | 2.2.4 Factory-Masked ROM 2-7                                                                                                                                                                                                             |
|   |            | 2.2.5 External Memory Interface Module 2-7                                                                                                                                                                                               |
|   | 2.3        | Central Processing Unit 2-8                                                                                                                                                                                                              |
|   |            | 2.3.1 Central Arithmetic Logic Unit (CALU) and Accumulator 2-8                                                                                                                                                                           |
|   |            | 2.3.2 Scaling Shifters 2-8                                                                                                                                                                                                               |
|   |            | 2.3.3 Multiplier 2-9                                                                                                                                                                                                                     |
|   |            | 2.3.4 Auxiliary Register Arithmetic Unit (ARAU) and Auxiliary Registers 2-9                                                                                                                                                              |
|   | 2.4        | Program Control 2-10                                                                                                                                                                                                                     |
|   | 2.5        | On-Chip Peripherals 2-11                                                                                                                                                                                                                 |
|   | 2.6        | Serial-Scan Emulation                                                                                                                                                                                                                    |
| 3 | Cent       | ral Processing Unit                                                                                                                                                                                                                      |
|   | the a      | ribes the TMS320C24x CPU. Includes information about the central arithmetic logic unit,<br>ccumulator, the shifters, the multiplier, and the auxiliary register arithmetic unit. Concludes<br>a description of the status register bits. |
|   | 3.1        | Input Scaling Section                                                                                                                                                                                                                    |
|   | 3.2        | Multiplication Section                                                                                                                                                                                                                   |
|   |            | 3.2.1 Multiplier                                                                                                                                                                                                                         |
|   |            | 3.2.2 Product-Scaling Shifter 3-6                                                                                                                                                                                                        |

|   | 3.3  | Centra  | al Arithmetic Logic Section                                          | 3-8  |
|---|------|---------|----------------------------------------------------------------------|------|
|   |      | 3.3.1   | Central Arithmetic Logic Unit (CALU)                                 | 3-9  |
|   |      | 3.3.2   | Accumulator                                                          | 3-9  |
|   |      | 3.3.3   | Output Data-Scaling Shifter                                          | 3-11 |
|   | 3.4  | Auxilia | ary Register Arithmetic Unit (ARAU)                                  | 3-12 |
|   |      | 3.4.1   | ARAU Functions                                                       | 3-13 |
|   |      | 3.4.2   | Auxiliary Register Functions                                         | 3-14 |
|   | 3.5  | Status  | Registers ST0 and ST1                                                | 3-15 |
| 4 | Mem  | orv and | I/O Spaces                                                           | 4-1  |
| • |      | -       | IS320C24x memory and I/O space configuration and operation. Includes |      |
|   | memo | ory map | . · · · · ·                                                          | -    |
|   | 4.1  | Overvi  | iew of the Memory and I/O Spaces                                     | 4-2  |
|   | 4.2  |         | am Memory                                                            | 4-3  |
|   |      | 4.2.1   | Program Memory Configuration                                         | 4-3  |
|   | 4.3  | Local I | Data Memory                                                          | 4-5  |
|   |      | 4.3.1   | Data Page 0 Address Map                                              | 4-7  |
|   |      | 4.3.2   | Local Data Memory Configuration                                      | 4-8  |
|   | 4.4  | Global  | Data Memory                                                          | 4-9  |
|   | 4.5  | I/O Sp  | ace                                                                  | 4-11 |
| 5 | Prog | ram Coi | ntrol                                                                | 5-1  |
|   | -    |         | e TMS320C24x hardware and software features used in controlling prog |      |
|   |      |         | gram-address generation logic.                                       |      |
|   | 5.1  | Progra  | am-Address Generation                                                |      |
|   | •••• | 5.1.1   | Program Counter (PC)                                                 |      |
|   |      | 5.1.2   | Stack                                                                |      |
|   |      | 5.1.3   | Microstack (MSTACK)                                                  |      |
|   | 5.2  |         |                                                                      |      |
|   | 5.3  |         | hes, Calls, and Returns                                              |      |
|   |      | 5.3.1   | Unconditional Branches                                               |      |
|   |      | 5.3.2   | Unconditional Calls                                                  |      |
|   |      | 5.3.3   | Unconditional Returns                                                |      |
|   | 5.4  | Condit  | tional Branches, Calls, and Returns                                  |      |
|   |      | 5.4.1   | Using Multiple Conditions                                            |      |
|   |      | 5.4.2   | Stabilization of Conditions                                          |      |
|   |      | 5.4.3   | Conditional Branches                                                 |      |
|   |      | 5.4.4   | Conditional Calls                                                    |      |
|   |      | 5.4.5   | Conditional Returns                                                  |      |
|   | 5.5  |         | ting a Single Instruction                                            |      |
|   |      |         |                                                                      |      |

| 6 | Syste | em Fund   | ctions                                                                             | 6-1  |
|---|-------|-----------|------------------------------------------------------------------------------------|------|
|   | Desc  | ribes the | e device functions, including interrupts, that are not specific to any peripheral. |      |
|   | 6.1   | Periph    | eral Interface                                                                     | 6-2  |
|   | 6.2   |           | n Configuration Registers                                                          |      |
|   |       | 6.2.1     | System Control Register (SYSCR)                                                    |      |
|   |       | 6.2.2     | System Status Register (SYSSR)                                                     |      |
|   |       | 6.2.3     | System Interrupt Vector Register (SYSIVR)                                          |      |
|   | 6.3   | Interru   | pts                                                                                |      |
|   |       | 6.3.1     | Interrupt Operation: Three Phases                                                  |      |
|   |       | 6.3.2     | Nonmaskable Interrupt Operation                                                    |      |
|   |       | 6.3.3     | Maskable Interrupt Structure                                                       |      |
|   |       | 6.3.4     | CPU Interrupt Registers                                                            |      |
|   |       | 6.3.5     | Maskable Interrupt Acknowledgement and Servicing                                   |      |
|   |       | 6.3.6     | Programming ISRs for Maskable Interrupts                                           | 6-25 |
|   |       | 6.3.7     | Programming an ISR for Nonmaskable Interrupt (NMI)                                 |      |
|   |       | 6.3.8     | Additional Tasks of ISRs                                                           | 6-31 |
|   |       | 6.3.9     | Interrupt Latency                                                                  | 6-33 |
|   |       | 6.3.10    | Summary of Interrupt Operation                                                     | 6-35 |
|   |       | 6.3.11    | External Interrupt Control Registers                                               | 6-37 |
|   |       | 6.3.12    | Type A, Type B, and Type C Interrupt Pins                                          | 6-39 |
|   |       | 6.3.13    | Power Module Interrupts                                                            | 6-46 |
|   | 6.4   | Reset     | Operation                                                                          | 6-48 |
|   | 6.5   | Power     | -Down Modes                                                                        | 6-51 |
|   |       | 6.5.1     | Setting and Entering the Power-Down Modes                                          | 6-53 |
|   |       | 6.5.2     | Exiting the Power-Down Modes                                                       | 6-53 |
|   |       | 6.5.3     | Summary of Power-Down Mode Operation                                               | 6-57 |
| 7 | Addr  | essina l  | Modes                                                                              | 7-1  |
|   |       |           | operation and use of the TMS320C24x data-memory addressing modes.                  |      |
|   | 7.1   | Immed     | liate Addressing Mode                                                              | 7-2  |
|   | 7.2   |           | Addressing Mode                                                                    |      |
|   |       | 7.2.1     | Using Direct Addressing Mode                                                       |      |
|   |       | 7.2.2     | Examples of Direct Addressing                                                      |      |
|   | 7.3   | Indirec   | t Addressing Mode                                                                  | 7-9  |
|   |       | 7.3.1     | Current Auxiliary Register                                                         | 7-9  |
|   |       | 7.3.2     | Indirect Addressing Options                                                        | 7-9  |
|   |       | 7.3.3     | Next Auxiliary Register                                                            | 7-11 |
|   |       | 7.3.4     | Indirect Addressing Opcode Format                                                  |      |
|   |       | 7.3.5     | Examples of Indirect Addressing                                                    | 7-14 |
|   |       | 7.3.6     | Modifying Auxiliary Register Content                                               | 7-16 |

| Contents |
|----------|
|----------|

| 8 | Asse  | mbly Language Instructions                                                                                                                      | -1 |
|---|-------|-------------------------------------------------------------------------------------------------------------------------------------------------|----|
|   |       | ribes the TMS320C24x assembly language instructions in alphabetical order. Begins with nmary of the TMS320C24x instructions.                    |    |
|   | 8.1   | Instruction Set Summary                                                                                                                         | -2 |
|   | 8.2   | How To Use the Instruction Descriptions                                                                                                         | 12 |
|   |       | 8.2.1 Syntax                                                                                                                                    | 12 |
|   |       | 8.2.2 Operands                                                                                                                                  | 4  |
|   |       | 8.2.3 Opcode                                                                                                                                    | 4  |
|   |       | 8.2.4 Execution                                                                                                                                 | 15 |
|   |       | 8.2.5 Status Bits                                                                                                                               | 15 |
|   |       | 8.2.6 Description                                                                                                                               | 15 |
|   |       | 8.2.7 Words                                                                                                                                     | 6  |
|   |       | 8.2.8 Cycles                                                                                                                                    | 6  |
|   |       | 8.2.9 Examples                                                                                                                                  | 8  |
|   | 8.3   | Instruction Descriptions                                                                                                                        | 9  |
| Α | TMS   | 320C1x/C2x/C24x/C5x Instruction Set Comparison A                                                                                                | -1 |
|   |       | isses the compatibility of program code among the following devices: TMS320C1x, 320C2x, TMS320C2xx, TMS320C24x, and TMS320C5x.                  |    |
|   | A.1   | Using the Instruction Set Comparison Table A                                                                                                    | -2 |
|   |       | A.1.1 An Example of a Table Entry A                                                                                                             | -2 |
|   |       | A.1.2 Symbols and Acronyms Used in the Table A                                                                                                  | -3 |
|   | A.2   | Enhanced Instructions A                                                                                                                         | -5 |
|   | A.3   | Instruction Set Comparison Table A                                                                                                              | -6 |
| в | Subn  | nitting ROM Codes to TIB                                                                                                                        | -1 |
|   |       | ins the process for submitting custom program code to TI for designing masks for the on-chip<br>on a TMS320 DSP. Submitting ROM Codes to TI     |    |
| с | Desig | gn Considerations for Using the XDS510 EmulatorC                                                                                                | -1 |
|   |       | ribes the JTAG emulator cable and how to construct a 14-pin connector on your target system<br>how to connect the target system to the emulator |    |
|   | C.1   | Designing Your Target System's Emulator Connector (14-Pin Header) C                                                                             | -2 |
|   | C.2   | Bus Protocol C                                                                                                                                  | -4 |
|   | C.3   | Emulator Cable Pod C                                                                                                                            | -5 |
|   | C.4   | Emulator Cable Pod Signal Timing C                                                                                                              | -6 |
|   | C.5   | Emulation Timing Calculations C                                                                                                                 | -7 |
|   | C.6   | Connections Between the Emulator and the Target System                                                                                          | 0  |
|   |       | C.6.1 Buffering Signals C-1                                                                                                                     |    |
|   |       | C.6.2 Using a Target-System Clock C-1                                                                                                           | 12 |
|   |       | C.6.3 Configuring Multiple Processors C-1                                                                                                       | 13 |

|   | C.7                                                                    | Physica | al Dimensions for the 14-Pin Emulator Connector            | C-14 |  |
|---|------------------------------------------------------------------------|---------|------------------------------------------------------------|------|--|
|   | C.8                                                                    | Emulat  | C-16                                                       |      |  |
|   |                                                                        | C.8.1   | Using Scan Path Linkers                                    | C-16 |  |
|   |                                                                        | C.8.2   | Emulation Timing Calculations for a Scan Path Linker (SPL) | C-18 |  |
|   |                                                                        | C.8.3   | Using Emulation Pins                                       | C-20 |  |
|   |                                                                        | C.8.4   | Performing Diagnostic Applications                         | C-24 |  |
| D | Gloss                                                                  | ary     |                                                            | D-1  |  |
|   | Explains terms, abbreviations, and acronyms used throughout this book. |         |                                                            |      |  |
| Е | Sumr                                                                   | nary of | Updates in This Document                                   | E-1  |  |
|   | Provides a summary of the updates in this version of the document      |         |                                                            |      |  |

# Figures

| 1–1  | TMS320 Family                                                                                        | 1-3    |
|------|------------------------------------------------------------------------------------------------------|--------|
| 2–1  | C24x High-Level Block Diagram                                                                        | 2-3    |
| 2–2  | C24x Address and Data Bus Structure                                                                  |        |
| 3–1  | Block Diagram of the Input Scaling, Central Arithmetic Logic, and Multiplication Sections of the CPU |        |
| 3–2  | Block Diagram of the Input Scaling Section                                                           |        |
| 3–3  | Operation of the Input Shifter for SXM = 0                                                           |        |
| 3–4  | Operation of the Input Shifter for SXM = 1                                                           |        |
| 3–5  | Block Diagram of the Multiplication Section                                                          |        |
| 3–6  | Block Diagram of the Central Arithmetic Logic Section                                                |        |
| 3–7  | Shifting and Storing the High Word of the Accumulator                                                |        |
| 3–8  | Shifting and Storing the Low Word of the Accumulator                                                 |        |
| 3–9  | ARAU and Related Logic                                                                               |        |
| 3–10 | Status Register ST0                                                                                  |        |
| 3–11 | Status Register ST1                                                                                  |        |
| 4–1  | Program Memory Map for 'C24x                                                                         |        |
| 4–2  | Data Memory Map for 'C24x                                                                            |        |
| 4–3  | Pages of Local Data Memory                                                                           |        |
| 4–4  | GREG Register Set to Configure 8K for Global Data Memory                                             |        |
| 4–5  | Global and Local Data Memory for GREG = 11100000                                                     |        |
| 4–6  | I/O-Space Address Map for 'C24x                                                                      | . 4-11 |
| 5–1  | Program-Address Generation Block Diagram                                                             | 5-2    |
| 5–2  | A Push Operation                                                                                     | 5-5    |
| 5–3  | A Pop Operation                                                                                      | 5-6    |
| 5–4  | Four-Level Pipeline Operation                                                                        |        |
| 6–1  | System Configuration Registers                                                                       | 6-4    |
| 6–2  | System Control Register (SYSCR) — Address 7018h                                                      | 6-5    |
| 6–3  | System Status Register (SYSSR) — Address 701Ah                                                       | 6-6    |
| 6–4  | System Interrupt Vector Register (SYSIVR) — Address 701Eh                                            | 6-8    |
| 6–5  | Example of Maskable Interrupt Structure                                                              | . 6-14 |
| 6–6  | Interrupt Flag Register (IFR) — Address 0006h                                                        | . 6-17 |
| 6–7  | Interrupt Mask Register (IMR) — Address 0004h                                                        | . 6-19 |
| 6–8  | Interrupt Service Routine Flow Chart                                                                 |        |
| 6–9  | Interrupt Operation Flow Chart                                                                       | . 6-36 |
| 6–10 | External Interrupt Control Registers                                                                 | . 6-37 |
| 6–11 | Type A Interrupt Control Register                                                                    | . 6-40 |

| 0 10 | The Polytom at Ocastral Devictor                                          | c 40 |
|------|---------------------------------------------------------------------------|------|
| 6–12 | Type B Interrupt Control Register                                         |      |
| 6–13 | Type C Interrupt Control Register                                         |      |
| 6–14 | PM INT Flag Bits                                                          |      |
| 6–15 | PM INT Enable Bits                                                        |      |
| 6–16 | Reset Signals                                                             |      |
| 7–1  | Instruction Register Contents for Example 7–1                             |      |
| 7–2  | Two Words Loaded Consecutively to the Instruction Register in Example 7–2 |      |
| 7–3  | Pages of Data Memory                                                      |      |
| 7–4  | Instruction Register (IR) Contents in Direct Addressing Mode              |      |
| 7–5  | Generation of Data Addresses in Direct Addressing Mode                    |      |
| 7–6  | Instruction Register Content in Indirect Addressing                       |      |
| 8–1  | Bit Numbers and Their Corresponding Bit Codes for BIT Instruction         |      |
| 8–2  | Bit Numbers and Their Corresponding Bit Codes for BITT Instruction        |      |
| 8–3  | LST #0 Operation                                                          | 8-86 |
| 8–4  | LST #1 Operation                                                          |      |
| B–1  | TMS320 ROM Code Procedural Flow Chart                                     | B-2  |
| C–1  | 14-Pin Header Signals and Header Dimensions                               | C-2  |
| C–2  | Emulator Cable Pod Interface                                              | C-5  |
| C–3  | Emulator Cable Pod Timings                                                | C-6  |
| C–4  | Emulator Connections Without Signal Buffering                             | C-10 |
| C–5  | Emulator Connections With Signal Buffering                                | C-11 |
| C–6  | Target-System-Generated Test Clock                                        | C-12 |
| C–7  | Multiprocessor Connections                                                | C-13 |
| C–8  | Pod/Connector Dimensions                                                  | C-14 |
| C–9  | 14-Pin Connector Dimensions                                               | C-15 |
| C–10 | Connecting a Secondary JTAG Scan Path to a Scan Path Linker               | C-17 |
| C–11 | EMU0/1 Configuration to Meet Timing Requirements of Less Than 25 ns       | C-21 |
| C–12 | Suggested Timings for the EMU0 and EMU1 Signals                           | C-22 |
| C–13 | EMU0/1 Configuration With Additional AND Gate to Meet Timing Requirements |      |
|      | of Greater Than 25 ns                                                     |      |
| C–14 | EMU0/1 Configuration Without Global Stop                                  |      |
| C–15 | TBC Emulation Connections for n JTAG Scan Paths                           | C-25 |
|      |                                                                           |      |

# **Tables**

| 2–1  | Where to Find Information About Program Control Features 2-10      |
|------|--------------------------------------------------------------------|
| 3–1  | Product Shift Modes for the Product-Scaling Shifter 3-7            |
| 3–2  | Bit Fields of Status Registers ST0 and ST1 3-16                    |
| 4–1  | Data Page 0 Address Map 4-7                                        |
| 4–2  | Global Data Memory Configurations 4-9                              |
| 5–1  | Program-Address Generation Summary 5-3                             |
| 5–2  | Address Loading to the Program Counter 5-4                         |
| 5–3  | Conditions for Conditional Calls and Returns 5-10                  |
| 5–4  | Groupings of Conditions 5-11                                       |
| 6–1  | CPU Cycles to Complete Reads From and Writes to the Peripheral Bus |
| 6–2  | C24x Interrupt Locations and Priorities                            |
| 6–3  | Priorities of the Maskable Interrupt Levels in the DSP Core        |
| 6–4  | Priority Ranking Under INT1                                        |
| 6–5  | C24x Maskable Interrupt Vector Table 6-22                          |
| 6–6  | Example Interrupt Locations and Priorities                         |
| 6–7  | Example of Method 1 ISR 6-26                                       |
| 6–8  | Example of Method 2 ISR 6-28                                       |
| 6–9  | Example of Method 3 ISR 6-30                                       |
| 6–10 | One Implementation of an ISR for NMI                               |
| 6–11 | External Interrupt Pin Types                                       |
| 6–12 | External Interrupt Pin Functions and Corresponding Bit Settings    |
| 6–13 | Power-Down Modes                                                   |
| 6–14 | Setting the Power-Down Mode with the PLLPM Bits                    |
| 6–15 | Power-Down Modes and Their Termination                             |
| 6–16 | Power-Down Modes/Run Mode Summary 6-57                             |
| 7–1  | Indirect Addressing Operands                                       |
| 7–2  | Effects of the ARU Code on the Current Auxiliary Register          |
| 7–3  | Field Bits and Notation for Indirect Addressing                    |
| 8–1  | Accumulator, Arithmetic, and Logic Instructions                    |
| 8–2  | Auxiliary Register Instructions                                    |
| 8–3  | TREG, PREG, and Multiply Instructions                              |
| 8–4  | Branch Instructions                                                |
| 8–5  | Control Instructions                                               |
| 8–6  | I/O and Memory Instructions                                        |
| 8–7  | Product Shift Modes                                                |
| 8–8  | Product Shift Modes                                                |

| A–1 | Symbols and Acronyms Used in the Instruction Set Comparison Table | A-3 |
|-----|-------------------------------------------------------------------|-----|
| A–2 | Summary of Enhanced Instructions                                  | A-5 |
| A–3 | Instruction Set Comparison                                        | A-6 |
| C–1 | 14-Pin Header Signal Descriptions                                 | C-3 |
| C–2 | Emulator Cable Pod Timing Parameters                              | C-6 |

# Examples

| 7–1  | RPT Instruction Using Short-Immediate Addressing                                  |
|------|-----------------------------------------------------------------------------------|
| 7–2  | ADD Instruction Using Long-Immediate Addressing                                   |
| 7–3  | Using Direct Addressing with ADD (Shift of 0 to 15)                               |
| 7–4  | Using Direct Addressing with ADD (Shift of 16)                                    |
| 7–5  | Using Direct Addressing with ADDC                                                 |
| 7–6  | Selecting a New Current Auxiliary Register 7-11                                   |
| 7–7  | Indirect Addressing—No Increment or Decrement                                     |
| 7–8  | Indirect Addressing—Increment by 1                                                |
| 7–9  | Indirect Addressing—Decrement by 1                                                |
| 7–10 | Indirect Addressing—Increment by Index Amount                                     |
| 7–11 | Indirect Addressing—Decrement by Index Amount                                     |
| 7–12 | Indirect Addressing—Increment by Index Amount With Reverse Carry Propagation 7-15 |
| 7–13 | Indirect Addressing—Decrement by Index Amount With Reverse Carry Propagation 7-15 |
| C–1  | Key Timing for a Single-Processor System Without Buffers C-8                      |
| C–2  | Key Timing for a Single-Processor System Without Buffering (SPL) C-19             |

1.1 1.2

1.3

# Chapter 1

# Introduction

The TMS320C24x ('C24x) series is a member of the TMS320 family of digital signal processors (DSPs). The 'C24x series is designed to meet a wide range of digital motor control (DMC) applications. This chapter provides an overview of the current TMS320 family, describes the background and benefits of the 'C24x DSP controller products, and introduces the 'C240 device.

# Topic Page TMS320 Family Overview ..... 1-2 TMS320C24x Series of DSP Controllers ...... 1-4

TMS320C240 Overview ...... 1-6

# 1.1 TMS320 Family Overview

The TMS320 family consists of fixed-point, floating-point, multiprocessor digital signal processors (DSPs), and fixed-point DSP controllers. TMS320 DSPs have an architecture designed specifically for real-time signal processing. The 'C24x series of DSP controllers combines this real-time processing capability with controller peripherals to create an ideal solution for control system applications. The following characteristics make the TMS320 family the right choice for a wide range of processing applications:

- Ury flexible instruction set
- Inherent operational flexibility
- High-speed performance
- Innovative parallel architecture
- Cost-effectiveness

In 1982, Texas Instruments introduced the TMS32010, the first fixed-point DSP in the TMS320 family. Before the end of the year, *Electronic Products* magazine awarded the TMS32010 the title "Product of the Year". Today, the TMS320 family consists of these generations (Figure 1–1): 'C1x, 'C2x, 'C2xx, 'C5x, 'C54x, and 'C6x fixed-point DSPs; 'C3x and 'C4x floating-point DSPs; and 'C8x multiprocessor DSPs. The 'C24x is considered part of the 'C2xx family of fixed-point DSPs.

Devices within a generation of the TMS320 family have the same CPU structure but different on-chip memory and peripheral configurations. Spin-off devices use new combinations of on-chip memory and peripherals to satisfy a wide range of needs in the worldwide electronics market. By integrating memory and peripherals onto a single chip, TMS320 devices reduce system costs and save circuit board space.





# 1.2 TMS320C24x Series of DSP Controllers

Designers are recognizing the opportunity to redesign existing DMC systems to use advanced algorithms, yielding better performance and reducing system component count. DSPs are enabling:

- Design of robust controllers for a new generation of inexpensive motors, such as AC induction, DC permanent magnet, and switched-reluctance motors
- Full variable-speed control of brushless motor types that have lower manufacturing cost and higher reliability
- Energy savings through variable-speed control, saving up to 25% of the energy used by fixed-speed controllers
- Increased fuel economy, improved performance, and elimination of hydraulic fluid in automotive electronic power steering (EPS) systems
- Reduced manufacturing and maintenance costs by eliminating hydraulic fluids in automotive electronic braking systems
- More efficient and quieter operation due to less generation of torque ripple, resulting in less loss of power, lower vibration, and longer life
- Elimination or reduction of memory lookup tables through real-time polynomial calculation, thereby reducing system cost
- □ Use of advanced algorithms that can reduce the number of sensors required in a system
- Control of power switching inverters along with control algorithm processing
- Single-processor control of multimotor systems

The 'C24x DSP controllers are designed to meet the needs of control-based applications. By integrating the high performance of a DSP core and the on-chip peripherals of a microcontroller into a single-chip solution, the 'C24x series yields a device that is an affordable alternative to traditional microcontroller units (MCUs) and expensive multichip designs. At 20 million instructions per second (MIPS), the 'C24x DSP controllers offer significant performance over traditional 16-bit microcontrollers and microprocessors.

The 16-bit, fixed-point DSP core of the 'C24x devices provides analog designers a digital solution that does not sacrifice the precision and performance of their systems. In fact, system performance can be enhanced through the use

of advanced control algorithms for techniques such as adaptive control, Kalman filtering, and state control. The 'C24x DSP controllers offer reliability and programmability. Analog control systems, on the other hand, are hardwired solutions and can experience performance degradation due to aging, component tolerance, and drift.

The high-speed central processing unit (CPU) allows the digital designer to process algorithms in real time rather than approximate results with look-up tables. The instruction set of these DSP controllers, which incorporates both signal processing instructions and general-purpose control functions, coupled with the extensive development support available for the 'C24x devices, reduces development time and provides the same ease of use as traditional 8- and 16-bit microcontrollers. The instruction set also allows you to retain your software investment when moving from other general-purpose TMS320 fixed-point DSPs. It is source- and object-code compatible with the other members of the 'C2xx generation, source code compatible with the 'C2x generation, and upward source code compatible with the 'C5x generation of DSPs from Texas Instruments.

The 'C24x architecture is also well-suited for processing control signals. A 16-bit word length is used along with 32-bit registers for storing intermediate results, and two hardware shifters are available to scale numbers independently of the CPU. This combination minimizes quantization and truncation errors, and increases processing power for additional functions. Such functions might include a notch filter that could cancel mechanical resonances in a system or an estimation technique that could eliminate state sensors in a system.

The 'C24x DSP controllers take advantage of an existing set of peripheral functions that allow Texas Instruments to quickly configure various series members for different price/performance points or for application optimization. This library of both digital and mixed-signal peripherals includes:

- □ Timers
- Serial communications ports (SCI, SPI)
- □ Analog-to-digital converters (ADC)
- Event manager
- System protection, such as low-voltage detection and watchdog timers

The DSP controller peripheral library is continually growing and changing to suit the needs of tomorrow's embedded control marketplace.

### 1.3 TMS320C240 Overview

The TMS320C240 is the first standard device introduced in the 'C24x series of DSP controllers. It sets the standard for a single-chip digital motor controller. The 'C240 can execute 20 MIPS. Almost all instructions are executed in a single cycle of 50 ns. This high performance allows real-time execution of very complex control algorithms, such as adaptive control and Kalman filters. Very high sampling rates can also be used to minimize loop delays.

The 'C240 has the architectural features necessary for high-speed signal processing and digital control functions, and it has the peripherals needed to provide a single-chip solution for motor control applications. The 'C240 is manufactured using submicron CMOS technology, achieving a low power dissipation rating. Also included are several power-down modes for further power savings.

Applications that benefit from the advanced processing power of the 'C240 include:

- Industrial motor drives
- Power inverters and controllers
- Automotive systems, such as electronic power steering, anti-lock brakes, and climate control
- Appliance and HVAC blower/compressor motor controls
- Printers, copiers, and other office products
- Tape drives, magnetic optical drives, and other mass storage products
- Robotics and CNC milling machines

To function as a system manager, DSPs must have robust on-chip I/O and other peripherals. The event manager of the 'C240 is unlike any other available on a DSP. This application-optimized peripheral unit, coupled with the high-performance DSP core, enables the use of advanced control techniques for high-precision and high-efficiency full variable-speed control of all motor types. Included in the event manager are special pulse-width modulation (PWM) generation functions, such as a programmable dead-band function and a space vector PWM state machine for three-phase motors that provides state-of-the-art maximum efficiency in the switching of power transistors. Three independent up/down timers, each with it's own compare register, support the generation of asymmetric (noncentered) as well as symmetric (centered) PWM waveforms. Two of the four capture inputs are direct connections for quadrature encoder pulse signals from an optical encoder. Here is a summary of 'C240 features:

TMS320C2xx core CPU:

- 32-bit central arithmetic logic unit (CALU)
- 32-bit accumulator
- 16-bit × 16-bit parallel multiplier with a 32-bit product capability
- Three scaling shifters
- Eight 16-bit auxiliary registers with a dedicated arithmetic unit for indirect addressing of data memory

□ Memory:

- 544 words × 16 bits of on-chip data/program dual-access RAM
- 16K words × 16 bits of on-chip program ROM or flash EEPROM
- 224K words × 16 bits of maximum addressable memory space (64K words of program space, 64K words of data space, 64K words of I/O space, and 32K words of global space)
- External Memory Interface Module with a software wait-state generator, a 16-bit address bus, and a 16-bit data bus
- Support of hardware wait-states
- Program control:
  - Four-level pipeline operation
  - Eight-level hardware stack
  - Six external interrupts: power-drive protection interrupt, reset, NMI, and three maskable interrupts
- Instruction set:
  - Source code compatibility with 'C2x, 'C2xx, and 'C5x fixed-point generations of the TMS320 family
  - Single-instruction repeat operation
  - Single-cycle multiply/accumulate instructions
  - Memory block move instructions for program/data management
  - Indexed-addressing capability
  - Bit-reversed indexed-addressing capability for radix-2 fast Fourier transforms (FFTs)
- Dever:
  - Static CMOS technology
  - Four power-down modes to reduce power consumption

- Emulation: IEEE Standard 1149.1 test access port interface to on-chip scan-based emulation logic
- Speed: 50-ns (20 MIPS) instruction cycle time, with most instructions single-cycle
- Event manager:
  - 12 compare/pulse-width modulation (PWM) channels (9 independent)
  - Three 16-bit general-purpose timers with six modes, including continuous up counting and continuous up/down counting
  - Three 16-bit full compare units with dead band capability
  - Three 16-bit simple compare units
  - Four capture units, two of which have quadrature encoder-pulse interface capability
- Dual 10-bit analog-to-digital converter
- 28 individually programmable, multiplexed I/O pins
- Phase-locked loop (PLL)-based clock module
- U Watchdog timer module with real-time interrupt
- Serial communication interface (SCI)
- Serial peripheral interface (SPI)

# Chapter 2

# **Architectural Overview**

This chapter provides an overview of the architectural structure and components of the 'C24x. The 'C24x uses an advanced, modified Harvard architecture that maximizes processing power by maintaining separate bus structures for program memory and data memory.

# Topic

# Page

| 2.1 | Architecture Summary 2-2    |
|-----|-----------------------------|
| 2.2 | Memory 2-5                  |
| 2.3 | Central Processing Unit 2-8 |
| 2.4 | Program Control 2-10        |
| 2.5 | On-Chip Peripherals         |
| 2.6 | Serial-Scan Emulation       |

# 2.1 Architecture Summary

A high-level block diagram of the 'C24x architecture is shown in Figure 2–1. The 'C24x architecture is based on the modified Harvard architecture, which supports separate bus structures for program space and data space. A third space, the input/output (I/O) space, is also available and is accessible through the *external bus interface* (shown at the bottom of the figure). To support a large selection of peripherals, a peripheral bus is used. The peripheral bus is mapped to the data space and interfaced to the data bus through the *system module*. Thus, all the instructions that operate on the data space also operate on all the peripheral registers.

Separate program and data spaces allow simultaneous access to program instructions and data. For example, while data is multiplied, a previous product can be added to the accumulator, and, at the same time, a new address can be generated. Such parallelism supports a set of arithmetic, logic, and bit-manipulation operations that can all be performed in a single machine cycle. The 'C24x also includes control mechanisms to manage interrupts, repeated operations, and function/subroutine calls.

The bus structure shown in Figure 2–1 forms the basis of the entire 'C24x generation of devices. In addition, the CPU is identical for all 'C24x devices. However, each different device configuration has a unique combination of memory and peripheral modules. In the figure, the address ranges given for the memory modules are for the maximum allowable memory sizes. Typically, specific 'C24x devices have subsets of these ranges. The peripheral locations shown in the figure are true for all 'C24x devices. If more than one instance of a certain peripheral is on a device, each additional instance occupies one of the slots labeled *Spare* in the figure. The exact memory and peripheral configurations for a specific 'C24x device are defined in the *TMS320C24x DSP Controllers Reference Set, Volume 2: Peripheral Library and Specific Devices* and in the device data sheet.





<sup>†</sup> Size of DARAM depends on device

<sup>‡</sup> Start address of SARAM depends on end address of ROM/Flash

The internal data and program bus structure is further divided into six 16-bit buses (see Figure 2–2):

- □ **PAB.** The *program address bus* provides addresses for both reads from and writes to program memory.
- DRAB. The data-read address bus provides addresses for reads from data memory.
- DWAB. The *data-write address bus* provides addresses for writes to data memory.
- □ **PRDB.** The *program read bus* carries instruction code and immediate operands, as well as table information, from program memory to the CPU.
- DRDB. The data-read bus carries data from data memory to the central arithmetic logic unit (CALU) and the auxiliary register arithmetic unit (ARAU).
- DWEB. The *data-write bus* carries data to both program memory and data memory.

Having separate address buses for data reads (DRAB) and data writes (DWAB) allows the CPU to read and write in the same machine cycle.



Figure 2–2. 'C24x Address and Data Bus Structure

Memory

2.2

The 'C24x can contain the following kinds of on-chip memory:

- Dual-access RAM (DARAM)
- □ Single-access RAM (SARAM)
- □ Flash EEPROM or ROM (masked)

The 'C24x memory is organized into four individually-selectable spaces:

- Program (64K words)
- Local data (64K words)
- Global data (32K words)
- Input/Output (64K words)

These spaces form an address range of 224K words. For a detailed description of the 'C24x memory and I/O spaces, see Chapter 4, *Memory and I/O Spaces*.

#### 2.2.1 On-Chip Dual-Access RAM (DARAM)

The 'C24x devices can have up to a maximum of 1056 words of on-chip DARAM, which can be accessed twice per machine cycle. This memory is primarily intended to hold data but, when needed, can also be used to hold programs. The memory can be configured in one of two ways, depending on the state of the CNF bit of status register ST1.

If total DARAM is 1056 words:

- □ When CNF = 0, all 1056 words are configured as data memory.
- When CNF = 1, 544 words are configured as data memory and 512 words are configured as program memory.

If total DARAM is 544 words:

- □ When CNF = 0, all 544 words are configured as data memory.
- When CNF = 1, 288 words are configured as data memory and 256 words are configured as program memory.

For the DARAM configurations of a particular 'C24x device, see the *TMS320C24x DSP Controllers Reference Set, Volume 2: Peripheral Library and Specific Devices* and the device data sheet.

Because DARAM can be accessed twice per cycle, it improves the speed of the CPU. The CPU operates within a 4-cycle pipeline. In this pipeline, the CPU reads data on the third cycle and writes data on the fourth cycle. However, DA-RAM allows the CPU to write and read in one cycle; the CPU writes to DARAM on the master phase of the cycle and reads from DARAM on the slave phase. For example, suppose two instructions, A and B, store the accumulator value to DARAM and load the accumulator with a new value from DARAM. Instruction A stores the accumulator value during the master phase of the CPU cycle, and instruction B loads the new value to the accumulator during the slave phase. Because part of the dual-access operation is a write, it only applies to RAM.

#### 2.2.2 On-Chip Program/Data Single-Access RAM (SARAM)

The 'C24x can have up to 16K 16-bit words of single-access RAM (SARAM), starting at address 800h in data space and the top of ROM/Flash in program space. These addresses can be used for both data memory and program memory. For example, in Figure 2–1, the SARAM block is double mapped to both program and data space. Code can be booted from off-chip ROM and then executed at full speed once it is loaded into the on-chip SARAM.

SARAM is accessed only once per CPU cycle. When the CPU requests multiple accesses, the SARAM schedules the accesses by providing a not-ready condition to the CPU and then executing the accesses, one per cycle. For example, if the instruction sequence involves storing the accumulator value and then loading a value to the accumulator, it would take two cycles to complete in SARAM, compared to one cycle in DARAM.

The SARAM block allows for more flexible address mapping than the DARAM block because SARAM can be mapped to program and data memory at the same time. Because of this, however, an instruction fetch and a data fetch that could be performed in one cycle using DARAM may take two cycles with SARAM.

#### 2.2.3 Flash EEPROM

The 'C24x family supports from 4K words to 64K words of on-chip flash EEPROM. The flash memory supports single cycle/single access in read mode. In write mode (programming), the 'C24x requires the regular 5-V supply on pin V<sub>CCP</sub>. The higher programming voltage is generated by on-chip charge pumps.

Detailed descriptions of the control register and bit functions used to program the flash block are given in the *TMS320C24x DSP Controllers Reference Set, Volume 2: Peripheral Library and Specific Devices.* 

# 2.2.4 Factory-Masked ROM

For large-volume applications in which the software is stable and free of bugs, low-cost, masked ROM is available. ROM sizes from 4K words to 32K words are supported. If you want a custom ROM, you can provide the code or data to be programmed into the ROM in object-file format, and Texas Instruments will generate the appropriate process mask to program the ROM. See Appendix B, *Submitting ROM Codes to TI*, for details.

# 2.2.5 External Memory Interface Module

In addition to full, on-chip memory support, the 'C24x can provide access to external memory by way of the *external memory interface* module. This interface provides 16 external address lines, 16 external data lines, and relevant control signals to select data, program, and I/O spaces. A wait-state generator allows interfacing with slower off-chip memory and peripherals. For a detailed description of the external memory interface, see the *TMS320C24x DSP Controllers Reference Set, Volume 2: Peripheral Library and Specific Devices.* 

# 2.3 Central Processing Unit

The 'C2xx CPU is on all the 'C24x devices. It contains:

- A 32-bit central arithmetic logic unit (CALU)
- A 32-bit accumulator
- Input and output data-scaling shifters for the CALU
- □ A 16-bit × 16-bit multiplier
- A product-scaling shifter
- Data-address generation logic, which includes eight auxiliary registers and an auxiliary register arithmetic unit (ARAU)
- Program-address generation logic

# 2.3.1 Central Arithmetic Logic Unit (CALU) and Accumulator

The 'C24x performs 2s-complement arithmetic using the 32-bit CALU. The CALU uses 16-bit words taken from data memory or derived from an immediate instruction, or it uses the 32-bit result from the multiplier. In addition to arithmetic operations, the CALU can perform Boolean operations.

The accumulator stores the output from the CALU; it can also provide a second input to the CALU. The accumulator is 32 bits wide and is divided into a high-order word (bits 31 through 16) and a low-order word (bits 15 through 0). Assembly language instructions are provided for storing the high- and low-order accumulator words to data memory.

#### 2.3.2 Scaling Shifters

The 'C24x has three 32-bit shifters that allow for scaling, bit extraction, extended arithmetic, and overflow-prevention operations:

- □ Input data-scaling shifter (input shifter). This shifter left shifts 16-bit input data by 0 to 16 bits to align the data to the 32-bit input of the CALU.
- Output data-scaling shifter (output shifter). This shifter can left shift output from the accumulator by 0 to 7 bits before the output is stored to data memory. The content of the accumulator remains unchanged.
- Product-scaling shifter (product shifter). The product register (PREG) receives the output of the multiplier. The product shifter shifts the output of the PREG before that output is sent to the input of the CALU. The product shifter has four product shift modes (no shift, left shift by one bit, left shift by four bits, and right shift by six bits), which are useful for performing multiply/accumulate operations, performing fractional arithmetic, or justifying fractional products.

### 2.3.3 Multiplier

The on-chip multiplier performs 16-bit  $\times$  16-bit 2s-complement multiplication with a 32-bit result. In conjunction with the multiplier, the 'C24x uses the 16-bit temporary register (TREG) and the 32-bit product register (PREG). The TREG always supplies one of the values to be multiplied. The PREG receives the result of each multiplication.

Using the multiplier, TREG, and PREG, the 'C24x efficiently performs fundamental DSP operations such as convolution, correlation, and filtering. The effective execution time of each multiplication instruction can be as short as one CPU cycle.

### 2.3.4 Auxiliary Register Arithmetic Unit (ARAU) and Auxiliary Registers

The ARAU generates data memory addresses when an instruction uses indirect addressing (see Chapter 7, *Addressing Modes*) to access data memory. The ARAU is supported by eight auxiliary registers (AR0 through AR7), each of which can be loaded with a 16-bit value from data memory or directly from an instruction word. Each auxiliary register value can also be stored to data memory. The auxiliary registers are referenced by a 3-bit auxiliary register pointer (ARP) embedded in status register ST0.

### 2.4 Program Control

Several hardware and software mechanisms provide program control:

- Program control logic decodes instructions, manages the 4-level pipeline, stores the status of operations, and decodes conditional operations. Hardware elements included in the program control logic are the program counter, the status registers, the stack, and the address-generation logic.
- Software mechanisms used for program control include branches, calls, conditional instructions, a repeat instruction, reset, interrupts, and power-down modes.

Table 2–1 shows where you can find detailed information about these program control features.

| For information about        | See                                |
|------------------------------|------------------------------------|
| Address-generation logic     | Chapter 5, Program Control         |
| Branches, calls, and returns | Chapter 5, Program Control         |
| Conditional operations       | Chapter 5, Program Control         |
| Interrupts                   | Chapter 6, System Functions        |
| Pipeline                     | Chapter 5, Program Control         |
| Power-down modes             | Chapter 6, System Functions        |
| Program counter              | Chapter 5, Program Control         |
| Repeat instruction           | Chapter 5, Program Control         |
| Reset                        | Chapter 6, System Functions        |
| Stack                        | Chapter 5, Program Control         |
| Status registers             | Chapter 3, Central Processing Unit |

Table 2–1. Where to Find Information About Program Control Features

### 2.5 On-Chip Peripherals

As shown in Figure 2–1 (page 2-3), the 'C24x bus structure supports access to numerous peripherals. Two types of bus interfaces are used for the on-chip peripherals. Most of the peripherals are accessed using the peripheral bus. This bus is mapped to the data space through the control of the system module. Each access to one of these peripherals requires more than one cycle. However, the event manager fits directly onto the data bus and takes advantage of the full speed of the DSP central processing unit (CPU). An access to the event manager is made with zero wait states; a read takes one cycle and a write takes two cycles.

Each individual 'C24x device has a unique combination of peripheral modules. However, the address locations for the peripherals are fixed and are the same for all 'C24x devices. If more than one instance of a particular peripheral is on the device, each additional instance occupies one of the locations labeled *Spare* in Figure 2–1.

For detailed descriptions of the peripherals, refer to the *TMS320C24x DSP Controllers Reference Set, Volume 2: Peripheral Library and Specific Devices.* 

### 2.6 Serial-Scan Emulation

The 'C24x has seven pins dedicated to the serial scan emulation port (JTAG port). This port allows for nonintrusive emulation of the 'C24x devices and is supported by Texas Instruments emulation tools and by many third party debugger tools. For documentation on these emulation and debugger tools, see *Related Documentation From Texas Instruments* on page v of the preface and Appendix C, *Design Considerations for Using XDS510 Emulator*.

## **Chapter 3**

# **Central Processing Unit**

This chapter describes the 'C24x central processing unit (CPU) operations. The CPU can perform high-speed arithmetic operations within one instruction cycle because of its parallel architectural design.

First, this chapter describes three fundamental sections of the CPU (see Figure 3–1). The chapter then describes the auxiliary register arithmetic unit (ARAU), which performs arithmetic operations independently of the central arithmetic logic section. The chapter concludes with a description of status registers ST0 and ST1, which contain bits for determining processor modes, addressing pointer values, and indicating various processor conditions and arithmetic logic results.

### Topic

### Page

| 3.1 | Input Scaling Section                     |
|-----|-------------------------------------------|
| 3.2 | Multiplication Section                    |
| 3.3 | Central Arithmetic Logic Section          |
| 3.4 | Auxiliary Register Arithmetic Unit (ARAU) |
| 3.5 | Status Registers ST0 and ST1 3-15         |

### Figure 3–1. Block Diagram of the Input Scaling, Central Arithmetic Logic, and Multiplication Sections of the CPU



### 3.1 Input Scaling Section

A 32-bit input data-scaling shifter (input shifter) aligns a 16-bit value coming from memory to the 32-bit central arithmetic logic unit (CALU). This data alignment is necessary for data-scaling arithmetic, as well as aligning masks for logical operations. The input shifter operates as part of the data path between program or data space and the CALU and, thus, requires no cycle overhead. Described directly below are the input, the output, and the shift count of the input shifter. Throughout the discussion, refer to Figure 3–2.





**Input**. Bits 15 through 0 of the input shifter accept a 16-bit input from either of two sources (see Figure 3–2):

- ☐ *The data read bus (DRDB).* This input is a value from a data memory location referenced in an instruction operand.
- ☐ *The program read bus (PRDB).* This input is a constant value given as an instruction operand.

**Output**. After a value has been accepted into bits 15 through 0, the input shifter aligns the16-bit value to the 32-bit bus of the CALU as shown in Figure 3–2. The shifter shifts the value left 0 to 16 bits and then sends the 32-bit result to the CALU.

During the left shift, unused LSBs in the shifter are filled with 0s, and unused MSBs in the shifter are either filled with 0s or sign extended, depending on the value of the sign-extension mode bit (SXM) of status register ST1.

**Shift count**. The shifter can left shift a 16-bit value by 0 to 16 bits. The size of the shift (or the shift count) is obtained from one of two sources:

- A constant embedded in the instruction word. Putting the shift count in the instruction word allows you to use specific data-scaling or alignment operations customized for your program code.
- ☐ The four LSBs of the temporary register (TREG). The TREG-based shift allows the data-scaling factor to be determined dynamically so that it can be adapted to the system's performance.

**Sign-extension mode bit.** For many but not all instructions, the sign-extension mode bit (SXM), bit 10 of status register ST1, determines whether the CALU uses sign extension during its calculations. If SXM = 0, sign extension is suppressed. If SXM = 1, the output of the input shifter is sign extended. Figure 3–3 shows an example of an input value shifted left by eight bits for SXM = 0. The MSBs of the value passed to the CALU are zero filled. Figure 3–4 shows the same shift but with SXM = 1. The value is sign extended during the shift.

#### Figure 3–3. Operation of the Input Shifter for SXM = 0







### 3.2 Multiplication Section

The 'C24x uses a 16-bit  $\times$  16-bit hardware multiplier that can produce a signed or unsigned 32-bit product in a single machine cycle. As shown in Figure 3–5, the multiplication section consists of:

- The 16-bit temporary register (TREG), which holds one of the multiplicands
- ☐ The multiplier, which multiplies the TREG value by a second value from data memory or program memory
- The 32-bit product register (PREG), which receives the result of the multiplication
- The product shifter, which scales the PREG value before passing it to the CALU

Figure 3–5. Block Diagram of the Multiplication Section



#### 3.2.1 Multiplier

The 16-bit  $\times$  16-bit hardware multiplier can produce a signed or unsigned 32-bit product in a single machine cycle. The two numbers being multiplied are treated as 2s-complement numbers, except during unsigned multiplication (MPYU instruction). Descriptions of the inputs and output of the multiplier follow.

Inputs. The multiplier accepts two 16-bit inputs:

- One input is always from the 16-bit temporary register (TREG). The TREG is loaded before the multiplication with a data-value from the data read bus (DRDB).
- The other input is one of the following:
  - A data-memory value from the data read bus (DRDB)
  - A program memory value from the program read bus (PRDB)

**Output**. After the two 16-bit inputs are multiplied, the 32-bit result is stored in the product register (PREG). The output of the PREG is connected to the 32-bit product-scaling shifter. Through this shifter, the product may be transferred from the PREG to the CALU or to data memory (by the SPH and SPL instructions).

#### 3.2.2 Product-Scaling Shifter

The product-scaling shifter (product shifter) facilitates scaling of the product register (PREG) value. The shifter has a 32-bit input connected to the output of the PREG and a 32-bit output connected to the input of the CALU.

**Input**. The shifter has a 32-bit input connected to the output of the PREG.

**Output**. After the shifter completes the shift, all 32 bits of the result can be passed to the CALU, or 16 bits of the result can be stored to data memory.

**Shift Modes**. This shifter uses one of four product shift modes, summarized in Table 3–1. As shown in the table, these modes are determined by the product shift mode (PM) bits of status register ST1. In the first shift mode (PM = 00), the shifter does not shift the product at all before giving it to the CALU or to data memory. The next two modes cause left shifts (of one or four), which are useful for implementing fractional arithmetic or justifying products. The right-shift mode shifts the product by six bits, enabling the execution of up to 128 consecutive multiply-and-accumulate operations without causing the accumulator to overflow. Note that the content of the PREG remains unchanged; the value is copied to the product shifter and shifted there.

#### Note:

The right shift in the product shifter is always sign extended, regardless of the value of the sign-extension mode bit (SXM) of status register ST1.

| PM  | Shift    | Comments <sup>†</sup>                                                                                                                                                                                                          |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00  | No shift | Product sent to CALU or data write bus (DWEB) with no shift                                                                                                                                                                    |
| 01  | Left 1   | Removes the extra sign bit generated in a 2s-complement multiply to produce a Q31 product                                                                                                                                      |
| 10c | Left 4   | Removes the extra four sign bits generated in a 16-bit $\times$ 13-bit 2s-complement multiply to produce a Q31 product when multiplying by a 13-bit constant                                                                   |
| 11  | Right 6  | Scales the product to allow up to 128 product accumulations without overflowing the accumulator. The right shift is always sign extended, regardless of the value of the sign-extension mode bit (SXM) of status register ST1. |

Table 3–1. Product Shift Modes for the Product-Scaling Shifter

 $^{\dagger}$  A Q31 number is a binary fraction in which there are 31 digits to the right of the binary point (the base 2 equivalent of the base 10 decimal point).

### 3.3 Central Arithmetic Logic Section

Figure 3–6 shows the main components of the central arithmetic logic section, which are:

- The central arithmetic logic unit (CALU), which implements a wide range of arithmetic and logic functions
- The 32-bit accumulator (ACC), which receives the output of the CALU and is capable of performing bit shifts on its contents with the help of the carry bit (C). Figure 3–6 shows the accumulator's high word (ACCH) and low word (ACCL).
- ☐ The output shifter, which can shift a copy of either the high word or low word of the accumulator before sending it to data memory for storage

Figure 3–6. Block Diagram of the Central Arithmetic Logic Section



To data memory

### 3.3.1 Central Arithmetic Logic Unit (CALU)

The CALU implements a wide range of arithmetic and logic functions, most of which execute in a single clock cycle. These functions can be grouped into four categories:

- 16-bit addition
- 16-bit subtraction
- Boolean logic operations
- Bit testing, shifting, and rotating

Because the CALU can perform Boolean operations, you can perform bit manipulation. For bit shifting and rotating, the CALU uses the accumulator. The CALU is referred to as central because there is an independent arithmetic unit, the auxiliary register arithmetic unit (ARAU), which is described in Section 3.4. A description of the inputs, the output, and an associated status bit of the CALU follows.

**Inputs**. The CALU has two inputs (see again Figure 3–6):

- One input is always provided by the 32-bit accumulator.
- The other input is provided by one of the following:
  - The product-scaling shifter (see subsection 3.2.2)
  - The input data-scaling shifter (see Section 3.1)

**Output**. Once the CALU performs an operation, it transfers the result to the 32-bit accumulator, which is capable of performing bit shifts of its contents. The output of the accumulator is connected to the 32-bit output data-scaling shifter. Through the output shifter, the accumulator's upper and lower 16-bit words can be individually shifted and stored to data memory.

**Sign-extension mode bit.** For many but not all instructions, the sign-extension mode bit (SXM), bit 10 of status register ST1, determines whether the CALU uses sign extension during its calculations. If SXM = 0, sign extension is suppressed. If SXM = 1, sign extension is enabled.

### 3.3.2 Accumulator

Once the CALU performs an operation, it transfers the result to the 32-bit accumulator, which can then perform single-bit shifts or rotations on its contents. Each of the accumulator's upper and lower 16-bit words can be passed to the output data-scaling shifter, where it can be shifted and then stored in data memory. The following describes the status bits and branch instructions associated with the accumulator.

Status bits. Four status bits are associated with the accumulator:

- Carry bit (C). C (bit 9 of status register ST1) is affected during:
  - Additions to and subtractions from the accumulator:
  - C = 0 When the result of a subtraction generates a borrow

When the result of an addition does not generate a carry (Exception: When the ADD instruction is used with a shift of 16 and no carry is generated, the ADD instruction has no effect on C.)

C = 1 When the result of an addition generates a carry

When the result of a subtraction does not generate a borrow (Exception: When the SUB instruction is used with a shift of 16 and no borrow is generated, the SUB instruction has no effect on C.)

- Single-bit shifts and rotations of the accumulator value. During a left shift or rotation, the MSB of the accumulator is passed to C; during a right shift or rotation, the LSB is passed to C.
- Overflow mode bit (OVM). OVM (bit 11 of status register ST0) determines how the accumulator reflects arithmetic overflows. When the processor is in overflow mode (OVM = 1) and an overflow occurs, the accumulator is filled with one of two specific values:
  - If the overflow is in the positive direction, the accumulator is filled with its most positive value (7FFF FFFFh).
  - If the overflow is in the negative direction, the accumulator is filled with its most negative value (8000 0000h).
- Overflow flag bit (OV). OV is bit 12 of status register ST0. When no accumulator overflow is detected, OV is latched at 0. When overflow (positive or negative) occurs, OV is set to 1 and latched.
- Test/control flag bit (TC). TC (bit 11 of status register ST1) is set to 0 or 1 depending on the value of a tested bit. In the case of the NORM instruction, if the exclusive-OR of the two MSBs of the accumulator is true, TC is set to 1.

A number of branch instructions are implemented, based on the status of bits C, OV, and TC, and on the value in the accumulator (as compared to 0). For more information about these instructions, see Section 5.4, *Conditional Branches, Calls, and Returns*, on page 5-10.

### 3.3.3 Output Data-Scaling Shifter

The output data-scaling shifter (output shifter) has a 32-bit input connected to the 32-bit output of the accumulator and a 16-bit output connected to the data bus. The shifter copies all 32 bits of the accumulator and then performs a left shift on its content; it can be shifted from zero to seven bits, as specified in the corresponding store instruction. The upper word (SACH instruction) or lower word (SACL instruction) of the shifter is then stored to data memory. The content of the accumulator remains unchanged.

When the output shifter performs the shift, the MSBs are lost and the LSBs are zero filled. Figure 3–7 shows an example in which the accumulator value is shifted left by four bits and the shifted high word is stored to data memory. Figure 3–8 shows the same accumulator value shifted left by six bits and then the shifted low word stored.

Figure 3–7. Shifting and Storing the High Word of the Accumulator



Figure 3–8. Shifting and Storing the Low Word of the Accumulator



### 3.4 Auxiliary Register Arithmetic Unit (ARAU)

The CPU also contains the ARAU, an arithmetic unit independent of the CALU. The main function of the ARAU is to perform arithmetic operations on eight auxiliary registers (AR7 through AR0) in parallel with operations occurring in the CALU. Figure 3–9 shows the ARAU and related logic.

Figure 3–9. ARAU and Related Logic



The eight auxiliary registers (AR7–AR0) provide flexible and powerful indirect addressing. Any location in the 64K data memory space can be accessed using a 16-bit address contained in an auxiliary register. For the details of indirect addressing, see Section 7.3 on page 7-9.

To select a specific auxiliary register, load the 3-bit auxiliary register pointer (ARP) of status register ST0 with a value from 0 through 7. The ARP can be loaded as a primary operation by the MAR instruction (which only performs modifications to the auxiliary registers and the ARP) or by the LST instruction (which can load a data-memory value to ST0 by way of the data read bus, DRDB). The ARP can be loaded as a secondary operation by any instruction that supports indirect addressing.

The register pointed to by the ARP is referred to as the *current auxiliary register* or *current AR*. During the processing of an instruction, the content of the current auxiliary register is used as the address at which the data-memory access will take place. The ARAU passes this address to the data-read address bus (DRAB) if the instruction requires a read from data memory, or it passes the address to the data-write address bus (DWAB) if the instruction requires a write to data memory. After the instruction uses the data value, the contents of the current auxiliary register can be incremented or decremented by the ARAU, which implements unsigned 16-bit arithmetic.

### 3.4.1 ARAU Functions

The ARAU performs the following operations:

- □ Increments or decrements an auxiliary register value by 1 or by an index amount (by way of any instruction that supports indirect addressing)
- Adds a constant value to an auxiliary register value (ADRK instruction) or subtracts a constant value from an auxiliary register value (SBRK instruction). The constant is an 8-bit value taken from the eight LSBs of the instruction word.
- Compares the content of AR0 with the content of the current AR and puts the result in the test/control flag bit (TC) of status register ST1 (CMPR instruction). The result is passed to TC by way of the data write bus (DWEB).

Normally, the ARAU performs its arithmetic operations in the decode phase of the pipeline (when the instruction specifying the operations is being decoded). This allows the address to be generated before the decode phase of the next instruction. There is an exception to this rule: During processing of the NORM instruction, the auxiliary register and/or ARP modification is done during the execute phase of the pipeline. For information on the operation of the pipeline, see Section 5.2 on page 5-7.

### 3.4.2 Auxiliary Register Functions

In addition to using the auxiliary registers to reference data-memory addresses, you can use them for other purposes. For example, you can:

- ❑ Use the auxiliary registers to support conditional branches, calls, and returns by using the CMPR instruction. This instruction compares the content of AR0 with the content of the current AR and puts the result in the test/control flag bit (TC) of status register ST1.
- Use the auxiliary registers for temporary storage by using the LAR instruction to load values into the registers and the SAR instruction to store AR values to data memory
- Use the auxiliary registers as software counters, incrementing or decrementing them as necessary

### 3.5 Status Registers ST0 and ST1

The 'C24x has two status registers, ST0 and ST1, which contain status and control bits. These registers can be stored into and loaded from data memory, thus allowing the status of the machine to be saved and restored for subroutines.

The LST (load status register) instruction writes to ST0 and ST1, and the SST (store status register) instruction reads from ST0 and ST1 (with the exception of the INTM bit, which is not affected by the LST instruction). Many of the individual bits of these registers can be set and cleared using the SETC and CLRC instructions. For example, the sign-extension mode is set with SETC SXM and cleared with CLRC SXM.

Figure 3–10 and Figure 3–11 show the organization of status registers ST0 and ST1, respectively. Several bits in the status registers are reserved; they are always read as logic 1s. The other bits are described in alphabetical order in Table 3–2.

| <i>Figure 3–10.</i> | Status | Reaister | ST0 |
|---------------------|--------|----------|-----|
|                     |        |          |     |

| 15 | 14    | 13 | 12    | 11    | 10 | 9     | 8 | 7 | 6 | 5 | 4     | 3 | 2 | 1 | 0 |
|----|-------|----|-------|-------|----|-------|---|---|---|---|-------|---|---|---|---|
|    | ARP   |    | OV    | OVM   | 11 | INTM  |   |   |   |   | DP    |   |   |   |   |
|    | R/W–x |    | R/W-0 | R/W-x |    | R/W-1 |   |   |   | F | R/W-× | ( |   |   |   |

Note: R = Read access; W = Write access; value following dash (-) is value after reset (x means value not affected by reset).

<sup>†</sup> This reserved bit is always read as 1. Writes have no effect on it.

### Figure 3–11. Status Register ST1

| 15 | 14    | 13 | 12    | 11    | 10    | 9     | 8  | 7  | 6  | 5  | 4     | 3  | 2  | 1   | 0   |
|----|-------|----|-------|-------|-------|-------|----|----|----|----|-------|----|----|-----|-----|
|    | ARB   |    | CNF   | TC    | SXM   | С     | 17 | 11 | 11 | 17 | XF    | 11 | 1† | PI  | М   |
|    | R/W-x |    | R/W-0 | R/W-x | R/W-1 | R/W-1 |    |    |    |    | R/W-1 |    |    | R/W | -00 |

Note: R = Read access; W = Write access; value following dash (-) is value after reset (x means value not affected by reset).
 † These reserved bits are always read as 1s. Writes have no effect on them.

### Table 3–2. Bit Fields of Status Registers ST0 and ST1

| Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ARB  | <b>Auxiliary register pointer buffer.</b> Whenever the auxiliary register pointer (ARP) is loaded, the previous ARP value is copied to the ARB, except during an LST (load status register) instruction. When the ARB is loaded by an LST instruction, the same value is also copied to the ARP.                                                                                                                                                                                                                                                                                                                                          |
| ARP  | <b>Auxiliary register pointer.</b> This 3-bit field selects which auxiliary register (AR) to use in indirect addressing. When the ARP is loaded, the previous ARP value is copied to the ARB register, except during an LST (load status register) instruction. The ARP may be modified by memory-reference instructions using indirect addressing, and by the MAR (modify auxiliary register) and LST instructions. When the ARB is loaded by an LST instruction, the same value is also copied to the ARP. For more details on the use of ARP in indirect addressing, see Section 7.3, <i>Indirect Addressing Mode</i> , on page 7-9.   |
| С    | <b>Carry bit.</b> This bit is set to 1 if the result of an addition generates a carry, or cleared to 0 if the result of a subtraction generates a borrow. Otherwise, it is cleared after an addition or set after a subtraction, except if the instruction is ADD or SUB with a 16-bit shift. In these cases, ADD can only set and SUB only clear the carry bit, but cannot affect it otherwise. The single-bit shift and rotate instructions also affect this bit, as well as the SETC, CLRC, and LST instructions. The conditional branch, call, and return instructions can execute, based on the status of C. C is set to 1 on reset. |
| CNF  | <b>On-chip DARAM configuration bit.</b> This bit determines whether reconfigurable dual-access RAM blocks are mapped to data space or to program space. The CNF bit may be modified by the SETC CNF, CLRC CNF, and LST instructions. Reset clears the CNF bit to 0. For more information about CNF and the dual-access RAM blocks, see Chapter 4, <i>Memory and I/O Spaces</i> .                                                                                                                                                                                                                                                          |
|      | CNF = 0 Reconfigurable dual-access RAM blocks are mapped to data space.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|      | CNF = 1 Reconfigurable dual-access RAM blocks are mapped to program space.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| DP   | <b>Data page pointer.</b> When an instruction uses direct addressing, the 9-bit DP field is concatenated with the seven LSBs of the instruction word to form a full 16-bit data-memory address. For more details, see Section 7.2, <i>Direct Addressing Mode</i> , on page 7-4. The LST and LDP (load DP) instructions can modify the DP field.                                                                                                                                                                                                                                                                                           |
| INTM | <b>Interrupt mode bit.</b> This bit enables or disables all maskable interrupts. INTM is set and cleared by the SETC INTM and CLRC INTM instructions, respectively. INTM has no effect on the non-maskable interrupts RS and NMI or on interrupts initiated by software. INTM is unaffected by the LST (load status register) instruction. INTM is set to 1 when an interrupt trap is taken (except in the case of the TRAP instruction) and at reset.                                                                                                                                                                                    |
|      | INTM = 0 All unmasked interrupts are enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|      | INTM = 1 All maskable interrupts are disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| OV   | <b>Overflow flag bit.</b> This bit holds a latched value that indicates whether overflow has occurred in the CALU. OV is set to 1 when an overflow occurs in the CALU. Once an overflow occurs, the OV bit remains set until it is cleared by a reset, a conditional branch on overflow (OV) or no overflow (NOV), or an LST instruction.                                                                                                                                                                                                                                                                                                 |

| Table 3–2. Bit Fields of Status Registers ST0 and ST1 (Continued) |
|-------------------------------------------------------------------|
|-------------------------------------------------------------------|

| Name | Descriptio                                | n                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OVM  |                                           | <b>mode bit.</b> OVM determines how overflows in the CALU are handled. The SETC and ructions set and clear this bit, respectively. An LST instruction can also be used to M.                                                                                                                                                                                                                                                      |
|      | OVM = 0                                   | Results overflow normally in the accumulator.                                                                                                                                                                                                                                                                                                                                                                                     |
|      | OVM = 1                                   | The accumulator is set to either its most positive or negative value upon encounter-<br>ing an overflow. (See subsection 3.3.2, <i>Accumulator</i> , on page 3-9.)                                                                                                                                                                                                                                                                |
| PM   | CALU or to<br>copied to t                 | <b>hift mode.</b> PM determines the amount that the PREG value is shifted on its way to the o data memory. Note that the content of the PREG remains unchanged; the value is he product shifter and shifted there. PM is loaded by the SPM and LST instructions. s are cleared by reset.                                                                                                                                          |
|      | PM = 00                                   | The multiplier's 32-bit product is passed to the CALU or to data memory with no shift.                                                                                                                                                                                                                                                                                                                                            |
|      | PM = 01                                   | The output of the PREG is left shifted one place (with the LSBs zero filled) before being passed to the CALU or to data memory.                                                                                                                                                                                                                                                                                                   |
|      | PM = 10                                   | The output of the PREG is left shifted four bits (with the LSBs zero filled) before being passed to the CALU or to data memory.                                                                                                                                                                                                                                                                                                   |
|      | PM = 11                                   | This mode produces a right shift of six bits, sign extended.                                                                                                                                                                                                                                                                                                                                                                      |
| SXM  | example, the SETC                         | <b>nsion mode bit.</b> SXM does not affect the basic operation of certain instructions. For<br>the ADDS instruction suppresses sign extension regardless of SXM. This bit is set by<br>SXM instruction and cleared by the CLRC SXM instruction and may be loaded by the<br>ction. SXM is set to 1 by reset.                                                                                                                       |
|      | SXM = 0                                   | This mode suppresses sign extension.                                                                                                                                                                                                                                                                                                                                                                                              |
|      | SXM = 1                                   | This mode produces sign extension on data as it is passed into the accumulator from the input shifter.                                                                                                                                                                                                                                                                                                                            |
| тс   | tion tested<br>function of<br>conditional | <b>ol flag bit.</b> The TC bit is set to 1 if a bit tested by BIT or BITT is a 1, if a compare condiby CMPR exists between the current auxiliary register and AR0, or if the exclusive-OR the two MSBs of the accumulator is true when tested by a NORM instruction. The branch, call, and return instructions can execute, based on the condition of the TC bit. is affected by the BIT, BITT, CMPR, LST, and NORM instructions. |
| XF   | pin. XF is s                              | <b>tus bit.</b> This bit determines the state of the XF pin, which is a general-purpose output set by the SETC XF instruction and cleared by the CLRC XF instruction. XF can also d with an LST instruction. XF is set to 1 by reset.                                                                                                                                                                                             |

## Chapter 4

# **Memory and I/O Spaces**

Each 'C24x device has a 16-bit address line that accesses four individually selectable spaces (224K words total):

- □ A 64K-word program space
- A 64K-word local data space
- A 32K-word global data space
- □ A 64K-word I/O space

This chapter describes these four spaces and shows generic memory maps for the program, data, and I/O spaces. It also describes the 'C24x memory configuration options.

### Topic

#### Page

|     |                                           | _ |
|-----|-------------------------------------------|---|
| 4.1 | Overview of the Memory and I/O Spaces 4-2 |   |
| 4.2 | Program Memory 4-3                        |   |
| 4.3 | Local Data Memory 4-5                     |   |
| 4.4 | Global Data Memory 4-9                    |   |
| 4.5 | I/O Space 4-11                            |   |
|     |                                           |   |

### 4.1 Overview of the Memory and I/O Spaces

The 'C24x design is based on an enhanced Harvard architecture. The 'C24x has multiple memory spaces accessible on three parallel buses—the program address bus (PAB), the data-read address bus (DRAB), and the data-write address bus (DWAB). Each of the three buses access different memory spaces for different aspects of the device's operation. Because the bus operations are independent, it is possible to access both the program and data spaces simultaneously. Within a given machine cycle, the CALU can execute as many as three concurrent memory operations.

The 'C24x address map is organized into four individually selectable spaces:

- Program memory (64K words) contains the instructions to be executed, as well as data used during program execution.
- **Local data memory** (64K words) holds data used by the instructions.
- Global data memory (32K words) shares data with other devices or serves as additional data space.
- Input/output (I/O) space (64K words) interfaces to external peripherals and may contain on-chip registers.

These spaces provide a total address space of 224K words. The 'C24x includes on-chip memory to aid in system performance and integration and a considerable number of addresses that can be used for external memory and I/O devices.

The advantages of operating from on-chip memory are:

- Higher performance than external memory (because the wait states required for slower external memories are avoided)
- Lower cost than external memory
- Lower power consumption than external memory

The advantage of operating from external memory is the ability to access a larger address space.

### 4.2 Program Memory

The program-memory space is where the application program code resides; it can also hold table information and immediate operands. The programmemory space addresses up to 64K 16-bit words. On all 'C24x devices, these words include on-chip DARAM. On-chip SARAM and on-chip ROM/flash EEPROM may be available on some of the devices. When the 'C24x generates an address outside the set of addresses configured to on-chip program memory, the device automatically generates an external access, asserting the appropriate control signals (if an external memory interface is present).

Figure 4–1 shows the program memory map.

### Figure 4–1. Program Memory Map for 'C24x





### 4.2.1 Program Memory Configuration

Depending on which types of memory are on board a particular 'C24x, up to three factors contribute to the configuration of program memory:

- □ **CNF bit.** The CNF bit (bit 12) of status register ST1 determines whether the addresses for DARAM B0 are available for program space:
  - **CNF = 0.** There is no addressable on-chip program DARAM.
  - CNF = 1. The 256 or 512 words of DARAM B0 are configured for program use.

At reset, any words of program/data DARAM are mapped into local data space (CNF = 0).

- MP/MC pin. The level on the MP/MC pin determines whether program instructions are read from on-chip ROM/flash EEPROM (if available) after reset:
  - MP/MC = 0. The device is configured as a microcomputer. The onchip ROM/flash EEPROM is accessible. The device fetches the reset vector from on-chip memory.
  - MP/MC = 1. The device is configured as a microprocessor. The device fetches the reset vector from external memory.

Regardless of the value of  $MP/\overline{MC}$ , the 'C24x fetches its reset vector at location 0000h of program memory.

- RAMEN pin. The RAMEN signal (if available—check device data sheet) allows you to toggle a preset range of data/program addresses between on-chip SARAM (if available) and external memory:
  - RAMEN = 1. The preset range of addresses in both data space and program space are mapped to the same physical locations in the onchip SARAM. For example, if 1000h were in the preset address range, 1000h in program memory and 1000h in data memory would point to the same physical location in the on-chip SARAM. Thus, the full block of on-chip SARAM is accessible for program and/or data space.

#### Note:

When RAMEN = 1, program memory and data memory share the same range of addresses. When writing data to these locations, be careful not to overwrite existing program instructions.

RAMEN = 0. The preset range of addresses is not shared by data memory and program memory. Instead, that range of addresses in data memory and the same range in program memory are mapped to external program memory. Thus, when RAMEN = 0, a block of addresses twice the size of the SARAM block is available for accessing external memory.

### 4.3 Local Data Memory

The local data-memory space addresses up to 64K 16-bit words. Figure 4–2 shows the data memory map for the 'C24x. The 'C24x devices each have three on-chip DARAM blocks: B0, B1, and B2. Block B0 is configurable as either data memory or program memory. Blocks B1 and B2 are available for data memory only. Some 'C24x devices also have an on-chip SARAM block that can be used for program and/or data memory.

Figure 4–2. Data Memory Map for 'C24x



Data memory can be addressed with either of two addressing modes: directaddressing or indirect-addressing. Addressing modes are described in detail in Chapter 7.

When direct addressing is used, data memory is addressed in blocks of 128 words called data pages. Figure 4–3 shows how these blocks are addressed. The entire 64K of data memory consists of 512 data pages labeled 0 through 511. The current data page is determined by the value in the 9-bit data page pointer (DP) in status register ST0. Each of the 128 words on the current page is referenced by a 7-bit offset, which is taken from the instruction that is using direct addressing. Therefore, when an instruction uses direct addressing, you must specify both the data page (with a preceding instruction) and the offset (in the instruction that accesses data memory).

Figure 4–3. Pages of Local Data Memory

| DP Value    | Offset   | Data Memory           |
|-------------|----------|-----------------------|
| 0000 0000 0 | 000 0000 |                       |
| :           | ÷        | Page 0: 0000h–007Fh   |
| 0000 0000 0 | 111 1111 | _                     |
| 0000 0000 1 | 000 0000 |                       |
| :           |          | Page 1: 0080h-00FFh   |
| 0000 0000 1 | 111 1111 |                       |
| 0000 0001 0 | 000 0000 |                       |
| :           | :        | Page 2: 0100h–017Fh   |
| 0000 0001 0 | 111 1111 |                       |
|             |          |                       |
|             | •        |                       |
| •           | •        |                       |
|             |          |                       |
|             |          |                       |
|             | •        |                       |
|             |          |                       |
| 1111 1111 1 | 000 0000 |                       |
| :           | :        | Page 511: FF80h–FFFFh |
| 1111 1111 1 | 111 1111 |                       |

### 4.3.1 Data Page 0 Address Map

The 64K words of local data memory include the device's memory-mapped registers, which reside at the top of data page 0 (addresses 0000h–007Fh). Note the following:

- Three registers that can be accessed with zero wait states:
  - Interrupt mask register (IMR)
  - Global memory allocation register (GREG)
  - Interrupt flag register (IFR)
- The test/emulation reserved area is used by the test and emulation systems for special information transfers.

**Do Not Write to Test/Emulation Addresses** 

Writing to the test/emulation addresses can cause the device to change its operational mode and, therefore, affect the operation of an application.

□ The scratch-pad RAM block (B2) includes 32 words of DARAM that provide for variable storage without fragmenting the larger RAM blocks, whether internal or external. This RAM block supports dual-access operations and can be addressed via any data-memory addressing mode.

Table 4–1 shows the address map of data page 0.

Table 4–1. Data Page 0 Address Map

| Address     | Name | Description                       |
|-------------|------|-----------------------------------|
| 0000h–0003h | -    | Reserved                          |
| 0004h       | IMR  | Interrupt mask register           |
| 0005h       | GREG | Global memory allocation register |
| 0006h       | IFR  | Interrupt flag register           |
| 0023h–0027h | -    | Reserved                          |
| 002Bh-002Fh | -    | Reserved for test/emulation       |
| 0060h–007Fh | B2   | Scratch-pad RAM (DARAM B2)        |

### 4.3.2 Local Data Memory Configuration

Two factors may contribute to the configuration of data memory:

- CNF bit. The CNF bit (bit 12) of status register ST1 determines whether the on-chip DARAM B0 is mapped into local data space or into program space.
  - CNF = 1. DARAM B0 is used for program space.
  - **CNF = 0.** B0 is used for data space.

At reset, B0 is mapped into local data space (CNF = 0).

- RAMEN pin. The RAMEN signal allows you to toggle a preset range of data/program addresses between on-chip SARAM (if available) and external memory:
  - RAMEN = 1. The preset range of addresses in both data space and program space are mapped to the same physical locations in the onchip SARAM. For example, if 1000h were in the preset address range, 1000h in program memory and 1000h in data memory would point to the same physical location in the on-chip SARAM. Thus, the full block of on-chip SARAM is accessible for program and/or data space.

#### Note:

When RAMEN = 1, program memory and data memory share the same range of addresses. When writing data to these locations, be careful not to overwrite existing program instructions.

RAMEN = 0. The preset range of addresses is not shared by data memory and program memory. Instead, that range of addresses in data memory and the same range in program memory are mapped to external program memory. Thus, when RAMEN = 0, a block of addresses twice the size of the SARAM block is available for accessing external memory.

### 4.4 Global Data Memory

Addresses in the upper 32K words (8000h–FFFFh) of local data memory can be used for global data memory. The global memory allocation register (GREG) determines the size of the global data-memory space, which is between 256 and 32K words. The GREG is connected to the eight LSBs of the internal data bus and is memory-mapped to data-memory location 0005h. Table 4–2 shows the allowable GREG values and shows the corresponding address range set aside for global data memory. Any remaining addresses within 8000h–FFFFh are available for local data memory.

#### Note:

Choose only the GREG values listed in Table 4–2. Other values lead to fragmented memory maps.

| abie + L. Global Dala Merror Corrigulations | Table 4–2. | Global Data | Memorv | Configurations |
|---------------------------------------------|------------|-------------|--------|----------------|
|---------------------------------------------|------------|-------------|--------|----------------|

| GREG      | Value     | Local Me    | mory   | Global Memory |        |  |  |  |
|-----------|-----------|-------------|--------|---------------|--------|--|--|--|
| High Byte | Low Byte  | Range       | Words  | Range         | Words  |  |  |  |
| XXXX XXXX | 0000 0000 | 0000h–FFFFh | 65 536 | _             | 0      |  |  |  |
| XXXX XXXX | 1000 0000 | 0000h–7FFFh | 32 768 | 8000h-FFFFh   | 32 768 |  |  |  |
| XXXX XXXX | 1100 0000 | 0000h–BFFFh | 49 152 | C000h-FFFFh   | 16 384 |  |  |  |
| XXXX XXXX | 1110 0000 | 0000h–DFFFh | 57 344 | E000h-FFFFh   | 8 192  |  |  |  |
| XXXX XXXX | 1111 0000 | 0000h-EFFFh | 61 440 | F000h-FFFFh   | 4 096  |  |  |  |
| XXXX XXXX | 1111 1000 | 0000h-F7FFh | 63 488 | F800h–FFFFh   | 2 048  |  |  |  |
| XXXX XXXX | 1111 1100 | 0000h–FBFFh | 64 512 | FC00h-FFFFh   | 1 024  |  |  |  |
| XXXX XXXX | 1111 1110 | 0000h-FDFFh | 65 024 | FE00h-FFFFh   | 512    |  |  |  |
| XXXX XXXX | 1111 1111 | 0000h-FEFFh | 65 280 | FF00h-FFFFh   | 256    |  |  |  |

Note: X = Don't care

When a program accesses any data address, the 'C24x drives the  $\overline{DS}$  signal low. If that address is within the range defined by the GREG as a global address,  $\overline{BR}$  signal is also asserted. Because  $\overline{BR}$  differentiates local and global accesses, the addresses configured by the GREG value are an additional data space. The external data-address range is extended by the selected amount of global space (up to 32K words).

As an example of configuring global memory, suppose you want to designate 8K data-memory addresses as global addresses. You would write the 8-bit value 11100000 to the GREG (see Figure 4–4). This would designate addresses E000h–FFFFh of data memory as global data addresses (see Figure 4–5).

Figure 4–4. GREG Register Set to Configure 8K for Global Data Memory

| 8 MSBs        |   |   |   |   |   |   |   |        |      |        | 8 L    | SBs   |      |   |   |   |
|---------------|---|---|---|---|---|---|---|--------|------|--------|--------|-------|------|---|---|---|
|               | Х | Х | Х | Х | Х | Х | Х | Х      | 1    | 1      | 1      | 0     | 0    | 0 | 0 | 0 |
| (Don't cares) |   |   |   |   |   |   | ; | Set fo | r 8K | of glo | bal da | ata m | emor | у |   |   |

Figure 4–5. Global and Local Data Memory for GREG = 11100000



### 4.5 I/O Space

The I/O space memory addresses up to 64K 16-bit words. Figure 4–6 shows the I/O-space address map for the 'C24x.

Figure 4–6. I/O-Space Address Map for 'C24x



Note: See device-specific data sheets for information on I/O mapped registers.

## Chapter 5

# **Program Control**

This chapter discusses the processes and features involved in controlling the flow of a program on the 'C24x.

Program control involves controlling the order in which one or more blocks of instructions are executed. Normally, the flow of a program is sequential: the 'C24x executes instructions at consecutive program-memory addresses. At times, a program must branch to a nonsequential address and then execute instructions sequentially at that new location. For this purpose, the 'C24x supports branches, calls, returns, repeats, and interrupts. Interrupts are described in Chapter 6, *System Functions*.

### Topic

#### Page

| 5.1 | Program-Address Generation 5-2                |
|-----|-----------------------------------------------|
| 5.2 | Pipeline Operation 5-7                        |
| 5.3 | Branches, Calls, and Returns 5-8              |
| 5.4 | Conditional Branches, Calls, and Returns 5-10 |
| 5.5 | Repeating a Single Instruction 5-14           |

### 5.1 Program-Address Generation

Program flow requires the processor to generate the next program address (sequential or nonsequential) while executing the current instruction. Program-address generation is illustrated in Figure 5–1 and summarized in Table 5–1.





| Operation                                                            | Program-Address Source                                           |
|----------------------------------------------------------------------|------------------------------------------------------------------|
| Sequential operation                                                 | PC (contains program address +1)                                 |
| Dummy cycle                                                          | PAR (contains program address)                                   |
| Return from subroutine                                               | Top of the stack (TOS)                                           |
| Return from table move or block move                                 | Microstack (MSTACK)                                              |
| Branch or call to address specified in instruction                   | Branch or call instruction by way of the program read bus (PRDB) |
| Branch or call to address specified in lower half of the accumulator | Low accumulator by way of the data read bus (DRDB)               |
| Branch to interrupt service routine                                  | Interrupt vector location by way of the program read bus (PRDB)  |

The 'C24x program-address generation logic uses the following hardware:

- Program counter (PC). The 'C24x has a 16-bit program counter (PC) that addresses internal and external program memory when fetching instructions.
- Program address register (PAR). The PAR drives the program address bus (PAB). The PAB is a 16-bit bus that provides program addresses for both reads and writes.
- ❑ Stack. The program-address generation logic includes a 16-bit-wide, 8level hardware stack for storing up to eight return addresses. In addition, you can use the stack for temporary storage.
- Microstack (MSTACK). Occasionally, the program-address generation logic uses the 16-bit-wide, 1-level MSTACK to store one return address.
- Repeat counter (RPTC). The 16-bit RPTC is used with the repeat (RPT) instruction to determine how many times the instruction following RPT is repeated.

#### 5.1.1 Program Counter (PC)

The program-address generation logic uses the 16-bit program counter (PC) to address internal and external program memory. The PC holds the address of the next instruction to be executed. Through the program address bus (PAB), an instruction is fetched from that address in program memory and loaded into the instruction register. When the instruction register is loaded, the PC holds the next address.

The 'C24x can load the PC in a number of ways, to accommodate sequential and nonsequential program flow. Table 5–2 shows what is loaded to the PC according to the code operation performed.

Table 5–2. Address Loading to the Program Counter

| Code Operation                 | Address Loaded to the PC                                                                                                                                                                                                                                                                                    |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sequential execution           | The PC is loaded with PC + 1 if the current instruction has one word or PC + 2 if the current instruction has two words.                                                                                                                                                                                    |
| Branch                         | The PC is loaded with the long immediate value directly fol-<br>lowing the branch instruction.                                                                                                                                                                                                              |
| Subroutine call and return     | For a call, the address of the next instruction is pushed from<br>the PC onto the stack, and then the PC is loaded with the<br>long immediate value directly following the call instruction.<br>A return instruction pops the return address back into the PC<br>to return to the calling sequence of code. |
| Software or hardware interrupt | The PC is loaded with the address of the appropriate inter-<br>rupt vector location. At this location is a branch instruction<br>that loads the PC with the address of the corresponding in-<br>terrupt service routine.                                                                                    |
| Computed GOTO                  | The content of the lower 16 bits of the accumulator is loaded<br>into the PC. Computed GOTO operations can be performed<br>using the BACC (branch to address in accumulator) or<br>CALA (call subroutine at location specified by the accumula-<br>tor) instructions.                                       |

#### 5.1.2 Stack

The 'C24x has a 16-bit-wide, 8-level-deep hardware stack. The program-address generation logic uses the stack for storing return addresses when a subroutine call or interrupt occurs. When an instruction forces the CPU into a subroutine or an interrupt forces the CPU into an interrupt service routine, the return address is loaded to the top of the stack automatically; this event does not require additional cycles. When the subroutine or interrupt service routine is complete, a return instruction transfers the return address from the top of the stack to the program counter.

When the eight levels are not used for return addresses, the stack may be used for saving context data during a subroutine or interrupt service routine or for other storage purposes.

You can access the stack with two sets of instructions:

PUSH and POP. The PUSH instruction copies the 16 LSBs of the accumulator to the top of the stack. The POP instruction copies the value on the top of the stack to the 16 LSBs of the accumulator.

PSHD and POPD. These instructions allow you to build a stack in data memory for the nesting of subroutines or interrupts beyond eight levels. The PSHD instruction pushes a data-memory value onto the top of the stack. The POPD instruction pops a value from the top of the stack to data memory.

Whenever a value is pushed onto the top of the stack (by an instruction or by the address-generation logic), the content of each level is pushed down one level, and the bottom (eighth) location of the stack is lost. Therefore, data is lost (stack overflow occurs) if more than eight successive pushes occur before a pop. Figure 5–2 shows a push operation.





Pop operations are the reverse of push operations. A pop operation copies the value at each level to the next higher level. Any pop after seven sequential pops yields the value that was originally at the bottom of the stack because, by then, the bottom value has been copied upward to all of the stack levels. Figure 5–3 shows a pop operation.

#### Figure 5–3. A Pop Operation



#### 5.1.3 Microstack (MSTACK)

The program-address generation logic uses the 16-bit-wide, 1-level-deep MSTACK to store a return address before executing certain instructions. These instructions use the program-address generation logic to provide a second address in a 2-operand instruction. These instructions are: BLDD, BLPD, MAC, MACD, TBLR, and TBLW. When repeated, these instructions use the PC to increment the first operand address and can use the auxiliary register arithmetic unit (ARAU) to generate the second operand address. When these instructions are used, the return address (the address of the next instruction to be fetched) is pushed onto the MSTACK. Upon completion of the repeated instruction, the MSTACK value is popped back into the program-address generation logic. The MSTACK operations are not visible to you. Unlike the stack, the MSTACK can be used only by the program-address generation logic; there are no instructions that allow you to use the MSTACK for storage.

#### 5.2 Pipeline Operation

Instruction pipelining consists of a sequence of bus operations that occur during the execution of an instruction. The 'C24x pipeline has four independent stages: instruction-fetch, instruction-decode, operand-fetch, and instructionexecute. Because the four stages are independent, these operations can overlap. During any given cycle, one to four different instructions can be active, each at a different stage of completion. Figure 5–4 shows the operation of the 4-level-deep pipeline for single-word, single-cycle instructions executing with no wait states.

The pipeline is essentially invisible to you, except in the following cases:

- ☐ A single-word, single-cycle instruction immediately following a modification of the global-memory allocation register (GREG) uses the previous global map.
- The NORM instruction modifies the auxiliary register pointer (ARP) and uses the current auxiliary register (the one pointed to by the ARP) during the execute phase of the pipeline. If the next two instruction words change the values in the current auxiliary register or the ARP, they will do so during the instruction decode phase of the pipeline (before the execution of NORM). This would cause NORM to use the wrong auxiliary register value and the following instructions to use the wrong ARP value.

| CLKOUT1 |       |       |       |       | _ |
|---------|-------|-------|-------|-------|---|
| Fetch   | ← N → | N + 1 | N + 2 | N + 3 |   |
| Decode  | N – 1 | Ν     | N + 1 | N + 2 |   |
| Operand | N – 2 | N – 1 | N     | N + 1 |   |
| Execute | N – 3 | N – 2 | N – 1 | N     |   |

#### Figure 5–4. Four-Level Pipeline Operation

The CPU is implemented using 2-phase static logic. The 2-phase operation of the 'C24x CPU consists of a master phase in which all commutation logic is executed, and a slave phase in which results are latched. Therefore, sequential operations require sequential master cycles. Although sequential operations require a deeper pipeline, 2-phase operation provides more time for the computational logic to execute. This allows the 'C24x to run at faster clock rates, despite having a deeper pipeline that imposes a penalty on branches and subroutine calls.

#### 5.3 Branches, Calls, and Returns

Branches, calls, and returns break the sequential flow of instructions by transferring control to another location in program memory. A *branch* only transfers control to the new location. A *call* also saves the return address (the address of the instruction following the call) to the top of the hardware stack. Every called subroutine or interrupt service routine is concluded with a *return* instruction, which pops the return address off the stack and back into the program counter (PC).

The 'C24x has two types of branches, calls, and returns:

- Unconditional. An unconditional branch, call, or return is always executed. The unconditional branch, call, and return instructions are described in subsections 5.3.1, 5.3.2, and 5.3.3, respectively.
- Conditional. A conditional branch, call, or return is executed only if certain specified conditions are met. The conditional branch, call, and return instructions are described in detail in Section 5.4, *Conditional Branches, Calls, and Returns*, on page 5-10.

#### 5.3.1 Unconditional Branches

When an unconditional branch is encountered, it is always executed. During the execution, the PC is loaded with the specified program-memory address and program execution begins at that address. The address loaded into the PC may come from either the second word of the branch instruction or the lower sixteen bits of the accumulator.

By the time the branch instruction reaches the execute phase of the pipeline, the next two instruction words have already been fetched. These two instruction words are flushed from the pipeline so that they are not executed, and then execution continues at the branched-to address. The unconditional branch instructions are B (branch) and BACC (branch to location specified by accumulator).

#### 5.3.2 Unconditional Calls

When an unconditional call is encountered, it is always executed. When the call is executed, the PC is loaded with the specified program-memory address and program execution begins at that address. The address loaded into the PC may come from either the second word of the call instruction or the lower 16 bits of the accumulator. Before the PC is loaded, the return address is saved in the stack. After the subroutine or function is executed, a return instruction loads the PC with the return address from the stack, and execution resumes at the instruction following the call.

By the time the unconditional call instruction reaches the execute phase of the pipeline, the next two instruction words have already been fetched. These two instruction words are flushed from the pipeline so that they are not executed, the return address is stored to the stack, and then execution continues at the beginning of the called function. The unconditional call instructions are CALL and CALA (call subroutine at location specified by accumulator).

## 5.3.3 Unconditional Returns

When an unconditional return (RET) instruction is encountered, it is always executed. When the return is executed, the PC is loaded with the value at the top of the stack, and execution resumes at that address.

By the time the unconditional return instruction reaches the execute phase of the pipeline, the next two instruction words have already been fetched. The two instruction words are flushed from the pipeline so that they are not executed, the return address is taken from the stack, and then execution continues in the calling function.

#### 5.4 Conditional Branches, Calls, and Returns

The 'C24x provides branch, call, and return instructions that execute only if one or more conditions are met. You specify the conditions as operands of the conditional instruction. Table 5–3 lists the conditions that you can use with these instructions and their corresponding operand symbols.

| Operand<br>Symbol | Condition    | Description                            |
|-------------------|--------------|----------------------------------------|
| EQ                | ACC = 0      | Accumulator equal to 0                 |
| NEQ               | ACC ≠ 0      | Accumulator not equal to 0             |
| LT                | ACC < 0      | Accumulator less than 0                |
| LEQ               | ACC $\leq 0$ | Accumulator less than or equal to 0    |
| GT                | ACC > 0      | Accumulator greater than 0             |
| GEQ               | $ACC \ge 0$  | Accumulator greater than or equal to 0 |
| С                 | C = 1        | Carry bit set to 1                     |
| NC                | C = 0        | Carry bit cleared to 0                 |
| OV                | OV = 1       | Accumulator overflow detected          |
| NOV               | OV = 0       | No accumulator overflow detected       |
| BIO               | BIO low      | BIO pin is low                         |
| тс                | TC = 1       | Test/control flag set to 1             |
| NTC               | TC = 0       | Test/control flag cleared to 0         |

Table 5–3. Conditions for Conditional Calls and Returns

#### 5.4.1 Using Multiple Conditions

Multiple conditions can be listed as operands of the conditional instructions. If multiple conditions are listed, all conditions must be met for the instruction to execute. Note that only certain combinations of conditions are meaningful. See Table 5–4. For each combination, the conditions must be selected from Group 1 and Group 2 as follows:

Group 1. You can select up to two conditions. Each of these conditions must be from a different category (A or B); you cannot have two conditions from the same category. For example, you can test EQ and OV at the same time, but you cannot test GT and NEQ at the same time. Group 2. You can select up to three conditions. Each of these conditions must be from a different category (A, B, or C); you cannot have two conditions from the same category. For example, you can test TC, C, and BIO at the same time, but you cannot test C and NC at the same time.

| Group 1    |            | Group 2    |            |            |
|------------|------------|------------|------------|------------|
| Category A | Category B | Category A | Category B | Category C |
| EQ         | OV         | тс         | С          | BIO        |
| NEQ        | NOV        | NTC        | NC         |            |
| LT         |            |            |            |            |
| LEQ        |            |            |            |            |
| GT         |            |            |            |            |
| GEQ        |            |            |            |            |

## Table 5–4. Groupings of Conditions

#### 5.4.2 Stabilization of Conditions

A conditional instruction must be able to test the most recent values of the status bits. Therefore, the conditions cannot be considered stable until the fourth, or execution, stage of the pipeline, one cycle after the previous instruction has been executed. The pipeline controller stops the decoding of any instructions following the conditional instruction until the conditions are stable.

#### 5.4.3 Conditional Branches

A branch instruction transfers program control to any location in program memory. Conditional branch instructions are executed only when one or more user-specified conditions are met (see Table 5–3 on page 5-10). If all the conditions are met, the PC is loaded with the second word of the branch instruction, which contains the address to branch to, and execution continues at this address.

By the time the conditions have been tested, the two instruction words following the conditional branch instruction have already been fetched in the pipeline. If all the conditions are met, these two instruction words are flushed from the pipeline so that they are not executed, and then execution continues at the branched-to address. If the conditions are *not* met, the two instruction words are executed instead of the branch. Because conditional branches use conditions determined by the execution of the previous instructions, a conditional branch takes one more cycle than an unconditional one.

The conditional branch instructions are BCND (branch conditionally) and BANZ (branch if currently selected auxiliary register is not equal to 0). The BANZ instruction is useful for implementing loops.

#### 5.4.4 Conditional Calls

The conditional call (CC) instruction is executed only when the specified condition or conditions are met (see Table 5–3 on page 5-10). This allows your program to choose among multiple subroutines; based on the data being processed. If all the conditions are met, the PC is loaded with the second word of the call instruction, which contains the starting address of the subroutine. Before branching to the subroutine, the processor stores the address of the instruction following the call instruction—the return address—to the stack. The function must end with a return instruction, which takes the return address off the stack and forces the processor to resume execution of the calling program.

By the time the conditions of the conditional call instruction have been tested, the two instruction words following the call instruction have already been fetched in the pipeline. If all the conditions are met, these two instruction words are flushed from the pipeline so that they are not executed, and then execution continues at the beginning of the called function. If the conditions are *not* met, the two instructions are executed instead of the call. Because there is a wait cycle for conditions to become stable, the conditional call takes one more cycle than the unconditional one.

#### 5.4.5 Conditional Returns

Returns are used in conjunction with calls and interrupts. A call or interrupt stores a return address to the stack and then transfers program control to a new location in program memory. The called subroutine or the interrupt service routine concludes with a return instruction, which pops the return address off the top of the stack and into the program counter (PC).

The conditional return instruction (RETC) is executed only when one or more conditions are met (see Table 5–3 on page 5-10). By using the RETC instruction, you can give a subroutine or interrupt service routine more than one possible return path. The path chosen then depends on the data being processed. In addition, you can use a conditional return to avoid conditionally branching to/around the return instruction at the end of the subroutine or interrupt service routine.

If all the conditions are met for execution of the RETC instruction, the processor loads the return address from the stack to the PC and resumes execution of the calling or interrupted program.

RETC, like RET, is a single-word instruction. However, because of the potential PC discontinuity, it operates with the same effective execution time as the conditional branch (BCND) and the conditional call (CC). By the time the conditions of the conditional return instruction have been tested, the two instruction words following the return instruction have already been fetched in the pipeline. If all the conditions are met, these two instruction words are flushed from the pipeline so that they are not executed, and then execution of the calling program continues. If the conditions are *not* met, the two instructions are executed instead of the return. Because there is a wait cycle for conditions to become stable, the conditional return takes one more cycle than the unconditional one.

## 5.5 Repeating a Single Instruction

The 'C24x repeat (RPT) instruction allows the execution of a single instruction N + 1 times, where N is specified as an operand of the RPT instruction. When RPT is executed, the repeat counter (RPTC) is loaded with N. RPTC is then decremented every time the repeated instruction is executed, until RPTC equals 0. RPTC can be used as a 16-bit counter when the count value is read from a data-memory location; if the count value is specified as a constant operand, it is in an 8-bit counter.

The repeat feature is useful with instructions such as NORM (normalize contents of accumulator), MACD (multiply and accumulate with data move), and SUBC (conditional subtract). When instructions are repeated, the address and data buses for program memory are free to fetch a second operand in parallel with the address and data buses for data memory. This allows instructions such as MACD and BLPD to effectively execute in a single cycle when repeated.

#### PRELIMINARY

## Chapter 6

# **System Functions**

This chapter describes the device functions that are not specific to any peripheral:

- □ The peripheral interface transfers data between the CPU data bus and the peripheral bus, which is independent of the CPU.
- □ The system configuration registers provide software control and status information for functions that affect both the DSP core and certain peripherals.
- Hardware interrupts (including reset) require control by both CPU registers and peripheral registers.
- Dever-down modes can affect both the CPU and the peripherals.

#### Topic

Page

| 6.1 | Peripheral Interface               |
|-----|------------------------------------|
| 6.2 | System Configuration Registers 6-4 |
| 6.3 | Interrupts                         |
| 6.4 | Reset Operation 6-48               |
| 6.5 | Power-Down Modes6-51               |
|     |                                    |

## 6.1 Peripheral Interface

In order to support a large number of peripherals without compromising the electrical performance of the 'C2xx DSP CPU's data bus, 'C24x devices have a separate peripheral bus which operates at a lower frequency than the CPU buses. Most peripherals are attached to this peripheral bus, although a few (for example, the event manager) interface directly to the CPU's data bus. See the individual peripheral specifications and device data sheets for details. Up to 16 peripherals may be connected to the peripheral bus.

One of the functions of the peripheral interface is to interface the CPU to the peripheral bus.

The CPU is clocked at either two times ( $2 \times$  mode) or four times ( $4 \times$  mode) the clock rate of the peripheral bus. Because the peripheral bus runs slower than the CPU bus, peripheral bus reads and writes take multiple CPU cycles. The exact number of CPU cycles a peripheral access takes to complete depends on:

- Peripheral clock rate
- Phase of the peripheral clock in which the CPU initiates the peripheral access
- Type of access: read or write

Table 6–1 shows how many CPU clock cycles it takes to complete read and write accesses to peripherals connected to the peripheral bus. If, for example, the clocks are in 4x mode, a single peripheral read may take 5, 6, 7, or 8 CPU cycles, depending on the phase of the peripheral clock when the CPU initiates the peripheral access. If back-to-back accesses are performed, all accesses after the first will take eight cycles in 4× mode. Note that writes always take one cycle longer than reads. This is consistent with zero-wait-state external memory accesses and event manager accesses over the CPU's data bus; these accesses take one cycle for a read and two cycles for a write.

| Table 6–1. CPU Cycles to Complete Reads From and Writes to the Peripheral Bus |
|-------------------------------------------------------------------------------|
|-------------------------------------------------------------------------------|

|                   | 2x Clo                      | ck Mode                           | 4x Clo                      | ck Mode                           |
|-------------------|-----------------------------|-----------------------------------|-----------------------------|-----------------------------------|
| Type of<br>Access | Single Accesses<br>(Cycles) | Back-to-Back<br>Accesses (Cycles) | Single Accesses<br>(Cycles) | Back-to-Back<br>Accesses (Cycles) |
| Read              | 3 or 4                      | 4                                 | 5, 6, 7, or 8               | 8                                 |
| Write             | 4 or 5                      | 4                                 | 6, 7, 8, or 9               | 8                                 |

All CPU memory accesses are 16 bits wide. Reads from 8-bit peripherals are LSB aligned. The most significant eight bits of a write to an 8-bit peripheral are ignored. All peripherals are located in the CPU's data space; this allows the full instruction set to act upon the peripheral registers. I/O space is not used by on-chip peripherals. A 'C24x device can have no more than 16 on-chip peripherals attached to the peripheral bus. There is no such limitation on peripherals that interface directly to the CPU.

## 6.2 System Configuration Registers

The system configuration registers are shown in Figure 6–1 and described in subsections 6.2.1 through 6.2.3. Note these points about the register locations:

- All unimplemented (reserved) bits are read as indeterminate values (unless otherwise stated).
- Bit 0 of the peripheral address bus is not decoded; therefore, these 16-bit registers are accessible at each even address location and the following (odd) address location. For example, the register SYSIVR is nominally at location 701Eh, but it can also be accessed at address 701Fh.

Figure 6–1. System Configuration Registers



Address Register

Figure 6–1. System Configuration Registers (Continued)



## 6.2.1 System Control Register (SYSCR)

Figure 6–2. System Control Register (SYSCR) — Address 7018h

| _ | 15     | 14     | 13–8     | 7       | 6       | 5–0      |
|---|--------|--------|----------|---------|---------|----------|
|   | RESET1 | RESET0 | Reserved | CLKSRC1 | CLKSRC0 | Reserved |
|   | R/W–0  | R/W-1  |          | R/W-1*  | R/W-1*  |          |

Note: R = Read access, W = Write access, -n = Value after reset,

\* = Not affected by reset, set to 1 by power-on reset

**Bits 15–14 RESET1, RESET0**. Software reset bits. 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 | Resulting<br>Action |
|--------|--------|---------------------|
| 0      | 0      | Global reset        |
| 0      | 1      | _                   |
| 1      | 0      | Global reset        |
| 1      | 1      | Global reset        |

Bits 13–8 Reserved. Reads are indeterminate and writes have no effect.

| CLKSRC1 | CLKSRC0 | CLKOUT Pin Function                                                       |
|---------|---------|---------------------------------------------------------------------------|
| 0       | 0       | Digital I/O mode (controlled by I/O register bits—see device data sheet). |
| 0       | 1       | WDCLK: Watchdog Timer Clock output mode (nomi-<br>nally 16 kHz).          |
| 1       | 0       | SYSCLK: system clock.                                                     |
| 1       | 1       | CPUCLK: CPU clock output mode.                                            |

**Bits 7–6 CLKSRC1, CLKSRC0**. CLKOUT-pin source select. These bits control the selection of the CLKOUT pin function.



#### 6.2.2 System Status Register (SYSSR)

Bits 15, 12, 10 and 9 of the system status register indicate the cause of a reset. The reset service routine can read this register and use these bits to take the appropriate action according to the cause of reset. For example, if a power-on reset occurs, the clock module control registers may have to be reconfigured.

Figure 6–3. System Status Register (SYSSR) — Address 701Ah

| 15    | 14–13 | 12     | 11  | 10    | 9     | 8–6 | 5     | 4   | 3      | 2–1 | 0     |
|-------|-------|--------|-----|-------|-------|-----|-------|-----|--------|-----|-------|
| PORST | Res   | ILLADR | Res | SWRST | WDRST | Res | HPO   | Res | VCCAOR | Res | VECRD |
| R/C-x |       | R/C-x  |     | R/C-x | R/C-x |     | R/C-i |     | R–1    |     | R–0   |

Note: R = Read access, C = Clear-only write access, -n = Value after reset (x means value unchanged by reset), -i = Value of V<sub>CCP</sub> pin latch on rising edge of RESET

**Bit 15 PORST.** Power-on reset status bit. The occurrence of a power-on reset sets this bit. Depending on the device configuration, a power-on reset may be caused by either an on-chip low-voltage detect module indicating that V<sub>DD</sub> is out of regulation, or from an off-chip power-on reset or low-voltage detection source connected to the PORST pin.

- 0 = No reset has occurred due to power-on reset or  $V_{DD}$  out of regulation.
- 1 = Reset due to power-on reset or V<sub>DD</sub> out of regulation.

Bits 14–13 Reserved. Reads are indeterminate and writes have no effect.

| Bit 12   | <b>ILLADR</b> . Illegal-address reset status bit. Illegal address reset occurs when an unimplemented on-chip address location in data or program space is accessed. See the data sheet for each specific 'C24x device for details of which addresses are illegal on that device.                                                                    |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | <ul> <li>0 = No illegal address conditions</li> <li>1 = Reset due to illegal address</li> </ul>                                                                                                                                                                                                                                                     |
| Bit 11   | Reserved. Reads are indeterminate and writes have no effect.                                                                                                                                                                                                                                                                                        |
| Bit 10   | SWRST. Software reset status bit.                                                                                                                                                                                                                                                                                                                   |
|          | <ul> <li>0 = No software reset</li> <li>1 = Software reset occurred. (A 1 was written to bit 15 of the SYSCR, or a 0 was written to bit 14 of the SYSCR.)</li> </ul>                                                                                                                                                                                |
| Bit 9    | WDRST. Watchdog reset status bit.                                                                                                                                                                                                                                                                                                                   |
|          | <ul><li>0 = No reset</li><li>1 = Reset due to Watchdog Timer overflow</li></ul>                                                                                                                                                                                                                                                                     |
| Bits 8–6 | Reserved. Reads are indeterminate and writes have no effect.                                                                                                                                                                                                                                                                                        |
| Bit 5    | <b>HPO</b> . Hardware protect override. If the flash programming voltage pin ( $V_{CCP}$ ) is at 5V on the trailing edge of the reset pin (RS) and is held at that value, the HPO bit is set. (This only applies to 'F24x devices, which have on-chip flash EEPROM). This value is cleared by software or if the $V_{CCP}$ pin level changes to 0V. |
|          | <ul> <li>Normal mode</li> <li>= HPO mode: Flash EEPROM programming is enabled and the Watch-<br/>dog can be disabled by setting the WDDIS bit in the WD control regis-<br/>ter. For details about this register, see <i>TMS320C24x DSP Controllers</i><br/><i>Reference Set, Volume 2: Peripheral Library and Specific Devices.</i></li> </ul>      |

- Bit 4 Reserved. Reads are indeterminate and writes have no effect.
- Bit 3 VCCAOR. Analog V<sub>CC</sub> (V<sub>CCA</sub>) out-of-regulation bit. This bit is only valid if the device has an on-chip low-voltage detect module.
  - $0 = V_{CCA}$  is on and in regulation.

 $1 = V_{CCA}$  is off or out of regulation.

Bits 2–1 Reserved. Reads are indeterminate and writes have no effect.

**Bit 0 VECRD**. Interrupt vector read pending bit. This bit is set when an interrupt vector is loaded into the SYSIVR (when the interrupt is acknowledged). It is cleared when the SYSIVR is read. This bit is used by the service routine of non-maskable interrupt NMI (see subsection 6.3.7, *Programming an ISR for Non-maskable Interrupt (NMI)* on page 6-30).

0 = No read of the interrupt vector register is pending.

1 = An interrupt vector has been latched but has not been read yet.

#### 6.2.3 System Interrupt Vector Register (SYSIVR)

The system interrupt vector register is a read-only register.

| Figure 6–4. | System Ir | nterrupt Vect | or Register | (SYSIVR | ) — Address 701Eh |
|-------------|-----------|---------------|-------------|---------|-------------------|
|             |           |               |             |         |                   |

| 15                      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| System Interrupt Vector |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                         |    |    |    |    |    |   |   | • |   |   |   |   |   |   |   |

R–0

Note: R = Read access, -n = Value after reset

- **Bits 15–8** Eight MSBs of the system interrupt vector. these bits are always read as 0s.
- **Bits 7–0** Eight LSBs of the system interrupt vector. These bits are loaded with the interrupt vector address offset value. This value is generated by a peripheral attached to the peripheral bus, in response to the acknowledgement of the corresponding maskable interrupt.

#### 6.3 Interrupts

Interrupts are hardware- or software-driven signals that cause the 'C24x to suspend its main program and execute a subroutine. Typically, interrupts are generated by hardware devices that need to give data to or take data from the 'C24x (for example, A/D and D/A converters and other processors). Interrupts may also be used to signal that a particular event has taken place (for example, a timer has finished counting).

The 'C24x supports both software and hardware interrupts:

- A *software interrupt* is requested by an instruction (INTR, NMI, or TRAP).
- A hardware interrupt is requested by a signal from a physical device. Two types exist:
  - External hardware interrupts are triggered by signals at external interrupt pins. All these interrupts have programmable polarity and priority and are controlled by the external interrupt control registers.
  - Internal hardware interrupts are triggered by signals from the on-chip peripherals.

If hardware interrupts are triggered at the same time, the 'C24x services them according to a set priority ranking. Each of the 'C24x interrupts, whether hardware or software, can be placed in one of the following two categories:

- ☐ Maskable interrupts. These are hardware interrupts that can be blocked (masked) or enabled (unmasked) by software.
- ❑ Nonmaskable interrupts. These interrupts cannot be blocked. The 'C24x always responds to this type of interrupt and branches from the main program to a subroutine. The 'C24x nonmaskable interrupts include all software interrupts and two external hardware interrupts: reset (RS) and NMI. Note that although RS is always active low, NMI has programmable polarity. For more information, see subsection 6.3.11, *External Interrupt Control Registers*, on page 6-37.

For information about the reset signal and its effects on the 'C24x, see Section 6.4, *Reset Operation*, on page 6-48. The control register for NMI is described in subsection 6.3.2, *Nonmaskable Interrupt Operation*, on page 6-12.

Table 6–2 summarizes the interrupts available on the CPU. Other maskable interrupts are available through on-chip peripherals. The relationship between the maskable CPU interrupts (INT1–INT6) and the maskable peripheral interrupts is included in this section; however, for details on the peripheral interrupts available on a specific 'C24x device, see the data sheet for that device.

| κ† | Vector<br>Location | Name  | Priority    | Function                        |
|----|--------------------|-------|-------------|---------------------------------|
| 0  | 0h                 | RS    | 1 (highest) | Hardware reset (nonmaskable)    |
| 1  | 2h                 | INT1  | 4           | Maskable interrupt level #1     |
| 2  | 4h                 | INT2  | 5           | Maskable interrupt level #2     |
| 3  | 6h                 | INT3  | 6           | Maskable interrupt level #3     |
| 4  | 8h                 | INT4  | 7           | Maskable interrupt level #4     |
| 5  | Ah                 | INT5  | 8           | Maskable interrupt level #5     |
| 6  | Ch                 | INT6  | 9           | Maskable interrupt level #6     |
| 7  | Eh                 |       | 10          | Reserved                        |
| 8  | 10h                | INT8  | _           | User-defined software interrupt |
| 9  | 12h                | INT9  | _           | User-defined software interrupt |
| 10 | 14h                | INT10 | _           | User-defined software interrupt |
| 11 | 16h                | INT11 | -           | User-defined software interrupt |
| 12 | 18h                | INT12 | -           | User-defined software interrupt |
| 13 | 1Ah                | INT13 | _           | User-defined software interrupt |
| 14 | 1Ch                | INT14 | _           | User-defined software interrupt |
| 15 | 1Eh                | INT15 | _           | User-defined software interrupt |
| 16 | 20h                | INT16 | _           | User-defined software interrupt |
| 17 | 22h                | TRAP  | _           | TRAP instruction vector         |
| 18 | 24h                | NMI   | 3           | Nonmaskable interrupt           |
| 19 | 26h                |       | 2           | Reserved                        |
| 20 | 28h                | INT20 | _           | User-defined software interrupt |
| 21 | 2Ah                | INT21 | -           | User-defined software interrupt |
| 22 | 2Ch                | INT22 | -           | User-defined software interrupt |
| 23 | 2Eh                | INT23 | _           | User-defined software interrupt |

Table 6–2. 'C24x Interrupt Locations and Priorities

Interrupts

<sup>†</sup> The K value is the operand used in an INTR instruction that branches to the corresponding interrupt vector location.

#### PRELIMINARY

| <b>K</b> † | Vector<br>Location | Name  | Priority | Function                        |
|------------|--------------------|-------|----------|---------------------------------|
| 24         | 30h                | INT24 | -        | User-defined software interrupt |
| 25         | 32h                | INT25 | -        | User-defined software interrupt |
| 26         | 34h                | INT26 | -        | User-defined software interrupt |
| 27         | 36h                | INT27 | _        | User-defined software interrupt |
| 28         | 38h                | INT28 | -        | User-defined software interrupt |
| 29         | 3Ah                | INT29 | _        | User-defined software interrupt |
| 30         | 3Ch                | INT30 | _        | User-defined software interrupt |
| 31         | 3Eh                | INT31 | _        | User-defined software interrupt |

| Table 6–2   | 'C24x Interrupt | t Locations | and Priorities | (Continued) |
|-------------|-----------------|-------------|----------------|-------------|
| 1 abio 0 E. |                 | Looullon    |                |             |

<sup>†</sup> The K value is the operand used in an INTR instruction that branches to the corresponding interrupt vector location.

#### 6.3.1 Interrupt Operation: Three Phases

The 'C24x handles interrupts in three main phases:

- Receive interrupt request. Suspension of the main program must be requested by software (program code) or hardware (a pin or an on-chip device).
- 2) Acknowledge interrupt. The 'C24x must acknowledge the interrupt request. If the interrupt is maskable, certain conditions must be met in order for the 'C24x to acknowledge it. For nonmaskable hardware interrupts and for software interrupts, acknowledgment is immediate.
- 3) Execute interrupt service routine. Once the interrupt is acknowledged, the 'C24x branches to its corresponding subroutine, called an interrupt service routine (ISR). The 'C24x follows the branch instruction you place at a predetermined address (the vector location) and executes the ISR you have written.

#### 6.3.2 Nonmaskable Interrupt Operation

Hardware nonmaskable interrupts can be requested through two pins:

- □ RS (reset). This interrupt stops program flow, returns the processor to a predetermined state, and then begins program execution at address 0000h. For details of the reset operation, see Section 6.4, *Reset Operation*, on page 6-48.
- NMI. This interrupt is used as a soft reset. Unlike a hardware reset, NMI neither affects any of the modes of the device nor aborts a currently active instruction or memory operation. Although NMI uses the same logic as the maskable interrupts, it is not maskable. NMI happens regardless of the value of the INTM bit, and there is no mask bit for NMI. This interrupt can only be locked out by an already executing NMI or a reset. When NMI is activated (either by the NMI pin or by the NMI instruction), the processor switches program control to vector location 24h. In addition, maskable interrupts are disabled: the INTM bit of status register ST0 is set to 1.

Note that although  $\overline{\text{RS}}$  is always active low, NMI has programmable polarity. For more information, see subsection 6.3.11, *External Interrupt Control Registers*, on page 6-37.

*Software interrupts* (which are inherently nonmaskable) are requested by the following instructions:

- INTR. This instruction allows you to initiate any 'C24x interrupt, including user-defined interrupts INT8–INT16 and INT20–INT31. The instruction operand (K) indicates which interrupt vector location the CPU branches to. Table 6–2 (page 6-10) shows the operand K that corresponds to each vector location. When an INTR interrupt is acknowledged, the interrupt mode (INTM) bit of status register ST1 is set to 1 to disable maskable interrupts.
- NMI. This instruction forces a branch to interrupt vector location 24h, the same location used for the nonmaskable hardware interrupt NMI. Thus, you can either initiate NMI by driving the NMI pin active or by executing an NMI instruction. When the NMI instruction is executed, INTM is set to 1 to disable maskable interrupts.
- TRAP. This instruction forces the CPU to branch to interrupt vector location 22h. The TRAP instruction does not disable maskable interrupts (INTM is not set to 1); thus when the CPU branches to the interrupt service routine, that routine can be interrupted by the maskable hardware interrupts.

After acknowledging a nonmaskable interrupt, the CPU:

- 1) Stores the program counter (PC) value (the return address) to the top of the hardware stack.
- 2) Loads the PC with the address of the interrupt vector.
- 3) Fetches the branch instruction that you stored at the vector location.

If the interrupt was a hardware interrupt or was requested by either the INTR or NMI instructions, the CPU also sets the INTM bit to 1 to disable maskable interrupts.

- 4) Executes the branch, which leads it to the address of your ISR.
- 5) Executes the ISR until a return instruction concludes the ISR.

If INTM is 1, all maskable interrupts are disabled during the execution of the ISR.

- 6) Pops the return address off the stack and into the PC.
- 7) Continues executing the main program.

To determine which vector address has been assigned to each of the interrupts, refer to Table 6–2 (page 6-10). Each interrupt address has been spaced apart by two locations so that 2-word branch instructions can be accommodated in those locations.

#### 6.3.3 Maskable Interrupt Structure

The CPU provides six maskable interrupt levels. Because a 'C24x device can have more than six maskable interrupt sources, each of the six interrupt levels can be shared by multiple interrupt sources. Figure 6–5 illustrates the structure used for receiving and acknowledging maskable interrupts. The figure shows four interrupt sources (XINT1, XINT2, XINT3, and RTI) sharing the interrupt level INT1. A similar situation exists for the other levels (INT2–INT6).





#### Path of a Maskable Interrupt Request

Each of the interrupt sources has its own control register with a flag bit and a mask bit (see subsection 6.3.12, *Type A, Type B, and Type C Interrupt Pins*, on page 6-39). When an interrupt signal is received, the flag bit in the corresponding control register is set, indicating that the interrupt has been requested. If the mask bit is also set, a signal is sent to arbitration logic, which may simultaneously receive similar signals from one or more other control registers. The arbitration logic compares the priority level of competing interrupt requests, and it passes the interrupt of highest priority to the CPU. The interrupt flag in the CPU's IFR that corresponds to the interrupt priority level on which the request was received is set. This indicates that the interrupt is pending. If the corresponding IMR bit is 1 and the INTM bit is 0, the CPU acknowledges the interrupt and executes the interrupt service routine (ISR).

#### Priorities of the Maskable Interrupts

All hardware interrupts are given a priority rank from 1 to 10 (1 being highest). The priorities are shown in Table 6–2 on page 6-10. When more than one of these hardware interrupts is pending, the interrupt of highest rank gets serviced first. The others are serviced in priority order after that. The maskable interrupt levels of the DSP core have the priorities shown in Table 6–3.

| Table 6–3. Priorities of the Maskable Interrupt Levels in the DSP Col |
|-----------------------------------------------------------------------|
|-----------------------------------------------------------------------|

| Maskable Interrupt<br>Level | Priority in the<br>DSP Core |
|-----------------------------|-----------------------------|
| INT1                        | 4                           |
| INT2                        | 5                           |
| INT3                        | 6                           |
| INT4                        | 7                           |
| INT5                        | 8                           |
| INT6                        | 9                           |

As an example of how the priority ranking is carried out, suppose INT1 and INT2 were both pending and not masked. INT1 would be acknowledged first, followed by INT2.

Each maskable interrupt level (INT1–INT6) is connected to multiple maskable interrupt sources, which also have set priority ranks. The source with highest priority has its interrupt request sent to the interrupt level first. Consider the interrupt sources in the example in Figure 6–5: XINT1, XINT2, XINT3, and RTI. Suppose they have the priority ranks with respect to INT1 listed in Table 6–4.

Table 6-4. Priority Ranking Under INT1

| Maskable Interrupt<br>Source | Priority<br>Under INT1 |
|------------------------------|------------------------|
| XINT1                        | 1                      |
| XINT2                        | 2                      |
| XINT3                        | 3                      |
| RTI                          | 4                      |

If all these sources had generated interrupt requests at the same time, XINT1 would get serviced first, then XINT2, followed by XINT3, and finally RTI.

#### 6.3.4 CPU Interrupt Registers

There are two CPU registers for controlling interrupts:

- ☐ The interrupt flag register (IFR) contains flag bits that indicate when maskable interrupt requests have reached the CPU on levels INT1 through INT6.
- ☐ The interrupt mask register (IMR) contains mask bits that enable or disable each of the interrupt levels (INT1 through INT6).

#### Interrupt Flag Register (IFR)

The interrupt flag register (IFR), a 16-bit, memory-mapped register at address 0006h in data-memory space, is used to identify and clear pending interrupts. The IFR contains flag bits for all the maskable interrupts.

When a maskable interrupt is requested, the flag bit in the corresponding control register is set to 1. If the mask bit in that same control register is also 1, the interrupt request is sent to the CPU, setting the corresponding flag in the IFR. This indicates that the interrupt is pending or waiting for acknowledgement.

You can read the IFR to identify pending interrupts and write to the IFR to clear pending interrupts. To clear a single interrupt, write a 1 to the corresponding

IFR bit. All pending interrupts can be cleared by writing the current contents of the IFR back into the IFR. A device reset clears all IFR bits.

The following events also clear an IFR flag:

- The CPU acknowledges the interrupt.
- The 'C24x is reset.

#### Notes:

- 1) To clear an IFR bit, you must write a 1 to it, not a 0.
- 2) When a maskable interrupt is acknowledged, *only* the IFR bit is cleared automatically. The flag bit in the corresponding control register is *not* cleared. If an application requires that the control register flag be cleared, the bit must be cleared by software.
- 3) When an interrupt is requested by an INTR instruction and the corresponding IFR bit is set, the CPU does not clear the bit automatically. If an application requires that the IFR bit be cleared, the bit must be cleared by software.

The IFR is shown in Figure 6–6, and descriptions of the bits follow the figure.

#### Figure 6–6. Interrupt Flag Register (IFR) — Address 0006h

| 15–6     | 5       | 4       | 3       | 2       | 1       | 0       |
|----------|---------|---------|---------|---------|---------|---------|
| Reserved | INT6    | INT5    | INT4    | INT3    | INT2    | INT1    |
| 0        | R/W1C-0 | R/W1C-0 | R/W1C-0 | R/W1C-0 | R/W1C-0 | R/W1C-0 |

Note: 0 = Always read as zeros, R = Read access, W1C = Write 1 to this bit to clear it, -n = Value after reset

Bits 15–6 Reserved. These bits are always read as 0s.

- **Bit 5 INT6.** Interrupt 6 flag. This bit is the flag for interrupts connected to interrupt level INT6.
  - 0 = No INT6 interrupt is pending.
  - 1 = At least one INT6 interrupt is pending. Write a 1 to this bit to clear it to 0 and clear the interrupt request.
- **Bit 4 INT5.** Interrupt 5 flag. This bit is the flag for interrupts connected to interrupt level INT5.
  - 0 = No INT5 interrupt is pending.
  - 1 = At least one INT5 interrupt is pending. Write a 1 to this bit to clear it to 0 and clear the interrupt request.

| В | it 3  | <b>INT4.</b> Interrupt 4 flag. This bit is the flag for interrupts connected to interrupt level INT4.                                                                            |
|---|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       | <ul> <li>0 =No INT4 interrupt is pending.</li> <li>1 =At least one INT4 interrupt is pending. Write a 1 to this bit to clear it to 0 and clear the interrupt request.</li> </ul> |
| В | it 2  | <b>INT3.</b> Interrupt 3 flag. This bit is the flag for interrupts connected to interrupt level INT3.                                                                            |
|   |       | <ul> <li>0 =No INT3 interrupt is pending.</li> <li>1 =At least one INT3 interrupt is pending. Write a 1 to this bit to clear it to 0 and clear the interrupt request.</li> </ul> |
| В | iit 1 | <b>INT2.</b> Interrupt 2 flag. This bit is the flag for interrupts connected to interrupt level INT2.                                                                            |
|   |       | <ul> <li>0 =No INT2 interrupt is pending.</li> <li>1 =At least one INT2 interrupt is pending. Write a 1 to this bit to clear it to 0 and clear the interrupt request.</li> </ul> |
| В | it O  | <b>INT1.</b> Interrupt 1 flag. This bit is the flag for interrupts connected to interrupt level INT1.                                                                            |
|   |       | <ul> <li>0 =No INT1 interrupt is pending.</li> <li>1 =At least one INT1 interrupt is pending. Write a 1 to this bit to clear it to 0 and clear the interrupt request.</li> </ul> |

#### Interrupt Mask Register (IMR)

The IMR is a 16-bit, memory-mapped register located at address 0004h in data memory space. The IMR contains mask bits for all the maskable interrupt levels (INT1–INT6). Neither NMI nor  $\overline{\text{RS}}$  is included in the IMR; thus, IMR has no effect on these interrupts.

You can read the IMR to identify masked or unmasked interrupt levels, and you can write to the IMR to mask or unmask interrupt levels. To unmask an interrupt level, set its corresponding IMR bit to 1. To mask an interrupt level, set its corresponding IMR bit to 0. When an interrupt is masked, it is not acknowledged, regardless of the value of the INTM bit. When an interrupt is unmasked, it is acknowledged if the corresponding IFR bit is 1 and the INTM bit is 0. At reset, the IMR bits are all set to 0, masking all the maskable interrupts.

The IMR is shown in Figure 6–7, and descriptions of the bits follow the figure.

## PRELIMINARY

|       | 15–6                                                                        | 5                                                                                                                                                                                                                                                                                                                            | 4              | 3                | 2                 | 1     | 0     |  |  |
|-------|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|-------------------|-------|-------|--|--|
|       | Reserved                                                                    | INT6                                                                                                                                                                                                                                                                                                                         | INT5           | INT4             | INT3              | INT2  | INT1  |  |  |
|       | 0                                                                           | R/W–0                                                                                                                                                                                                                                                                                                                        | R/W–0          | R/W-0            | R/W-0             | R/W–0 | R/W-0 |  |  |
| Note: | 0 = Always read as ze                                                       | eros, R = Read a                                                                                                                                                                                                                                                                                                             | access, W = Wr | ite access, -n = | Value after reset |       |       |  |  |
|       | Bits 15–6                                                                   |                                                                                                                                                                                                                                                                                                                              |                |                  |                   |       |       |  |  |
|       | Bit 5                                                                       |                                                                                                                                                                                                                                                                                                                              |                |                  |                   |       |       |  |  |
|       |                                                                             | <ul> <li>0 = Level INT6 is masked.</li> <li>1 = Level INT6 is unmasked.</li> <li>INT5. Interrupt 5 mask. This bit masks or unmasks interrupt level INT5.</li> <li>0 = Level INT5 is masked.</li> <li>1 = Level INT5 is unmasked.</li> <li>INT4. Interrupt 4 mask. This bit masks or unmasks interrupt level INT4.</li> </ul> |                |                  |                   |       |       |  |  |
|       | Bit 4                                                                       |                                                                                                                                                                                                                                                                                                                              |                |                  |                   |       |       |  |  |
|       |                                                                             |                                                                                                                                                                                                                                                                                                                              |                |                  |                   |       |       |  |  |
|       | Bit 3                                                                       |                                                                                                                                                                                                                                                                                                                              |                |                  |                   |       |       |  |  |
|       |                                                                             | 0 =Level INT4 is masked.<br>1 =Level INT4 is unmasked.                                                                                                                                                                                                                                                                       |                |                  |                   |       |       |  |  |
|       | Bit 2 INT3. Interrupt 3 mask. This bit masks or unmasks interrupt level INT |                                                                                                                                                                                                                                                                                                                              |                |                  |                   |       |       |  |  |
|       |                                                                             | 0 =Level INT3 is masked.<br>1 =Level INT3 is unmasked.                                                                                                                                                                                                                                                                       |                |                  |                   |       |       |  |  |
|       | Bit 1                                                                       | it 1 INT2. Interrupt 2 mask. This bit masks or unmasks interrupt level INT2.                                                                                                                                                                                                                                                 |                |                  |                   |       |       |  |  |
|       |                                                                             | 0 =Level INT2 is masked.<br>1 =Level INT2 is unmasked.                                                                                                                                                                                                                                                                       |                |                  |                   |       |       |  |  |
|       | Bit 0                                                                       | <b>INT1.</b> Interrupt 1 mask. This bit masks or unmasks interrupt level INT1.                                                                                                                                                                                                                                               |                |                  |                   |       |       |  |  |
|       | 0 =Level INT1 is masked.<br>1 =Level INT1 is unmasked.                      |                                                                                                                                                                                                                                                                                                                              |                |                  |                   |       |       |  |  |

## Figure 6–7. Interrupt Mask Register (IMR) — Address 0004h

#### 6.3.5 Maskable Interrupt Acknowledgement and Servicing

After an interrupt has been requested by hardware or software, the CPU must decide whether to acknowledge the request. If the CPU acknowledges the interrupt, the CPU executes its ISR.

#### Acknowledging Maskable Interrupts

Software interrupts and nonmaskable hardware interrupts are acknowledged immediately. Maskable hardware interrupts are acknowledged only after certain conditions are met:

- □ Priority is highest. When more than one hardware interrupt is requested at the same time, the 'C24x services each interrupt according to a set priority ranking (see Table 6–2 on page 6-10).
- □ **INTM bit is 0.** The interrupt mode (INTM) bit, bit 9 of status register ST0, enables or disables all maskable interrupts:
  - When INTM = 0, all unmasked interrupts are enabled.
  - When INTM = 1, all maskable interrupts are disabled.

INTM is set to 1 automatically when the CPU acknowledges an interrupt (except when initiated by the TRAP instruction). INTM can also be set to 1 by a hardware reset or by execution of a disable-interrupts instruction (SETC INTM). INTM is reset to 0 by executing the enable-interrupts instruction (CLRC INTM). INTM has no effect on reset, NMI, or software-interrupts. Also, INTM is unaffected by the LST (load status register) instruction.

INTM does not modify the interrupt mask register (IMR) or the interrupt flag register (IFR).

□ **IMR mask bit is 1.** Each of the maskable interrupt levels has a mask bit in the IMR. To unmask an interrupt level, set its IMR bit to 1. For more details about the IMR, see *Interrupt Mask Register (IMR)* on page 6-18.

When the CPU acknowledges a maskable hardware interrupt, it jams the instruction bus with the INTR instruction. This instruction forces the PC to the appropriate address from which the CPU fetches the software vector.

#### Two-Part Interrupt Service Routine (ISR)

The 'C2xx CPU has six interrupt levels, but 'C24x devices provide a means of creating more than six ISRs. Figure 6–8 illustrates the process of servicing an interrupt request. For each of the six interrupt levels, the CPU branches to a corresponding general interrupt service routine (GISR). For example, when an interrupt request on priority level INT1 is responded to, the CPU branches to and executes GISR1. The GISR, after performing any necessary context saves, will identify and then branch to the specific interrupt service routine (SISR). The SISR performs the actions specific to the triggering interrupt and then returns program control to the interrupted program sequence.

#### Figure 6–8. Interrupt Service Routine Flow Chart



System Functions 6-21

Interrupts

**Branching to the GISR.** Table 6–5 shows the addresses and contents of the interrupt vector locations for the maskable interrupt levels (for a table of all the interrupt vector locations, see Table 6–2 on page 6-10). When an interrupt is acknowledged through one of these interrupt levels, the CPU branches to the corresponding vector address and follows the branch at that address to the GISR. For example, if an interrupt is acknowledged through INT3, the program counter (PC) value is stored to the stack, and then the PC is loaded with program-memory address 0006h. Locations 0006h and 0007h contain a branch instruction that takes the CPU to the GISR.

#### Table 6–5. 'C24x Maskable Interrupt Vector Table

| Interrupt<br>Level | Interrupt Vector<br>Location | Contents of<br>Vector Location |
|--------------------|------------------------------|--------------------------------|
| INT1               | 0002h                        | Branch to GISR1                |
| INT2               | 0004h                        | Branch to GISR2                |
| INT3               | 0006h                        | Branch to GISR3                |
| INT4               | 0008h                        | Branch to GISR4                |
| INT5               | 000Ah                        | Branch to GISR5                |
| INT6               | 000Ch                        | Branch to GISR6                |

**Branching to the SISR.** When a peripheral interrupt request is acknowledged (this includes the external interrupt control registers), the peripheral generates a vector address offset (vector) that corresponds to this interrupt event. This vector is usually latched in the system interrupt vector register (SYSIVR), although some peripherals, including the event manager, may keep the vector in a register in the peripheral. For details on the location of the interrupt vector register (IVR) for each interrupt level and also the vector value for each interrupt event, see the device data sheet. The GISR must read the value stored in the IVR and use it to generate the branch target address to the SISR. Several methods of doing this are described in subsection 6.3.8, *Additional Tasks of ISRs*, on page 6-31.

#### Interrupt Vectors

Table 6–6 shows an edited example of an interrupt vector table for a 'C24x device. Note that most peripherals use the system interrupt vector register (SYSIVR) to fetch the vector address offset, but the event manager has its own register for each of its three interrupt priority level requests:

- EVIVRA for interrupts in Group A
- EVIVRB for interrupts in Group B
- EVIVRC for interrupts in Group C

## PRELIMINARY

| Interrupt<br>Name | Overall<br>Priority | DSP-Core<br>Interrupt<br>and | Peripheral<br>Vector<br>Address | Peripheral<br>Vector<br>Address | Maskable? | Source                  | Function                                     |
|-------------------|---------------------|------------------------------|---------------------------------|---------------------------------|-----------|-------------------------|----------------------------------------------|
| RS                |                     | Address<br>RS                | N/A                             | Offset                          | No        | Pin, S/W,               | External,                                    |
| по                | Highest             |                              | N/A                             |                                 | INO       | Watchdog<br>Timer, etc. | system reset<br>(RESET)                      |
| RESERVED          | 2                   | 0026h                        | N/A                             | N/A                             | No        | Core                    | Emulator trap                                |
| NMI               | 3                   | NMI<br>0024h                 | N/A                             | N/A                             | No        | External<br>pin         | External<br>user interrupt                   |
| XINT1             | 4                   | INT1<br>0002h                | SYSIVR                          | 0002h                           | Yes       | External<br>pins        | High-priority<br>external user<br>interrupts |
| XINT2             | 5                   | (System)                     | 701Eh                           | 0011h                           |           | <b>PP</b>               |                                              |
| XINT3             | 6                   | (Oystem)                     |                                 | 001Fh                           |           |                         |                                              |
| RTI               | 10                  |                              |                                 | 0010h                           | Yes       | Watchdog<br>Timer       | Watchdog<br>timer<br>interrupt               |
| PDPINT            | 11                  | INT2<br>0004h                | EVIVRA<br>7432h                 | 0020h                           | Yes       | External<br>pin         | Power drive<br>protection<br>interrupt       |
|                   |                     | (EV INTA)                    |                                 |                                 |           |                         | monup                                        |
| CMP1INT           | 12                  | (Group A)                    |                                 | 0021h                           | Yes       | Event<br>Manager        | Compare 1<br>interrupt                       |
| etc.              |                     |                              |                                 |                                 |           |                         |                                              |
| TPINT2            | 22                  | INT3<br>0006h                | EVIVRB                          | 002Bh                           | Yes       | Event<br>Manager        | Timer 2<br>period                            |
|                   |                     | (EV INTB)                    | 7434h                           |                                 |           |                         | interrupt                                    |
| TCINT2            | 23                  | (Group B)                    |                                 | 002Ch                           | Yes       | Event<br>Manager        | Timer 2<br>compare<br>interrupt              |
| etc.              |                     |                              |                                 |                                 |           |                         |                                              |

Table 6–6. Example Interrupt Locations and Priorities

| Interrupt<br>Name | Overall<br>Priority | DSP-Core<br>Interrupt<br>and<br>Address | Peripheral<br>Vector<br>Address | Peripheral<br>Vector<br>Address<br>Offset | Maskable? | Source           | Function                                        |
|-------------------|---------------------|-----------------------------------------|---------------------------------|-------------------------------------------|-----------|------------------|-------------------------------------------------|
| CAPINT1           | 30                  | INT4<br>0008h<br>(EV INTC)              | EVIVRC<br>7431h                 | 0033h                                     | Yes       | Event<br>Manager | Capture 1<br>interrupt                          |
| CAPINT2           | 31                  | (Group C)                               |                                 | 0034h                                     | Yes       | Event<br>Manager | Capture 2 interrupt                             |
| CAPINT3           | 32                  |                                         |                                 | 0035h                                     | Yes       | Event<br>Manager | Capture 3<br>interrupt                          |
| CAPINT4           | 33                  |                                         |                                 | 0036h                                     | Yes       | Event<br>Manager | Capture 4<br>interrupt                          |
| etc.              |                     |                                         |                                 |                                           |           |                  |                                                 |
| ADCINT            | 37                  | INT6<br>000Ch<br>(System)               | SYSIVR<br>701Eh                 | 0004h                                     | Yes       | ADC              | Analog-to-<br>Digital<br>Converter<br>interrupt |
| XINT1             | 38                  |                                         |                                 | 0002h                                     | Yes       | External         | Low-priority                                    |
| XINT2             | 39                  |                                         |                                 | 0011h                                     | Yes       | pins             | external user<br>interrupts                     |
| XINT3             | 40                  |                                         |                                 | 001Fh                                     | Yes       |                  |                                                 |
| RESERVED          | 41                  | -<br>000Eh                              | N/A                             |                                           | Yes       | DSP core         | Used for<br>analysis                            |
| TRAP              | N/A                 | –<br>0022h                              | N/A                             |                                           | N/A       |                  | TRAP<br>instruction<br>vector                   |

| Tahla 6_6 | Example Interrupt I | l ocations and | Priorities | (Continued) |
|-----------|---------------------|----------------|------------|-------------|
|           |                     | Localions and  | FIIUIIIIES | (COULINED)  |

#### Phantom Interrupt Vector

The phantom interrupt vector is an interrupt system-integrity feature. In the event that an interrupt is acknowledged but no peripheral responds by loading an interrupt vector address offset value into the interrupt vector register (IVR), the phantom vector (0000h) is loaded into the IVR instead so that this fault can be handled in a controlled manner.

Two causes of phantom interrupts are:

- Execution of the INTR instruction with an argument in the range of 1 to 6. This is a software request to service one of the six maskable interrupt levels (INT1, INT2, INT3, INT4, INT5, or INT6).
- A glitch on an interrupt request line.

In either case, when the interrupt is acknowledged, no peripheral loads a vector into the IVR. Loading the IVR with the phantom interrupt vector ensures that the DSP branches to a known location.

# 6.3.6 Programming ISRs for Maskable Interrupts

This subsection lists three methods for creating an interrupt service routine (ISR) for a maskable interrupt:

- Method 1: A typical ISR
- Method 2: An ISR that is designed to reduce the latency between the time the interrupt is requested and the time the event-specific portion of the ISR is executed
- Method 3: An ISR that has very little latency. It can be used only if one peripheral interrupt source is connected to an interrupt request priority level or if only one of many interrupt sources connected to an interrupt request priority level is enabled.

# Method 1: Typical ISR

The method described here is the typical implementation of an ISR for the 'C24x. Methods 2 and 3, described below are slightly more difficult to program. It is best to implement this typical ISR first and then develop a more complex routine if the latency for certain events is too high.

In Method 1, the ISR for a maskable interrupt is divided into two segments:

- General ISR (GISR). When an interrupt on one of the six maskable interrupt levels (INT1–INT6) is acknowledged, the GISR reads the relevant interrupt vector register (IVR), shifts the value left by one bit, adds an offset to the value, and then branches to a peripheral interrupt vector table. From this table, it fetches and executes the appropriate branch to the specific ISR (SISR).
- Specific ISR (SISR). The SISR performs actions specific to the event that caused the interrupt and then returns program control to the interrupted code sequence.

Table 6–7 shows an example of Method 1.

| Cycle<br>Count | Address          | Assem  | bly Language Code |                                                                                           |
|----------------|------------------|--------|-------------------|-------------------------------------------------------------------------------------------|
|                |                  | ;CPU i | nterrupt vector   | table                                                                                     |
|                |                  |        | •••               |                                                                                           |
| 0              | 0006h            | INT3   | В                 | ;Branch to address of general ISR                                                         |
|                | 0007h            |        | GISR3             | ; for INT3.                                                                               |
|                |                  |        |                   |                                                                                           |
| 4              | GISR3 Addr       | GISR3  | LACC xIVR,1       | ;Load accumulator with<br>;contents of interrupt vector<br>;register (xIVR) shifted by 1. |
| 4+n†           | GISR3 Addr+1     |        | ADD offset        | ;Add offset to accumulator.                                                               |
| 5+n†           | GISR3 Addr+2     |        | BACC              | ;Branch to address in accumulator ;(2*IVR+offset).                                        |
|                |                  |        |                   |                                                                                           |
|                |                  | ;Perip | oheral interrupt  | vector table                                                                              |
|                |                  |        | •••               |                                                                                           |
| 9+n†           | 2*IVR+offset     |        | В                 | ;Branch to specific ISR for                                                               |
|                | (2*IVR+offset)+1 |        | SISRx             | ; event that requested interrupt.                                                         |
|                |                  |        |                   |                                                                                           |
| 13+n†          | SISRx Addr       | SISRx  |                   | ;Perform event-specific actions.                                                          |
|                | SISRx Addr+1     |        |                   | ;                                                                                         |
|                |                  |        |                   | ;                                                                                         |
|                | SISRx Addr+n     |        | RET               | ;Return from ISR.                                                                         |

Table 6–7. Example of Method 1 ISR

<sup>†</sup> For the peripheral interface, n = 2; for the event manager, n = 1

In the example, the following events take place:

- 1) An acknowledged peripheral interrupt asserts INT3 and causes the device to enter its interrupt vector table at address 0006h.
- 2) From addresses 0006h and 0007h, the device reads a branch that leads it to GISR3.
- 3) GISR3 loads the accumulator with the contents of the relevant IVR shifted by 1 (that is, multiplied by 2). Note the following:
  - ☐ The LACC instruction uses direct addressing to access the IVR value. For this to work, the data page pointer (DP in status register ST0) must be set to point to the page in data memory that contains the IVR.

- You may want to save the accumulator value before loading the accumulator with the shifted IVR value.
- The incoming vector has been multiplied by two because a peripheral interrupt vector table must support a 2-word branch instruction for each peripheral interrupt.
- GISR3 adds to the accumulator an offset that corresponds to the start of the peripheral interrupt vector table. The accumulator now contains the address that needs to be accessed in the peripheral interrupt vector table.
- 5) GISR3 branches to the address in the accumulator.
- 6) From the peripheral interrupt vector location, the device reads a branch that leads to the SISR for the event that requested the interrupt.
- 7) The SISR is executed. The SISR concludes with a return instruction, which returns program control to the interrupted code sequence.

# Method 2: Minimum Latency ISR for Multiple Events per Interrupt Level

This method is similar to Method 1, but has reduced latency because one of the branches (the branch to the peripheral interrupt vector table) is bypassed. Instead, the general ISR (GISR) branches directly to the specific ISR (SISR) To do this, the GISR shifts the value from the IVR by more than 2 and uses the result as the branch target. It may be difficult to locate all the SISRs in program space without leaving some holes in memory. It is best to use Method 1 initially and then Method 2 for some interrupts if the higher latency of Method 1 is unacceptable.

The Method 2 ISR is implemented as follows:

- General ISR (GISR). When an interrupt on one of the six maskable interrupt levels (INT1–INT6) is acknowledged, the GISR reads the relevant interrupt vector register (IVR), shifts the value left by a predetermined amount, and then branches to the specific ISR (SISR). The shift amount is chosen such that the accumulator will contain the address of the SISR. For example, if three interrupt sources were tied to INT2, and the SISR for each of the events were not greater than 16 words long, then a shift of 4 would be suitable.
- Specific ISR (SISR). The SISR performs actions specific to the event that caused the interrupt and then returns program control to the interrupted code sequence.

Table 6–8 shows an example of Method 2.

| Cycle<br>Count | Address      | Assem                       | bly Language Code |                                                                                                                                                            |  |  |  |
|----------------|--------------|-----------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                |              | ;CPU interrupt vector table |                   |                                                                                                                                                            |  |  |  |
|                |              |                             | •••               |                                                                                                                                                            |  |  |  |
| 0              | 0004h        | INT2                        | В                 | ;Branch to GISR                                                                                                                                            |  |  |  |
|                | 0005h        |                             | GISR2             | ;for INT2.                                                                                                                                                 |  |  |  |
|                |              |                             |                   |                                                                                                                                                            |  |  |  |
| 4              | GISR2 Addr   | GISR2                       | LACC xIVR, shift  | ;Load accumulator with<br>;contents of interrupt vector<br>;register (xIVR) shifted by<br>;an amount that will result in<br>;SISRx address in accumulator. |  |  |  |
| 4+n†           | GISR2 Addr+1 |                             | BACC              | ;Branch to address in ;accumulator.                                                                                                                        |  |  |  |
|                |              |                             |                   |                                                                                                                                                            |  |  |  |
| 8+n†           | SISRx Addr   | SISRx                       |                   | ;Perform event-specific actions.                                                                                                                           |  |  |  |
|                | SISRx Addr+1 |                             |                   | ;                                                                                                                                                          |  |  |  |
|                |              |                             |                   | ;                                                                                                                                                          |  |  |  |
|                | SISRx Addr+n |                             | RET               | ;Return from ISR.                                                                                                                                          |  |  |  |

Table 6–8. Example of Method 2 ISR

<sup>†</sup> For the peripheral interface, n = 2; for the event manager, n = 1.

In the example, the following events take place:

- 1) An acknowledged peripheral interrupt asserts INT2 and causes the device to enter it's interrupt vector table at address 0004h.
- 2) From addresses 0004h and 0005h, the device reads a branch that leads it to GISR2.
- GISR2 loads the accumulator with the contents of the relevant IVR shifted by an amount that results in the accumulator's holding the address of the SISR. Note the following:
  - ☐ The LACC instruction uses direct addressing to access the IVR value. For this to work, the data page pointer (DP in status register ST0) must be set to point to the page in data memory that contains the IVR.
  - ☐ You may want to save the accumulator value before loading the accumulator with the shifted IVR value.

- GISR2 branches to the address in the accumulator (the start address of the SISR).
- 5) The SISR is executed. The SISR concludes with a return instruction, which returns program control to the interrupted code sequence.

# Method 3: ISR for Single Event per Interrupt Level

A device can be configured such that only one event can assert a particular maskable interrupt.

**Either:** Both of these conditions must be met:

- Only one peripheral is connected to the maskable interrupt level (INT1, INT2, INT3, INT4, INT5, or INT6).
- That one peripheral has only one event that can cause an interrupt request (and, thus, has only one interrupt vector).

**Or:** Only one of the many events tied to a particular interrupt priority level would be enabled.

In either situation, there is no need for a 2-part ISR like the one in Method 1 or the one in Method 2. There is one simple ISR and, thus, only one branch instruction. The address of the ISR is known; it does not have to be calculated in a routine. The GISR and the SISR become one and the same.

Table 6–9 shows an example of Method 3. In the example, the following events take place:

- 1) An acknowledged peripheral interrupt asserts INT1 and causes the device to enter its interrupt vector table at address 0002h.
- From addresses 0002h and 0003h, the device reads a branch that leads it directly to the SISR.
- The SISR is executed and concludes with a return instruction, which returns program control to the interrupted code sequence.

| Cycle<br>Count | Address      | Assem | bly Language Code |                                  |
|----------------|--------------|-------|-------------------|----------------------------------|
|                |              | ;CPU  | interrupt vector  | table                            |
|                |              |       |                   |                                  |
| 0              | 0002h        | INT1  | В                 | ;Branch to ISR1.                 |
|                | 0003h        |       | ISR1              |                                  |
|                |              |       |                   |                                  |
| 4              | SISRx Addr   | ISR1  |                   | ;Perform event-specific actions. |
|                | SISRx Addr+1 |       |                   | ;                                |
|                |              |       |                   | ;                                |
|                | SISRx Addr+n |       | RET               | ;Return from ISR.                |

Table 6–9. Example of Method 3 ISR

# 6.3.7 Programming an ISR for Nonmaskable Interrupt (NMI)

Generally, there cannot be more than one event capable of generating an NMI request, and in cases where they do, they all share the same ISR. Thus, NMI does not require loading an interrupt vector register (IVR), and the branch at vector location 24h is the only branch necessary for the ISR.

An NMI can interrupt a maskable ISR after the vector has been loaded into the IVR but before the maskable ISR has read the IVR. Because NMI does not cause a loading of the IVR, an NMI does not cause overwriting of the maskable interrupt's vector address offset. However, an enabled interrupt immediately following the NMI ISR could overwrite the value in the IVR before the interrupted ISR has read it. Therefore, the ISR for NMI must check the VECRD bit (bit 0) in the system status register (SSR). If VECRD = 1, a read of the IVR is pending, and the NMI ISR should not reenable maskable interrupts.

The ISR for NMI could be implemented as shown in Table 6–10.

| Address      | Assembly | Languag | e Code          |                                     |
|--------------|----------|---------|-----------------|-------------------------------------|
|              | ; CPU in | terrupt | vector ta       | ble                                 |
|              |          | •••     |                 |                                     |
| 0024h        | NMI      | В       |                 | ;Branch to NMI ISR.                 |
| 0025h        |          | NMI_I   | SR              |                                     |
|              |          |         |                 |                                     |
| NMI ISR Addr | NMI_ISR  |         |                 | ;Start of ISR                       |
|              |          |         |                 | ;Body of ISR                        |
|              |          | BIT     | SSR <b>,</b> 15 | ;Test bit 0 (VECRD) of SYSSR0       |
|              |          | RETC    | TC              | ;If set, return from ISR            |
|              |          |         |                 | ;(without enabling interrupts)      |
|              |          | CLRC    | INTM            | ; If not set, enable interrupts and |
|              |          | RET     |                 | ;return from ISR.                   |

Table 6–10. One Implementation of an ISR for NMI

# 6.3.8 Additional Tasks of ISRs

While performing the tasks requested by an interrupt, the ISR may also be:

- Saving and restoring register values
- Managing ISRs within ISRs

## Saving and Restoring Register Values

Only the incremented program counter value is stored automatically before the CPU enters an ISR. You must design the ISR to save and then restore any other important register values or control bit values. You can use a common routine or routines individualized for each interrupt to secure the context of the processor during interrupt processing.

You can manage stack storage as long as the stack does not exceed the memory space. This stack is also used for subroutine calls; the 'C24x supports subroutine calls within the ISR. The PSHD and POPD instructions can transfer data-memory values to and from the stack.

# Managing ISRs Within ISRs

The 'C24x hardware stack allows you to have ISRs within ISRs. When considering nesting ISRs like this, keep the following in mind:

- If you want the ISR to be interrupted by a maskable interrupt, the ISR must unmask the interrupt by setting the appropriate individual mask bit and the appropriate IMR bit and globally reenabling interrupts by clearing the INTM bit (CLRC INTM).
- The appropriate interrupt vector register must have been read by the GISR to obtain the vector address offset before globally reenabling interrupts. Otherwise, a subsequent interrupt can cause the old vector value to be overwritten.
- The hardware stack is limited to eight levels. Each time an interrupt is serviced or a subroutine is entered, the return address is pushed onto the hardware stack. This provides a way to return to the previous context after the interrupt service routine. The stack contains eight locations, allowing interrupts or subroutines to be nested up to eight levels deep. (One level of the stack is reserved for debugging, to be used for break-point/single-step operations. If debugging is not used, this extra level is available for internal use.) If your software requires more than eight levels of stack, you can use the POPD and PSHD instructions to extend the stack into data memory.
- If you do not nest ISRs, you can avoid stack overflow. The 'C24x has a feature that allows you to prevent unintentional nesting. If an interrupt occurs during the execution of a CLRC INTM instruction, the device always completes CLRC INTM as well as the following instruction before the pending interrupt is processed. This ensures that a return (RET) placed immediately after the CLRC INTM can be executed before the next interrupt is processed. The processor removes the previous return address from the stack before it adds the new return address.
- If you want an ISR to occur within the current ISR rather than after the current ISR, place the CLRC INTM instruction more than one instruction before the return (RET) instruction.

#### 6.3.9 Interrupt Latency

The length of an interrupt latency—the delay between when an interrupt request is made and when it is serviced—depends on many factors. This subsection describes the factors that determine minimum latency and then describes factors that may cause additional latency. The maximum latency is a function of wait states and pipeline protection.

There are several components to interrupt latency on the 'C24x:

- Peripheral interface synchronization time
- CPU response time
- ISR branching time

#### Peripheral Interface Synchronization Time

Peripheral Interface synchronization time is the time it takes for the interrupt request from the peripheral to be recognized by the peripheral interface, arbitrated and converted into a request to the DSP. This takes up to one SYSCLK cycle for internal interrupts from on-chip peripherals (peripheral bus operates at the SYSCLK rate); in other words, in divide-by-two clock mode, *two* CPUCLK cycles, in divide-by-four mode, *four* CPUCLK cycles. External interrupts (NMI, INTx) have a two-SYSCLK-cycle synchronization delay.

Interrupt requests from the event manager peripheral are not arbitrated by the peripheral interface; there is a one-CPUCLK-cycle delay for the CPU to recognize the interrupt.

#### CPU Response Time

CPU response time is the time it takes for the CPU to recognize the enabled interrupt request, acknowledge the interrupt, clear its pipeline, and begin retrieving the first instruction from the CPU's interrupt vector table. The minimum CPU latency is *four* CPUCLK cycles. If a higher priority maskable interrupt is requested during this minimum latency period, it is masked until the ISR for the interrupt being serviced is completed. NMIs are not maskable and are serviced before the current ISR is completed.

Latency is longer if the interrupt request occurs during multicycle operations or other operations that cannot be interrupted. If a higher priority interrupt occurs during this additional latency period, it is serviced before the original lower priority interrupt, assuming both are enabled.

Here are details about the effects of multicycle instructions:

- Memory access using wait states. An instruction that writes to or reads from external memory may be delayed by wait states caused by the external READY pin or the on-chip wait-state generator. These wait states may affect the instruction being executed at the time the interrupt is requested, and they may affect the interrupt itself if the interrupt vector must be fetched from external memory.
- Repeat loop. When repeated with RPT, instructions run parallel operations in the pipeline, and the context of these additional parallel operations cannot be saved in an interrupt service routine. To protect the context of the repeated instruction, the CPU locks out all interrupts except reset until the RPT loop completes.

#### Note:

Reset ( $\overline{RS}$ ) is not delayed by multicycle instructions. An NMI can be delayed by multicycle instructions.

If one interrupt is being serviced, there are other factors that delay the servicing of a new interrupt:

- A return address (incremented program counter value) is forced onto the hardware stack every time the CPU follows another interrupt service routine or other subroutine. The 'C24x has a feature that helps you keep the hardware stack from overflowing. Interrupts cannot be processed between the CLRC INTM (enable maskable interrupts) instruction and the next instruction in a program sequence. This ensures that a return instruction that directly follows CLRC INTM is executed before an interrupt is processed. The return instruction pops the previous return address off the top of the stack before the new return address is pushed onto the stack. If the interrupt were to occur before the return, the new return address would be added to the hardware stack, even if the stack were already full.
- Interrupts are also blocked after a RET instruction until at least one instruction at the return address is executed.

#### ISR Branching Time

ISR branching time is the time it takes to execute all the necessary branches to get to the event-specific portion of the ISR. This length of time varies depending on how you have implemented the ISR. For the simplest situation in which only one branch to the ISR is required, the minimum branching time is four DSP cycles. See subsection 6.3.8, *Additional Tasks of ISRs*, on page 6-31 for three different methods of implementing ISRs for maskable interrupts.

# 6.3.10 Summary of Interrupt Operation

Once an interrupt has been passed to the CPU, the CPU operates in the following manner (see Figure 6–9):

☐ If a maskable interrupt is requested:

- 1) The flag bit in the individual control register is set. If the individual mask bit is also set, the corresponding IFR bit is set.
- 2) Once the IFR bit is set, the acknowledgement conditions (INTM bit = 0 and IMR bit = 1) are tested. If the conditions are true, the CPU services the interrupt, generating an interrupt acknowledge signal; otherwise, it ignores the interrupt and continues with the current code sequence.
- 3) When the interrupt has been acknowledged, the IFR bit is cleared to 0 and the INTM bit is set to 1 (to block other maskable interrupts). The flag bit in the corresponding control register is *not* cleared.
- 4) The return address (incremented PC value) is saved on the stack.
- 5) The CPU branches to and executes the interrupt service routine (ISR). The ISR is concluded by a return instruction, which pops the return address off the stack. The CPU continues with the interrupt code sequence.
- □ If a nonmaskable interrupt is requested:
  - 1) The CPU immediately acknowledges the interrupt, generating an interrupt acknowledge signal.

#### Note:

When an interrupt is requested by an INTR instruction and the corresponding IFR bit is set, the CPU does not clear the bit automatically. If an application requires that the IFR bit be cleared, the bit must be cleared by software.

- 2) If the interrupt was requested by the RS pin, the NMI pin, the NMI instruction, or the INTR instruction, the the INTM bit is set to 1 to block maskable hardware interrupts. If the interrupt was requested by the TRAP instruction, the INTM bit is *not* set to 1.
- 3) The return address (incremented PC value) is saved on the stack.
- 4) The CPU branches to and executes the ISR. The ISR is concluded by a return instruction, which pops the return address of the stack. The CPU continues with the interrupted code sequence.



Figure 6–9. Interrupt Operation Flow Chart

# 6.3.11 External Interrupt Control Registers

A 'C24x device has up to six external interrupt pins with software programmable polarity and, in most cases, priority. These pins are programmed using Type A, B, and C interrupt control registers. Up to 14 additional interrupt pins can be supported using the two power module interrupt registers. In some 'C24x device configurations, the power module control registers may be used to generate interrupts in response to events occurring in certain peripherals. In all cases, refer to the device data sheet for details about the implementation of external interrupts on a particular 'C24x device.

There are three types of external interrupts: Type A, Type B, and Type C. A device will typically have two of each type, although they may not all be used. The actual number and type of external interrupt pins is dependent upon the device configuration. Figure 6–10 shows the available external interrupt control registers, including the Power Module interrupt registers.

| Address | Register                    |                                |                       |                       |          |                |                         |                    |                  |
|---------|-----------------------------|--------------------------------|-----------------------|-----------------------|----------|----------------|-------------------------|--------------------|------------------|
|         |                             | 15                             | 14                    | 13                    | 12       | 11             | 10                      | 9                  | 8                |
|         |                             | XINTA1<br>Flag                 |                       |                       | Re       | eserve         | d                       |                    |                  |
| 7070h   | XINTA1CR<br>(Type A)        | 7                              | 6                     | 5                     | 4        | 3              | 2                       | 1                  | 0                |
|         |                             | Res                            | XINTA1<br>Pin data    | XINTA1<br>NMIT        | Rese     | rved           | XINTA1<br>Polarity      | XINTA1<br>Priority | XINTA1<br>Enable |
|         |                             | † This bit is fixed            | 1 at logic 0, which   | h means a pin o<br>13 | connecte | ed to th<br>11 | nis register cann<br>10 | ot generati<br>9   | e an NMI.<br>8   |
| 7072h   |                             | XINTA–NMI<br>Flag              |                       |                       | Re       | eserve         | d                       |                    |                  |
|         | XINTA–NMICR<br>(Type A–NMI) | 7                              | 6                     | 5                     | 4        | 3              | 2                       | 1                  | 0                |
|         |                             | Res                            | XINTA–NMI<br>Pin data | XINTA-NMI<br>NMI†     | Rese     | rved           | XINTA–NMI<br>Polarity   | Rese               | erved            |
|         |                             | <sup>†</sup> This bit is fixed | at logic 1, which     | means a pin c         | onnecte  | d to thi       | s register can o        | nlv generat        | e an NML         |

Figure 6–10. External Interrupt Control Registers

<sup>†</sup> This bit is fixed at logic 1, which means a pin connected to this register can *only* generate an NMI.

# Interrupts

| Address | Register             |                |                    |               |                    |                    |                    |                    |                  |
|---------|----------------------|----------------|--------------------|---------------|--------------------|--------------------|--------------------|--------------------|------------------|
|         |                      | 15             | 14                 | 13            | 12                 | 11                 | 10                 | 9                  | 8                |
|         |                      | XINTB1<br>Flag |                    |               |                    | Reserved           |                    |                    |                  |
| 7074h   | XINTB1CR<br>(Type B) | 7              | 6                  | 5             | 4                  | 3                  | 2                  | 1                  | 0                |
|         | (Type D)             | Res            | XINTB1<br>Pin data | XINTB1<br>NMI | XINTB1<br>Data dir | XINTB1<br>Data out | XINTB1<br>Polarity | XINTB1<br>Priority | XINTB1<br>Enable |
|         |                      | 15             | 14                 | 13            | 12                 | 11                 | 10                 | 9                  | 8                |
|         | XINTB2CR<br>(Type B) | XINTB2<br>Flag |                    |               |                    | Reserved           |                    |                    |                  |
| 7076h   |                      | 7              | 6                  | 5             | 4                  | 3                  | 2                  | 1                  | 0                |
|         |                      | Res            | XINTB2<br>Pin data | XINTB2<br>NMI | XINTB2<br>Data dir | XINTB2<br>Data out | XINTB2<br>Polarity | XINTB2<br>Priority | XINTB2<br>Enable |
|         |                      | 15             | 14                 | 13            | 12                 | 11                 | 10                 | 9                  | 8                |
|         |                      | XINTC1<br>Flag |                    |               |                    | Reserved           |                    |                    |                  |
| 7078h   | XINTC1CR             | 7              | 6                  | 5             | 4                  | 3                  | 2                  | 1                  | 0                |
|         | (Type C)             | Res            | XINTC1<br>Pin data | Res           | XINTC1<br>Data dir | XINTC1<br>Data out | XINTC1<br>Polarity | XINTC1<br>Priority | XINTC1<br>Enable |

# Figure 6–10. External Interrupt Control Registers (Continued)

# PRELIMINARY

Register

Address

| Addic33 | ricgister            |                  |                    |                  |                    |                    |                    |                    |                  |
|---------|----------------------|------------------|--------------------|------------------|--------------------|--------------------|--------------------|--------------------|------------------|
|         |                      | 15               | 14                 | 13               | 12                 | 11                 | 10                 | 9                  | 8                |
|         |                      | XINTC2<br>Flag   |                    |                  |                    | Reserved           |                    |                    |                  |
| 707Ah   | XINTC2CR<br>(Type C) | 7                | 6                  | 5                | 4                  | 3                  | 2                  | 1                  | 0                |
|         |                      | Res              | XINTC2<br>Pin data | Res              | XINTC2<br>Data dir | XINTC2<br>Data out | XINTC2<br>Polarity | XINTC2<br>Priority | XINTC2<br>Enable |
|         |                      | 15               | 14                 | 13               | 12                 | 11                 | 10                 | 9                  | 8                |
|         |                      | PMINT1<br>Flag   | PM INT<br>STS 13   | PM INT<br>STS 12 | PM INT<br>STS 11   | PM INT<br>STS 10   | PM INT<br>STS 9    | PM INT<br>STS 8    | PM INT<br>STS 7  |
| 707Ch   | PMINT1CR             | 7                | 6                  | 5                | 4                  | 3                  | 2                  | 1                  | 0                |
|         |                      | PMINT1<br>Enable | PM INT<br>ENA 13   | PM INT<br>ENA 12 | PM INT<br>ENA 11   | PM INT<br>ENA 10   | PM INT<br>ENA 9    | PM INT<br>ENA 8    | PM INT<br>ENA 7  |
|         |                      | 15               | 14                 | 13               | 12                 | 11                 | 10                 | 9                  | 8                |
|         |                      |                  |                    | 1                |                    |                    |                    |                    |                  |
|         |                      | PMINT2<br>Flag   | PM INT<br>STS 6    | PM INT<br>STS 5  | PM INT<br>STS 4    | PM INT<br>STS 3    | PM INT<br>STS 2    | PM INT<br>STS 1    | PM INT<br>STS 0  |
| 707Eh   | PMINT2CR             | 7                | 6                  | 5                | 4                  | 3                  | 2                  | 1                  | 0                |
|         |                      | PMINT2           | PM INT             | PM INT           | PM INT             | PM INT             | PM INT             | PM INT             | PM INT           |

# Figure 6–10. External Interrupt Control Registers (Continued)

# 6.3.12 Type A, Type B, and Type C Interrupt Pins

Enable

ENA 6

Table 6–11 summarizes the external interrupt pin types. Note the following:

ENA 3

ENA 2

ENA 1

ENA 0

ENA 4

Type A interrupt pins allow for digital input only.

ENA 5

- One Type A pin is a maskable interrupt pin, the other is a nonmaskable interrupt pin.
- Type B pins can be programmed as maskable or nonmaskable interrupts.
- Type C inputs can only be maskable.
- Type B and Type C interrupt pins can be used as digital input or output.

# PRELIMINARY

System Functions 6-39

- All three types can be active on rising or falling edges; the polarity is programmable.
- □ All three types of interrupts can be configured for low or high priority interrupt requests.
- All interrupt pins are configured to digital inputs on reset.

| Table 6–11. | External Interrupt Pin Types |  |
|-------------|------------------------------|--|
|             |                              |  |

| Pin Type     | NMI Capability?    | Number Available | Digital I/O |
|--------------|--------------------|------------------|-------------|
| Type A – NMI | Yes – hardwired    | 1                | Input only  |
| Туре А       | No – hardwired     | 1                | Input only  |
| Туре В       | Yes – programmable | 2                | I/O         |
| Туре С       | No                 | 2                | I/O         |

# Type A Interrupt Pins

Type A interrupt pins can be used as nonmaskable interrupts, normal maskable interrupts, or digital input pins. Type A control registers have the general form shown in Figure 6–11.

Figure 6–11. Type A Interrupt Control Register

| 15           | 14–7     | 6                | 5           | 4–3      | 2                | 1                | 0              |
|--------------|----------|------------------|-------------|----------|------------------|------------------|----------------|
| INTx<br>Flag | Reserved | INTx<br>Pin data | INTx<br>NMI | Reserved | INTx<br>Polarity | INTx<br>Priority | INTx<br>Enable |
| R/C-0        |          | R–p              | R–x         |          | R/W-0            | R/W-0            | R/W-0          |

Note: R = Read access, W = Write access, C = Clear-only write access, -n = Value after reset (x means value unchanged by reset), -p = Logic level of pin

- Bit 15 INTx Flag. Interrupt x flag. This read/clear bit indicates whether the selected transition has been detected on the pin for interrupt x. This bit is set whether or not the interrupt is enabled. You can use this bit for software polling to see if the selected edge has occurred. This bit is cleared by software or a system reset. This bit need not be cleared when this pin is used as an interrupt; the interrupt occurs once for each selected edge on the interrupt pin, even though this bit is already set. Clearing this bit, however, clears a pending request from the pin.
  - 0 = No transition detected
  - 1 = Transition detected

Bits 14–7 Reserved. Reads are undefined; writes have no effect.

| Bit 6    | <b>INTx Pin data.</b> Interrupt pin data bit. This read-only bit reflects the current level on the interrupt pin, regardless of how the interrupt pin is configured.                                                                                                                                                    |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 0 =Pin is a logic 0<br>1 =Pin is a logic 1                                                                                                                                                                                                                                                                              |
| Bit 5    | <b>INTx NMI.</b> Nonmaskable interrupt enable bit. This read-only bit determines whether this pin can generate a nonmaskable interrupt. On most 'C24x devices, one Type A interrupt register has this bit hardwired to a logic 0 level; the other register has this bit hardwired to a logic 1 level.                   |
|          | <ul> <li>0 = Pin is for a regular interrupt or a digital input</li> <li>1 = Pin is for a nonmaskable interrupt</li> </ul>                                                                                                                                                                                               |
| Bits 4–3 | Reserved. Reads are undefined; writes have no effect.                                                                                                                                                                                                                                                                   |
| Bit 2    | <b>INTx Polarity.</b> Interrupt polarity bit. This read/write bit determines whether interrupts are generated on the rising edge or the falling edge of a signal on the pin.                                                                                                                                            |
|          | <ul> <li>0 = Interrupt generated on a falling edge (high to low transition)</li> <li>1 = Interrupt generated on a rising edge (low to high transition)</li> </ul>                                                                                                                                                       |
| Bit 1    | <b>INTx Priority.</b> Interrupt priority bit. This read/write bit determines which interrupt priority is requested. This bit has no effect if the NMI bit is set. See the device data sheet for details about which interrupt level corresponds to high priority and which interrupt level corresponds to low priority. |
|          | 0 = High priority<br>1 = Low priority                                                                                                                                                                                                                                                                                   |
| Bit 0    | <b>INTx Enable.</b> Interrupt enable bit. This read/write bit enables or disables the maskable interrupt. This bit has no effect if the NMI bit is set.                                                                                                                                                                 |
|          | <ul><li>0 = Disable interrupt (use pin as digital input)</li><li>1 = Enable interrupt</li></ul>                                                                                                                                                                                                                         |

# Type B Interrupt Pins

Type B interrupt pins can be used as nonmaskable interrupts, normal interrupts, digital output or digital input pins. The general form for a Type B control registers is shown in Figure 6–12.

Figure 6–12. Type B Interrupt Control Register

| 15           | 14–7     | 6                | 5           | 4                | 3                | 2                | 1                | 0              |
|--------------|----------|------------------|-------------|------------------|------------------|------------------|------------------|----------------|
| INTx<br>Flag | Reserved | INTx<br>Pin data | INTx<br>NMI | INTx<br>Data dir | INTx<br>Data out | INTx<br>Polarity | INTx<br>Priority | INTx<br>Enable |
| R/C0         |          | R–p              | R/W-0       | R/W-0            | R/W-0            | R/W-0            | R/W-0            | R/W-0          |

Note: R = Read access, W = Write access, C = Clear-only write access, -n = Value after reset, -p = Logic level of pin

- **Bit 15 INTx Flag.** Interrupt flag. This read/clear bit indicates if the selected transition has been detected. This bit is set whether or not the interrupt is enabled. You can use this bit for software polling to see if the selected edge has occurred. This bit can only be cleared by software or a system reset. This bit need not be cleared when this pin is used as an interrupt. The interrupt occurs once for each selected edge on the interrupt pin, even though this bit is already set. Clearing this bit, however, clears a pending request from the pin.
  - 0 = No transition detected
  - 1 = Transition detected
- Bits 14–7 Reserved. Reads are undefined; writes have no effect.
- **Bit 6 INTx Pin data.** Interrupt pin data bit. This read-only bit reflects the current level on the interrupt pin, regardless of how the interrupt pin is configured.
  - 0 = Pin is a logic 0 1 = Pin is a logic 1
- **Bit 5 INTx NMI.** Nonmaskable interrupt enable bit. This read/write bit determines whether this pin can generate a nonmaskable interrupt.
  - 0 = Pin is for a regular interrupt or a digital I/O
  - 1 = Pin is for a nonmaskable interrupt
- **Bit 4 INTx Data dir.** Interrupt pin data direction bit. When the interrupt pin is not enabled for interrupts, this read/write bit determines whether the pin is a digital input or a digital output.
  - 0 = Pin is an input 1 = Pin is an output

| Bit 3 | <b>INTx Data out.</b> Interrupt pin output data bit. This read/write bit determines whether the logic level on the pin is low or high when the pin is used as a digital output pin. |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <ul> <li>0 = Pin level is low (when pin used as digital output)</li> <li>1 = Pin level is high (when pin used as digital output)</li> </ul>                                         |
| Bit 2 | <b>INTx Polarity.</b> Interrupt polarity bit. This read/write bit determines whether interrupts are generated on the rising edge or the falling edge of a signal on the pin.        |
|       | <ul> <li>0 = Interrupt generated on a falling edge (high to low transition)</li> <li>1 = Interrupt generated on a rising edge (low to high transition)</li> </ul>                   |

- **Bit 1 INTx Priority.** Interrupt priority bit. This read/write bit determines which interrupt priority is requested. This bit has no effect if the NMI bit is set. See the device data sheet for details about which interrupt level corresponds to high priority and which interrupt level corresponds to low priority.
  - 0 = High priority
  - 1 = Low priority
- Bit 0 INTx Enable. Interrupt enable bit. This read/write bit enables or disables the maskable interrupt. This bit has no effect if the NMI bit is set.
  - 0 = Disable interrupt (use pin as digital input or output)
  - 1 = Enable interrupt

# Type C Interrupt Pins

Type C interrupt pins can be used as normal interrupts, digital output, or digital input pins. Figure 6–13 shows the general form of a Type C control register.

| Figure 6–13.   | Type C Interrupt | Control Register  |
|----------------|------------------|-------------------|
| 1 igui 0 0 10. | Type e milenapi  | oonin on nogiotor |

| 15           | 14–7     | 6                | 5        | 4                | 3                | 2                | 1                | 0              |
|--------------|----------|------------------|----------|------------------|------------------|------------------|------------------|----------------|
| INTx<br>Flag | Reserved | INTx<br>Pin data | Reserved | INTx<br>Data dir | INTx<br>Data out | INTx<br>Polarity | INTx<br>Priority | INTx<br>Enable |
| R/C-0        |          | R–p              | R/W–0    | R/W-0            | R/W-0            | R/W-0            | R/W-0            | R/W–0          |

Note: R = Read access, W = Write access, C = Clear-only write access, -n = Value after reset, -p = Logic level of pin

- Bit 15 INTx Flag. Interrupt flag. This read/clear bit indicates if the selected transition has been detected. This bit is set whether or not the interrupt is enabled. You can use this bit for software polling to see if the selected edge has occurred. This bit can only be cleared by software or a system reset. This bit need not be cleared when this pin is used as an interrupt. The interrupt occurs once for each selected edge on the interrupt pin, even though this bit is already set. Clearing this bit, however, clears a pending request from the pin.
  - 0 = No transition detected
  - 1 = Transition detected
- Bits 14–7 Reserved. Reads are undefined; writes have no effect.
- **Bit 6 INTx Pin data.** Interrupt pin data bit. This read-only bit reflects the current level on the interrupt pin, regardless of how the interrupt pin is configured.
  - 0 = Pin is a logic 0 1 = Pin is a logic 1
- Bits 5 Reserved. Reads are undefined; writes have no effect.
- **Bit 4 INTx Data dir.** Interrupt pin data direction bit. When the interrupt pin is not enabled for interrupts, this read/write bit determines whether the pin is a digital input or a digital output.
  - 0 = Pin is an input
  - 1 = Pin is an output
- Bit 3 INTx Data out. Interrupt pin output data bit. This read/write bit determines whether the logic level on the pin is low or high when the pin is used as a digital output pin.
  - 0 = Pin level is low (when pin used as digital output)
  - 1 = Pin level is high (when pin used as digital output)

| Bit 2 | <ul> <li>INTx Polarity. Interrupt polarity bit. This read/write bit determines whether interrupts are generated on the rising edge or the falling edge of a signal on the pin.</li> <li>0 = Interrupt generated on a falling edge (high to low transition)</li> <li>1 = Interrupt generated on a rising edge (low to high transition)</li> </ul> |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                                                                                                                                                                                                                                                                                                                                                  |
| Bit 1 | <b>INTx Priority.</b> Interrupt priority bit. This read/write bit determines which interrupt priority is requested. See the device data sheet for details about which interrupt level corresponds to high priority and which interrupt level corresponds to low priority.                                                                        |
|       | 0 = High priority<br>1 = Low priority                                                                                                                                                                                                                                                                                                            |
| Bit 0 | <b>INTx Enable.</b> Interrupt enable bit. This read/write bit enables or disables the maskable interrupt.                                                                                                                                                                                                                                        |
|       | <ul><li>0 = Disable interrupt (use pin as digital input or output)</li><li>1 = Enable interrupt</li></ul>                                                                                                                                                                                                                                        |

# Summary of External Interrupt Pin Functions

Table 6–12. External Interrupt Pin Functions and Corresponding Bit Settings

|                         | Control Register Bit Values |          |                       |           |          |            |  |  |
|-------------------------|-----------------------------|----------|-----------------------|-----------|----------|------------|--|--|
| Pin Used As             | NMI Bit <sup>†</sup>        | Data Out | Data Dir <sup>‡</sup> | Polarity§ | Priority | Int Enable |  |  |
| Nonmaskable interrupt   | 1                           | Х        | х                     | 0, 1      | х        | Х          |  |  |
| Interrupt high priority | 0                           | Х        | х                     | 0, 1      | 0        | 1          |  |  |
| Interrupt low priority  | 0                           | х        | х                     | 0, 1      | 1        | 1          |  |  |
| Digital output – 0      | 0                           | 0        | 1                     | х         | х        | 0          |  |  |
| Digital output – 1      | 0                           | 1        | 1                     | х         | х        | 0          |  |  |
| Digital input           | 0                           | х        | 0                     | х         | х        | 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.

§ A polarity value of 1 indicates rising edge and a value of 0 indicates falling edge.

# 6.3.13 Power Module Interrupts

Power module interrupts may be used to interface to signals from internal peripherals such as linear module fault condition signals (high or low active) that need to request an interrupt. These interrupts may also be used with signals coming from external pins.

Each interrupt signal has one enable bit and one interrupt flag. Each set of seven internal interrupts has a single interrupt vector. The interrupt priority level is determined at device fabrication; it is not programmable. Each power module interrupt flag can have either an active high input or an active low input. See the device data sheet for details.

The bits available in a power module interrupt register are shown in Figure 6–14 and Figure 6–15.

| 15             | 14                 | 13                 | 12                 | 11                 | 10                 | 9                  | 8                  |
|----------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|
| PM INT<br>Flag | PM INT<br>Status 6 | PM INT<br>Status 5 | PM INT<br>Status 4 | PM INT<br>Status 3 | PM INT<br>Status 2 | PM INT<br>Status 1 | PM INT<br>Status 0 |
| R/C0           | R/C0               | R/C0               | R/C0               | R/C0               | R/C0               | R/C0               | R/C0               |

Figure 6–14. PM INT Flag Bits

Note: R = Read access, W = Write access, C = Clear-only write access, -n = Value after reset

Figure 6–15. PM INT Enable Bits

| 7             | 6                  | 5                  | 4                  | 3                  | 2                  | 1                  | 0                  |
|---------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|
| PM INT<br>ENA | PM INT<br>Enable 6 | PM INT<br>Enable 5 | PM INT<br>Enable 4 | PM INT<br>Enable 3 | PM INT<br>Enable 2 | PM INT<br>Enable 1 | PM INT<br>Enable 0 |
| R/W-0         | R/W–0              | R/W-0              | R/W-0              | R/W-0              | R/W-0              | R/W-0              | R/W–0              |

Note: R = Read access, W = Write access, -n = Value after reset

- **Bit 15 PM INT Flag.** Power module interrupt flag. This bit is set any time one of the power module interrupt sources sees the appropriate edge when the corresponding PM INT Enable x bit is set. This flag can only be cleared by writing a 0; writing a 1 has no effect.
  - 0 = Power module interrupt event has not occurred since the flag was last cleared
  - 1 = Power module interrupt event has occurred since the flag was last cleared

- **Bits 14–8 PM INT Status x.** Power module interrupt status flags. These read-only bits reflect the status of the input source signals to the power module interrupts. If the source is in its active state, causing an interrupt, this bit contains a 1; otherwise, it contains a 0.
  - 0 = Power module interrupt is inactive
  - 1 = Power module interrupt is active
- **Bit 7 PM INT ENA.** Power module interrupt enable bit. This bit designates whether the seven power module interrupts associated with this register are able to generate an interrupt request to the CPU. If this bit is cleared, none of the seven related interrupts in bits 14–8 can cause an interrupt request to be generated. If this bit is set, an active and enabled interrupt can be acknowledged. This bit provides a quick means to disable all power module interrupts associated with a register. The wakeup signal associated with this interrupt is also disabled when the interrupt is disabled (see Section 6.5, *Power-Down Modes*, on page 6-51).
  - 0 = All power module interrupts are disabled
  - 1 = All power module interrupts are enabled
- **Bits 6–0 PM INT Enable x.** Power module interrupt enable bits. These bits specify whether the power module interrupt sources are enabled to set the PM INT Flag (bit 15). To allow an interrupt from a particular power module interrupt input, the corresponding PM INT Enable x bit must be set, as well as the PM INT ENA bit.
  - 0 = Power module interrupt x is disabled
  - 1 = Power module interrupt x is enabled

# 6.4 Reset Operation

The reset (RS) pin generates a nonmaskable external interrupt that can be used at any time to put the 'C24x into a known state. Reset is the highest priority interrupt; no other interrupt takes precedence over a reset. Reset is typically applied after power up when the machine is in an unknown state. Because the reset signal aborts memory operations and initializes status bits, the system should be reinitialized after each reset. The NMI interrupt can be used for soft resets because it neither aborts memory operations nor initializes status bits.

Depending on the device configuration, there are up to five causes of a device reset, as shown in Figure 6–16. Four of these causes are internally generated; the other cause, the RS pin, is controlled externally.

#### Figure 6–16. Reset Signals



The five possible reset signals are generated as follows:

- Watchdog timer reset. A Watchdog timer-generated reset occurs if the Watchdog timer (if present) overflows or an improper value is written to either the Watchdog key register or the Watchdog control register. (Note that when the device is powered on, the Watchdog timer is automatically active.)
- Software-generated reset. This is implemented with the system control register (SCR). Clearing the RESET0 bit (bit 14) or setting the RESET1 bit (bit 15) causes a system reset.
- Power-on reset/V<sub>DD</sub> out of regulation. This reset action is generated by either of two sources:
  - The external power-on reset pin (PORESET)
  - The low voltage detect circuitry, if present on the device. This circuitry sends a reset signal if the 'C24x device is operating with V<sub>DD</sub> outside the recommended operating range.
- Illegal address. The system and peripheral module control register frame address map contains unimplemented address locations in the ranges labeled 'Illegal' in a device data sheet. Any access to an address located in the Illegal ranges generates an illegal-address reset.

Reset pin active. To generate an external reset pulse on the RS pin, a low level pulse duration of as little as a few nanoseconds is usually effective; however, pulses of one SYSCLK cycle are necessary to ensure that the device recognizes the reset signal. A typical reset circuit required for a 'C24x device consists of a 10-kΩ pull-up resistor from the RS pin to V<sub>DD</sub>.

Once a reset source is activated, the external  $\overline{RS}$  pin is driven (active) low for a minimum of eight SYSCLK cycles. This allows the 'C24x to reset external devices connected to the  $\overline{RS}$  pin. (The  $\overline{RS}$  pin is an open collector I/O pin and should have a pull-up resistor attached.) Additionally, if a V<sub>DD</sub> out-of-regulation condition occurs or this  $\overline{RS}$  pin is held low, the reset logic holds the device in a reset state for as long as these actions are active.

When a reset signal is received, the program determines the source of the reset by reading the contents of the system status register (SYSSR). The SYSSR contains one status bit for each of the five internal sources that can cause a reset.

The occurrence of a reset condition causes the 'C24x to terminate execution and affects various registers and status bits. During a reset, RAM contents remain unchanged, and all control bits that are affected by a reset are initialized. Then processor execution begins at location 0, which normally contains a branch instruction to the system initialization routine.

When a 'C24x reset occurs, the following actions take place:

- A logic 0 is loaded into the CNF (configuration control) bit in status register ST1; this maps dual-access RAM block 0 into the data space.
- The program counter is cleared to 0.
- ☐ The INTM (interrupt mode) bit is set to 1, disabling all maskable interrupts. (RS and NMI are not maskable.) Also, the interrupt flag register (IFR) and interrupt mask register (IMR) are cleared.
- □ The status bits are loaded with the following values: OV = 0, XF = 1, SXM = 1, PM = 0, CNF = 0, INTM = 1, and C = 1. (The other status bits remain undefined and should be initialized after a reset.)
- □ The global memory allocation register (GREG) is cleared to make all memory local.
- The repeat counter (RPTC) is cleared.
- ☐ The wait states (if the device has an external memory interface) are set for the maximum duration.

□ The peripheral register bits are initialized as described in the *TMS320C24x DSP Controllers Reference Set, Volume 2: Peripheral Library and Specific Devices.* 

No other CPU registers or status bits (such as the accumulator, the DP, the ARP, and the auxiliary registers) are initialized.

# 6.5 Power-Down Modes

A 'C24x device can have up to four power-down modes that reduce the operating power of the 'C24x device by stopping the clocks (and, thus, the activity and power consumption) of the CPU and various on-chip peripherals. While the 'C24x is in a power-down mode, all of its internal contents are maintained and operation continues unaltered when the power-down mode is terminated with an interrupt. The content of all on-chip RAM remains unchanged. However, if the power-down mode is terminated with a reset, the contents of some registers are changed (the register contents that are always changed during a reset).

There are three different clock domains that can be shut off during power down:

- CPU clock domain. All clocks in the CPU and memories, except the interrupt control registers
- System clock domain. All peripheral clocks (CPUCLK or SYSCLK), the clocks for the CPU's interrupt control registers and the analog module clock (ACLK)
- Watchdog clock. The nominally 16 kHz clock used to increment the Watchdog Timer and Real Time Interrupt module (WDCLK)

#### Note:

The terms CPUCLK and CPU clock domain, SYSCLK and system clock domain are *not* interchangeable.

The four types of possible power-down modes on a 'C24x device have decreasing levels of power consumption and increasing delays to exit the low power mode. All of the possible power-down modes may not be implemented on a 'C24x device. A low-power mode is entered when the CPU executes an IDLE instruction. Which of the four possible low power modes is entered is determined by the PLLPM(1:0) bits in the CKCR0 register in the clock module. See the *TMS320C24x DSP Controllers Reference Set, Volume 2: Peripheral Library and Specific Devices* for more details on this register and on the power-down modes. The power-down modes in order of decreasing power and increasing startup time are:

Idle1 mode stops the clocks to the CPU (CPU clock domain) but the clocks for all peripherals (system clock domain) continue to run. Exit from Idle1 occurs immediately following any interrupt or a reset.

- □ Idle2 mode stops the clocks in both the CPU clock domain and the system clock domain. Exit from Idle2 occurs immediately following a wakeup interrupt or a reset. The Watchdog clock continues to run and eventually times out, causing a reset.
- □ PLL power-down mode powers down the PLL (if enabled). The Watchdog clock continues to run. Exit from this mode can be caused by a wakeup interrupt or a reset. The Watchdog clock continues to run and eventually times out, causing a reset. The device does not start full-speed operation until the PLL has powered up and reattained lock (this can be hundreds of microseconds; see the TMS320C24x DSP Controllers Reference Set, Volume 2: Peripheral Library and Specific Devices for more details).
- Oscillator power-down mode shuts off power to the oscillator (if enabled) and is the lowest power mode available. No clocks are running on the device. A wakeup interrupt or reset causes the device to exit this low-power mode. No clock runs until the oscillator has powered back up (the power-up time is on the order of milliseconds; see the TMS320C24x DSP Controllers Reference Set, Volume 2: Peripheral Library and Specific Devices for more details). The device does not start full-speed operation until the PLL has powered up and reattained lock (this can be additional hundreds of microseconds).

See the relevant device data sheet for details of low-power mode power consumption for each device. Table 6–13 shows the status of the CPU and peripheral clocks during each of the four power-down modes.

| Mode                  | CPU<br>Clock<br>Domain | System<br>Clock<br>Domain | Watchdog<br>Clock | Oscillator |
|-----------------------|------------------------|---------------------------|-------------------|------------|
| Idle1                 | Off                    | On                        | On                | On         |
| ldle2                 | Off                    | Off                       | On                | On         |
| PLL power down        | Off                    | Off                       | On                | On         |
| Oscillator power down | Off                    | Off                       | Off               | Off        |

### 6.5.1 Setting and Entering the Power-Down Modes

All the power-down modes are initiated by the execution of the IDLE instruction. The mode entered then depends on the value in the PLLPM field of clock module control register 0 (CKCR0). Table 6–14 shows how the two PLLPM bits of CKCR0 determine the power-down mode.

| Table 6–14. | Setting the Power-Down Mode with the PLLPM Bit |
|-------------|------------------------------------------------|
| 10010 0 11. |                                                |

| PLLPM bits | Power-Down Mode       |
|------------|-----------------------|
| 00         | Idle1                 |
| 01         | ldle2                 |
| 10         | PLL power down        |
| 11         | Oscillator power down |

#### 6.5.2 Exiting the Power-Down Modes

In any one of the four power-down modes (Idle1, Idle2, PLL power down, and oscillator power down), the CPU clock domain is off. Therefore, software interrupts cannot be generated to take the processor out of power-down. Interrupts can only be generated at external pins or by on-chip peripherals.

**Reset.** Reset signals terminate power-down modes as follows:

- $\Box$  The reset pin ( $\overline{RS}$ ) causes the device to exit *any* power-down mode.
- Watchdog timeout reset causes the device to exit Idle1, Idle2, or PLL power down. The Watchdog timer is not incrementing during oscillator power down because the Watchdog clock is stopped.

**External interrupts.** Any of the power-down modes terminate when the CPU receives any one of these interrupts at a pin:

- 🗋 NMI
- XINTn (any external interrupt controlled by the external interrupt control registers, if unmasked).

**Wakeup interrupts.** The external interrupts XINTn and NMI are also wakeup interrupts. This means that when the clocks are shut off, there is a combinatorial logic path from these pins to restart the clocks.

The external interrupts, XINTn, are maskable interrupts and can only completely bring the processor out of the power-down mode if they are unmasked. If they are masked, they wake up the device by starting all clocks, but the device remains in the IDLE state.

Certain peripherals are also able to generate wakeup interrupts when the clocks in the system clock domain are shut off. For example, some communication ports may be able to generate a wakeup interrupt in response to receiving a character.

Oscillator power down mode is only terminated by an external interrupt (NMI or XINTn). In this mode, the oscillator is off (no clocks on the device are active); thus, no interrupts can be generated by on-chip peripherals, and the Watchdog timer cannot generate a time-out signal.

**Peripheral interrupts.** The Idle1, Idle2, and PLL power-down modes can be terminated by various peripheral interrupts under the right conditions. In Idle1 mode, all the clocks for the peripheral devices are still running; therefore, any unmasked peripheral interrupt terminates Idle1 mode. In the Idle2 and PLL power-down modes, the clocks in the system clock domain are off. As a result, only unmasked peripheral interrupts not timed by the system clock can bring the processor out of the Idle2 and PLL power-down modes.

In oscillator power-down mode, the peripheral clocks and the Watchdog timer clocks are off. Only unmasked peripheral interrupts not timed by either of those clocks can terminate oscillator power-down mode.

Table 6–15 summarizes the state of processors in each power-down mode and lists the interrupts that do and do not terminate each mode.

| Mode          | CPU<br>Clock<br>Domain | System<br>Clock<br>Domain | Watchdog<br>Clock | PLL | Oscillator | Terminated By                          | Not Terminated<br>By                   |
|---------------|------------------------|---------------------------|-------------------|-----|------------|----------------------------------------|----------------------------------------|
| Idle1         | Off                    | On                        | On                | On  | On         | Reset (RS)<br>Watchdog reset           | Masked interrupts                      |
|               |                        |                           |                   |     |            | NMI (at pin)                           |                                        |
|               |                        |                           |                   |     |            | XINT's (at pin,<br>unmasked)           |                                        |
|               |                        |                           |                   |     |            | Any peripheral<br>interrupt (unmasked) |                                        |
| ldle2         | Off                    | Off                       | On                | On  | On         | Reset (RS)<br>Watchdog reset           | Masked interrupts<br>Peripheral inter- |
|               |                        |                           |                   |     |            | NMI (at pin)                           | rupts dependent                        |
|               |                        |                           |                   |     |            | XINT's (at pin,<br>unmasked)           | on the system clock.                   |
|               |                        |                           |                   |     |            | Peripheral wakeup interrupts.          |                                        |
| PLL<br>power  | Off                    | Off                       | On                | Off | On         | Reset (RS)<br>Watchdog reset           | Masked interrupts<br>Peripheral inter- |
| down<br>(PPD) |                        |                           |                   |     |            | NMI (at pin)                           | rupts dependent                        |
| (110)         |                        |                           |                   |     |            | XINT's (at pin,<br>unmasked)           | on the system<br>clock                 |
|               |                        |                           |                   |     |            | Peripheral wakeup<br>interrupts        |                                        |
| Oscillator    | Off                    | Off                       | Off               | Off | Off        | Reset (RS)                             | Masked interrupts                      |
| power<br>down |                        |                           |                   |     |            | NMI (at pin)                           | Peripheral inter-                      |
| (OPD)         |                        |                           |                   |     |            | XINT's (at pin,<br>unmasked)           | rupts                                  |
|               |                        |                           |                   |     |            | Peripheral wakeup interrupts           |                                        |

# Table 6–15. Power-Down Modes and Their Termination

#### After Exiting Power-Down

There are two items to consider when deciding how to wake the processor:

- ☐ If you use reset or NMI, the CPU immediately executes the corresponding interrupt service routine.
- If you use a maskable hardware interrupt, the next action depends on the interrupt mode (INTM) bit of status register ST0:
  - **INTM = 0:** The interrupt is enabled, and the CPU executes the corresponding interrupt service routine.
  - INTM = 1: The interrupt is disabled, and the CPU continues with the instruction after IDLE.

If you do not want the CPU to take an interrupt service routine before continuing with the interrupted program sequence:

- Do not use reset or NMI to bring the processor out of power-down.
- Make sure your program sets INTM to 1 (SETC INTM) before IDLE is executed.

If you want the CPU to take the interrupt service routine before continuing:

- Make sure your program clears INTM to 0 (CLRC INTM) before IDLE is executed.
- Make sure you enable all relevant interrupt sources, both locally (in the peripheral mask/enable registers) and globally (in the CPU's interrupt mask register).

#### 6.5.3 Summary of Power-Down Mode Operation

When the IDLE instruction is executed:

- The program counter is incremented once, so that when the power-down mode is exited, the next instruction is the one that follows the IDLE instruction, except in the case of reset.
- The 'C24x enters the power-down mode selected by the PLLPM bits and remains in that low-power state until it receives a proper hardware interrupt (as described in subsection 6.5.2, *Exiting the Power-Down Modes*, on page 6-53).
- 3) Upon receipt of the proper interrupt, the 'C24x exits the power-down mode.
- If you use NMI to wake the processor, the CPU executes the corresponding interrupt service routine before continuing with the interrupted program sequence.

If you use a maskable interrupt, the next action depends on the value of the INTM bit:

- INTM = 0: Maskable interrupts are enabled; the CPU first executes the interrupt service routine of the interrupt that brought it out of power-down. Then it continues with the instruction after the IDLE instruction.
- INTM = 1: Maskable interrupts are disabled; the CPU continues execution at the instruction after IDLE.

Table 6–16 summarizes the four power-down modes, including the approximate power level for each. (For more accurate power values, see the data sheet for your particular 'C24x device.) In addition, the table shows the status of the 'C24x when not in a power-down mode. See Table 6–15 for the list of interrupts that do and do not terminate each mode.

| Table 6–16. | Power-Down | Modes/Run | Mode Summary |
|-------------|------------|-----------|--------------|
|-------------|------------|-----------|--------------|

| Mode   | PLLPM | + | IDLE       | Power<br>Level | CPU<br>Clock<br>Domain | System<br>Clock<br>Domain | Watchdog<br>Clock | PLL | Oscillator |  |
|--------|-------|---|------------|----------------|------------------------|---------------------------|-------------------|-----|------------|--|
| Run    | XX    | + | No<br>IDLE | > 40 mA        | On                     | On                        | On                | On  | On         |  |
| Idle 1 | 00    | + | IDLE       | ~15 mA         | Off                    | On                        | On                | On  | On         |  |
| Idle 2 | 01    | + | IDLE       | ~4 mA          | Off                    | Off                       | On                | On  | On         |  |
| PPD    | 10    | + | IDLE       | ~1 mA          | Off                    | Off                       | On                | Off | On         |  |
| OPD    | 11    | + | IDLE       | < 30 μA        | Off                    | Off                       | off Off           |     | Off        |  |

# PRELIMINARY

# PRELIMINARY

# Chapter 7

# **Addressing Modes**

This chapter explains the three basic memory addressing modes used by the 'C24x instruction set. The three modes are:

- Immediate addressing mode
- Direct addressing mode
- Indirect addressing mode

In immediate addressing, a constant to be manipulated by the instruction is supplied directly as an operand of that instruction. Two types of immediate addressing are available—short and long. In short-immediate addressing, an 8-, 9-, or 13-bit operand is included in the instruction word. Long-immediate addressing uses a 16-bit operand.

When you need to access data memory, you can use direct or indirect addressing. Direct addressing concatenates seven bits of the instruction word with the nine bits of the data-memory page pointer (DP) to form the 16-bit data memory address. Indirect addressing accesses data memory through one of eight 16-bit auxiliary registers.

| Торі | c Page                        |
|------|-------------------------------|
| 7.1  | Immediate Addressing Mode 7-2 |
| 7.2  | Direct Addressing Mode 7-4    |
| 7.3  | Indirect Addressing Mode7-9   |

# 7.1 Immediate Addressing Mode

In immediate addressing, the instruction word contains a constant to be manipulated by the instruction. The 'C24x supports two types of immediate addressing:

- Short-immediate addressing. Instructions that use short-immediate addressing take an 8-bit, 9-bit, or 13-bit constant as an operand. Short-immediate instructions require a single instruction word, with the constant embedded in that word.
- Long-immediate addressing. Instructions that use long-immediate addressing take a 16-bit constant as an operand and require two instruction words. The constant is sent as the second instruction word. This 16-bit value can be used as an absolute constant or as a 2s-complement value.

In Example 7–1, the immediate operand is contained as a part of the RPT instruction word. For this RPT instruction, the instruction register will be loaded with the value shown in Figure 7–1. Immediate operands are preceded by the symbol #.

#### Example 7–1. RPT Instruction Using Short-Immediate Addressing

RPT #99 ;Execute the instruction that follows RPT ;100 times.

Figure 7–1. Instruction Register Contents for Example 7–1

| 15                                  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                   | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|-------------------------------------|----|----|----|----|----|---|---|---|---------------------|---|---|---|---|---|---|--|--|
| 1                                   | 0  | 1  | 1  | 1  | 0  | 1 | 1 | 0 | 1                   | 1 | 0 | 0 | 0 | 1 | 1 |  |  |
| RPT opcode for immediate addressing |    |    |    |    |    |   |   |   | 8-bit constant = 99 |   |   |   |   |   |   |  |  |

In Example 7–2, the immediate operand is contained in the second instruction word. The instruction register receives, consecutively, the two 16-bit values shown in Figure 7–2.

Example 7–2. ADD Instruction Using Long-Immediate Addressing

ADD #16384,2 ;Shift the value 16384 left by two bits ;and add the result to the accumulator.

| 15       14       13       12       11       10       9       8       7       6       5       4       3       2       1         1       0       1       1       1       1       1       1       0       0       1       0       0       1       0       0       1       0       1       1       1       1       1       1       1       1       0       0       1       0       0       1       0       0       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 | 1 11 31 | instr  | uctic |       |        |      |     |        |       |        |    |   |   |       |     |   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------|-------|-------|--------|------|-----|--------|-------|--------|----|---|---|-------|-----|---|
| ADD opcode for long-immediate addressing       shift = 2         Second instruction word:       15         15       14       13       12       11       10       9       8       7       6       5       4       3       2       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 15      | 14     | 13    | 12    | 11     | 10   | 9   | 8      | 7     | 6      | 5  | 4 | 3 | 2     | 1   | 0 |
| Second instruction word:<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1       | 0      | 1     | 1     | 1      | 1    | 1   | 1      | 1     | 0      | 0  | 1 | 0 | 0     | 1   | 0 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |        | חח מ  | nncor | do for | long | imm | adiate | v odd | roccir | 20 |   |   | ahift | 0   |   |
| 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Seco    |        |       |       |        | •    |     |        |       | 62211  | iy |   |   | Shint | = 2 |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         | ond ir | nstru | ction | wor    | d:   |     |        |       |        | •  | 4 | 3 |       | = 2 | 0 |

Figure 7–2. Two Words Loaded Consecutively to the Instruction Register in Example 7–2

16-bit constant = 16 384 = 4000h

#### 7.2 Direct Addressing Mode

In the direct addressing mode, data memory is addressed in blocks of 128 words called data pages. The entire 64K of data memory consists of 512 data pages labeled 0 through 511, as shown in Figure 7–3. The current data page is determined by the value in the 9-bit data page pointer (DP) in status register ST0. For example, if the DP value is 0 0000 0000<sub>2</sub>, the current data page is 0. If the DP value is 0 0000 0010<sub>2</sub>, the current data page is 2.

Figure 7–3. Pages of Data Memory

| DP Value    | Offset   | Data Memory           |
|-------------|----------|-----------------------|
| 0000 0000 0 | 000 0000 |                       |
| :           | :        | Page 0: 0000h–007Fh   |
| 0000 0000 0 | 111 1111 | C C                   |
| 0000 0000 1 | 000 0000 |                       |
| :           | :        | Page 1: 0080h-00FFh   |
| 0000 0000 1 | 111 1111 | -                     |
| 0000 0001 0 | 000 0000 |                       |
|             |          | Page 2: 0100h–017Fh   |
| 0000 0001 0 | 111 1111 |                       |
|             |          |                       |
|             |          |                       |
|             |          | •                     |
|             | •        |                       |
|             |          |                       |
|             |          |                       |
|             |          |                       |
| 1111 1111 1 | 000 0000 |                       |
| :           | ÷        | Page 511: FF80h-FFFFh |
| 1111 1111 1 | 111 1111 | -                     |

In addition to the data page, the processor must know the particular word being referenced on that page. This is determined by a 7-bit offset (see Figure 7–3). The offset is supplied by the seven least significant bits (LSBs) of the instruction register, which holds the opcode for the next instruction to be executed. In direct addressing mode, the content of the instruction register has the format shown in Figure 7–4.

| 15   | 14                                                                                                                                                                                | 13 | 12   | 11     | 10             | 9      | 8     | 7                    | 6      | 5      | 4       | 3       | 2     | 1     | 0   |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------|--------|----------------|--------|-------|----------------------|--------|--------|---------|---------|-------|-------|-----|
|      |                                                                                                                                                                                   |    | 8 N  | /ISBs  |                |        |       | 0                    |        |        | 7 L     | SBs     |       |       |     |
| 8 M  | 8 MSBs Bits 15 through 8 indicate the instruction type (for example, ADD) and also contain any information regarding a shift of the data value to be accessed by the instruction. |    |      |        |                |        |       |                      |        |        |         |         |       |       |     |
| 0    |                                                                                                                                                                                   |    |      |        | ndire<br>g mod |        |       | <b>tor.</b> B<br>ct. | it7c   | ontai  | ns a (  | ) to de | efine | the   | ad- |
| 7 LS | SBs                                                                                                                                                                               |    | Bits | s 6 th | roua           | h 0 ii | ndica | te the               | e offs | et for | r the o | data-i  | mem   | orv a | ad- |

dress referenced by the instruction.

Figure 7-4. Instruction Register (IR) Contents in Direct Addressing Mode

To form a complete 16-bit address, the processor concatenates the DP value and the seven LSBs of the instruction register, as shown in Figure 7–5. The DP supplies the nine most significant bits (MSBs) of the address (the page number), and the seven LSBs of the instruction register supply the seven LSBs of the address (the offset). For example, to access data address 003Fh, you specify data page 0 (DP = 0000 0000 0) and an offset of 011 1111. Concatenating the DP and the offset produces the 16-bit address 0000 0000 0011 1111, which is 003Fh or decimal 63.

Figure 7–5. Generation of Data Addresses in Direct Addressing Mode



#### Initialize the DP in All Programs

It is critical that all programs initialize the DP. The DP is not initialized by reset and is undefined after power up. The 'C24x development tools use default values for many parameters, including the DP. However, programs that do not explicitly initialize the DP can execute improperly, depending on whether they are executed on a 'C24x device or with a development tool.

#### 7.2.1 Using Direct Addressing Mode

When you use direct addressing mode, the processor uses the DP to find the data page and uses the seven LSBs of the instruction register to find a particular address on that page. Always do the following:

 Set the data page. Load the appropriate value (from 0 to 511) into the DP. The DP register can be loaded by the LDP instruction or by any instruction that can load a value to ST0. The LDP instruction loads the DP directly without affecting the other bits of ST0, and it clearly indicates the value loaded into the DP. For example, to set the current data page to 32 (addresses 1000h–107Fh), you can use:

LDP #32 ; Initialize data page pointer

 Specify the offset. Supply the 7-bit offset as an operand of the instruction. For example, if you want the ADD instruction to use the value at the second address of the current data page, you would write:

```
ADD 1h;Add to accumulator the value in the current ;data page, offset of 1.
```

You do not have to set the data page prior to every instruction that uses direct addressing. If all the instructions in a block of code access the same data page, you can simply load the DP at the front of the block. However, if various data pages are being accessed throughout the block of code, be sure the DP is changed whenever a new data page should be accessed.

#### 7.2.2 Examples of Direct Addressing

In Example 7–3, the first instruction loads the DP with 0 0000  $0100_2$  to set the current data page to 4. The ADD instruction then references a data memory address that is generated as shown following the program code. Before the ADD instruction is executed, the opcode is loaded into the instruction register. Together, the DP and the seven LSBs of the instruction register form the complete 16-bit address, 0000 0010 0000  $1001_2$  (0209h).



Example 7–3. Using Direct Addressing with ADD (Shift of 0 to 15)

In Example 7–4, the ADD instruction references a data memory address that is generated as shown following the program code. For any instruction that performs a shift of 16, the shift value is not embedded directly in the instruction word; instead, all eight MSBs contain an opcode that not only indicates the instruction type, but also a shift of 16. The eight MSBs of the instruction word indicate an ADD with a shift of 16.





In Example 7–5, the ADDC instruction references a data memory address that is generated as shown following the program code. Note that if an instruction does not perform shifts, like the ADDC instruction does not, all eight MSBs of the instruction contain the opcode for the instruction type.





#### 7.3 Indirect Addressing Mode

Eight auxiliary registers (AR0–AR7) provide flexible and powerful indirect addressing. Any location in the 64K data memory space can be accessed using a 16-bit address contained in an auxiliary register.

#### 7.3.1 Current Auxiliary Register

To select a specific auxiliary register, load the 3-bit auxiliary register pointer (ARP) of status register ST0 with a value from 0 to 7. The ARP can be loaded as a primary operation by the MAR instruction or by the LST instruction. The ARP can be loaded as a secondary operation by any instruction that supports indirect addressing.

The register pointed to by the ARP is referred to as the *current auxiliary register* or *current AR*. During the processing of an instruction, the content of the current auxiliary register is used as the address at which the data-memory access takes place. The ARAU passes this address to the data-read address bus (DRAB) if the instruction requires a read from data memory, or it passes the address to the data-write address bus (DWAB) if the instruction requires a write to data memory. After the instruction uses the data value, the contents of the current auxiliary register can be incremented or decremented by the ARAU, which implements unsigned 16-bit arithmetic.

Normally, the ARAU performs its arithmetic operations in the decode phase of the pipeline (when the instruction specifying the operations is being decoded). This allows the address to be generated before the decode phase of the next instruction. There is an exception to this rule: during processing of the NORM instruction, the auxiliary register and/or ARP modification is done during the execute phase of the pipeline. For information on pipeline operation, see Section 5.2 on page 5-7.

#### 7.3.2 Indirect Addressing Options

The 'C24x provides four types of indirect addressing options:

- ❑ No increment or decrement. The instruction uses the content of the current auxiliary register as the data memory address but neither increments nor decrements the content of the current auxiliary register.
- Increment or decrement by 1. The instruction uses the content of the current auxiliary register as the data memory address and then increments or decrements the content of the current auxiliary register by one.
- Increment or decrement by an index amount. The value in AR0 is the index amount. The instruction uses the content of the current auxiliary register as the data memory address and then increments or decrements the content of the current auxiliary register by the index amount.

Increment or decrement by an index amount using reverse carry. The value in AR0 is the index amount. After the instruction uses the content of the current auxiliary register as the data-memory address, that content is incremented or decremented by the index amount. The addition or sub-traction, in this case, is done with the carry propagation reversed for fast Fourier transforms (FFTs).

These four option types provide the seven indirect addressing options listed in Table 7–1. The table also shows the instruction operand that corresponds to each indirect addressing option and gives an example of how each option is used.

Table 7–1. Indirect Addressing Operands

| Operand | Option                                                    | Example                                                                                                                                                                                                                                                            |
|---------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| *       | No increment or decrement                                 | LT * loads the temporary register (TREG) with the content of the data memory address referenced by the current AR.                                                                                                                                                 |
| *+      | Increment by 1                                            | LT *+ loads the temporary register (TREG) with the content of<br>the data memory address referenced by the current AR and<br>then adds 1 to the content of the current AR.                                                                                         |
| *       | Decrement by 1                                            | LT *- loads the temporary register (TREG) with the content of the data memory address referenced by the current AR and then subtracts 1 from the content of the current AR.                                                                                        |
| *0+     | Increment by index amount                                 | LT *0+ loads the temporary register (TREG) with the content of the data memory address referenced by the current AR and then adds the content of AR0 to the content of the current AR.                                                                             |
| *0–     | Decrement by index amount                                 | <b>LT</b> * <b>0</b> – loads the temporary register (TREG) with the content of the data memory address referenced by the current AR and then subtracts the content of AR0 from the content of the current AR.                                                      |
| *BR0+   | Increment by index amount, adding with reverse carry      | <b>LT *BR0+</b> loads the temporary register (TREG) with the content of the data memory address referenced by the current AR and then adds the content of AR0 to the content of the current AR, adding with reverse carry propagation.                             |
| *BR0-   | Decrement by index amount, subtracting with reverse carry | <b>LT *BR0</b> – loads the temporary register (TREG) with the con-<br>tent of the data memory address referenced by the current AR<br>and then subtracts the content of AR0 from the content of the<br>current AR, subtracting with bit reverse carry propagation. |

All increments or decrements are performed by the auxiliary register arithmetic unit (ARAU) in the same cycle during which the instruction is being decoded in the pipeline.

The bit-reversed indexed addressing allows efficient I/O operations by resequencing the data points in a radix-2 FFT program. The direction of carry propagation in the ARAU is reversed when the address is selected, and ARO is added to or subtracted from the current auxiliary register. A typical use of this addressing mode requires that ARO first be set to a value corresponding to half of the array's size, and that the current AR value be set to the base address of the data (the first data point).

#### 7.3.3 Next Auxiliary Register

In addition to updating the current auxiliary register, a number of instructions can also specify the *next auxiliary register* or *next AR*. This register will be the current auxiliary register when the instruction execution is complete. The instructions that allow you to specify the next auxiliary register load the ARP with a new value. When the ARP is loaded with that value, the previous ARP value is loaded into the auxiliary register pointer buffer (ARB). Example 7–6 illustrates the selection of a next auxiliary register, as well as other indirect addressing features discussed so far.

Example 7-6. Selecting a New Current Auxiliary Register

| MAR*,AR1  | ;Load the ARP with 1 to make AR1 the ;current auxiliary register.                                                                                                  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LT *+,AR2 | ;AR2 is the next auxiliary register.<br>;Load the TREG with the content of the<br>;address referenced by AR1, add one to<br>;the content of AR1, then make AR2 the |
| MPY*      | ;current auxiliary register.<br>;Multiply TREG by content of address<br>;referenced by AR2.                                                                        |

## 7.3.4 Indirect Addressing Opcode Format

Figure 7–6 shows the format of the instruction word loaded into the instruction register when you use indirect addressing. The opcode fields are described following Figure 7–6.

## Figure 7–6. Instruction Register Content in Indirect Addressing

| 15                                     | 14     | 13 | 12   | 11                                                                                                      | 10  | 9    | 8     | 7     | 6       | 5      | 4     | 3                          | 2     | 1      | 0   |
|----------------------------------------|--------|----|------|---------------------------------------------------------------------------------------------------------|-----|------|-------|-------|---------|--------|-------|----------------------------|-------|--------|-----|
|                                        | 8 MSBs |    |      |                                                                                                         |     |      |       |       |         | ARU    |       | Ν                          | I     | NAR    |     |
| 8 M                                    | SBs    |    |      |                                                                                                         |     |      |       |       |         |        |       | ype (f<br>rding            |       |        |     |
| 1 Direct/indirect i<br>dressing mode a |        |    |      |                                                                                                         |     |      |       |       | Bit 7 c | ontai  | ns a  | 1 to d                     | efine | the a  | ad- |
| ARI                                    | J      |    | whe  | ether                                                                                                   | and | hov  | v the | curre | ent a   |        | ry re | ough<br>egiste             |       |        |     |
| Ν                                      |        |    |      | <b>Next auxiliary register indicator.</b> Bit 3 specifies whethe the instruction changes the ARP value. |     |      |       |       |         |        |       |                            | ıer   |        |     |
|                                        |        |    | N =  | N = 0 The content of the ARP remains unchanged                                                          |     |      |       |       |         |        |       | ange                       | d.    |        |     |
|                                        |        |    | N =  | : 1                                                                                                     |     | the  | old A | NRP v | alue    | is loa | aded  | l into t<br>into<br>us reg | the a | uxilia | ary |
| NAF                                    | 2      |    | valı | ue of                                                                                                   |     | next | -     |       |         |        |       | ugh 0<br>is Ioa            |       |        |     |

Table 7–2. Effects of the ARU Code on the Current Auxiliary Register

| A | ARU Code |   |                                                                       |
|---|----------|---|-----------------------------------------------------------------------|
| 6 | 5        | 4 | Arithmetic Operation Performed on Current AR                          |
| 0 | 0        | 0 | No operation on current AR                                            |
| 0 | 0        | 1 | Current AR – 1 $\rightarrow$ current AR                               |
| 0 | 1        | 0 | Current AR + 1 $\rightarrow$ current AR                               |
| 0 | 1        | 1 | Reserved                                                              |
| 1 | 0        | 0 | Current AR – AR0 $\rightarrow$ current AR [reverse carry propagation] |
| 1 | 0        | 1 | Current AR – AR0 $\rightarrow$ current AR                             |
| 1 | 1        | 0 | Current AR + AR0 $\rightarrow$ current AR                             |
| 1 | 1        | 1 | Current AR + AR0 $\rightarrow$ current AR [reverse carry propagation] |

Table 7-3 shows the opcode field bits and the notation used for indirect addressing. It also shows the corresponding operations performed on the current auxiliary register and the ARP.

|              | Instruction Opcode Bits |                 |   |   |   |   | ts                           |                   |                                                                                        |
|--------------|-------------------------|-----------------|---|---|---|---|------------------------------|-------------------|----------------------------------------------------------------------------------------|
| 15           | _                       | 87              | 6 | 5 | 4 | 3 | 2 1 0                        | _<br>Operand(s)   | Operation                                                                              |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 0 | 0 | 0 | 0 | $\leftarrow NAR \rightarrow$ | *                 | No manipulation of current AR                                                          |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 0 | 0 | 0 | 1 | $\leftarrow NAR \rightarrow$ | *,AR <i>n</i>     | $NAR \rightarrow ARP$                                                                  |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 0 | 0 | 1 | 0 | $\leftarrow NAR \rightarrow$ | *                 | Current AR – 1 $\rightarrow$ current AR                                                |
| $\leftarrow$ | 8 MSBs                  | → 1             | 0 | 0 | 1 | 1 | $\leftarrow NAR \rightarrow$ | *–,AR <i>n</i>    | Current AR – 1 $\rightarrow$ current AR NAR $\rightarrow$ ARP                          |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 0 | 1 | 0 | 0 | $\leftarrow NAR \rightarrow$ | *+                | Current AR + 1 $\rightarrow$ current AR                                                |
| $\leftarrow$ | 8 MSBs                  | → 1             | 0 | 1 | 0 | 1 | $\leftarrow NAR \rightarrow$ | *+,AR <i>n</i>    | Current AR + 1 $\rightarrow$ current AR NAR $\rightarrow$ ARP                          |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 1 | 0 | 0 | 0 | $\leftarrow NAR \rightarrow$ | *BR0-             | Current AR – $rcAR0 \rightarrow$ current AR †                                          |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 1 | 0 | 0 | 1 | $\leftarrow NAR \rightarrow$ | *BR0–,AR <i>n</i> | Current AR – <i>rc</i> AR0 $\rightarrow$ current AR NAR $\rightarrow$ ARP <sup>†</sup> |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 1 | 0 | 1 | 0 | $\leftarrow NAR \rightarrow$ | *0—               | Current AR – AR0 $\rightarrow$ current AR                                              |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 1 | 0 | 1 | 1 | $\leftarrow NAR \rightarrow$ | *0–,AR <i>n</i>   | Current AR – AR0 $\rightarrow$ current AR NAR $\rightarrow$ ARP                        |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 1 | 1 | 0 | 0 | $\leftarrow NAR \rightarrow$ | *0+               | Current AR + AR0 $\rightarrow$ current AR                                              |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 1 | 1 | 0 | 1 | $\leftarrow NAR \rightarrow$ | *0+,AR <i>n</i>   | Current AR + AR0 $\rightarrow$ current AR NAR $\rightarrow$ ARP                        |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 1 | 1 | 1 | 0 | $\leftarrow NAR \rightarrow$ | *BR0+             | Current AR + $rcAR0 \rightarrow$ current AR †                                          |
| $\leftarrow$ | 8 MSBs                  | $\rightarrow$ 1 | 1 | 1 | 1 | 1 | $\leftarrow NAR \rightarrow$ | *BR0+,AR <i>n</i> | Current AR + <i>rc</i> AR0 $\rightarrow$ current AR NAR $\rightarrow$ ARP <sup>†</sup> |

Table 7–3. Field Bits and Notation for Indirect Addressing

<sup>†</sup>Bit-reversed addressing mode

п

Reverse carry propagation rc NAR Next AR 0, 1, 2, ..., or 7

8 MSBs Eight bits determined by instruction type and (sometimes) shift information

Is loaded into  $\rightarrow$ 

#### 7.3.5 Examples of Indirect Addressing

In Example 7–7, when the ADD instruction is fetched from program memory, the instruction register is loaded with the value shown.

Example 7–7. Indirect Addressing—No Increment or Decrement



In Example 7–8, when the ADD instruction is fetched from program memory, the instruction register is loaded with the value shown.

Example 7-8. Indirect Addressing-Increment by 1



```
Example 7–9. Indirect Addressing—Decrement by 1
```

```
ADD *-,8 ;Operates as in Example 7-7, but in ;addition, the current auxiliary register ;is decremented by one.
```

Example 7–10. Indirect Addressing—Increment by Index Amount

ADD \*0+,8 ;Operates as in Example 7-7, but in ;addition, the content of register AR0 ;is added to the current auxiliary ;register.

Example 7–11. Indirect Addressing—Decrement by Index Amount

```
ADD *0-,8 ;Operates as in Example 7-7, but in ;addition, the content of register AR0 ;is subtracted from the current auxiliary ;register.
```

#### Example 7–12. Indirect Addressing—Increment by Index Amount With Reverse Carry Propagation

ADD \*BR0+,8 ;Operates as in Example 7-10, except that ;the content of register AR0 is added to ;the current auxiliary register with ;reverse carry propagation.

## Example 7–13. Indirect Addressing—Decrement by Index Amount With Reverse Carry Propagation

ADD \*BR0-,8 ;Operates as in Example 7-11, except that ;the content of register AR0 is subtracted ;from the current auxiliary register with ;reverse carry propagation.

#### 7.3.6 Modifying Auxiliary Register Content

The LAR, ADRK, SBRK, and MAR instructions are specialized instructions for changing the content of an auxiliary register (AR):

- ☐ The LAR instruction loads an AR.
- The ADRK instruction adds an immediate value to an AR; SBRK subtracts an immediate value.
- The MAR instruction can increment or decrement an AR value by 1 or by an index amount.

However, you are not limited to these four instructions. Auxiliary registers can be modified by any instruction that supports indirect addressing operands. (Indirect addressing can be used with all instructions except those that have immediate operands or no operands.)

## **Chapter 8**

# **Assembly Language Instructions**

#### Note:

The instruction set for the TMS320C24x is identical to that of the TMS320C2xx. All references to 'C2xx devices in this chapter also apply to 'C24x devices.

This chapter describes the 'C24x assembly language instructions. This instruction set supports numerically intensive signal-processing operations as well as general-purpose applications, such as multiprocessing and high-speed control. The 'C2xx instruction set is compatible with the 'C2x instruction set; code written for the 'C2x can be reassembled to run on the 'C2xx. The 'C5x instruction set is a superset of that of the 'C2xx; thus, code written for the 'C2xx can be upgraded to run on a 'C5x.

#### Topic

Page

| 8.1 | Instruction Set Summary 8-2             |
|-----|-----------------------------------------|
| 8.2 | How To Use the Instruction Descriptions |
| 8.3 | Instruction Descriptions 8-19           |

#### 8.1 Instruction Set Summary

This section provides six tables (Table 8–1 to Table 8–6) that summarize the instruction set according to the following functional headings:

- Accumulator, arithmetic, and logic instructions (see Table 8–1 on page 8-5)
- Auxiliary register and data page pointer instructions (see Table 8–2 on page 8-7)
- TREG, PREG, and multiply instructions (see Table 8–3 on page 8-8)
- Branch instructions (see Table 8–4 on page 8-9)
- Control instructions (see Table 8–5 on page 8-10)
- □ I/O and memory operations (see Table 8–6 on page 8-11)

Within each table, the instructions are arranged alphabetically. The number of words that an instruction occupies in program memory is specified in column three of each table; the number of cycles that an instruction requires to execute is in column four. All instructions are assumed to be executed from internal program memory (RAM) and internal data dual-access memory. The cycle timings are for single-instruction execution, not for repeat mode. Additional information about each instruction is presented in the individual instruction descriptions in Section 8.2 on page 8-12.

For your reference, here are the definitions of the symbols used in the six summary tables:

- ACC The accumulator
- AR The auxiliary register
- **ARX** A 3-bit value used in the LAR and SAR instructions to designate which auxiliary register will be loaded (LAR) or have its contents stored (SAR)
- **BITX** A 4-bit value (called the bit code) that determines which bit of a designated data memory value will be tested by the BIT instruction
- **CM** A 2-bit value. The CMPR instruction performs a comparison specified by the value of CM:

If CM = 00, test whether current AR = AR0 If CM = 01, test whether current AR < AR0 If CM = 10, test whether current AR > AR0 If CM = 11, test whether current AR  $\neq$  AR0

| ΙΑΑΑ ΑΑΑΑ        | that reflects whether<br>dressing $(I = 1)$ is bein<br>the seven As are the<br>data memory address<br>are bits that control a | ven As) The I at the left represents a bit<br>direct addressing (I = 0) or indirect ad-<br>g used. When direct addressing is used,<br>seven least significant bits (LSBs) of a<br>s. For indirect addressing, the seven As<br>uxiliary register manipulation (see Sec-<br>ressing Mode, on page 7-9). |  |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 1111 1111        | (Eight Is) An 8-bit constant used in short immediate addressing                                                               |                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| 1 1111 1111      | (Nine Is) A 9-bit constant used in short immediate addressin for the LDP instruction                                          |                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| 1 1111 1111 1111 | (Thirteen Is) A 13-bit constant used in short immediate addressing for the MPY instruction                                    |                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| I NTR#           | •                                                                                                                             | nting a number from 0 to 31. The INTR<br>umber to change program control to one<br>ctor addresses.                                                                                                                                                                                                    |  |  |  |  |  |  |
| РМ               | A 2-bit value copied in the SPM instruction                                                                                   | nto the PM bits of status register ST1 by                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| SHF              | A 3-bit left-shift value                                                                                                      |                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| SHFT             | A 4-bit left-shift value                                                                                                      |                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| ТР               | A 2-bit value used by represent four condition                                                                                | the conditional execution instructions to ons:                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|                  | $\overline{\text{BIO}}$ pin low<br>TC bit =1<br>TC bit = 0                                                                    | TP = 00<br>TP = 01<br>TP = 10                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |

TP = 11

No condition

**ZLVC ZLVC** Two 4-bit fields — each representing the following conditions:

| ACC = 0  | Z |
|----------|---|
| ACC < 0  | L |
| Overflow | V |
| Carry    | С |

A conditional instruction contains two of these 4-bit fields. The 4-LSB field of the instruction is a mask field. A 1 in the corresponding mask bit indicates that condition is being tested. For example, to test for ACC  $\geq$  0, the Z and L fields are set, and the V and C fields are not set. The Z field is set to test the condition ACC  $\geq$  0, and the L field is reset to test the condition ACC  $\geq$  0. The second 4-bit field (bits 4 – 7) indicates the state of the conditions to test. The conditions possible with these eight bits are shown in the descriptions for the BCND, CC, and RETC instructions.

+ 1 word The second word of a 2-word opcode. This second word contains a 16-bit constant. Depending on the instruction, this constant is a long immediate value, a program memory address, or an address for an I/O port or an I/O-mapped register.

| Mnemonic | Description                                                           | Words | Cycles | Opcode                          |
|----------|-----------------------------------------------------------------------|-------|--------|---------------------------------|
| ABS      | Absolute value of ACC                                                 | 1     | 1      | 1011 1110 0000 0000             |
| ADD      | Add to ACC with shift of 0 to 15, direct or indirect                  | 1     | 1      | 0010 SHFT IAAA AAAA             |
|          | Add to ACC with shift 0 to 15, long immediate                         | 2     | 2      | 1011 1111 1001 SHFT<br>+ 1 word |
|          | Add to ACC with shift of 16, direct or indirect                       | 1     | 1      | 0110 0001 IAAA AAAA             |
|          | Add to ACC, short immediate                                           | 1     | 1      | 1011 1000 IIII IIII             |
| ADDC     | Add to ACC with carry, direct or indirect                             | 1     | 1      | 0110 0000 IAAA AAAA             |
| ADDS     | Add to low ACC with sign-extension suppressed, direct or indirect     | 1     | 1      | 0110 0010 IAAA AAAA             |
| ADDT     | Add to ACC with shift (0 to 15) specified by TREG, direct or indirect | 1     | 1      | 0110 0011 IAAA AAAA             |
| AND      | AND ACC with data value, direct or indirect                           | 1     | 1      | 0110 1110 IAAA AAAA             |
|          | AND with ACC with shift of 0 to 15, long immediate                    | 2     | 2      | 1011 1111 1011 SHFT<br>+ 1 word |
|          | AND with ACC with shift of 16, long immediate                         | 2     | 2      | 1011 1110 1000 0001<br>+ 1 word |
| CMPL     | Complement ACC                                                        | 1     | 1      | 1011 1110 0000 0001             |
| LACC     | Load ACC with shift of 0 to 15, direct or indirect                    | 1     | 1      | 0001 SHFT IAAA AAAA             |
|          | Load ACC with shift of 0 to 15, long immediate                        | 2     | 2      | 1011 1111 1000 SHFT<br>+ 1 word |
|          | Load ACC with shift of 16, direct or indirect                         | 1     | 1      | 0110 1010 IAAA AAAA             |
| LACL     | Load low word of ACC, direct or indirect                              | 1     | 1      | 0110 1001 IAAA AAAA             |
|          | Load low word of ACC, short immediate                                 | 1     | 1      | 1011 1001                       |
| LACT     | Load ACC with shift (0 to 15) specified by TREG, direct or indirect   | 1     | 1      | 0110 1011 IAAA AAAA             |
| NEG      | Negate ACC                                                            | 1     | 1      | 1011 1110 0000 0010             |
| NORM     | Normalize the contents of ACC, indirect                               | 1     | 1      | 1010 0000 IAAA AAAA             |
| OR       | OR ACC with data value, direct or indirect                            | 1     | 1      | 0110 1101 IAAA AAAA             |

Assembly Language Instructions 8-5

| Mnemonic | Description                                                                  | Words | Cycles | Opcode                          |
|----------|------------------------------------------------------------------------------|-------|--------|---------------------------------|
|          | OR with ACC with shift of 0 to 15, long immediate                            | 2     | 2      | 1011 1111 1100 SHFT<br>+ 1 word |
|          | OR with ACC with shift of 16, long immediate                                 | 2     | 2      | 1011 1110 1000 0010<br>+ 1 word |
| ROL      | Rotate ACC left                                                              | 1     | 1      | 1011 1110 0000 1100             |
| ROR      | Rotate ACC right                                                             | 1     | 1      | 1011 1110 0000 1101             |
| SACH     | Store high ACC with shift of 0 to 7, direct or indirect                      | 1     | 1      | 1001 1SHF IAAA AAAA             |
| SACL     | Store low ACC with shift of 0 to 7, direct or indirect                       | 1     | 1      | 1001 0SHF IAAA AAAA             |
| SFL      | Shift ACC left                                                               | 1     | 1      | 1011 1110 0000 1001             |
| SFR      | Shift ACC right                                                              | 1     | 1      | 1011 1110 0000 1010             |
| SUB      | Subtract from ACC with shift of 0 to 15, direct or indirect                  | 1     | 1      | 0011 SHFT IAAA AAAA             |
|          | Subtract from ACC with shift of 0 to 15, long immediate                      | 2     | 2      | 1011 1111 1010 SHFT<br>+ 1 word |
|          | Subtract from ACC with shift of 16, direct or indirect                       | 1     | 1      | 0110 0101 IAAA AAAA             |
|          | Subtract from ACC, short immediate                                           | 1     | 1      | 1011 1010                       |
| SUBB     | Subtract from ACC with borrow, direct or indirect                            | 1     | 1      | 0110 0100 IAAA AAAA             |
| SUBC     | Conditional subtract, direct or indirect                                     | 1     | 1      | 0000 1010 IAAA AAAA             |
| SUBS     | Subtract from ACC with sign-extension<br>suppressed, direct or indirect      | 1     | 1      | 0110 0110 IAAA AAAA             |
| SUBT     | Subtract from ACC with shift (0 to 15) specified by TREG, direct or indirect | 1     | 1      | 0110 0111 IAAA AAAA             |
| XOR      | Exclusive OR ACC with data value, direct or indirect                         | 1     | 1      | 0110 1100 IAAA AAAA             |
|          | Exclusive OR with ACC with shift of 0 to 15, long immediate                  | 2     | 2      | 1011 1111 1101 SHFT<br>+ 1 word |
|          | Exclusive OR with ACC with shift of 16, long immediate                       | 2     | 2      | 1011 1110 1000 0011<br>+ 1 word |
| ZALR     | Zero low ACC and load high ACC with rounding, direct or indirect             | 1     | 1      | 0110 1000 IAAA AAAA             |

Table 8–1. Accumulator, Arithmetic, and Logic Instructions (Continued)

| Mnemonic | Description                                                                      | Words | Cycles                                    | Opcode                          |
|----------|----------------------------------------------------------------------------------|-------|-------------------------------------------|---------------------------------|
| ADRK     | Add constant to current AR, short immediate                                      | 1     | 1                                         | 0111 1000                       |
| BANZ     | Branch on current AR not 0, indirect                                             | 2     | 4 (condition true)<br>2 (condition false) | 0111 1011 1AAA AAAA<br>+ 1 word |
| CMPR     | Compare current AR with AR0                                                      | 1     | 1                                         | 1011 1111 0100 01CM             |
| LAR      | Load specified AR from<br>specified data location,<br>direct or indirect         | 1     | 2                                         | 0000 OARX IAAA AAAA             |
|          | Load specified AR with constant, short immediate                                 | 1     | 2                                         | 1011 OARX IIII IIII             |
|          | Load specified AR with constant, long immediate                                  | 2     | 2                                         | 1011 1111 0000 1ARX<br>+ 1 word |
| MAR      | Modify current AR and/or ARP,<br>indirect (performs no operation<br>when direct) | 1     | 1                                         | 1000 1011 IAAA AAAA             |
| SAR      | Store specified AR to specified data location, direct or indirect                | 1     | 1                                         | 1000 OARX IAAA AAAA             |
| SBRK     | Subtract constant from current AR, short immediate                               | 1     | 1                                         | 0111 1100                       |

## Table 8–2. Auxiliary Register Instructions

| Mnemonic | Description                                                               | Words | Cycles | Opcode                          |
|----------|---------------------------------------------------------------------------|-------|--------|---------------------------------|
| APAC     | Add PREG to ACC                                                           | 1     | 1      | 1011 1110 0000 0100             |
| LPH      | Load high PREG, direct or indirect                                        | 1     | 1      | 0111 0101 IAAA AAAA             |
| LT       | Load TREG, direct or indirect                                             | 1     | 1      | 0111 0011 IAAA AAAA             |
| LTA      | Load TREG and accumulate previous product, direct or indirect             | 1     | 1      | 0111 0000 IAAA AAAA             |
| LTD      | Load TREG, accumulate previous product, and move data, direct or indirect | 1     | 1      | 0111 0010 IAAA AAAA             |
| LTP      | Load TREG and store PREG in accumulator, direct or indirect               | 1     | 1      | 0111 0001 IAAA AAAA             |
| LTS      | Load TREG and subtract previous product, direct or indirect               | 1     | 1      | 0111 0100 IAAA AAAA             |
| MAC      | Multiply and accumulate, direct or indirect                               | 2     | 3      | 1010 0010 IAAA AAAA<br>+ 1 word |
| MACD     | Multiply and accumulate with data move, direct or indirect                | 2     | 3      | 1010 0011 IAAA AAAA<br>+ 1 word |
| MPY      | Multiply TREG by data value, direct or indirect                           | 1     | 1      | 0101 0100 IAAA AAAA             |
|          | Multiply TREG by 13-bit constant, short immediate                         | 1     | 1      | 110                             |
| MPYA     | Multiply and accumulate previous product, direct or indirect              | 1     | 1      | 0101 0000 IAAA AAAA             |
| MPYS     | Multiply and subtract previous product, direct or in-<br>direct           | 1     | 1      | 0101 0001 IAAA AAAA             |
| MPYU     | Multiply unsigned, direct or indirect                                     | 1     | 1      | 0101 0101 IAAA AAAA             |
| PAC      | Load ACC with PREG                                                        | 1     | 1      | 1011 1110 0000 0011             |
| SPAC     | Subtract PREG from ACC                                                    | 1     | 1      | 1011 1110 0000 0101             |
| SPH      | Store high PREG, direct or indirect                                       | 1     | 1      | 1000 1101 IAAA AAAA             |
| SPL      | Store low PREG, direct or indirect                                        | 1     | 1      | 1000 1100 IAAA AAAA             |
| SPM      | Set product shift mode                                                    | 1     | 1      | 1011 1111 0000 00PM             |
| SQRA     | Square and accumulate previous product, direct or indirect                | 1     | 1      | 0101 0010 IAAA AAAA             |
| SQRS     | Square and subtract previous product, direct or indirect                  | 1     | 1      | 0101 0011 IAAA AAAA             |

## Table 8–3. TREG, PREG, and Multiply Instructions

| Mnemonic | Description                                  | Words | Cycles                                         | Opcode                          |
|----------|----------------------------------------------|-------|------------------------------------------------|---------------------------------|
| В        | Branch unconditionally, indirect             | 2     | 4                                              | 0111 1001 1AAA AAAA<br>+ 1 word |
| BACC     | Branch to address specified by ACC           | 1     | 4                                              | 1011 1110 0010 0000             |
| BANZ     | Branch on current AR not 0, indirect         | 2     | 4 (condition true)<br>2 (condition false)      | 0111 1011 1AAA AAAA<br>+ 1 word |
| BCND     | Branch conditionally                         | 2     | 4 (conditions true)<br>2 (any condition false) | 1110 00TP ZLVC ZLVC<br>+ 1 word |
| CALA     | Call subroutine at location specified by ACC | 1     | 4                                              | 1011 1110 0011 0000             |
| CALL     | Call subroutine, indirect                    | 2     | 4                                              | 0111 1010 1AAA AAAA<br>+ 1 word |
| CC       | Call conditionally                           | 2     | 4 (conditions true)<br>2 (any condition false) | 1110 10TP ZLVC ZLVC<br>+ 1 word |
| INTR     | Soft interrupt                               | 1     | 4                                              | 1011 1110 011I NTR#             |
| NMI      | Nonmaskable interrupt                        | 1     | 4                                              | 1011 1110 0101 0010             |
| RET      | Return from subroutine                       | 1     | 4                                              | 1110 1111 0000 0000             |
| RETC     | Return conditionally                         | 1     | 4 (conditions true)<br>2 (any condition false) | 1110 11TP ZLVC ZLVC             |
| TRAP     | Software interrupt                           | 1     | 4                                              | 1011 1110 0101 0001             |

## Table 8–4. Branch Instructions

| Mnemonic | Description                                            | Words | Cycles | Opcode              |
|----------|--------------------------------------------------------|-------|--------|---------------------|
| BIT      | Test bit, direct or indirect                           | 1     | 1      | 0100 BITX IAAA AAAA |
| BITT     | Test bit specified by TREG, direct or indirect         | 1     | 1      | 0110 1111 IAAA AAAA |
| CLRC     | Clear C bit                                            | 1     | 1      | 1011 1110 0100 1110 |
|          | Clear CNF bit                                          | 1     | 1      | 1011 1110 0100 0100 |
|          | Clear INTM bit                                         | 1     | 1      | 1011 1110 0100 0000 |
|          | Clear OVM bit                                          | 1     | 1      | 1011 1110 0100 0010 |
|          | Clear SXM bit                                          | 1     | 1      | 1011 1110 0100 0110 |
|          | Clear TC bit                                           | 1     | 1      | 1011 1110 0100 1010 |
|          | Clear XF bit                                           | 1     | 1      | 1011 1110 0100 1100 |
| IDLE     | Idle until interrupt                                   | 1     | 1      | 1011 1110 0010 0010 |
| LDP      | Load data page pointer,<br>direct or indirect          | 1     | 2      | 0000 1101 IAAA AAAA |
|          | Load data page pointer,<br>short immediate             | 1     | 2      | 1011 110I IIII IIII |
| LST      | Load status register ST0, direct or indirect           | 1     | 2      | 0000 1110 IAAA AAAA |
|          | Load status register ST1, direct or indirect           | 1     | 2      | 0000 1111 IAAA AAAA |
| NOP      | No operation                                           | 1     | 1      | 1000 1011 0000 0000 |
| POP      | Pop top of stack to low ACC                            | 1     | 1      | 1011 1110 0011 0010 |
| POPD     | Pop top of stack to data memory, direct or indirect    | 1     | 1      | 1000 1010 IAAA AAAA |
| PSHD     | Push data memory value on stack, direct or<br>indirect | 1     | 1      | 0111 0110 IAAA AAAA |
| PUSH     | Push low ACC onto stack                                | 1     | 1      | 1011 1110 0011 1100 |
| RPT      | Repeat next instruction, direct or indirect            | 1     | 1      | 0000 1011 IAAA AAAA |
|          | Repeat next instruction, short immediate               | 1     | 1      | 1011 1011           |
| SETC     | Set C bit                                              | 1     | 1      | 1011 1110 0100 1111 |
|          | Set CNF bit                                            | 1     | 1      | 1011 1110 0100 0101 |
|          | Set INTM bit                                           | 1     | 1      | 1011 1110 0100 0001 |
|          | Set OVM bit                                            | 1     | 1      | 1011 1110 0100 0011 |
|          | Set SXM bit                                            | 1     | 1      | 1011 1110 0100 0111 |
|          | Set TC bit                                             | 1     | 1      | 1011 1110 0100 1011 |
|          | Set XF bit                                             | 1     | 1      | 1011 1110 0100 1101 |
| SPM      | Set product shift mode                                 | 1     | 1      | 1011 1111 0000 00PM |
| SST      | Store status register ST0, direct or indirect          | 1     | 1      | 1000 1110 IAAA AAAA |
|          | Store status register ST1, direct or indirect          | 1     | 1      | 1000 1111 IAAA AAAA |

## Table 8–5. Control Instructions

| Mnemonic | Description                                                                                    | Words | Cycles | Opcode                          |
|----------|------------------------------------------------------------------------------------------------|-------|--------|---------------------------------|
| BLDD     | Block move from data memory to data memory,<br>direct/indirect with long immediate source      |       | 3      | 1010 1000 IAAA AAAA<br>+ 1 word |
|          | Block move from data memory to data memory,<br>direct/indirect with long immediate destination | 2     | 3      | 1010 1001 IAAA AAAA<br>+ 1 word |
| BLPD     | Block move from program memory to data memory, direct/indirect with long immediate source      | 2     | 3      | 1010 0101 IAAA AAAA<br>+ 1 word |
| DMOV     | Data move in data memory, direct or indirect                                                   | 1     | 1      | 0111 0111 IAAA AAAA             |
| IN       | Input data from I/O location, direct or indirect                                               | 2     | 2      | 1010 1111 IAAA AAAA<br>+ 1 word |
| OUT      | Output data to port, direct or indirect                                                        | 2     | 3      | 0000 1100 IAAA AAAA<br>+ 1 word |
| SPLK     | Store long immediate to data memory location, direct or indirect                               | 2     | 2      | 1010 1110 IAAA AAAA<br>+ 1 word |
| TBLR     | Table read, direct or indirect                                                                 | 1     | 3      | 1010 0110 IAAA AAAA             |
| TBLW     | Table write, direct or indirect                                                                | 1     | 3      | 1010 0111 IAAA AAAA             |

## Table 8–6. I/O and Memory Instructions

## 8.2 How To Use the Instruction Descriptions

Section 8.3 contains detailed information on the instruction set. The description for each instruction presents the following categories of information:

- Syntax
- Operands
- Opcode
- Execution
- Status Bits
- Description
- Words
- Cycles
- Examples

#### 8.2.1 Syntax

Each instruction begins with a list of the available assembler syntax expressions and the addressing mode type(s) for each expression. For example, the description for the ADD instruction begins with:

| ADD dma [, shift]                                              | Direct addressing              |
|----------------------------------------------------------------|--------------------------------|
| ADD dma, 16                                                    | Direct with left shift of 16   |
| <b>ADD</b> <i>ind</i> [, <i>shift</i> [, <b>AR</b> <i>n</i> ]] | Indirect addressing            |
| ADD ind, 16 [, ARn]                                            | Indirect with left shift of 16 |
| ADD #k                                                         | Short immediate addressing     |
| ADD #lk [, shift]                                              | Long immediate addressing      |

These are the notations used in the syntax expressions:

| italic                 | •                      | ls in an instruction syntax represent variables.                                     |
|------------------------|------------------------|--------------------------------------------------------------------------------------|
| symbols                | Example:               | For the syntax                                                                       |
|                        |                        | ADD dma                                                                              |
|                        |                        | you may use a variety of values for <i>dma</i> .<br>Samples with this syntax follow: |
|                        |                        | ADD DAT                                                                              |
|                        |                        | ADD 15                                                                               |
| boldface<br>characters | Boldface cha<br>shown. | aracters in an instruction syntax must be typed as                                   |
|                        | Example:               | For the syntax<br><b>ADD</b> <i>dma</i> , <b>16</b>                                  |

you may use a variety of values for *dma*, but the word ADD and the number 16 must be typed as shown. Samples with this syntax follow: ADD 7h, 16 ADD X, 16

| [, X]         | Operand x is optional.<br>Example: For the syntax<br>ADD dma, [, shift]<br>you must supply dma, as in the instruction:<br>ADD 7h<br>and you have the option of adding a shift value,<br>as in the instruction:<br>ADD 7h, 5                                                                                                                                                                                                                                               |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [, x1 [, x2]] | Operands x1 and x2 are optional, but you cannot include x2<br>without also including x1.<br><i>Example:</i> For the syntax<br><b>ADD</b> <i>ind</i> , [, <i>shift</i> [, <b>AR</b> <i>n</i> ]]<br>you must supply <i>ind</i> , as in the instruction:<br>ADD *+<br>You have the option of including <i>shift</i> ,<br>as in the instruction:<br>ADD *+, 5<br>If you wish to include <b>AR</b> <i>n</i> , you must also<br>include <i>shift</i> , as in:<br>ADD *+, 0, AR2 |
| #             | The # symbol is a prefix for constants used in immediate<br>addressing. For short- or long- immediate operands, it is<br>used in instructions where there is ambiguity with other<br>addressing modes.<br><i>Example:</i> RPT #15 uses short immediate addressing. It<br>causes the next instruction to be repeated<br>16 times. But RPT 15 uses direct addressing.<br>The number of times the next instruction                                                           |

Finally, consider this code example:

| MoveData | BLDD | DAT5, | #310h | ;move data at address      |      |
|----------|------|-------|-------|----------------------------|------|
|          |      |       |       | ;referenced by DAT5 to add | ress |
|          |      |       |       | ;310h.                     |      |

memory.

repeats is determined by a value stored in

Note the optional MoveData label is used as a reference in front of the instruction mnemonic. Place labels either before the instruction mnemonic on the same line or on the preceding line in the first column. (Be sure there are no spaces in your labels.) An optional comment field can conclude the syntax expression. At least one space is required between fields (label, mnemonic, operand, and comment).

#### 8.2.2 Operands

Operands can be constants, or assembly-time expressions referring to memory, I/O ports, register addresses, pointers, shift counts, and a variety of other constants. The operands category for each instruction description defines the variables used for and/or within operands in the syntax expressions. For example, for the ADD instruction, the syntax category gives these syntax expressions:

| ADD dma [, shift]                                              | Direct addressing              |
|----------------------------------------------------------------|--------------------------------|
| ADD dma, 16                                                    | Direct with left shift of 16   |
| <b>ADD</b> <i>ind</i> [, <i>shift</i> [, <b>AR</b> <i>n</i> ]] | Indirect addressing            |
| ADD ind, 16 [, ARn]                                            | Indirect with left shift of 16 |
| ADD #k                                                         | Short immediate addressing     |
| ADD #lk [, shift]                                              | Long immediate addressing      |

The operands category defines the variables *dma*, *shift*, *ind*, *n*, *k*, and *lk*. For *ind*, an indirect addressing variable, you supply one of the following seven symbols:

\* \*+ \*- \*0+ \*0- \*BR0+ \*BR0-

These symbols are defined in subsection 7.3.2, *Indirect Addressing Options*, on page 7-9.

#### 8.2.3 Opcode

The opcode category breaks down the various bit fields that make up each instruction word. When one of the fields contains a constant value derived directly from an operand, it has the same name as that operand. The contents of fields that do not directly relate to operands have other names; the opcode category either explains these names directly or refers you to a section of this book that explains them in detail. For example, these opcodes are given for the ADDC instruction:

| ADI | DC d  | ma      |                      |    |    |   |   |   |     |   |   |     |   |     |   |  |
|-----|-------|---------|----------------------|----|----|---|---|---|-----|---|---|-----|---|-----|---|--|
| 15  | 14    | 13      | 12                   | 11 | 10 | 9 | 8 | 7 | 6   | 5 | 4 | 3   | 2 | 1   | 0 |  |
| 0   | 1     | 1       | 0                    | 0  | 0  | 0 | 0 | 0 |     |   |   | dma |   |     |   |  |
| ADI | DC ir | nd [, I | <b>4R</b> <i>n</i> ] |    |    |   |   |   |     |   |   |     |   |     |   |  |
| 15  | 14    | 13      | 12                   | 11 | 10 | 9 | 8 | 7 | 6   | 5 | 4 | 3   | 2 | 1   | 0 |  |
| 0   | 1     | 1       | 0                    | 0  | 0  | 0 | 0 | 1 | ARU |   |   | Ν   |   | NAR |   |  |
|     |       |         |                      |    |    |   | - |   |     |   |   |     |   |     |   |  |

Note: ARU, N, and NAR are defined in Section 7.3, Indirect Addressing Mode (page 7-9).

The field called dma contains the value *dma*, which is defined in the operands category. The contents of the fields ARU, N, and NAR are derived from the operands *ind* and *n* but do not directly correspond to those operands; therefore, a note directs you to the appropriate section for more details.

#### 8.2.4 Execution

The execution category presents an instruction operation sequence that describes the processing that takes place when the instruction is executed. If the execution event or events depend on the addressing mode used, the execution category specifies which events are associated with which addressing modes. Here are notations used in the execution category:

| (r)       | The content<br>Example:          | of register or location r.<br>(ACC) represents the value in the accumulator.                                                                                            |
|-----------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $x \to y$ | Value x is as<br><i>Example:</i> | signed to register or location y.<br>(data-memory address) $\rightarrow$ ACC means:<br>The content of the specified data-memory<br>address is put into the accumulator. |
| r(n:m)    | Bits n throug<br><i>Example:</i> | h m of register or location r.<br>ACC(15:0) represents bits 15 through 0 of the accumulator.                                                                            |
| (r(n:m))  | The content <i>Example:</i>      | of bits n through m of register or location r.<br>(ACC(31:16)) represents the content of bits 31<br>through 16 of the accumulator.                                      |
| nnh       | Indicates tha                    | t nn represents a hexadecimal number.                                                                                                                                   |

#### 8.2.5 Status Bits

The bits in status registers ST0 and ST1 affect the operation of certain instructions and are affected by certain instructions. The status bits category of each instruction description states which of the bits (if any) affect the execution of the instruction and which of the bits (if any) are affected by the instruction.

#### 8.2.6 Description

The description category explains what happens during instruction execution and its effect on the rest of the processor or on memory contents. It also discusses any constraints on the operands imposed by the processor or the assembler. This description parallels and supplements the information given in the execution category.

#### 8.2.7 Words

The words category specifies the number of memory words required to store the instruction (one or two). When the number of words depends on the addressing mode used for an instruction, the words category specifies which addressing modes require one word and which require two words.

#### 8.2.8 Cycles

The cycles category of each instruction description contains tables showing the number of processor machine cycles (CLKOUT1 periods) required for the instruction to execute in a given memory configuration when executed as a single instruction or when repeated with the RPT instruction. For example:

. ..

|          | Program |       |       |          |  |  |  |  |  |  |  |  |  |  |
|----------|---------|-------|-------|----------|--|--|--|--|--|--|--|--|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |  |  |  |  |  |  |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |  |  |  |  |  |  |  |  |
| SARAM    | 1       | 1     | 1     | 1+p      |  |  |  |  |  |  |  |  |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |  |  |  |  |  |  |  |

#### Cycles for a Repeat (RPT) Execution of an Instruction

|          | Program |       |       |          |  |  |  |  |  |  |  |  |
|----------|---------|-------|-------|----------|--|--|--|--|--|--|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |  |  |  |  |  |  |
| DARAM    | n       | n     | n     | n+p      |  |  |  |  |  |  |  |  |
| SARAM    | n       | n     | n     | n+p      |  |  |  |  |  |  |  |  |
| External | n+nd    | n+nd  | n+nd  | n+1+p+nd |  |  |  |  |  |  |  |  |

The column headings in these tables indicate the program source location, defined as follows:

| ROM      | The instruction executes from internal program ROM.               |
|----------|-------------------------------------------------------------------|
| DARAM    | The instruction executes from internal dual-access program RAM.   |
| SARAM    | The instruction executes from internal single-access program RAM. |
| External | The instruction executes from external program memory.            |

If an instruction requires memory operand(s), the rows in the table indicate the location(s) of the operand(s), as defined here:

| DARAM    | The operand is in internal dual-access RAM.   |
|----------|-----------------------------------------------|
| SARAM    | The operand is in internal single-access RAM. |
| External | The operand is in external memory.            |

For the RPT mode execution, *n* indicates the number of times a given instruction is repeated by an RPT instruction. Additional cycles (wait states) can be generated for program-memory, data-memory, and I/O accesses by the waitstate generator or by the external READY signal. These additional wait states are represented in the tables by the following variables:

- p Program-memory wait states. Represents the number of additional clock cycles the device waits for external program memory to respond to a single access.
- d Data-memory wait states. Represents the number of additional clock cycles the device waits for external data memory to respond to a single access.
- io I/O wait states. Represents the number of additional clock cycles the device waits for an external I/O device to respond to a single access.
- n Number of repetitions (where n > 2 to fill the pipeline). Represents the number of times a repeated instruction is executed.

If there are multiple accesses to one of the spaces, the variable is preceded by the appropriate integer multiple. For example, two accesses to external program memory would require 2p wait states. The above variables may also use the subscripts *src*, *dst*, and *code* to indicate source, destination, and code, respectively.

The internal single-access memory on each 'C24x processor is divided into 2K-word blocks contiguous in address space. All 'C24x processors support parallel accesses to these internal single-access RAM blocks. Furthermore, one single access block allows only one access per cycle. Thus, the processor can read/write on single-access RAM block while accessing another single-access RAM block at the same time.

All external reads take at least one machine cycle while all external writes take at least two machine cycles. However, if an external write is immediately followed or preceded by an external read cycle, then the external write requires three cycles. If the wait state generator or the READY pin is used to add m (m > 0) wait states to an external access, then external reads require m + 1 cycles, and external write accesses require m + 2 cycles.

The instruction-cycle timings are based on the following assumptions:

- At least the next four instructions are fetched from the same memory section (internal or external) that was used to fetch the current instruction (except in the case of PC discontinuity instructions, such as B, CALL, etc.)
- In the single-execution mode, there is no pipeline conflict between the current instruction and the instructions immediately preceding or following that instruction. The only exception is the conflict between the fetch phase of the pipeline and the memory read/write (if any) access of the instruction under consideration. See Section 5.2, *Pipeline Operation*, on page 5-7 for more information about pipeline operations.
- In the repeat execution mode, all conflicts caused by the pipelined execution of an instruction are considered.

#### 8.2.9 Examples

Example code is included for each instruction. The effect of the code on memory and/or registers is summarized. Consider this example of the ADD instruction:



Here are the facts and events represented in this example:

- The auxiliary register pointer (ARP) points to the current auxiliary register. Because ARP = 4, the current auxiliary register is AR4.
- When the addition takes place, the CPU follows AR4 to data-memory address 0302h. The content of that address, 2h, is added to the content of the accumulator, also 2h. The result (4h) is placed in the accumulator. (Because the second operand of the instruction specifies a left shift of 0, the data-memory value is not shifted before being added to the accumulator value.)

- ☐ The instruction specifies an increment of 1 for the contents of the current auxiliary register (\*+); therefore, after the addition is performed, the content of AR4 is incremented to 0303h.
- ☐ The instruction also specifies that AR0 is the next auxiliary register; therefore, after the instruction ARP = 0.
- □ Because no carry is generated during the addition, the carry bit (C) is cleared to 0.

## 8.3 Instruction Descriptions

This section contains detailed information on the instruction set for the 'C24x. A summary of the instruction set is shown in Section 8.1 on page 8-2. The instructions are presented alphabetically, and the description for each instruction presents the following categories of information:

- Syntax
- Operands
- Opcode
- Execution
- Status Bits
- Description
- U Words
- Cycles
- **Examples**

For a description of how to use each of these categories, see Section 8.2 on page 8-12.

| Syntax      | ABS                                                                                                                                                                                                                                                                                                                                            |         |         |         |         |        |        |        |        |        |      |        |        |        |      |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|---------|---------|--------|--------|--------|--------|--------|------|--------|--------|--------|------|
| Operands    | None                                                                                                                                                                                                                                                                                                                                           |         |         |         |         |        |        |        |        |        |      |        |        |        |      |
| Opcode      | 15 14<br>1 0                                                                                                                                                                                                                                                                                                                                   | 13<br>1 | 12<br>1 | 11<br>1 | 10<br>1 | 9<br>1 | 8<br>0 | 7<br>0 | 6<br>0 | 5<br>0 | 4    | 3<br>0 | 2<br>0 | 1<br>0 | 0    |
| Execution   | Increment PC, then $ (ACC)  \rightarrow ACC; 0 \rightarrow C$                                                                                                                                                                                                                                                                                  |         |         |         |         |        |        |        |        |        |      |        |        |        |      |
| Status Bits | <u>Affected by</u> <u>Affects</u><br>OVM C and OV                                                                                                                                                                                                                                                                                              |         |         |         |         |        |        |        |        |        |      |        |        |        |      |
|             | This instruction is not affected by SXM                                                                                                                                                                                                                                                                                                        |         |         |         |         |        |        |        |        |        |      |        |        |        |      |
| Description | If the contents of the accumulator are greater than or equal to 0, the accumula-<br>tor is unchanged by the execution of ABS. If the contents of the accumulator<br>are less than 0, the accumulator is replaced by its 2s-complement value. The<br>carry bit (C) on the 'C24x is always reset to 0 by the execution of this instruc-<br>tion. |         |         |         |         |        |        |        |        |        |      |        |        |        |      |
|             | Note that 8000 0000h is a special case. When the overflow mode is not set $(OVM = 0)$ , the ABS of 8000 0000h is 8000 0000h. When the overflow mode is set $(OVM = 1)$ , the ABS of 8000 0000h is 7FFF FFFFh. In either case, the OV status bit is set.                                                                                        |         |         |         |         |        |        |        |        |        |      |        |        |        | mode |
| Words       | 1                                                                                                                                                                                                                                                                                                                                              |         |         |         |         |        |        |        |        |        |      |        |        |        |      |
| Cycles      |                                                                                                                                                                                                                                                                                                                                                |         |         | Су      | cles f  | or a   | Singl  | e AB   | S Ins  | struct | tion |        |        |        |      |
|             | ROM DARAM SARAM External                                                                                                                                                                                                                                                                                                                       |         |         |         |         |        |        |        |        |        |      |        |        |        |      |
|             | 1 1 1 1+p                                                                                                                                                                                                                                                                                                                                      |         |         |         |         |        |        |        |        |        |      |        |        |        |      |
|             |                                                                                                                                                                                                                                                                                                                                                |         |         |         |         |        |        |        |        |        |      |        |        |        |      |

| Cycles for a Rep | peat (RPT) Execut | ion of an ABS Instruction |
|------------------|-------------------|---------------------------|
|------------------|-------------------|---------------------------|

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| n   | n     | n     | n+p      |



| Syntax   | ADD dma, 16<br>ADD ind [, shift [, ARn]]<br>ADD ind, 16 [, ARn]<br>ADD #k                                                                                                                                                                                                 |       |                      |               |              |          |        |         |         |        |         |       | Direct addressing<br>Direct with left shift of 16<br>Indirect addressing<br>Indirect with left shift of 16<br>Short immediate addressing<br>Long immediate addressing |       |               |      |  |  |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------|---------------|--------------|----------|--------|---------|---------|--------|---------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------------|------|--|--|--|
| Operands | dma:7 LSBs of the data-memory addressshift:Left shift value from 0 to 15 (defaults to 0)n:Value from 0 to 7 designating the next auxiliary registerk:8-bit short immediate valuelk:16-bit long immediate valueind:Select one of the following seven options:**+**0+**BR0+ |       |                      |               |              |          |        |         |         |        |         |       |                                                                                                                                                                       |       |               |      |  |  |  |
| Opcode   | Α                                                                                                                                                                                                                                                                         | DD d  | <i>ma</i> [,         | shift]        |              |          |        |         |         |        |         |       |                                                                                                                                                                       |       |               |      |  |  |  |
|          | 15                                                                                                                                                                                                                                                                        | 5 14  | 13                   | 12            | 11           | 10       | 9      | 8       | 7       | 6      | 5       | 4     | 3                                                                                                                                                                     | 2     | 1             | 0    |  |  |  |
|          | 0                                                                                                                                                                                                                                                                         | 0     | 1                    | 0             |              | sh       | nift   |         | 0       |        |         |       | dma                                                                                                                                                                   |       |               |      |  |  |  |
|          |                                                                                                                                                                                                                                                                           |       | <i>ma</i> , <b>1</b> |               |              | 4.0      | •      |         | _       | •      | _       |       | •                                                                                                                                                                     | •     |               | •    |  |  |  |
|          | 15                                                                                                                                                                                                                                                                        | -     | -                    | 12<br>0       | 11<br>0      | 10       | 9      | 8       | 7       | 6      | 5       | 4     | 3                                                                                                                                                                     | 2     | 1             | 0    |  |  |  |
|          | 0                                                                                                                                                                                                                                                                         |       | -                    | 0             | 0            | 0        | 0      | I       | 0       |        | dma     |       |                                                                                                                                                                       |       |               |      |  |  |  |
|          | Α                                                                                                                                                                                                                                                                         | DD ir | nd[, si              | hift [,       | <b>AR</b> r  | 7]]      |        |         |         |        |         |       |                                                                                                                                                                       |       |               |      |  |  |  |
|          | 15                                                                                                                                                                                                                                                                        |       |                      | 12            | 11           | 10       | 9      | 8       | 7       | 6      | 5       | 4     | 3                                                                                                                                                                     | 2     | 1             | 0    |  |  |  |
|          | 0                                                                                                                                                                                                                                                                         | 0     | 1                    | 0             |              | sh       | nift   |         | 1       |        | ARU     |       | Ν                                                                                                                                                                     |       | NAR           |      |  |  |  |
|          | No                                                                                                                                                                                                                                                                        |       | ARU, N<br>(page 7    |               | NAR a        | re defir | ned ir | n subse | ction 7 | 7.3.4, | Indirec | t Add | ressing                                                                                                                                                               | д Орс | code Fo       | rmat |  |  |  |
|          | Α                                                                                                                                                                                                                                                                         | DD ir | nd, <b>16</b>        | [, <b>A</b> R | [ <i>n</i> ] |          |        |         |         |        |         |       |                                                                                                                                                                       |       |               |      |  |  |  |
|          | 15                                                                                                                                                                                                                                                                        | 5 14  | 13                   | 12            | 11           | 10       | 9      | 8       | 7       | 6      | 5       | 4     | 3                                                                                                                                                                     | 2     | 1             | 0    |  |  |  |
|          | 0                                                                                                                                                                                                                                                                         | 1     | 1                    | 0             | 0            | 0        | 0      | 1       | 1       |        | ARU     |       | Ν                                                                                                                                                                     |       | NAR           |      |  |  |  |
|          | No                                                                                                                                                                                                                                                                        |       | ARU, N<br>(page 7    |               | NAR a        | re defir | ned ir | subse   | ction 7 | 7.3.4, | Indirec | t Add | ressing                                                                                                                                                               | д Орс | <i>ode</i> Fo | rmat |  |  |  |
|          | A                                                                                                                                                                                                                                                                         | DD #  | k                    |               |              |          |        |         |         |        |         |       |                                                                                                                                                                       |       |               |      |  |  |  |
|          | 15                                                                                                                                                                                                                                                                        | 5 14  | 13                   | 12            | 11           | 10       | 9      | 8       | 7       | 6      | 5       | 4     | 3                                                                                                                                                                     | 2     | 1             | 0    |  |  |  |
|          | 1 0 1 1 1 0 0 0                                                                                                                                                                                                                                                           |       |                      |               |              |          |        |         |         |        |         |       | k                                                                                                                                                                     |       |               |      |  |  |  |
|          | Α                                                                                                                                                                                                                                                                         | DD #  | lk [, sł             | nift]         |              |          |        |         |         |        |         |       |                                                                                                                                                                       |       |               |      |  |  |  |
|          | 15                                                                                                                                                                                                                                                                        |       | 13                   | 12            | 11           | 10       | 9      | 8       | 7       | 6      | 5       | 4     | 3                                                                                                                                                                     | 2     | 1             | 0    |  |  |  |
|          | 1                                                                                                                                                                                                                                                                         | 0     | 1                    | 1             | 1            | 1        | 1      | 1       | 1       | 0      | 0       | 1     |                                                                                                                                                                       | S     | hift          |      |  |  |  |
|          |                                                                                                                                                                                                                                                                           |       |                      |               |              |          |        |         | k       |        |         |       |                                                                                                                                                                       |       |               |      |  |  |  |

| Execution   | <u>Event</u>                                                              | Increment PC, then<br><u>Event</u><br>(ACC) + ((data-memory address) $\times 2^{\text{shift}}$ ) $\rightarrow$ ACC                                                                                                                                                                                                                  |                                                                          |  |  |  |  |
|-------------|---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--|--|--|--|
|             | (ACC) + ((data-men                                                        | nory address) $	imes$ 2 <sup>16</sup> ) $ ightarrow$ ACC                                                                                                                                                                                                                                                                            | Direct or indirect<br>(shift of 16)                                      |  |  |  |  |
|             | $(ACC) + k \rightarrow ACC$                                               |                                                                                                                                                                                                                                                                                                                                     | Short immediate                                                          |  |  |  |  |
|             | (ACC) + lk $	imes$ 2 <sup>shift</sup> -                                   | $\rightarrow$ ACC                                                                                                                                                                                                                                                                                                                   | Long immediate                                                           |  |  |  |  |
| Status Bits | <u>Affected by</u><br>SXM and OVM                                         | <u>Affects</u><br>C and OV                                                                                                                                                                                                                                                                                                          | <u>Addressing mode</u><br>Direct or indirect                             |  |  |  |  |
|             | OVM                                                                       | C and OV                                                                                                                                                                                                                                                                                                                            | Short immediate                                                          |  |  |  |  |
|             | SXM and OVM                                                               | C and OV                                                                                                                                                                                                                                                                                                                            | Long immediate                                                           |  |  |  |  |
| Description | is left-shifted and ad<br>zero filled. High-ord<br>SXM = 0. The resul     | ddressed data memory location or a<br>ded to the accumulator. During shift<br>ler bits are sign extended if SXM<br>It is stored in the accumulator. W<br>the addition is unaffected by SXM a                                                                                                                                        | ing, low-order bits are<br>= 1 and zero filled if<br>hen short immediate |  |  |  |  |
|             |                                                                           | rect addressing and update the AR<br>ever, if you do not want a shift to oc<br>ole:                                                                                                                                                                                                                                                 |                                                                          |  |  |  |  |
|             | ADD *+,0,AR2                                                              |                                                                                                                                                                                                                                                                                                                                     |                                                                          |  |  |  |  |
|             | and is cleared (C =<br>with a shift of 16, the<br>carry bit is unaffected | Normally, the carry bit is set $(C = 1)$ if the result of the addition<br>and is cleared $(C = 0)$ if it does not generate a carry. How<br>with a shift of 16, the carry bit is set if a carry is generated<br>carry bit is unaffected. This allows the accumulator to ge<br>single carry when adding a 32-bit number to the accumu |                                                                          |  |  |  |  |
| Words       | <u>Words</u><br>1                                                         |                                                                                                                                                                                                                                                                                                                                     | <u>Addressing mode</u><br>Direct, indirect, or<br>short immediate        |  |  |  |  |
|             | 2                                                                         |                                                                                                                                                                                                                                                                                                                                     | Long immediate                                                           |  |  |  |  |

#### ADD Add to Accumulator

| Cycles fo | Cycles for a Single ADD Instruction (Using Direct and Indirect Addressing) |       |       |          |  |  |  |  |  |
|-----------|----------------------------------------------------------------------------|-------|-------|----------|--|--|--|--|--|
|           | Program                                                                    |       |       |          |  |  |  |  |  |
| Operand   | ROM                                                                        | DARAM | SARAM | External |  |  |  |  |  |
| DARAM     | 1                                                                          | 1     | 1     | 1+p      |  |  |  |  |  |
| SARAM     | 1                                                                          | 1     | 1, 2† | 1+p      |  |  |  |  |  |
| External  | 1+d                                                                        | 1+d   | 1+d   | 2+d+p    |  |  |  |  |  |

#### Cycles

#### <sup>†</sup> If the operand and the code are in the same SARAM block

# Cycles for a Repeat (RPT) Execution of an ADD Instruction (Using Direct and Indirect Addressing)

|          |      | Program |         |          |  |  |  |  |  |
|----------|------|---------|---------|----------|--|--|--|--|--|
| Operand  | ROM  | DARAM   | SARAM   | External |  |  |  |  |  |
| DARAM    | n    | n       | n       | n+p      |  |  |  |  |  |
| SARAM    | n    | n       | n, n+1† | n+p      |  |  |  |  |  |
| External | n+nd | n+nd    | n+nd    | n+1+p+nd |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

#### Cycles for a Single ADD Instruction (Using Short Immediate Addressing)

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| 1   | 1     | 1     | 1+p      |

#### Cycles for a Single ADD Instruction (Using Long Immediate Addressing)

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| 2   | 2     | 2     | 2+2p     |

Add to Accumulator **ADD** 

| Example 1 | ADD | 1,1 ; (DP = 6)<br>Before Instruction<br>Data Memory<br>301h 1h<br>ACC $X$ 2h<br>C                 | Data Memory<br>301h<br>ACC 0<br>C               | After Instruction 1h 04h                     |
|-----------|-----|---------------------------------------------------------------------------------------------------|-------------------------------------------------|----------------------------------------------|
| Example 2 | ADD | *+, 0, AR0<br>Before Instruction<br>ARP 4<br>AR4 0302h<br>Data Memory<br>302h 2h<br>ACC X 2h<br>C | ARP<br>AR4<br>Data Memory<br>302h<br>ACC 0<br>C | After Instruction<br>0<br>0303h<br>2h<br>04h |
| Example 3 | ADD | #1h ;Add short<br>Before Instruction<br>ACC X 2h<br>C                                             | immediate<br>ACC 0<br>C                         | After Instruction                            |
| Example 4 | ADD | #1111h,1 ;Add long in<br>Before Instruction<br>ACC X 2h<br>C                                      | mmediate with<br>ACC 0<br>C                     | n shift of 1<br>After Instruction<br>2224h   |

| Syntax      | ADD<br>ADD                                                                                                                                                                                                                                                                                                                                       |            |       | <b>R</b> <i>n</i> ]  |             |                        |      |                                |                 |       | Direc <sup>:</sup><br>Indire |        |         | •     |        |       |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------|----------------------|-------------|------------------------|------|--------------------------------|-----------------|-------|------------------------------|--------|---------|-------|--------|-------|
| Operands    | dma:<br>n:<br>ind:                                                                                                                                                                                                                                                                                                                               |            | Va    | alue f               | from<br>one | 0 to<br>of the         | 7 de | nemo<br>signa<br>lowinę<br>*0– | ting t<br>g sev | the n | ext a ption                  |        | ary re  | giste | ər     |       |
| Opcode      | AD                                                                                                                                                                                                                                                                                                                                               | DC a       | Ima   |                      |             |                        |      |                                |                 |       |                              |        |         |       |        |       |
| •           | 15                                                                                                                                                                                                                                                                                                                                               | 14         | 13    | 12                   | 11          | 10                     | 9    | 8                              | 7               | 6     | 5                            | 4      | 3       | 2     | 1      | 0     |
|             | 0                                                                                                                                                                                                                                                                                                                                                | 1          | 1     | 0                    | 0           | 0                      | 0    | 0                              | 0               |       |                              |        | dma     |       |        |       |
|             | AD                                                                                                                                                                                                                                                                                                                                               | DC ii      | nd [  | <b>AR</b> <i>n</i> ] |             |                        |      |                                |                 |       |                              |        |         |       |        |       |
|             | 15                                                                                                                                                                                                                                                                                                                                               | 14         | 13    | 12                   | 11          | 10                     | 9    | 8                              | 7               | 6     | 5                            | 4      | 3       | 2     | 1      | 0     |
|             | 0                                                                                                                                                                                                                                                                                                                                                | 1          | 1     | 0                    | 0           | 0                      | 0    | 0                              | 1               |       | ARU                          |        | Ν       |       | NAR    |       |
| Execution   | Not<br>Increi<br>(ACC                                                                                                                                                                                                                                                                                                                            | ہ»<br>ment | PC,   | '-12).<br>then       |             |                        |      | n subse<br>⊦ (C) -             |                 |       | , inaire                     | ci Add | iressir | ig Op | oae ro | rmat  |
| Status Bits | <u>Affec</u><br>OVM                                                                                                                                                                                                                                                                                                                              |            | Ľ     |                      |             | f <u>ects</u><br>and C | V    |                                |                 |       |                              |        |         |       |        |       |
|             | This i                                                                                                                                                                                                                                                                                                                                           | nstru      | ction | is no                | ot aff      | ected                  | by   | SXM.                           |                 |       |                              |        |         |       |        |       |
| Description | The contents of the addressed data-memory location and the value of the carry bit are added to the accumulator with sign extension suppressed. The carry bit is then affected in the normal manner: the carry bit is set ( $C = 1$ ) if the result of the addition generates a carry and is cleared ( $C = 0$ ) if it does not generate a carry. |            |       |                      |             |                        |      |                                |                 |       |                              |        |         |       |        |       |
|             | The A                                                                                                                                                                                                                                                                                                                                            |            | instr | ructio               | nca         | nbeu                   | ised | in per                         | rform           | ing n | nultip                       | le-pr  | ecisi   | on ar | ithme  | etic. |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                |            |       |                      |             |                        |      |                                |                 |       |                              |        |         |       |        |       |

Cycles

|          | Cycles for a Single ADDC Instruction |       |       |          |  |  |  |  |
|----------|--------------------------------------|-------|-------|----------|--|--|--|--|
| Program  |                                      |       |       |          |  |  |  |  |
| Operand  | ROM                                  | DARAM | SARAM | External |  |  |  |  |
| DARAM    | 1                                    | 1     | 1     | 1+p      |  |  |  |  |
| SARAM    | 1                                    | 1     | 1, 2† | 1+p      |  |  |  |  |
| External | 1+d                                  | 1+d   | 1+d   | 2+d+p    |  |  |  |  |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

| C)       | Cycles for a Repeat (RPT) Execution of an ADDC Instruction |       |         |          |  |  |  |  |
|----------|------------------------------------------------------------|-------|---------|----------|--|--|--|--|
| Program  |                                                            |       |         |          |  |  |  |  |
| Operand  | ROM                                                        | DARAM | SARAM   | External |  |  |  |  |
| DARAM    | n                                                          | n     | n       | n+p      |  |  |  |  |
| SARAM    | n                                                          | n     | n, n+1† | n+p      |  |  |  |  |
| External | n+nd                                                       | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block



| Syntax      | ADDS<br>ADDS                      |                                  |                                  | <b>R</b> <i>n</i> ]               |                                  |                                   |                                |                                |                       |                           | Direct<br>Indire                                    |                         |                        | -                    |                          |                     |
|-------------|-----------------------------------|----------------------------------|----------------------------------|-----------------------------------|----------------------------------|-----------------------------------|--------------------------------|--------------------------------|-----------------------|---------------------------|-----------------------------------------------------|-------------------------|------------------------|----------------------|--------------------------|---------------------|
| Operands    | dma:<br>n:<br>ind:                |                                  | Va                               | alue                              | from<br>one                      | of the                            | 7 de                           | signa                          | ting t<br>g sev       | the r                     | next au                                             |                         | ary re                 | giste                | er                       |                     |
| Opcode      |                                   | DS a                             |                                  | 10                                |                                  | 10                                | 0                              | 0                              | -                     | 0                         | -                                                   |                         | 0                      | 0                    |                          | 0                   |
|             | 15<br>0                           | 14                               | 13<br>1                          | 12<br>0                           | 11<br>0                          | 10<br>0                           | 9                              | 8                              | 7                     | 6                         | 5                                                   | 4                       | 3<br>dma               | 2                    | 1                        | 0                   |
|             |                                   |                                  |                                  | -                                 | •                                | •                                 |                                | •                              | •                     |                           |                                                     |                         | unia                   |                      |                          |                     |
|             | <b>AD</b><br>15                   | <b>DS</b> ii<br>14               | <i>ומ</i> ן, <i>ו</i><br>13      | <b>AR</b> <i>n</i> J<br>12        | 11                               | 10                                | 9                              | 8                              | 7                     | 6                         | 5                                                   | 4                       | 3                      | 2                    | 1                        | 0                   |
|             | 0                                 | 1                                | 1                                | 0                                 | 0                                | 0                                 | 1                              | 0                              | 1                     |                           | ARU                                                 |                         | N                      | _                    | NAR                      |                     |
| Execution   | Not<br>Increi<br>(ACC             | ہ)<br>ment                       | PC,                              | '-12).<br>then                    |                                  |                                   |                                |                                |                       | 7.3.4,                    | Indirec                                             | t Addi                  | ressing                | y Opc                | ode Fo                   | rmat                |
| Status Bits | <u>Affec</u><br>OVM               | <u>ted b</u>                     | Ľ                                |                                   |                                  | <i>ects</i><br>and C              | V                              |                                |                       |                           |                                                     |                         |                        |                      |                          |                     |
|             | This i                            | nstru                            | ction                            | is no                             | ot aff                           | ected                             | by S                           | SXM.                           |                       |                           |                                                     |                         |                        |                      |                          |                     |
| Description | lator v<br>numb<br>numb<br>with S | vith s<br>er, re<br>er. N<br>SXM | ign e:<br>gard<br>ote t<br>= 0 a | xtens<br>less o<br>hat A<br>.nd a | sion s<br>of SX<br>ADDS<br>shift | Suppro<br>M. Th<br>S proo<br>coun | esse<br>ne ac<br>duce<br>it of | ed. Th<br>ccum<br>es the<br>0. | e dat<br>ulato<br>sam | ta is t<br>r cor<br>ne re | on are<br>treated<br>ntents a<br>esults a<br>dition | d as a<br>are t<br>as a | an un<br>reate<br>n AD | sign<br>d as<br>D in | ed 16<br>a sigi<br>struc | -bit<br>ned<br>tion |
|             | is clea                           | -                                |                                  |                                   |                                  |                                   |                                |                                |                       |                           |                                                     |                         |                        | •                    |                          |                     |
| Words       | 1                                 |                                  |                                  |                                   |                                  |                                   |                                |                                |                       |                           |                                                     |                         |                        |                      |                          |                     |

| Cycles |
|--------|
|--------|

| Cycles for a Single ADDS Instruction |     |       |       |          |  |  |  |  |
|--------------------------------------|-----|-------|-------|----------|--|--|--|--|
| Program                              |     |       |       |          |  |  |  |  |
| Operand                              | ROM | DARAM | SARAM | External |  |  |  |  |
| DARAM                                | 1   | 1     | 1     | 1+p      |  |  |  |  |
| SARAM                                | 1   | 1     | 1, 2† | 1+p      |  |  |  |  |
| External                             | 1+d | 1+d   | 1+d   | 2+d+p    |  |  |  |  |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

| Cy       | Cycles for a Repeat (RPT) Execution of an ADDS Instruction |       |         |          |  |  |  |
|----------|------------------------------------------------------------|-------|---------|----------|--|--|--|
|          | Program                                                    |       |         |          |  |  |  |
| Operand  | ROM                                                        | DARAM | SARAM   | External |  |  |  |
| DARAM    | n                                                          | n     | n       | n+p      |  |  |  |
| SARAM    | n                                                          | n     | n, n+1† | n+p      |  |  |  |
| External | n+nd                                                       | n+nd  | n+nd    | n+1+p+nd |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block



| Syntax      |                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |         |               |             | Direct addressing<br>Indirect addressing |                 |       |                 |       |       |   |        |        |     |   |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---------------|-------------|------------------------------------------|-----------------|-------|-----------------|-------|-------|---|--------|--------|-----|---|
| Operands    | dma:<br>n:<br>ind:                                                                                                                                                                                                                                                                                                                                                                                                                            |       | Va      | alue          | from<br>one |                                          | 7 des<br>e foll | signa | ting t<br>g sev | the r | ext a |   | ary re | egiste | ər  |   |
| Opcode      | AD                                                                                                                                                                                                                                                                                                                                                                                                                                            | DT d  | ma      |               |             |                                          |                 |       |                 |       |       |   |        |        |     |   |
| -           | 15                                                                                                                                                                                                                                                                                                                                                                                                                                            | 14    | 13      | 12            | 11          | 10                                       | 9               | 8     | 7               | 6     | 5     | 4 | 3      | 2      | 1   | 0 |
|             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1     | 1       | 0             | 0           | 0                                        | 1               | 1     | 0               |       |       |   | dma    |        |     |   |
|             | AD                                                                                                                                                                                                                                                                                                                                                                                                                                            | DT ir | nd [. 🖌 | AR <i>n</i> ] |             |                                          |                 |       |                 |       |       |   |        |        |     |   |
|             | 15                                                                                                                                                                                                                                                                                                                                                                                                                                            | 14    | 13      | 12            | 11          | 10                                       | 9               | 8     | 7               | 6     | 5     | 4 | 3      | 2      | 1   | 0 |
|             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1     | 1       | 0             | 0           | 0                                        | 1               | 1     | 1               |       | ARU   |   | Ν      |        | NAR |   |
| Execution   | Note:ARU, N, and NAR are defined in subsection 7.3.4, Indirect Addressing Opcode Format<br>(page 7-12).ExecutionIncrement PC, then<br>(ACC) + [(data-memory address) $\times 2^{(TREG(3:0))}] \rightarrow (ACC)$                                                                                                                                                                                                                              |       |         |               |             |                                          | rmat            |       |                 |       |       |   |        |        |     |   |
| Status Bits | <u>Affec</u><br>SXM                                                                                                                                                                                                                                                                                                                                                                                                                           |       | _       |               |             | <i>ects</i><br>and C                     | )V              |       |                 |       |       |   |        |        |     |   |
| Description | <b>on</b> The data-memory value is left shifted and added to the accumulator, and the result replaces the accumulator contents. The left shift is defined by the four LSBs of the TREG, resulting in shift options from 0 to 15 bits. Sign extension on the data-memory value is controlled by SXM. The carry bit (C) is set when a carry is generated out of the MSB of the accumulator; if no carry is generated, the carry bit is cleared. |       |         |               |             |                                          |                 |       |                 |       |       |   |        |        |     |   |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |               |             |                                          |                 |       |                 |       |       |   |        |        |     |   |

| Cycles |
|--------|
|--------|

| Cycles for a Single ADDT Instruction |         |       |       |          |  |  |
|--------------------------------------|---------|-------|-------|----------|--|--|
|                                      | Program |       |       |          |  |  |
| Operand                              | ROM     | DARAM | SARAM | External |  |  |
| DARAM                                | 1       | 1     | 1     | 1+p      |  |  |
| SARAM                                | 1       | 1     | 1, 2† | 1+p      |  |  |
| External                             | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block.

| Cy       | Cycles for a Repeat (RPT) Execution of an ADDT Instruction |       |         |          |  |  |  |
|----------|------------------------------------------------------------|-------|---------|----------|--|--|--|
|          | Program                                                    |       |         |          |  |  |  |
| Operand  | ROM                                                        | DARAM | SARAM   | External |  |  |  |
| DARAM    | n                                                          | n     | n       | n+p      |  |  |  |
| SARAM    | n                                                          | n     | n, n+1† | n+p      |  |  |  |
| External | n+nd                                                       | n+nd  | n+nd    | n+1+p+nd |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block



Assembly Language Instructions 8-31

| Syntax      | ADRK #k                                                                                                                                                                                                                                                                                                                                                                            |                                |                               | Shor          | t immediate ado | dressing                |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-------------------------------|---------------|-----------------|-------------------------|--|
| Operands    | k:                                                                                                                                                                                                                                                                                                                                                                                 | k: 8-bit short immediate value |                               |               |                 |                         |  |
| Opcode      | <b>ADRK #</b> <i>k</i><br>15 14 1<br>0 1 -                                                                                                                                                                                                                                                                                                                                         | 3 12 11 10<br>I 1 1 0          |                               | 765           | 4 3 2<br>k      | 1 0                     |  |
| Execution   | Increment PC<br>(current AR)                                                                                                                                                                                                                                                                                                                                                       | C, then<br>+ 8-bit positive    | $constant \rightarrow c$      | current AR    |                 |                         |  |
| Status Bits | None                                                                                                                                                                                                                                                                                                                                                                               |                                |                               |               |                 |                         |  |
| Description | The 8-bit immediate value is added, right justified, to the current auxiliary regis-<br>ter (the one specified by the current ARP value) and the result replaces the<br>auxiliary register contents. The addition takes place in the ARAU, with the<br>immediate value treated as an 8-bit positive integer. All arithmetic operations<br>on the auxiliary registers are unsigned. |                                |                               |               |                 |                         |  |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                                                  |                                |                               |               |                 |                         |  |
| Cycles      |                                                                                                                                                                                                                                                                                                                                                                                    | Cycles f                       | or a Single AD                | ORK Instructi | on              |                         |  |
|             | ROM                                                                                                                                                                                                                                                                                                                                                                                | DARAM                          | SA                            | RAM           | External        |                         |  |
|             | 1                                                                                                                                                                                                                                                                                                                                                                                  | 1                              | 1                             |               | 1+p             |                         |  |
| Example     | ADRK<br>AF<br>AF                                                                                                                                                                                                                                                                                                                                                                   | RP                             | ore Instruction<br>5<br>4321h | ARP<br>AR5    | After Ins       | struction<br>5<br>43A1h |  |

| Syntax<br>Operands | AND dmaDirect addressingAND ind [, ARn]Indirect addressingAND #/k [, shift]Long immediate addressingAND #/k, 16Long immediate with leftdma:7 LSBs of the data-memory addressshift:Left shift value from 0 to 15 (defaults to 0)n:Value from 0 to 7 designating the next auxiliary registerlk:16-bit long immediate valueind:Select one of the following seven options:** +** -** +** -** BR0- |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Opcode             | AND dma                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0<br>0 1 1 0 1 1 1 0 0 dma                                                                                                                                                                                                                                                                                                                                |
|                    | 0 1 1 0 1 1 1 0 0 dma                                                                                                                                                                                                                                                                                                                                                                         |
|                    | AND ind [, ARn]                                                                                                                                                                                                                                                                                                                                                                               |
|                    | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0<br>0 1 1 0 1 1 1 0 1 ARU N NAR                                                                                                                                                                                                                                                                                                                          |
|                    | <b>Note:</b> ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode</i> Format (page 7-12).                                                                                                                                                                                                                                                                           |
|                    | <b>AND #</b> <i>lk</i> [, <i>shift</i> ]<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                             |
|                    | 1 0 1 1 1 1 1 1 0 1 1 shift                                                                                                                                                                                                                                                                                                                                                                   |
|                    | lk                                                                                                                                                                                                                                                                                                                                                                                            |
|                    | AND #/k, 16                                                                                                                                                                                                                                                                                                                                                                                   |
|                    | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                         |
|                    | 1 0 1 1 1 1 0 1 0 0 0 0 0 1<br> k                                                                                                                                                                                                                                                                                                                                                             |
|                    |                                                                                                                                                                                                                                                                                                                                                                                               |
| Execution          | Increment PC, then<br><u>Event(s)</u><br>(ACC(15:0)) AND (data-memory address) $\rightarrow$ ACC(15:0) Direct or indirect<br>$0 \rightarrow$ ACC(31:16)                                                                                                                                                                                                                                       |
|                    | $(ACC(31:0)) \text{ AND Ik} \times 2^{\text{shift}} \rightarrow ACC \qquad \qquad \text{Long immediate}$                                                                                                                                                                                                                                                                                      |
|                    | (ACC(31:0)) AND lk $\times 2^{16} \rightarrow$ ACC Long immediate with left shift of 16                                                                                                                                                                                                                                                                                                       |
| Status Bits        | None                                                                                                                                                                                                                                                                                                                                                                                          |
| PRELIMINARY        | Assembly Language Instructions 8-33                                                                                                                                                                                                                                                                                                                                                           |

#### This instruction is not affected by SXM.

**Description** If direct or indirect addressing is used, the low word of the accumulator is ANDed with a data-memory value, and the result is placed in the low word position in the accumulator. The high word of the accumulator is zeroed. If immediate addressing is used, the long-immediate constant can be shifted. During the shift, low-order and high-order bits not filled by the shifted value are zeroed. The resulting value is ANDed with the accumulator contents.

| Words | <u>Words</u><br>1 | Addressing mode<br>Direct or indirect |
|-------|-------------------|---------------------------------------|
|       | 2                 | Long immediate                        |

Cycles

Cycles for a Single AND Instruction (Using Direct and Indirect Addressing)

| Operand  | ROM | DARAM | SARAM | External |
|----------|-----|-------|-------|----------|
| DARAM    | 1   | 1     | 1     | 1+p      |
| SARAM    | 1   | 1     | 1, 2† | 1+p      |
| External | 1+d | 1+d   | 1+d   | 2+d+p    |

<sup>†</sup> If the operand and the code are in the same SARAM block

# Cycles for a Repeat (RPT) Execution of an AND Instruction (Using Direct and Indirect Addressing)

|          | Program |       |         |          |  |  |
|----------|---------|-------|---------|----------|--|--|
| Operand  | ROM     | DARAM | SARAM   | External |  |  |
| DARAM    | n       | n     | n       | n+p      |  |  |
| SARAM    | n       | n     | n, n+1† | n+p      |  |  |
| External | n+nd    | n+nd  | n+nd    | n+1+p+nd |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Cycles for a Single AND Instruction | (Using Long Immediate Addressing) |
|-------------------------------------|-----------------------------------|
|                                     |                                   |

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| 2   | 2     | 2     | 2+2p     |

AND With Accumulator **AND** 

| Example 1 | AND | 16                          | ; (DP = 4:                | addresses 020               | 0h-027Fh)         |
|-----------|-----|-----------------------------|---------------------------|-----------------------------|-------------------|
|           |     |                             | <b>Before Instruction</b> |                             | After Instruction |
|           |     | Data Memory<br>0210h<br>ACC | 00FFh                     | Data Memory<br>0210h<br>ACC | 00FFh             |
| Example 2 | AND | *                           |                           |                             |                   |
|           |     |                             | Before Instruction        |                             | After Instruction |
|           |     | ARP                         | 0                         | ARP                         | 0                 |
|           |     | AR0                         | 0301h                     | AR0                         | 0301h             |
|           |     | Data Memory<br>0301h        | 0FF00h                    | Data Memory<br>0301h        | 0FF00h            |
|           |     | ACC                         | 12345678h                 | ACC                         | 00005600h         |
| Example 3 | AND | #00FFh,                     | 4                         |                             |                   |
|           |     |                             | Before Instruction        |                             | After Instruction |
|           |     | ACC                         | 12345678h                 | ACC                         | 00000670h         |

| Syntax      | APAC                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands    | None                                                                                                                                                                                                                                                                                                                                                                                                            |
| Opcode      | APAC                                                                                                                                                                                                                                                                                                                                                                                                            |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                           |
|             | 1 0 1 1 1 1 1 0 0 0 0 0 1 0 0                                                                                                                                                                                                                                                                                                                                                                                   |
| Execution   | Increment PC, then (ACC) + shifted (PREG) $\rightarrow$ ACC                                                                                                                                                                                                                                                                                                                                                     |
| Status Bits | <u>Affected by</u> <u>Affects</u><br>PM and OVM C and OV                                                                                                                                                                                                                                                                                                                                                        |
|             | This instruction is not affected by SXM.                                                                                                                                                                                                                                                                                                                                                                        |
| Description | The contents of PREG are shifted as defined by the PM status bits of the ST1 register (see Table 8–7) and added to the contents of the accumulator. The result is placed in the accumulator. APAC is not affected by the SXM bit of the status register. PREG is always sign extended. The task of the APAC instruction is also performed as a subtask of the LTA, LTD, MAC, MACD, MPYA, and SQRA instructions. |

#### Table 8–7. Product Shift Modes

1

| PM    | Bits  |                       |
|-------|-------|-----------------------|
| Bit 1 | Bit 0 | Resulting Shift       |
| 0     | 0     | No shift              |
| 0     | 1     | Left shift of 1 bit   |
| 1     | 0     | Left shift of 4 bits  |
| 1     | 1     | Right shift of 6 bits |

## Words Cycles

|     | Cycles for a S | Single APAC Instruc | tion     |
|-----|----------------|---------------------|----------|
| ROM | DARAM          | SARAM               | External |
| 1   | 1              | 1                   | 1+p      |

| Cycles for a Repeat (RPT) Execution of an APAC Instruction | Cycles for a | Repeat (RPT) | Execution of an | <b>APAC Instruction</b> |
|------------------------------------------------------------|--------------|--------------|-----------------|-------------------------|
|------------------------------------------------------------|--------------|--------------|-----------------|-------------------------|

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| n   | n     | n     | n+p      |



| Syntax      | <b>B</b> pma [, ii                                                                                                                                                                                    | nd [, <b>AR</b> n]]                                                                                                                                              |                                             | Indirect ad                           | dressing                                                       |  |  |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|---------------------------------------|----------------------------------------------------------------|--|--|--|
| Operands    | pma:16-bit program-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+**0+**BR0+                                               |                                                                                                                                                                  |                                             |                                       |                                                                |  |  |  |
| Opcode      | 15 14<br>0 1<br>Note: A                                                                                                                                                                               | , <i>ind</i> [, <b>AR</b> <i>n</i> ]]<br><u>13</u> <u>12</u> <u>11</u> <u>10</u><br><u>1</u> <u>1</u> <u>1</u> <u>0</u><br>RU, N, and NAR are def<br>bage 7-12). | 9 8 7<br>0 1 1<br>pma<br>ined in subsection | 6 5 4<br>ARU<br>7.3.4, Indirect Addre | 3     2     1     0       N     NAR       essing Opcode Format |  |  |  |
| Execution   | pma $\rightarrow$ PC Modify (current AR) and (ARP) as specified.                                                                                                                                      |                                                                                                                                                                  |                                             |                                       |                                                                |  |  |  |
| Status Bits | None                                                                                                                                                                                                  |                                                                                                                                                                  |                                             |                                       |                                                                |  |  |  |
| Description | The current auxiliary register and ARP contents are modified as specified, and control is passed to the designated program-memory address (pma). The pma can be either a symbolic or numeric address. |                                                                                                                                                                  |                                             |                                       |                                                                |  |  |  |
| Words       | 2                                                                                                                                                                                                     |                                                                                                                                                                  |                                             |                                       |                                                                |  |  |  |
| Cycles      | Cycles for a Single B Instruction                                                                                                                                                                     |                                                                                                                                                                  |                                             |                                       |                                                                |  |  |  |
|             | ROM DARAM SARAM External                                                                                                                                                                              |                                                                                                                                                                  |                                             |                                       |                                                                |  |  |  |
|             | 4                                                                                                                                                                                                     | 4                                                                                                                                                                | 4                                           | 4                                     | +4p                                                            |  |  |  |
|             | tion                                                                                                                                                                                                  | nen this instruction reach<br>n words have entered th<br>truction words are disca                                                                                | ne pipeline. When                           |                                       |                                                                |  |  |  |
| Example     | В                                                                                                                                                                                                     | 191,*+,AR1                                                                                                                                                       |                                             |                                       |                                                                |  |  |  |
|             | to execute                                                                                                                                                                                            | 191 is loaded into t<br>from that location.<br>P is set to point to a                                                                                            | The current au                              | uxiliary register i                   | •                                                              |  |  |  |

| Syntax      | BACC                                                                                                                                                                                                                     | BACC            |                   |     |     |      |     |          |       |       |        |        |       |      |      |       |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------------|-----|-----|------|-----|----------|-------|-------|--------|--------|-------|------|------|-------|
| Operands    | None                                                                                                                                                                                                                     | None            |                   |     |     |      |     |          |       |       |        |        |       |      |      |       |
| Opcode      |                                                                                                                                                                                                                          |                 |                   |     |     |      |     |          |       |       |        |        |       |      |      |       |
| Execution   | ACC(1                                                                                                                                                                                                                    | 5:0)            | $) \rightarrow  $ | PC  |     |      |     |          |       |       |        |        |       |      |      |       |
| Status Bits | None                                                                                                                                                                                                                     | None            |                   |     |     |      |     |          |       |       |        |        |       |      |      |       |
| Description | Control is passed to the 16-bit address residing in the lower half (16 LSBs) of the accumulator.                                                                                                                         |                 |                   |     |     |      |     |          |       |       |        |        |       |      |      |       |
| Words       | 1                                                                                                                                                                                                                        |                 |                   |     |     |      |     |          |       |       |        |        |       |      |      |       |
| Cycles      | Cycles for a Single BACC Instruction                                                                                                                                                                                     |                 |                   |     |     |      |     |          |       |       |        |        |       |      |      |       |
|             | ROM                                                                                                                                                                                                                      | ROM DARAM SARAM |                   |     |     |      | Ext | External |       |       |        |        |       |      |      |       |
|             | 4 4 4 4+3p                                                                                                                                                                                                               |                 |                   |     |     |      |     |          |       |       |        |        |       |      |      |       |
|             | <b>Note:</b> When this instruction reaches the execute phase of the pipeline, two additional instruction words have entered the pipeline. When the PC discontinuity is taken, these two instruction words are discarded. |                 |                   |     |     |      |     |          |       |       |        |        |       |      |      |       |
| Example     | BACC                                                                                                                                                                                                                     |                 | ;                 | (AC | C C | onta | ins | the      | e va  | lue   | 191    | )      |       |      |      |       |
|             | The va                                                                                                                                                                                                                   |                 |                   |     |     |      |     | orogra   | am co | ounte | er, an | id the | e pro | gram | cont | inues |

| Syntax      | BANZ pma                                                                                                                                                                                                                                                                                                                                                                                                                        | a [, ind [, <b>/</b>                   | <b>4R</b> <i>n</i> ]]                  |          |          |                 | I        | ndire   | ct ac | ddres  | sing  |         |       |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------------------------|----------|----------|-----------------|----------|---------|-------|--------|-------|---------|-------|
| Operands    | pma:<br>n:<br>ind:                                                                                                                                                                                                                                                                                                                                                                                                              | Value                                  | program<br>from 0 to<br>one of t<br>*_ | 7 de     | signat   | ting t<br>g sev | he n     | ption   |       | ary re | giste | er      |       |
| Opcode      | BANZ pl                                                                                                                                                                                                                                                                                                                                                                                                                         | ma [, ind                              | [, <b>AR</b> n]]                       |          |          |                 |          |         |       |        |       |         |       |
|             | 15 14                                                                                                                                                                                                                                                                                                                                                                                                                           | 13 12<br>1 1                           | 11 10<br>1 0                           | 9<br>1   | 8        | 7               | 6        | 5       | 4     | 3<br>N | 2     | 1       | 0     |
|             | 0 1                                                                                                                                                                                                                                                                                                                                                                                                                             | 1 1                                    | 1 0                                    | I        | 1<br>prr | 1<br>1a         |          | ARU     |       | IN     |       | NAR     |       |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                 | RU, N, and N<br>age 7-12).             | NAR are de                             | fined ir | •        |                 | 7.3.4, 1 | Indirec | t Add | ressin | g Opc | ode Fc  | ormat |
| Execution   | •                                                                                                                                                                                                                                                                                                                                                                                                                               | $ma \rightarrow P(PC) + 2 \rightarrow$ | PC                                     | P) as    | speci    | ified           |          |         |       |        |       |         |       |
| Status Bits | None                                                                                                                                                                                                                                                                                                                                                                                                                            |                                        |                                        |          |          |                 |          |         |       |        |       |         |       |
| Description | Control is passed to the designated program-memory address (pma) if the contents of the current auxiliary register are not 0. Otherwise, control passes to the next instruction. The default modification to the current AR is a decrement by 1. N loop iterations can be executed by initializing an auxiliary register (as a loop counter) to N–1 prior to loop entry. The pma can be either a symbolic or a numeric address. |                                        |                                        |          |          |                 |          |         |       |        |       |         |       |
| Words       | 2                                                                                                                                                                                                                                                                                                                                                                                                                               |                                        |                                        |          |          |                 |          |         |       |        |       |         |       |
| Cycles      |                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                        | Cycles f                               | or a S   | ingle E  | BANZ            | 2 Inst   | ructio  | on    |        |       |         |       |
|             | Condition                                                                                                                                                                                                                                                                                                                                                                                                                       | ROM                                    |                                        | DAR      | АМ       |                 | SAF      | RAM     |       | E      | ctern | al      |       |
|             | True                                                                                                                                                                                                                                                                                                                                                                                                                            | 4                                      |                                        | 4        |          |                 | 4        |         |       | 4+     | -4p   |         |       |
|             | False                                                                                                                                                                                                                                                                                                                                                                                                                           | 2                                      |                                        | 2        |          |                 | 2        |         |       | 2+     | -2p   |         |       |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                 | C24x perfo<br>PC disconti              |                                        |          | -        |                 | -        |         |       |        |       | n words | s. lf |

| Example 1 | BANZ                    | PGMO ;(PG                                           | M0 labels program                                                                                           | address 0)                                       |
|-----------|-------------------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
|           |                         | Before In                                           | struction                                                                                                   | After Instruction                                |
|           |                         | ARP                                                 | 0 ARP                                                                                                       | 0                                                |
|           |                         | AR0                                                 | 5h AR0                                                                                                      | 4h                                               |
|           | gram coun<br>The defaul | iter (PC) and the prog<br>It auxiliary register ope | t 0, program address 0 i<br>ram continues executin<br>ration is a decrement of<br>ains 4h at the end of the | g from that location.<br>I the current auxiliary |
|           | or                      |                                                     |                                                                                                             |                                                  |
|           |                         | Before In                                           | struction                                                                                                   | After Instruction                                |
|           |                         | ARP                                                 | 0 ARP                                                                                                       | 0                                                |
|           |                         | AR0                                                 | 0h AR0                                                                                                      | FFFh                                             |
|           | is incremer             | nted by 2, and executic<br>ruction. Because of the  | the branch is not exect<br>on continues with the ins<br>default decrement, AR                               | truction following the                           |
| Example 2 |                         | MAR *, ARO                                          | ;Set ARP to poi                                                                                             | nt to AR0.                                       |
|           |                         | LAR AR1,#3                                          | ;Load AR1 with                                                                                              |                                                  |
|           |                         | LAR AR0,#60h                                        | ;Load AR0 with                                                                                              | 60h.                                             |
|           | PGM191                  | ADD *+,AR1                                          | ;Loop: While AR                                                                                             | 1 not zero,                                      |
|           |                         | BANZ PGM191,AR                                      | .0 ;add data refer                                                                                          | enced by AR0                                     |
|           |                         |                                                     | ;to accumulator                                                                                             | and increment                                    |
|           |                         |                                                     | ;AR0 value.                                                                                                 |                                                  |
|           | The conter              | nts of data-memory loc                              | ations 60h–63h are add                                                                                      | ded to the accumula-                             |

tor.

| Syntax      | BCND pma                                                                                              | , <i>cond</i> 1                    | [,cond2                                                                                                                                                | <u>2] [,]</u>      |                 |          |       |               |       |          |       |        |
|-------------|-------------------------------------------------------------------------------------------------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------|----------|-------|---------------|-------|----------|-------|--------|
| Operands    | pma:                                                                                                  | pma: 16-bit program-memory address |                                                                                                                                                        |                    |                 |          |       |               |       |          |       |        |
|             | <i>cond</i><br>EQ<br>NEQ<br>LT<br>LEQ<br>GT<br>GEQ<br>NC<br>C<br>NOV<br>OV<br>BIO<br>NTC<br>TC<br>UNC |                                    | $\frac{Conditio}{ACC} = 0$ $ACC \neq 0$ $ACC \leq 0$ $ACC \geq 0$ $ACC \geq 0$ $C = 0$ $C = 1$ $OV = 0$ $OV = 1$ $BIO low$ $TC = 0$ $TC = 1$ $Uncondi$ |                    | /               |          |       |               |       |          |       |        |
| Opcode      | 15 14                                                                                                 | 13 12                              | 11 10                                                                                                                                                  |                    |                 | 76       | 5     | 4             | 3     | 2        | 1     | 0      |
|             | 1 1 1 0 0 0 TP ZLVC ZLVC                                                                              |                                    |                                                                                                                                                        |                    |                 |          |       | VC            |       |          |       |        |
| Execution   | Note: The                                                                                             |                                    | VC fields a                                                                                                                                            |                    | pma<br>led on p | ages 8-3 | and 8 | 8-4.          |       |          |       |        |
| Execution   | Then p                                                                                                | ma $\rightarrow$ P<br>crement      | С                                                                                                                                                      |                    |                 |          |       |               |       |          |       |        |
| Status Bits | None                                                                                                  |                                    |                                                                                                                                                        |                    |                 |          |       |               |       |          |       |        |
| Description | A branch is<br>fied condition<br>example, te<br>mutually ex                                           | ons are n<br>esting fo             | net. Not<br>or LT and                                                                                                                                  | all com<br>d GT is | binatio         | ons of c | ondit | ions          | are n | nean     | ingfu | l. For |
| Words       | 2                                                                                                     |                                    |                                                                                                                                                        |                    |                 |          |       |               |       |          |       |        |
| Cycles      |                                                                                                       |                                    | Cycles                                                                                                                                                 | ior a Si           | ngle B          | CND In   | struc | tion          |       |          |       |        |
|             | Condition                                                                                             | ROM                                |                                                                                                                                                        | DAR                | M               | S        | ARAN  | I             | E     | Exter    | nal   |        |
|             | True                                                                                                  | 4                                  |                                                                                                                                                        | 4                  |                 | 4        |       |               | 2     | 1+4p     |       |        |
|             | False                                                                                                 | 2                                  |                                                                                                                                                        | 2                  |                 | 2        |       |               | 2     | 2+2p     |       |        |
|             | Nata, The                                                                                             | 004                                |                                                                                                                                                        |                    | - + -           |          |       | a d d i t i a |       | atru ati |       | rdo If |

**Note:** The 'C24x performs speculative fetching by reading two additional instruction words. If the PC discontinuity is taken, these two instruction words are discarded.

#### Example

BCND PGM191, LEQ, C

If the accumulator contents are less than or equal to 0 and the carry bit is set, program address 191 is loaded into the program counter, and the program continues to execute from that location. If these conditions do not hold, execution continues from location PC + 2.

| Syntax               | BIT dma, bit codeDirect addressingBIT ind, bit code [, ARn]Indirect addressing                                                                                                                                                                                                                                              |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands             | dma:7 LSBs of the data-memory addressbit code:Value from 0 to 15 indicating which bit to test (see Figure 8–1)n:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+**0+**BR0+                                                                                        |
| Opcode               | BIT dma, bit code                                                                                                                                                                                                                                                                                                           |
| •                    | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                       |
|                      | 0 1 0 0 bit code 0 dma                                                                                                                                                                                                                                                                                                      |
|                      | PIT ind bit and [ ADn]                                                                                                                                                                                                                                                                                                      |
|                      | <b>BIT</b> ind, bit code [, <b>AR</b> n]<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                           |
|                      | 0 1 0 0 bit code 1 ARU N NAR                                                                                                                                                                                                                                                                                                |
|                      | <b>Note:</b> ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).                                                                                                                                                                                                         |
| Execution            | Increment PC, then (data bit number (15 – bit code)) $\rightarrow$ TC                                                                                                                                                                                                                                                       |
| Status Bits          | <u>Affects</u><br>TC                                                                                                                                                                                                                                                                                                        |
| Description          | The BIT instruction copies the specified bit of the data-memory value to the TC bit of status register ST1. Note that the BITT, CMPR, LST #1, and NORM instructions also affect the TC bit in ST1. A bit code value is specified that corresponds to a certain bit number of the data-memory value, as shown in Figure 8–1. |
|                      |                                                                                                                                                                                                                                                                                                                             |
| Figure 8–1. Bit Nurr | bers and Their Corresponding Bit Codes for BIT Instruction                                                                                                                                                                                                                                                                  |

| Bit code   | 0   | 1  | 2  | 3  | 4  | 5  | 6     | 7     | 8      | 9  | 10 | 11 | 12 | 13 | 14 | 15  |  |
|------------|-----|----|----|----|----|----|-------|-------|--------|----|----|----|----|----|----|-----|--|
| Bit number | 15  | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0   |  |
|            |     |    |    |    |    |    |       |       |        |    |    |    |    |    |    |     |  |
|            | MSB |    |    |    |    | Da | ata-m | nemor | y valı | Je |    |    |    |    |    | LSB |  |
|            |     |    |    |    |    |    |       |       |        |    |    |    |    |    |    |     |  |

Words

1

Cycles

1

|          | Cycles for a Single BIT Instruction |       |       |          |  |  |  |  |  |  |
|----------|-------------------------------------|-------|-------|----------|--|--|--|--|--|--|
| Program  |                                     |       |       |          |  |  |  |  |  |  |
| Operand  | ROM                                 | DARAM | SARAM | External |  |  |  |  |  |  |
| DARAM    | 1                                   | 1     | 1     | 1+p      |  |  |  |  |  |  |
| SARAM    | 1                                   | 1     | 1, 2† | 1+p      |  |  |  |  |  |  |
| External | 1+d                                 | 1+d   | 1+d   | 2+d+p    |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

|          | Cycles for a Repeat (RPT) Execution of a BIT Instruction |       |         |          |  |  |  |  |  |  |  |  |
|----------|----------------------------------------------------------|-------|---------|----------|--|--|--|--|--|--|--|--|
|          | Program                                                  |       |         |          |  |  |  |  |  |  |  |  |
| Operand  | ROM                                                      | DARAM | SARAM   | External |  |  |  |  |  |  |  |  |
| DARAM    | n                                                        | n     | n       | n+p      |  |  |  |  |  |  |  |  |
| SARAM    | n                                                        | n     | n, n+1† | n+p      |  |  |  |  |  |  |  |  |
| External | n+nd                                                     | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |  |  |  |  |

0

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

тс

| Example 1 | BIT | 0h,15               | ; $(DP = 6)$ .     | Test LSB at 3       | 300h              |
|-----------|-----|---------------------|--------------------|---------------------|-------------------|
|           |     | I                   | Before Instruction |                     | After Instruction |
|           |     | Data Memory<br>300h | 4DC8h              | Data Memory<br>300h | 4DC8h             |
|           |     | тс [                | 0                  | ТС                  | 0                 |
| Example 2 | BIT | *,0,AR1             | ;Test MSB          | at 310h, then       | set ARP = 1       |
|           |     |                     | Before Instruction |                     | After Instruction |
|           |     | ARP                 | 0                  | ARP                 | 1                 |
|           |     | AR0                 | 310h               | AR0                 | 310h              |
|           |     | Data Memory<br>310h | 8000h              | Data Memory<br>310h | 8000h             |

Assembly Language Instructions 8-45

тс

| Syntax                       |                                                                                                                                                                                                                                                                                                                                     | TT c<br>TT ii      |            | AR             | n]                  |             |                                |       |       |                 |                 | Direc <sup>:</sup><br>ndire |        |        | -     |        |       |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------|----------------|---------------------|-------------|--------------------------------|-------|-------|-----------------|-----------------|-----------------------------|--------|--------|-------|--------|-------|
| Operands                     | dm<br>n:<br>ind                                                                                                                                                                                                                                                                                                                     |                    |            | Va             | alue                | from<br>one | the da<br>0 to<br>0 th<br>- *( | 7 des | signa | ting t<br>g sev | he n            | ext a ption                 |        | ry re  | giste | er     |       |
| Opcode                       | E                                                                                                                                                                                                                                                                                                                                   | вітт               | Г dm       | a              |                     |             |                                |       |       |                 |                 |                             |        |        |       |        |       |
|                              | _                                                                                                                                                                                                                                                                                                                                   | 15                 | 14         | 13             | 12                  | 11          | 10                             | 9     | 8     | 7               | 6               | 5                           | 4      | 3      | 2     | 1      | 0     |
|                              |                                                                                                                                                                                                                                                                                                                                     | 0                  | 1          | 1              | 0                   | 1           | 1                              | 1     | 1     | 0               |                 |                             |        | dma    |       |        |       |
|                              | E                                                                                                                                                                                                                                                                                                                                   | вітт               | Г ina      | /[, <b>A</b> l | <b>R</b> <i>n</i> ] |             |                                |       |       |                 |                 |                             |        |        |       |        |       |
|                              |                                                                                                                                                                                                                                                                                                                                     | 15                 | 14         | 13             | 12                  | 11          | 10                             | 9     | 8     | 7               | 6               | 5                           | 4      | 3      | 2     | 1      | 0     |
|                              |                                                                                                                                                                                                                                                                                                                                     | 0                  | 1          | 1              | 0                   | 1           | 1                              | 1     | 1     | 1               |                 | ARU                         |        | Ν      |       | NAR    |       |
| Execution                    | Inc                                                                                                                                                                                                                                                                                                                                 |                    | (p<br>nent | age 7<br>PC, 1 | -12).<br>then       |             | re defi                        |       |       |                 | 7.3.4, <i>I</i> | ndirec                      | t Addr | essing | у Орс | ode Fc | ormat |
| Status Bits                  | <u>Aff</u><br>TC                                                                                                                                                                                                                                                                                                                    | f <u>ects</u><br>; | <u>5</u>   |                |                     |             |                                |       |       |                 |                 |                             |        |        |       |        |       |
| Description                  | The BITT instruction copies the specified bit of the data-memory value to the TC bit of status register ST1. Note that the BITT, CMPR, LST #1, and NORM instructions also affect the TC bit in status register ST1. The bit number is specified by a bit code value contained in the four LSBs of the TREG, as shown in Figure 8–2. |                    |            |                |                     |             |                                |       |       |                 |                 |                             |        |        |       |        |       |
| Figure 8–2. Bit Num          | Figure 8–2. Bit Numbers and Their Corresponding Bit Codes for BITT Instruction                                                                                                                                                                                                                                                      |                    |            |                |                     |             |                                |       |       |                 |                 |                             |        |        |       |        |       |
| Bit code (in 4 LSBs of TREG) | 0                                                                                                                                                                                                                                                                                                                                   | 1                  | 2          | 3              | 3 4                 | 1 !         | 56                             | 5 7   | 7 8   | 8 9             | 1(              | <b>) 1</b> 1                | 12     | 2 10   | 3 1   | 4 1    | 5     |

| Dir oodo | TREG)      | Ũ   |    | -  | 0  | •  | Ũ  | Ũ     |      | Ũ      | Ũ  | 10 |   |   | 10 | •• | 10  |
|----------|------------|-----|----|----|----|----|----|-------|------|--------|----|----|---|---|----|----|-----|
|          | Bit number | 15  | 14 | 13 | 12 | 11 | 10 | 9     | 8    | 7      | 6  | 5  | 4 | 3 | 2  | 1  | 0   |
|          |            |     |    |    |    |    |    |       |      |        |    |    |   |   |    |    |     |
|          |            | MSB |    |    |    |    | Da | ata-m | emor | y valı | le |    |   |   |    |    | LSB |
|          |            |     |    |    |    |    |    |       |      |        |    |    |   |   |    |    |     |
| Words    |            | 1   |    |    |    |    |    |       |      |        |    |    |   |   |    |    |     |

Cycles

|          | Cycles for a Single BITT Instruction |       |       |          |  |  |  |  |  |  |
|----------|--------------------------------------|-------|-------|----------|--|--|--|--|--|--|
| Program  |                                      |       |       |          |  |  |  |  |  |  |
| Operand  | ROM                                  | DARAM | SARAM | External |  |  |  |  |  |  |
| DARAM    | 1                                    | 1     | 1     | 1+p      |  |  |  |  |  |  |
| SARAM    | 1                                    | 1     | 1, 2† | 1+p      |  |  |  |  |  |  |
| External | 1+d                                  | 1+d   | 1+d   | 2+d+p    |  |  |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Cycles for a Repeat (RPT) Execution of an BITT Instruction |         |       |         |          |  |  |  |  |  |  |  |
|------------------------------------------------------------|---------|-------|---------|----------|--|--|--|--|--|--|--|
|                                                            | Program |       |         |          |  |  |  |  |  |  |  |
| Operand                                                    | ROM     | DARAM | SARAM   | External |  |  |  |  |  |  |  |
| DARAM                                                      | n       | n     | n       | n+p      |  |  |  |  |  |  |  |
| SARAM                                                      | n       | n     | n, n+1† | n+p      |  |  |  |  |  |  |  |
| External                                                   | n+nd    | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

| Example 1 | BITT 00h                          | ;(DP = 6) Test bit 14<br>;at 300h<br>Before Instruction | of data                      |
|-----------|-----------------------------------|---------------------------------------------------------|------------------------------|
|           | Data Memory<br>300h<br>TREG<br>TC |                                                         | 4DC8h                        |
| Example 2 | BITT *                            | ;Test bit 1 of data a Before Instruction                | it 310h<br>After Instruction |
|           | ARP<br>AR1                        | 1 ARP<br>310h AR1                                       | 1<br>310h                    |
|           | Data Memory<br>310h<br>TREG<br>TC | Data Memory Data Memory 8000h 310h DEh TREG 0 TC        | 8000h<br>0Eh                 |

#### PRELIMINARY

Assembly Language Instructions 8-47

| SyntaxGeneral syntax:BLDD source, destination |                                                                                                                                                                                           |                       |                 |               |             |         |        |       |          |        |                                                               |                                          |         |       |          |      |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------|---------------|-------------|---------|--------|-------|----------|--------|---------------------------------------------------------------|------------------------------------------|---------|-------|----------|------|
|                                               | BLDI                                                                                                                                                                                      | <b>) #</b> /k,        | dm              | а             |             |         |        |       |          |        | Direct                                                        | t witł                                   | n long  | g imi | nedia    | te   |
|                                               | BLDI                                                                                                                                                                                      | <b>) #</b> /k,        | ind [           | [, <b>AR</b>  | <i>n</i> ]  |         |        |       |          |        | source<br>Indirect with long                                  |                                          |         |       |          |      |
|                                               | BLDI                                                                                                                                                                                      | <b>)</b> dm           | a, <b>#</b> //  | ſ             |             |         |        |       |          |        | immediate source<br>Direct with long immediate<br>destination |                                          |         |       |          |      |
|                                               | BLDI                                                                                                                                                                                      | BLDD ind, #lk [, ARn] |                 |               |             |         |        |       |          |        |                                                               | Indirect with long immediate destination |         |       |          |      |
| Operands                                      | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerlk:16-bit long immediate valueind:Select one of the following seven options:**+**0+**BR0+ |                       |                 |               |             |         |        |       |          |        |                                                               |                                          |         |       |          |      |
| Opcode                                        |                                                                                                                                                                                           | DD #                  | -               |               |             |         |        |       |          |        |                                                               |                                          |         |       |          |      |
|                                               | 15                                                                                                                                                                                        | 14                    | 13              | 12            | 11<br>1     | 10<br>0 | 9<br>0 | 8     | 7        | 6      | 5                                                             | 4                                        | 3       | 2     | 1        | 0    |
|                                               | 1                                                                                                                                                                                         | 0                     | 1               | 0             |             | 0       | 0      | -     | 0<br>k   |        |                                                               |                                          | dma     |       |          |      |
|                                               |                                                                                                                                                                                           |                       |                 |               |             |         |        |       | 11X      |        |                                                               |                                          |         |       |          |      |
|                                               |                                                                                                                                                                                           | DD #                  |                 | -             | -           | 10      | •      | •     | -        | •      | -                                                             |                                          | •       | ~     |          | •    |
|                                               | 15                                                                                                                                                                                        | 14<br>0               | 13<br>1         | 12<br>0       | 11          | 10<br>0 | 9<br>0 | 8     | 7        | 6      | 5<br>ARU                                                      | 4                                        | 3<br>N  | 2     | 1<br>NAR | 0    |
|                                               | -                                                                                                                                                                                         | 0                     |                 | U             |             | U       | 0      |       | k k      |        | 7110                                                          |                                          |         |       | 117.111  |      |
|                                               | Not                                                                                                                                                                                       |                       | RU, N<br>bage 7 |               | NARa        | re defi | nedin  | subse | ection 7 | 7.3.4, | Indirec                                                       | t Add                                    | ressing | g Орс | ode Fo   | rmat |
|                                               | BL                                                                                                                                                                                        | DD d                  | lma, i          | #lk           |             |         |        |       |          |        |                                                               |                                          |         |       |          |      |
|                                               | 15                                                                                                                                                                                        | 14                    | 13              | 12            | 11          | 10      | 9      | 8     | 7        | 6      | 5                                                             | 4                                        | 3       | 2     | 1        | 0    |
|                                               | 1                                                                                                                                                                                         | 0                     | 1               | 0             | 1           | 0       | 0      | 1     | 0        |        |                                                               |                                          | dma     |       |          |      |
|                                               |                                                                                                                                                                                           |                       |                 |               |             |         |        | I     | k        |        |                                                               |                                          |         |       |          |      |
|                                               | BL                                                                                                                                                                                        | DD ir                 | nd, #I          | lk[, <b>A</b> | <b>R</b> n] |         |        |       |          |        |                                                               |                                          |         |       |          |      |
|                                               | 15                                                                                                                                                                                        | 14                    | 13              | 12            | 11          | 10      | 9      | 8     | 7        | 6      | 5                                                             | 4                                        | 3       | 2     | 1        | 0    |
|                                               | 1                                                                                                                                                                                         | 0                     | 1               | 0             | 1           | 0       | 0      | 1     | 1        |        | ARU                                                           |                                          | Ν       |       | NAR      |      |
|                                               |                                                                                                                                                                                           |                       |                 |               |             |         |        | I     | k        |        |                                                               |                                          |         |       |          |      |
|                                               | Not                                                                                                                                                                                       |                       |                 |               | VARa        | re defi | ned in | subse | ection 7 | 7.3.4, | Indirec                                                       | t Add                                    | ressing | g Opc | ode Fo   | rmat |
|                                               |                                                                                                                                                                                           | (¢                    | bage 7          | -12).         |             |         |        |       |          |        |                                                               |                                          |         |       |          |      |

| Execution   | Increment PC, then<br>$(PC) \rightarrow MSTACK$<br>$lk \rightarrow PC$<br>$(source) \rightarrow destination$<br>For indirect, modify (current AR) and (ARP) as specified<br>$(PC) + 1 \rightarrow PC$<br>While (repeat counter) $\neq 0$ :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | (source) $\rightarrow$ destination<br>For indirect, modify (current AR) and (ARP) as specified<br>(PC) + 1 $\rightarrow$ PC<br>(repeat counter) -1 $\rightarrow$ repeat counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|             | $(MSTACK) \to PC$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Status Bits | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Description | The word in data memory pointed to by <i>source</i> is copied to a data-memory space pointed at by <i>destination</i> . The word of the source and/or destination space can be pointed at with a long-immediate value or by a data-memory address. Note that not all source/destination combinations of pointer types are valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|             | BLDD does not work with core memory-mapped registers such as IMR, IFR, and GREG.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | RPT can be used with the BLDD instruction to move consecutive words in data memory. The number of words to be moved is one greater than the number contained in the repeat counter (RPTC) at the beginning of the instruction. When the BLDD instruction is repeated, the source (destination) address specified by the long immediate constant is stored to the PC. Because the PC is incremented by 1 during each repetition, it is possible to access a series of source (destination) addresses. If you use indirect addressing to specify the destination (source) address, a new destination (source) address can be accessed during each repetition. If you use the direct addressing mode, the specified destination (source) address is a constant; it is not modified during each repetition. |
|             | The source and destination blocks do not have to be entirely on chip or off chip.<br>Interrupts are inhibited during a BLDD operation used with the RPT instruction.<br>When used with RPT, BLDD becomes a single-cycle instruction once the RPT<br>pipeline is started.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|             | Assembly Language Instructions 8-49                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

2

#### Words

#### Cycles

| Cycles for a Single BLDD Instruction      |                                      |                                      |                                            |                                          |  |  |  |  |  |  |
|-------------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------------|------------------------------------------|--|--|--|--|--|--|
| Operand                                   | ROM                                  | DARAM                                | SARAM                                      | External                                 |  |  |  |  |  |  |
| Source: DARAM<br>Destination: DARAM       | 3                                    | 3                                    | 3                                          | 3+2p                                     |  |  |  |  |  |  |
| Source: SARAM<br>Destination: DARAM       | 3                                    | 3                                    | 3                                          | 3+2p                                     |  |  |  |  |  |  |
| Source: External<br>Destination: DARAM    | 3+d <sub>src</sub>                   | 3+d <sub>src</sub>                   | 3+d <sub>src</sub>                         | 3+d <sub>src</sub> +2p                   |  |  |  |  |  |  |
| Source: DARAM<br>Destination: SARAM       | 3                                    | 3                                    | 3<br>4†                                    | 3+2p                                     |  |  |  |  |  |  |
| Source: SARAM<br>Destination: SARAM       | 3                                    | 3                                    | 3<br>4†                                    | 3+2p                                     |  |  |  |  |  |  |
| Source: External<br>Destination: SARAM    | 3+d <sub>src</sub>                   | 3+d <sub>src</sub>                   | 3+d <sub>src</sub><br>4+d <sub>src</sub> † | 3+d <sub>src</sub> +2p                   |  |  |  |  |  |  |
| Source: DARAM<br>Destination: External    | 4+d <sub>dst</sub>                   | 4+d <sub>dst</sub>                   | 4+d <sub>dst</sub>                         | 6+d <sub>dst</sub> +2p                   |  |  |  |  |  |  |
| Source: SARAM<br>Destination: External    | 4+d <sub>dst</sub>                   | 4+d <sub>dst</sub>                   | 4+d <sub>dst</sub>                         | 6+d <sub>dst</sub> +2p                   |  |  |  |  |  |  |
| Source: External<br>Destination: External | 4+d <sub>src</sub> +d <sub>dst</sub> | 4+d <sub>src</sub> +d <sub>dst</sub> | 4+d <sub>src</sub> +d <sub>dst</sub>       | 6+d <sub>src</sub> +d <sub>dst</sub> +2p |  |  |  |  |  |  |

#### **Cycles for a Single BLDD Instruction**

 $\ensuremath{^\dagger}$  If the destination operand and the code are in the same SARAM block.

|                                           | Cycles for a Repeat (RPT) Execution of a BLDD Instruction |                                         |                                                  |                                               |  |  |  |  |
|-------------------------------------------|-----------------------------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------------|--|--|--|--|
| Operand                                   | ROM                                                       | DARAM                                   | SARAM                                            | External                                      |  |  |  |  |
| Source: DARAM<br>Destination: DARAM       | n+2                                                       | n+2                                     | n+2                                              | n+2+2p                                        |  |  |  |  |
| Source: SARAM<br>Destination: DARAM       | n+2                                                       | n+2                                     | n+2                                              | n+2+2p                                        |  |  |  |  |
| Source: External<br>Destination: DARAM    | n+2+nd <sub>src</sub>                                     | n+2+nd <sub>src</sub>                   | n+2+nd <sub>src</sub>                            | n+2+nd <sub>src</sub> +2p                     |  |  |  |  |
| Source: DARAM<br>Destination: SARAM       | n+2                                                       | n+2                                     | n+2<br>n+4†                                      | n+2+2p                                        |  |  |  |  |
| Source: SARAM<br>Destination: SARAM       | n+2<br>2n‡                                                | n+2<br>2n‡                              | n+2<br>2n‡<br>n+4†<br>2n+2§                      | n+2+2p<br>2n+2p‡                              |  |  |  |  |
| Source: External<br>Destination: SARAM    | n+2+nd <sub>src</sub>                                     | n+2+nd <sub>src</sub>                   | n+2+nd <sub>src</sub><br>n+4+nd <sub>src</sub> † | n+2+nd <sub>src</sub> +2p                     |  |  |  |  |
| Source: DARAM<br>Destination: External    | 2n+2+nd <sub>dst</sub>                                    | 2n+2+nd <sub>dst</sub>                  | 2n+2+nd <sub>dst</sub>                           | 2n+2+nd <sub>dst</sub> +2p                    |  |  |  |  |
| Source: SARAM<br>Destination: External    | 2n+2+nd <sub>dst</sub>                                    | 2n+2+nd <sub>dst</sub>                  | 2n+2+nd <sub>dst</sub>                           | 2n+2+nd <sub>dst</sub> +2p                    |  |  |  |  |
| Source: External<br>Destination: External | 4n+nd <sub>src</sub> +nd <sub>dst</sub> ‡                 | 4n+nd <sub>src</sub> +nd <sub>dst</sub> | 4n+nd <sub>src</sub> +nd <sub>dst</sub>          | 4n+2+nd <sub>src</sub> +nd <sub>dst</sub> +2p |  |  |  |  |

 $^{\dagger}$  If the destination operand and the code are in the same SARAM block

<sup>4</sup> If both the source and the destination operands are in the same SARAM block <sup>§</sup> If both operands and the code are in the same SARAM block

01h

| Example 1 | BLDD | #300h,2                     | Oh ; (DP = 6)<br>Before Instruction |                             | After Instruction |
|-----------|------|-----------------------------|-------------------------------------|-----------------------------|-------------------|
|           |      | Data Memory<br>300h<br>320h | Oh<br>OFh                           | Data Memory<br>300h<br>320h | 0h                |
| Example 2 | BLDD | *+ <b>,</b> #321            |                                     |                             |                   |
|           |      |                             | Before Instruction                  |                             | After Instruction |
|           |      | ARP                         | 2                                   | ARP                         | 3                 |
|           |      | AR2                         | 301h                                | AR2                         | 302h              |
|           |      | Data Memory<br>301h         | 01h                                 | Data Memory<br>301h         | 01h               |

0Fh

321h

321h

BLDD Block Move From Data Memory to Data Memory

| Syntax      | General syntax: BLPD sour                                                                                                                                                                                                                                 | rce, destination                                       |  |  |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--|--|--|--|--|
|             | BLPD #pma, dma                                                                                                                                                                                                                                            | Direct with long immediate                             |  |  |  |  |  |
|             | BLPD #pma, ind [, ARn]                                                                                                                                                                                                                                    | source<br>Indirect with long immediate<br>source       |  |  |  |  |  |
| Operands    |                                                                                                                                                                                                                                                           | -                                                      |  |  |  |  |  |
| Opcode      | BLPD #pma, dma                                                                                                                                                                                                                                            |                                                        |  |  |  |  |  |
|             | 15 14 13 12 11 10 9<br>1 0 1 0 0 1 0                                                                                                                                                                                                                      | 1                                                      |  |  |  |  |  |
|             |                                                                                                                                                                                                                                                           | pma                                                    |  |  |  |  |  |
|             | BLPD #pma, ind [, ARn]                                                                                                                                                                                                                                    |                                                        |  |  |  |  |  |
|             | 15 14 13 12 11 10 9                                                                                                                                                                                                                                       | 876543210                                              |  |  |  |  |  |
|             | 1 0 1 0 0 1 0                                                                                                                                                                                                                                             | 1 1 ARU N NAR                                          |  |  |  |  |  |
|             |                                                                                                                                                                                                                                                           | pma                                                    |  |  |  |  |  |
|             | Note: ARU, N, and NAR are defined (page 7-12).                                                                                                                                                                                                            | in subsection 7.3.4, Indirect Addressing Opcode Format |  |  |  |  |  |
|             |                                                                                                                                                                                                                                                           |                                                        |  |  |  |  |  |
| Execution   | Increment PC, then<br>(PC) $\rightarrow$ MSTACK<br>pma $\rightarrow$ PC<br>(source) $\rightarrow$ destination<br>For indirect, modify (current AR)<br>(PC) + 1 $\rightarrow$ PC<br>While (repeat counter) $\neq$ 0:<br>(pource) $\rightarrow$ destination | and (ARP) as specified                                 |  |  |  |  |  |
|             | (source) $\rightarrow$ destination<br>For indirect, modify (current AR) and (ARP) as specified<br>(PC) + 1 $\rightarrow$ PC<br>(repeat counter) -1 $\rightarrow$ repeat counter                                                                           |                                                        |  |  |  |  |  |
|             | $(MSTACK) \to PC$                                                                                                                                                                                                                                         |                                                        |  |  |  |  |  |
| Status Bits | None                                                                                                                                                                                                                                                      |                                                        |  |  |  |  |  |
| PRELIMINARY |                                                                                                                                                                                                                                                           | Assembly Language Instructions 8-53                    |  |  |  |  |  |

2

DescriptionA word in program memory pointed to by the source is copied to data-memory<br/>space pointed to by destination. The first word of the source space is pointed<br/>to by a long-immediate value. The data-memory destination space is pointed<br/>to by a data-memory address or auxiliary register pointer. Not all source/des-<br/>tination combinations of pointer types are valid.RPT can be used with the BLPD instruction to move consecutive words. The<br/>number of words to be moved is one greater than the number contained in the<br/>repeat counter (RPTC) at the beginning of the instruction. When the BLPD in-<br/>struction is repeated, the source (program-memory) address specified by the

long immediate constant is stored to the PC. Because the PC is incremented by 1 during each repetition, it is possible to access a series of programmemory addresses. If you use indirect addressing to specify the destination (data-memory) address, a new data-memory address can be accessed during each repetition. If you use the direct addressing mode, the specified datamemory address is a constant; it is not modified during each repetition.

The source and destination blocks do not have to be entirely on chip or off chip. Interrupts are inhibited during a repeated BLPD instruction. When used with RPT, BLPD becomes a single-cycle instruction once the RPT pipeline is started.

Words

Cycles

| Operand                                    | ROM                | DARAM              | SARAM                                      | External                               |  |  |  |  |
|--------------------------------------------|--------------------|--------------------|--------------------------------------------|----------------------------------------|--|--|--|--|
| Source: DARAM/ROM Destination: DARAM       | 3                  | 3                  | 3                                          | 3+2p <sub>code</sub>                   |  |  |  |  |
| Source: SARAM<br>Destination: DARAM        | 3                  | 3                  | 3                                          | 3+2p <sub>code</sub>                   |  |  |  |  |
| Source: External<br>Destination: DARAM     | 3+p <sub>src</sub> | 3+p <sub>src</sub> | 3+p <sub>src</sub>                         | 3+p <sub>src</sub> +2p <sub>code</sub> |  |  |  |  |
| Source: DARAM/ROM<br>Destination: SARAM    | 3                  | 3                  | 3<br>4†                                    | 3+2p <sub>code</sub>                   |  |  |  |  |
| Source: SARAM<br>Destination: SARAM        | 3                  | 3                  | 3<br>4†                                    | 3+2p <sub>code</sub>                   |  |  |  |  |
| Source: External<br>Destination: SARAM     | 3+p <sub>src</sub> | 3+p <sub>src</sub> | 3+p <sub>src</sub><br>4+p <sub>src</sub> † | 3+p <sub>src</sub> +2p <sub>code</sub> |  |  |  |  |
| Source: DARAM/ROM<br>Destination: External | 4+d <sub>dst</sub> | 4+d <sub>dst</sub> | 4+d <sub>dst</sub>                         | 6+d <sub>dst</sub> +2p <sub>code</sub> |  |  |  |  |

#### **Cycles for a Single BLPD Instruction**

<sup>†</sup> If the destination operand and the code are in the same SARAM block

| Cycles for a Single BLPD Instruction (Continued) |                                      |                                      |                                      |                                                          |  |  |  |
|--------------------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|----------------------------------------------------------|--|--|--|
| Operand                                          | ROM                                  | DARAM                                | SARAM                                | External                                                 |  |  |  |
| Source: SARAM<br>Destination: External           | 4+d <sub>dst</sub>                   | 4+d <sub>dst</sub>                   | 4+d <sub>dst</sub>                   | 6+d <sub>dst</sub> +2p <sub>code</sub>                   |  |  |  |
| Source: External<br>Destination: External        | 4+p <sub>src</sub> +d <sub>dst</sub> | 4+p <sub>src</sub> +d <sub>dst</sub> | 4+p <sub>src</sub> +d <sub>dst</sub> | 6+p <sub>src</sub> +d <sub>dst</sub> +2p <sub>code</sub> |  |  |  |

<sup>†</sup> If the destination operand and the code are in the same SARAM block

| Operand                                    | ROM                                       | DARAM                                   | SARAM                                            | External                                                          |
|--------------------------------------------|-------------------------------------------|-----------------------------------------|--------------------------------------------------|-------------------------------------------------------------------|
| Source: DARAM/ROM<br>Destination: DARAM    | n+2                                       | n+2                                     | n+2                                              | n+2+2p <sub>code</sub>                                            |
| Source: SARAM<br>Destination: DARAM        | n+2                                       | n+2                                     | n+2                                              | n+2+2p <sub>code</sub>                                            |
| Source: External<br>Destination: DARAM     | n+2+np <sub>src</sub>                     | n+2+np <sub>src</sub>                   | n+2+np <sub>src</sub>                            | n+2+np <sub>src</sub> +2p <sub>code</sub>                         |
| Source: DARAM/ROM<br>Destination: SARAM    | n+2                                       | n+2                                     | n+2<br>n+4†                                      | n+2+2p <sub>code</sub>                                            |
| Source: SARAM<br>Destination: SARAM        | n+2<br>2n‡                                | n+2<br>2n‡                              | n+2<br>2n‡<br>n+4†<br>2n+2§                      | n+2+2p <sub>code</sub><br>2n+2p <sub>code</sub> ‡                 |
| Source: External<br>Destination: SARAM     | n+2+np <sub>src</sub> †                   | n+2+np <sub>src</sub>                   | n+2+np <sub>src</sub><br>n+4+np <sub>src</sub> † | n+2+np <sub>src</sub> +2p <sub>code</sub>                         |
| Source: DARAM/ROM<br>Destination: External | 2n+2+nd <sub>dst</sub>                    | 2n+2+nd <sub>dst</sub>                  | 2n+2+nd <sub>dst</sub>                           | 2n+2+nd <sub>dst</sub> +2p <sub>code</sub>                        |
| Source: SARAM<br>Destination: External     | 2n+2+nd <sub>dst</sub>                    | 2n+2+nd <sub>dst</sub>                  | 2n+2+nd <sub>dst</sub>                           | 2n+2+nd <sub>dst</sub> +2p <sub>code</sub>                        |
| Source: External<br>Destination: External  | 4n+np <sub>src</sub> +nd <sub>dst</sub> ‡ | 4n+np <sub>src</sub> +nd <sub>dst</sub> | 4n+np <sub>src</sub> +nd <sub>dst</sub>          | 4n+2+np <sub>src</sub> +nd <sub>dst</sub> +<br>2p <sub>code</sub> |

#### $\ensuremath{^\dagger}$ If the destination operand and the code are in the same SARAM block

 $\ddagger$  If both the source and the destination operands are in the same SARAM block

§ If both operands and the code are in the same SARAM block

0Fh

0Fh

7

310h

1111h

1111h

#### Example 1 #800h,00h ;(DP=6) BLPD **Before Instruction** After Instruction **Program Memory Program Memory** 800h 0Fh 800h Data Memory Data Memory 300h 0h 300h Example 2 #800h,\*,AR7 BLPD **Before Instruction** After Instruction

0

310h

1111h

0100h

ARP

AR0

**Program Memory** 

800h

Data Memory

310h

ARP

AR0

**Program Memory** 

800h

Data Memory

310h

PRELIMINARY

#### BLPD Block Move From Program Memory to Data Memory

| Syntax          | CALA                        |                            |                                 |                                      |                   |                                     |                                                                     |                             |               |                         |               |                                  |                                   |                    |               |
|-----------------|-----------------------------|----------------------------|---------------------------------|--------------------------------------|-------------------|-------------------------------------|---------------------------------------------------------------------|-----------------------------|---------------|-------------------------|---------------|----------------------------------|-----------------------------------|--------------------|---------------|
| Operands        | None                        |                            |                                 |                                      |                   |                                     |                                                                     |                             |               |                         |               |                                  |                                   |                    |               |
| Opcode          |                             | <u>14 13</u><br>0 1        | <u>3 12</u><br>1                | 11<br>1                              | 10<br>1           | 9<br>1                              | 8<br>0                                                              | 7<br>0                      | 6<br>0        | 5<br>1                  | 4<br>1        | 3<br>0                           | 2<br>0                            | 1<br>0             | 0             |
| Execution       | PC + 1<br>ACC(1             |                            |                                 |                                      |                   |                                     |                                                                     |                             |               |                         |               |                                  |                                   |                    |               |
| Status Bits     | None                        |                            |                                 |                                      |                   |                                     |                                                                     |                             |               |                         |               |                                  |                                   |                    |               |
| Description     | The cu<br>the sta<br>loaded | ack (T                     | DS). T                          | hen,                                 | the c             | onte                                | nts o                                                               | f the                       | lowe          | er ha                   | lf of         | the a                            |                                   |                    | •             |
|                 | The C                       | ALA ir                     | struct                          | ion is                               | use               | d to r                              | berfo                                                               | rm co                       | ompu          | uted :                  | subr          | outin                            | e cal                             | ls.                |               |
|                 |                             |                            |                                 |                                      |                   |                                     |                                                                     |                             |               |                         |               |                                  |                                   |                    |               |
| Words           | 1                           |                            |                                 |                                      |                   | ·                                   |                                                                     |                             |               |                         |               |                                  |                                   |                    |               |
| Words<br>Cycles | 1                           |                            |                                 |                                      | les fo            |                                     | Single                                                              | e CAI                       | _A In         | struc                   |               |                                  |                                   |                    |               |
|                 | 1<br><b>ROM</b>             |                            |                                 | Сус                                  |                   |                                     | Single                                                              |                             | _A In<br>RAM  | struc                   |               |                                  | ernal                             |                    |               |
|                 |                             |                            |                                 | Сус                                  | cles fo           |                                     | Single                                                              |                             |               | struc                   |               |                                  | ernal                             |                    |               |
|                 | ROM                         | tion w                     | this ins<br>ords ha             | Cyc<br>DAI<br>4<br>tructio<br>ve ent | cles for<br>RAM   | bras<br>hesth                       | e exec                                                              | SAF<br>4<br>cute ph         | RAM<br>nase o | fthep                   | <b>ipelin</b> | Ext<br>4+3<br>e, two             | ernal<br>Bp<br>additio            | l<br>onal in       |               |
|                 | <b>ROM</b><br>4             | tion w                     | this ins<br>ords ha             | Cyc<br>DAI<br>4<br>tructio<br>ve ent | cles for<br>RAM   | bras<br>hesth                       | e exec                                                              | SAF<br>4<br>cute ph         | RAM<br>nase o | fthep                   | <b>ipelin</b> | Ext<br>4+3<br>e, two             | ernal<br>Bp<br>additio            | l<br>onal in       |               |
| Cycles          | ROM<br>4<br>Note:           | tion w<br>instru           | this ins<br>ords ha<br>ction wo | Cyc<br>DAI<br>4<br>tructio<br>ve ent | n reac<br>tered t | br a S<br>hes th<br>he pip<br>arded | e exec<br>beline.<br>structi                                        | SAF<br>4<br>cute ph<br>Wher | RAM<br>nase o | f the p<br>PC dis       | <b>ipelin</b> | Ext<br>4+3<br>e, two<br>nuity is | ernal<br>Bp<br>additions<br>taker | onal in<br>h, thes | e two         |
| Cycles          | ROM<br>4<br>Note:           | tion w<br>instru<br>F      | this ins<br>ords ha<br>ction wo | Cyc<br>DAI<br>4<br>tructio<br>ve ent | n reac<br>tered t | br a S<br>hes th<br>he pip<br>arded | e exec<br>beline.<br>structi                                        | SAF<br>4<br>cute ph<br>Wher | RAM<br>nase o | f the p<br>°C dis<br>PC | <b>ipelin</b> | Ext<br>4+3<br>e, two<br>nuity is | ernal<br>Bp<br>additions<br>taker | onal in<br>h, thes | iction<br>83h |
| Cycles          | ROM<br>4<br>Note:           | tion w<br>instru<br>F<br>A | this ins<br>ords ha<br>ction wo | Cyc<br>DAI<br>4<br>tructio<br>ve ent | n reac<br>tered t | br a S<br>hes th<br>he pip<br>arded | e exec<br>beline.<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>• | SAF<br>4<br>cute ph<br>Wher | RAM<br>nase o | f the p<br>PC dis       | <b>ipelin</b> | Ext<br>4+3<br>e, two<br>nuity is | ernal<br>Bp<br>additions<br>taker | onal in<br>h, thes | e two         |

| Syntax      | CALL pma [, ind [, ARn]] Indirect addressing                                                                                                                                                                                                                                                             |                                                                                                                                                                            |                                                                                                                  |                                                                    |  |  |  |  |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--|--|--|--|--|
| Operands    | pma:16-bit program-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options: $*$ $* + * - *0 + *0 - *BR0 + *BR0 -$                                                                                                                         |                                                                                                                                                                            |                                                                                                                  |                                                                    |  |  |  |  |  |
| Opcode      | 15 14<br>0 1<br>Note: Al                                                                                                                                                                                                                                                                                 | ma [, ind [, <b>AR</b> n]]<br><u>13</u> <u>12</u> <u>11</u> <u>10</u> <u>9</u><br><u>1</u> <u>1</u> <u>1</u> <u>0</u> <u>1</u><br>RU, N, and NAR are defined<br>age 7-12). | 0 1 AR<br>pma                                                                                                    |                                                                    |  |  |  |  |  |
| Execution   | PC + 2 $\rightarrow$ TOS<br>pma $\rightarrow$ PC<br>Modify (current AR) and (ARP) as specified.                                                                                                                                                                                                          |                                                                                                                                                                            |                                                                                                                  |                                                                    |  |  |  |  |  |
| Status Bits | None                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                            |                                                                                                                  |                                                                    |  |  |  |  |  |
| Description | The current program counter (PC) is incremented and pushed onto the top of the stack (TOS). Then, the contents of the pma, either a symbolic or numeric address, are loaded into the PC. Execution continues at this address. The current auxiliary register and ARP contents are modified as specified. |                                                                                                                                                                            |                                                                                                                  |                                                                    |  |  |  |  |  |
| Words       | 2                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                            |                                                                                                                  |                                                                    |  |  |  |  |  |
| Cycles      |                                                                                                                                                                                                                                                                                                          | Cycles for a                                                                                                                                                               | Single CALL Instruc                                                                                              | tion                                                               |  |  |  |  |  |
|             | ROM                                                                                                                                                                                                                                                                                                      | DARAM                                                                                                                                                                      | SARAM                                                                                                            | External                                                           |  |  |  |  |  |
|             | 4                                                                                                                                                                                                                                                                                                        | 4                                                                                                                                                                          | 4                                                                                                                | 4+4p†                                                              |  |  |  |  |  |
|             | tion                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                            | peline. When the PC dis                                                                                          | ipeline, two additional instruc-<br>continuity is taken, these two |  |  |  |  |  |
| Example     |                                                                                                                                                                                                                                                                                                          | 191, *+, AR0 Before Ins ARP AR1 PC TOS                                                                                                                                     | attraction           1         ARP           05h         AR1           30h         PC           100h         TOS | After Instruction<br>0<br>06h<br>0BFh<br>32h                       |  |  |  |  |  |

Program address 0BFh (191) is loaded into the program counter, and the program continues executing from that location.

| Syntax      | CC pma, co                                                                                                                                                                                                                                                                                                                                                                 | ond 1 [,coi  | nd 2] [,                                                                                                                                                                                                                                                                                                                                                                              | ]             |         |             |          |         |         |       |       |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------|-------------|----------|---------|---------|-------|-------|
| Operands    | pma:<br><u>cond</u><br>EQ<br>NEQ<br>LT<br>LEQ<br>GT<br>GEQ<br>NC<br>C<br>NOV<br>OV<br>BIO<br>NTC<br>TC<br>UNC                                                                                                                                                                                                                                                              |              | $\begin{array}{l} \hline \text{ondition}\\ \hline \text{CC} = 0\\ \hline \text{CC} \neq 0\\ \hline \text{CC} \leq 0\\ \hline \text{CC} \leq 0\\ \hline \text{CC} \geq 0\\ \hline \text{CC} \geq 0\\ \hline = 0\\ \hline = 1\\ \hline \hline \text{V} = 0\\ \hline \hline \text{V} = 1\\ \hline \hline \text{O} \text{ low}\\ \hline \text{C} = 0\\ \hline \text{C} = 1\\ \end{array}$ | ionally       | addre   | ess         |          |         |         |       |       |
| Opcode      |                                                                                                                                                                                                                                                                                                                                                                            |              | 1 10                                                                                                                                                                                                                                                                                                                                                                                  | 98            | 7       | 65          | 4        | 3       | 2       | 1     | 0     |
|             | 1 1                                                                                                                                                                                                                                                                                                                                                                        | 1 0          | 10_                                                                                                                                                                                                                                                                                                                                                                                   | TP<br>pr      | na      | ZLVC        |          |         | ZL      | VC    |       |
|             | Note: The                                                                                                                                                                                                                                                                                                                                                                  | TP and ZLV   | C fields a                                                                                                                                                                                                                                                                                                                                                                            |               |         | s 8-3 and 8 | 3-4.     |         |         |       |       |
| Execution   | If cond 1 AND cond 2 AND<br>Then<br>$PC + 2 \rightarrow TOS$<br>$pma \rightarrow PC$<br>Else<br>Increment PC                                                                                                                                                                                                                                                               |              |                                                                                                                                                                                                                                                                                                                                                                                       |               |         |             |          |         |         |       |       |
| Status Bits | None                                                                                                                                                                                                                                                                                                                                                                       |              |                                                                                                                                                                                                                                                                                                                                                                                       |               |         |             |          |         |         |       |       |
| Description | Control is passed to the specified program-memory address (pma) if the speci-<br>fied conditions are met. Not all combinations of conditions are meaningful. For<br>example, testing for LT and GT is contradictory. In addition, testing BIO is<br>mutually exclusive to testing TC. The CC instruction operates like the CALL<br>instruction if all conditions are true. |              |                                                                                                                                                                                                                                                                                                                                                                                       |               |         |             |          |         |         |       |       |
| Words       | 2                                                                                                                                                                                                                                                                                                                                                                          |              |                                                                                                                                                                                                                                                                                                                                                                                       |               |         |             |          |         |         |       |       |
| Cycles      |                                                                                                                                                                                                                                                                                                                                                                            |              | Cycles                                                                                                                                                                                                                                                                                                                                                                                | for a Sing    | gle CC  | Instructi   | ion      |         |         |       |       |
|             | Condition                                                                                                                                                                                                                                                                                                                                                                  | ROM          |                                                                                                                                                                                                                                                                                                                                                                                       | DARAM         | -       | SARAN       |          | E       | Exterr  | nal   |       |
|             | True                                                                                                                                                                                                                                                                                                                                                                       | 4            |                                                                                                                                                                                                                                                                                                                                                                                       | 4             |         | 4           |          | 2       | 1+4p†   |       |       |
|             | False                                                                                                                                                                                                                                                                                                                                                                      | 2            |                                                                                                                                                                                                                                                                                                                                                                                       | 2             |         | 2           |          | 2       | 2+2p    |       |       |
|             | † The process                                                                                                                                                                                                                                                                                                                                                              | sor performs | specula                                                                                                                                                                                                                                                                                                                                                                               | tive fetching | by read | ing two add | litional | linstru | ction w | ords. | lfthe |

The processor performs speculative fetching by reading two additional instruction words. If the PC discontinuity is taken, these two instruction words are discarded.

СС

### Example

PGM191,LEQ,C

If the accumulator contents are less than or equal to 0 and the carry bit is set, 0BFh (191) is loaded into the program counter, and the program continues to execute from that location. If the conditions are not met, execution continues at the instruction following the CC instruction.

| Syntax      | CLRO                           | C con   | ntrol                      | bit                                     |                                              |                                                                            |                                                     |                                                     |                                             |                                                      |                                                    |                                               |                                |            |   |    |
|-------------|--------------------------------|---------|----------------------------|-----------------------------------------|----------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|---------------------------------------------|------------------------------------------------------|----------------------------------------------------|-----------------------------------------------|--------------------------------|------------|---|----|
| Operands    | contro                         | ol bit: | 0<br>0<br>1<br>0<br>5<br>7 | Selec<br>CNF<br>NTM<br>DVM<br>SXM<br>CC | Ca<br>R/<br>In<br>O <sup>r</sup><br>Si<br>Te | e of th<br>arry b<br>AM co<br>terrup<br>verflo<br>gn-ex<br>est/co<br>= pin | bit of<br>onfig<br>ot mo<br>ow m<br>otens<br>ontrol | statu<br>jurati<br>ode b<br>ode l<br>sion r<br>flag | on co<br>oit of<br>oit of<br>node<br>bit of | gister<br>ontro<br>statu<br>statu<br>bit c<br>f stat | ST1<br>bit o<br>s reg<br>us reg<br>of sta<br>us re | of sta<br>jister<br>gister<br>tus re<br>giste | ST0<br>r ST(<br>egist<br>er ST | )<br>er Sī |   | Г1 |
| Opcode      | CLRO                           | cc      |                            |                                         |                                              |                                                                            |                                                     |                                                     |                                             |                                                      |                                                    |                                               |                                |            |   |    |
| opoodo      | 15                             | 14      | 13                         | 12                                      | 11                                           | 10                                                                         | 9                                                   | 8                                                   | 7                                           | 6                                                    | 5                                                  | 4                                             | 3                              | 2          | 1 | 0  |
|             | 1                              | 0       | 1                          | 1                                       | 1                                            | 1                                                                          | 1                                                   | 0                                                   | 0                                           | 1                                                    | 0                                                  | 0                                             | 1                              | 1          | 1 | 0  |
|             | CLRO                           |         | F                          |                                         |                                              |                                                                            |                                                     |                                                     |                                             |                                                      |                                                    |                                               |                                |            |   |    |
|             | 15                             | 14      | 13                         | 12                                      | 11                                           | 10                                                                         | 9                                                   | 8                                                   | 7                                           | 6                                                    | 5                                                  | 4                                             | 3                              | 2          | 1 | 0  |
|             | 1                              | 0       | 1                          | 1                                       | 1                                            | 1                                                                          | 1                                                   | 0                                                   | 0                                           | 1                                                    | 0                                                  | 0                                             | 0                              | 1          | 0 | 0  |
|             | CLRO                           | C INT   | м                          |                                         |                                              |                                                                            |                                                     |                                                     |                                             |                                                      |                                                    |                                               |                                |            |   |    |
|             | 15                             | 14      | 13                         | 12                                      | 11                                           | 10                                                                         | 9                                                   | 8                                                   | 7                                           | 6                                                    | 5                                                  | 4                                             | 3                              | 2          | 1 | 0  |
|             | 1                              | 0       | 1                          | 1                                       | 1                                            | 1                                                                          | 1                                                   | 0                                                   | 0                                           | 1                                                    | 0                                                  | 0                                             | 0                              | 0          | 0 | 0  |
|             | CLRC OVM                       |         |                            |                                         |                                              |                                                                            |                                                     |                                                     |                                             |                                                      |                                                    |                                               |                                |            |   |    |
|             | 15                             | 14      | 13                         | 12                                      | 11                                           | 10                                                                         | 9                                                   | 8                                                   | 7                                           | 6                                                    | 5                                                  | 4                                             | 3                              | 2          | 1 | 0  |
|             | 1                              | 0       | 1                          | 1                                       | 1                                            | 1                                                                          | 1                                                   | 0                                                   | 0                                           | 1                                                    | 0                                                  | 0                                             | 0                              | 0          | 1 | 0  |
|             | CLRO                           | C SXI   | М                          |                                         |                                              |                                                                            |                                                     |                                                     |                                             |                                                      |                                                    |                                               |                                |            |   |    |
|             | 15                             | 14      | 13                         | 12                                      | 11                                           | 10                                                                         | 9                                                   | 8                                                   | 7                                           | 6                                                    | 5                                                  | 4                                             | 3                              | 2          | 1 | 0  |
|             | 1                              | 0       | 1                          | 1                                       | 1                                            | 1                                                                          | 1                                                   | 0                                                   | 0                                           | 1                                                    | 0                                                  | 0                                             | 0                              | 1          | 1 | 0  |
|             | CLRO                           | стс     |                            |                                         |                                              |                                                                            |                                                     |                                                     |                                             |                                                      |                                                    |                                               |                                |            |   |    |
|             | 15                             | 14      | 13                         | 12                                      | 11                                           | 10                                                                         | 9                                                   | 8                                                   | 7                                           | 6                                                    | 5                                                  | 4                                             | 3                              | 2          | 1 | 0  |
|             | 1                              | 0       | 1                          | 1                                       | 1                                            | 1                                                                          | 1                                                   | 0                                                   | 0                                           | 1                                                    | 0                                                  | 0                                             | 1                              | 0          | 1 | 0  |
|             | CLRO                           | C XF    |                            |                                         |                                              |                                                                            |                                                     |                                                     |                                             |                                                      |                                                    |                                               |                                |            |   |    |
|             | 15                             | 14      | 13                         | 12                                      | 11                                           | 10                                                                         | 9                                                   | 8                                                   | 7                                           | 6                                                    | 5                                                  | 4                                             | 3                              | 2          | 1 | 0  |
|             | 1                              | 0       | 1                          | 1                                       | 1                                            | 1                                                                          | 1                                                   | 0                                                   | 0                                           | 1                                                    | 0                                                  | 0                                             | 1                              | 1          | 0 | 0  |
| Execution   | Increi<br>0 → c                |         |                            |                                         | ۱                                            |                                                                            |                                                     |                                                     |                                             |                                                      |                                                    |                                               |                                |            |   |    |
| Status Bits | None                           |         |                            |                                         |                                              |                                                                            |                                                     |                                                     |                                             |                                                      |                                                    |                                               |                                |            |   |    |
| Description | The s<br>be us<br><i>ST1</i> , | ed to   | load                       | d ST(                                   | ) and                                        | ST1                                                                        | . Se                                                | e sub                                               | secti                                       | ion 3                                                | .5, <i>S</i>                                       | tatus                                         | Reg                            | ister      |   |    |

Assembly Language Instructions 8-61

1

Words

Cycles

| Cycles for a Single CLRC Instruction |       |       |          |  |  |
|--------------------------------------|-------|-------|----------|--|--|
| ROM                                  | DARAM | SARAM | External |  |  |
| 1                                    | 1     | 1     | 1+p      |  |  |

## Cycles for a Repeat (RPT) Execution of a CLRC Instruction

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| n   | n     | n     | n+p      |

Example

### CLRC TC ; (TC is bit 11 of ST1)

|     | Before Instruction |     | After Instruction |
|-----|--------------------|-----|-------------------|
| ST1 | x9xxh              | ST1 | x1xxh             |

| Syntax      | CMPL                                                                   |                     |            |            |          |                  |         |        |       |
|-------------|------------------------------------------------------------------------|---------------------|------------|------------|----------|------------------|---------|--------|-------|
| Operands    | None                                                                   |                     |            |            |          |                  |         |        |       |
| Opcode      | 15 14 13 12<br>1 0 1 1                                                 | <u>11 10</u><br>1 1 | 9 8<br>1 0 | 7 6<br>0 0 | -        | 4 <u>3</u><br>00 | 2<br>0  | 1<br>0 | 0     |
| Execution   | $\frac{\text{Increment PC, the}}{(\text{ACC})} \rightarrow \text{ACC}$ | en                  |            |            |          |                  |         |        |       |
| Status Bits | None                                                                   |                     |            |            |          |                  |         |        |       |
| Description | The contents of the complement). The                                   |                     |            |            | with its | s logica         | ıl inve | ersio  | n (1s |
| Words       | 1                                                                      |                     |            |            |          |                  |         |        |       |
| Cycles      |                                                                        | Cycles fo           | or a Singl | e CMPL In  | structio | on               |         |        |       |
|             | ROM                                                                    | DARAM               |            | SARAM      |          | Ext              | ernal   |        |       |
|             | 1                                                                      | 1                   | _          | 1          |          | 1+p              |         |        |       |

|    | Cycles for a Repeat (RPT | ) Execution of an C | MPL Instruction |
|----|--------------------------|---------------------|-----------------|
| ОМ | DARAM                    | SARAM               | External        |

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| n   | n     | n     | n+p      |

Example

CMPL

|     |   | Before Instruction |     |   | After Instruction |
|-----|---|--------------------|-----|---|-------------------|
| ACC | X | 0F7982513h         | ACC | X | 0867DAECh         |
|     | С |                    |     | С |                   |

| Syntax      | CMPR                                                                                                                                                                                                  | CM                  |         |                |                |        |        |         |        |        |        |        |        |        |         |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------|----------------|----------------|--------|--------|---------|--------|--------|--------|--------|--------|--------|---------|
| Operands    | CM:                                                                                                                                                                                                   |                     | Value   | e fror         | n 0 to         | o 3    |        |         |        |        |        |        |        |        |         |
| Opcode      | 15<br>1                                                                                                                                                                                               | <u>14 13</u><br>0 1 | 12<br>1 | <u>11</u><br>1 | <u>10</u><br>1 | 9<br>1 | 8<br>1 | 7<br>0  | 6<br>1 | 5<br>0 | 4      | 3<br>0 | 2<br>1 | 1<br>C | 0<br>CM |
| Execution   | Increm<br>Compa<br>registe                                                                                                                                                                            | are (cu             | rrent   |                | to (A          | R0)    | and    | place   | e the  | resu   | ılt in | the 7  | ⊺C bi  | t of s | status  |
| Status Bits | <u>Affects</u><br>TC                                                                                                                                                                                  | <u>5</u>            |         |                |                |        |        |         |        |        |        |        |        |        |         |
|             | This in                                                                                                                                                                                               | structi             | on is i | not a          | ffecte         | ed by  | SXN    | Л. It c | does   | not a  | affect | SXN    | Λ.     |        |         |
| Description | The C                                                                                                                                                                                                 | MPR ir              | nstruc  | tion p         | oerfo          | rms a  | a cor  | npari   | son :  | spec   | ified  | by th  | e val  | ue o   | f CM:   |
|             | If CM = 00, test whether (current AR) = (AR0)<br>If CM = 01, test whether (current AR) < (AR0)<br>If CM = 10, test whether (current AR) > (AR0)<br>If CM = 11, test whether (current AR) $\neq$ (AR0) |                     |         |                |                |        |        |         |        |        |        |        |        |        |         |
|             | If the condition is true, the TC bit is set to 1. If the condition is false, the TC bit is cleared to 0.                                                                                              |                     |         |                |                |        |        |         |        |        |        |        |        |        |         |
|             | Note that the auxiliary register values are treated as unsigned integers in the comparisons.                                                                                                          |                     |         |                |                |        |        |         |        |        |        |        |        |        |         |
| Words       | 1                                                                                                                                                                                                     |                     |         |                |                |        |        |         |        |        |        |        |        |        |         |
| Cycles      |                                                                                                                                                                                                       |                     |         | Сус            | les fo         | or a S | Single | e CM    | PR In  | struc  | ction  |        |        |        |         |
|             | ROM                                                                                                                                                                                                   |                     |         | DAI            | RAM            |        |        | SA      | RAM    |        |        | Ext    | ernal  |        |         |
|             | 1                                                                                                                                                                                                     |                     |         | 1              |                |        |        | 1       |        |        |        | 1+p    | )      |        |         |
|             | Cycles for a Repeat (RPT) Execution of an CMPR Instruction                                                                                                                                            |                     |         |                |                |        |        |         |        |        |        |        |        |        |         |
|             | ROM                                                                                                                                                                                                   |                     |         | DAI            | RAM            |        |        | SAI     | RAM    |        |        | Ext    | ernal  |        |         |
|             | n                                                                                                                                                                                                     |                     |         | n              |                |        |        | n       |        |        |        | n+p    | )      |        |         |

Example

CMPR

;(current AR) > (AR0)?

| 2   | ;(current          | AR) > (AR0)? |                   |
|-----|--------------------|--------------|-------------------|
|     | Before Instruction |              | After Instruction |
| ARP | 4                  | ARP          | 4                 |
| AR0 | 0FFFFh             | AR0          | 0FFFFh            |
| AR4 | 7FFFh              | AR4          | 7FFFh             |
| тс  | 1                  | TC           | 0                 |

| Syntax      | DMOV dmaDirect addressingDMOV ind [, ARn]Indirect addressing                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+*+*0+* BR0+*BR0-                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
| Opcode      | DMOV dma                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|             | 0 1 1 1 0 1 1 1 0 dma                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|             | DMOV ind [, ARn]                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|             | 0 1 1 1 0 1 1 1 1 ARU N NAR                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
| Execution   | Note: ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|             | (data-memory address) $\rightarrow$ data-memory address + 1                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
| Status Bits | <u>Affected by</u><br>CNF                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Description | The contents of the specified data-memory address are copied into the contents of the next higher address. When data is copied from the addressed location to the next higher location, the contents of the addressed location remain unaltered.                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
|             | DMOV works only within on-chip data RAM blocks. It works within any confi-<br>gurable RAM block if that block is configured as data memory. In addition, the<br>data move function is continuous across block boundaries. The data move<br>function cannot be performed on external data memory. If the instruction spec-<br>ifies an external memory address, DMOV reads the specified memory location<br>but performs <i>no</i> operations. |  |  |  |  |  |  |  |  |
|             | The data move function is useful in implementing the $z^{-1}$ delay encountered in digital signal processing. The DMOV function is a subtask of the LTD and MACD instructions (see the LTD and MACD instructions for more information).                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |

### **DMOV** Data Move in Data Memory

### Cycles

#### Cycles for a Single DMOV Instruction

|           | Program |       |       |          |  |  |  |  |  |
|-----------|---------|-------|-------|----------|--|--|--|--|--|
| Operand   | ROM     | DARAM | SARAM | External |  |  |  |  |  |
| DARAM     | 1       | 1     | 1     | 1+p      |  |  |  |  |  |
| SARAM     | 1       | 1     | 1, 3† | 1+p      |  |  |  |  |  |
| External‡ | 2+2d    | 2+2d  | 2+2d  | 5+2d+p   |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

If used on external memory, DMOV reads the specified memory location but performs no operations.

|           | Program  |          |             |            |  |  |  |  |  |
|-----------|----------|----------|-------------|------------|--|--|--|--|--|
| Operand   | ROM      | DARAM    | SARAM       | External   |  |  |  |  |  |
| DARAM     | n        | n        | n           | n+p        |  |  |  |  |  |
| SARAM     | 2n–2     | 2n–2     | 2n–2, 2n+1† | 2n–2+p     |  |  |  |  |  |
| External‡ | 4n-2+2nd | 4n-2+2nd | 4n-2+2nd    | 4n+1+2nd+p |  |  |  |  |  |

### Cycles for a Repeat (RPT) Execution of a DMOV Instruction

<sup>†</sup> If the operand and the code are in the same SARAM block

<sup>‡</sup> If used on external memory, DMOV reads the specified memory location but performs no operations.

| Example 1 | DMOV | DAT8                | ; $(DP = 6)$       |                     |                          |
|-----------|------|---------------------|--------------------|---------------------|--------------------------|
|           |      |                     | Before Instruction |                     | After Instruction        |
|           | C    | 0ata Memory<br>308h | 43h                | Data Memory<br>308h | 43h                      |
|           | C    | ata Memory<br>309h  | 2h                 | Data Memory<br>309h | 43h                      |
| Example 2 | DMOV | *,AR1               |                    |                     |                          |
|           | DMOV | , ALT               |                    |                     |                          |
|           | DMOV | , ANI               | Before Instruction |                     | After Instruction        |
|           | DMOV | ARP                 | Before Instruction | ARP                 | After Instruction        |
|           | DMOV | ·                   |                    | ARP<br>AR0          | After Instruction 1 30Ah |
|           |      | ARP                 | 0                  |                     | 1                        |

| Syntax      | IDLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |                |                |                |                   |        |        |        |        |               |      |        |        |        |       |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------------|----------------|----------------|-------------------|--------|--------|--------|--------|---------------|------|--------|--------|--------|-------|
| Operands    | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | )       |                |                |                |                   |        |        |        |        |               |      |        |        |        |       |
| Opcode      | 15<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 14<br>0 | <u>13</u><br>1 | <u>12</u><br>1 | <u>11</u><br>1 | <u>10</u><br>1    | 9<br>1 | 8<br>0 | 7<br>0 | 6<br>0 | <u>5</u><br>1 | 4    | 3<br>0 | 2<br>0 | 1<br>1 | 0     |
| Execution   | Incre                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | men     | t PC,          | , ther         | n wai          | t for u           | unma   | asked  | d or r | nonm   | naska         | able | hardv  | ware   | inter  | rupt. |
| Status Bits | <u>Affec</u><br>INTM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         | <u>9</u>       |                |                |                   |        |        |        |        |               |      |        |        |        |       |
| Description | <ul> <li>The IDLE instruction forces the program being executed to halt until the CPU receives a request from an unmasked hardware interrupt (external or internal), NMI, or reset. Execution of the IDLE instruction causes the 'C24x to enter a power-down mode. The PC is incremented once before the 'C24x enters power down; it is not incremented during the idle state. On-chip peripherals remain active; thus, their interrupts are among those that can wake the processor.</li> <li>The idle state is exited by an unmasked interrupt even if INTM is 1. (INTM, the interrupt mode bit of status register ST0, normally disables maskable interrupts when it is set to 1.) When the idle state is exited by an unmasked interrupt, the CPU's next action, however, depends on INTM:</li> <li>If INTM is 0, the program branches to the corresponding interrupt service routine.</li> <li>If INTM is 1, the program continues executing at the instruction following the IDLE.</li> </ul> |         |                |                |                |                   |        |        |        |        |               |      |        |        |        |       |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |                |                |                |                   |        |        |        |        |               |      |        |        |        |       |
| Cycles      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |                |                | Су             | cles f            | or a   | Singl  | e IDL  | .E Ins | struc         | tion |        |        |        |       |
|             | ROM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1       |                |                | DA             | RAM               |        |        | SAF    | RAM    |               |      | Ext    | ernal  |        |       |
|             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |                |                | 1              |                   |        |        | 1      |        |               |      | 1+p    | )      |        |       |
| Example     | IDLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1       | ;              |                | ard            | oces<br>ware<br>• |        |        |        |        |               |      |        |        |        | et,   |

| Syntax      |                                                                                                                                                                                                                           | IN dma, PA<br>IN ind, PA [, ARn] |                 |                |                |         |        |              |       |         | Direct addressing<br>Indirect addressing |        |        |        |         |       |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------|----------------|----------------|---------|--------|--------------|-------|---------|------------------------------------------|--------|--------|--------|---------|-------|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerPA:16-bit I/O port or I/O-mapped register addressind:Select one of the following seven options:* $*_{+}$ **_{0+}**_{BR0+} |                                  |                 |                |                |         |        |              |       |         |                                          |        |        |        |         |       |
| Opcode      | IN                                                                                                                                                                                                                        | dma ,                            | PA              |                |                |         |        |              |       |         |                                          |        |        |        |         |       |
| •           | 15                                                                                                                                                                                                                        | 14                               | 13              | 12             | 11             | 10      | 9      | 8            | 7     | 6       | 5                                        | 4      | 3      | 2      | 1       | 0     |
|             | 1                                                                                                                                                                                                                         | 0                                | 1               | 0              | 1              | 1       | 1      | 1            | 0     |         |                                          |        | dma    |        |         |       |
|             |                                                                                                                                                                                                                           |                                  |                 |                |                |         |        | Р            | PA    |         |                                          |        |        |        |         |       |
|             | IN ind ,PA [,ARn]                                                                                                                                                                                                         |                                  |                 |                |                |         |        |              |       |         |                                          |        |        |        |         |       |
|             | 15                                                                                                                                                                                                                        | 14                               | 13              | 12             | 11             | 10      | 9      | 8            | 7     | 6       | 5                                        | 4      | 3      | 2      | 1       | 0     |
|             | 1                                                                                                                                                                                                                         | 0                                | 1               | 0              | 1              | 1       | 1      | 1            | 1     |         | ARU                                      |        | Ν      |        | NAR     |       |
|             | Not                                                                                                                                                                                                                       | e: A                             | RU, N           | , and I        | NAR a          | are def | ined i | P<br>in Sect |       | 3, Indi | rect Ac                                  | ldress | sing M | ode (p | bage 7- | –12). |
| Execution   | C                                                                                                                                                                                                                         | $A \rightarrow$                  | addre<br>us lir | ess b<br>nes D | ous li<br>015– | D0 —    | → dat  | a-me         | mory  | add     | lress                                    |        |        |        |         |       |
| Status Bits | None                                                                                                                                                                                                                      |                                  |                 |                |                |         |        |              |       |         |                                          |        |        |        |         |       |
| Description | The I<br>data-<br>STRE<br>read.                                                                                                                                                                                           | mem                              | ory lo          | ocatio         | on. T          | he IS   | 5 line | e goe        | s low | ı to i  | ndica                                    | te ar  | n I/O  | acc    | ess     | The   |
|             | The r                                                                                                                                                                                                                     | •                                | •               | ,              |                |         |        |              |       |         |                                          | l ins  | tructi | on t   | o read  | d in  |
| Words       | 2                                                                                                                                                                                                                         |                                  |                 |                |                |         |        |              |       |         |                                          |        |        |        |         |       |

| Cycles                | Cycles for a Single IN Instruction    |                                       |                                                |                                                           |  |  |  |  |  |  |
|-----------------------|---------------------------------------|---------------------------------------|------------------------------------------------|-----------------------------------------------------------|--|--|--|--|--|--|
|                       | Program                               |                                       |                                                |                                                           |  |  |  |  |  |  |
| Operand               | ROM                                   | DARAM                                 | SARAM                                          | External                                                  |  |  |  |  |  |  |
| Destination: DARAM    | 2+io <sub>src</sub>                   | 2+io <sub>src</sub>                   | 2+io <sub>src</sub>                            | 3+io <sub>src</sub> +2p <sub>code</sub>                   |  |  |  |  |  |  |
| Destination: SARAM    | 2+io <sub>src</sub>                   | 2+io <sub>src</sub>                   | 2+io <sub>src</sub> †<br>3+io <sub>src</sub> † | 3+io <sub>src</sub> +2p <sub>code</sub>                   |  |  |  |  |  |  |
| Destination: External | 3+d <sub>dst</sub> +io <sub>src</sub> | 3+d <sub>dst</sub> +io <sub>src</sub> | 3+d <sub>dst</sub> +io <sub>src</sub>          | 6+d <sub>dst</sub> +io <sub>src</sub> +2p <sub>code</sub> |  |  |  |  |  |  |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

### Cycles for a Repeat (RPT) Execution of an IN Instruction

|                       | Program                                        |                                            |                                                    |                                                                    |  |  |  |  |  |
|-----------------------|------------------------------------------------|--------------------------------------------|----------------------------------------------------|--------------------------------------------------------------------|--|--|--|--|--|
| Operand               | ROM                                            | DARAM                                      | SARAM                                              | External                                                           |  |  |  |  |  |
| Destination: DARAM    | 2n+nio <sub>src</sub>                          | 2n+nio <sub>src</sub>                      | 2n+nio <sub>src</sub>                              | 2n+1+nio <sub>src</sub> +2p <sub>code</sub>                        |  |  |  |  |  |
| Destination: SARAM    | 2n+nio <sub>src</sub>                          | 2n+nio <sub>src</sub>                      | 2n+nio <sub>src</sub><br>2n+2+nio <sub>src</sub> † | 2n+1+nio <sub>src</sub> +2p <sub>code</sub>                        |  |  |  |  |  |
| Destination: External | 4n–1+nd <sub>dst</sub> +<br>nio <sub>src</sub> | 4n–1+nd <sub>dst</sub> +nio <sub>src</sub> | 4n–1+nd <sub>dst</sub> +nio <sub>src</sub>         | 4n+2+nd <sub>dst</sub> +nio <sub>src</sub> +<br>2p <sub>code</sub> |  |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Example 1 | IN | 7,1000h | ;Read in word from peripheral on<br>;port address 1000h. Store word in<br>;data memory location 307h (DP=6).                              |
|-----------|----|---------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Example 2 | IN | *,5h    | ;Read in word from peripheral on<br>;port address 5h. Store word in<br>;data memory location specified by<br>;current auxiliary register. |

| Syntax      | INTR K                                                                                                                                                                                    |                                                                                                                     |                                                                                                                    |                                                                         |                                                                            |                                                                                 |                                                                           |                                                                       |                                                                                     |                                                                                        |                                                                                    |                                                                                     |                                                                                       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| Operands    | K: Value from 0 to 31 that indicates the interrupt vector location to branch to                                                                                                           |                                                                                                                     |                                                                                                                    |                                                                         |                                                                            |                                                                                 |                                                                           |                                                                       |                                                                                     |                                                                                        |                                                                                    |                                                                                     |                                                                                       |
| Opcode      |                                                                                                                                                                                           | <u>3 12</u><br>I 1                                                                                                  | <u>11 10</u><br>1 1                                                                                                | 9<br>1                                                                  | 8<br>0                                                                     | 7<br>0                                                                          | 6<br>1                                                                    | 5<br>1                                                                | 4                                                                                   | 3                                                                                      | 2<br>K                                                                             | 1                                                                                   | 0                                                                                     |
| Execution   | (PC) + 1 $\rightarrow$ stack corresponding interrupt vector location $\rightarrow$ PC                                                                                                     |                                                                                                                     |                                                                                                                    |                                                                         |                                                                            |                                                                                 |                                                                           |                                                                       |                                                                                     |                                                                                        |                                                                                    |                                                                                     |                                                                                       |
| Status Bits | <u>Affects</u><br>INTM<br>This instruction is not affected by INTM.                                                                                                                       |                                                                                                                     |                                                                                                                    |                                                                         |                                                                            |                                                                                 |                                                                           |                                                                       |                                                                                     |                                                                                        |                                                                                    |                                                                                     |                                                                                       |
| Description | The process<br>sented by a<br>that transfer<br>K. The vector<br>routine. Thu<br>to be execut<br>ing K values<br>the value Po<br>INTM bit no<br>external int<br>acknowledg<br>setting INTM | value k<br>s progr<br>or at tha<br>s, the in<br>ed from<br>, see Ta<br>C + 1 (t<br>r the int<br>errupts<br>e is ger | C from 0 t<br>cam contr<br>t address<br>nstruction<br>your soft<br>able 6–2 c<br>the return<br>errupt m<br>looks e | o 31.<br>ol to<br>then<br>allo<br>ware<br>on pa<br>add<br>asks<br>xactl | The<br>the p<br>lead<br>ws and<br>For<br>ge 6-<br>ress)<br>affec<br>y like | INTF<br>progr<br>s to t<br>ny or<br>a list<br>-10. [<br>) is p<br>t the<br>e an | R inst<br>am-r<br>he co<br>ne of<br>of in<br>Ourin<br>Ushe<br>INTF<br>ext | ruction<br>orres<br>the i<br>terrup<br>g exe<br>d on<br>R ins<br>erna | on is<br>ory a<br>ponc<br>nterr<br>pts a<br>ecution<br>to th<br>truction<br>f inter | a so<br>ddre<br>ling ii<br>rupt s<br>nd th<br>on of<br>e sta<br>ion. <i>I</i><br>errup | ftwar<br>ss sp<br>nterru<br>ervic<br>eir cc<br>the in<br>the in<br>nck. N<br>An IN | re inte<br>pecifi<br>upt se<br>rou<br>prresp<br>nstru<br>Neithe<br>ITR fe<br>n inte | errupt<br>ed by<br>ervice<br>utines<br>bond-<br>ction,<br>er the<br>bor the<br>errupt |
| Words       | 1                                                                                                                                                                                         |                                                                                                                     |                                                                                                                    |                                                                         |                                                                            |                                                                                 |                                                                           |                                                                       |                                                                                     |                                                                                        |                                                                                    |                                                                                     |                                                                                       |
| Cycles      |                                                                                                                                                                                           |                                                                                                                     | Cycles                                                                                                             | for a                                                                   | Singl                                                                      | e INT                                                                           | 'R Ins                                                                    | struc                                                                 | tion                                                                                |                                                                                        |                                                                                    |                                                                                     |                                                                                       |
|             | ROM                                                                                                                                                                                       |                                                                                                                     | DARAM                                                                                                              |                                                                         |                                                                            | SAF                                                                             | RAM                                                                       |                                                                       |                                                                                     | Ext                                                                                    | ernal                                                                              |                                                                                     |                                                                                       |
|             | 4<br>† The process<br>PC discontin                                                                                                                                                        | uity is ta                                                                                                          |                                                                                                                    |                                                                         |                                                                            |                                                                                 |                                                                           |                                                                       |                                                                                     |                                                                                        | •                                                                                  | words                                                                               | . If the                                                                              |
| Example     | INTR                                                                                                                                                                                      | 3                                                                                                                   | ;                                                                                                                  | PC<br>The<br>mem                                                        | n cc                                                                       | ontr                                                                            | ol i                                                                      | s p                                                                   | asse                                                                                |                                                                                        |                                                                                    |                                                                                     |                                                                                       |

| Syntax   | LACC dma<br>LACC dma,<br>LACC ind [,<br>LACC ind,<br>LACC #lk [, | 16<br>shift [, AR <i>n</i> ]]<br>16[, AR <i>n</i> ]                   | Direct addressing<br>Direct with left shift of 16<br>Indirect addressing<br>Indirect with left shift of 16<br>Long immediate addressing |
|----------|------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Operands | dma:<br>shift:                                                   | 7 LSBs of the data-memory addr<br>Left shift value from 0 to 15 (defa |                                                                                                                                         |

| n:   | Value from 0 to 7 designating the next auxiliary register |  |  |  |  |  |  |  |  |  |  |
|------|-----------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| lk:  | 16-bit long immediate value                               |  |  |  |  |  |  |  |  |  |  |
| ind: | Select one of the following seven options:                |  |  |  |  |  |  |  |  |  |  |
|      | * *+ *– *0+ *0– *BR0+ *BR0–                               |  |  |  |  |  |  |  |  |  |  |

| Opcode |  |
|--------|--|
|--------|--|

## LACC dma [, shift]

| 15                     | 14                                           | 13                                                                           | 12                                                                                                                                                                   | 11                                       | 10                  | 9                | 8               | 7                 | 6           | 5                   | 4           | 3                        | 2               | 1                  | 0          |
|------------------------|----------------------------------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|---------------------|------------------|-----------------|-------------------|-------------|---------------------|-------------|--------------------------|-----------------|--------------------|------------|
| 0                      | 0                                            | 0                                                                            | 1                                                                                                                                                                    |                                          | sh                  | ift              |                 | 0                 |             |                     |             | dma                      |                 |                    |            |
|                        |                                              |                                                                              |                                                                                                                                                                      |                                          |                     |                  |                 |                   |             |                     |             |                          |                 |                    |            |
| LAC                    | CC d                                         | ma, 1                                                                        | 6                                                                                                                                                                    |                                          |                     |                  |                 |                   |             |                     |             |                          |                 |                    |            |
| 15                     | 14                                           | 13                                                                           | 12                                                                                                                                                                   | 11                                       | 10                  | 9                | 8               | 7                 | 6           | 5                   | 4           | 3                        | 2               | 1                  | 0          |
| 0                      | 1                                            | 1                                                                            | 0                                                                                                                                                                    | 1                                        | 0                   | 1                | 0               | 0                 |             |                     |             | dma                      |                 |                    |            |
| LAC                    | CC in                                        | nd[s                                                                         | shift[                                                                                                                                                               | AR                                       | <i>n</i> ]]         |                  |                 |                   |             |                     |             |                          |                 |                    |            |
| 15                     | 14                                           | 13                                                                           | 12                                                                                                                                                                   | 11                                       | 10                  | 9                | 8               | 7                 | 6           | 5                   | 4           | 3                        | 2               | 1                  | 0          |
| 0                      | 0                                            | 0                                                                            | 1                                                                                                                                                                    |                                          | sh                  | -                |                 | 1                 |             | ARU                 | •           | N                        | -               | NAR                |            |
| 0                      | 0                                            | 0                                                                            |                                                                                                                                                                      |                                          | 01                  |                  |                 |                   |             | / 110               |             |                          |                 | 147.11             |            |
|                        |                                              |                                                                              | <ul> <li>Note: ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).</li> <li>LACC <i>ind</i>, 16[, ARn]</li> </ul> |                                          |                     |                  |                 |                   |             |                     |             |                          |                 |                    |            |
|                        | (p                                           | age 7                                                                        | -12).                                                                                                                                                                |                                          | re defir            | ned in           | subse           | ction 7           | 7.3.4,      | Indirec             | et Add      | ressin                   | д Орс           | ode Fo             | ormat      |
|                        | (p                                           | age 7                                                                        | -12).                                                                                                                                                                |                                          | re defir<br>10      | ned in<br>9      | subse<br>8      | ction 7           | 7.3.4,<br>6 | Indired<br>5        | t Add.<br>4 | ressin <sub>t</sub><br>3 | g Opc<br>2      | ode Fo             | ormat<br>0 |
| LAC                    | (p<br>CC in                                  | age 7<br>nd, <b>16</b>                                                       | -12).<br>6[, <b>Af</b>                                                                                                                                               | <b>R</b> n]                              |                     |                  |                 |                   |             |                     |             |                          |                 |                    | 0          |
| LAC<br>15<br>0<br>Note | (p<br><b>CC</b> in<br>14<br>1<br>2: Al<br>(p | age 7<br>nd, <b>16</b><br><u>13</u><br>1<br>RU, N,<br>age 7                  | -12).<br>5[, <b>AF</b><br>12<br>0<br>, and N<br>-12).                                                                                                                | <b>R</b> <i>n</i> ]<br>11<br>1           | 10<br>0             | 9<br>1           | 8<br>0          | 7                 | 6           | 5                   | 4           | 3<br>N                   | 2               | 1<br>NAR           | 0          |
| LAC<br>15<br>0<br>Note | (p<br><b>CC</b> in<br>14<br>1<br>5: A        | age 7<br>nd, <b>16</b><br><u>13</u><br>1<br>RU, N,<br>age 7                  | -12).<br>5[, <b>AF</b><br>12<br>0<br>, and N<br>-12).                                                                                                                | <b>R</b> <i>n</i> ]<br>11<br>1           | 10<br>0             | 9<br>1           | 8<br>0          | 7                 | 6           | 5<br>ARU            | 4           | 3<br>N                   | 2               | 1<br>NAR           | 0          |
| LAC<br>15<br>0<br>Note | (p<br><b>CC</b> in<br>14<br>1<br>2: Al<br>(p | age 7<br>nd, <b>16</b><br><u>13</u><br>1<br>RU, N,<br>age 7                  | -12).<br>5[, <b>AF</b><br>12<br>0<br>, and N<br>-12).                                                                                                                | <b>R</b> <i>n</i> ]<br>11<br>1           | 10<br>0             | 9<br>1           | 8<br>0          | 7                 | 6           | 5<br>ARU            | 4           | 3<br>N                   | 2               | 1<br>NAR           | 0          |
| LAC<br>15<br>0<br>Note | (p<br>CC in<br>14<br>1<br>: Al<br>(p<br>CC # | age 7<br>nd, <b>16</b><br>13<br>1<br>RU, N<br>age 7<br><i>Ik</i> [, <i>s</i> | -12).<br>5[, <b>AF</b><br>12<br>0<br>, and N<br>-12).<br>5 <i>hiff</i> ]                                                                                             | <b>R</b> <i>n</i> ]<br>11<br>1<br>JAR ar | 10<br>0<br>re defir | 9<br>1<br>ned in | 8<br>0<br>subse | 7<br>1<br>ction 7 | 6           | 5<br>ARU<br>Indirec | 4<br>ct Add | 3<br>N<br>ressin         | 2<br>g Opc<br>2 | 1<br>NAR<br>ode Fo | 0<br>prmat |

### LACC Load Accumulator With Shift

PRELIMINARY

| Execution   | Increment PC, then<br><u>Event</u><br>(data-memory address) $\times 2^{\text{shift}} \rightarrow \text{ACC}$<br>(data-memory address) $\times 2^{16} \rightarrow \text{ACC}$ | <u>Addressing mode</u><br>Direct or indirect<br>Direct or indirect (shift of 16) |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
|             |                                                                                                                                                                              | Direct of indirect (Shift of To)                                                 |
|             | $lk \times 2^{shift} \rightarrow ACC$                                                                                                                                        | Long immediate                                                                   |
| Status Bits | <u>Affected by</u><br>SXM                                                                                                                                                    |                                                                                  |
| Description | The contents of the specified data-memory ad<br>left shifted and loaded into the accumulator. Du<br>zero filled. High-order bits are sign extended if S                      | ring shifting, low-order bits are                                                |
| Words       | <u>Words</u><br>1                                                                                                                                                            | <u>Addressing mode</u><br>Direct or indirect                                     |
|             | 2                                                                                                                                                                            | Long immediate                                                                   |

### Cycles

### Cycles for a Single LACC Instruction (Using Direct and Indirect Addressing)

|          |     | Program |       |          |  |  |  |  |  |
|----------|-----|---------|-------|----------|--|--|--|--|--|
| Operand  | ROM | DARAM   | SARAM | External |  |  |  |  |  |
| DARAM    | 1   | 1       | 1     | 1+p      |  |  |  |  |  |
| SARAM    | 1   | 1       | 1, 2† | 1+p      |  |  |  |  |  |
| External | 1+d | 1+d     | 1+d   | 2+d+p    |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

# Cycles for a Repeat (RPT) Execution of an LACC Instruction (Using Direct and Indirect Addressing)

|          | Program |       |         |          |  |  |  |
|----------|---------|-------|---------|----------|--|--|--|
| Operand  | ROM     | DARAM | SARAM   | External |  |  |  |
| DARAM    | n       | n     | n       | n+p      |  |  |  |
| SARAM    | n       | n     | n, n+1† | n+p      |  |  |  |
| External | n+nd    | n+nd  | n+nd    | n+1+p+nd |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

|           | Сус  | les for a Singl                   | e LACC Instruction            | n (Using Imme     | diate A        | ddressing)                     |
|-----------|------|-----------------------------------|-------------------------------|-------------------|----------------|--------------------------------|
|           | ROM  | DA                                | RAM S                         | ARAM              | Ex             | ternal                         |
|           | 2    | 2                                 | 2                             |                   | 2+             | 2р                             |
| Example 1 | LACC | 6,4                               | ;(DP = 8:<br>;SXM = 0)        | addresses         | 04003          | h-047Fh,                       |
|           |      |                                   | Before Instruction            |                   |                | After Instruction              |
|           | C    | Pata Memory<br>406h<br>ACC X<br>C | 01h                           |                   | ry<br>X [<br>C | 01h<br>10h                     |
| Example 2 | LACC | *,4                               | ;(SXM = 0                     | )                 |                |                                |
|           |      |                                   | Before Instruction            |                   |                | After Instruction              |
|           |      | ARP                               | 2                             | ARP               | [              | 2                              |
|           |      | AR2                               | 0300h                         | AR2               | [              | 0300h                          |
|           | C    | ata Memory<br>300h                | 0FFh                          | Data Memo<br>300h | ry<br>[        | 0FFh                           |
|           |      | ACC X                             | 12345678h                     |                   |                | 0FF0h                          |
|           |      | C                                 |                               | 1 100             | C              |                                |
| Example 3 | LACC | #0F0001                           | n,1 ;(SXM = 1                 | )                 |                |                                |
|           |      | ACC X                             | Before Instruction 012345678h | -                 | X  <br>c       | After Instruction<br>FFFFE000h |

| Syntax      | LACL dmaDirect addressingLACL ind [, ARn]Indirect addressingLACL #kShort immediate                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerk:8-bit short immediate valueind:Select one of the following seven options:**+*-*0+**BR0+**BR0+                                                                                                                                                                                   |  |  |  |  |  |  |  |
| Opcode      | LACL dma                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|             | 0 1 1 0 1 0 0 1 0 dma                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|             | LACL ind [, ARn]                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|             | 0 1 1 0 1 0 0 1 1 ARU N NAR                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
|             | <ul> <li>Note: ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).</li> <li>LACL #k</li> </ul>                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|             | 1 0 1 1 1 0 0 1 k                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
| Execution   | Increment PC, thenAddressing mode $\underline{Events}$ $\underline{Addressing mode}$ $0 \rightarrow ACC(31:16)$ Direct or indirect(data-memory address) $\rightarrow ACC(15:0)$                                                                                                                                                                                                   |  |  |  |  |  |  |  |
|             | $0 \rightarrow ACC(31:8)$ Short immediate<br>k $\rightarrow ACC(7:0)$                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
| Status Bits | This instruction is not affected by SXM.                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| Description | The contents of the addressed data-memory location or a zero-extended 8-bit constant are loaded into the 16 low-order bits of the accumulator. The upper half of the accumulator is zeroed. The data is treated as an unsigned 16-bit number rather than a 2s-complement number. There is no sign extension of the operand with this instruction, regardless of the state of SXM. |  |  |  |  |  |  |  |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
| 8-74        | PRELIMINARY                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |

### Cycles

#### Cycles for a Single LACL Instruction (Using Direct and Indirect Addressing)

|          |     | Program |       |          |  |  |  |
|----------|-----|---------|-------|----------|--|--|--|
| Operand  | ROM | DARAM   | SARAM | External |  |  |  |
| DARAM    | 1   | 1       | 1     | 1+p      |  |  |  |
| SARAM    | 1   | 1       | 1, 2† | 1+p      |  |  |  |
| External | 1+d | 1+d     | 1+d   | 2+d+p    |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

# Cycles for a Repeat (RPT) Execution of an LACL Instruction (Using Direct and Indirect Addressing)

|          | Program |       |         |          |  |  |  |  |
|----------|---------|-------|---------|----------|--|--|--|--|
| Operand  | ROM     | DARAM | SARAM   | External |  |  |  |  |
| DARAM    | n       | n     | n       | n+p      |  |  |  |  |
| SARAM    | n       | n     | n, n+1† | n+p      |  |  |  |  |
| External | n+nd    | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

#### Cycles for a Single LACL Instruction (Using Immediate Addressing)

| ROM | DARAM | SARAM | External |  |  |
|-----|-------|-------|----------|--|--|
| 1   | 1     | 1     | 1+p      |  |  |



### PRELIMINARY

Assembly Language Instructions 8-75

### LACL Load Low Accumulator and Clear High Accumulator



| Syntax      | LACT (<br>LACT /                                                                               |                                                                      | <b>R</b> <i>n</i> ]                                                              |                                                                |                                                                |                                                  |                                                                 |                                                                 |                                                         | Direc <sup>:</sup><br>ndire                                   |                                          |                                                        | -                                                          | I                                                  |                                 |
|-------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|--------------------------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------------|------------------------------------------|--------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------|---------------------------------|
| Operands    | dma:<br>n:<br>ind:                                                                             |                                                                      | 7 LSB<br>Value<br>Select<br>* *+                                                 | from<br>one                                                    | 0 to <sup>.</sup><br>of the                                    | 7 de                                             | signa<br>Iowin                                                  | ating 1                                                         | the n<br>ven o                                          | ext a ption                                                   |                                          | ary re                                                 | egiste                                                     | ər                                                 |                                 |
| Opcode      | LAC                                                                                            | T dma                                                                |                                                                                  |                                                                |                                                                |                                                  |                                                                 |                                                                 |                                                         |                                                               |                                          |                                                        |                                                            |                                                    |                                 |
| ·           | 15                                                                                             | 14 13                                                                | 3 12                                                                             | 11                                                             | 10                                                             | 9                                                | 8                                                               | 7                                                               | 6                                                       | 5                                                             | 4                                        | 3                                                      | 2                                                          | 1                                                  | 0                               |
|             | 0                                                                                              | 1 1                                                                  | 0                                                                                | 1                                                              | 0                                                              | 1                                                | 1                                                               | 0                                                               |                                                         |                                                               |                                          | dma                                                    |                                                            |                                                    |                                 |
|             | LAC.                                                                                           | T ind [,                                                             | <b>AR</b> n]                                                                     |                                                                |                                                                |                                                  |                                                                 |                                                                 |                                                         |                                                               |                                          |                                                        |                                                            |                                                    |                                 |
|             |                                                                                                | 14 13                                                                | -                                                                                | 11                                                             | 10                                                             | 9                                                | 8                                                               | 7                                                               | 6                                                       | 5                                                             | 4                                        | 3                                                      | 2                                                          | 1                                                  | 0                               |
|             | 0                                                                                              | 1 1                                                                  | 0                                                                                | 1                                                              | 0                                                              | 1                                                | 1                                                               | 1                                                               |                                                         | ARU                                                           |                                          | Ν                                                      |                                                            | NAR                                                |                                 |
| Execution   | Note:                                                                                          | (page                                                                | N, and I<br>7-12).                                                               |                                                                | re defii                                                       | ned ir                                           | subse                                                           | ection 7                                                        | 7.3.4,                                                  | Indirec                                                       | t Addı                                   | ressin                                                 | g Opc                                                      | code Fc                                            | rmat                            |
| Status Bits | (data-m<br>If SXM<br>Ther<br>If SXM<br>Ther                                                    | nemory<br>= 1:<br>n (data<br>= 0:<br>n (data                         | addre                                                                            | ess) ><br>ory a                                                | ddres                                                          | ss) is                                           | s sigr                                                          | ı exte                                                          | ndec                                                    |                                                               |                                          |                                                        |                                                            |                                                    |                                 |
| Status Bits | <u>Affecte</u><br>SXM                                                                          | <u>:a by</u>                                                         |                                                                                  |                                                                |                                                                |                                                  |                                                                 |                                                                 |                                                         |                                                               |                                          |                                                        |                                                            |                                                    |                                 |
| Description | The LA<br>has bee<br>resultin<br>a shift<br>high-or<br>LACT n<br>nent is<br>enced b<br>used or | en left<br>ng in sh<br>code<br>der bit<br>may be<br>placed<br>by the | shifted<br>ift option<br>provides are s<br>used <sup>1</sup><br>in the<br>data-n | l. The<br>ons fi<br>des a<br>lign e<br>to de<br>four l<br>nemo | e left s<br>rom C<br>a dyr<br>extend<br>norm<br>LSBs<br>ory ac | shift<br>) to 1<br>nami<br>ded<br>alize<br>of th | is sp<br>5 bits<br>ic sh<br>if SX<br>e a flo<br>ne TF<br>ss. Tl | ecifie<br>s. Usi<br>iift m<br>M = 1<br>pating<br>REG r<br>nis m | d by<br>ng th<br>echa<br>and<br>-poir<br>egist<br>ethoo | the fou<br>e fou<br>nism<br>zero<br>nt nun<br>er an<br>d of d | our L<br>r LSI<br>ed if<br>nber<br>d the | SBs<br>Bs of<br>uring<br>SXM<br>if the<br>mar<br>maliz | of th<br>the<br>shif<br>I = C<br>acture<br>acture<br>tissa | e TRI<br>TREG<br>iting,<br>).<br>ual ex<br>a is re | EG,<br>as<br>the<br>po-<br>fer- |
| Words       | 1                                                                                              |                                                                      |                                                                                  |                                                                |                                                                |                                                  |                                                                 |                                                                 |                                                         |                                                               |                                          |                                                        |                                                            |                                                    |                                 |
|             |                                                                                                |                                                                      |                                                                                  |                                                                |                                                                |                                                  | Δςς                                                             | amhlv                                                           | Lano                                                    | uane                                                          | Inctri                                   | uction                                                 | ne                                                         | 8                                                  | -77                             |

PRELIMINARY

Assembly Language Instructions 8-77

| Cycles |
|--------|
|--------|

### Cycles for a Single LACT Instruction

|          |     | Program |       |          |  |  |  |  |
|----------|-----|---------|-------|----------|--|--|--|--|
| Operand  | ROM | DARAM   | SARAM | External |  |  |  |  |
| DARAM    | 1   | 1       | 1     | 1+p      |  |  |  |  |
| SARAM    | 1   | 1       | 1, 2† | 1+p      |  |  |  |  |
| External | 1+d | 1+d     | 1+d   | 2+d+p    |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

|           | C              | ycles for a R    | epeat (RPT) Executi      | on of an LACI       | <b>FInstruction</b> |
|-----------|----------------|------------------|--------------------------|---------------------|---------------------|
|           |                |                  | Pr                       | ogram               |                     |
|           | Operand        | ROM              | DARAM                    | SARAM               | External            |
|           | DARAM          | n                | n                        | n                   | n+p                 |
|           | SARAM          | n                | n                        | n, n+1†             | n+p                 |
|           | External       | n+nd             | n+nd                     | n+nd                | n+1+p+nd            |
|           | † If the opera | and and the coo  | de are in the same SAR   | AM block            |                     |
| Example 1 | LACT           | 1                | ;(DP = 6: a<br>;SXM = 0) | ddresses (          | 0300h-037Fh,        |
|           |                |                  | Before Instruction       |                     | After Instruction   |
|           |                | Memory<br>301h   | 1376h                    | Data Memory<br>301h | 1376h               |
|           | ٦              | TREG             | 14h                      | TREG                | 14h                 |
|           |                | ACC X            | 98F7EC83h                | ACC                 | X 13760h            |
|           |                | С                |                          |                     | С                   |
|           |                |                  |                          |                     |                     |
| Example 2 | LACT           | *-,AR3           | ;(SXM = 1)               |                     |                     |
|           |                | ARP              | Before Instruction       | ARP                 | After Instruction   |
|           |                | ARP<br>AR1       | 1<br>310h                | ARP<br>AR1          | 30Fh                |
|           |                |                  | 31011                    |                     |                     |
|           |                | a Memory<br>310h | 0FF00h                   | Data Memory<br>310h | 0FF00h              |
|           | ٢              | TREG             | 11h                      | TREG                | 11h                 |
|           |                | ACC X            | 098F7EC83h               | ACC                 | X 0FFFFE00h<br>C    |

| Syntax      | LAR<br>LAR<br>LAR<br>LAR                  |          | Direct addressing<br>Indirect addressing<br>Short immediate addressing<br>Long immediate addressing |                               |                                         |               |        |        |          |        |                                 |         |        |       |        |       |
|-------------|-------------------------------------------|----------|-----------------------------------------------------------------------------------------------------|-------------------------------|-----------------------------------------|---------------|--------|--------|----------|--------|---------------------------------|---------|--------|-------|--------|-------|
| Operands    | x:<br>dma:<br>k:<br>Ik:<br>n:<br>ind:     |          | 7<br>8-<br>10<br>Va                                                                                 | LSB<br>bit s<br>6-bit<br>alue | s of t<br>hort i<br>long<br>from<br>one | ldres<br>he n | ext a  | uxilia | -        |        |                                 | ded     |        |       |        |       |
| Opcode      | LA                                        | r af     | <b>R</b> x, dr                                                                                      | na                            |                                         |               |        |        |          |        |                                 |         |        |       |        |       |
|             | 15                                        | 14       | 13                                                                                                  | 12                            | 11                                      | 10            | 9      | 8      | 7        | 6      | 5                               | 4       | 3      | 2     | 1      | 0     |
|             | 0                                         | 0        | 0                                                                                                   | 0                             | 0                                       |               | Х      |        | 0        |        |                                 |         | dma    |       |        |       |
|             | LAR ARx, ind [, ARn]                      |          |                                                                                                     |                               |                                         |               |        |        |          |        |                                 |         |        |       |        |       |
|             | 15                                        | 14       | ,<br>13                                                                                             | 12                            | 11                                      | 10            | 9      | 8      | 7        | 6      | 5                               | 4       | 3      | 2     | 1      | 0     |
|             | 0                                         | 0        | 0                                                                                                   | 0                             | 0                                       |               | Х      |        | 1        |        | ARU                             |         | Ν      |       | NAR    |       |
|             | Note                                      | ()       | bage 7                                                                                              | -12).                         | NARa                                    | re defir      | ned in | subse  | ection 7 | 7.3.4, | Indirec                         | t Addı  | ressin | g Opc | ode Fo | ormat |
|             |                                           |          | <b>R</b> x, #k                                                                                      |                               |                                         |               | -      |        |          |        |                                 |         |        |       |        |       |
|             | 15                                        | 14       | 13                                                                                                  | 12                            | 11                                      | 10            | 9      | 8      | 7        | 6      | 5                               | 4       | 3      | 2     | 1      | 0     |
|             | 1                                         | 0        | 1                                                                                                   | 1                             | 0                                       |               | Х      |        |          | k      |                                 |         |        |       |        |       |
|             | LA                                        | R AF     | <b>R</b> x, #/                                                                                      | k                             |                                         |               |        |        |          |        |                                 |         |        |       |        |       |
|             | 15                                        | 14       | 13                                                                                                  | 12                            | 11                                      | 10            | 9      | 8      | 7        | 6      | 5                               | 4       | 3      | 2     | 1      | 0     |
|             | 1                                         | 0        | 1                                                                                                   | 1                             | 1                                       | 1             | 1      | 1      | 0        | 0      | 0                               | 0       | 1      |       | х      |       |
|             |                                           |          |                                                                                                     |                               |                                         |               |        |        | k        |        |                                 |         |        |       |        |       |
|             |                                           |          |                                                                                                     |                               |                                         |               |        |        |          |        |                                 |         |        |       |        |       |
| Execution   | Increr<br><u>Eveni</u><br>(data-<br>k → A | t<br>men |                                                                                                     |                               |                                         | ightarrow AF  | łx     |        |          |        | <u>Addre</u><br>Direct<br>Short | t or ii | ndire  | ct    |        |       |
|             | $lk \to k$                                | ٩Rx      |                                                                                                     |                               |                                         |               |        |        |          |        | Long                            | imm     | ediat  | e     |        |       |
| Status Bits | None                                      |          |                                                                                                     |                               |                                         |               |        |        |          |        |                                 |         |        |       |        |       |

PRELIMINARY

Assembly Language Instructions 8-79

| Description | constant a                                                                                                                                                                                                                                                                                                                                                                                                           |                                                |                     |                   |                     |  |  |  |  |  |  |  |  |  |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|---------------------|-------------------|---------------------|--|--|--|--|--|--|--|--|--|--|
|             | The LAR and SAR (store auxiliary register) instructions can be used to<br>and store the auxiliary registers during subroutine calls and interrupts. I<br>auxiliary register is not being used for indirect addressing, LAR and SAR<br>able the register to be used as an additional storage register, especially<br>swapping values between data-memory locations without affecting the<br>tents of the accumulator. |                                                |                     |                   |                     |  |  |  |  |  |  |  |  |  |  |
| Words       | <u>Words</u><br>1                                                                                                                                                                                                                                                                                                                                                                                                    | -                                              |                     |                   |                     |  |  |  |  |  |  |  |  |  |  |
|             | 2                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                |                     | Long imr          | mediate             |  |  |  |  |  |  |  |  |  |  |
| Cycles      | Cycles fo                                                                                                                                                                                                                                                                                                                                                                                                            | r a Single LAR                                 | Instruction (Usi    | ng Direct and Inc | lirect Addressing)  |  |  |  |  |  |  |  |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                | Р                   | rogram            |                     |  |  |  |  |  |  |  |  |  |  |
|             | Operand                                                                                                                                                                                                                                                                                                                                                                                                              | ROM                                            | DARAM               | SARAM             | External            |  |  |  |  |  |  |  |  |  |  |
|             | DARAM                                                                                                                                                                                                                                                                                                                                                                                                                | 2                                              | 2                   | 2                 | 2+p <sub>code</sub> |  |  |  |  |  |  |  |  |  |  |
|             | SARAM                                                                                                                                                                                                                                                                                                                                                                                                                | ARAM 2 2 2, 3 <sup>†</sup> 2+p <sub>code</sub> |                     |                   |                     |  |  |  |  |  |  |  |  |  |  |
|             | External 2+d <sub>src</sub> 2+d <sub>src</sub> 2+d <sub>src</sub> 3+d <sub>src</sub> +p <sub>code</sub>                                                                                                                                                                                                                                                                                                              |                                                |                     |                   |                     |  |  |  |  |  |  |  |  |  |  |
|             | † If the opera                                                                                                                                                                                                                                                                                                                                                                                                       | and and the code a                             | are in the same SAF | RAM block         |                     |  |  |  |  |  |  |  |  |  |  |

# Cycles for a Repeat (RPT) Execution of an LAR Instruction (Using Direct and Indirect Addressing)

|          |                      |                      | Program              |                                          |
|----------|----------------------|----------------------|----------------------|------------------------------------------|
| Operand  | ROM                  | DARAM                | SARAM                | External                                 |
| DARAM    | 2n                   | 2n                   | 2n                   | 2n+p <sub>code</sub>                     |
| SARAM    | 2n                   | 2n                   | 2n, 2n+1†            | 2n+p <sub>code</sub>                     |
| External | 2n+nd <sub>src</sub> | 2n+nd <sub>src</sub> | 2n+nd <sub>src</sub> | 2n+1+nd <sub>src</sub> p <sub>code</sub> |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| ROM | DARAM | SARAM | External            |
|-----|-------|-------|---------------------|
| 2   | 2     | 2     | 2+p <sub>code</sub> |

|       | ROM                       | DARAM                  | SARAM            | External                                                                           |
|-------|---------------------------|------------------------|------------------|------------------------------------------------------------------------------------|
|       | 2                         | 2                      | 2                | 2+2p                                                                               |
| ple 1 | LAR                       | , , , ,                |                  | ses 0300h-037Fh)                                                                   |
|       | Data                      | Before In:<br>//emory  |                  | After Instruction                                                                  |
|       |                           | l0h                    |                  | 0h 18h                                                                             |
|       | A                         | R0                     | 6h Al            | R0 18h                                                                             |
|       | LAR                       | AR4,*-                 |                  |                                                                                    |
|       |                           | Before In:             | struction        | After Instruction                                                                  |
|       | A                         | RP                     | 4 AI             | RP 4                                                                               |
|       |                           | /lemory                |                  | lemory                                                                             |
|       |                           | 00h                    |                  | 10h <u>32h</u>                                                                     |
|       | A                         | R4                     | 300hAI           | R4 32h                                                                             |
|       | Note:                     |                        |                  |                                                                                    |
|       | LAR in the i specified by | the instruction is the | same as that poi | AR modifications if the AR<br>nted to by the ARP. There-<br>r the LAR instruction. |
| 3     | LAR                       | AR4,#01h               |                  |                                                                                    |
|       | LAR                       | Before In:             | struction        | After Instruction                                                                  |
|       | Δ                         | R4                     |                  | R4 01h                                                                             |
|       | ,,                        |                        | 0110011          |                                                                                    |
|       | LAR                       | AR6,#3FFFh             |                  |                                                                                    |
|       |                           |                        |                  | After Instruction                                                                  |

### LDP Load Data Page Pointer

| Syntax      | LDP dma<br>LDP ind [, ARn]<br>LDP #k                                                                                                                                                            |           |         |           |         |         |        |        |                  |      |        | Direct addressing<br>Indirect addressing<br>Short immediate<br>addressing |       |     |       |     |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|-----------|---------|---------|--------|--------|------------------|------|--------|---------------------------------------------------------------------------|-------|-----|-------|-----|--|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerk:9-bit short immediate valueind:Select one of the following seven options:**+*-*0+**BR0+**BR0+ |           |         |           |         |         |        |        |                  |      |        |                                                                           |       |     |       |     |  |
| Opcode      | LDP dma                                                                                                                                                                                         |           |         |           |         |         |        |        |                  |      |        |                                                                           |       |     |       |     |  |
|             | 15                                                                                                                                                                                              | 14        | 13      | 12        | 11      | 10      | 9      | 8      | 7                | 6    | 5      | 4                                                                         | 3     | 2   | 1     | 0   |  |
|             | 0 0 0 0 1 1 0 1 0 dma                                                                                                                                                                           |           |         |           |         |         |        |        |                  |      |        |                                                                           |       |     |       |     |  |
|             | LDP ind [, ARn]                                                                                                                                                                                 |           |         |           |         |         |        |        |                  |      |        |                                                                           |       |     |       |     |  |
|             | 15                                                                                                                                                                                              | 14        | 13      | 12        | 11      | 10      | 9      | 8      | 7                | 6    | 5      | 4                                                                         | 3     | 2   | 1     | 0   |  |
|             | 0                                                                                                                                                                                               | 0         | 0       | 0         | 1       | 1       | 0      | 1      | 1                |      | ARU    |                                                                           | Ν     |     | NAR   |     |  |
|             | <ul> <li>Note: ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).</li> <li>LDP #k</li> </ul>                                                |           |         |           |         |         |        |        |                  |      |        |                                                                           |       |     |       |     |  |
|             | 15                                                                                                                                                                                              | 14        | 13<br>1 | 12        | 11      | 10<br>1 | 9<br>0 | 8      | 7                | 6    | 5      | 4                                                                         | 3     | 2   | 1     | 0   |  |
| Execution   |                                                                                                                                                                                                 | 0         |         | 1<br>then | 1       | 1       | 0      |        |                  |      |        | k                                                                         |       |     |       |     |  |
| Execution   | Increr<br><u>Event</u>                                                                                                                                                                          |           | FU, 1   | llien     |         |         |        |        |                  |      | Addre  | essin                                                                     | g mo  | ode |       |     |  |
|             | Nine I                                                                                                                                                                                          | -         | of (c   | data-i    | mem     | ory a   | ddre   | ss) -  | $\rightarrow DP$ |      | Direct |                                                                           | -     |     |       |     |  |
|             | $k \rightarrow D$                                                                                                                                                                               | P         |         |           |         |         |        |        |                  |      | Short  | imm                                                                       | ediat | te  |       |     |  |
| Status Bits | <u>Affect</u><br>DP                                                                                                                                                                             | <u>'s</u> |         |           |         |         |        |        |                  |      |        |                                                                           |       |     |       |     |  |
| Description | The n<br>9-bit ii<br>ter ST                                                                                                                                                                     | mme       | diate   | valu      | e is lo | bade    | d into | the    | data p           | bage | point  | er (C                                                                     | P) of |     |       |     |  |
|             | In dire<br>(dma)<br>the ins                                                                                                                                                                     | are       | conca   | atena     | ated t  | o forr  | n the  | e 16-k | oit dat          | ta-m | emory  | / add                                                                     | dress | acc | essec | lby |  |
| Words       | 1                                                                                                                                                                                               |           |         |           |         |         |        |        |                  |      |        |                                                                           |       |     |       |     |  |
| 8-82        |                                                                                                                                                                                                 |           |         |           |         |         |        |        |                  |      |        |                                                                           | PRE   | LIN | 11NA  | RY  |  |

|          |                    | Program            |                    |                                       |  |  |  |  |  |  |  |  |  |  |
|----------|--------------------|--------------------|--------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|--|
| Operand  | ROM                | DARAM              | SARAM              | External                              |  |  |  |  |  |  |  |  |  |  |
| DARAM    | 2                  | 2                  | 2                  | 2+p <sub>code</sub>                   |  |  |  |  |  |  |  |  |  |  |
| SARAM    | 2                  | 2                  | 2, 3†              | 2+p <sub>code</sub>                   |  |  |  |  |  |  |  |  |  |  |
| External | 2+d <sub>src</sub> | 2+d <sub>src</sub> | 2+d <sub>src</sub> | 3+d <sub>src</sub> +p <sub>code</sub> |  |  |  |  |  |  |  |  |  |  |

Cycles for a Single LDP Instruction (Using Direct and Indirect Addressing)

Cycles

 $^{\dagger}$  If the operand and the code are in the same SARAM block

#### Cycles for a Repeat (RPT) Execution of an LDP Instruction (Using Direct and Indirect Addressing)

|          |                      |                      | Program              |                                          |
|----------|----------------------|----------------------|----------------------|------------------------------------------|
| Operand  | ROM                  | DARAM                | SARAM                | External                                 |
| DARAM    | 2n                   | 2n                   | 2n                   | 2n+p <sub>code</sub>                     |
| SARAM    | 2n                   | 2n                   | 2n, 2n+1†            | 2n+p <sub>code</sub>                     |
| External | 2n+nd <sub>src</sub> | 2n+nd <sub>src</sub> | 2n+nd <sub>src</sub> | 2n+1+nd <sub>src</sub> p <sub>code</sub> |

<sup>†</sup> If the operand and the code are in the same SARAM block

|           | Cycle | es for a Single      | LDP Instructio | on (Usin | ig Short Immed       | diate Addressing)   |
|-----------|-------|----------------------|----------------|----------|----------------------|---------------------|
|           | ROM   | DA                   | ARAM           | SA       | RAM                  | External            |
|           | 2     | 2                    |                | 2        |                      | 2+p <sub>code</sub> |
| Example 1 | LDP   | 127                  | ;(DP =         | 511:     | addresses            | FF80h-FFFFh)        |
|           |       |                      | Before Instru  | ction    |                      | After Instruction   |
|           | I     | Data Memory<br>FFFFh | FI             | EDCh     | Data Memory<br>FFFFh | FEDCh               |
|           |       | DP                   |                | 1FFh     | DP                   | 0DCh                |
| Example 2 | LDP   | #0h                  |                |          |                      |                     |
|           |       |                      | Before Instru  | ction    |                      | After Instruction   |
|           |       | DP                   |                | 1FFh     | DP                   | 0h                  |
| Example 3 | LDP   | *,AR5                |                |          |                      |                     |
|           |       |                      | Before Instru  | ction    |                      | After Instruction   |
|           |       | ARP                  |                | 4        | ARP                  | 5                   |
|           |       | AR4                  |                | 300h     | AR4                  | 300h                |
|           | I     | Data Memory<br>300h  |                | 06h      | Data Memory<br>300h  | 06h                 |
|           |       |                      |                |          |                      |                     |
|           |       | DP                   |                | 1FFh     | DP                   | 06h                 |

## PRELIMINARY

Assembly Language Instructions

8-83

| Syntax      | LPH dma<br>LPH ind [, ARn]                                                                                                                                        |      |    |                 |               |      |                  |        |       |       |        | Direct addressing<br>Indirect addressing |        |         |       |        |      |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----|-----------------|---------------|------|------------------|--------|-------|-------|--------|------------------------------------------|--------|---------|-------|--------|------|--|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+**0+**BR0+**BR0+ |      |    |                 |               |      |                  |        |       |       |        |                                          |        | ٢       |       |        |      |  |
| Opcode      | LPH dma                                                                                                                                                           |      |    |                 |               |      |                  |        |       |       |        |                                          |        |         |       |        |      |  |
|             | -                                                                                                                                                                 | 15   | 14 | 13              | 12            | 11   | 10               | 9      | 8     | 7     | 6      | 5                                        | 4      | 3       | 2     | 1      | 0    |  |
|             | 0 1 1 1 0 1 0 1 0 dma                                                                                                                                             |      |    |                 |               |      |                  |        |       |       |        |                                          |        |         |       |        |      |  |
|             | LPH ind [, ARn]                                                                                                                                                   |      |    |                 |               |      |                  |        |       |       |        |                                          |        |         |       |        |      |  |
|             | -                                                                                                                                                                 | 15   | 14 | 13              | 12            | 11   | 10               | 9      | 8     | 7     | 6      | 5                                        | 4      | 3       | 2     | 1      | 0    |  |
|             | L                                                                                                                                                                 | 0    | 1  | 1               | 1             | 0    | 1                | 0      | 1     | 1     |        | ARU                                      |        | Ν       |       | NAR    |      |  |
|             |                                                                                                                                                                   | Note |    | RU, N<br>bage 7 |               | NARa | re defir         | ned in | subse | ction | 7.3.4, | Indirec                                  | t Addi | ressin  | д Орс | ode Fo | rmat |  |
| Execution   |                                                                                                                                                                   |      |    |                 | then<br>addre |      | $\rightarrow PF$ | EG     | (31:1 | 6)    |        |                                          |        |         |       |        |      |  |
| Status Bits | No                                                                                                                                                                | one  |    |                 |               |      |                  |        |       |       |        |                                          |        |         |       |        |      |  |
| Description |                                                                                                                                                                   |      | •  |                 |               |      |                  |        |       |       |        | h the<br>are u                           |        |         |       | specit | ied  |  |
|             |                                                                                                                                                                   |      |    |                 |               |      | oe us<br>outine  |        |       | torin | g the  | high-                                    | orde   | er bits | of th | e PR   | EG   |  |
| Words       | 1                                                                                                                                                                 |      |    |                 |               |      |                  |        |       |       |        |                                          |        |         |       |        |      |  |

Cycles

|          | Cycles for a Single LPH Instruction |       |         |          |  |  |  |  |  |  |  |  |
|----------|-------------------------------------|-------|---------|----------|--|--|--|--|--|--|--|--|
|          |                                     | F     | Program |          |  |  |  |  |  |  |  |  |
| Operand  | ROM                                 | DARAM | SARAM   | External |  |  |  |  |  |  |  |  |
| DARAM    | 1                                   | 1     | 1       | 1+p      |  |  |  |  |  |  |  |  |
| SARAM    | 1                                   | 1     | 1, 2†   | 1+p      |  |  |  |  |  |  |  |  |
| External | 1+d                                 | 1+d   | 1+d     | 2+d+p    |  |  |  |  |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| C        | ycles for a Repe | eat (RPT) Execu | tion of an LPH I | nstruction |
|----------|------------------|-----------------|------------------|------------|
|          |                  | Pi              | rogram           |            |
| Operand  | ROM              | DARAM           | SARAM            | External   |
| DARAM    | n                | n               | n                | n+p        |
| SARAM    | n                | n               | n, n+1†          | n+p        |
| External | n+nd             | n+nd            | n+nd             | n+1+p+nd   |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Example 1 | LPH | DATO                        | ; (DP = 4)                |                             |                   |
|-----------|-----|-----------------------------|---------------------------|-----------------------------|-------------------|
|           |     |                             | <b>Before Instruction</b> |                             | After Instruction |
|           |     | Data Memory<br>200h<br>PREG | 0F79Ch<br>30079844h       | Data Memory<br>200h<br>PREG | 0F79Ch            |
| Example 2 | LPH | *,AR6                       |                           |                             |                   |
|           |     |                             | <b>Before Instruction</b> |                             | After Instruction |
|           |     | ARP                         | 5                         | ARP                         | 6                 |
|           |     | AR5                         | 200h                      | AR5                         | 200h              |
|           |     | Data Memory<br>200h         | 0F79Ch                    | Data Memory<br>200h         | 0F79Ch            |
|           |     | PREG                        | 30079844h                 | PREG                        | 0F79C9844h        |

| Syntax    | LST #m, dma<br>LST #m, ind [, ARn] |                   |               |                           |                                      |                                   |                                                |                                           |                        |                                   | Direct addressing<br>Indirect addressing |         |        |        |       |  |  |
|-----------|------------------------------------|-------------------|---------------|---------------------------|--------------------------------------|-----------------------------------|------------------------------------------------|-------------------------------------------|------------------------|-----------------------------------|------------------------------------------|---------|--------|--------|-------|--|--|
| Operands  | dma:<br>n:<br>m:<br>ind:           | V<br>S<br>0<br>1  | alue<br>elect | from<br>one<br>Ind<br>Ind | of the<br>licate<br>licate<br>of the | 7 des<br>e foll<br>s tha<br>s tha | signa<br>owing<br>It ST(<br>It ST <sup>-</sup> | ting t<br>g:<br>) will<br>1 will<br>g sev | he n<br>be lo<br>be lo | ext a<br>badec<br>badec<br>ption: | k<br>k                                   | ary re  | giste  | r      |       |  |  |
| Opcode    |                                    | <b>0</b> , dma    |               |                           |                                      |                                   |                                                |                                           |                        |                                   |                                          |         |        |        |       |  |  |
|           | -                                  | 4 13              | 12            | 11                        | 10                                   | 9                                 | 8                                              | 7                                         | 6                      | 5                                 | 4                                        | 3       | 2      | 1      | 0     |  |  |
|           | 0 (                                | ) ()              | 0             | 1                         | 1                                    | 1                                 | 0                                              | 0                                         |                        |                                   |                                          | dma     |        |        |       |  |  |
|           | LST #                              | <b>0</b> , ind    | , <b>AR</b>   | n]                        |                                      |                                   |                                                |                                           |                        |                                   |                                          |         |        |        |       |  |  |
|           |                                    | 4 13              | 12            | -11                       | 10                                   | 9                                 | 8                                              | 7                                         | 6                      | 5                                 | 4                                        | 3       | 2      | 1      | 0     |  |  |
|           | 0 (                                | ) ()              | 0             | 1                         | 1                                    | 1                                 | 0                                              | 1                                         |                        | ARU                               |                                          | Ν       |        | NAR    |       |  |  |
|           | Note:                              | ARU, N<br>(page 7 |               | NARa                      | re defii                             | ned in                            | subse                                          | ction 7                                   | ′.3.4, i               | Indirec                           | t Addi                                   | ressinį | д Орса | ode Fo | ormat |  |  |
|           | LST #                              | <b>1</b> , dma    | ı             |                           |                                      |                                   |                                                |                                           |                        |                                   |                                          |         |        |        |       |  |  |
|           | 15 1                               | 4 13              | 12            | 11                        | 10                                   | 9                                 | 8                                              | 7                                         | 6                      | 5                                 | 4                                        | 3       | 2      | 1      | 0     |  |  |
|           | 0 0                                | ) ()              | 0             | 1                         | 1                                    | 1                                 | 1                                              | 0                                         |                        |                                   |                                          | dma     |        |        |       |  |  |
|           | LST #                              | <b>1</b> , ind    | , <b>AR</b>   | n]                        |                                      |                                   |                                                |                                           |                        |                                   |                                          |         |        |        |       |  |  |
|           | 15 1                               | 4 13              | 12            | 11                        | 10                                   | 9                                 | 8                                              | 7                                         | 6                      | 5                                 | 4                                        | 3       | 2      | 1      | 0     |  |  |
|           | 0 (                                | ) ()              | 0             | 1                         | 1                                    | 1                                 | 1                                              | 1                                         |                        | ARU                               |                                          | Ν       |        | NAR    |       |  |  |
| Execution | Note:                              | ARU, N<br>(page 7 | '-12).        | NARa                      | re defii                             | ned in                            | subse                                          | ction 7                                   | 7.3.4, i               | Indirec                           | t Addı                                   | ressinį | g Opco | ode Fo | ormat |  |  |

Execution

Increment PC, then ...

 $(\text{data-memory address}) \rightarrow \text{status register STm}$ 

For details about the differences between an LST #0 operation and an LST #1 operation, see Figure 8–3, Figure 8–4, and the description paragraph.

| 0    |    |     |    | '   |     |    |      |   |   |   |   |     |   |              |   |              |
|------|----|-----|----|-----|-----|----|------|---|---|---|---|-----|---|--------------|---|--------------|
|      | 15 | 14  | 13 | 12  | 11  | 10 | 9    | 8 | 7 | 6 | 5 | 4   | 3 | 2            | 1 | 0            |
| Data |    |     |    |     |     |    |      |   |   |   |   |     |   |              |   |              |
|      | +  | ★   | ★  | . ↓ | ★   |    |      | ¥ | ▼ | ★ | ★ | . ↓ | ★ | $\checkmark$ | • | $\checkmark$ |
|      | 15 | 14  | 13 | 12  | 11  | 10 | 9    | 8 | 7 | 6 | 5 | 4   | 3 | 2            | 1 | 0            |
| ST0  |    | ARP |    | OV  | OVM | 1  | INTM |   |   |   |   | D   | Р |              |   |              |

# Figure 8–3. LST #0 Operation

|        | 15     | 14        | 13       | 12        | 11                                                                                                                        | 10        | 9                                 | 8     | 7      | 6      | 5       | 4       | 3       | 2       | 1        | 0        |
|--------|--------|-----------|----------|-----------|---------------------------------------------------------------------------------------------------------------------------|-----------|-----------------------------------|-------|--------|--------|---------|---------|---------|---------|----------|----------|
| ST0    |        | ARP       |          | OV        | OVM                                                                                                                       | 1         | INTM                              |       |        |        |         |         | DP      |         |          |          |
|        | •      | <b></b>   | •        |           |                                                                                                                           |           |                                   |       |        |        |         |         |         |         |          |          |
|        | 15     | 14        | 13       | 12        | 11                                                                                                                        | 10        | 9                                 | 8     | 7      | 6      | 5       | 4       | 3       | 2       | 1        | 0        |
| Data   |        |           |          |           |                                                                                                                           |           |                                   |       |        |        |         |         |         |         |          |          |
|        | •      | •         | <b>V</b> | •         | <b>\</b>                                                                                                                  | <b>V</b>  | •                                 |       | _      |        | _       | •       | •       |         | •        | <b>\</b> |
| ST1    | 15     | 14<br>ARB | 13       | 12<br>CNF | 11<br>TC                                                                                                                  | 10<br>SXM | 9<br>C                            | 8     | 7      | 6<br>1 | 5       | 4<br>XF | 3       | 2       | 1        | 0<br>M   |
| 311    |        | And       |          | CINI      | 10                                                                                                                        | SAIVI     | 0                                 | 1     | 1      | I      | 1       | ΛI      | 1       | 1       | F        | IVI      |
| Status | s Bit  | 5         |          | AR        | <u>Affects</u><br>ARB, ARP, OV, OVM, DP, CNF, TC, SXM, C, XF, and PM<br>This instruction does not affect INTM.            |           |                                   |       |        |        |         |         |         |         |          |          |
|        |        |           |          |           |                                                                                                                           |           |                                   |       |        |        |         |         |         |         |          |          |
| Descr  | riptio | n         |          |           | The specified status register (ST0 or ST1) is loaded with the addressed data-<br>memory value. Note the following points: |           |                                   |       |        |        |         |         |         |         | ed data- |          |
|        |        |           |          |           |                                                                                                                           |           | operation<br>a new /              |       |        |        | ect the | e ARB   | field   | in the  | ST1 r    | egister, |
|        |        |           |          |           | During<br>ARP.                                                                                                            | g the LS  | ST #1 op                          | erati | on, th | e valı | ue loa  | ded in  | ito AR  | Bisal   | so load  | ded into |
|        |        |           |          |           | mode                                                                                                                      | , this o  | value is<br>perand i<br>ned in th | s ign | ored.  | ARP    | is loa  | aded w  | ith the | e three |          | -        |
|        |        |           |          |           |                                                                                                                           |           | t values<br>have no               |       |        | us reę | gister  | s are a | always  | s read  | as 1s    | . Writes |
|        |        |           |          |           |                                                                                                                           |           | ion can b<br>errupts.             | be us | ed for | resto  | oring t | he sta  | tus reę | gisters | after    | subrou-  |
| Word   | s      |           |          | 1         |                                                                                                                           |           |                                   |       |        |        |         |         |         |         |          |          |

Figure 8–4. LST #1 Operation

### LST Load Status Register

| Cycles for a Single LST Instruction |                    |                    |                    |                                       |  |  |  |  |  |  |
|-------------------------------------|--------------------|--------------------|--------------------|---------------------------------------|--|--|--|--|--|--|
|                                     |                    | F                  | Program            |                                       |  |  |  |  |  |  |
| Operand                             | ROM                | DARAM              | SARAM              | External                              |  |  |  |  |  |  |
| DARAM                               | 2                  | 2                  | 2                  | 2+p <sub>code</sub>                   |  |  |  |  |  |  |
| SARAM                               | 2                  | 2                  | 2, 3†              | 2+p <sub>code</sub>                   |  |  |  |  |  |  |
| External                            | 2+d <sub>src</sub> | 2+d <sub>src</sub> | 2+d <sub>src</sub> | 3+d <sub>src</sub> +p <sub>code</sub> |  |  |  |  |  |  |

### Cycles

### <sup>†</sup> If the operand and the code are in the same SARAM block

|          |                      |                      | Program              |                                           |
|----------|----------------------|----------------------|----------------------|-------------------------------------------|
| Operand  | ROM                  | DARAM                | SARAM                | External                                  |
| DARAM    | 2n                   | 2n                   | 2n                   | 2n+p <sub>code</sub>                      |
| SARAM    | 2n                   | 2n                   | 2n, 2n+1†            | 2n+p <sub>code</sub>                      |
| External | 2n+nd <sub>src</sub> | 2n+nd <sub>src</sub> | 2n+nd <sub>src</sub> | 2n+1+nd <sub>src</sub> +p <sub>code</sub> |

<sup>†</sup> If the operand and the code are in the same SARAM block

Example 1 MAR \*, AR0 #0,\*,AR1 LST ; The data memory word addressed by the ; contents of auxiliary register AR0 is ;loaded into status register STO, except ; for the INTM bit. Note that even ;though a next ARP value is specified, ;that value is ignored. Also note that ;the old ARP is not loaded into the ;ARB. Example 2 #0,60h; (DP = 0) LST

|                    | Before Instruction |                    | After Instruction |
|--------------------|--------------------|--------------------|-------------------|
| Data Memory<br>60h | 2404h              | Data Memory<br>60h | 2404h             |
| ST0                | 6E00h              | ST0                | 2604h             |
| ST1                | 05ECh              | ST1                | 05ECh             |

| Example 3 | LST | #0,*-,A     | R1                        |             |                   |
|-----------|-----|-------------|---------------------------|-------------|-------------------|
|           |     |             | <b>Before Instruction</b> |             | After Instruction |
|           |     | ARP         | 4                         | ARP         | 7                 |
|           |     | AR4         | 3FFh                      | AR4         | 3FEh              |
|           |     | Data Memory |                           | Data Memory |                   |
|           |     | 3FFh        | EE04h                     | 3FFh        | EE04h             |
|           |     | ST0         | EE00h                     | ST0         | EE04h             |
|           |     | ST1         | F7ECh                     | ST1         | F7ECh             |
| Example 4 | LST | #1,00h      | ;(DP = 6)                 |             |                   |
|           |     |             | ;Note that                | the ARB is  | loaded with       |
|           |     |             | ;the new Al               | RP value.   |                   |
|           |     |             | <b>Before Instruction</b> |             | After Instruction |
|           |     | Data Memory |                           | Data Memory |                   |
|           |     | 300h        | E1BCh                     | 300h        | E1BCh             |
|           |     | ST0         | 0406h                     | ST0         | E406h             |
|           |     | ST1         | 09ECh                     | ST1         | E1FCh             |

| Syntax      | LT dma<br>LT ind [, ARn]                                                                                                                                                                                                       |         |                  |                 |        |                                   |                 |       | Direct addressing<br>Indirect addressing |                |             |        |         |        |        |       |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------|-----------------|--------|-----------------------------------|-----------------|-------|------------------------------------------|----------------|-------------|--------|---------|--------|--------|-------|--|
| Operands    | dma:<br>n:<br>ind:                                                                                                                                                                                                             |         | Va               | alue f<br>elect | rom    | he da<br>0 to 7<br>of the<br>- *0 | 7 des<br>e foll | signa | ting t<br>g sev                          | the n<br>ven o | ext a ption |        | ıry re  | giste  | ٢      |       |  |
| Opcode      | LT d                                                                                                                                                                                                                           | lma     |                  |                 |        |                                   |                 |       |                                          |                |             |        |         |        |        |       |  |
|             | 15                                                                                                                                                                                                                             | 14      | 13               | 12              | 11     | 10                                | 9               | 8     | 7                                        | 6              | 5           | 4      | 3       | 2      | 1      | 0     |  |
|             | 0                                                                                                                                                                                                                              | 1       | 1                | 1               | 0      | 0                                 | 1               | 1     | 0                                        |                |             |        | dma     |        |        |       |  |
|             | LT in                                                                                                                                                                                                                          | nd [, . | ARn              | ]               |        |                                   |                 |       |                                          |                |             |        |         |        |        |       |  |
|             | 15                                                                                                                                                                                                                             | 14      | 13               | 12              | 11     | 10                                | 9               | 8     | 7                                        | 6              | 5           | 4      | 3       | 2      | 1      | 0     |  |
|             | 0                                                                                                                                                                                                                              | 1       | 1                | 1               | 0      | 0                                 | 1               | 1     | 1                                        |                | ARU         |        | Ν       |        | NAR    |       |  |
|             | Note:                                                                                                                                                                                                                          |         | RU, N,<br>age 7: |                 | IAR ai | re defir                          | ned in          | subse | ction 7                                  | 7.3.4, 1       | Indirec     | t Addı | ressing | д Орса | ode Fo | ormat |  |
| Execution   | Increm<br>(data-n                                                                                                                                                                                                              |         |                  |                 |        | $\rightarrow TR$                  | EG              |       |                                          |                |             |        |         |        |        |       |  |
| Status Bits | None                                                                                                                                                                                                                           |         |                  |                 |        |                                   |                 |       |                                          |                |             |        |         |        |        |       |  |
| Description | TREG is loaded with the contents of the specified data-memory address. The LT instruction may be used to load TREG in preparation for multiplication. See also the LTA, LTD, LTP, LTS, MPY, MPYA, MPYS, and MPYU instructions. |         |                  |                 |        |                                   |                 |       |                                          |                |             |        |         |        |        |       |  |
| Words       | 1                                                                                                                                                                                                                              |         |                  |                 |        |                                   |                 |       |                                          |                |             |        |         |        |        |       |  |

Cycles

| _        | Cycles for a Single LT Instruction |       |         |          |  |  |  |  |  |  |  |
|----------|------------------------------------|-------|---------|----------|--|--|--|--|--|--|--|
|          |                                    | F     | Program |          |  |  |  |  |  |  |  |
| Operand  | ROM                                | DARAM | SARAM   | External |  |  |  |  |  |  |  |
| DARAM    | 1                                  | 1     | 1       | 1+p      |  |  |  |  |  |  |  |
| SARAM    | 1                                  | 1     | 1, 2†   | 1+p      |  |  |  |  |  |  |  |
| External | 1+d                                | 1+d   | 1+d     | 2+d+p    |  |  |  |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

|          | Cycles for a Repeat (RPT) Execution of an LT Instruction |       |         |          |  |  |  |  |
|----------|----------------------------------------------------------|-------|---------|----------|--|--|--|--|
|          | Program                                                  |       |         |          |  |  |  |  |
| Operand  | ROM                                                      | DARAM | SARAM   | External |  |  |  |  |
| DARAM    | n                                                        | n     | n       | n+p      |  |  |  |  |
| SARAM    | n                                                        | n     | n, n+1† | n+p      |  |  |  |  |
| External | n+nd                                                     | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Example 1 | LT | 24                  | ;(DP = 8: a)       | ddresses 0400       | h-047Fh)          |
|-----------|----|---------------------|--------------------|---------------------|-------------------|
|           |    |                     | Before Instruction |                     | After Instruction |
|           |    | Data Memory<br>418h | 62h                | Data Memory<br>418h | 62h               |
|           |    | TREG                | 3h                 | TREG                | 62h               |
| Example 2 | LT | *,AR3               |                    |                     |                   |
|           |    |                     | Before Instruction |                     | After Instruction |
|           |    | ARP                 | 2                  | ARP                 | 3                 |
|           |    | AR2                 | 418h               | AR2                 | 418h              |
|           |    | Data Memory<br>418h | 62h                | Data Memory<br>418h | 62h               |
|           |    | TREG                | 3h                 | TREG                | 62h               |

Assembly Language Instructions

| Syntax      | LTA d<br>LTA i                                                                                                                                                                                                             |        | <b>AR</b> n]  |                                                                                                                                                                             |        |                      |        |        |       |       | Direct<br>Indire |       |        | -     |        |     |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------|--------|--------|-------|-------|------------------|-------|--------|-------|--------|-----|
| Operands    | dma:<br>n:<br>ind:                                                                                                                                                                                                         |        |               | 7 LSBs of the data-memory address<br>Value from 0 to 7 designating the next auxiliary register<br>Select one of the following seven options:<br>* *+ *- *0+ *0- *BR0+ *BR0- |        |                      |        |        |       |       |                  |       |        |       |        |     |
| Opcode      | LTA                                                                                                                                                                                                                        | A dm   | a             |                                                                                                                                                                             |        |                      |        |        |       |       |                  |       |        |       |        |     |
|             | 15                                                                                                                                                                                                                         | 14     | 13            | 12                                                                                                                                                                          | 11     | 10                   | 9      | 8      | 7     | 6     | 5                | 4     | 3      | 2     | 1      | 0   |
|             | 0                                                                                                                                                                                                                          | 1      | 1             | 1                                                                                                                                                                           | 0      | 0                    | 0      | 0      | 0     |       |                  |       | dma    |       |        |     |
|             | LTA                                                                                                                                                                                                                        | l ind  | [, <b>A</b> F | <b>R</b> n]                                                                                                                                                                 |        |                      |        |        |       |       |                  |       |        |       |        |     |
|             | 15                                                                                                                                                                                                                         | 14     | 13            | 12                                                                                                                                                                          | 11     | 10                   | 9      | 8      | 7     | 6     | 5                | 4     | 3      | 2     | 1      | 0   |
|             | 0                                                                                                                                                                                                                          | 1      | 1             | 1                                                                                                                                                                           | 0      | 0                    | 0      | 0      | 1     |       | ARU              |       | Ν      |       | NAR    |     |
| Execution   | Note: ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).<br>Increment PC, then<br>(data-memory address) $\rightarrow$ TREG<br>(ACC) + shifted (PREG) $\rightarrow$ ACC |        |               |                                                                                                                                                                             |        |                      |        |        |       |       |                  |       |        |       |        |     |
| Status Bits | <u>Affec</u><br>PM a                                                                                                                                                                                                       |        |               |                                                                                                                                                                             |        | <u>ects</u><br>and O | V      |        |       |       |                  |       |        |       |        |     |
| Description | TREC<br>conte<br>adde                                                                                                                                                                                                      | nts o  | f the         | prod                                                                                                                                                                        | uct re | egiste               | er, sh | ifted  | as d  | efine | d by             | the F | PM st  | atus  | bits,  |     |
|             | The c<br>is cle                                                                                                                                                                                                            |        |               |                                                                                                                                                                             |        | '                    |        |        |       |       | dition           | gene  | erates | sac   | arry a | and |
|             | The f                                                                                                                                                                                                                      | unctio | on of         | the l                                                                                                                                                                       | _TA i  | nstruc               | ction  | is a : | subta | ısk o | f the            | LTD   | instru | uctio | n.     |     |
| Words       | 1                                                                                                                                                                                                                          |        |               |                                                                                                                                                                             |        |                      |        |        |       |       |                  |       |        |       |        |     |

Cycles

| Cycles for a Single LTA Instruction |         |       |       |          |  |  |  |
|-------------------------------------|---------|-------|-------|----------|--|--|--|
|                                     | Program |       |       |          |  |  |  |
| Operand                             | ROM     | DARAM | SARAM | External |  |  |  |
| DARAM                               | 1       | 1     | 1     | 1+p      |  |  |  |
| SARAM                               | 1       | 1     | 1, 2† | 1+p      |  |  |  |
| External                            | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

| C        | Cycles for a Repeat (RPT) Execution of an LTA Instruction |       |         |          |  |  |  |  |  |
|----------|-----------------------------------------------------------|-------|---------|----------|--|--|--|--|--|
|          | Program                                                   |       |         |          |  |  |  |  |  |
| Operand  | ROM                                                       | DARAM | SARAM   | External |  |  |  |  |  |
| DARAM    | n                                                         | n     | n       | n+p      |  |  |  |  |  |
| SARAM    | n                                                         | n     | n, n+1† | n+p      |  |  |  |  |  |
| External | n+nd                                                      | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block



| Syntax      | LTD dmaDirect addressingLTD ind [, ARn]Indirect addressing                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Operands    | dma:7 LSBs of the data-memory addressn:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+**0+**BR0+                                                                                                                                  |  |  |  |  |  |  |  |  |
| Opcode      | <b>LTD</b> dma<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|             | 0 1 1 1 0 0 1 0 0 dma                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
|             | LTD ind [, ARn]                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0<br>0 1 1 1 0 0 1 0 1 ARU N NAR                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
|             | <b>Note:</b> ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
| Execution   | Increment PC, then<br>(data-memory address) $\rightarrow$ TREG<br>(data-memory address) $\rightarrow$ data-memory address + 1<br>(ACC) + shifted (PREG) $\rightarrow$ ACC                                                                                                                                                       |  |  |  |  |  |  |  |  |
| Status Bits | Affected by Affects PM and OVM C and OV                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
| Description | TREG is loaded with the contents of the specified data-memory address. The contents of the PREG, shifted as defined by the PM status bits, are added to the accumulator, and the result is placed in the accumulator. The contents of the specified data-memory address are also copied to the next higher data-memory address. |  |  |  |  |  |  |  |  |
|             | This instruction is valid for all blocks of on-chip RAM configured as data memory. The data move function is continuous across the boundaries of contiguous blocks of memory but cannot be used with external data memory or memory-mapped registers. The data move function is described under the instruction DMOV.           |  |  |  |  |  |  |  |  |
|             | Note:                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
|             | If LTD is used with external data memory, its function is identical to that of LTA; that is, the previous product is accumulated, and the TREG is loaded from external data memory, but <i>the data move does not occur</i> .                                                                                                   |  |  |  |  |  |  |  |  |
|             | The carry bit is set (C = 1) if the result of the addition generates a carry and is cleared (C = 0) if it does not generate a carry.                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
| 8-9/        |                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |

1

LTD

#### Words

Cycles

| Cycles for a Single LTD Instruction |                      |                                                               |                                                                                                                                  |  |  |  |  |  |  |  |  |
|-------------------------------------|----------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Program                             |                      |                                                               |                                                                                                                                  |  |  |  |  |  |  |  |  |
| ROM                                 | DARAM                | SARAM                                                         | External <sup>‡</sup>                                                                                                            |  |  |  |  |  |  |  |  |
| 1                                   | 1                    | 1                                                             | 1+p                                                                                                                              |  |  |  |  |  |  |  |  |
| 1                                   | 1                    | 1, 3†                                                         | 1+p                                                                                                                              |  |  |  |  |  |  |  |  |
| 2+2d                                | 2+2d                 | 2+2d                                                          | 5+2d+p                                                                                                                           |  |  |  |  |  |  |  |  |
|                                     | <b>ROM</b><br>1<br>1 | ROM         DARAM           1         1           1         1 | Program           ROM         DARAM         SARAM           1         1         1           1         1         1,3 <sup>†</sup> |  |  |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

<sup>‡</sup> If the LTD instruction is used with external memory, the data move does not occur. (The previous product is accumulated, and the TREG is loaded.)

#### Cycles for a Repeat (RPT) Execution of an LTD Instruction

|          | Program  |          |             |                       |  |  |  |  |  |  |
|----------|----------|----------|-------------|-----------------------|--|--|--|--|--|--|
| Operand  | ROM      | DARAM    | SARAM       | External <sup>‡</sup> |  |  |  |  |  |  |
| DARAM    | n        | n        | n           | n+p                   |  |  |  |  |  |  |
| SARAM    | 2n–2     | 2n–2     | 2n–2, 2n+1† | 2n–2+p                |  |  |  |  |  |  |
| External | 4n-2+2nd | 4n-2+2nd | 4n-2+2nd    | 4n+1+2nd+p            |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

126

‡ If the LTD instruction is used with external memory, the data move does not occur. (The previous product is accumulated, and the TREG is loaded.)

#### Example 1

; (DP = 7: addresses 0380h-03FFh,

;PM = 0: no shift of product).

| ro | Inctri | iction |  |  |
|----|--------|--------|--|--|

|                     | Before Instruction |                     | After Instruction |
|---------------------|--------------------|---------------------|-------------------|
| Data Memory<br>3FEh | 62h                | Data Memory<br>3FEh | 62h               |
| Data Memory<br>3FFh | 0h                 | Data Memory<br>3FFh | 62h               |
| TREG                | 3h                 | TREG                | 62h               |
| PREG                | 0Fh                | PREG                | 0Fh               |
| ACC X               | 5h                 | ACC 0               | 14h               |
| C                   |                    | C                   |                   |



Note: The data move function for LTD can occur only within on-chip data memory RAM blocks.

| Syntax      | LTP dma<br>LTP ind [, ARn]                                                                                                                                  |                          |                 |       |        |                  |        |        |          | Direct addressing<br>Indirect addressing |         |        |        |       |        |       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------|-------|--------|------------------|--------|--------|----------|------------------------------------------|---------|--------|--------|-------|--------|-------|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+**0+**BR0+ |                          |                 |       |        |                  |        |        |          |                                          |         | er     |        |       |        |       |
| Opcode      | LTP dma                                                                                                                                                     |                          |                 |       |        |                  |        |        |          |                                          |         |        |        |       |        |       |
|             | 15                                                                                                                                                          |                          | 13              | 12    | 11     | 10               | 9      | 8      | 7        | 6                                        | 5       | 4      | 3      | 2     | 1      | 0     |
|             | 0                                                                                                                                                           | 1                        | 1               | 1     | 0      | 0                | 0      | 1      | 0        |                                          |         |        | dma    |       |        |       |
|             | LTP ind [, ARn]                                                                                                                                             |                          |                 |       |        |                  |        |        |          |                                          |         |        |        |       |        |       |
|             | 15                                                                                                                                                          |                          | 13              | 12    | 11     | 10               | 9      | 8      | 7        | 6                                        | 5       | 4      | 3      | 2     | 1      | 0     |
|             | 0                                                                                                                                                           | 1                        | 1               | 1     | 0      | 0                | 0      | 1      | 1        |                                          | ARU     |        | Ν      |       | NAR    |       |
|             | No                                                                                                                                                          |                          | RU, N<br>bage 7 |       | NARa   | re defi          | ned in | subse  | ection 7 | 7.3.4,                                   | Indirec | t Addi | ressin | д Орс | ode Fo | ormat |
| Execution   | (data                                                                                                                                                       | ement<br>a-men<br>ed (PF | nory a          | addre | ess) - | $\rightarrow$ TF | REG    |        |          |                                          |         |        |        |       |        |       |
| Status Bits | <u>Affe</u><br>PM                                                                                                                                           | <u>cted b</u>            | Ľ               |       |        |                  |        |        |          |                                          |         |        |        |       |        |       |
| Description | and                                                                                                                                                         | TREG<br>the PF<br>G is c | REG             | value | is st  | ored             | in the | e acci | umul     |                                          |         |        |        | -     |        |       |
| Words       | 1                                                                                                                                                           |                          |                 |       |        |                  |        |        |          |                                          |         |        |        |       |        |       |

### Cycles

#### **Cycles for a Single LTP Instruction**

|          |     | Program |       |          |  |  |  |  |  |  |
|----------|-----|---------|-------|----------|--|--|--|--|--|--|
| Operand  | ROM | DARAM   | SARAM | External |  |  |  |  |  |  |
| DARAM    | 1   | 1       | 1     | 1+p      |  |  |  |  |  |  |
| SARAM    | 1   | 1       | 1, 2† | 1+p      |  |  |  |  |  |  |
| External | 1+d | 1+d     | 1+d   | 2+d+p    |  |  |  |  |  |  |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

| C        | Cycles for a Repeat (RPT) Execution of an LTP Instruction |       |               |          |  |  |  |  |  |  |  |
|----------|-----------------------------------------------------------|-------|---------------|----------|--|--|--|--|--|--|--|
|          |                                                           | F     | Program       |          |  |  |  |  |  |  |  |
| Operand  | ROM                                                       | DARAM | SARAM         | External |  |  |  |  |  |  |  |
| DARAM    | n                                                         | n     | n             | n+p      |  |  |  |  |  |  |  |
| SARAM    | n                                                         | n     | n n, n+1† n+p |          |  |  |  |  |  |  |  |
| External | n+nd                                                      | n+nd  | n+nd          | n+1+p+nd |  |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block



| Syntax      | LTS dmaDirect addLTS ind [, ARn]Indirect add                                                                                                                                                             | dressing<br>ddressing  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliaind:Select one of the following seven options:**+*0+**0+                                                            |                        |
| Opcode      | LTS dma                                                                                                                                                                                                  |                        |
|             | 15 14 13 12 11 10 9 8 7 6 5 4                                                                                                                                                                            | 3 2 1 0                |
|             | 0 1 1 1 0 1 0 0 0                                                                                                                                                                                        | dma                    |
|             | LTS ind [, ARn]                                                                                                                                                                                          |                        |
|             | 15 14 13 12 11 10 9 8 7 6 5 4                                                                                                                                                                            | 3 2 1 0                |
|             | 0 1 1 1 0 1 0 0 1 ARU                                                                                                                                                                                    | N NAR                  |
| Execution   | <ul> <li>Note: ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Add</i> (page 7-12).</li> <li>Increment PC, then</li> <li>(data-memory address) → TREG</li> </ul>                            | Iressing Opcode Format |
|             | ACC – shifted (PREG) $\rightarrow$ ACC                                                                                                                                                                   |                        |
| Status Bits | Affected by Affects<br>PM and OVM C and OV                                                                                                                                                               |                        |
| Description | TREG is loaded with the contents of the addressed data-me<br>contents of the product register, shifted as defined by the o<br>status bits, are subtracted from the accumulator. The rest<br>accumulator. | contents of the PM     |
|             | The carry bit is cleared (C = 0) if the result of the subtractio<br>row and is set (C = 1) if it does not generate a borrow.                                                                             | on generates a bor-    |
| Words       | 1                                                                                                                                                                                                        |                        |

LTS

| Cycles for a Single LTS Instruction |     |       |       |          |  |  |  |  |  |  |
|-------------------------------------|-----|-------|-------|----------|--|--|--|--|--|--|
| Program                             |     |       |       |          |  |  |  |  |  |  |
| Operand                             | ROM | DARAM | SARAM | External |  |  |  |  |  |  |
| DARAM                               | 1   | 1     | 1     | 1+p      |  |  |  |  |  |  |
| SARAM                               | 1   | 1     | 1, 2† | 1+p      |  |  |  |  |  |  |
| External                            | 1+d | 1+d   | 1+d   | 2+d+p    |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

| C        | Cycles for a Repeat (RPT) Execution of an LTS Instruction |       |         |          |  |  |  |  |  |  |  |  |
|----------|-----------------------------------------------------------|-------|---------|----------|--|--|--|--|--|--|--|--|
| Program  |                                                           |       |         |          |  |  |  |  |  |  |  |  |
| Operand  | ROM                                                       | DARAM | SARAM   | External |  |  |  |  |  |  |  |  |
| DARAM    | n                                                         | n     | n       | n+p      |  |  |  |  |  |  |  |  |
| SARAM    | n                                                         | n     | n, n+1† | n+p      |  |  |  |  |  |  |  |  |
| External | n+nd                                                      | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

Example 1

DAT36 ;(D • PM

;(DP = 6: addresses 0300h-037Fh, ;PM = 0: no shift of product)

| TREG3h TREG6                           | 62h<br>62h |
|----------------------------------------|------------|
|                                        | 2h         |
| PREG 0Fh PREG 0                        |            |
|                                        | Fh         |
| ACC X 05h ACC 0 OFFFFFF                | 6h         |
| C C<br>Example 2 LTS *, AR2 ; (PM = 0) |            |
| Before Instruction After Instructi     | on         |
| ARP 1 ARP                              | 2          |
| AR1 324h AR1 32                        | 24h        |
| 324h 62h 324h 6                        | 62h        |
| TREG 3h TREG 6                         | 62h        |
| PREG 0Fh PREG 0                        | Fh         |
| ACC X 05h ACC 0 OFFFFFF<br>C C         | 6h         |

| Syntax    | MAC pma, dmaDirect addressingMAC pma, ind [, ARn]Indirect addressing                                                                                                                           |                                                                                                                                    |                                                                                                                                           |                                                                                                                  |                                                                  |                                                         |                                                       |                              |            |   |                 |    |     |   |     |   |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------|------------------------------|------------|---|-----------------|----|-----|---|-----|---|
| Operands  | dma:7 LSBs of the data-memory addresspma:16-bit program-memory addressn:Value from 0 to 7 designating the next auxiliary regisind:Select one of the following seven options:**+*0+**BR0+**BR0+ |                                                                                                                                    |                                                                                                                                           |                                                                                                                  |                                                                  |                                                         |                                                       |                              |            |   | giste           | er |     |   |     |   |
| Opcode    | MAC pma, dma                                                                                                                                                                                   |                                                                                                                                    |                                                                                                                                           |                                                                                                                  |                                                                  |                                                         |                                                       |                              |            |   |                 |    |     |   |     |   |
|           | 15                                                                                                                                                                                             | 14                                                                                                                                 | 13                                                                                                                                        | 12                                                                                                               | 11                                                               | 10                                                      | 9                                                     | 8                            | 7          | 6 | 5               | 4  | 3   | 2 | 1   | 0 |
|           | 1                                                                                                                                                                                              | 0                                                                                                                                  | 1                                                                                                                                         | 0                                                                                                                | 0                                                                | 0                                                       | 1                                                     | 0                            | 0          |   |                 |    | dma |   |     |   |
|           |                                                                                                                                                                                                |                                                                                                                                    |                                                                                                                                           |                                                                                                                  |                                                                  |                                                         |                                                       | pr                           | na         |   |                 |    |     |   |     |   |
|           | МА                                                                                                                                                                                             | <b>C</b> pn                                                                                                                        | na in                                                                                                                                     |                                                                                                                  | <b>R</b> nl                                                      |                                                         |                                                       |                              |            |   |                 |    |     |   |     |   |
|           | 15                                                                                                                                                                                             | 14                                                                                                                                 | 13                                                                                                                                        | 12 12                                                                                                            | 11                                                               | 10                                                      | 9                                                     | 8                            | 7          | 6 | 5               | 4  | 3   | 2 | 1   | 0 |
|           | 1                                                                                                                                                                                              | 0                                                                                                                                  | 1                                                                                                                                         | 0                                                                                                                | 0                                                                | 0                                                       | 1                                                     | 0                            | 1          |   | ARU             |    | Ν   |   | NAR |   |
|           |                                                                                                                                                                                                |                                                                                                                                    |                                                                                                                                           |                                                                                                                  |                                                                  |                                                         |                                                       | pr                           | na         |   |                 |    |     |   |     |   |
| Execution | (d<br>(d<br>Fe                                                                                                                                                                                 | ment<br>$\rightarrow$ MS<br>$\rightarrow$ PC<br>mem<br>direc<br>+ 1<br>(rep<br>ACC)<br>lata-r<br>lata-r<br>or inc<br>PC) +<br>epea | STAC<br>shifted<br>a ory a<br>a ory a<br>t, mo<br>$\rightarrow$ PC<br>eat c<br>+ sh<br>nemo<br>nemo<br>lirect<br>$1 \rightarrow$<br>t cou | then<br>K<br>(PR<br>addre<br>addre<br>addre<br>odify<br>ounte<br>ifted<br>ory a<br>ory a<br>pry a<br>PC<br>nter) | EG)<br>ess) -<br>ess) ><br>(curr<br>(PRI<br>ddre<br>ddre<br>ddre | → TR<br>< (pm<br>ent A<br>0:<br>EG) –<br>ss) –<br>ss) × | EG<br>a) →<br>R) ai<br>→ AC<br>→ TRI<br>(pma<br>nt AF | nd (A<br>EG<br>a) →<br>R) an | RP)<br>PRE | G | pecifi<br>as sp |    | əd  |   |     |   |

| Status Bits | <u>Affected by</u> <u>Affects</u><br>PM and OVM C and OV                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | The MAC instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|             | Adds the previous product, shifted as defined by the PM status bits, to the accumulator. The carry bit is set $(C = 1)$ if the result of the addition generates a carry and is cleared $(C = 0)$ if it does not generate a carry.                                                                                                                                                                                                                                                 |
|             | Loads the TREG with the content of the specified data-memory address.                                                                                                                                                                                                                                                                                                                                                                                                             |
|             | Multiplies the data-memory value in the TREG by the contents of the specified program-memory address.                                                                                                                                                                                                                                                                                                                                                                             |
|             | The data and program memory locations on the 'C24x may be any non-<br>reserved on-chip or off-chip memory locations. If the program memory is block<br>B0 of on-chip RAM, the CNF bit must be set to 1.                                                                                                                                                                                                                                                                           |
|             | When the MAC instruction is repeated, the program-memory address contained in the PC is incremented by 1 during each repetition. This makes it possible to access a series of operands in program memory. If you use indirect addressing to specify the data-memory address, a new data-memory address can be accessed during each repetition. If you use the direct addressing mode, the specified data-memory address is a constant; it is not modified during each repetition. |
|             | MAC is useful for long sum-of-products operations because, when repeated, it becomes a single-cycle instruction once the RPT pipeline is started.                                                                                                                                                                                                                                                                                                                                 |
| Words       | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### Cycles

| Cycles for a Single MAC Instruction             |                                      |                                      |                                      |                                                          |  |  |  |
|-------------------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|----------------------------------------------------------|--|--|--|
| Operand                                         | ROM                                  | DARAM                                | SARAM                                | External                                                 |  |  |  |
| Operand 1: DARAM/<br>ROM<br>Operand 2: DARAM    | 3                                    | 3                                    | 3                                    | 3+2p <sub>code</sub>                                     |  |  |  |
| Operand 1: SARAM<br>Operand 2: DARAM            | 3                                    | 3                                    | 3                                    | 3+2p <sub>code</sub>                                     |  |  |  |
| Operand 1: External<br>Operand 2: DARAM         | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub> +2p <sub>code</sub>                   |  |  |  |
| Operand 1: DARAM/<br>ROM<br>Operand 2: SARAM    | 3                                    | 3                                    | 3                                    | 3+2p <sub>code</sub>                                     |  |  |  |
| Operand 1: SARAM<br>Operand 2: SARAM            | 3<br>4†                              | 3<br>4†                              | 3<br>4†                              | 3+2p <sub>code</sub><br>4+2p <sub>code</sub> †           |  |  |  |
| Operand 1: External<br>Operand 2: SARAM         | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub> +2p <sub>code</sub>                   |  |  |  |
| Operand 1: DARAM/<br>ROM<br>Operand 2: External | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub> +2p <sub>code</sub>                   |  |  |  |
| Operand 1: SARAM<br>Operand 2: External         | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub> +2p <sub>code</sub>                   |  |  |  |
| Operand 1: External<br>Operand 2: External      | 4+p <sub>op1</sub> +d <sub>op2</sub> +2p <sub>code</sub> |  |  |  |

 $\ensuremath{^\dagger}$  If both operands are in the same SARAM block

| Cycles for a Repeat (RPT) Execution of an MAC Instruction |
|-----------------------------------------------------------|
|-----------------------------------------------------------|

| Operand                                      | ROM                   | DARAM                 | SARAM                 | External                                  |
|----------------------------------------------|-----------------------|-----------------------|-----------------------|-------------------------------------------|
| Operand 1: DARAM/<br>ROM<br>Operand 2: DARAM | n+2                   | n+2                   | n+2                   | n+2+2p <sub>code</sub>                    |
| Operand 1: SARAM<br>Operand 2: DARAM         | n+2                   | n+2                   | n+2                   | n+2+2p <sub>code</sub>                    |
| Operand 1: External<br>Operand 2: DARAM      | n+2+np <sub>op1</sub> | n+2+np <sub>op1</sub> | n+2+np <sub>op1</sub> | n+2+np <sub>op1</sub> +2p <sub>code</sub> |

 $\ensuremath{^\dagger}$  If both operands are in the same SARAM block

| Operand                                         | ROM                                                      | DARAM                                     | SARAM                                                                                                                           | External                                                          |
|-------------------------------------------------|----------------------------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| Dperand 1: DARAM/<br>ROM<br>Dperand 2: SARAM    | n+2                                                      | n+2                                       | n+2                                                                                                                             | n+2+2p <sub>code</sub>                                            |
| Operand 1: SARAM<br>Operand 2: SARAM            | n+2<br>2n+2†                                             | n+2<br>2n+2†                              | n+2<br>2n+2†                                                                                                                    | n+2+2p <sub>code</sub><br>2n+2†                                   |
| Operand 1: External<br>Operand 2: SARAM         | n+2+np <sub>op1</sub>                                    | n+2+np <sub>op1</sub>                     | n+2+np <sub>op1</sub>                                                                                                           | n+2+np <sub>op1</sub> +2p <sub>code</sub>                         |
| Dperand 1: DARAM/<br>ROM<br>Dperand 2: External | n+2+nd <sub>op2</sub>                                    | n+2+nd <sub>op2</sub>                     | n+2+nd <sub>op2</sub>                                                                                                           | n+2+nd <sub>op2</sub> +2p <sub>code</sub>                         |
| Operand 1: SARAM<br>Operand 2: External         | n+2+nd <sub>op2</sub>                                    | n+2+nd <sub>op2</sub>                     | n+2+nd <sub>op2</sub>                                                                                                           | n+2+nd <sub>op2</sub> +2p <sub>code</sub>                         |
| Operand 1: External<br>Operand 2: External      | 2n+2+np <sub>op1</sub> +<br>nd <sub>op2</sub>            | 2n+2+np <sub>op1</sub> +nd <sub>op2</sub> | 2n+2+np <sub>op1</sub> +nd <sub>op2</sub>                                                                                       | 2n+2+np <sub>op1</sub> +nd <sub>op2</sub> +<br>2p <sub>code</sub> |
| If both operands are in t                       | he same SARAM bl                                         | ock                                       |                                                                                                                                 |                                                                   |
| xample 1                                        | MAC                                                      | 0FF00h,02h                                | ;(DP = 6, PM =                                                                                                                  | = 0, CNF = 1)                                                     |
|                                                 | Data M<br>30<br>Program<br>FFC<br>TRE<br>PR<br>AC        | 2h<br>Memory<br>00h<br>EG4                | Data Memor<br>23h 302h<br>Program Memor<br>4h FF00h<br>45h TREG<br>58972h PREG<br>3EC41h ACC                                    | 231                                                               |
| xample 2                                        | MAC<br>AF<br>Data M<br>30<br>Program<br>FFC<br>TRE<br>PR | A4                                        | ; (PM = 0, CNF<br>ruction<br>4 ARP<br>302h AR4<br>Data Memor<br>302h<br>Program Memor<br>4h<br>FF00h<br>45h TREG<br>58972h PREG | After Instruction                                                 |

| Syntax    | MACD pm<br>MACD pm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                 | <b>\R</b> n]                                          |               |                |                         |             | Direct<br>Indire |   |        | -     |     |   |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------------------------------------------------|---------------|----------------|-------------------------|-------------|------------------|---|--------|-------|-----|---|
| Operands  | dma:<br>pma:<br>n:<br>ind:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 16-bit<br>Value | s of the o<br>program<br>from 0 to<br>one of th<br>*_ | -mem<br>7 des | ory a<br>signa | ddre<br>ting t<br>g sev | ss<br>the n | ext au           |   | ary re | giste | er  |   |
| Opcode    | MACD p                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ma, dma         |                                                       |               |                |                         |             |                  |   |        |       |     |   |
|           | 15 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 13 12           | 11 10                                                 | 9             | 8              | 7                       | 6           | 5                | 4 | 3      | 2     | 1   | 0 |
|           | 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1 0             | 0 0                                                   | 1             | 1              | 0                       |             |                  |   | dma    |       |     |   |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                 |                                                       |               | pr             | na                      |             |                  |   |        |       |     |   |
|           | MACD p                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ma ind [        | <b>AR</b> <i>n</i> ]                                  |               |                |                         |             |                  |   |        |       |     |   |
|           | 15 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 13 12           | 11 10                                                 | 9             | 8              | 7                       | 6           | 5                | 4 | 3      | 2     | 1   | 0 |
|           | 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1 0             | 0 0                                                   | 1             | 1              | 1                       |             | ARU              |   | Ν      |       | NAR |   |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                 |                                                       |               | pr             | na                      | •           |                  |   |        | •     |     |   |
| Execution | pma         Note:       ARU, N, and NAR are defined in subsection 7.3.4, Indirect Addressing Opcode Format (page 7-12).         Increment PC, then       (PC) → MSTACK         pma → PC       (ACC) + shifted (PREG) → ACC         (data-memory address) → TREG       (data-memory address) × (pma) → PREG         For indirect, modify (current AR) and (ARP) as specified       (PC) + 1 → PC         (data-memory address) → data-memory address + 1       While (repeat counter) ≠ 0:         (ACC) + shifted (PREG) → ACC       (data-memory address) → TREG         (data-memory address) → TREG       (data-memory address) → TREG         (data-memory address) → TREG       (data-memory address) → TREG         (data-memory address) → DREG       For indirect, modify (current AR) and (ARP) as specified         (PC) + 1 → PC       (data-memory address) → TREG         (data-memory address) → TREG       (data-memory address) → TREG         (data-memory address) → DREG       For indirect, modify (current AR) and (ARP) as specified         (PC) + 1 → PC       (data-memory address) → data-memory address + 1         (repeat counter) - 1 → repeat counter       (MSTACK) → PC |                 |                                                       |               |                |                         |             |                  |   |        |       |     |   |

| Status Bits | <u>Affected by</u><br>PM and OVM                                                                 | <u>Affects</u><br>C and OV                                                                                                                                                                                                                                                                                                                                          |
|-------------|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description | The MACD instruction                                                                             | n:                                                                                                                                                                                                                                                                                                                                                                  |
|             | accumulator. The                                                                                 | s product, shifted as defined by the PM status bits, to the carry bit is set (C = 1) if the result of the addition gener-<br>is cleared (C = 0) if it does not generate a carry.                                                                                                                                                                                    |
|             | Loads the TREG                                                                                   | with the content of the specified data-memory address.                                                                                                                                                                                                                                                                                                              |
|             |                                                                                                  | ta-memory value in the TREG by the contents of the n-memory address.                                                                                                                                                                                                                                                                                                |
|             | Copies the content<br>higher data-mem                                                            | ents of the specified data-memory address to the next ory address.                                                                                                                                                                                                                                                                                                  |
|             | reserved, on-chip or<br>block B0 of on-chip R/<br>of the memory-mappe<br>tion, the effect of the | am-memory locations on the 'C24x may be any non-<br>off-chip memory locations. If the program memory is<br>AM, the CNF bit must be set to 1. If MACD addresses one<br>ed registers or external memory as a data-memory loca-<br>instruction is that of a MAC instruction; the data move<br>the DMOV instruction description on page 8-65).                          |
|             | contained in the PC i<br>it possible to access<br>direct addressing to s<br>address can be acces | estruction is repeated, the program-memory address<br>s incremented by 1 during each repetition. This makes<br>a series of operands in program memory. If you use in-<br>specify the data-memory address, a new data-memory<br>seed during each repetition. If you use the direct address-<br>ed data-memory address is a constant; it will not be modi-<br>tition. |
|             | for on-chip RAM block such as convolution                                                        | e same manner as MAC, with the addition of a data move<br>cks. This feature makes MACD useful for applications<br>and transversal filtering. When used with RPT, MACD<br>cle instruction once the RPT pipeline is started.                                                                                                                                          |
| Words       | 2                                                                                                |                                                                                                                                                                                                                                                                                                                                                                     |

#### Cycles

| Cycles for a Single MACD Instruction             |                                      |                                      |                                      |                                                          |  |  |  |
|--------------------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|----------------------------------------------------------|--|--|--|
| Operand                                          | ROM                                  | DARAM                                | SARAM                                | External                                                 |  |  |  |
| Operand 1: DARAM/<br>ROM<br>Operand 2: DARAM     | 3                                    | 3                                    | 3                                    | 3+2p <sub>code</sub>                                     |  |  |  |
| Operand 1: SARAM<br>Operand 2: DARAM             | 3                                    | 3                                    | 3                                    | 3+2p <sub>code</sub>                                     |  |  |  |
| Operand 1: External<br>Operand 2: DARAM          | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub> +2p <sub>code</sub>                   |  |  |  |
| Operand 1: DARAM/<br>ROM<br>Operand 2: SARAM     | 3                                    | 3                                    | 3                                    | 3+2p <sub>code</sub>                                     |  |  |  |
| Operand 1: SARAM<br>Operand 2: SARAM             | 3                                    | 3                                    | 3<br>4†<br>5‡                        | 3+2p <sub>code</sub><br>4+2p <sub>code</sub> †           |  |  |  |
| Operand 1: External<br>Operand 2: SARAM          | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub>                   | 3+p <sub>op1</sub> +2p <sub>code</sub>                   |  |  |  |
| Operand 1: DARAM/<br>ROM<br>Operand 2: External§ | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub> +2p <sub>code</sub>                   |  |  |  |
| Operand 1: SARAM<br>Operand 2: External§         | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub>                   | 3+d <sub>op2</sub> +2p <sub>code</sub>                   |  |  |  |
| Operand 1: External<br>Operand 2: External§      | 4+p <sub>op1</sub> +d <sub>op2</sub> +2p <sub>code</sub> |  |  |  |

....

† If both operands are in the same SARAM block
 ‡ If both operands and code are in the same SARAM block
 § Data move operation is not performed when operand2 is in external data memory.

|                                                  | Cycles for a Repeat (RPT) Execution of an MACD Instruction |                                           |                                                  |                                                                   |  |  |  |
|--------------------------------------------------|------------------------------------------------------------|-------------------------------------------|--------------------------------------------------|-------------------------------------------------------------------|--|--|--|
| Operand                                          | ROM                                                        | DARAM                                     | SARAM                                            | External                                                          |  |  |  |
| Operand 1: DARAM/<br>ROM<br>Operand 2: DARAM     | n+2                                                        | n+2                                       | n+2                                              | n+2+2p <sub>code</sub>                                            |  |  |  |
| Operand 1: SARAM<br>Operand 2: DARAM             | n+2                                                        | n+2                                       | n+2                                              | n+2+2p <sub>code</sub>                                            |  |  |  |
| Operand 1: External<br>Operand 2: DARAM          | n+2+np <sub>op1</sub>                                      | n+2+np <sub>op1</sub>                     | n+2+np <sub>op1</sub>                            | n+2+np <sub>op1</sub> +2p <sub>code</sub>                         |  |  |  |
| Operand 1: DARAM/<br>ROM<br>Operand 2: SARAM     | 2n                                                         | 2n                                        | 2n<br>2n+2†                                      | 2n+2p <sub>code</sub>                                             |  |  |  |
| Operand 1: SARAM<br>Operand 2: SARAM             | 2n<br>3n‡                                                  | 2n<br>3n‡                                 | 2n<br>2n+2†<br>3n‡<br>3n+2§                      | 2n+2p <sub>code</sub><br>3n‡                                      |  |  |  |
| Operand 1: External<br>Operand 2: SARAM          | 2n+np <sub>op1</sub>                                       | 2n+np <sub>op1</sub>                      | 2n+np <sub>op1</sub><br>2n+2+np <sub>op1</sub> † | 2n+np <sub>op1</sub> +2p <sub>code</sub>                          |  |  |  |
| Operand 1: DARAM/<br>ROM<br>Operand 2: External¶ | n+2+nd <sub>op2</sub>                                      | n+2+nd <sub>op2</sub>                     | n+2+nd <sub>op2</sub>                            | n+2+nd <sub>op2</sub> +2p <sub>code</sub>                         |  |  |  |
| Operand 1: SARAM<br>Operand 2: External¶         | n+2+nd <sub>op2</sub>                                      | n+2+nd <sub>op2</sub>                     | n+2+nd <sub>op2</sub>                            | n+2+nd <sub>op2</sub> +2p <sub>code</sub>                         |  |  |  |
| Operand 1: External<br>Operand 2: External¶      | 2n+2+np <sub>op1</sub> +<br>nd <sub>op2</sub>              | 2n+2+np <sub>op1</sub> +nd <sub>op2</sub> | 2n+2+np <sub>op1</sub> +nd <sub>op2</sub>        | 2n+2+np <sub>op1</sub> +nd <sub>op2</sub> +<br>2p <sub>code</sub> |  |  |  |

Cycles for a Repeat (RPT) Execution of an MACD Instruction

<sup>†</sup> If operand 2 and code are in the same SARAM block <sup>‡</sup> If both operands are in the same SARAM block

§ If both operands and code are in the same SARAM block

 $\P$  Data move operation is not performed when operand2 is in external data memory.

| Example 1 | MACD OFF00h,08h                                                                              | ;(DP = 6: addresse                                                                                                                                                                                                        |                                                                    |
|-----------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
|           |                                                                                              | ;PM = 0: no shift                                                                                                                                                                                                         |                                                                    |
|           |                                                                                              | ;CNF = 1: RAM B0 c                                                                                                                                                                                                        | onfigured to                                                       |
|           |                                                                                              | ;program memory).                                                                                                                                                                                                         |                                                                    |
|           |                                                                                              | Before Instruction                                                                                                                                                                                                        | After Instruction                                                  |
|           | Data Memory                                                                                  | Data Mem                                                                                                                                                                                                                  |                                                                    |
|           | 308h                                                                                         | 23h308h                                                                                                                                                                                                                   | 23h                                                                |
|           | Data Memory                                                                                  | Data Mem                                                                                                                                                                                                                  |                                                                    |
|           | 309h                                                                                         | 18h 309h                                                                                                                                                                                                                  | 23h                                                                |
|           | Program Memory<br>FF00h                                                                      | Program Me<br>4h FF00h                                                                                                                                                                                                    |                                                                    |
|           | TREG                                                                                         | 45h TREG                                                                                                                                                                                                                  | 23h                                                                |
|           | PREG                                                                                         | 458972h PREG                                                                                                                                                                                                              | 8Ch                                                                |
|           | ACC X                                                                                        | 723EC41h ACC                                                                                                                                                                                                              | 0 76975B3h                                                         |
|           | C                                                                                            |                                                                                                                                                                                                                           | С                                                                  |
|           |                                                                                              |                                                                                                                                                                                                                           |                                                                    |
| Example 2 | MACD OFFOOh,                                                                                 | *, AR6 ; (PM = 0                                                                                                                                                                                                          | , $CNF = 1$ )                                                      |
|           |                                                                                              |                                                                                                                                                                                                                           |                                                                    |
|           |                                                                                              | Before Instruction                                                                                                                                                                                                        | After Instruction                                                  |
|           | ARP                                                                                          | Before Instruction           5         ARP                                                                                                                                                                                | After Instruction                                                  |
|           | ARP<br>AR5                                                                                   |                                                                                                                                                                                                                           |                                                                    |
|           |                                                                                              | 5   ARP     308h   AR5     Data Mem                                                                                                                                                                                       | 6<br>308h                                                          |
|           | AR5                                                                                          | 5         ARP           308h         AR5                                                                                                                                                                                  | 6<br>308h                                                          |
|           | AR5<br>Data Memory<br>308h<br>Data Memory                                                    | 5         ARP           308h         AR5           Data Mem           23h         308h           Data Mem                                                                                                                 | 6<br>308h<br>Iory<br>23h                                           |
|           | AR5<br>Data Memory<br>308h<br>Data Memory<br>309h                                            | 5         ARP           308h         AR5           Data Mem           23h         308h           Data Mem           18h         309h                                                                                      | 6<br>308h<br>lory<br>23h<br>lory<br>23h                            |
|           | AR5<br>Data Memory<br>308h<br>Data Memory                                                    | 5         ARP           308h         AR5           Data Mem           23h         308h           Data Mem                                                                                                                 | 6<br>308h<br>iory 23h<br>iory 23h<br>emory                         |
|           | AR5<br>Data Memory<br>308h<br>Data Memory<br>309h<br>Program Memory                          | 5         ARP           308h         AR5           Data Mem           23h         308h           Data Mem           18h         309h           Program Met                                                                | 6<br>308h<br>iory 23h<br>iory 23h<br>emory                         |
|           | AR5<br>Data Memory<br>308h<br>Data Memory<br>309h<br>Program Memory<br>FF00h                 | 5ARP308hAR5Data Mem23h308hData Mem18h309hProgram Me4hFF00h                                                                                                                                                                | 6<br>308h<br>lory 23h<br>lory 23h<br>emory 4h<br>23h               |
|           | AR5<br>Data Memory<br>308h<br>Data Memory<br>309h<br>Program Memory<br>FF00h<br>TREG<br>PREG | 5         ARP           308h         AR5           Data Mem           23h         308h           Data Mem           309h           Program Me           4h           FF00h           TREG                                 | 6<br>308h<br>iory 23h<br>iory 23h<br>emory 4h<br>23h<br>23h<br>8Ch |
|           | AR5<br>Data Memory<br>308h<br>Data Memory<br>309h<br>Program Memory<br>FF00h<br>TREG<br>PREG | 5         ARP           308h         AR5           Data Mem           23h         308h           Data Mem           309h           Program Me           4h           FF00h           45h           TREG           458972h | 6<br>308h<br>iory 23h<br>iory 23h<br>emory 4h<br>23h<br>23h<br>8Ch |

**Note:** The data move function for MACD can occur only within on-chip data memory RAM blocks.

| Syntax      | MAR dmaDirect addressingMAR ind [, ARn]Indirect addressing                                                                                                                                                                                                                                                                                                                                                                                    |    |  |  |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|--|--|--|--|
| Operands    | n: Value from 0 to 7 designating the next auxiliary register<br>ind: Select one of the following seven options:<br>* *+ *- *0+ *0- *BR0+ *BR0-                                                                                                                                                                                                                                                                                                |    |  |  |  |  |  |
| Opcode      | MAR dma                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |  |  |  |  |  |
|             | 15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         1       0       0       1       0       1       1       0       dma                                                                                                                                                                                                                                   | ٦  |  |  |  |  |  |
|             | MAR ind [, ARn]                                                                                                                                                                                                                                                                                                                                                                                                                               |    |  |  |  |  |  |
|             | <u>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</u>                                                                                                                                                                                                                                                                                                                                                                                                  |    |  |  |  |  |  |
|             | 1 0 0 0 1 0 1 1 1 ARU N NAR                                                                                                                                                                                                                                                                                                                                                                                                                   |    |  |  |  |  |  |
|             | <b>Note:</b> ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).                                                                                                                                                                                                                                                                                                                           | j. |  |  |  |  |  |
| Execution   | Event(s)Addressing modeIncrement PCDirect                                                                                                                                                                                                                                                                                                                                                                                                     |    |  |  |  |  |  |
|             | Increment PC Indirect<br>Modify (current AR) and (ARP) as specified                                                                                                                                                                                                                                                                                                                                                                           |    |  |  |  |  |  |
| Status Bits | AffectsAddressing modeNoneDirect                                                                                                                                                                                                                                                                                                                                                                                                              |    |  |  |  |  |  |
|             | ARP and ARB Indirect                                                                                                                                                                                                                                                                                                                                                                                                                          |    |  |  |  |  |  |
| Description | In the direct addressing mode, the MAR instruction acts as a NOP instruction.                                                                                                                                                                                                                                                                                                                                                                 |    |  |  |  |  |  |
|             | In the indirect addressing mode, an auxiliary register value and the ARP value can be modified; however, the memory being referenced is not used. When MAR modifies the ARP value, the old ARP value is copied to the ARB field of ST1. Any operation that MAR performs with indirect addressing can also be performed with any instruction that supports indirect addressing. In addition, the ARP can also be loaded by an LST instruction. |    |  |  |  |  |  |
|             | The LARP instruction from the 'C25 instruction set is a subset of MAR. For example, MAR*, AR4 performs the same function as LARP 4, which loads the ARP with 4.                                                                                                                                                                                                                                                                               |    |  |  |  |  |  |
|             | For loading an auxiliary register, see the description for the LAR instruction on page 8-79. For storing an auxiliary register value to data memory, see the SAR instruction on page 8-151.                                                                                                                                                                                                                                                   |    |  |  |  |  |  |
| 8-110       | PRELIMINARY                                                                                                                                                                                                                                                                                                                                                                                                                                   | /  |  |  |  |  |  |

| Words     | 1   |                 |                     |                |                   |
|-----------|-----|-----------------|---------------------|----------------|-------------------|
| Cycles    |     | Сус             | cles for a Single M | AR Instruction |                   |
|           | ROM | DAF             | AM SA               | RAM            | External          |
|           | 1   | 1               | 1                   |                | 1+p               |
|           |     | Cycles for a Re | epeat (RPT) Execut  | ion of an MAR  | Instruction       |
|           | ROM | DAF             | AM SA               | RAM            | External          |
|           | n   | n               | n                   |                | n+p               |
|           |     |                 |                     |                |                   |
| Example 1 | MAR | *,AR1           | ;Load the A         | ARP with 1.    |                   |
|           |     |                 | Before Instruction  |                | After Instruction |
|           |     | ARP             | 0                   | ARP            | 1                 |
|           |     | ARB             | 7                   | ARB            | 0                 |
| Example 2 | MAR | *+,AR5          | ;Increment          | current au     | uxiliary          |
| -         |     |                 | ;register (         | (AR1) and ]    | load ARP          |
|           |     |                 | ;with 5.            |                |                   |
|           |     |                 | Before Instruction  |                | After Instruction |
|           |     | AR1             | 34h                 | AR1            | 35h               |
|           |     | ARP             | 1                   | ARP            | 5                 |
|           |     | ARB             | 0                   | ARB            | 1                 |

| Syntax      | MPY dma<br>MPY ind [, ARn]<br>MPY #k                                                                                                                                                                                                                                                                                                          |                                            |                      |                         |               |                  |                        |       | Direct addressing<br>Indirect addressing<br>Short immediate addressing |       |        |        |       |     |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|----------------------|-------------------------|---------------|------------------|------------------------|-------|------------------------------------------------------------------------|-------|--------|--------|-------|-----|
| Operands    | dma:<br>n:<br>k:<br>ind:                                                                                                                                                                                                                                                                                                                      | 7 LSB<br>Value<br>13-bit<br>Select<br>* *+ | from<br>short<br>one | 0 to 7<br>imm<br>of the | 7 de:<br>edia | signa<br>te val  | ting t<br>lue<br>g sev | he n  | ext au                                                                 |       | ıry re | giste  | ïr    |     |
| Opcode      | MPY dma                                                                                                                                                                                                                                                                                                                                       | а                                          |                      |                         |               |                  |                        |       |                                                                        |       |        |        |       |     |
| ·           | 15 14                                                                                                                                                                                                                                                                                                                                         | 13 12                                      | 11                   | 10                      | 9             | 8                | 7                      | 6     | 5                                                                      | 4     | 3      | 2      | 1     | 0   |
|             | 0 1                                                                                                                                                                                                                                                                                                                                           | 0 1                                        | 0                    | 1                       | 0             | 0                | 0                      |       |                                                                        |       | dma    |        |       |     |
|             | MPY ind                                                                                                                                                                                                                                                                                                                                       | [, <b>AR</b> <i>n</i> ]                    |                      |                         |               |                  |                        |       |                                                                        |       |        |        |       |     |
|             | 15 14                                                                                                                                                                                                                                                                                                                                         | 13 12                                      | 11                   | 10                      | 9             | 8                | 7                      | 6     | 5                                                                      | 4     | 3      | 2      | 1     | 0   |
|             | 0 1<br>Note: AF                                                                                                                                                                                                                                                                                                                               |                                            |                      | 1<br>ro dofir           | 0<br>aad in   | 0                | 1                      | 7 7 4 | ARU                                                                    | + Add | N      |        | NAR   |     |
|             |                                                                                                                                                                                                                                                                                                                                               | age 7-12).                                 | NARa                 | redeni                  | leain         | subse            | CUON /                 | .3.4, | maireci                                                                | Auui  | essing | y Opco | Jueru | mai |
|             | MPY #k                                                                                                                                                                                                                                                                                                                                        |                                            |                      |                         |               |                  |                        |       |                                                                        |       |        |        |       |     |
|             | 15 14                                                                                                                                                                                                                                                                                                                                         | 13 12                                      | 11                   | 10                      | 9             | 8                | 7                      | 6     | 5                                                                      | 4     | 3      | 2      | 1     | 0   |
|             | 1 1                                                                                                                                                                                                                                                                                                                                           | 0                                          |                      |                         |               |                  |                        | k     |                                                                        |       |        |        |       |     |
| Execution   | Increment F<br><u>Event</u><br>(TREG) × (r<br>(TREG) × k                                                                                                                                                                                                                                                                                      | data-me                                    | mory                 | addr                    | ess)          | $\rightarrow$ PI | REG                    |       | <u>Addre</u><br>Direct<br>Short                                        | or ii | ndire  | ct     |       |     |
| Status Bits | None                                                                                                                                                                                                                                                                                                                                          |                                            |                      |                         |               |                  |                        |       |                                                                        |       |        |        |       |     |
| Description | The contents of TREG are multiplied by the contents of the addressed data memory location. The result is placed in the product register (PREG). With short immediate addressing, TREG is multiplied by a signed 13-bit constant. The short-immediate value is right justified and sign extended before the multiplication, regardless of SXM. |                                            |                      |                         |               |                  |                        |       | Vith<br>ant.                                                           |       |        |        |       |     |
| Words       | 1                                                                                                                                                                                                                                                                                                                                             |                                            |                      |                         |               |                  |                        |       |                                                                        |       |        |        |       |     |
| 8-112       |                                                                                                                                                                                                                                                                                                                                               |                                            |                      |                         |               |                  |                        |       |                                                                        |       | PRE    | LIM    | IINA  | RY  |

| Cycles for a Single MPY Instruction (Using Direct and Indirect Addressing) |     |       |       |          |  |  |  |  |
|----------------------------------------------------------------------------|-----|-------|-------|----------|--|--|--|--|
| Program                                                                    |     |       |       |          |  |  |  |  |
| Operand                                                                    | ROM | DARAM | SARAM | External |  |  |  |  |
| DARAM                                                                      | 1   | 1     | 1     | 1+p      |  |  |  |  |
| SARAM                                                                      | 1   | 1     | 1, 2† | 1+p      |  |  |  |  |
| External                                                                   | 1+d | 1+d   | 1+d   | 2+d+p    |  |  |  |  |

### Cycles

#### $\ensuremath{^\dagger}$ If the operand and the code are in the same SARAM block

# Cycles for a Repeat (RPT) Execution of an MPY Instruction (Using Direct and Indirect Addressing)

|          | Program |       |         |          |  |  |  |  |  |
|----------|---------|-------|---------|----------|--|--|--|--|--|
| Operand  | ROM     | DARAM | SARAM   | External |  |  |  |  |  |
| DARAM    | n       | n     | n       | n+p      |  |  |  |  |  |
| SARAM    | n       | n     | n, n+1† | n+p      |  |  |  |  |  |
| External | n+nd    | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

| Cycles for a Single MPY Instruction (Using Short Immediate Addressing) |       |       |          |  |  |  |  |  |  |
|------------------------------------------------------------------------|-------|-------|----------|--|--|--|--|--|--|
| ROM                                                                    | DARAM | SARAM | External |  |  |  |  |  |  |
| 1                                                                      | 1     | 1     | 1+p      |  |  |  |  |  |  |

| Example 1 | MPY | DAT13              | ;(DP = 8)                 |                     |                   |
|-----------|-----|--------------------|---------------------------|---------------------|-------------------|
|           |     |                    | <b>Before Instruction</b> |                     | After Instruction |
|           | Da  | ata Memory<br>40Dh | 7h                        | Data Memory<br>40Dh | 7h                |
|           |     | TREG               | 6h                        | TREG                | 6h                |
|           |     | PREG               | 36h                       | PREG                | 2Ah               |

MPY Multiply

PRELIMINARY

| Example 2 | MPY | *,AR2               |                           |                     |                   |
|-----------|-----|---------------------|---------------------------|---------------------|-------------------|
|           |     |                     | <b>Before Instruction</b> |                     | After Instruction |
|           |     | ARP                 | 1                         | ARP                 | 2                 |
|           |     | AR1                 | 40Dh                      | AR1                 | 40Dh              |
|           |     | Data Memory<br>40Dh | 7h                        | Data Memory<br>40Dh | 7h                |
|           |     | TREG                | 6h                        | TREG                | 6h                |
|           |     | PREG                | 36h                       | PREG                | 2Ah               |
| Example 3 | MPY | #031h               |                           |                     |                   |
|           |     |                     | Before Instruction        |                     | After Instruction |
|           |     | TREG                | 2h                        | TREG                | 2h                |
|           |     | PREG                | 36h                       | PREG                | 62h               |

| Syntax      |                 |              | dma<br>ind             |                 | <b>[</b> <i>n</i> ]  |             |                             |        |                 |                 |        | Direct<br>Indire           |        |         | •     |        |      |
|-------------|-----------------|--------------|------------------------|-----------------|----------------------|-------------|-----------------------------|--------|-----------------|-----------------|--------|----------------------------|--------|---------|-------|--------|------|
| Operands    | dm<br>n:<br>inc | na:<br>d:    |                        | Va              | alue                 | from<br>one | 0 to <sup>.</sup><br>of the | 7 de   | •               | ting t<br>g sev | he n   | ext au                     |        | ary re  | giste | er     |      |
| Opcode      | I               | MP۱          | <b>(A</b> di           | ma              |                      |             |                             |        |                 |                 |        |                            |        |         |       |        |      |
|             | _               | 15           | 14                     | 13              | 12                   | 11          | 10                          | 9      | 8               | 7               | 6      | 5                          | 4      | 3       | 2     | 1      | 0    |
|             |                 | 0            | 1                      | 0               | 1                    | 0           | 0                           | 0      | 0               | 0               |        |                            |        | dma     |       |        |      |
|             | I               | MP۱          | <b>(A</b> in           | d [, 🖌          | <b>4R</b> <i>n</i> ] |             |                             |        |                 |                 |        |                            |        |         |       |        |      |
|             | -               | 15           | 14                     | 13              | 12                   | 11          | 10                          | 9      | 8               | 7               | 6      | 5                          | 4      | 3       | 2     | 1      | 0    |
|             |                 | 0            | 1                      | 0               | 1                    | 0           | 0                           | 0      | 0               | 1               |        | ARU                        |        | Ν       |       | NAR    |      |
|             | I               | Note         |                        | RU, N<br>age 7  |                      | IAR a       | re defii                    | ned in | subse           | ection 7        | 7.3.4, | Indirec                    | t Addı | ressing | д Орс | ode Fc | rmat |
| Execution   | (A              | CC)          | + sh                   | nifted          | •                    | EG)         | $\rightarrow A($ addr       |        | $\rightarrow P$ | REG             |        |                            |        |         |       |        |      |
| Status Bits |                 |              | <i>ed b</i> y<br>id O∖ |                 |                      |             | <u>ects</u><br>and C        | V      |                 |                 |        |                            |        |         |       |        |      |
| Description | me<br>vic       | emo<br>ous j | ry loo                 | catio<br>uct, s | n. Th                | e res       | ultis                       | plac   | ed in           | the p           | rodu   | tents<br>ct reg<br>us bits | ister  | (PRI    | EG).  | Thep   | ore- |
| Words       | 1               |              |                        |                 |                      |             |                             |        |                 |                 |        |                            |        |         |       |        |      |

#### Cycles

#### Cycles for a Single MPYA Instruction

|          | Program |       |       |          |  |  |  |  |  |
|----------|---------|-------|-------|----------|--|--|--|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |  |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |  |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |  |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |  |  |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

| Cy       | Cycles for a Repeat (RPT) Execution of an MPYA Instruction |       |         |          |  |  |  |  |  |  |
|----------|------------------------------------------------------------|-------|---------|----------|--|--|--|--|--|--|
|          | Program                                                    |       |         |          |  |  |  |  |  |  |
| Operand  | ROM                                                        | DARAM | SARAM   | External |  |  |  |  |  |  |
| DARAM    | n                                                          | n     | n       | n+p      |  |  |  |  |  |  |
| SARAM    | n                                                          | n     | n, n+1† | n+p      |  |  |  |  |  |  |
| External | n+nd                                                       | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block



| Syntax      |         | IPYS<br>IPYS         |                  | a<br>[, AF      | <b>R</b> <i>n</i> ] |                 |                       |               |                 |                 |               | Direct<br>Indire                     |                 |               | •     |        |       |
|-------------|---------|----------------------|------------------|-----------------|---------------------|-----------------|-----------------------|---------------|-----------------|-----------------|---------------|--------------------------------------|-----------------|---------------|-------|--------|-------|
| Operands    | n       | ma:<br>:<br>id:      |                  | Va              | alue                | from<br>one     | 0 to<br>of the        | 7 de          | -               | ting t<br>g sev | the n         | ext au                               |                 | ary re        | giste | ər     |       |
| Opcode      |         | MP                   | <b>YS</b> d      | ma              |                     |                 |                       |               |                 |                 |               |                                      |                 |               |       |        |       |
|             |         | 15                   | 14               | 13              | 12                  | 11              | 10                    | 9             | 8               | 7               | 6             | 5                                    | 4               | 3             | 2     | 1      | 0     |
|             |         | 0                    | 1                | 0               | 1                   | 0               | 0                     | 0             | 1               | 0               |               |                                      |                 | dma           |       |        |       |
|             |         | MP                   | YS ir            | nd [, I         | AR <i>n</i> ]       |                 |                       |               |                 |                 |               |                                      |                 |               |       |        |       |
|             | 1       | 15                   | 14               | 13              | 12                  | 11              | 10                    | 9             | 8               | 7               | 6             | 5                                    | 4               | 3             | 2     | 1      | 0     |
|             |         | 0                    | 1                | 0               | 1                   | 0               | 0                     | 0             | 1               | 1               |               | ARU                                  |                 | Ν             |       | NAR    |       |
|             |         | Note                 |                  | RU, N<br>age 7  |                     | IAR a           | re defii              | ned in        | I SUDSE         | ection          | 7.3.4,        | Indirec                              | t Addi          | ressing       | g Opc | ode Fc | ormat |
| Execution   | (A      | ACC)                 | – sł             | nifted          |                     | EG)             | $\rightarrow A($ addr |               | $\rightarrow P$ | REG             |               |                                      |                 |               |       |        |       |
| Status Bits |         | <i>ffect</i><br>M ar | -                |                 |                     |                 | <u>ects</u><br>and C  | V             |                 |                 |               |                                      |                 |               |       |        |       |
| Description | m<br>vi | iemo<br>ous j        | ory loo<br>orodu | catio<br>uct, s | n. Th<br>shifte     | e res<br>d as o | ult is<br>define      | plac<br>ed by | ed in<br>y the  | the p<br>PM s   | rodu<br>tatus | tents<br>ict reg<br>bits, i<br>iccum | ister<br>is als | (PRI<br>so su | EG).  | Thep   | ore-  |
| Words       | 1       |                      |                  |                 |                     |                 |                       |               |                 |                 |               |                                      |                 |               |       |        |       |

#### Cycles

#### Cycles for a Single MPYS Instruction

|          | Program |       |       |          |  |  |  |  |  |
|----------|---------|-------|-------|----------|--|--|--|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |  |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |  |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |  |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |  |  |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

| Cy       | Cycles for a Repeat (RPT) Execution of an MPYS Instruction |       |         |          |  |  |  |  |  |  |
|----------|------------------------------------------------------------|-------|---------|----------|--|--|--|--|--|--|
|          | Program                                                    |       |         |          |  |  |  |  |  |  |
| Operand  | ROM                                                        | DARAM | SARAM   | External |  |  |  |  |  |  |
| DARAM    | n                                                          | n     | n       | n+p      |  |  |  |  |  |  |
| SARAM    | n                                                          | n     | n, n+1† | n+p      |  |  |  |  |  |  |
| External | n+nd                                                       | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block



| Syntax      | MPYU dma<br>MPYU ind [, ARn]                                                                                                                                      |                          |                          |                          |                            |                          |                        |                            |                            |                          |                 | Direct addressing<br>Indirect addressing |                  |                 |                    |              |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------|--------------------------|----------------------------|--------------------------|------------------------|----------------------------|----------------------------|--------------------------|-----------------|------------------------------------------|------------------|-----------------|--------------------|--------------|--|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+**0+**BR0+**BR0+ |                          |                          |                          |                            |                          |                        |                            |                            |                          |                 |                                          |                  |                 |                    |              |  |
| Opcode      | MP                                                                                                                                                                | YU a                     | lma                      |                          |                            |                          |                        |                            |                            |                          |                 |                                          |                  |                 |                    |              |  |
|             | 15                                                                                                                                                                | 14                       | 13                       | 12                       | 11                         | 10                       | 9                      | 8                          | 7                          | 6                        | 5               | 4                                        | 3                | 2               | 1                  | 0            |  |
|             | 0                                                                                                                                                                 | 1                        | 0                        | 1                        | 0                          | 1                        | 0                      | 1                          | 0                          |                          |                 |                                          | dma              |                 |                    |              |  |
|             | MP                                                                                                                                                                | YU ir                    | nd [, <b>F</b>           | <b>R</b> n]              |                            |                          |                        |                            |                            |                          |                 |                                          |                  |                 |                    |              |  |
|             | 15                                                                                                                                                                | 14                       | 13                       | 12                       | 11                         | 10                       | 9                      | 8                          | 7                          | 6                        | 5               | 4                                        | 3                | 2               | 1                  | 0            |  |
|             | 0                                                                                                                                                                 | 1                        | 0                        | 1                        | 0                          | 1                        | 0                      | 1                          | 1                          |                          | ARU             |                                          | Ν                |                 | NAR                |              |  |
| <b>F</b>    | Note                                                                                                                                                              | (p                       | age 7                    | '-12).                   |                            | reaem                    | neair                  | SUDSE                      | ection                     | 7.3.4,                   | Indirec         | t Addi                                   | ressinį          | д Орс           | ode FC             | ormat        |  |
| Execution   | Incren<br>Unsigi                                                                                                                                                  |                          |                          |                          |                            | gned                     | (da                    | ta-me                      | emory                      | y ado                    | dress)          | ightarrow F                              | PREC             | 3               |                    |              |  |
| Status Bits | None<br>This ir                                                                                                                                                   | nstru                    | ction                    | is no                    | ot aff                     | ectec                    | l by                   | SXM                        |                            |                          |                 |                                          |                  |                 |                    |              |  |
| Description | The ur<br>addres<br>(PREC<br>tion, w                                                                                                                              | ssed<br>G). T<br>/ith tl | data<br>he m<br>he M     | i-mei<br>iultip<br>SB o  | mory<br>lier a<br>of bot   | locat<br>cts a<br>h ope  | tion.<br>s a s<br>eran | The<br>signed<br>ds for    | resuli<br>d 17 :<br>rced l | t is p<br>× 17-<br>to 0. | laced<br>bit mu | in th<br>ultipl                          | ie pro<br>ier fo | oduc<br>or this | t regi:<br>s insti | ster<br>ruc- |  |
|             | When<br>or to th<br>of the<br>when<br>used i                                                                                                                      | ne C/<br>PRE<br>PM =     | ALU,<br>EG. T<br>= 3 (ri | the v<br>his s<br>ight-s | value<br>hiftei<br>shift-l | pass<br>r alwa<br>by-6 i | ses fi<br>ays i<br>mod | irst th<br>nvoko<br>e). Tł | irougl<br>es sig           | h the<br>gn e>           | produ<br>tensio | uct s<br>on oi                           | hifter<br>n the  | r at th<br>PRE  | ne out<br>EG va    | tput<br>alue |  |
|             | The M<br>produc<br>uct.                                                                                                                                           |                          |                          |                          |                            |                          |                        | -                          |                            |                          |                 | -                                        |                  | • •             |                    |              |  |
| Words       | 1                                                                                                                                                                 |                          |                          |                          |                            |                          |                        |                            |                            |                          |                 |                                          |                  |                 |                    |              |  |

#### MPYU Multiply Unsigned

### Cycles

#### Cycles for a Single MPYU Instruction

|          | Program |       |       |          |  |  |  |  |  |  |  |  |
|----------|---------|-------|-------|----------|--|--|--|--|--|--|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |  |  |  |  |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |  |  |  |  |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |  |  |  |  |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |  |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Cy       | Cycles for a Repeat (RPT) Execution of an MPYU Instruction |       |         |          |  |  |  |  |  |  |  |  |  |
|----------|------------------------------------------------------------|-------|---------|----------|--|--|--|--|--|--|--|--|--|
|          | Program                                                    |       |         |          |  |  |  |  |  |  |  |  |  |
| Operand  | ROM                                                        | DARAM | SARAM   | External |  |  |  |  |  |  |  |  |  |
| DARAM    | n                                                          | n     | n       | n+p      |  |  |  |  |  |  |  |  |  |
| SARAM    | n                                                          | n     | n, n+1† | n+p      |  |  |  |  |  |  |  |  |  |
| External | n+nd                                                       | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |  |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Example 1 | MPYU | 16                          | ; (DP = 4:                | addresses 020               | 0h-027Fh)         |
|-----------|------|-----------------------------|---------------------------|-----------------------------|-------------------|
|           |      |                             | <b>Before Instruction</b> |                             | After Instruction |
|           |      | Data Memory<br>210h<br>TREG | OFFFFh<br>OFFFFh          | Data Memory<br>210h<br>TREG | 0FFFFh<br>0FFFFh  |
|           |      | PREG                        | 1h                        | PREG                        | 0FFFE0001h        |
| Example 2 | MPYU | *,AR6                       | Before Instruction        |                             | After Instruction |
|           |      | ARP                         | 5                         | ARP                         | 6                 |
|           |      | AR5                         | 210h                      | AR5                         | 210h              |
|           |      | Data Memory<br>210h         | 0FFFh                     | Data Memory<br>210h         | 0FFFFh            |
|           |      | TREG                        | 0FFFFh                    | TREG                        | 0FFFFh            |
|           |      | PREG                        | 1h                        | PREG                        | 0FFFE0001h        |

| Syntax      | NEG                                                            |                               |                       |                                                              |                           |                            |                          |                                |                         |                         |                      |                            |                        |                        |                         |
|-------------|----------------------------------------------------------------|-------------------------------|-----------------------|--------------------------------------------------------------|---------------------------|----------------------------|--------------------------|--------------------------------|-------------------------|-------------------------|----------------------|----------------------------|------------------------|------------------------|-------------------------|
| Operands    | None                                                           |                               |                       |                                                              |                           |                            |                          |                                |                         |                         |                      |                            |                        |                        |                         |
| Opcode      | 15 14<br>1 0                                                   | 13<br>1                       | 12<br>1               | 11<br>1                                                      | 10<br>1                   | 9<br>1                     | 8<br>0                   | 7<br>0                         | 6<br>0                  | 5<br>0                  | 4<br>0               | 3<br>0                     | 2<br>0                 | 1                      | 0                       |
| Execution   | Incremer<br>(ACC) ×                                            |                               |                       |                                                              |                           |                            |                          |                                |                         |                         |                      |                            |                        |                        |                         |
| Status Bits | <u>Affected</u><br>OVM                                         | <u>by</u>                     |                       |                                                              | f <u>fects</u><br>and     |                            |                          |                                |                         |                         |                      |                            |                        |                        |                         |
| Description | The cont<br>complem<br>OVM = 1<br>the resul<br>all nonze<br>0. | nent).<br>, the a<br>t is 800 | The<br>accum<br>00 00 | OV<br>nulat<br>000h                                          | bit is<br>tor co<br>. The | s set<br>onter<br>e cari   | t whe<br>t is r<br>y bit | en ta<br>eplac<br>(C) is       | king<br>ced w<br>s clea | the<br>/ith 7<br>ared 1 | NEG<br>FFF<br>to 0 k | i of a<br>FFF<br>by thi    | 8000<br>Fh. I<br>s ins | 000<br>f OVI<br>tructi | 0h. If $M = 0$ , on for |
| Words       | 1                                                              |                               |                       |                                                              |                           |                            |                          |                                |                         |                         |                      |                            |                        |                        |                         |
| Cycles      |                                                                |                               |                       | Сус                                                          | cles f                    | or a                       | Singl                    | e NE                           | G Ins                   | truct                   | ion                  |                            |                        |                        |                         |
|             | ROM                                                            |                               |                       |                                                              | RAM                       |                            |                          | SAF                            | 2 A M                   |                         |                      | Evt                        | ernal                  |                        |                         |
|             |                                                                |                               |                       | DAF                                                          | NAIVI                     |                            |                          | UA                             |                         |                         |                      | EXI                        | emai                   |                        |                         |
|             | 1                                                              |                               |                       | 1                                                            | <b>NAIVI</b>              |                            |                          | 1                              |                         |                         |                      | 1+p                        |                        |                        |                         |
|             |                                                                | Cycle                         |                       | 1                                                            |                           | (RP                        | Г) Ex(                   | 1                              |                         | an N                    | IEG li               | 1+p                        | )                      |                        |                         |
|             |                                                                | Cycle                         | s for                 | 1                                                            | epeat                     | (RP                        | Г) Exc                   | 1<br>ecutio                    |                         | an N                    | IEG I                | 1+p<br>nstru               | )                      | 1                      |                         |
|             | 1                                                              | Cycle                         | es for                | 1<br>a Re                                                    | epeat                     | (RP]                       | Г) Exc                   | 1<br>ecutio                    | on of                   | an N                    | ieg i                | 1+p<br>nstru               | )<br>Ictior            | 1                      |                         |
| Example 1   | 1<br>ROM                                                       | -                             | es for                | 1<br><b>a Re</b><br><b>DAF</b><br>n<br>M =<br>()<br>()<br>() | epeat<br>RAM              | Con <sup>,</sup><br>re Ins |                          | 1<br>ecution<br>SAF<br>n<br>3. | on of<br>RAM            |                         | +354                 | 1+p<br>nstru<br>Ext<br>n+p | )<br>Ictior            | Instru                 | iction<br>DD8h          |

### PRELIMINARY

Assembly Language Instructions 8-121

### **NEG** Negate Accumulator



| Syntax      | ΝΜΙ                                                                                                                                                                                                                                   |                   |         |         |         |        |        |        |         |        |        |         |         |           |       |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------|---------|---------|--------|--------|--------|---------|--------|--------|---------|---------|-----------|-------|
| Operands    | None                                                                                                                                                                                                                                  |                   |         |         |         |        |        |        |         |        |        |         |         |           |       |
| Opcode      | 15 14<br>1 0                                                                                                                                                                                                                          | 13<br>1           | 12<br>1 | 11<br>1 | 10<br>1 | 9<br>1 | 8<br>0 | 7<br>0 | 6<br>1  | 5<br>0 | 4<br>1 | 3<br>0  | 2<br>0  | 1<br>1    | 0     |
| Execution   | (PC) + 1<br>24h $\rightarrow$ P<br>1 $\rightarrow$ INT                                                                                                                                                                                | С                 | ack     |         |         |        |        |        |         |        |        |         |         |           |       |
| Status Bits | <u>Affects</u><br>INTM                                                                                                                                                                                                                |                   |         |         |         |        |        |        |         |        |        |         |         |           |       |
|             | This inst                                                                                                                                                                                                                             | ructio            | n is r  | not at  | ffecte  | d by   | INTI   | M.     |         |        |        |         |         |           |       |
| Description | This instruction is not affected by INTM.<br>The NMI instruction forces the program counter to the nonmaskable interrupt<br>vector located at 24h. This instruction has the same effect as the hardware<br>nonmaskable interrupt NMI. |                   |         |         |         |        |        |        |         |        |        |         |         | •         |       |
| Words       | 1                                                                                                                                                                                                                                     |                   |         |         |         |        |        |        |         |        |        |         |         |           |       |
| Cycles      |                                                                                                                                                                                                                                       |                   |         | Су      | cles    | for a  | Sing   | le NN  | /II Ins | truct  | ion    |         |         |           |       |
|             | ROM                                                                                                                                                                                                                                   |                   |         | DAF     | RAM     |        |        | SA     | RAM     |        |        | Ext     | ernal   |           |       |
|             | 4                                                                                                                                                                                                                                     |                   |         | 4       |         |        |        | 4      |         |        |        | 4+3     | 8p†     |           |       |
|             | † The 'C2<br>disconti                                                                                                                                                                                                                 |                   |         |         |         |        |        |        |         |        |        | tructic | on word | ds. If th | ne PC |
| Example     |                                                                                                                                                                                                                                       | PC<br>cont<br>24h | trol    | -       | -       |        |        |        |         |        |        |         |         | ion       |       |

| Syntax      | NOP          |                     |         |         |        |        |        |        |        |        |        |        |        |     |
|-------------|--------------|---------------------|---------|---------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-----|
| Operands    | None         |                     |         |         |        |        |        |        |        |        |        |        |        |     |
| Opcode      | 15 14<br>1 0 | <u>13 12</u><br>0 0 | 11<br>1 | 10<br>0 | 9<br>1 | 8<br>1 | 7<br>0 | 6<br>0 | 5<br>0 | 4<br>0 | 3<br>0 | 2<br>0 | 1<br>0 | 0   |
| Execution   | Increment    | PC                  |         |         |        |        |        |        |        |        |        |        |        |     |
| Status Bits | None         |                     |         |         |        |        |        |        |        |        |        |        |        |     |
| Description | No operation |                     |         |         |        |        |        |        |        |        | •      | e PC   | . The  | NOP |
| Words       | 1            |                     |         |         |        |        |        |        |        |        |        |        |        |     |
| Cycles      |              |                     | Су      | cles f  | or a   | Singl  | le NO  | P Ins  | struc  | tion   |        |        |        |     |
|             | ROM          |                     | DAF     | RAM     |        |        | SAF    | RAM    |        |        | Ext    | ernal  |        |     |
|             | 1            |                     | 1       |         |        |        | 1      |        |        |        | 1+p    | )      |        |     |
|             | с            | ycles fo            | or a Re | epeat   | (RP)   | Γ) Ex  | ecuti  | on o   | f an N |        | nstru  | ictior | ı      |     |
|             | ROM          |                     | DAF     | RAM     |        |        | SAF    | RAM    |        |        | Ext    | ernal  |        |     |
|             | n            |                     | n       |         |        |        | n      |        |        |        | n+p    | )      |        |     |
| Example     | NOP          | ; No                | ope     | rati    | on :   | is p   | perf   | orme   | ed.    |        |        |        |        |     |

| Syntax      | NORM ind                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Indirect addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|
| Operands    | ind: Select one of the following seven options:<br>* *+ *- *0+ *0- *BR0+ *BR0-                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |
| Opcode      | NORM ind           15         14         13         12         11         10         9           1         0         1         0         0         0         0           Note:         ARU, N, and NAR are defined (page 7-12).                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |
| Execution   | Increment PC, then<br>If (ACC) = 0:<br>Then TC $\rightarrow$ 1;<br>Else, if (ACC(31)) XOR (ACC(30)<br>Then TC $\rightarrow$ 0,<br>(ACC) $\times$ 2 $\rightarrow$ ACC<br>Modify (current AR) as s<br>Else TC $\rightarrow$ 1.                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |
| Status Bits | <u>Affects</u><br>TC                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |  |
| Description | accumulator. Normalizing a fixed<br>and an exponent. By finding the<br>exclusive-OR operation is perform<br>mine if bit 30 is part of the magnit<br>the same, they are both sign bits<br>nate the extra sign bit.<br>The current AR is modified as a<br>exponent. It is assumed that the<br>begins. The default modification<br>Multiple executions of the NORM<br>normalize a 32-bit number in the<br>RPT does not cause execution of<br>cally when the normalization is of | es a signed number that is contained in the<br>d-point number separates it into a mantissa<br>magnitude of the sign-extended number. An<br>med on accumulator bits 31 and 30 to deter-<br>tude or part of the sign extension. If they are<br>s, and the accumulator is left shifted to elimi-<br>specified to generate the magnitude of the<br>current AR is initialized before normalization<br>of the current AR is an increment.<br>M instruction may be required to completely<br>e accumulator. Although using NORM with<br>NORM to fall out of the repeat loop automati-<br>complete, no operation is performed for the<br>DRM functions on both positive and negative |  |  |  |  |  |  |  |  |  |  |  |  |
| PRELIMINARY | 2s-complement numbers.                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Assembly Language Instructions 8-125                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |

#### Notes:

NORM

For the NORM instruction, the auxiliary register operations are executed during the fourth phase of the pipeline, the execution phase. For other instructions, the auxiliary register operations take place in the second phase of the pipeline, in the decode phase. Therefore:

- The auxiliary register values should not be modified by the two instruction words following NORM. If the auxiliary register used in the NORM instruction is to be affected by either of the next two instruction words, the auxiliary register value is modified by the other instructions *before* it is modified by the NORM instruction.
- 2) The value in the auxiliary register pointer (ARP) should not be modified by the two instruction words following NORM. If either of the next two instruction words specify a change in the ARP value, the ARP value is changed *before* NORM is executed; the ARP does not point to the correct auxiliary register when NORM is executed.

|           | L                                                         | Coneci                     | auxillary reę                      |                                                           |                         | uleu.     |          |  |  |  |  |  |  |  |
|-----------|-----------------------------------------------------------|----------------------------|------------------------------------|-----------------------------------------------------------|-------------------------|-----------|----------|--|--|--|--|--|--|--|
| Words     | 1                                                         |                            |                                    |                                                           |                         |           |          |  |  |  |  |  |  |  |
| Cycles    |                                                           |                            | Cycles f                           | or a Single NO                                            | RM Instruction          | on        |          |  |  |  |  |  |  |  |
|           | ROM                                                       |                            | DARAM                              | SAI                                                       | RAM                     | External  |          |  |  |  |  |  |  |  |
|           | 1                                                         |                            | 1                                  | 1                                                         |                         | 1+p       |          |  |  |  |  |  |  |  |
|           | Cycles for a Repeat (RPT) Execution of a NORM Instruction |                            |                                    |                                                           |                         |           |          |  |  |  |  |  |  |  |
|           | ROM                                                       |                            | DARAM                              | SAI                                                       | RAM                     | External  |          |  |  |  |  |  |  |  |
|           | n                                                         |                            | n                                  | n                                                         |                         | n+p       |          |  |  |  |  |  |  |  |
| Francis   |                                                           |                            |                                    |                                                           |                         |           |          |  |  |  |  |  |  |  |
| Example 1 | NORM                                                      | *+                         |                                    | ore Instruction                                           |                         | After Ins | truction |  |  |  |  |  |  |  |
|           |                                                           | ARP                        |                                    | 2                                                         | ARP                     |           | 2        |  |  |  |  |  |  |  |
|           |                                                           | AR2                        |                                    | 00h                                                       | AR2                     |           | 01h      |  |  |  |  |  |  |  |
|           |                                                           | ACC                        |                                    | 0FFFFF001h                                                | ACC                     |           | FE002h   |  |  |  |  |  |  |  |
|           |                                                           |                            | X                                  |                                                           |                         | C<br>O    |          |  |  |  |  |  |  |  |
|           |                                                           |                            | тс                                 |                                                           |                         | тс        |          |  |  |  |  |  |  |  |
| Example 2 | 31-Bit N                                                  | Vormaliza                  | ation:                             |                                                           |                         |           |          |  |  |  |  |  |  |  |
|           | LOOP                                                      | MAR<br>LAR<br>NORM<br>BCND | *,AR1<br>AR1,#Oh<br>*+<br>LOOP,NTC | ;Use AR1 to<br>;Clear out a<br>;One bit is<br>;If TC = 0, | exponent c<br>normalize | counter.  | yet.     |  |  |  |  |  |  |  |

Example 3

| 15-Bit No | ormalizatior              | 1:                                                                                                                                                   |
|-----------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| LAR A     | *,AR1<br>AR1,#0Fh<br>\$14 | ;Use AR1 to store the exponent.<br>;Initialize exponent counter.<br>;15-bit normalization specified (yielding                                        |
|           |                           | ;a 4-bit exponent and 16-bit mantissa).                                                                                                              |
| NORM *    | <                         | ;NORM automatically stops shifting when first<br>;significant magnitude bit is found,<br>;performing NOPs for the remainder of the<br>;repeat loops. |

The method used in Example 2 normalizes a 32-bit number and yields a 5-bit exponent magnitude. The method used in Example 3 normalizes a 16-bit number and yields a 4-bit magnitude. If the number requires only a small amount of normalization, the Example 2 method may be preferable to the Example 3 method because the loop in Example 2 runs only until normalization is complete. Example 3 always executes all 15 cycles of the repeat loop. Specifically, Example 2 is more efficient if the number requires three or fewer shifts. If the number requires six or more shifts, Example 3 is more efficient.

| Syntax    | OR dma<br>OR ind [, ARn]<br>OR #lk [, shiff]<br>OR #lk, 16                                                                                                                                                                    |              |             |              |       |          |        |       |        |        | Direct addressing<br>Indirect addressing<br>Long immediate addressing<br>Long immediate with left<br>shift of 16 |                         |         |       |        |       |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------|--------------|-------|----------|--------|-------|--------|--------|------------------------------------------------------------------------------------------------------------------|-------------------------|---------|-------|--------|-------|
| Operands  | dma:7 LSBs of the data-memory addressshift:Left shift value from 0 to 15 (defaults to 0)n:Value from 0 to 7 designating the next auxlk:16-bit long immediate valueind:Select one of the following seven options:**+**0+**BR0+ |              |             |              |       |          |        |       |        |        |                                                                                                                  | uxilia<br>s:            | ary re  | giste | er     |       |
| Opcode    | OR                                                                                                                                                                                                                            | dma          |             |              |       |          |        |       |        |        |                                                                                                                  |                         |         |       |        |       |
|           | 15                                                                                                                                                                                                                            | 14           | 13          | 12           | 11    | 10       | 9      | 8     | 7      | 6      | 5                                                                                                                | 4                       | 3       | 2     | 1      | 0     |
|           | 0                                                                                                                                                                                                                             | 1            | 1           | 0            | 1     | 1        | 0      | 1     | 0      |        |                                                                                                                  |                         | dma     |       |        |       |
|           | OR                                                                                                                                                                                                                            | ind [        | , <b>AR</b> | n]           |       |          |        |       |        |        |                                                                                                                  |                         |         |       |        |       |
|           | 15                                                                                                                                                                                                                            | 14           | 13          | 12           | 11    | 10       | 9      | 8     | 7      | 6      | 5                                                                                                                | 4                       | 3       | 2     | 1      | 0     |
|           | 0                                                                                                                                                                                                                             | 1            | 1           | 0            | 1     | 1        | 0      | 1     | 1      |        | ARU                                                                                                              |                         | Ν       |       | NAR    |       |
|           | Note                                                                                                                                                                                                                          |              | age 7       | -12).        | IAR a | re defir | ned in | subse | ection | 7.3.4, | Indirec                                                                                                          | et Add                  | ressinį | д Орс | ode Fo | ormat |
|           | 15                                                                                                                                                                                                                            | 14           | 13          | - <u>1</u> 2 | 11    | 10       | 9      | 8     | 7      | 6      | 5                                                                                                                | 4                       | 3       | 2     | 1      | 0     |
|           | 1                                                                                                                                                                                                                             | 0            | 1           | 1            | 1     | 1        | 1      | 1     | 1      | 1      | 0                                                                                                                | 0                       |         | sł    | nift   |       |
|           |                                                                                                                                                                                                                               |              |             |              |       |          |        | I     | k      |        |                                                                                                                  |                         |         |       |        |       |
|           | OR                                                                                                                                                                                                                            | <b>#</b>  k[ | , 16]       |              |       |          |        |       |        |        |                                                                                                                  |                         |         |       |        |       |
|           | 15                                                                                                                                                                                                                            | 14           | 13          | 12           | 11    | 10       | 9      | 8     | 7      | 6      | 5                                                                                                                | 4                       | 3       | 2     | 1      | 0     |
|           | 1                                                                                                                                                                                                                             | 0            | 1           | 1            | 1     | 1        | 1      | 0     | 1      | 0      | 0                                                                                                                | 0                       | 0       | 0     | 1      | 0     |
|           |                                                                                                                                                                                                                               |              |             |              |       |          |        |       | k      |        |                                                                                                                  |                         |         |       |        |       |
| Execution | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                          |              |             |              |       |          |        |       |        |        | or ind<br>mme<br>mme                                                                                             | direc<br>diate<br>diate | t       |       |        |       |

| Status Bits | None<br>This instruction is not affected by SXM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   |       |                |                                                                |  |  |  |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------|----------------|----------------------------------------------------------------|--|--|--|--|--|--|
| Description | An OR operation is performed on the contents of the accumulator and the con-<br>tents of the addressed data-memory location or a long-immediate value. The<br>long-immediate value may be shifted before the OR operation. The result<br>remains in the accumulator. All bit positions unoccupied by the data operand<br>are zero filled, regardless of the value of the SXM status bit. Thus, the high<br>word of the accumulator is unaffected by this instruction if direct or indirect<br>addressing is used, or if immediate addressing is used with a shift of 0. Zeros<br>are shifted into the least significant bits of the operand if immediate addressing<br>is used with a nonzero shift count. |                   |       |                |                                                                |  |  |  |  |  |  |
| Words       | <u>Words</u><br>1<br>2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                   |       |                | <u>Addressing mode</u><br>Direct or indirect<br>Long immediate |  |  |  |  |  |  |
| Cualaa      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   |       |                | -                                                              |  |  |  |  |  |  |
| Cycles      | Cycles fo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | or a Single OR li |       |                | ndirect Addressing)                                            |  |  |  |  |  |  |
|             | Operand                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ROM               | DARAM | ogram<br>SARAM | External                                                       |  |  |  |  |  |  |
|             | DARAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1                 | 1     | 1              | 1+p                                                            |  |  |  |  |  |  |
|             | SARAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1                 | 1     | 1, 2†          | 1+p                                                            |  |  |  |  |  |  |
|             | External                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1+d               | 1+d   | 1+d            | 2+d+p                                                          |  |  |  |  |  |  |
|             | <sup>†</sup> If the operand and the code are in the same SARAM block                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   |       |                |                                                                |  |  |  |  |  |  |
|             | Cycles for a Repeat (RPT) Execution of an OR Instruction (Using Direct and Indirect Addressing)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   |       |                |                                                                |  |  |  |  |  |  |

| ternal |
|--------|
| c      |
| c      |
| 1+p+nd |
| p      |

<sup>†</sup> If the operand and the code are in the same SARAM block

| Cycles for a Single OR Instruction | (Using Long Immediate Addressing) |
|------------------------------------|-----------------------------------|
|                                    |                                   |

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| 2   | 2     | 2     | 2+2p     |

# PRELIMINARY

Assembly Language Instructions 8-129

#### **OR** OR With Accumulator

PRELIMINARY



| Syntax      | OUT dma, PA<br>OUT ind, PA [, ARn]                                                                                                                                                                                                                                                 |            |                  |                |                     |             |        |        | Direct addressing<br>Indirect addressing |        |         |        |        |       |        |       |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------------|----------------|---------------------|-------------|--------|--------|------------------------------------------|--------|---------|--------|--------|-------|--------|-------|
| Operands    | dma:7 LSBs of the data-memory addressPA:16-bit I/O addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+**0+**BR0+**BR0+                                                                                             |            |                  |                |                     |             |        |        |                                          | ər     |         |        |        |       |        |       |
| Opcode      | <b>OUT</b> dma, PA                                                                                                                                                                                                                                                                 |            |                  |                |                     |             |        |        |                                          |        |         |        |        |       |        |       |
|             | 15                                                                                                                                                                                                                                                                                 | 14         | 13               | 12             | 11                  | 10          | 9      | 8      | 7                                        | 6      | 5       | 4      | 3      | 2     | 1      | 0     |
|             | 0                                                                                                                                                                                                                                                                                  | 0          | 0                | 0              | 1                   | 1           | 0      | 0      | 0                                        |        |         |        | dma    |       |        |       |
|             |                                                                                                                                                                                                                                                                                    |            |                  |                |                     |             |        | F      | PA                                       |        |         |        |        |       |        |       |
|             | OU                                                                                                                                                                                                                                                                                 | T inc      | I, PA            | [, <b>AF</b>   | <b>{</b> <i>n</i> ] |             |        |        |                                          |        |         |        |        |       |        |       |
|             | 15                                                                                                                                                                                                                                                                                 | 14         | 13               | 12             | 11                  | 10          | 9      | 8      | 7                                        | 6      | 5       | 4      | 3      | 2     | 1      | 0     |
|             | 0                                                                                                                                                                                                                                                                                  | 0          | 0                | 0              | 1                   | 1           | 0      | 0      | 1                                        |        | ARU     |        | Ν      |       | NAR    |       |
|             | Note                                                                                                                                                                                                                                                                               |            | RU, N<br>bage 7  |                | NARa                | re defi     | ned ir |        | PA<br>ection 7                           | 7.3.4, | Indirec | ct Add | ressin | д Орс | ode Fc | ormat |
| Execution   | Increr<br>PA →<br>(data-<br>(data-                                                                                                                                                                                                                                                 | add<br>men | ress l<br>nory a | bus A<br>addre | 415—<br>ess) -      | ightarrowda |        | us D1  | 5-D(                                     | 0      |         |        |        |       |        |       |
| Status Bits | None                                                                                                                                                                                                                                                                               |            |                  |                |                     |             |        |        |                                          |        |         |        |        |       |        |       |
| Description | The OUT instruction writes a 16-bit value from a data-memory location to the specified I/O location. The $\overline{IS}$ line goes low to indicate an I/O access. The $\overline{STRB}$ , R/ $\overline{W}$ , and READY timings are the same as for an external data-memory write. |            |                  |                |                     |             |        |        |                                          |        |         |        |        |       |        |       |
|             | RPT data r                                                                                                                                                                                                                                                                         |            |                  |                |                     |             | JT ir  | nstruc | ction                                    | to w   | rite co | onse   | cutiv  | e wo  | rds fi | rom   |
| Words       | 2                                                                                                                                                                                                                                                                                  |            |                  |                |                     |             |        |        |                                          |        |         |        |        |       |        |       |

### **OUT** Output Data to Port

#### Cycles

| Cycles for a Single OUT Instruction   |                                                   |                                                              |                                                                                                                                           |  |  |  |  |  |  |  |  |
|---------------------------------------|---------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Program                               |                                                   |                                                              |                                                                                                                                           |  |  |  |  |  |  |  |  |
| ROM                                   | DARAM                                             | SARAM                                                        | External                                                                                                                                  |  |  |  |  |  |  |  |  |
| 3+io <sub>dst</sub>                   | 3+io <sub>dst</sub>                               | 3+io <sub>dst</sub>                                          | 5+io <sub>dst</sub> +2p <sub>code</sub>                                                                                                   |  |  |  |  |  |  |  |  |
| 3+io <sub>dst</sub>                   | 3+io <sub>dst</sub>                               | 3+io <sub>dst</sub><br>4+io <sub>dst</sub> †                 | 5+io <sub>dst</sub> +2p <sub>code</sub>                                                                                                   |  |  |  |  |  |  |  |  |
| 3+d <sub>src</sub> +io <sub>dst</sub> | 3+d <sub>src</sub> +io <sub>dst</sub>             | 3+d <sub>src</sub> +io <sub>dst</sub>                        | 6+d <sub>src</sub> +io <sub>dst</sub> +2p <sub>code</sub>                                                                                 |  |  |  |  |  |  |  |  |
|                                       | ROM<br>3+io <sub>dst</sub><br>3+io <sub>dst</sub> | ROMDARAM $3+io_{dst}$ $3+io_{dst}$ $3+io_{dst}$ $3+io_{dst}$ | ROMDARAMSARAM $3+io_{dst}$ $3+io_{dst}$ $3+io_{dst}$ $3+io_{dst}$ $3+io_{dst}$ $3+io_{dst}$ $4+io_{dst}^{\dagger}$ $4+io_{dst}^{\dagger}$ |  |  |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

#### Cycles for a Repeat (RPT) Execution of an OUT Instruction

|                       | Program                                        |                                            |                                                    |                                                                    |  |  |  |  |  |  |
|-----------------------|------------------------------------------------|--------------------------------------------|----------------------------------------------------|--------------------------------------------------------------------|--|--|--|--|--|--|
| Operand               | ROM                                            | DARAM                                      | SARAM                                              | External                                                           |  |  |  |  |  |  |
| Destination: DARAM    | 3n+nio <sub>dst</sub>                          | 3n+nio <sub>dst</sub>                      | 3n+nio <sub>dst</sub>                              | 3n+3+nio <sub>dst</sub> +2p <sub>code</sub>                        |  |  |  |  |  |  |
| Destination: SARAM    | 3n+nio <sub>dst</sub>                          | 3n+nio <sub>dst</sub>                      | 3n+nio <sub>dst</sub><br>3n+1+nio <sub>dst</sub> † | 3n+3+nio <sub>dst</sub> +2p <sub>code</sub>                        |  |  |  |  |  |  |
| Destination: External | 5n–2+nd <sub>src</sub> +<br>nio <sub>dst</sub> | 5n–2+nd <sub>src</sub> +nio <sub>dst</sub> | 5n–2+nd <sub>src</sub> +nio <sub>dst</sub>         | 5n+1+nd <sub>src</sub> +nio <sub>dst</sub> +<br>2p <sub>code</sub> |  |  |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Example 1 | OUT | DAT0,100h | ;(DP = 4) Write data word stored in<br>;data memory location 200h to<br>;peripheral at I/O port address<br>;100h. |
|-----------|-----|-----------|-------------------------------------------------------------------------------------------------------------------|
| Example 2 | OUT | *,100h    | ;Write data word referenced by<br>;current auxiliary register to<br>;peripheral at I/O port address<br>;100h.     |

| Syntax      | PAC                                 |         |                |                |                |                |        |        |        |        |        |        |        |         |        |        |
|-------------|-------------------------------------|---------|----------------|----------------|----------------|----------------|--------|--------|--------|--------|--------|--------|--------|---------|--------|--------|
| Operands    | None                                |         |                |                |                |                |        |        |        |        |        |        |        |         |        |        |
| Opcode      | 15<br>1                             | 14<br>0 | <u>13</u><br>1 | <u>12</u><br>1 | <u>11</u><br>1 | <u>10</u><br>1 | 9<br>1 | 8<br>0 | 7<br>0 | 6<br>0 | 5<br>0 | 4<br>0 | 3<br>0 | 2<br>0  | 1<br>1 | 0<br>1 |
| Execution   | Incren<br>shifted                   |         |                |                |                |                |        |        |        |        |        |        |        |         |        |        |
| Status Bits | <u>Affect</u><br>PM                 | ed b    | Ľ              |                |                |                |        |        |        |        |        |        |        |         |        |        |
| Description | The co<br>the ac                    |         |                |                | G, sh          | ifted          | as sp  | pecifi | ed by  | y the  | PM క   | status | s bits | , is lo | adeo   | d into |
| Words       | 1                                   |         |                |                |                |                |        |        |        |        |        |        |        |         |        |        |
| Cycles      | Cycles for a Single PAC Instruction |         |                |                |                |                |        |        |        |        |        |        |        |         |        |        |
|             | ROM                                 |         |                |                | DAR            | AM             |        |        | SAR    | АМ     |        |        | Exte   | ernal   |        |        |
|             | 1                                   |         |                |                | 1              |                |        |        | 1      |        |        |        | 1+p    |         |        |        |

| Cycles for a Repeat (RPT) Execution of a PAC Instruction |       |       |          |  |  |  |  |  |  |
|----------------------------------------------------------|-------|-------|----------|--|--|--|--|--|--|
| ROM                                                      | DARAM | SARAM | External |  |  |  |  |  |  |
| n                                                        | n     | n     | n+p      |  |  |  |  |  |  |

| Example | PAC | ;(PM = 0: no shift of product) |   |                           |      |   |                   |  |  |  |  |
|---------|-----|--------------------------------|---|---------------------------|------|---|-------------------|--|--|--|--|
|         |     |                                |   | <b>Before Instruction</b> |      |   | After Instruction |  |  |  |  |
|         |     | PREG                           |   | 144h                      | PREG |   | 144h              |  |  |  |  |
|         |     | ACC                            | X | 23h                       | ACC  | X | 144h              |  |  |  |  |
|         |     |                                | С |                           |      | С |                   |  |  |  |  |
|         |     |                                |   |                           |      |   |                   |  |  |  |  |

| Syntax      | POP                                                                                                          |                                                                           |                                                             |                                               |                                                  |                                                     |                                                |                                    |                                    |                                  |                                   |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------|--------------------------------------------------|-----------------------------------------------------|------------------------------------------------|------------------------------------|------------------------------------|----------------------------------|-----------------------------------|--|--|
| Operands    | None                                                                                                         |                                                                           |                                                             |                                               |                                                  |                                                     |                                                |                                    |                                    |                                  |                                   |  |  |
| Opcode      | 15 14 13<br>1 0 1                                                                                            |                                                                           | <u>10 9</u><br>1 1                                          | 8<br>0                                        | 7<br>0                                           | 65<br>01                                            | 4<br>1                                         | 3<br>0                             | 2<br>0                             | 1<br>1                           | 0<br>0                            |  |  |
| Execution   | Increment P<br>(TOS) $\rightarrow$ AC<br>0 $\rightarrow$ ACC(31<br>Pop stack of                              | C(15:0)<br>:16)                                                           |                                                             |                                               |                                                  |                                                     |                                                |                                    |                                    |                                  |                                   |  |  |
| Status Bits | None                                                                                                         |                                                                           |                                                             |                                               |                                                  |                                                     |                                                |                                    |                                    |                                  |                                   |  |  |
| Description | The content<br>then the stac<br>is set to all 0                                                              | ck values m                                                               |                                                             | •                                             | ,                                                | •                                                   |                                                |                                    |                                    |                                  |                                   |  |  |
|             | The hardwar<br>Any time a p<br>location, and<br>two stack we<br>if more than<br>tions) occur<br>value. No pr | oop occurs,<br>I the top val<br>ords have th<br>seven stack<br>before any | every sta<br>ue is rem<br>ne same<br>< pops (us<br>pushes o | ack va<br>oved<br>value<br>sing th<br>ccur, a | alue is<br>from t<br>. Beca<br>ne PO<br>all leve | copied<br>he stac<br>ause ea<br>P, POP<br>els of th | d to th<br>k. Aft<br>ich st<br>D, RE<br>ie sta | ne ne<br>er a p<br>ack v<br>ETC, ( | xt hię<br>pop, t<br>value<br>or RE | gher<br>he bo<br>is co<br>ET ins | stack<br>ottom<br>pied,<br>struc- |  |  |
| Words       | 1                                                                                                            |                                                                           |                                                             |                                               |                                                  |                                                     |                                                |                                    |                                    |                                  |                                   |  |  |
| Cycles      |                                                                                                              | Cy                                                                        | cles for a                                                  | Singl                                         | e POP                                            | Instruc                                             | tion                                           |                                    |                                    |                                  |                                   |  |  |
|             | ROM                                                                                                          | DAF                                                                       | RAM                                                         |                                               | SAR                                              | ۹M                                                  |                                                | Ext                                | ernal                              |                                  |                                   |  |  |
|             | 1                                                                                                            | 1                                                                         |                                                             |                                               | 1                                                |                                                     |                                                | 1+p                                | )                                  |                                  |                                   |  |  |
|             | Cycles for a Repeat (RPT) Execution of a POP Instruction                                                     |                                                                           |                                                             |                                               |                                                  |                                                     |                                                |                                    |                                    |                                  |                                   |  |  |
|             | ROM                                                                                                          | DAF                                                                       | RAM                                                         |                                               | SAR                                              | AM                                                  |                                                | Ext                                | ernal                              |                                  |                                   |  |  |

n

n

n

n+p

| Example | POP |       |   |                    |       |   |                   |
|---------|-----|-------|---|--------------------|-------|---|-------------------|
|         |     |       |   | Before Instruction |       |   | After Instruction |
|         |     | ACC   | X | 82h                | ACC   | X | 45h               |
|         |     |       | С |                    |       | С |                   |
|         |     | Stack |   | 45h                | Stack |   | 16h               |
|         |     |       |   | 16h                |       |   | 7h                |
|         |     |       |   | 7h                 |       |   | 33h               |
|         |     |       |   | 33h                |       |   | 42h               |
|         |     |       |   | 42h                |       |   | 56h               |
|         |     |       |   | 56h                |       |   | 37h               |
|         |     |       |   | 37h                |       |   | 61h               |
|         |     |       |   | 61h                |       |   | 61h               |

| Syntax                                  | <b>POPD</b> dmaDirect addressing <b>POPD</b> ind [, <b>AR</b> n]Indirect addressing                                                                                                                                                          |                       |                  |                  |              |               |               |               |                  |                |                |                |              |             |
|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------|------------------|--------------|---------------|---------------|---------------|------------------|----------------|----------------|----------------|--------------|-------------|
| Operands                                | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+*+*0+*BR0+*BR0-                                                                             |                       |                  |                  |              |               |               |               |                  |                |                |                |              |             |
| Opcode                                  | <b>POPD</b> d                                                                                                                                                                                                                                | ma                    |                  |                  |              |               |               |               |                  |                |                |                |              |             |
|                                         | 15 14                                                                                                                                                                                                                                        | 13 12                 | 11               | 10               | 9            | 8             | 7             | 6             | 5                | 4              | 3              | 2              | 1            | 0           |
|                                         | 1 0                                                                                                                                                                                                                                          | 1 0 0 0 1 0 1 0 0 dma |                  |                  |              |               |               |               |                  |                |                |                |              |             |
|                                         | POPD in                                                                                                                                                                                                                                      | nd [, <b>AR</b> n]    |                  |                  |              |               |               |               |                  |                |                |                |              |             |
|                                         | 15 14                                                                                                                                                                                                                                        | 13 12                 | 11               | 10               | 9            | 8             | 7             | 6             | 5                | 4              | 3              | 2              | 1            | 0           |
|                                         | 1 0                                                                                                                                                                                                                                          | 0 0                   | 1                | 0                | 1            | 0             | 1             |               | ARU              |                | Ν              |                | NAR          |             |
| Execution<br>Status Bits<br>Description | <ul> <li>Note: ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).</li> <li>Increment PC, then</li> <li>(TOS) → data-memory address</li> <li>Pop stack one level</li> <li>None</li> </ul> |                       |                  |                  |              |               |               |               |                  |                |                |                |              |             |
|                                         | The value f<br>specified b<br>values are<br>tion for the                                                                                                                                                                                     | by the ins            | structi<br>o one | ion. I<br>level. | n the<br>The | e low<br>stac | verse<br>kope | even<br>ratio | locat<br>n is ex | tions<br>xplai | of th<br>ned i | ne si<br>n the | ack,<br>desc | the<br>rip- |
| Words                                   | 1                                                                                                                                                                                                                                            |                       |                  |                  |              |               |               |               |                  |                |                |                |              |             |
| Cycles                                  |                                                                                                                                                                                                                                              |                       | Cycle            | es for           | a Si         | ngle          | ΡΟΡΙ          | ) Inst        | tructio          | on             |                |                |              |             |
|                                         |                                                                                                                                                                                                                                              |                       |                  |                  |              |               | Prog          |               |                  |                |                |                |              |             |
|                                         | Operand                                                                                                                                                                                                                                      | ROM                   |                  | C                | DARA         | M             |               | SAF           | RAM              |                | Ex             | tern           | al           |             |
|                                         | DARAM                                                                                                                                                                                                                                        | 1                     |                  | 1                |              |               |               | 1             |                  |                | 1+             | р              |              |             |
|                                         | SARAM                                                                                                                                                                                                                                        | 1                     |                  | 1                |              |               |               | 1, 2          | t                |                | 1+             | р              |              |             |
|                                         | External                                                                                                                                                                                                                                     | 2+d                   |                  | 2                | l+d          |               |               | 2+d           |                  |                | 4+             | d+p            |              |             |
|                                         | <sup>†</sup> If the operand and the code are in the same SARAM block                                                                                                                                                                         |                       |                  |                  |              |               |               |               |                  |                |                |                |              |             |

| C        | Cycles for a Repeat (RPT) Execution of a POPD Instruction |       |         |           |  |  |  |  |  |  |  |
|----------|-----------------------------------------------------------|-------|---------|-----------|--|--|--|--|--|--|--|
|          | Program                                                   |       |         |           |  |  |  |  |  |  |  |
| Operand  | ROM                                                       | DARAM | SARAM   | External  |  |  |  |  |  |  |  |
| DARAM    | n                                                         | n     | n       | n+p       |  |  |  |  |  |  |  |
| SARAM    | n                                                         | n     | n, n+2† | n+p       |  |  |  |  |  |  |  |
| External | 2n+nd                                                     | 2n+nd | 2n+nd   | 2n+2+nd+p |  |  |  |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Example 1 | POPD | DAT10             | ;(DP = 8)                 |                     |                   |
|-----------|------|-------------------|---------------------------|---------------------|-------------------|
|           |      |                   | <b>Before Instruction</b> |                     | After Instruction |
|           | Da   | ta Memory<br>40Ah | 55h                       | Data Memory<br>40Ah | 92h               |
|           |      | Stack             | 92h                       | Stack               | 72h               |
|           |      |                   | 72h                       |                     | 8h                |
|           |      |                   | 8h                        |                     | 44h               |
|           |      |                   | 44h                       |                     | 81h               |
|           |      |                   | 81h                       |                     | 75h               |
|           |      |                   | 75h                       |                     | 32h               |
|           |      |                   | 32h                       |                     | 0AAh              |
|           |      |                   | 0AAh                      |                     | 0AAh              |

Example 2 POPD \*+, AR1

|                     | <b>Before Instruction</b> |                     | After Instruction |
|---------------------|---------------------------|---------------------|-------------------|
| ARP                 | 0                         | ARP                 | 1                 |
| AR0                 | 300h                      | AR0                 | 301h              |
| Data Memory<br>300h | 55h                       | Data Memory<br>300h | 92h               |
| Stack               | 92h                       | Stack               | 72h               |
|                     | 72h                       |                     | 8h                |
|                     | 8h                        |                     | 44h               |
|                     | 44h                       |                     | 81h               |
|                     | 81h                       |                     | 75h               |
|                     | 75h                       |                     | 32h               |
|                     | 32h                       |                     | 0AAh              |
|                     | 0AAh                      |                     | 0AAh              |

Assembly Language Instructions 8-137

| Syntax                   | PSHD dma<br>PSHD ind                                 |                                |                |                  |                 |                |                 |               | Direct<br>ndire |              |                | -              |        |      |
|--------------------------|------------------------------------------------------|--------------------------------|----------------|------------------|-----------------|----------------|-----------------|---------------|-----------------|--------------|----------------|----------------|--------|------|
| Operands                 | dma:<br>n:<br>ind:                                   | 7 LSE<br>Value<br>Selec<br>* * | from<br>t one  | 0 to<br>of the   | 7 des           | signa          | ting t<br>g sev | the ne        | ext a<br>ption  |              | ary re         | giste          | er     |      |
| Opcode                   | PSHD d                                               | ma                             |                |                  |                 |                |                 |               |                 |              |                |                |        |      |
| -                        | 15 14                                                | 13 12                          | 11             | 10               | 9               | 8              | 7               | 6             | 5               | 4            | 3              | 2              | 1      | 0    |
|                          | 0 1                                                  | 1 1                            | 0              | 1                | 1               | 0              | 0               |               |                 |              | dma            |                |        |      |
|                          | PSHD ir                                              | nd [, <b>AR</b> r              | 1              |                  |                 |                |                 |               |                 |              |                |                |        |      |
|                          | 15 14                                                | 13 12                          | -              | 10               | 9               | 8              | 7               | 6             | 5               | 4            | 3              | 2              | 1      | 0    |
|                          | 0 1                                                  | 1 1                            | 0              | 1                | 1               | 0              | 1               |               | ARU             |              | Ν              |                | NAR    |      |
| Execution<br>Status Bits |                                                      | nory add                       | 1<br>'ess) -   | $\rightarrow$ TC | os              |                |                 | 7.3.4,7       | narec           | I Addi       | essing         | ς Ορc          | oue ro | nnat |
| Description              | The value<br>ferred to th<br>values are<br>PUSH inst | ne top of<br>also cop          | the s<br>ied o | stack.<br>ne lev | In th<br>rel do | ne lov<br>own, | wer's<br>as ex  | even<br>plain | loca<br>led in  | tions<br>the | s of t<br>desc | he s<br>riptic | tack,  | the  |
| Words                    | 1                                                    |                                |                |                  |                 |                |                 |               |                 |              |                |                |        |      |
| Cycles                   |                                                      |                                | Cycl           | es for           | ' a Si          | ngle           | PSHE            | ) Inst        | ructio          | on           |                |                |        |      |
|                          |                                                      |                                |                |                  |                 |                | Prog            | gram          |                 |              |                |                |        |      |
|                          | Operand                                              | ROM                            |                | 0                | DARA            | M              |                 | SAR           | AM              |              | Ex             | tern           | al     |      |
|                          | DARAM                                                | 1                              |                | 1                |                 |                |                 | 1             |                 |              | 1+             | р              |        |      |
|                          | SARAM                                                | 1                              |                | 1                |                 |                |                 | 1, 2†         | t               |              | 1+             | р              |        |      |
|                          | External                                             | 1+d                            |                | 1                | +d              |                |                 | 1+d           |                 |              | 2+             | d+p            |        |      |
|                          | † If the oper                                        | and and th                     | e code         | are in           | the sa          | ame S          | ARAN            | l block       |                 |              |                |                |        | -    |

| C        | Cycles for a Repeat (RPT) Execution of a PSHD Instruction |       |         |          |  |  |  |  |  |  |  |
|----------|-----------------------------------------------------------|-------|---------|----------|--|--|--|--|--|--|--|
|          | Program                                                   |       |         |          |  |  |  |  |  |  |  |
| Operand  | ROM                                                       | DARAM | SARAM   | External |  |  |  |  |  |  |  |
| DARAM    | n                                                         | n     | n       | n+p      |  |  |  |  |  |  |  |
| SARAM    | n                                                         | n     | n, n+1† | n+p      |  |  |  |  |  |  |  |
| External | n+nd                                                      | n+nd  | n+nd    | n+1+nd+p |  |  |  |  |  |  |  |

2h

33h

78h

99h

42h

50h

0h

0h

Stack

<sup>†</sup> If the operand and the code are in the same SARAM block

| Example 1 | PSHD | 127                 | ;(DP = 3:          | addresses 018       | 0-01FFh)          |
|-----------|------|---------------------|--------------------|---------------------|-------------------|
|           |      |                     | Before Instruction |                     | After Instruction |
|           |      | Data Memory         |                    | Data Memory         |                   |
|           |      | 1FFh                | 65h                | 1FFh                | 65h               |
|           |      | Stack               | 2h                 | Stack               | 65h               |
|           |      |                     | 33h                |                     | 2h                |
|           |      |                     | 78h                |                     | 33h               |
|           |      |                     | 99h                |                     | 78h               |
|           |      |                     | 42h                |                     | 99h               |
|           |      |                     | 50h                |                     | 42h               |
|           |      |                     | 0h                 |                     | 50h               |
|           |      |                     | 0h                 |                     | 0h                |
| Example 2 | PSHD | *,AR1               |                    |                     |                   |
|           | FOID | , ANI               | Defens la standina |                     | A (1 )            |
|           |      |                     | Before Instruction |                     | After Instruction |
|           |      | ARP                 | 0                  | ARP                 | 1                 |
|           |      | AR0                 | 1FFh               | AR0                 | 1FFh              |
|           |      | Data Memory<br>1FFh | 12h                | Data Memory<br>1FFh | 12h               |

Stack

Assembly Language Instructions 8-139

12h

2h

33h

78h

99h

42h

50h

0h

| Syntax      | PUSH                                       |                       |                     |                  |                |         |                                                       |              |        |       |                     |                 |        |                            |
|-------------|--------------------------------------------|-----------------------|---------------------|------------------|----------------|---------|-------------------------------------------------------|--------------|--------|-------|---------------------|-----------------|--------|----------------------------|
| Operands    | None                                       |                       |                     |                  |                |         |                                                       |              |        |       |                     |                 |        |                            |
| Opcode      | 15 14<br>1 0                               |                       | <u>12 11</u><br>1 1 | 10<br>1          | 9<br>1         | 8<br>0  | 7<br>0                                                | 6<br>0       | 5<br>1 | 4     | <u>3</u><br>1       | 2<br>1          | 1<br>0 | 0<br>0                     |
| Execution   | Increme<br>Push all<br>ACC(15              | l stack lo            | cation              | s dow            | n one          | e lev   | el                                                    |              |        |       |                     |                 |        |                            |
| Status Bits | None                                       |                       |                     |                  |                |         |                                                       |              |        |       |                     |                 |        |                            |
| Description | The stac<br>the accu                       |                       |                     |                  |                |         |                                                       |              |        |       |                     |                 | wer ł  | nalf of                    |
|             | The har<br>If more<br>INTR, o<br>lost with | than eig<br>r NMI in: | ht push<br>structio | nes (d<br>n) oco | ue to<br>cur b | aC      | ALA,                                                  | CAL          | L, C   | C, P  | SHD                 | , PUS           | SH, 1  | RAP,                       |
| Words       | 1                                          |                       |                     |                  |                |         |                                                       |              |        |       |                     |                 |        |                            |
| Cycles      |                                            |                       | Су                  | cles f           | or a S         | Single  | e PUS                                                 | SH In        | struc  | tion  |                     |                 |        |                            |
|             | ROM                                        |                       | DA                  | RAM              |                |         | SA                                                    | RAM          |        |       | Ext                 | ernal           |        |                            |
|             | 1                                          |                       | 1                   |                  |                |         | 1                                                     |              |        |       | 1+p                 | )               |        |                            |
|             |                                            |                       | -                   |                  |                |         | •                                                     |              |        |       | 116                 |                 |        |                            |
|             | ROM                                        | Cycles                | for a F             |                  | : (RP1         | T) Ex   | ecuti                                                 |              | a PU   | ISH I | nstru               | ictior          |        |                            |
|             | ROM                                        | Cycles                | for a F<br>DA       | lepeat<br>RAM    | (RP1           | T) Ex   | ecuti<br>SAI                                          | on of<br>RAM | a PU   | ISH I | nstru<br>Ext        | ictior<br>ernal |        |                            |
|             | <b>ROM</b><br>n                            | Cycles                | for a F             |                  | ( <b>RP</b> 1  | T) Ex   | ecuti                                                 |              | a PU   | ISH I | nstru               | ictior<br>ernal |        |                            |
| Example     |                                            | Cycles                | for a F<br>DA       | RAM              |                |         | ecuti<br>SAI<br>n                                     |              | a PU   | ISH I | nstru<br>Ext<br>n+p | ernal           |        |                            |
| Example     | n                                          | Cycles                | for a F<br>DA<br>n  | RAM              |                | tructi  | ecuti<br>SAI<br>n                                     |              | a PU   | []    | nstru<br>Ext<br>n+p | ernal           |        | ction<br>7h                |
| Example     | n                                          | ACC                   | for a F<br>DA       | RAM              |                | tructi  | ecuti<br>SAI<br>n                                     | RAM          | ACC    | []    | nstru<br>Ext<br>n+p | ernal           |        | 7h                         |
| Example     | n                                          |                       | for a F<br>DA<br>n  | RAM              |                | tructi  | ecuti<br>SAI<br>n                                     | RAM          |        | []    | nstru<br>Ext<br>n+p | ernal           |        |                            |
| Example     | n                                          | ACC                   | for a F<br>DA<br>n  | RAM              |                | tructi  | ecuti<br>SAI<br>n<br>on<br>7h<br>2h<br>5h<br>3h       | RAM          | ACC    | []    | nstru<br>Ext<br>n+p | ernal           |        | 7h<br>7h<br>2h<br>5h       |
| Example     | n                                          | ACC                   | for a F<br>DA<br>n  | RAM              |                | tructi  | ecuti<br>SAI<br>n<br>on<br>7h<br>2h<br>5h<br>3h<br>0h | RAM          | ACC    | []    | nstru<br>Ext<br>n+p | ernal           |        | 7h<br>7h<br>2h<br>5h<br>3h |
| Example     | n                                          | ACC                   | for a F<br>DA<br>n  | RAM              |                | structi | ecuti<br>SAI<br>n<br>on<br>7h<br>2h<br>5h<br>3h       | RAM          | ACC    | []    | nstru<br>Ext<br>n+p | ernal           |        | 7h<br>7h<br>2h<br>5h       |
| Example     | n                                          | ACC                   | for a F<br>DA<br>n  | RAM              |                | tructi  | ecuti<br>SAI<br>n<br>2h<br>2h<br>5h<br>3h<br>0h<br>2h | RAM          | ACC    | []    | nstru<br>Ext<br>n+p | ernal           |        | 7h<br>7h<br>2h<br>5h<br>3h |

| Syntax      | RET                                    |                       |                      |                       |                              |                 |                                                       |                                                                                       |        |        |        |                    |               |                    |                                                                 |
|-------------|----------------------------------------|-----------------------|----------------------|-----------------------|------------------------------|-----------------|-------------------------------------------------------|---------------------------------------------------------------------------------------|--------|--------|--------|--------------------|---------------|--------------------|-----------------------------------------------------------------|
| Operands    | None                                   |                       |                      |                       |                              |                 |                                                       |                                                                                       |        |        |        |                    |               |                    |                                                                 |
| Opcode      | 15<br>1                                | <u>14 1</u><br>1 1    |                      | 11<br>1               | 10<br>1                      | 9<br>1          | 8<br>1                                                | 7<br>0                                                                                | 6<br>0 | 5<br>0 | 4<br>0 | 3<br>0             | 2<br>0        | 1<br>0             | 0                                                               |
| Execution   | (TOS)<br>Pop st                        |                       |                      | əl.                   |                              |                 |                                                       |                                                                                       |        |        |        |                    |               |                    |                                                                 |
| Status Bits | None                                   |                       |                      |                       |                              |                 |                                                       |                                                                                       |        |        |        |                    |               |                    |                                                                 |
| Description | The co<br>remain<br>tines a<br>interru | ning st<br>and int    | ack va<br>errupt     | lues<br>servi         | are th<br>ice ro             | nen o<br>utine  | opie                                                  | d up                                                                                  | one    | level  | . RÉ   | T cor              | lud           | es su              | brou-                                                           |
| Words       | 1                                      |                       |                      |                       |                              |                 |                                                       |                                                                                       |        |        |        |                    |               |                    |                                                                 |
| Cycles      |                                        |                       |                      | Су                    | cles                         | for a           | Sing                                                  | le RE                                                                                 | T Ins  | struc  | tion   |                    |               |                    |                                                                 |
|             |                                        |                       |                      |                       |                              |                 |                                                       |                                                                                       |        |        |        |                    |               |                    |                                                                 |
|             | ROM                                    |                       |                      | DAI                   | RAM                          |                 |                                                       | SAI                                                                                   | RAM    |        |        | Ext                | erna          |                    |                                                                 |
|             | <b>ROM</b><br>4                        |                       |                      | <b>DA</b>             | RAM                          |                 |                                                       | <b>SAI</b><br>4                                                                       | RAM    |        |        | <b>Ex</b> t<br>4+3 | -             | I                  |                                                                 |
|             |                                        | tion v                | this ins<br>ords ha  | 4<br>tructio<br>ve en | n reac<br>tered t            | he pip          | beline.                                               | 4<br>cute pl                                                                          | nasec  |        |        | 4+3<br>e, two      | 3p<br>additi  | onalin             |                                                                 |
| Example     | 4                                      | tion v                | ords ha              | 4<br>tructio<br>ve en | n reac<br>tered t            | he pip          | beline.                                               | 4<br>cute pl                                                                          | nasec  |        |        | 4+3<br>e, two      | 3p<br>additi  | onalin             |                                                                 |
| Example     | 4<br>Note:                             | tion v                | ords ha              | 4<br>tructio<br>ve en | n reac<br>tered t<br>re disc | he pip<br>arded | beline.                                               | 4<br>cute pl<br>When                                                                  | nasec  |        |        | 4+3<br>e, two      | 3p<br>additio | onalin             | e two                                                           |
| Example     | 4<br>Note:                             | tion v<br>instru      | ords ha              | 4<br>tructio<br>ve en | n reac<br>tered t<br>re disc | he pip<br>arded | eline.                                                | 4<br>cute pl<br>When                                                                  | nasec  |        |        | 4+3<br>e, two      | 3p<br>additio | onal in<br>n, thes | e two                                                           |
| Example     | 4<br>Note:                             | tion v<br>instru<br>F | ords ha              | 4<br>tructio<br>ve en | n reac<br>tered t<br>re disc | he pip<br>arded | eline.                                                | 4<br>cute pl<br>When<br>on<br>96h                                                     | nasec  | PC dis | contir | 4+3<br>e, two      | 3p<br>additio | onal in<br>n, thes | ction<br>37h<br>45h                                             |
| Example     | 4<br>Note:                             | tion v<br>instru<br>F | vords ha<br>ction wo | 4<br>tructio<br>ve en | n reac<br>tered t<br>re disc | he pip<br>arded | eline.                                                | 4<br>cute pl<br>When<br>on<br>06h<br>87h                                              | nasec  | PC dis | contir | 4+3<br>e, two      | 3p<br>additio | onal in<br>n, thes | e two<br>ction<br>37h<br>45h<br>75h                             |
| Example     | 4<br>Note:                             | tion v<br>instru<br>F | vords ha<br>ction wo | 4<br>tructio<br>ve en | n reac<br>tered t<br>re disc | he pip<br>arded | eline.                                                | 4<br>cute pl<br>When<br>on<br><u>66h</u><br>57h<br>55h                                | nasec  | PC dis | contir | 4+3<br>e, two      | 3p<br>additio | onal in<br>n, thes | e two<br>ction<br>37h<br>45h<br>75h<br>21h                      |
| Example     | 4<br>Note:                             | tion v<br>instru<br>F | vords ha<br>ction wo | 4<br>tructio<br>ve en | n reac<br>tered t<br>re disc | he pip<br>arded | eline.                                                | 4<br>Cute pl<br>When<br>06h<br>06h<br>07h<br>15h<br>21h                               | nasec  | PC dis | contir | 4+3<br>e, two      | 3p<br>additio | onal in<br>n, thes | ction<br>37h<br>45h<br>75h<br>3Fh                               |
| Example     | 4<br>Note:                             | tion v<br>instru<br>F | vords ha<br>ction wo | 4<br>tructio<br>ve en | n reac<br>tered t<br>re disc | he pip<br>arded | structi                                               | 4<br>Cute pl<br>When<br>on<br>66h<br>67h<br>55h<br>21h<br>Fh                          | nasec  | PC dis | contir | 4+3<br>e, two      | 3p<br>additio | onal in<br>n, thes | etwo<br>ction<br>37h<br>45h<br>21h<br>3Fh<br>45h                |
| Example     | 4<br>Note:                             | tion v<br>instru<br>F | vords ha<br>ction wo | 4<br>tructio<br>ve en | n reac<br>tered t<br>re disc | he pip<br>arded | structi                                               | 4<br>Cute pl<br>When<br>06h<br>06h<br>07h<br>15h<br>21h                               | nasec  | PC dis | contir | 4+3<br>e, two      | 3p<br>additio | onal in<br>n, thes | ction<br>37h<br>45h<br>75h<br>3Fh                               |
| Example     | 4<br>Note:                             | tion v<br>instru<br>F | vords ha<br>ction wo | 4<br>tructio<br>ve en | n reac<br>tered t<br>re disc | he pip<br>arded | structi<br>structi<br>3<br>4<br>7<br>2<br>3<br>4<br>6 | 4<br>Sute pl<br>When<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | nasec  | PC dis | contir | 4+3<br>e, two      | 3p<br>additio | onal in<br>n, thes | e two<br>ction<br>37h<br>45h<br>75h<br>21h<br>3Fh<br>45h<br>6Eh |

| Syntax      | RETC co                                              | ond 1 [, co                                        | ond 2] [,]                                 |                                 |                    |                                 |                   |                                                                   |                  |  |
|-------------|------------------------------------------------------|----------------------------------------------------|--------------------------------------------|---------------------------------|--------------------|---------------------------------|-------------------|-------------------------------------------------------------------|------------------|--|
| Operands    | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |                                                    |                                            |                                 |                    |                                 |                   |                                                                   |                  |  |
| Opcode      | 15 14<br>1 1<br>Note: Th                             | <u>13 12</u><br>1 0                                | <u>11 10</u><br><u>1 1</u><br>LVC fields a | 9 8<br>TP                       | 7                  | 6 5<br>ZLVC                     | 4<br>8-4          | 3 2 1<br>ZLVC                                                     | 0                |  |
| Execution   | lf <i>cond</i> 1<br>(TOS                             | AND <i>con</i><br>S) $\rightarrow$ PC<br>stack one | d 2 AND .                                  |                                 | in page            |                                 | 5 4.              |                                                                   |                  |  |
| Status Bits | None                                                 |                                                    |                                            |                                 |                    |                                 |                   |                                                                   |                  |  |
| Description | (see the combinat                                    | descriptio<br>tions of co                          | n for the I<br>nditions a                  | RET instru<br>re mean <u>in</u> | uction<br>Igful. F | on page<br><sup>-</sup> or exam | 8-141<br>ple, tes | return is exe<br>). Note that<br>sting for LT a<br>ive to testing | not all<br>nd GT |  |
| Words       | 1                                                    |                                                    |                                            |                                 |                    |                                 |                   |                                                                   |                  |  |
| Cycles      |                                                      |                                                    | Cvcles f                                   | or a Single                     | e RET              | C Instruc                       | tion              |                                                                   |                  |  |
|             | Conditio                                             | n ROM                                              |                                            | DARAM                           |                    | SARAN                           |                   | External                                                          |                  |  |
|             | True                                                 | 4                                                  |                                            | 4                               |                    | 4                               |                   | 4+4p                                                              |                  |  |
|             | False                                                | 2                                                  |                                            | 2                               |                    | 2                               |                   | 2+2p                                                              |                  |  |
|             |                                                      |                                                    |                                            |                                 |                    |                                 |                   | additional instr<br>ords are discard                              |                  |  |
| Example     | RETC                                                 | GEQ,                                               | ;                                          |                                 | lator<br>and       | conte<br>l if th                | nt is             | f the<br>positive<br>(overflow                                    |                  |  |

| Syntax      | ROL                                                        |                     |          |         |         |        |        |        |        |        |        |        |        |        |       |
|-------------|------------------------------------------------------------|---------------------|----------|---------|---------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-------|
| Operands    | None                                                       |                     |          |         |         |        |        |        |        |        |        |        |        |        |       |
| Opcode      |                                                            | <u>4 1</u> ;<br>0 1 |          | 11<br>1 | 10<br>1 | 9<br>1 | 8<br>0 | 7<br>0 | 6<br>0 | 5<br>0 | 4<br>0 | 3<br>1 | 2<br>1 | 1<br>0 | 0     |
| Execution   | Increm<br>$C \rightarrow A0$<br>$(ACC)^{3}$<br>$(ACC)^{3}$ | CC(0)<br>31)) –     | )<br>→ C |         | 1:1)    |        |        |        |        |        |        |        |        |        |       |
| Status Bits | <u>Affects</u><br>C                                        |                     |          |         |         |        |        |        |        |        |        |        |        |        |       |
|             | This in:                                                   | struct              | ion is   | not a   | ffecte  | d by   | SXN    | Λ.     |        |        |        |        |        |        |       |
| Description | The RC<br>bit is sh                                        |                     |          |         |         |        |        |        |        |        |        |        |        |        | carry |
| Words       | 1                                                          |                     |          |         |         |        |        |        |        |        |        |        |        |        |       |
| Cycles      |                                                            |                     |          | Су      | cles f  | or a   | Sing   | le RC  | )L Ins | struc  | tion   |        |        |        |       |
|             | ROM                                                        |                     |          | DA      | RAM     |        |        | SA     | RAM    |        |        | Ext    | ernal  |        |       |
|             | 1                                                          |                     |          | 1       |         |        |        | 1      |        |        |        | 1+p    | )      |        |       |
|             |                                                            | Су                  | cles fo  | or a R  | epeat   | (RP    | T) Ex  | ecuti  | on o   | f an F | ROLI   | nstru  | ıctior | ı      |       |
|             | ROM                                                        |                     |          | DA      | RAM     |        |        | SA     | RAM    |        |        | Ext    | ernal  |        |       |
|             | n                                                          |                     |          | n       |         |        |        | n      |        |        |        | n+p    | )      |        |       |

Example

ROL

|     |   | Before Instruction |     |   | After Instruction |
|-----|---|--------------------|-----|---|-------------------|
| ACC | 0 | B0001234h          | ACC | 1 | 60002468h         |
|     | С |                    |     | С |                   |

| Syntax      | ROR                                                      |                      |         |                |         |        |        |        |        |        |        |               |        |        |   |
|-------------|----------------------------------------------------------|----------------------|---------|----------------|---------|--------|--------|--------|--------|--------|--------|---------------|--------|--------|---|
| Operands    | None                                                     |                      |         |                |         |        |        |        |        |        |        |               |        |        |   |
| Opcode      | 15 14<br>1 0                                             | 13<br>1              | 12<br>1 | <u>11</u><br>1 | 10<br>1 | 9<br>1 | 8<br>0 | 7<br>0 | 6<br>0 | 5<br>0 | 4<br>0 | <u>3</u><br>1 | 2<br>1 | 1<br>0 | 0 |
| Execution   | Incremen<br>$C \rightarrow ACC$<br>(ACC(0))<br>(ACC(31)) | $(31) \rightarrow C$ |         |                | :0)     |        |        |        |        |        |        |               |        |        |   |
| Status Bits | <u>Affects</u><br>C                                      |                      |         |                |         |        |        |        |        |        |        |               |        |        |   |
|             | This instr                                               | uctio                | n is r  | not af         | fecte   | d by   | SXN    | 1.     |        |        |        |               |        |        |   |
| Description | The ROR<br>carry bit is<br>mulator is                    | s shif               | ted ir  | nto th         | ne MS   | SB of  | the a  |        |        | -      |        |               |        |        |   |
| Words       | 1                                                        |                      |         |                |         |        |        |        |        |        |        |               |        |        |   |
|             |                                                          |                      |         | Сус            | cles f  | or a s | Singl  | e RO   | R Ins  | struc  | tion   |               |        |        |   |
| Cycles      | ROM                                                      |                      |         | DAF            | RAM     |        |        | SAF    | RAM    |        |        | Ext           | ernal  |        |   |
|             | 1                                                        |                      |         | 1              |         |        |        | 1      |        |        |        | 1+p           | )      |        |   |

| _   | Cycles for a Repeat (RPT) Execution of an ROR Instruction |   |     |  |  |  |  |  |  |  |  |
|-----|-----------------------------------------------------------|---|-----|--|--|--|--|--|--|--|--|
| ROM | ROM DARAM SARAM External                                  |   |     |  |  |  |  |  |  |  |  |
| n   | n                                                         | n | n+p |  |  |  |  |  |  |  |  |

| Example | ROR |     |                    |     |                   |
|---------|-----|-----|--------------------|-----|-------------------|
|         |     |     | Before Instruction |     | After Instruction |
|         |     | ACC | 0 B0001235h        | ACC | 1 5800091Ah       |
|         |     |     | С                  |     | С                 |

| Syntax      | <b>RPT</b> dmaDirect addressing <b>RPT</b> ind [, <b>AR</b> n]Indirect addressing <b>RPT</b> #kShort immediate                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerk:8-bit short immediate valueind:Select one of the following seven options:**+**0+**BR0+**BR0+                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| Opcode      | RPT dma                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|             | 0 0 0 0 1 0 1 1 0 dma                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|             | RPT ind [, ARn]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|             | 0 0 0 0 1 0 1 1 1 ARU N NAR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|             | <b>Note:</b> ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0<br>1 0 1 1 1 0 1 1 k                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| Execution   | Increment PC, thenAddressing mode $\underline{Event}$ Addressing mode(data-memory address) $\rightarrow$ RPTCDirect or indirect                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|             | $k \rightarrow RPTC$ Short immediate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| Status Bits | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| Description | The repeat counter (RPTC) is loaded with the content of the addressed data-<br>memory location if direct or indirect addressing is used; it is loaded with an 8-bit<br>immediate value if short immediate addressing is used. The instruction follow-<br>ing the RPT is repeated $n$ times, where $n$ is the initial value of the RPTC plus<br>1. Since the RPTC cannot be saved during a context switch, repeat loops are<br>regarded as multicycle instructions and are not interruptible. The RPTC is<br>cleared to 0 on a device reset. |  |  |  |  |  |  |
|             | RPT is especially useful for block moves, multiply/accumulates, and normal-<br>ization. The repeat instruction itself is not repeatable.                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| PRELIMINARY | Assembly Language Instructions 8-145                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |

1

Words

Cycles

### Cycles for a Single RPT Instruction (Using Direct and Indirect Addressing)

|          | Program |       |       |          |  |  |
|----------|---------|-------|-------|----------|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

# Cycles for a Single RPT Instruction (Using Short Immediate Addressing)

|           | Addressing) |                      |         |                           |                      |                                |  |
|-----------|-------------|----------------------|---------|---------------------------|----------------------|--------------------------------|--|
|           | ROM         |                      | DARAM   | SAF                       | RAM                  | External                       |  |
|           | 1           |                      | 1       | 1                         |                      | 1+p                            |  |
| Example 1 | RPT         | DAT127               |         |                           | esses OF80h          |                                |  |
|           |             |                      | ;Repeat | next in                   | struction 1          | 3 times.                       |  |
|           |             |                      | Before  | Instruction               |                      | After Instruction              |  |
|           |             | Data Memory<br>0FFFh |         | 0Ch                       | Data Memory<br>0FFFh | 0Ch                            |  |
|           |             | RPTC                 |         | 0h                        | RPTC                 | 0Ch                            |  |
| Example 2 | RPT         | *,AR1                | ;Repeat | next in                   | struction 4          | 096 times.                     |  |
|           |             |                      | Before  | Instruction               |                      | After Instruction              |  |
|           |             | ARP                  |         | 0                         | ARP                  | 1                              |  |
|           |             | AR0                  |         | 300h                      | AR0                  | 300h                           |  |
|           |             | Data Memory<br>300h  |         | 0FFFh                     | Data Memory<br>300h  | 0FFFh                          |  |
|           |             | RPTC                 |         | 0h                        | RPTC                 | 0FFFh                          |  |
| Example 3 | RPT         | #1                   | _       | t next in:<br>Instruction | struction t          | wo times.<br>After Instruction |  |
|           |             | RPTC                 |         | Oh                        | RPTC                 | 1h                             |  |

| Syntax      |                                                                                                                                                                                                                                                                                                                                                           |            |                |              | Direc<br>ndire |   |   | • |     |   |     |   |     |   |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------|--------------|----------------|---|---|---|-----|---|-----|---|-----|---|
| Operands    | dma:7 LSBs of the data-memory addressshift2:Left shift value from 0 to 7 (defaults to 0)n:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options: $*$ $*_{+}$ $*_{-}$ $*_{0-}$ $*$ $BR0+$ $*BR0-$                                                                                                         |            |                |              |                |   |   |   |     |   |     |   |     |   |
| Opcode      | SACH dr                                                                                                                                                                                                                                                                                                                                                   | na [, shif | ť2]            |              |                |   |   |   |     |   |     |   |     |   |
|             | 15 14                                                                                                                                                                                                                                                                                                                                                     | 13 12      | 11             | 10           | 9              | 8 | 7 | 6 | 5   | 4 | 3   | 2 | 1   | 0 |
|             | 1 0                                                                                                                                                                                                                                                                                                                                                       | 0 1        | 1              |              | shift2         |   | 0 |   |     |   | dma |   |     |   |
|             | SACH ind                                                                                                                                                                                                                                                                                                                                                  | d[, shift2 | 2[, <b>A</b> F | <b>R</b> n]] |                |   |   |   |     |   |     |   |     |   |
|             | 15 14                                                                                                                                                                                                                                                                                                                                                     | 13 12      | 11             | 10           | 9              | 8 | 7 | 6 | 5   | 4 | 3   | 2 | 1   | 0 |
|             | 1 0                                                                                                                                                                                                                                                                                                                                                       | 0 1        | 1              |              | shift2         |   | 1 |   | ARU |   | Ν   |   | NAR |   |
|             | <b>Note:</b> ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).                                                                                                                                                                                                                                       |            |                |              |                |   |   |   |     |   |     |   |     |   |
| Execution   | Increment PC, then 16 MSBs of ((ACC) $\times$ 2 <sup>shift2</sup> ) $\rightarrow$ data-memory address                                                                                                                                                                                                                                                     |            |                |              |                |   |   |   |     |   |     |   |     |   |
| Status Bits | This instruction is not affected by SXM                                                                                                                                                                                                                                                                                                                   |            |                |              |                |   |   |   |     |   |     |   |     |   |
| Description | The SACH instruction copies the entire accumulator into the output shifter, where it left shifts the entire 32-bit number from 0 to 7 bits. It then copies the upper 16 bits of the shifted value into data memory. During the shift, the low-order bits are filled with 0s, and the high-order bits are lost. The accumulator itself remains unaffected. |            |                |              |                |   |   |   |     |   |     |   |     |   |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                         |            |                |              |                |   |   |   |     |   |     |   |     |   |

#### Cycles

#### Cycles for a Single SACH Instruction

|          | Program |       |       |          |  |  |
|----------|---------|-------|-------|----------|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |
| External | 2+d     | 2+d   | 2+d   | 4+d+p    |  |  |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

#### Cycles for a Repeat (RPT) Execution of an SACH Instruction

|          | Program |       |         |           |  |
|----------|---------|-------|---------|-----------|--|
| Operand  | ROM     | DARAM | SARAM   | External  |  |
| DARAM    | n       | n     | n       | n+p       |  |
| SARAM    | n       | n     | n, n+2† | n+p       |  |
| External | 2n+nd   | 2n+nd | 2n+nd   | 2n+2+nd+p |  |

<sup>†</sup> If the operand and the code are in the same SARAM block



| Syntax      | SACL dma [, shift2]Direct addressingSACL ind [, shift2 [, ARn]]Indirect addressing                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Operands    | dma:7 LSBs of the data-memory addressshift2:Left shift value from 0 to 7 (defaults to 0)n:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options: $*$ $*$ $*$ $*$ $*$ $*$ $*$ $*$ $*$ $*$ $*$ $*$                                                                                                         |  |  |  |  |  |
| Opcode      | SACL dma [, shift2]                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|             | 1 0 0 1 0 shift2 0 dma                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|             | SACL ind [, shift2[, ARn]]                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|             | 1 0 0 1 0 shift2 1 ARU N NAR                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|             | <b>Note:</b> ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).                                                                                                                                                                                                                                       |  |  |  |  |  |
| Execution   | Increment PC, then 16 LSBs of ((ACC) $\times$ 2 <sup>shift2</sup> ) $\rightarrow$ data-memory address                                                                                                                                                                                                                                                     |  |  |  |  |  |
| Status Bits | This instruction is not affected by SXM.                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| Description | The SACL instruction copies the entire accumulator into the output shifter, where it left shifts the entire 32-bit number from 0 to 7 bits. It then copies the lower 16 bits of the shifted value into data memory. During the shift, the low-order bits are filled with 0s, and the high-order bits are lost. The accumulator itself remains unaffected. |  |  |  |  |  |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |

| Cycles |
|--------|
|--------|

#### Cycles for a Single SACL Instruction

|          | Program |       |       |          |  |  |
|----------|---------|-------|-------|----------|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |
| External | 2+d     | 2+d   | 2+d   | 4+d+p    |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block.

| Cycles for a Repeat (RPT) | Execution of an SACL Instruction |
|---------------------------|----------------------------------|
|---------------------------|----------------------------------|

|          | Program |       |         |           |  |
|----------|---------|-------|---------|-----------|--|
| Operand  | ROM     | DARAM | SARAM   | External  |  |
| DARAM    | n       | n     | n       | n+p       |  |
| SARAM    | n       | n     | n, n+2† | n+p       |  |
| External | 2n+nd   | 2n+nd | 2n+nd   | 2n+2+nd+p |  |

<sup>†</sup> If the operand and the code are in the same SARAM block.



| Syntax      | SAR ARx, dmaDirect addressingSAR ARx, ind [, ARn]Indirect addressing                                                                                                                                                                                                                                                                                               |        |  |  |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--|--|--|--|--|
| Operands    | <ul> <li>dma: 7 LSBs of the data-memory address</li> <li>x: Value from 0 to 7 designating the auxiliary register value t stored</li> <li>n: Value from 0 to 7 designating the next auxiliary register ind: Select one of the following seven options:</li> <li>* *+ *- *0+ *0- *BR0+ *BR0-</li> </ul>                                                              | o be   |  |  |  |  |  |
| Opcode      | SAR ARx, dma                                                                                                                                                                                                                                                                                                                                                       |        |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1                                                                                                                                                                                                                                                                                                                                | 0      |  |  |  |  |  |
|             | 1 0 0 0 0 x 0 dma                                                                                                                                                                                                                                                                                                                                                  |        |  |  |  |  |  |
|             | SAR ARx, ind [, ARn]                                                                                                                                                                                                                                                                                                                                               |        |  |  |  |  |  |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1                                                                                                                                                                                                                                                                                                                                | 0      |  |  |  |  |  |
|             | 1 0 0 0 0 x 0 ARU N NAF                                                                                                                                                                                                                                                                                                                                            |        |  |  |  |  |  |
|             | <b>Note:</b> ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode F</i> (page 7-12).                                                                                                                                                                                                                                                     | Format |  |  |  |  |  |
| Execution   | Increment PC, then $(ARx) \rightarrow data$ -memory address                                                                                                                                                                                                                                                                                                        |        |  |  |  |  |  |
| Status Bits | None                                                                                                                                                                                                                                                                                                                                                               |        |  |  |  |  |  |
| Description | The content of the designated auxiliary register (ARx) is stored in the specified data-memory location. When the content of the designated auxiliary register is also modified by the instruction (in indirect addressing mode), SAR copies the auxiliary register value to data memory before it increments or decrements the contents of the auxiliary register. |        |  |  |  |  |  |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                                  |        |  |  |  |  |  |

#### SAR Store Auxiliary Register

### Cycles

#### Cycles for a Single SAR Instruction

|          |     | P     | rogram |          |
|----------|-----|-------|--------|----------|
| Operand  | ROM | DARAM | SARAM  | External |
| DARAM    | 1   | 1     | 1      | 1+p      |
| SARAM    | 1   | 1     | 1, 2†  | 1+p      |
| External | 2+d | 2+d   | 2+d    | 4+d+p    |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

#### Cycles for a Repeat (RPT) Execution of an SAR Instruction

|          |       | F     | Program |           |
|----------|-------|-------|---------|-----------|
| Operand  | ROM   | DARAM | SARAM   | External  |
| DARAM    | n     | n     | n       | n+p       |
| SARAM    | n     | n     | n, n+2† | n+p       |
| External | 2n+nd | 2n+nd | 2n+nd   | 2n+2+nd+p |

<sup>†</sup> If the operand and the code are in the same SARAM block

Example 1

SAR

#### AR0, DAT30 ; (DP = 6: addresses 0300h-037Fh)

|           |     |                     | Before Instruction        |                     | After Instruction |
|-----------|-----|---------------------|---------------------------|---------------------|-------------------|
|           |     | AR0                 | 37h                       | AR0                 | 37h               |
|           |     | Data Memory<br>31Eh | 18h                       | Data Memory<br>31Eh | 37h               |
| Example 2 | SAR | AR0,*+              |                           |                     |                   |
|           |     |                     |                           |                     |                   |
|           |     |                     | Before Instruction        |                     | After Instruction |
|           |     | ARP                 | Before Instruction        | ARP                 | After Instruction |
|           |     | ARP<br>AR0          | Before Instruction 0 401h | ARP<br>AR0          |                   |

| Syntax      | SBRK #                                                                    | k                                         |                          |                         |                          |                         |                          |                       |                        | Shor                       | t imm                  | ediat                   | te ad                  | dress                   | sing                 |
|-------------|---------------------------------------------------------------------------|-------------------------------------------|--------------------------|-------------------------|--------------------------|-------------------------|--------------------------|-----------------------|------------------------|----------------------------|------------------------|-------------------------|------------------------|-------------------------|----------------------|
| Operands    | k:                                                                        | 8-                                        | bit p                    | ositiv                  | ve sho                   | ort in                  | nmec                     | liate                 | value                  | Э                          |                        |                         |                        |                         |                      |
| Opcode      | <b>SBRK</b><br>15 1                                                       | 4 13                                      | 12<br>1                  | 11<br>1                 | 10<br>1                  | 9<br>0                  | 8                        | 7                     | 6                      | 5                          | 4                      | 3                       | 2                      | 1                       | 0                    |
| Execution   | Increme<br>(current<br>Note tha                                           | AR) – I                                   | $c \to c$                | curre                   |                          |                         | stant                    |                       |                        |                            |                        |                         |                        |                         |                      |
| Status Bits | None                                                                      |                                           |                          | •                       |                          |                         |                          |                       |                        |                            |                        |                         |                        |                         |                      |
| Description | The 8-bit<br>current a<br>replaces<br>the auxil<br>as an 8-b<br>are unsig | auxiliar<br>the co<br>ary reg<br>oit posi | y reg<br>ntent<br>jister | gister<br>s of<br>arith | r (the<br>the a<br>metio | one<br>uxilia<br>c unit | e poi<br>ary re<br>: (AR | nted<br>giste<br>AU), | to b<br>er. Th<br>with | by the<br>le sul<br>the ir | e AR<br>btract<br>mmed | P) a<br>tion t<br>diate | nd th<br>akes<br>value | ne re<br>plac<br>e trea | sult<br>e in<br>ıted |
| Words       | 1                                                                         |                                           |                          |                         |                          |                         |                          |                       |                        |                            |                        |                         |                        |                         |                      |
| Cycles      |                                                                           |                                           |                          | Cycl                    | es for                   | a Si                    | ngle                     | SBRI                  | K Ins                  | tructi                     | on                     |                         |                        |                         |                      |
|             | ROM                                                                       |                                           |                          | DAR                     | AM                       |                         |                          | SAR                   | AM                     |                            |                        | Exter                   | nal                    |                         |                      |
|             | 1                                                                         |                                           |                          | 1                       |                          |                         |                          | 1                     |                        |                            |                        | 1+p                     |                        |                         |                      |
| Example     | SBRK                                                                      | #<br>ARP<br>AR7                           | OFFh                     |                         | Before                   | Instr                   |                          | 7                     |                        | ARP<br>AR7                 |                        | Af                      | ter Ins                | struct<br>FF(           | 7                    |

| Syntax      | SET               | C cor          | ntro           | l bit                                               |                                              |                                                                          |                                                             |                                                    |                                               |                                                       |                                                    |                                             |                                |            |               |          |
|-------------|-------------------|----------------|----------------|-----------------------------------------------------|----------------------------------------------|--------------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------|-------------------------------------------------------|----------------------------------------------------|---------------------------------------------|--------------------------------|------------|---------------|----------|
| Operands    | contr             | ol bit         | :              | Selec<br>C<br>CNF<br>INTM<br>OVM<br>SXM<br>TC<br>XF | Ca<br>R/<br>In<br>O <sup>r</sup><br>Si<br>Te | e of th<br>arry b<br>AM c<br>terrup<br>verflo<br>gn-e<br>est/co<br>F pin | bit of<br>onfig<br>ot mo<br>ow m<br>ow m<br>otens<br>ontrol | statu<br>urati<br>ode b<br>ode l<br>sion r<br>flag | on co<br>bit of s<br>bit of<br>node<br>bit of | gister<br>ontrol<br>statu<br>statu<br>bit c<br>f stat | ST1<br>bit c<br>s reg<br>us reg<br>of sta<br>us re | of sta<br>jister<br>giste<br>tus r<br>giste | ST0<br>r ST(<br>egist<br>er ST | )<br>er S1 |               | Γ1       |
| Opcode      | SET               | сс             |                |                                                     |                                              |                                                                          |                                                             |                                                    |                                               |                                                       |                                                    |                                             |                                |            |               |          |
|             | 15                | <u>14</u><br>0 | <u>13</u><br>1 | <u>12</u>                                           | <u>11</u><br>1                               | <u>10</u><br>1                                                           | <u>9</u><br>1                                               | <u>8</u><br>0                                      | 7                                             | <u>6</u><br>1                                         | <u>5</u><br>0                                      | 4                                           | <u>3</u><br>1                  | 2          | <u>1</u><br>1 | 0        |
|             | SET               |                | F              |                                                     |                                              | •                                                                        | •                                                           |                                                    |                                               |                                                       |                                                    |                                             |                                |            |               | <u>`</u> |
|             | 15                | 14             | 13             | 12                                                  | 11                                           | 10                                                                       | 9                                                           | 8                                                  | 7                                             | 6                                                     | 5                                                  | 4                                           | 3                              | 2          | 1             | 0        |
|             | 1                 | 0              | 1              | 1                                                   | 1                                            | 1                                                                        | 1                                                           | 0                                                  | 0                                             | 1                                                     | 0                                                  | 0                                           | 0                              | 1          | 0             | 1        |
|             | SET               | С ІМТ          | м              |                                                     |                                              |                                                                          |                                                             |                                                    |                                               |                                                       |                                                    |                                             |                                |            |               |          |
|             | 15                | <u>14</u><br>0 | 13             |                                                     | <u>11</u><br>1                               | <u>10</u><br>1                                                           | 9<br>1                                                      | <u>8</u><br>0                                      | 7                                             | <u>6</u><br>1                                         | 5<br>0                                             | 4                                           | <u>3</u><br>0                  | 2          | 1<br>0        | 0        |
|             | 1                 | 0              | 1              | 1                                                   | I                                            | I                                                                        | -                                                           | 0                                                  | 0                                             | I                                                     | 0                                                  | 0                                           | 0                              | 0          | 0             | 1        |
|             | SET               |                |                |                                                     |                                              |                                                                          |                                                             |                                                    |                                               |                                                       |                                                    |                                             |                                |            |               |          |
|             | 15                | <u>14</u><br>0 | <u>13</u><br>1 | <u>12</u>                                           | <u>11</u><br>1                               | <u>10</u><br>1                                                           | <u>9</u><br>1                                               | <u>8</u><br>0                                      | 7                                             | <u>6</u><br>1                                         | 5<br>0                                             | 4                                           | <u>3</u><br>0                  | 2<br>0     | <u>1</u><br>1 | 0        |
|             | L                 |                |                |                                                     | •                                            |                                                                          | •                                                           | 0                                                  | •                                             |                                                       | •                                                  | •                                           | 0                              | 0          |               |          |
|             | <b>SET(</b><br>15 | 14             | 13             | 12                                                  | 11                                           | 10                                                                       | 9                                                           | 8                                                  | 7                                             | 6                                                     | 5                                                  | 4                                           | 3                              | 2          | 1             | 0        |
|             | 1                 | 0              | 1              | 1                                                   | 1                                            | 1                                                                        | 1                                                           | 0                                                  | 0                                             | 1                                                     | 0                                                  | 0                                           | 0                              | 1          | 1             | 1        |
|             | SET               | стс            |                |                                                     |                                              |                                                                          |                                                             |                                                    |                                               |                                                       |                                                    |                                             |                                |            |               |          |
|             | 15                | 14             | 13             |                                                     | <u>11</u><br>1                               | 10                                                                       | 9<br>1                                                      | <u>8</u><br>0                                      | 7                                             | <u>6</u><br>1                                         | 5                                                  | 4                                           | <u>3</u><br>1                  | 2          | 1             | 0        |
|             | 1                 | 0              | 1              | 1                                                   | 1                                            | 1                                                                        | 1                                                           | 0                                                  | 0                                             | 1                                                     | 0                                                  | 0                                           | 1                              | 0          | 1             | 1        |
|             | SET               | C XF           |                |                                                     |                                              |                                                                          |                                                             |                                                    |                                               |                                                       |                                                    |                                             |                                |            |               |          |
|             | 15                | <u>14</u><br>0 | <u>13</u><br>1 | <u>12</u>                                           | <u>11</u><br>1                               | <u>10</u><br>1                                                           | <u>9</u><br>1                                               | <u>8</u><br>0                                      | 7                                             | <u>6</u><br>1                                         | <u>5</u><br>0                                      | 4                                           | <u>3</u><br>1                  | 2<br>1     | 1<br>0        | 0        |
| Execution   |                   | ment           | t PC           | C, ther                                             |                                              |                                                                          |                                                             |                                                    | 0                                             |                                                       |                                                    |                                             |                                | <u> </u>   | 0             |          |
| Status Bits | None              | <b>;</b>       |                |                                                     |                                              |                                                                          |                                                             |                                                    |                                               |                                                       |                                                    |                                             |                                |            |               |          |
| Description | ST0 a             | and S          | ST1            | l conti<br>. See<br>matio                           | Secti                                        | ion 3.                                                                   | 5, S                                                        | tatus                                              | Regi                                          |                                                       |                                                    |                                             |                                |            |               |          |

| Words  | 1   |                   |                    |          |
|--------|-----|-------------------|--------------------|----------|
| Cycles |     | Cycles for a Sing | e SETC Instruction |          |
|        | ROM | DARAM             | SARAM              | External |
|        | 1   | 1                 | 1                  | 1+p      |

|         |      | Cycles for | r a Repeat (RPT | ) Execution of an S   | ETC Instruction   |
|---------|------|------------|-----------------|-----------------------|-------------------|
|         | ROM  |            | DARAM           | SARAM                 | External          |
|         | n    |            | n               | n                     | n+p               |
|         |      |            |                 |                       |                   |
| Example | SETC | TC         | ; TC :          | is bit 11 of S        | Τ1                |
|         |      | ST1        | Before Ins      | truction<br>x1xxh ST1 | After Instruction |

| Syntax      | SFL                                                                              |                     |                |        |        |        |        |        |        |        |        |        |   |
|-------------|----------------------------------------------------------------------------------|---------------------|----------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|
| Operands    | None                                                                             |                     |                |        |        |        |        |        |        |        |        |        |   |
| Opcode      | 15 14 13<br>1 0 1                                                                | <u>12 11</u><br>1 1 | <u>10</u><br>1 | 9<br>1 | 8<br>0 | 7<br>0 | 6<br>0 | 5<br>0 | 4<br>0 | 3<br>1 | 2<br>0 | 1<br>0 | 0 |
| Execution   | Increment PC,<br>(ACC(31)) $\rightarrow$ (ACC(30:0)) –<br>0 $\rightarrow$ ACC(0) | 0                   | 1:1)           |        |        |        |        |        |        |        |        |        |   |
| Status Bits | <u>Affects</u><br>C                                                              |                     |                |        |        |        |        |        |        |        |        |        |   |
|             | This instruction                                                                 | n is not a          | ffecte         | d by   | SXⅣ    | 1.     |        |        |        |        |        |        |   |
| Description | The SFL instru<br>with a 0, and the affected by SX                               | he MSB i            |                |        |        |        |        |        |        |        | -      |        |   |
| Words       | 1                                                                                |                     |                |        |        |        |        |        |        |        |        |        |   |
| Cycles      |                                                                                  | Cy                  | /cles f        | or a   | Singl  | le SF  | L Ins  | truct  | ion    |        |        |        |   |
|             | ROM                                                                              | DA                  | RAM            |        |        | SAF    | RAM    |        |        | Ext    | ernal  |        |   |
|             | 1                                                                                | 1                   |                |        |        | 1      |        |        |        | 1+p    | )      |        |   |
|             |                                                                                  |                     |                |        |        |        |        |        |        |        |        |        |   |

|     | Cycles for a Repeat (RP | T) Execution of an S | SFL Instruction |  |
|-----|-------------------------|----------------------|-----------------|--|
| ROM | DARAM                   | SARAM                | External        |  |
| n   | n                       | n                    | n+p             |  |

| Example | SFL |     |   |                    |     |   |                   |
|---------|-----|-----|---|--------------------|-----|---|-------------------|
|         |     |     |   | Before Instruction |     |   | After Instruction |
|         |     | ACC | X | B0001234h          | ACC | 1 | 60002468h         |
|         |     |     | С |                    |     | С |                   |

| Syntax      | SFF                 | 2                                                      |                                |                      |               |                |        |        |        |        |        |        |               |        |        |                  |
|-------------|---------------------|--------------------------------------------------------|--------------------------------|----------------------|---------------|----------------|--------|--------|--------|--------|--------|--------|---------------|--------|--------|------------------|
| Operands    | Nor                 | ie                                                     |                                |                      |               |                |        |        |        |        |        |        |               |        |        |                  |
| Opcode      | 15<br>1             | 14<br>0                                                | <u>13</u><br>1                 | 12<br>1              | 11<br>1       | <u>10</u><br>1 | 9<br>1 | 8<br>0 | 7<br>0 | 6<br>0 | 5<br>0 | 4<br>0 | <u>3</u><br>1 | 2<br>0 | 1<br>1 | 0<br>0           |
| Execution   | If S<br>If S<br>(AC | emen<br>XM =<br>Then<br>XM =<br>Then<br>C(31:<br>C(0)) | 0<br>0 →<br>1<br>(AC(<br>1)) - | ACC<br>C(31)<br>→ AC | C(31)<br>)) → | ACC            | (31)   |        |        |        |        |        |               |        |        |                  |
| Status Bits | <u>Affe</u><br>SXN  | e <u>cted</u><br>N                                     | <u>by</u>                      |                      | <u>A</u><br>C | ffects         | 5      |        |        |        |        |        |               |        |        |                  |
| Description | The                 | SFR                                                    | instr                          | uctio                | n shi         | fts th         | e ac   | cumı   | ulato  | r righ | it one | e bit. |               |        |        |                  |
|             |                     |                                                        | B) is u                        | incha                |               |                | •      |        |        |        |        | -      |               |        |        | gn bit<br>to the |
|             |                     |                                                        | ts are                         | shift                | ed rig        | ght b          | y one  |        |        | -      | -      |        |               |        |        | mula-<br>t, and  |
| Words       | 1                   |                                                        |                                |                      |               |                |        |        |        |        |        |        |               |        |        |                  |
| Cycles      |                     |                                                        |                                |                      | Су            | cles           | for a  | Sing   | le SF  | R Ins  | struc  | tion   |               |        |        |                  |
|             | RO                  | М                                                      |                                |                      | DAF           | RAM            |        |        | SA     | RAM    |        |        | Ext           | ernal  |        |                  |
|             | 1                   |                                                        |                                |                      | 1             |                |        |        | 1      |        |        |        | 1+p           | )      |        |                  |
|             |                     |                                                        | Cycl                           | es fo                | r a R         | epeat          | t (RP  | T) Ex  | ecuti  | on o   | fans   | SFR I  | nstru         | ictior | 1      |                  |
|             | RO                  | М                                                      |                                |                      | DAF           | RAM            |        |        | SA     | RAM    |        |        | Ext           | ernal  |        |                  |

n

n

n

### PRELIMINARY

n+p

#### SFR Shift Accumulator Right

### PRELIMINARY



| Syntax      | SPAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                  |                      |                         |         |        |            |              |        |      |               |               |        |        |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------------|-------------------------|---------|--------|------------|--------------|--------|------|---------------|---------------|--------|--------|
| Operands    | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                  |                      |                         |         |        |            |              |        |      |               |               |        |        |
| Opcode      | 15 14<br>1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | - <u>13</u><br>1 | <u>12 11</u><br>1 1  | <u>10</u><br>1          | 9<br>1  | 8<br>0 | 7<br>0     | 6<br>0       | 5<br>0 | 4    | <u>3</u><br>0 | <u>2</u><br>1 | 1<br>0 | 0<br>1 |
| Execution   | Incremer<br>(ACC) –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                  |                      | $\rightarrow A$         | СС      |        |            |              |        |      |               |               |        |        |
| Status Bits | <u>Affected</u><br>PM and (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | -                |                      | f <u>fects</u><br>and ( | ΟV      |        |            |              |        |      |               |               |        |        |
|             | This inst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ruction          | is not af            | fecte                   | dby     | SXM    |            |              |        |      |               |               |        |        |
| Description | The cont<br>from the<br>SPAC is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | conten           | t of the a           | accur                   | nulat   | or. T  | he re      | sult         | is sto | ored | in th         | e acc         | umu    | lator. |
|             | The function the functiont the function the |                  | he SPAC              | ) instr                 | uctio   | n is a | subt       | asko         | ofthe  | LTS  | , MP          | YS, a         | Ind S  | QRS    |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                  |                      |                         |         |        |            |              |        |      |               |               |        |        |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  |                      |                         |         |        |            |              |        |      |               |               |        |        |
| Cycles      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  | Сус                  | les fo                  | or a Si | ingle  | SPA        | C Ins        | truct  | ion  |               |               |        |        |
| Cycles      | ROM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                  | Cyc<br>DAF           |                         | or a Si | -      | SPA<br>SAR |              | truct  | ion  | Exte          | ernal         |        |        |
| Cycles      | <b>ROM</b><br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                  | -                    |                         | or a Si | -      |            |              | truct  | ion  | Exte          | ernal         |        |        |
| Cycles      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Cycles           | DAF<br>1<br>for a Re | RAM                     |         |        | SAR<br>1   | AM<br>n of a |        |      | 1+p<br>nstru  | ictior        | 1      |        |
| Cycles      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Cycles           | <b>DAF</b><br>1      | RAM                     |         |        | SAR<br>1   | AM<br>n of a |        |      | 1+p<br>nstru  |               | 1      |        |

| Syntax      | SPH<br>SPH              |            | <b>AR</b> n    | <i>i</i> ]                                                                                                                                                                  |    |    |   |   |   |   | Direc<br>Indire |         |         | -     |        |      |
|-------------|-------------------------|------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|---|---|---|-----------------|---------|---------|-------|--------|------|
| Operands    | dma:<br>n:<br>ind:      |            | V              | 7 LSBs of the data-memory address<br>Value from 0 to 7 designating the next auxiliary register<br>Select one of the following seven options:<br>* *+ *- *0+ *0- *BR0+ *BR0- |    |    |   |   |   |   |                 |         |         |       |        |      |
| Opcode      | SP                      | H dm       | a              |                                                                                                                                                                             |    |    |   |   |   |   |                 |         |         |       |        |      |
|             | 15                      | 14         | 13             | 12                                                                                                                                                                          | 11 | 10 | 9 | 8 | 7 | 6 | 5               | 4       | 3       | 2     | 1      | 0    |
|             | 1                       | 0          | 0              | 0                                                                                                                                                                           | 1  | 1  | 0 | 1 | 0 |   |                 |         | dma     |       |        |      |
|             | SP                      | H ina      | /[, <b>A</b> I | <b>R</b> <i>n</i> ]                                                                                                                                                         |    |    |   |   |   |   |                 |         |         |       |        |      |
|             | 15                      | 14         | 13             | 12                                                                                                                                                                          | 11 | 10 | 9 | 8 | 7 | 6 | 5               | 4       | 3       | 2     | 1      | 0    |
|             | 1                       | 0          | 0              | 0                                                                                                                                                                           | 1  | 1  | 0 | 1 | 1 |   | ARU             |         | Ν       |       | NAR    |      |
| Execution   | Note<br>Increi<br>16 MS | ہ)<br>nent | PC,            | '-12).<br>then                                                                                                                                                              |    |    |   |   |   |   | Indired         | ct Addı | ressinų | g Opc | ode Fo | rmat |
| Status Bits | <u>Affec</u><br>PM      | ted b      | Ľ              |                                                                                                                                                                             |    |    |   |   |   |   |                 |         |         |       |        |      |
| Description | •                       |            |                |                                                                                                                                                                             |    |    |   |   |   |   |                 |         |         |       |        |      |
| Words       | 1                       |            |                |                                                                                                                                                                             |    |    |   |   |   |   |                 |         |         |       |        |      |

|          | Су  | cles for a Single S | SPH Instruction |          |
|----------|-----|---------------------|-----------------|----------|
|          |     | F                   | Program         |          |
| Operand  | ROM | DARAM               | SARAM           | External |
| DARAM    | 1   | 1                   | 1               | 1+p      |
| SARAM    | 1   | 1                   | 1, 2†           | 1+p      |
| External | 2+d | 2+d                 | 2+d             | 4+d+p    |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| C        | Cycles for a Repeat (RPT) Execution of an SPH Instruction |       |         |           |  |  |  |  |  |  |
|----------|-----------------------------------------------------------|-------|---------|-----------|--|--|--|--|--|--|
| Program  |                                                           |       |         |           |  |  |  |  |  |  |
| Operand  | ROM                                                       | DARAM | SARAM   | External  |  |  |  |  |  |  |
| DARAM    | n                                                         | n     | n       | n+p       |  |  |  |  |  |  |
| SARAM    | n                                                         | n     | n, n+2† | n+p       |  |  |  |  |  |  |
| External | 2n+nd                                                     | 2n+nd | 2n+nd   | 2n+2+nd+p |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

| Example 1 | SPH | DAT3                | ;(DP = 4: a);PM = 0: no | ddresses 0200<br>shift) | )h-027Fh,         |
|-----------|-----|---------------------|-------------------------|-------------------------|-------------------|
|           |     |                     | Before Instruction      |                         | After Instruction |
|           |     | PREG                | FE079844h               | PREG                    | FE079844h         |
|           |     | Data Memory<br>203h | 4567h                   | Data Memory<br>203h     | FE07h             |
| Example 2 | SPH | * <b>,</b> AR7      | ;(PM = 2: 1             | eft shift of            | four)             |
|           |     |                     | Before Instruction      |                         | After Instruction |
|           |     | ARP                 | 6                       | ARP                     | 7                 |
|           |     | AR6                 | 203h                    | AR6                     | 203h              |
|           |     | PREG                | FE079844h               | PREG                    | FE079844h         |
|           |     | Data Memory<br>203h | 4567h                   | Data Memory<br>203h     | E079h             |

Assembly Language Instructions 8-161

PRELIMINARY

# Cycles

| Syntax      | SPL a<br>SPL i                                                             |                                                    | <b>AR</b> n                                    | ]                                                                                                                                                                          |                                                     |                                                        |                                                   |                                                          |                                         |                                             | Direc<br>Indire                               |                                               |                                         | -                                         |                                             |                                     |
|-------------|----------------------------------------------------------------------------|----------------------------------------------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------------------|---------------------------------------------------|----------------------------------------------------------|-----------------------------------------|---------------------------------------------|-----------------------------------------------|-----------------------------------------------|-----------------------------------------|-------------------------------------------|---------------------------------------------|-------------------------------------|
| Operands    | dma:<br>n:<br>ind:                                                         |                                                    | Va                                             | 7 LSBs of the data-memory address<br>Value from 0 to 7 designating the next auxiliary registe<br>Select one of the following seven options:<br>* *+ *- *0+ *0- *BR0+ *BR0- |                                                     |                                                        |                                                   |                                                          |                                         |                                             |                                               | giste                                         | ər                                      |                                           |                                             |                                     |
| Opcode      | SPI                                                                        | _ dm                                               | а                                              |                                                                                                                                                                            |                                                     |                                                        |                                                   |                                                          |                                         |                                             |                                               |                                               |                                         |                                           |                                             |                                     |
|             | 15                                                                         | 14                                                 | 13                                             | 12                                                                                                                                                                         | 11                                                  | 10                                                     | 9                                                 | 8                                                        | 7                                       | 6                                           | 5                                             | 4                                             | 3                                       | 2                                         | 1                                           | 0                                   |
|             | 1                                                                          | 0                                                  | 0                                              | 0                                                                                                                                                                          | 1                                                   | 1                                                      | 0                                                 | 0                                                        | 0                                       |                                             |                                               |                                               | dma                                     |                                           |                                             |                                     |
|             | SPI                                                                        | _ ind                                              | [, <b>A</b> F                                  | <b>R</b> <i>n</i> ]                                                                                                                                                        |                                                     |                                                        |                                                   |                                                          |                                         |                                             |                                               |                                               |                                         |                                           |                                             |                                     |
|             | 15                                                                         | 14                                                 | 13                                             | 12                                                                                                                                                                         | 11                                                  | 10                                                     | 9                                                 | 8                                                        | 7                                       | 6                                           | 5                                             | 4                                             | 3                                       | 2                                         | 1                                           | 0                                   |
|             | 1                                                                          | 0                                                  | 0                                              | 0                                                                                                                                                                          | 1                                                   | 1                                                      | 0                                                 | 0                                                        | 1                                       |                                             | ARU                                           |                                               | Ν                                       |                                           | NAR                                         |                                     |
| Execution   | Note<br>Increr<br>16 LS                                                    | ہ»<br>nent                                         | PC,                                            | '-12).<br>then                                                                                                                                                             |                                                     | re defiı<br>G) →                                       |                                                   |                                                          |                                         |                                             |                                               | ct Addı                                       | ressinų                                 | д Орс                                     | ode Fo                                      | ormat                               |
| Status Bits | <u>Affect</u><br>PM                                                        | ed b                                               | ¥                                              |                                                                                                                                                                            |                                                     |                                                        |                                                   |                                                          |                                         |                                             |                                               |                                               |                                         |                                           |                                             |                                     |
| Description | The 1<br>stored<br>shiften<br>mode<br>are loa<br>bits ar<br>value<br>value | l in d<br>, wh<br>is se<br>st. lf<br>e ze<br>are s | ata m<br>ere if<br>lecte<br>a left<br>ro fille | nemo<br>t is s<br>ed, th<br>shift<br>ed. If<br>d in d                                                                                                                      | ory. F<br>hifteo<br>e hig<br>is se<br>PM =<br>ata m | irst, tł<br>d as s<br>h-ord<br>electe<br>= 00,<br>nemo | ne 32<br>spec<br>er bi<br>d, th<br>no sl<br>ry. N | 2-bit f<br>ified<br>ts are<br>e higl<br>hift oc<br>eithe | PRE(<br>by th<br>sigr<br>h-ord<br>ccurs | G val<br>ne Pl<br>n exte<br>ler bi<br>. The | ue is<br>M bits<br>endeo<br>its are<br>en the | copie<br>s. If t<br>d and<br>e lost<br>e 16 L | ed int<br>he rig<br>the l<br>and<br>SBs | o the<br>ght-s<br>ow-c<br>the lo<br>of th | e proc<br>hift-b<br>order<br>ow-or<br>e shi | luct<br>by-6<br>bits<br>der<br>fted |
| Words       | 1                                                                          |                                                    |                                                |                                                                                                                                                                            |                                                     |                                                        |                                                   |                                                          |                                         |                                             |                                               |                                               |                                         |                                           |                                             |                                     |

Cycles

|          | C)  | cles for a Single S | SPL Instruction |          |  |  |  |  |  |
|----------|-----|---------------------|-----------------|----------|--|--|--|--|--|
| Program  |     |                     |                 |          |  |  |  |  |  |
| Operand  | ROM | DARAM               | SARAM           | External |  |  |  |  |  |
| DARAM    | 1   | 1                   | 1               | 1+p      |  |  |  |  |  |
| SARAM    | 1   | 1                   | 1, 2†           | 1+p      |  |  |  |  |  |
| External | 2+d | 2+d                 | 2+d             | 4+d+p    |  |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| C        | Cycles for a Repeat (RPT) Execution of an SPL Instruction |       |         |           |  |  |  |  |  |  |  |
|----------|-----------------------------------------------------------|-------|---------|-----------|--|--|--|--|--|--|--|
| Program  |                                                           |       |         |           |  |  |  |  |  |  |  |
| Operand  | ROM                                                       | DARAM | SARAM   | External  |  |  |  |  |  |  |  |
| DARAM    | n                                                         | n     | n       | n+p       |  |  |  |  |  |  |  |
| SARAM    | n                                                         | n     | n, n+2† | n+p       |  |  |  |  |  |  |  |
| External | 2n+nd                                                     | 2n+nd | 2n+nd   | 2n+2+nd+p |  |  |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

| Example 1 | SPL | DAT5                | ;(DP = 4: a<br>;PM = 2: le |                     | ,                 |
|-----------|-----|---------------------|----------------------------|---------------------|-------------------|
|           |     |                     | <b>Before Instruction</b>  |                     | After Instruction |
|           |     | PREG                | 0FE079844h                 | PREG                | 0FE079844h        |
|           |     | Data Memory<br>205h | 4567h                      | Data Memory<br>205h | 08440h            |
| Example 2 | SPL | *,AR3               | ;(PM = 0: n                | o shift)            |                   |
|           |     |                     | <b>Before Instruction</b>  |                     | After Instruction |
|           |     | ARP                 | 2                          | ARP                 | 3                 |
|           |     | AR2                 | 205h                       | AR2                 | 205h              |
|           |     | PREG                | 0FE079844h                 | PREG                | 0FE079844h        |
|           |     | Data Memory<br>205h | 4567h                      | Data Memory<br>205h | 09844h            |

| Syntax      | SPLK<br>SPLK                                                                                                                                                                              |                       |        |              | [ <i>n</i> ]            |        |        |       |         |        | Direct<br>ndire |        |         | •      |        |       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--------|--------------|-------------------------|--------|--------|-------|---------|--------|-----------------|--------|---------|--------|--------|-------|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerlk:16-bit long immediate valueind:Select one of the following seven options:**+**0+**BR0+ |                       |        |              |                         |        |        |       |         |        |                 |        |         |        |        |       |
| Opcode      | SPI                                                                                                                                                                                       | L <b>K</b> #/         | lk, dn | na           |                         |        |        |       |         |        |                 |        |         |        |        |       |
|             | 15                                                                                                                                                                                        | 14                    | 13     | 12           | 11                      | 10     | 9      | 8     | 7       | 6      | 5               | 4      | 3       | 2      | 1      | 0     |
|             | 1                                                                                                                                                                                         | 0                     | 1      | 0            | 1                       | 1      | 1      | 0     | 0       |        |                 |        | dma     |        |        |       |
|             | <u></u>                                                                                                                                                                                   | L <b>K</b> #/         | lk in  | <b>√ I ∧</b> | <b>P</b> <sub>p</sub> ] |        |        |       | n.      |        |                 |        |         |        |        | ]     |
|             | 15                                                                                                                                                                                        | 14                    | 13     | 12 12        | 11                      | 10     | 9      | 8     | 7       | 6      | 5               | 4      | 3       | 2      | 1      | 0     |
|             | 1                                                                                                                                                                                         | 0                     | 1      | 0            | 1                       | 1      | 1      | 0     | 1       |        | ARU             |        | Ν       |        | NAR    |       |
|             |                                                                                                                                                                                           |                       |        |              |                         |        |        | I     | ĸ       |        |                 |        |         |        |        |       |
| Execution   | Note<br>Increr<br>Ik → c                                                                                                                                                                  | <sup>(p</sup><br>nent | PC, 1  | then         |                         |        | ied in | subse | ction 7 | 7.3.4, | Indirec         | t Addı | ressing | у Орсо | ode Fc | ormat |
| Status Bits | None                                                                                                                                                                                      |                       |        |              |                         |        |        |       |         |        |                 |        |         |        |        |       |
| Description | The S<br>memo                                                                                                                                                                             |                       |        |              | n all                   | ows a  | a full | 16-b  | oit pa  | ttern  | to be           | e wri  | tten i  | into a | any c  | lata  |
| Words       | 2                                                                                                                                                                                         |                       |        |              |                         |        |        |       |         |        |                 |        |         |        |        |       |
| Cycles      |                                                                                                                                                                                           |                       |        |              | Cycl                    | es for | a Si   | ngle  | SPLK    | Inst   | ructio          | on     |         |        |        |       |
|             |                                                                                                                                                                                           |                       |        |              | -                       |        |        | •     | Prog    |        |                 |        |         |        |        |       |
|             | Oper                                                                                                                                                                                      | and                   | RC     | DM           |                         | C      | ARA    | M     |         | SAF    | RAM             |        | Ex      | terna  | al     |       |
|             | DAR                                                                                                                                                                                       | ۹M                    | 2      |              |                         | 2      |        |       |         | 2      |                 |        | 2+      | 2р     |        |       |
|             | SARA                                                                                                                                                                                      | ۸M                    | 2      |              |                         | 2      |        |       |         | 2, 3   | t               |        | 2+      | 2p     |        |       |
|             | Exter                                                                                                                                                                                     | nal                   | 3+     | d            |                         | 3      | +d     |       |         | 3+d    |                 |        | 5+      | d+2p   |        |       |

<sup>†</sup> If the operand and the code are in the same SARAM block

| Example 1 | SPLK | #7FFFh,             | DAT3              | ;(DP = 6)           |                   |
|-----------|------|---------------------|-------------------|---------------------|-------------------|
|           |      |                     | Before Instructio | n                   | After Instruction |
|           |      | Data Memory<br>303h | FE07              | Data Memo<br>h 303h | ory 7FFFh         |
| Example 2 | SPLK | #1111h,             | *+,AR4            |                     |                   |
|           |      |                     | Before Instructio | า                   | After Instruction |
|           |      | ARP                 |                   | D ARP               | 4                 |
|           |      | AR0                 | 300               | h AR0               | 301h              |
|           |      | Data Memory         |                   | Data Memo           | ary               |

| Syntax      | SPM constant                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands    | constant: Value from 0 to 3 that determines the product shift mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Opcode      | 15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         1       0       1       1       1       1       1       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 |
| Execution   | Increment PC, then constant $\rightarrow$ product shift mode (PM) bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Status Bits | <u>Affects</u><br>PM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|             | This instruction is not affected by SXM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Description | The two LSBs of the instruction word are copied into the product shift mode (PM) bits of status register ST1 (bits 1 and 0 of ST1). The PM bits control the mode of the shifter at the output of the PREG. This shifter can shift the PREG output either one or four bits to the left or six bits to the right. The possible PM bit combinations and their meanings are shown in Table 8–8. When an instruction accesses the PREG value, the value first passes through the shifter, where it is shifted by the specified amount.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### Table 8–8. Product Shift Modes

1

| PM Field | Specified Product Shift                                    |
|----------|------------------------------------------------------------|
| 00       | No shift of PREG output                                    |
| 01       | PREG output to be left shifted 1 place                     |
| 10       | PREG output to be left shifted 4 places                    |
| 11       | PREG output to be right shifted 6 places and sign extended |
|          |                                                            |

The left shifts allow the product to be justified for fractional arithmetic. The right-shift-by-six mode allows up to 128 multiply accumulate processes without the possibility of overflow occurring. PM may also be loaded by an LST #1 instruction.

#### Words

Cycles

| Cycles  | Cycles for a Single SPM Instruction |                                                                                                                                                                                   |       |          |
|---------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------|
|         | ROM                                 | DARAM                                                                                                                                                                             | SARAM | External |
|         | 1                                   | 1                                                                                                                                                                                 | 1     | 1+p      |
| Example | SPM 3                               | <pre>SPM 3 ;Product register shift mode 3 (PM = 11) ;is selected causing all subsequent ;transfers from the product register (PREG) ;to be shifted to the right six places.</pre> |       |          |

| Syntax      | SQR/<br>SQR/                    |                 |                 | <b>R</b> n]          |               |                      |        |            |                 |                | Direc<br>Indire              |        |         | •     |        |       |
|-------------|---------------------------------|-----------------|-----------------|----------------------|---------------|----------------------|--------|------------|-----------------|----------------|------------------------------|--------|---------|-------|--------|-------|
| Operands    | dma:<br>n:<br>ind:              |                 | Va              | alue                 | from<br>one   | 0 to<br>of the       | 7 de   | lowing     | ting t<br>g sev | the r<br>ven c | ss<br>iext a<br>option<br>*B | s:     | ary re  | giste | ər     |       |
| Opcode      | SQ                              | RA a            | lma             |                      |               |                      |        |            |                 |                |                              |        |         |       |        |       |
| •           | 15                              | 14              | 13              | 12                   | 11            | 10                   | 9      | 8          | 7               | 6              | 5                            | 4      | 3       | 2     | 1      | 0     |
|             | 0                               | 1               | 0               | 1                    | 0             | 0                    | 1      | 0          | 0               |                |                              |        | dma     |       |        |       |
|             | SQ                              | RA ii           | nd [            | <b>AR</b> <i>n</i> ] |               |                      |        |            |                 |                |                              |        |         |       |        |       |
|             | 15                              | 14              | 13              | 12                   | 11            | 10                   | 9      | 8          | 7               | 6              | 5                            | 4      | 3       | 2     | 1      | 0     |
|             | 0                               | 1               | 0               | 1                    | 0             | 0                    | 1      | 0          | 1               |                | ARU                          |        | Ν       |       | NAR    |       |
|             | Not                             | -               | RU, N<br>bage 7 |                      | NAR a         | re defi              | ned ir | ı subse    | ection 7        | 7.3.4,         | Indirec                      | t Addi | ressing | д Орс | ode Fo | ormat |
| Execution   | Increi<br>(ACC<br>(data<br>(TRE | ) + sl<br>-merr | nifted          | l (PR<br>addre       | EG)<br>ess) - | $\rightarrow TF$     | REG    | $F) \to F$ | PREC            | à              |                              |        |         |       |        |       |
| Status Bits | <u>Affec</u><br>OVM             |                 |                 |                      |               | <i>ects</i><br>′ and | С      |            |                 |                |                              |        |         |       |        |       |
| Description | The c<br>to the<br>TREC         | accu            | mula            | ator. 7              | Then          | the a                | lddre  | essed      | data            | -              |                              |        |         |       |        |       |
| Words       | 1                               |                 |                 |                      |               |                      |        |            |                 |                |                              |        |         |       |        |       |

# Cycles

#### Cycles for a Single SQRA Instruction

|          | Program |       |       |          |  |  |  |
|----------|---------|-------|-------|----------|--|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

| Cy       | Cycles for a Repeat (RPT) Execution of an SQRA Instruction |       |         |          |  |  |  |  |  |
|----------|------------------------------------------------------------|-------|---------|----------|--|--|--|--|--|
|          | Program                                                    |       |         |          |  |  |  |  |  |
| Operand  | ROM                                                        | DARAM | SARAM   | External |  |  |  |  |  |
| DARAM    | n                                                          | n     | n       | n+p      |  |  |  |  |  |
| SARAM    | n                                                          | n     | n, n+1† | n+p      |  |  |  |  |  |
| External | n+nd                                                       | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

| Example 1 | SQRA | DATS                | 30 | ;(DP = 6: a<br>;PM = 0: no |                   |    |                   |
|-----------|------|---------------------|----|----------------------------|-------------------|----|-------------------|
|           |      |                     |    | Before Instruction         |                   |    | After Instruction |
|           |      | Data Memory         |    |                            | Data Memo         | ry |                   |
|           |      | 31Eh                |    | 0Fh                        | 31Eh              |    | 0Fh               |
|           |      | TREG                |    | 3h                         | TREG              |    | 0Fh               |
|           |      | PREG                |    | 12Ch                       | PREG              |    | 0E1h              |
|           |      | ACC [               | Х  | 1F4h                       | ACC               | 0  | 320h              |
|           |      |                     | С  |                            |                   | С  |                   |
| Example 2 | SQRA | *,AF                | ۲4 | ;(PM = 0)                  |                   |    |                   |
|           |      |                     |    | Before Instruction         |                   |    | After Instruction |
|           |      | ARP                 |    | 3                          | ARP               |    | 4                 |
|           |      | AR3                 |    | 31Eh                       | AR3               |    | 31Eh              |
|           |      | Data Memory<br>31Eh |    | 0Fh                        | Data Memo<br>31Eh | ry | 0Fh               |
|           |      | TREG                |    | 3h                         | TREG              |    | 0Fh               |
|           |      | PREG                |    | 12Ch                       | PREG              |    | 0E1h              |
|           |      | ACC                 | Х  | 1F4h                       | ACC               | 0  | 320h              |
|           |      |                     | С  |                            |                   | С  |                   |

| Syntax      | SQRS<br>SQRS                     |                 |                 | <b>{</b> n]    |               |                    |        |                   |          |                | Direct<br>Indire |        |         | •     |        |      |
|-------------|----------------------------------|-----------------|-----------------|----------------|---------------|--------------------|--------|-------------------|----------|----------------|------------------|--------|---------|-------|--------|------|
| Operands    | dma:<br>n:<br>ind:               |                 | Va              | alue           | from<br>one   | 0 to<br>of the     | 7 de   | owing             | ting t   | the r<br>ren c | ext a            | s:     | ıry re  | giste | er     |      |
| Opcode      | SQ                               | RS d            | ma              |                |               |                    |        |                   |          |                |                  |        |         |       |        |      |
| -           | 15                               | 14              | 13              | 12             | 11            | 10                 | 9      | 8                 | 7        | 6              | 5                | 4      | 3       | 2     | 1      | 0    |
|             | 0                                | 1               | 0               | 1              | 0             | 0                  | 1      | 1                 | 0        |                |                  |        | dma     |       |        |      |
|             | SQ                               | RS ir           | nd [            | AR <i>n</i> ]  |               |                    |        |                   |          |                |                  |        |         |       |        |      |
|             | 15                               | 14              | 13              | 12             | 11            | 10                 | 9      | 8                 | 7        | 6              | 5                | 4      | 3       | 2     | 1      | 0    |
|             | 0                                | 1               | 0               | 1              | 0             | 0                  | 1      | 1                 | 1        |                | ARU              |        | Ν       |       | NAR    |      |
|             | Note                             |                 | RU, N<br>bage 7 |                | NAR a         | re defii           | ned in | subse             | ection 7 | 7.3.4,         | Indirec          | t Addı | ressinų | g Opc | ode Fo | rmat |
| Execution   | Increr<br>(ACC<br>(data-<br>(TRE | ) – sł<br>∙merr | nifted          | l (PR<br>addre | EG)<br>ess) - | $\rightarrow TF$   | REG    | $) \rightarrow F$ | PREC     | à              |                  |        |         |       |        |      |
| Status Bits | <u>Affec</u><br>OVM              |                 |                 |                |               | <i>ects</i><br>and | С      |                   |          |                |                  |        |         |       |        |      |
| Description | The c<br>tracte<br>loade         | d fro           | m th            | e ac           | cum           | ulator             | r. Th  | ien th            | ne ac    | dres           | ssed             | data   |         |       |        |      |
| Words       | 1                                |                 |                 |                |               |                    |        |                   |          |                |                  |        |         |       |        |      |

# Cycles

#### Cycles for a Single SQRS Instruction

|          | Program |       |       |          |  |  |  |
|----------|---------|-------|-------|----------|--|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| C)       | Cycles for a Repeat (RPT) Execution of an SQRS Instruction |       |         |          |  |  |  |  |
|----------|------------------------------------------------------------|-------|---------|----------|--|--|--|--|
|          | Program                                                    |       |         |          |  |  |  |  |
| Operand  | ROM                                                        | DARAM | SARAM   | External |  |  |  |  |
| DARAM    | n                                                          | n     | n       | n+p      |  |  |  |  |
| SARAM    | n                                                          | n     | n, n+1† | n+p      |  |  |  |  |
| External | n+nd                                                       | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Example 1 | SQRS | DAT9                |                    | ddresses 030        |                   |
|-----------|------|---------------------|--------------------|---------------------|-------------------|
|           |      |                     | ;PM = 0: no        | shift of pro        | oduct)            |
|           |      |                     | Before Instruction |                     | After Instruction |
|           |      | Data Memory<br>309h | 08h                | Data Memory<br>309h | 08h               |
|           |      | TREG                | 1124h              | TREG                | 08h               |
|           |      | PREG                | 190h               | PREG                | 40h               |
|           |      | ACC X               | 1450h              | ACC 1               | 12C0h             |
|           |      | C                   |                    | C                   |                   |
| Example 2 | SQRS | *,AR5               | ;(PM = 0)          |                     |                   |
|           |      |                     | Before Instruction |                     | After Instruction |
|           |      | ARP                 | 3                  | ARP                 | 5                 |
|           |      | AR3                 | 309h               | AR3                 | 309h              |
|           |      | Data Memory<br>309h | 08h                | Data Memory<br>309h | 08h               |
|           |      | TREG                | 1124h              | TREG                | 08h               |
|           |      | PREG                | 190h               | PREG                | 40h               |
|           |      | ACC X               | 1450h              | ACC 1               | 12C0h             |
|           |      | С                   |                    | C                   |                   |

| Syntax      | SST #m, dmaDirect addressingSST #m, ind [, ARn]Indirect addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Operands    | dma:       7 LSBs of the data-memory address         n:       Value from 0 to 7 designating the next auxiliary register         m:       Select one of the following:         0       Indicates that ST0 will be stored         1       Indicates that ST1 will be stored         ind:       Select one of the following seven options:         *       *+       *-       *0-       *BR0+       *BR0-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| Opcode      | <b>SST #0</b> , <i>dma</i><br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0<br>1 0 0 0 1 1 1 0 0 dma                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|             | SST #0, ind [, ARn]         15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         1       0       0       1       1       1       0       1       ARU       N       NAR         Note:       ARU, N, and NAR are defined in subsection 7.3.4, Indirect Addressing Opcode Format (page 7-12).       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 |  |  |  |  |  |  |
|             | <b>SST #1</b> , <i>dma</i><br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0<br>1 0 0 0 1 1 1 1 0 dma<br><b>SST #1</b> , <i>ind</i> [, <b>AR</b> <i>n</i> ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|             | 15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         1       0       0       1       1       1       1       ARU       N       NAR         Note: ARU, N, and NAR are defined in subsection 7.3.4, Indirect Addressing Opcode Format (page 7-12).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| Execution   | Increment PC, then (status register STm) $\rightarrow$ data-memory address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| Status Bits | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Description | Status register ST0 or ST1 (whichever is specified) is stored in data memory.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|             | In direct addressing mode, the specified status register is always stored in page 0, regardless of the value of the data page pointer (DP) in ST0. Although the processor automatically accesses page 0, the DP is not physically modified; this allows the DP value to be stored unchanged when ST0 is stored. The specific storage location within page 0 is given in the instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|             | In indirect addressing mode, the storage address is obtained from the auxiliary register selected; thus, the specified status register contents can be stored to an address on any page in data memory.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| PRELIMINARY | Assembly Language Instructions 8-171                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |

1

Status registers ST0 and ST1 are defined in Section 3.5, *Status Registers ST0 and ST1*, on page 3-15.

----

Words

Cycles

| Program  |     |       |       |          |  |  |  |  |
|----------|-----|-------|-------|----------|--|--|--|--|
| Operand  | ROM | DARAM | SARAM | External |  |  |  |  |
| DARAM    | 1   | 1     | 1     | 1+p      |  |  |  |  |
| SARAM    | 1   | 1     | 1, 2† | 1+p      |  |  |  |  |
| External | 2+d | 2+d   | 2+d   | 4+d+p    |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

| Cycles for a Repeat (RPT) Exec | ution of an SST Instruction |
|--------------------------------|-----------------------------|
|--------------------------------|-----------------------------|

|          | Program |       |         |           |  |  |  |  |
|----------|---------|-------|---------|-----------|--|--|--|--|
| Operand  | ROM     | DARAM | SARAM   | External  |  |  |  |  |
| DARAM    | n       | n     | n       | n+p       |  |  |  |  |
| SARAM    | n       | n     | n, n+2† | n+p       |  |  |  |  |
| External | 2n+nd   | 2n+nd | 2n+nd   | 2n+2+nd+p |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

Example 1 #0,96 SST (Direct addressing: data page 0 ;accessed automatically) **Before Instruction** After Instruction 0A408h 0A408h ST0 ST0 Data Memory Data Memory 0Ah 0A408h 60h 60h Example 2 SST #1,\*,AR7 (Indirect addressing) **Before Instruction** After Instruction ARP ARP 7 0 AR0 300h AR0 300h ST1 2580h ST1 2580h Data Memory Data Memory 0h 2580h 300h 300h

| Syntax   | SUB (<br>SUB (<br>SUB (<br>SUB (<br>SUB (<br>SUB ( | dma,<br>nd [,<br>nd, <b>1</b><br>‡k | <b>16</b><br>shift<br>6[, <b>A</b> | [, AR<br>[R <i>n</i> ]                | n]]                               |                               |                                   |                                     |                                        |               | Direct<br>Direct<br>Indire<br>Indire<br>Short<br>Long | t with<br>ct ac<br>ct w<br>imm | n left<br>ddres<br>ith lef<br>nediat | shift<br>sing<br>t shi<br>te |               |       |
|----------|----------------------------------------------------|-------------------------------------|------------------------------------|---------------------------------------|-----------------------------------|-------------------------------|-----------------------------------|-------------------------------------|----------------------------------------|---------------|-------------------------------------------------------|--------------------------------|--------------------------------------|------------------------------|---------------|-------|
| Operands | dma:<br>shift:<br>n:<br>k:<br>Ik:<br>ind:          |                                     | Le<br>Va<br>8-<br>16               | eft sh<br>alue f<br>bit sl<br>6-bit l | iift va<br>from<br>hort i<br>long | 0 to<br>mme<br>imme<br>of the | rom (<br>7 des<br>diate<br>ediate | 0 to 1<br>signa<br>e valu<br>e valu | I 5 (de<br>ting t<br>le<br>ue<br>g sev | efau<br>the r | Its to (<br>next a                                    | uxilia                         | ary re                               | giste                        | er            |       |
| Opcode   | SUE                                                | 3 dm                                | na [,s                             | hift]                                 |                                   |                               |                                   |                                     |                                        |               |                                                       |                                |                                      |                              |               |       |
|          | 15                                                 | 14                                  | 13                                 | 12                                    | 11                                | 10                            | 9                                 | 8                                   | 7                                      | 6             | 5                                                     | 4                              | 3                                    | 2                            | 1             | 0     |
|          | 0                                                  | 0                                   | 1                                  | 1                                     |                                   | sh                            | nift                              |                                     | 0                                      |               |                                                       |                                | dma                                  |                              |               |       |
|          | 9119                                               | a dm                                | <i>ia,</i> 16                      | :                                     |                                   |                               |                                   |                                     |                                        |               |                                                       |                                |                                      |                              |               |       |
|          | 15                                                 | 14                                  | 13                                 | ,<br>12                               | 11                                | 10                            | 9                                 | 8                                   | 7                                      | 6             | 5                                                     | 4                              | 3                                    | 2                            | 1             | 0     |
|          |                                                    | 1                                   | 1                                  | 0                                     | 0                                 | 1                             | 0                                 | 1                                   | 0                                      |               | 0                                                     |                                | dma                                  | -                            |               |       |
|          |                                                    |                                     |                                    | -                                     | -                                 |                               | -                                 |                                     | -                                      |               |                                                       |                                |                                      |                              |               |       |
|          | SUE                                                | <b>3</b> ind                        | l [, sł                            | hift [,                               | AR                                | [[י                           |                                   |                                     |                                        |               |                                                       |                                |                                      |                              |               |       |
|          | 15                                                 | 14                                  | 13                                 | 12                                    | 11                                | 10                            | 9                                 | 8                                   | 7                                      | 6             | 5                                                     | 4                              | 3                                    | 2                            | 1             | 0     |
|          | 0                                                  | 0                                   | 1                                  | 1                                     |                                   | sh                            | nift                              |                                     | 1                                      |               | ARU                                                   |                                | Ν                                    |                              | NAR           |       |
|          | Note                                               | (p                                  | age 7                              | -12).                                 |                                   | re defir                      | ned in                            | subse                               | ection 7                               | 7.3.4         | Indirec                                               | t Add                          | ressing                              | д Орс                        | ode Fo        | ormat |
|          |                                                    |                                     | -                                  | , <b>AR</b> /                         | -                                 |                               |                                   |                                     |                                        |               |                                                       |                                |                                      |                              |               |       |
|          | 15                                                 | 14                                  | 13                                 | 12                                    | 11                                | 10                            | 9                                 | 8                                   | 7                                      | 6             | 5                                                     | 4                              | 3                                    | 2                            |               | 0     |
|          | 0<br>Note                                          |                                     | 1<br>RU, N<br>bage 7               |                                       | 0<br>NAR ai                       | 1<br>re defir                 | 0<br>ned in                       | 1<br>subse                          | 1<br>ection 7                          | 7.3.4         | ARU<br>Indirec                                        | t Add                          | N<br>N                               | g Opc                        | NAR<br>ode Fo |       |
|          | 0.17                                               |                                     | -                                  |                                       |                                   |                               |                                   |                                     |                                        |               |                                                       |                                |                                      |                              |               |       |
|          |                                                    | 3 #k                                | 10                                 | 10                                    | 4.4                               | 10                            | ~                                 | 0                                   | 7                                      | ~             | -                                                     | 4                              | 0                                    | 0                            |               | 0     |
|          | 15                                                 | 14                                  | 13                                 | 12                                    | 11                                | 10                            | 9                                 | 8                                   | 7                                      | 6             | 5                                                     | 4                              | 3<br>k                               | 2                            | 1             | 0     |
|          |                                                    | -                                   | · ·                                |                                       | 1                                 | 0                             |                                   | 0                                   |                                        |               |                                                       |                                |                                      |                              |               |       |
|          |                                                    |                                     | [, sh                              | -                                     |                                   |                               |                                   |                                     |                                        |               |                                                       |                                |                                      |                              |               |       |
|          | 15                                                 |                                     | 13                                 |                                       | 11                                | 10                            | 9                                 | 8                                   | 7                                      | 6             | 5                                                     | 4                              | 3                                    | 2                            |               | 0     |
|          | 1                                                  | 0                                   | 1                                  | 1                                     | 1                                 | 1                             | 1                                 | 1                                   | 1                                      | 0             | 1                                                     | 0                              |                                      | S                            | hift          |       |
|          |                                                    |                                     |                                    |                                       |                                   |                               |                                   | I                                   | k                                      |               |                                                       |                                |                                      |                              |               |       |

| Execution   |                                             | <br>nory address) $	imes$ 2 <sup>shift</sup> ) $ ightarrow$ ACC<br>nory address) $	imes$ 2 <sup>16</sup> ) $ ightarrow$ ACC                                                 | <u>Addressing mode</u><br>Direct or indirect<br>Direct or indirect<br>(shift of 16) |
|-------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
|             | $(ACC)-k \to ACC$                           |                                                                                                                                                                             | Short immediate                                                                     |
|             | (ACC) – lk $	imes$ 2 <sup>shift</sup> -     | $\rightarrow$ ACC                                                                                                                                                           | Long immediate                                                                      |
| Status Bits | <u>Affected by</u><br>OVM and SXM           | <u>Affects</u><br>OV and C                                                                                                                                                  | <u>Addressing mode</u><br>Direct or indirect                                        |
|             | OVM                                         | OV and C                                                                                                                                                                    | Short immediate                                                                     |
|             | OVM and SXM                                 | OV and C                                                                                                                                                                    | Long immediate                                                                      |
| Description | addressed data-mer<br>tracted from the acc  | and long immediate addressing,<br>mory location or a 16-bit constant ar<br>cumulator. During shifting, low-orde<br>sign extended if SXM = 1 and zero<br>in the accumulator. | e left shifted and sub-<br>er bits are zero filled.                                 |
|             | from the accumulato                         | ddressing is used, an 8-bit positive o<br>r. In this case, no shift value may be s<br>v SXM, and the instruction is not rep                                                 | specified, the subtrac-                                                             |
|             | ates a borrow and is a 16-bit shift is spec | bit is cleared (C = 0) if the result of t<br>is set (C = 1) if it does not generate<br>dified with the subtraction, the instru-<br>difference but does not affect the carry | a borrow. However, if action clears the carry                                       |
| Words       | <u>Words</u><br>1                           |                                                                                                                                                                             | <u>Addressing mode</u><br>Direct, indirect<br>or short immediate                    |
|             | 2                                           |                                                                                                                                                                             | Long immediate                                                                      |

| Cyci | es |
|------|----|
|------|----|

#### Cycles for a Single SUB Instruction (Using Direct and Indirect Addressing)

|          | Program |       |       |          |  |  |
|----------|---------|-------|-------|----------|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block.

# Cycles for a Repeat (RPT) Execution of an SUB Instruction (Using Direct and Indirect Addressing)

|          | Program |       |         |          |  |  |
|----------|---------|-------|---------|----------|--|--|
| Operand  | ROM     | DARAM | SARAM   | External |  |  |
| DARAM    | n       | n     | n       | n+p      |  |  |
| SARAM    | n       | n     | n, n+1† | n+p      |  |  |
| External | n+nd    | n+nd  | n+nd    | n+1+p+nd |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block.

# Cycles for a Single SUB Instruction (Using Short Immediate Addressing)

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| 1   | 1     | 1     | 1+p      |

#### Cycles for a Single SUB Instruction (Using Long Immediate Addressing)

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| 2   | 2     | 2     | 2+2p     |

| Example 1 | SUB | DAT80               | ;(DP = 8: ad<br>;SXM=0: sign |                     |                   |
|-----------|-----|---------------------|------------------------------|---------------------|-------------------|
|           |     |                     | Before Instruction           |                     | After Instruction |
|           | [   | Data Memory         |                              | Data Memory         |                   |
|           |     | 450h                | 11h                          | 450h                | 11h               |
|           |     | ACC X               | 24h                          | ACC 1               | 13h               |
|           |     | С                   |                              | C                   |                   |
| Example 2 | SUB | *-,1,AR0            | ;(Left shift                 | t by 1, SXM         | = 0)              |
|           |     |                     | Before Instruction           |                     | After Instruction |
|           |     | ARP [               | 7                            | ARP                 | 0                 |
|           |     | AR7                 | 301h                         | AR7                 | 300h              |
|           | Γ   | Data Memory<br>301h | 04h                          | Data Memory<br>301h | 04h               |
|           |     | ACC X               | 09h                          | ACC 1               | 01h               |
|           |     | С                   |                              | С                   |                   |
| Example 3 | SUB | #8h                 | ;(SXM = 1: s                 | sign-extens:        | ion mode)         |
|           |     |                     | Before Instruction           |                     | After Instruction |
|           |     | ACC X               | 07h                          | ACC 0               | FFFFFFFh          |
|           |     | С                   |                              | С                   |                   |
| Example 4 | SUB | #OFFFh,4            | ;(Left shift                 | t by four, S        | SXM = 0)          |
|           |     |                     | Before Instruction           |                     | After Instruction |
|           |     | ACC X               | 0FFFh                        | ACC 1               | 0Fh               |
|           |     | С                   |                              | C                   |                   |

| Syntax      | SUBI<br>SUBI                                                                                                                                                                                                                                                                                                                                                           |              |       | <b>R</b> <i>n</i> ] |        |                    |              |        |                 |       | Direct<br>Indire |       |        | -     |        |       |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------|---------------------|--------|--------------------|--------------|--------|-----------------|-------|------------------|-------|--------|-------|--------|-------|
| Operands    | dma:<br>n:<br>ind:                                                                                                                                                                                                                                                                                                                                                     |              | V     | alue                | from   | 0 to<br>of the     | 7 de         | -      | ting t<br>g sev | he r  | ext a            |       | ary re | giste | ər     |       |
| Opcode      | SU                                                                                                                                                                                                                                                                                                                                                                     | BB a         | lma   |                     |        |                    |              |        |                 |       |                  |       |        |       |        |       |
|             | 15                                                                                                                                                                                                                                                                                                                                                                     | 14           | 13    | 12                  | 11     | 10                 | 9            | 8      | 7               | 6     | 5                | 4     | 3      | 2     | 1      | 0     |
|             | 0                                                                                                                                                                                                                                                                                                                                                                      | 1            | 1     | 0                   | 0      | 1                  | 0            | 0      | 0               |       |                  |       | dma    |       |        |       |
|             | SU                                                                                                                                                                                                                                                                                                                                                                     | BB ii        | nd [  | ARn]                |        |                    |              |        |                 |       |                  |       |        |       |        |       |
|             | 15                                                                                                                                                                                                                                                                                                                                                                     | 14           | 13    | 12                  | 11     | 10                 | 9            | 8      | 7               | 6     | 5                | 4     | 3      | 2     | 1      | 0     |
|             | 0                                                                                                                                                                                                                                                                                                                                                                      | 1            | 1     | 0                   | 0      | 1                  | 0            | 0      | 1               |       | ARU              |       | Ν      |       | NAR    |       |
| Execution   | Not<br>Incre<br>(ACC                                                                                                                                                                                                                                                                                                                                                   | ہ)<br>ment   | PC,   | '-12).<br>then      |        |                    |              |        |                 |       | Indirec          |       |        |       | ode Fo | ormat |
| Status Bits | <u>Affec</u><br>OVM                                                                                                                                                                                                                                                                                                                                                    | <u>ted b</u> | Y     |                     |        | <i>ects</i><br>and | С            |        |                 |       |                  |       |        |       |        |       |
|             | This i                                                                                                                                                                                                                                                                                                                                                                 | nstru        | ction | is no               | ot aff | ected              | by           | SXM.   |                 |       |                  |       |        |       |        |       |
| Description | The content of the addressed data-memory location and the logical inversion of the carry bit is subtracted from the accumulator with sign extension suppressed. The carry bit is then affected in the normal manner: the carry bit is cleared ( $C = 0$ ) if the result of the subtraction generates a borrow and is set ( $C = 1$ ) if it does not generate a borrow. |              |       |                     |        |                    | up-<br>it is |        |                 |       |                  |       |        |       |        |       |
|             | The S                                                                                                                                                                                                                                                                                                                                                                  | UBB          | instr | uctio               | n car  | n be u             | sed          | in pei | rform           | ing r | nultipl          | le-pr | ecisio | on ar | rithme | etic. |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                                      |              |       |                     |        |                    |              |        |                 |       |                  |       |        |       |        |       |

#### Cycles

#### Cycles for a Single SUBB Instruction

|          | Program |       |       |          |  |  |  |
|----------|---------|-------|-------|----------|--|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

|           | Cy             | Cycles for a Repeat (RPT) Execution of an SUBB Instruction |                           |              |                   |  |  |  |  |
|-----------|----------------|------------------------------------------------------------|---------------------------|--------------|-------------------|--|--|--|--|
|           |                |                                                            | Pr                        | ogram        |                   |  |  |  |  |
|           | Operand        | ROM                                                        | DARAM                     | SARAM        | External          |  |  |  |  |
|           | DARAM          | n                                                          | n                         | n            | n+p               |  |  |  |  |
|           | SARAM          | n                                                          | n                         | n, n+1†      | n+p               |  |  |  |  |
|           | External       | n+nd                                                       | n+nd                      | n+nd         | n+1+p+nd          |  |  |  |  |
|           | † If the opera | and and the coo                                            | de are in the same SAR    | AM block     |                   |  |  |  |  |
| Example 1 | SUBB           | DAT5                                                       | ;(DP = 8: a               | ddresses 040 | 0h-047Fh)         |  |  |  |  |
|           |                |                                                            | <b>Before Instruction</b> |              | After Instruction |  |  |  |  |
|           |                | Memory                                                     |                           | Data Memory  |                   |  |  |  |  |
|           |                | 405h                                                       | 06h                       | 405h         | 06h               |  |  |  |  |
|           |                | ACC 0                                                      | 06h                       | ACC 0        | 0FFFFFFFh         |  |  |  |  |
|           |                | С                                                          |                           | С            |                   |  |  |  |  |
| Example 2 | SUBB           | *                                                          |                           |              |                   |  |  |  |  |
|           |                |                                                            | Before Instruction        |              | After Instruction |  |  |  |  |
|           |                | ARP                                                        | 6                         | ARP          | 6                 |  |  |  |  |
|           |                | AR6                                                        | 301h                      | AR6          | 301h              |  |  |  |  |
|           | Data           | Memory                                                     |                           | Data Memory  |                   |  |  |  |  |
|           | :              | 301h                                                       | 02h                       | 301h         | 02h               |  |  |  |  |
|           |                | ACC 1                                                      | 04h                       | ACC 1        | 02h               |  |  |  |  |
|           |                | С                                                          |                           | С            |                   |  |  |  |  |

In the first example, C is originally zeroed, presumably from the result of a previous subtract instruction that performed a borrow. The effective operation performed was 6 - 6 - (1) = -1, generating another borrow (resetting carry) in the process. In the second example, no borrow was previously generated (C = 1), and the result from the subtract instruction does not generate a borrow.

| Syntax      | SUBC dmaDirect addressingSUBC ind [, ARn]Indirect addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+**0+**BR0+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Opcode      | SUBC dma                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|             | 15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         0       0       0       1       0       1       0       0       dma                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|             | SUBC ind [, ARn]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|             | 0 0 0 1 0 1 0 1 ARU N NAR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|             | Note: ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Execution   | For $(ACC) \ge 0$ and $(data-memory address) \ge 0$ :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|             | Increment PC, then<br>(ACC) – [(data-memory address) × 2 <sup>15</sup> ] $\rightarrow$ ALU output<br>If ALU output ≥ 0<br>Then (ALU output) × 2 + 1 $\rightarrow$ ACC<br>Else (ACC) × 2 $\rightarrow$ ACC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Status Bits | <u>Affects</u><br>OV and C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Description | The SUBC instruction performs conditional subtraction, which can be used for<br>division as follows: Place a positive 16-bit dividend in the low accumulator and<br>clear the high accumulator. Place a 16-bit positive divisor in data memory.<br>Execute SUBC 16 times. After completion of the last SUBC, the quotient of the<br>division is in the lower-order 16 bits of the accumulator, and the remainder is<br>in the higher-order 16 bits of the accumulator. For negative accumulator and/or<br>data-memory values, SUBC cannot be used for division.<br>If the 16-bit dividend contains fewer than 16 significant bits, the dividend may<br>be placed in the accumulator and left shifted by the number of leading non-<br>significant 0s. The number of executions of SUBC is reduced from 16 by that<br>number. One leading 0 is always significant.<br>SUBC operations performed as previously stated are not affected by the sign-<br>extension mode bit (SXM). |
| PRELIMINARY | Assembly Language Instructions 8-179                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

1

SUBC affects OV but is not affected by OVM; therefore, the accumulator does not saturate upon positive or negative overflows when executing this instruction. The carry bit is affected in the normal manner during this instruction: the carry bit is cleared (C = 0) if the result of the subtraction generates a borrow and is set (C = 1) if it does not generate a borrow.

# Words

Cycles

| Cycles for a Single SUBC Instruction |         |       |       |          |  |  |  |  |
|--------------------------------------|---------|-------|-------|----------|--|--|--|--|
|                                      | Program |       |       |          |  |  |  |  |
| Operand                              | ROM     | DARAM | SARAM | External |  |  |  |  |
| DARAM                                | 1       | 1     | 1     | 1+p      |  |  |  |  |
| SARAM                                | 1       | 1     | 1, 2† | 1+p      |  |  |  |  |
| External                             | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

|           | C              | Cycles for a Repeat (RPT) Execution of an SUBC Instruction |                           |             |                   |  |  |  |  |  |  |
|-----------|----------------|------------------------------------------------------------|---------------------------|-------------|-------------------|--|--|--|--|--|--|
|           |                |                                                            | Program                   |             |                   |  |  |  |  |  |  |
|           | Operand        | ROM                                                        | DARAM SARAM               |             | External          |  |  |  |  |  |  |
|           | DARAM          | n                                                          | n                         | n           | n+p               |  |  |  |  |  |  |
|           | SARAM          | n                                                          | n                         | n, n+1†     | n+p               |  |  |  |  |  |  |
|           | External       | n+nd                                                       | n+nd                      | n+nd        | n+1+p+nd          |  |  |  |  |  |  |
|           | † If the opera | and and the co                                             | de are in the same SAR    | AM block    |                   |  |  |  |  |  |  |
| Example 1 | SUBC           | DAT2                                                       | ;(DP = 6)                 |             |                   |  |  |  |  |  |  |
|           |                |                                                            | <b>Before Instruction</b> |             | After Instruction |  |  |  |  |  |  |
|           | Data           | a Memory                                                   |                           | Data Memory |                   |  |  |  |  |  |  |
|           |                | 302h                                                       | 01h                       | 302h        | 01h               |  |  |  |  |  |  |
|           |                | ACC X                                                      | 04h                       | ACC 0       | 08h               |  |  |  |  |  |  |
|           |                | С                                                          |                           | C           |                   |  |  |  |  |  |  |
| Example 2 | RPT            | #15                                                        |                           |             |                   |  |  |  |  |  |  |
|           | SUBC           | *                                                          |                           |             |                   |  |  |  |  |  |  |
|           |                |                                                            | <b>Before Instruction</b> |             | After Instruction |  |  |  |  |  |  |
|           |                | ARP                                                        | 3                         | ARP         | 3                 |  |  |  |  |  |  |
|           |                | AR3                                                        | 1000h                     | AR3         | 1000h             |  |  |  |  |  |  |
|           | Data           | a Memory                                                   |                           | Data Memory |                   |  |  |  |  |  |  |
|           |                | 1000h                                                      | 07h                       | 1000h       | 07h               |  |  |  |  |  |  |
|           |                | ACC X                                                      | 41h                       | ACC 1       | 20009h            |  |  |  |  |  |  |
|           |                | С                                                          |                           | С           |                   |  |  |  |  |  |  |

| Syntax      | SUBS<br>SUBS                                                                                                                                                                                                                                                                                                                                |              |               | <b>R</b> n]    |        |                    |      |       |                 |        | Direc<br>Indire |       |         | •     |        |      |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------|----------------|--------|--------------------|------|-------|-----------------|--------|-----------------|-------|---------|-------|--------|------|
| Operands    | dma:<br>n:<br>ind:                                                                                                                                                                                                                                                                                                                          |              | V             | alue           | from   | of the             | 7 de | signa | ting t<br>g sev | the r  | next a option   |       | ary re  | giste | er     |      |
| Opcode      | SU                                                                                                                                                                                                                                                                                                                                          | BS a         | lma           |                |        |                    |      |       |                 |        |                 |       |         |       |        |      |
|             | 15                                                                                                                                                                                                                                                                                                                                          | 14           | 13            | 12             | 11     | 10                 | 9    | 8     | 7               | 6      | 5               | 4     | 3       | 2     | 1      | 0    |
|             | 0                                                                                                                                                                                                                                                                                                                                           | 1            | 1             | 0              | 0      | 1                  | 1    | 0     | 0               |        |                 |       | dma     |       |        |      |
|             | SU                                                                                                                                                                                                                                                                                                                                          | BS ir        | nd [          | AR <i>n</i> ]  |        |                    |      |       |                 |        |                 |       |         |       |        |      |
|             | 15                                                                                                                                                                                                                                                                                                                                          | 14           | 13            | 12             | 11     | 10                 | 9    | 8     | 7               | 6      | 5               | 4     | 3       | 2     | 1      | 0    |
|             | 0                                                                                                                                                                                                                                                                                                                                           | 1            | 1             | 0              | 0      | 1                  | 1    | 0     | 1               |        | ARU             |       | Ν       |       | NAR    |      |
| Execution   | Note<br>Increr<br>(ACC                                                                                                                                                                                                                                                                                                                      | ہ)<br>nent   | page 7<br>PC, | '-12).<br>then |        |                    |      |       |                 | 7.3.4, | Indirec         | n Add | ressing | y Opc | oue ru | "mai |
| Status Bits | <u>Affect</u><br>OVM                                                                                                                                                                                                                                                                                                                        | <u>ted b</u> | ¥             |                | -      | <i>ects</i><br>and | С    |       |                 |        |                 |       |         |       |        |      |
|             | This i                                                                                                                                                                                                                                                                                                                                      | nstru        | ction         | is no          | ot aff | ected              | by S | SXM.  |                 |        |                 |       |         |       |        |      |
| Description | The content of the specified data-memory location is subtracted from the accu-<br>mulator with sign extension suppressed. The data is treated as a 16-bit<br>unsigned number, regardless of SXM. The accumulator behaves as a signed<br>number. SUBS produces the same results as a SUB instruction with SXM = 0<br>and a shift count of 0. |              |               |                |        |                    |      |       | 8-bit<br>ned    |        |                 |       |         |       |        |      |
|             | The c<br>borro                                                                                                                                                                                                                                                                                                                              | -            |               |                |        | •                  | ,    |       |                 |        |                 |       | ction   | gen   | erate  | s a  |
| Words       | 1                                                                                                                                                                                                                                                                                                                                           |              |               |                |        |                    |      |       |                 |        |                 |       |         |       |        |      |

#### Cycles

#### Cycles for a Single SUBS Instruction

|          | Program |       |       |          |  |  |  |
|----------|---------|-------|-------|----------|--|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

#### Cycles for a Repeat (RPT) Execution of an SUBS Instruction

|          | Program |       |         |          |  |  |  |
|----------|---------|-------|---------|----------|--|--|--|
| Operand  | ROM     | DARAM | SARAM   | External |  |  |  |
| DARAM    | n       | n     | n       | n+p      |  |  |  |
| SARAM    | n       | n     | n, n+1† | n+p      |  |  |  |
| External | n+nd    | n+nd  | n+nd    | n+1+p+nd |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block



| Syntax      | SUBT<br>SUBT                                                                                                                                                                                                                                                                                                     |                         | AR               | n]          |            |                      |       |        |        |       | Direc <sup>:</sup><br>Indire |        |        | -     |          |      |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------------|-------------|------------|----------------------|-------|--------|--------|-------|------------------------------|--------|--------|-------|----------|------|
| Operands    | dma:<br>n:<br>ind:                                                                                                                                                                                                                                                                                               |                         | Va               | lue f       | rom<br>one | 0 to 7<br>of the     | 7 de  | signa  | g sev  | the n | ext a ption                  |        | ary re | giste | ۶r       |      |
| Opcode      | SUB                                                                                                                                                                                                                                                                                                              | <b>T</b> dn             | na               |             |            |                      |       |        |        |       |                              |        |        |       |          |      |
|             | 15                                                                                                                                                                                                                                                                                                               | 14                      | 13               | 12          | 11         | 10                   | 9     | 8      | 7      | 6     | 5                            | 4      | 3      | 2     | 1        | 0    |
|             | 0                                                                                                                                                                                                                                                                                                                | I                       | 1                | 0           | 0          | I                    | 1     | I      | 0      |       |                              |        | dma    |       |          |      |
|             | SUB                                                                                                                                                                                                                                                                                                              |                         | -                | -           |            |                      |       |        |        |       |                              |        |        |       |          |      |
|             | 15                                                                                                                                                                                                                                                                                                               | 14                      | 13<br>1          | 12<br>0     | 11<br>0    | 10                   | 9     | 8      | 7      | 6     | 5<br>ARU                     | 4      | 3<br>N | 2     | 1<br>NAR | 0    |
|             | Note:                                                                                                                                                                                                                                                                                                            | -                       | •                | -           | -          |                      |       | -      |        | 734   | Indired                      | t Addı |        | n Onc |          |      |
| Execution   | Increm                                                                                                                                                                                                                                                                                                           | <sub>(pa</sub><br>ent F | ige 7-<br>PC, tl | 12).<br>hen |            |                      |       |        |        |       |                              |        |        |       |          |      |
|             | If SXM                                                                                                                                                                                                                                                                                                           | = 1<br>n (da<br>= 0     | ta-m             | iemc        | ory a      | ddres                | s) is | s sigr | 1-exte | ende  |                              |        | ,)     |       |          |      |
| Status Bits | <u>Affecte</u><br>OVM a                                                                                                                                                                                                                                                                                          |                         |                  |             | -          | <u>ects</u><br>' and | С     |        |        |       |                              |        |        |       |          |      |
| Description | The data-memory value is left shifted and subtracted from the accumulator.<br>The left shift is defined by the four LSBs of TREG, resulting in shift options from<br>0 to 15 bits. The result replaces the accumulator contents. Sign extension on<br>the data-memory value is controlled by the SXM status bit. |                         |                  |             |            |                      |       |        |        |       |                              |        |        |       |          |      |
|             | The ca<br>borrow                                                                                                                                                                                                                                                                                                 | -                       |                  |             |            |                      |       |        |        |       |                              |        | ction  | gen   | erate    | es a |
| Words       | 1                                                                                                                                                                                                                                                                                                                |                         |                  |             |            |                      |       |        |        |       |                              |        |        |       |          |      |

| Cycles | S |
|--------|---|
|--------|---|

#### Cycles for a Single SUBT Instruction

|          | Program |       |       |          |  |  |  |
|----------|---------|-------|-------|----------|--|--|--|
| Operand  | ROM     | DARAM | SARAM | External |  |  |  |
| DARAM    | 1       | 1     | 1     | 1+p      |  |  |  |
| SARAM    | 1       | 1     | 1, 2† | 1+p      |  |  |  |
| External | 1+d     | 1+d   | 1+d   | 2+d+p    |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block.

#### Cycles for a Repeat (RPT) Execution of an SUBT Instruction

|          | Program |       |         |          |  |  |  |
|----------|---------|-------|---------|----------|--|--|--|
| Operand  | ROM     | DARAM | SARAM   | External |  |  |  |
| DARAM    | n       | n     | n       | n+p      |  |  |  |
| SARAM    | n       | n     | n, n+1† | n+p      |  |  |  |
| External | n+nd    | n+nd  | n+nd    | n+1+p+nd |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block.

Example 1 SUBT DAT127 ; (DP = 5: addresses 0280h-02FFh) **Before Instruction** After Instruction Data Memory Data Memory 2FFh 06h 2FFh 06h TREG 08h TREG 08h Χ 1 0F7A5h ACC 0FDA5h ACC С С Example 2 SUBT \* **Before Instruction** After Instruction ARP ARP 1 1 AR1 800h AR1 800h Data Memory Data Memory 800h 01h 800h 01h TREG TREG 08h 08h 0 FFFFFF00h ACC Х 0h ACC С С

| Syntax      | TBLR dmaDirect addressingTBLR ind [, ARn]Indirect addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+*-*0+* BR0+*BR0-                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| Opcode      | <b>TBLR</b> dma<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|             | 1 0 1 0 0 1 1 0 0 dma                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|             | TBLR ind [, ARn]         15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         1       0       1       0       1       1       0       1       ARU       N       NAR                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|             | <b>Note:</b> ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| Execution   | Increment PC, then                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|             | $\begin{array}{l} (PC) \rightarrow MSTACK \\ (ACC(15:0)) \rightarrow PC \\ (pma) \rightarrow data\text{-memory address} \\ For indirect, modify (current AR) and (ARP) as specified, \\ (PC) + 1 \rightarrow PC \end{array}$                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|             | While (repeat counter) $\neq 0$<br>(pma) $\rightarrow$ data-memory address<br>For indirect, modify (current AR) and (ARP) as specified,<br>(PC) + 1 $\rightarrow$ PC<br>(repeat counter) -1 $\rightarrow$ repeat counter.                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|             | $(MSTACK) \rightarrow PC$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| Status Bits | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| Description | None<br>The TBLR instruction transfers a word from a location in program memory to<br>a data-memory location specified by the instruction. The program-memory<br>address is defined by the low-order 16 bits of the accumulator. For this opera-<br>tion, a read from program memory is performed, followed by a write to data<br>memory. When repeated with the repeat (RPT) instruction, TBLR effectively<br>becomes a single-cycle instruction, and the program counter that was loaded<br>with (ACC(15:0)) is incremented once each cycle. |  |  |  |  |  |  |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |

#### TBLR Table Read

# Cycles

| Cycles for a Single TBLR Instruction       |                                      |                                      |                                            |                                                         |  |  |  |
|--------------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------------|---------------------------------------------------------|--|--|--|
|                                            |                                      | I                                    | Program                                    |                                                         |  |  |  |
| Operand                                    | ROM                                  | DARAM                                | SARAM                                      | External                                                |  |  |  |
| Source: DARAM/ROM Destination: DARAM       | 3                                    | 3                                    | 3                                          | 3+p <sub>code</sub>                                     |  |  |  |
| Source: SARAM<br>Destination: DARAM        | 3                                    | 3                                    | 3                                          | 3+p <sub>code</sub>                                     |  |  |  |
| Source: External<br>Destination: DARAM     | 3+p <sub>src</sub>                   | 3+p <sub>SrC</sub>                   | 3+p <sub>SrC</sub>                         | 3+p <sub>src</sub> +p <sub>code</sub>                   |  |  |  |
| Source: DARAM/ROM<br>Destination: SARAM    | 3                                    | 3                                    | 3<br>4†                                    | 3+p <sub>code</sub>                                     |  |  |  |
| Source: SARAM<br>Destination: SARAM        | 3                                    | 3                                    | 3<br>4†                                    | 3+p <sub>code</sub>                                     |  |  |  |
| Source: External<br>Destination: SARAM     | 3+p <sub>src</sub>                   | 3+p <sub>src</sub>                   | 3+p <sub>src</sub><br>4+p <sub>src</sub> † | 3+p <sub>src</sub> +p <sub>code</sub>                   |  |  |  |
| Source: DARAM/ROM<br>Destination: External | 4+d <sub>dst</sub>                   | 4+d <sub>dst</sub>                   | 4+d <sub>dst</sub>                         | 6+d <sub>dst</sub> +p <sub>code</sub>                   |  |  |  |
| Source: SARAM<br>Destination: External     | 4+d <sub>dst</sub>                   | 4+d <sub>dst</sub>                   | 4+d <sub>dst</sub>                         | 6+d <sub>dst</sub> +p <sub>code</sub>                   |  |  |  |
| Source: External<br>Destination: External  | 4+p <sub>src</sub> +d <sub>dst</sub> | 4+p <sub>src</sub> +d <sub>dst</sub> | 4+p <sub>src</sub> +d <sub>dst</sub>       | 6+p <sub>src</sub> +d <sub>dst</sub> +p <sub>code</sub> |  |  |  |

. . .

<sup>†</sup> If the destination operand and the code are in the same SARAM block

| Cycles for a Repeat (RPT) Execution of a TBLR Instruction |                       |                       |                       |                                          |  |  |  |  |
|-----------------------------------------------------------|-----------------------|-----------------------|-----------------------|------------------------------------------|--|--|--|--|
|                                                           |                       |                       | Program               |                                          |  |  |  |  |
| Operand                                                   | ROM                   | DARAM                 | SARAM                 | External                                 |  |  |  |  |
| Source: DARAM/ROM Destination: DARAM                      | n+2                   | n+2                   | n+2                   | n+2+p <sub>code</sub>                    |  |  |  |  |
| Source: SARAM<br>Destination: DARAM                       | n+2                   | n+2                   | n+2                   | n+2+p <sub>code</sub>                    |  |  |  |  |
| Source: External<br>Destination: DARAM                    | n+2+np <sub>src</sub> | n+2+np <sub>src</sub> | n+2+np <sub>src</sub> | n+2+np <sub>src</sub> +p <sub>code</sub> |  |  |  |  |

<sup>†</sup> If the destination operand and the code are in the same SARAM block

 $\ddagger$  If both the source and the destination operands are in the same SARAM block If both operands and the code are in the same SARAM block

|                                            | Program                                 |                                         |                                                  |                                                                  |  |  |  |  |  |
|--------------------------------------------|-----------------------------------------|-----------------------------------------|--------------------------------------------------|------------------------------------------------------------------|--|--|--|--|--|
| Operand                                    | ROM                                     | DARAM                                   | SARAM                                            | External                                                         |  |  |  |  |  |
| Source: DARAM/ROM<br>Destination: SARAM    | n+2                                     | n+2                                     | n+2<br>n+4†                                      | n+2+p <sub>code</sub>                                            |  |  |  |  |  |
| Source: SARAM<br>Destination: SARAM        | n+2<br>2n‡                              | n+2<br>2n‡                              | n+2<br>2n‡<br>2n+2§                              | n+2+p <sub>code</sub><br>2n‡                                     |  |  |  |  |  |
| Source: External<br>Destination: SARAM     | n+2+np <sub>src</sub>                   | n+2+np <sub>src</sub>                   | n+2+np <sub>src</sub><br>n+4+np <sub>src</sub> † | n+2+np <sub>src</sub> +p <sub>code</sub>                         |  |  |  |  |  |
| Source: DARAM/ROM<br>Destination: External | 2n+2+nd <sub>dst</sub>                  | 2n+2+nd <sub>dst</sub>                  | 2n+2+nd <sub>dst</sub>                           | 2n+4+nd <sub>dst</sub> +p <sub>code</sub>                        |  |  |  |  |  |
| Source: SARAM<br>Destination: External     | 2n+2+nd <sub>dst</sub>                  | 2n+2+nd <sub>dst</sub>                  | 2n+2+nd <sub>dst</sub>                           | 2n+4+nd <sub>dst</sub> +p <sub>code</sub>                        |  |  |  |  |  |
| Source: External<br>Destination: External  | 4n+np <sub>src</sub> +nd <sub>dst</sub> | 4n+np <sub>src</sub> +nd <sub>dst</sub> | 4n+np <sub>src</sub> +nd <sub>dst</sub>          | 4n+2+np <sub>src</sub> +nd <sub>dst</sub> +<br>p <sub>code</sub> |  |  |  |  |  |

#### Cycles for a Repeat (RPT) Execution of a TBLR Instruction (Continued)

<sup>†</sup> If the destination operand and the code are in the same SARAM block

<sup>‡</sup> If both the source and the destination operands are in the same SARAM block

 $\$  If both operands and the code are in the same SARAM block

| Example 1 | TBLR DAT6             | ;(DP = 4: addresses 0200   | )h-027Fh)         |
|-----------|-----------------------|----------------------------|-------------------|
|           |                       | Before Instruction         | After Instruction |
|           | ACC                   | 23h ACC                    | 23h               |
|           | Program Memory<br>23h | Program Memory<br>306h 23h |                   |
|           | Data Memory<br>206h   | Data Memory<br>75h 206h    | 306h              |
| Example 2 | TBLR *, ART           |                            |                   |
|           |                       | Before Instruction         | After Instruction |
|           | ARP                   | 0 ARP                      | 7                 |
|           | AR0                   | 300h AR0                   | 300h              |
|           | ACC                   | 24h ACC                    | 24h               |
|           | Program Memory<br>24h | Program Memory<br>307h 24h |                   |
|           | Data Memory<br>300h   | Data Memory<br>75h 300h    | 307h              |

# PRELIMINARY

Assembly Language Instructions 8-187

| Syntax      | <b>TBLW</b> dmaDirect addressing <b>TBLW</b> ind [, <b>AR</b> n]Indirect addressing                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands    | dma:7 LSBs of the data-memory addressn:Value from 0 to 7 designating the next auxiliary registerind:Select one of the following seven options:**+**0+**BR0+**BR0+                                                                                                                                                                                                                                                                                                                                                                     |
| Opcode      | <b>TBLW</b> dma<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|             | 1 0 1 0 0 1 1 1 0 dma                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|             | TBLW ind [, ARn]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|             | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|             | 1 0 1 0 0 1 1 1 1 ARU N NAR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|             | <b>Note:</b> ARU, N, and NAR are defined in subsection 7.3.4, <i>Indirect Addressing Opcode Format</i> (page 7-12).                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Execution   | Increment PC, then<br>$(PC+1) \rightarrow MSTACK$<br>$(ACC(15:0)) \rightarrow PC+1$<br>$(data-memory address) \rightarrow pma,$<br>For indirect, modify (current AR) and (ARP) as specified<br>$(PC) + 1 \rightarrow PC$<br>While (repeat counter) $\neq 0$<br>$(data-memory address) \rightarrow pma,$<br>For indirect, modify (current AR) and (ARP) as specified<br>$(PC) + 1 \rightarrow PC$<br>$(repeat counter) -1 \rightarrow repeat counter.$<br>(MSTACK) $\rightarrow PC+1$                                                  |
| Status Bits | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Description | The TBLW instruction transfers a word in data memory to program memory.<br>The data-memory address is specified by the instruction, and the program-<br>memory address is specified by the lower 16 bits of the accumulator. A read<br>from data memory is followed by a write to program memory to complete the<br>instruction. When repeated with the repeat (RPT) instruction, TBLW effectively<br>becomes a single-cycle instruction, and the program counter that was loaded<br>with (ACC(15:0)) is incremented once each cycle. |
| Words       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8-188       | PRELIMINARY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### Cycles

| Cycles for a Single TBLW Instruction       |                                      |                                      |                                            |                                                         |  |  |  |  |  |
|--------------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------------|---------------------------------------------------------|--|--|--|--|--|
|                                            | Program                              |                                      |                                            |                                                         |  |  |  |  |  |
| Operand                                    | ROM                                  | DARAM                                | SARAM                                      | External                                                |  |  |  |  |  |
| Source: DARAM/ROM Destination: DARAM       | 3                                    | 3                                    | 3                                          | 3+p <sub>code</sub>                                     |  |  |  |  |  |
| Source: SARAM<br>Destination: DARAM        | 3                                    | 3                                    | 3                                          | 3+p <sub>code</sub>                                     |  |  |  |  |  |
| Source: External<br>Destination: DARAM     | 3+d <sub>src</sub>                   | 3+d <sub>src</sub>                   | 3+d <sub>src</sub>                         | 3+d <sub>src</sub> +p <sub>code</sub>                   |  |  |  |  |  |
| Source: DARAM/ROM<br>Destination: SARAM    | 3                                    | 3                                    | 3<br>4†                                    | 3+p <sub>code</sub>                                     |  |  |  |  |  |
| Source: SARAM<br>Destination: SARAM        | 3                                    | 3                                    | 3<br>4†                                    | 3+p <sub>code</sub>                                     |  |  |  |  |  |
| Source: External<br>Destination: SARAM     | 3+d <sub>src</sub>                   | 3+d <sub>src</sub>                   | 3+d <sub>src</sub><br>4+d <sub>src</sub> † | 3+d <sub>src</sub> +p <sub>code</sub>                   |  |  |  |  |  |
| Source: DARAM/ROM<br>Destination: External | 4+p <sub>dst</sub>                   | 4+p <sub>dst</sub>                   | 4+p <sub>dst</sub>                         | 5+p <sub>dst</sub> +p <sub>code</sub>                   |  |  |  |  |  |
| Source: SARAM<br>Destination: External     | 4+p <sub>dst</sub>                   | 4+p <sub>dst</sub>                   | 4+p <sub>dst</sub>                         | 5+p <sub>dst</sub> +p <sub>code</sub>                   |  |  |  |  |  |
| Source: External<br>Destination: External  | 4+d <sub>src</sub> +p <sub>dst</sub> | 4+d <sub>src</sub> +p <sub>dst</sub> | 4+d <sub>src</sub> +p <sub>dst</sub>       | 5+d <sub>src</sub> +p <sub>dst</sub> +p <sub>code</sub> |  |  |  |  |  |

<sup>†</sup> If the destination operand and the code are in the same SARAM block

|                                         | Cycles for a Repeat (RPT) Execution of a TBLW Instruction |                       |                       |                                          |  |  |  |  |  |  |
|-----------------------------------------|-----------------------------------------------------------|-----------------------|-----------------------|------------------------------------------|--|--|--|--|--|--|
|                                         |                                                           | Program               |                       |                                          |  |  |  |  |  |  |
| Operand                                 | ROM                                                       | DARAM                 | SARAM                 | External                                 |  |  |  |  |  |  |
| Source: DARAM/ROM<br>Destination: DARAM | n+2                                                       | n+2                   | n+2                   | n+2+p <sub>code</sub>                    |  |  |  |  |  |  |
| Source: SARAM<br>Destination: DARAM     | n+2                                                       | n+2                   | n+2                   | n+2+p <sub>code</sub>                    |  |  |  |  |  |  |
| Source: External<br>Destination: DARAM  | n+2+nd <sub>src</sub>                                     | n+2+nd <sub>src</sub> | n+2+nd <sub>src</sub> | n+2+nd <sub>src</sub> +p <sub>code</sub> |  |  |  |  |  |  |

<sup>†</sup> If the destination operand and the code are in the same SARAM block

 $\ddagger$  If both the source and the destination operands are in the same SARAM block

\$ If both operands and the code are in the same SARAM block

PRELIMINARY

|                                           |                                         | ,                                       | (                                                |                                                                  |  |  |  |  |  |
|-------------------------------------------|-----------------------------------------|-----------------------------------------|--------------------------------------------------|------------------------------------------------------------------|--|--|--|--|--|
|                                           |                                         | Program                                 |                                                  |                                                                  |  |  |  |  |  |
| Operand                                   | ROM                                     | DARAM                                   | SARAM                                            | External                                                         |  |  |  |  |  |
| Source: DARAM/ROM<br>Destination: SARAM   | n+2                                     | n+2                                     | n+2<br>n+3†                                      | n+2+p <sub>code</sub>                                            |  |  |  |  |  |
| Source: SARAM<br>Destination: SARAM       | n+2<br>2n‡                              | n+2<br>2n‡                              | n+2<br>2n‡<br>2n+1§                              | n+2+p <sub>code</sub><br>2n‡                                     |  |  |  |  |  |
| Source: External<br>Destination: SARAM    | n+2+nd <sub>src</sub>                   | n+2+nd <sub>src</sub>                   | n+2+nd <sub>src</sub><br>n+3+nd <sub>src</sub> † | n+2+nd <sub>src</sub> +p <sub>code</sub>                         |  |  |  |  |  |
| Source: DARAM/ROM Destination: External   | 2n+2+np <sub>dst</sub>                  | 2n+2+np <sub>dst</sub>                  | 2n+2+np <sub>dst</sub>                           | 2n+3+np <sub>dst</sub> +p <sub>code</sub>                        |  |  |  |  |  |
| Source: SARAM<br>Destination: External    | 2n+2+np <sub>dst</sub>                  | 2n+2+np <sub>dst</sub>                  | 2n+2+np <sub>dst</sub>                           | 2n+3+np <sub>dst</sub> +p <sub>code</sub>                        |  |  |  |  |  |
| Source: External<br>Destination: External | 4n+nd <sub>src</sub> +np <sub>dst</sub> | 4n+nd <sub>src</sub> +np <sub>dst</sub> | 4n+nd <sub>src</sub> +np <sub>dst</sub>          | 4n+1+nd <sub>src</sub> +np <sub>dst</sub> +<br>P <sub>code</sub> |  |  |  |  |  |

#### Cycles for a Repeat (RPT) Execution of a TBLW Instruction (Continued)

 $^{\dagger}$  If the destination operand and the code are in the same SARAM block  $^{\ddagger}$  If both the source and the destination operands are in the same SARAM block  $^{\$}$  If both operands and the code are in the same SARAM block

| Example 1 | TBLW | DAT5                 | ;(DP = 32:         | addresses 100          | 0h-107Fh)         |
|-----------|------|----------------------|--------------------|------------------------|-------------------|
|           |      |                      | Before Instruction |                        | After Instruction |
|           |      | ACC                  | 257h               | ACC                    | 257h              |
|           | [    | Data Memory<br>1005h | 4339h              | Data Memory<br>1005h   | 4339h             |
|           | Pro  | ogram Memory<br>257h | 306h               | Program Memory<br>257h | 4399h             |
| Example 2 | TBLW | *                    |                    |                        |                   |
|           |      |                      | Before Instruction |                        | After Instruction |
|           |      | ARP                  | 6                  | ARP                    | 6                 |
|           |      | AR6                  | 1006h              | AR6                    | 1006h             |
|           |      | ACC                  | 258h               | ACC                    | 258h              |
|           | [    | Data Memory<br>1006h | 4340h              | Data Memory<br>1006h   | 4340h             |
|           | Pro  | ogram Memory<br>258h | 307h               | Program Memory<br>258h | 4340h             |

| Syntax      | TRAP                                                                            |                                   |                                    |                                 |                               |                                  |                                  |                               |                                |                                |                                |                                   |                                     |                                 |                                     |
|-------------|---------------------------------------------------------------------------------|-----------------------------------|------------------------------------|---------------------------------|-------------------------------|----------------------------------|----------------------------------|-------------------------------|--------------------------------|--------------------------------|--------------------------------|-----------------------------------|-------------------------------------|---------------------------------|-------------------------------------|
| Operands    | None                                                                            |                                   |                                    |                                 |                               |                                  |                                  |                               |                                |                                |                                |                                   |                                     |                                 |                                     |
| Opcode      | 15 14<br>1 0                                                                    | <u>13</u><br>1                    | <u>12</u><br>1                     | <u>11</u><br>1                  | <u>10</u><br>1                | 9<br>1                           | 8<br>0                           | 7<br>0                        | 6<br>1                         | 5<br>0                         | 4<br>1                         | <u>3</u><br>0                     | 2<br>0                              | 1<br>0                          | 0                                   |
| Execution   | $(PC) + 1 - 22h \rightarrow PC$                                                 |                                   | ck                                 |                                 |                               |                                  |                                  |                               |                                |                                |                                |                                   |                                     |                                 |                                     |
| Status Bits | Not affect                                                                      | ed by                             |                                    | M; d                            | oes                           | not a                            | ffect                            | INTI                          | И.                             |                                |                                |                                   |                                     |                                 |                                     |
| Description | The TRAF<br>program-r<br>onto the h<br>instruction<br>stack enal<br>instruction | nemo<br>ardwa<br>to tra<br>ples a | ry loo<br>are st<br>ansfe<br>retur | catio<br>ack.<br>er co<br>m ins | n 22<br>The<br>ntrol<br>struc | h an<br>insti<br>to th<br>tion t | d pu<br>ructio<br>ne Tf<br>o pop | shes<br>on at<br>RAP<br>o the | the<br>locat<br>routi<br>retur | prog<br>ion 2<br>ne. F<br>n ad | ram<br>2h m<br>Puttin<br>dress | coun<br>lay co<br>g (P(<br>s (whi | ter (F<br>ontaii<br>C + 1<br>ich po | PC) p<br>n a b<br>) on<br>pints | olus 1<br>ranch<br>to the<br>to the |
| Cycles      |                                                                                 |                                   |                                    | Cvc                             | les fr                        | or a S                           | Sinal                            | e TR/                         | \P In                          | struc                          | tion                           |                                   |                                     |                                 |                                     |
|             | ROM                                                                             |                                   |                                    | DAR                             |                               | <i></i>                          | , ingit                          |                               | RAM                            | onac                           |                                | Ext                               | ernal                               |                                 |                                     |
|             | 4                                                                               |                                   |                                    | 4                               |                               |                                  |                                  | 4                             |                                |                                |                                | 4+3                               | 3p†                                 |                                 |                                     |
|             | † The proce<br>PC discor                                                        |                                   |                                    |                                 |                               |                                  |                                  |                               |                                |                                |                                |                                   | uction                              | words                           | . If the                            |
| Example     | TRAP                                                                            | ;                                 | PC +<br>cont<br>22h.               | rol                             |                               | -                                |                                  |                               |                                |                                |                                |                                   |                                     |                                 |                                     |

| Syntax    | XOR<br>XOR<br>XOR<br>XOR                       | <i>ind</i> [,<br><b>#</b> Ik, [,          | shif                        | -                         |                         |                                   |                      |                |                                   |               | Direc<br>Indire<br>Long<br>Long<br>shift | ct ac<br>imm    | ddres<br>ediat<br>ediat    | sing<br>e ad | dress                                                | -          |
|-----------|------------------------------------------------|-------------------------------------------|-----------------------------|---------------------------|-------------------------|-----------------------------------|----------------------|----------------|-----------------------------------|---------------|------------------------------------------|-----------------|----------------------------|--------------|------------------------------------------------------|------------|
| Operands  | dma:<br>shift:<br>n:<br>lk:<br>ind:            |                                           | Le<br>Va<br>16              | eft sh<br>alue 1<br>6-bit | iift va<br>from<br>long | alue fi<br>0 to<br>imme<br>of the | rom<br>7 de<br>ediat | signa<br>e val | I 5 (de<br>iting t<br>ue<br>g sev | efau<br>the r | lts to<br>next a<br>option               | uxilia          | ary re                     | giste        | ۶r                                                   |            |
| Opcode    | хо                                             | R dm                                      | a                           |                           |                         |                                   |                      |                |                                   |               |                                          |                 |                            |              |                                                      |            |
|           | 15                                             | 14                                        | 13                          | 12                        | 11                      | 10                                | 9                    | 8              | 7                                 | 6             | 5                                        | 4               | 3                          | 2            | 1                                                    | 0          |
|           | 0                                              | 1                                         | 1                           | 0                         | 1                       | 1                                 | 0                    | 0              | 0                                 |               |                                          |                 | dma                        |              |                                                      |            |
|           | хо                                             | R ind                                     | /[, <b>A</b>                | <b>R</b> <i>n</i> ]       |                         |                                   |                      |                |                                   |               |                                          |                 |                            |              |                                                      |            |
|           | 15                                             | 14                                        | 13                          | 12                        | 11                      | 10                                | 9                    | 8              | 7                                 | 6             | 5                                        | 4               | 3                          | 2            | 1                                                    | 0          |
|           | 0                                              | 1                                         | 1                           | 0                         | 1                       | 1                                 | 0                    | 0              | 1                                 |               | ARU                                      |                 | Ν                          |              | NAR                                                  |            |
|           | 15                                             | (p<br><b>R #</b> /k<br>14                 | age 7<br>[, <i>sh</i><br>13 | -12).<br>niff]<br>12      | 11                      | 10                                | 9                    | 8              | 7                                 | 6             | Indired                                  | 4               | ressinų<br>3               | 2            | 1                                                    | ormat<br>0 |
|           | 1                                              | 0                                         | 1                           | 1                         | 1                       | 1                                 | 1                    | 1              | 1                                 | 1             | 0                                        | 1               |                            | Sł           | nift                                                 |            |
|           |                                                |                                           |                             |                           |                         |                                   |                      | I              | k                                 |               |                                          |                 |                            |              |                                                      |            |
|           | хо                                             | <b>R #</b> /k,                            | , 16                        |                           |                         |                                   |                      |                |                                   |               |                                          |                 |                            |              |                                                      |            |
|           | 15                                             | 14                                        | 13                          | 12                        | 11                      | 10                                | 9                    | 8              | 7                                 | 6             | 5                                        | 4               | 3                          | 2            | 1                                                    | 0          |
|           | 1                                              | 0                                         | 1                           | 1                         | 1                       | 1                                 | 1                    | 0              | 1                                 | 0             | 0                                        | 0               | 0                          | 0            | 1                                                    | 1          |
|           |                                                |                                           |                             |                           |                         |                                   |                      | I              | k                                 |               |                                          |                 |                            |              |                                                      |            |
| Execution | Increr<br><u>Eveni</u><br>(ACC<br>(ACC<br>(ACC | <u>((s)</u><br>(15:0)<br>(31:1)<br>(31:0) | )) X(<br>6)) –<br>)) X(     | OR (c<br>→ AC<br>OR lk    | lata-ı<br>C(31<br>× 2   | :16)<br>shift _                   | $\rightarrow A($     | CC(3           | 1:0)                              | → AC          | C(15                                     | :0) [<br>L<br>L | Direct<br>.ong i<br>.ong i | or ir        | <u>g mod</u><br>ndirec<br>ediate<br>ediate<br>hift o | et<br>e    |

| Status Bits | None                                                       | ne                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                                  |                 |  |  |  |  |
|-------------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------------------------------|-----------------|--|--|--|--|
| Description | exclusive C<br>the result re<br>accumulato<br>diate consta | t or indirect addressing, the low half of the accumulator value is<br>DRed with the content of the addressed data memory location, and<br>replaces the low half of the accumulator value; the upper half of the<br>or value is unaffected. With immediate addressing, the long imme-<br>tant is shifted and zero filled on both ends and exclusive ORed with<br>content of the accumulator. The carry bit (C) is unaffected by XOR. |                        |                                  |                 |  |  |  |  |
| Words       | <u>Words</u><br>1                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                     |                        | <u>Addressin</u><br>Direct or ir | -               |  |  |  |  |
|             | 2                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                     |                        | Long imme                        | ediate          |  |  |  |  |
| Cycles      | Cycles for                                                 | r a Single XOR I                                                                                                                                                                                                                                                                                                                                                                                                                    | Instruction (Usin      | g Direct and Indir               | ect Addressing) |  |  |  |  |
|             |                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                     | Pr                     | ogram                            |                 |  |  |  |  |
|             | Operand                                                    | ROM                                                                                                                                                                                                                                                                                                                                                                                                                                 | DARAM                  | SARAM                            | External        |  |  |  |  |
|             | DARAM                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1                      | 1                                | 1+p             |  |  |  |  |
|             | SARAM                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1 1,2 <sup>†</sup> 1+p |                                  |                 |  |  |  |  |
|             | External                                                   | 1+d                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1+d                    | 1+d                              | 2+d+p           |  |  |  |  |

 $\ensuremath{^\dagger}$  If the operand and the code are in the same SARAM block

| Cycles for a Repeat (RPT) Execution of an XOR Instruction (Using Direct |
|-------------------------------------------------------------------------|
| and Indirect Addressing)                                                |

|          |      | Program |         |          |  |  |  |  |  |
|----------|------|---------|---------|----------|--|--|--|--|--|
| Operand  | ROM  | DARAM   | SARAM   | External |  |  |  |  |  |
| DARAM    | n    | n       | n       | n+p      |  |  |  |  |  |
| SARAM    | n    | n       | n, n+1† | n+p      |  |  |  |  |  |
| External | n+nd | n+nd    | n+nd    | n+1+p+nd |  |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block

| Cycles for a Single XOR Instruction | (Using Long Immediate Addressing) |
|-------------------------------------|-----------------------------------|
|                                     |                                   |

| ROM | DARAM | SARAM | External |
|-----|-------|-------|----------|
| 2   | 2     | 2     | 2+2p     |

# PRELIMINARY

Assembly Language Instructions 8-193

#### XOR Exclusive OR With Accumulator

#### PRELIMINARY



| Syntax      | ZALF<br>ZALF                                                                                                                                                                                                                                           |       |                 | [ <i>n</i> ]         |             |                |        |                                |                 |        | Direc<br>Indire |        |         | •     |        |       |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------|----------------------|-------------|----------------|--------|--------------------------------|-----------------|--------|-----------------|--------|---------|-------|--------|-------|
| Operands    | dma:<br>n:<br>ind:                                                                                                                                                                                                                                     |       | Va              | alue f               | from<br>one | 0 to<br>of the | 7 de   | nemo<br>signa<br>lowiną<br>*0– | ting t<br>g sev | the n  | ext a           |        | ary re  | giste | er     |       |
| Opcode      | ZA                                                                                                                                                                                                                                                     | LR d  | ma              |                      |             |                |        |                                |                 |        |                 |        |         |       |        |       |
|             | 15                                                                                                                                                                                                                                                     | 14    | 13              | 12                   | 11          | 10             | 9      | 8                              | 7               | 6      | 5               | 4      | 3       | 2     | 1      | 0     |
|             | 0                                                                                                                                                                                                                                                      | 1     | 1               | 0                    | 1           | 0              | 0      | 0                              | 0               |        |                 |        | dma     |       |        |       |
|             | ZA                                                                                                                                                                                                                                                     | LR in | nd [, <b>/</b>  | <b>\R</b> <i>n</i> ] |             |                |        |                                |                 |        |                 |        |         |       |        |       |
|             | 15                                                                                                                                                                                                                                                     | 14    | 13              | 12                   | 11          | 10             | 9      | 8                              | 7               | 6      | 5               | 4      | 3       | 2     | 1      | 0     |
|             | 0                                                                                                                                                                                                                                                      | 1     | 1               | 0                    | 1           | 0              | 0      | 0                              | 1               |        | ARU             |        | Ν       |       | NAR    |       |
|             | Not                                                                                                                                                                                                                                                    |       | RU, N<br>bage 7 |                      | IAR a       | re defii       | ned ir | n subse                        | ection          | 7.3.4, | Indirec         | t Addi | ressing | g Opc | ode Fa | ormat |
| Execution   | Increment PC, then<br>(data-memory address) $\rightarrow$ ACC(31:16)<br>8000h $\rightarrow$ ACC(15:0)                                                                                                                                                  |       |                 |                      |             |                |        |                                |                 |        |                 |        |         |       |        |       |
| Status Bits | None                                                                                                                                                                                                                                                   |       |                 |                      |             |                |        |                                |                 |        |                 |        |         |       |        |       |
| Description | To load a data-memory value into the high-order half of the accumulator, the ZALR instruction rounds the value by adding 1/2 LSB; that is, the 15 low bits (bits 14–0) of the accumulator are cleared to 0, and bit 15 of the accumulator is set to 1. |       |                 |                      |             |                |        |                                |                 |        |                 |        |         |       |        |       |
| Words       | 1                                                                                                                                                                                                                                                      |       |                 |                      |             |                |        |                                |                 |        |                 |        |         |       |        |       |

### Cycles

#### Cycles for a Single ZALR Instruction

|          |     | F     | Program |          |
|----------|-----|-------|---------|----------|
| Operand  | ROM | DARAM | SARAM   | External |
| DARAM    | 1   | 1     | 1       | 1+p      |
| SARAM    | 1   | 1     | 1, 2†   | 1+p      |
| External | 1+d | 1+d   | 1+d     | 2+d+p    |

 $^{\dagger}$  If the operand and the code are in the same SARAM block

#### Cycles for a Repeat (RPT) Execution of a ZALR Instruction

|          | Program |       |         |          |  |  |  |  |
|----------|---------|-------|---------|----------|--|--|--|--|
| Operand  | ROM     | DARAM | SARAM   | External |  |  |  |  |
| DARAM    | n       | n     | n       | n+p      |  |  |  |  |
| SARAM    | n       | n     | n, n+1† | n+p      |  |  |  |  |
| External | n+nd    | n+nd  | n+nd    | n+1+p+nd |  |  |  |  |

<sup>†</sup> If the operand and the code are in the same SARAM block



# Appendix A

# TMS320C1x/C2x/C24x/C5x Instruction Set Comparison

#### Note:

The instruction set for the TMS320C24x is identical to that of the TMS320C2xx. All references to 'C2xx devices in this appendix also apply to 'C24x devices.

This appendix contains a table that compares the TMS320C1x, TMS320C2x, TMS320C2xx, and TMS320C5x instructions alphabetically. Each table entry shows the syntax for the instruction, indicates which devices support the instruction, and describes the operation of the instruction. Section A.1 shows a sample table entry and describes the symbols and abbreviations used in the table.

The TMS320C2x, TMS320C2xx, and TMS320C5x devices have enhanced instructions; these instructions are single mnemonics that perform the functions of several similar instructions. Section A.2 summarizes these enhanced instructions.

| Торі | ic                                         | Page |
|------|--------------------------------------------|------|
| A.1  | Using the Instruction Set Comparison Table | Δ-2  |

| A.1 | Using the Instruction Set Comparison Table | 4-2 |
|-----|--------------------------------------------|-----|
| A.2 | Enhanced Instructions                      | 4-5 |
| A.3 | Instruction Set Comparison Table           | 4-6 |

# A.1 Using the Instruction Set Comparison Table

To help you read the comparison table, this section provides an example of a table entry and a list of acronyms.

#### A.1.1 An Example of a Table Entry

In cases where more than one syntax is used, the first syntax is usually for direct addressing and the second is usually for indirect addressing. Where three or more syntaxes are used, the syntaxes are normally specific to a device.

This is how the AND instruction appears in the table:

| Syntax                                     | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------------------------------|--------------|--------------|--------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AND dma                                    | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | AND With Accumulator                                                                                                                                                                                                                                                                                                                                                                      |
| AND {ind} [, next ARP]<br>AND #lk[, shift] | V            | V            |              | √<br>√       | TMS320C1x and TMS320C2x devices: AND the con-<br>tents of the addressed data-memory location with the<br>16 LSBs of the accumulator. The 16 MSBs of the accu-<br>mulator are ANDed with 0s.                                                                                                                                                                                               |
|                                            |              |              |              |              | TMS320C2xx and TMS320C5x devices: AND the con-<br>tents of the addressed data-memory location or a<br>16-bit immediate value with the contents of the accu-<br>mulator. The 16 MSBs of the accumulator are ANDed<br>with 0s. If a shift is specified, left shift the constant be-<br>fore the AND. Low-order bits below and high-order bits<br>above the shifted value are treated as 0s. |

The first column, *Syntax*, states the mnemonic and the syntaxes for the AND instruction.

The checks in the second through the fifth columns, 1x, 2x, 2xx, and 5x, indicate the devices that can be used with each of the syntaxes.

1x refers to the TMS320C1x devices.

- 2x refers to the TMS320C2x devices, including TMS320C25.
- 2xx refers to the TMS320C2xx devices.
- 5x refers to the TMS320C5x devices.

In this example, you can use the first two syntaxes with TMS320C1x, TMS320C2x, TMS320C2xx, and TMS320C5x devices, but you can use the last syntax only with TMS320C2xx and TMS320C5x devices.

The sixth column, *Description*, briefly describes how the instruction functions. Often, an instruction functions slightly differently for the different devices: read the entire description before using the instruction.

# A.1.2 Symbols and Acronyms Used in the Table

Table A–1 lists the instruction set symbols and acronyms used throughout this appendix.

Table A–1. Symbols and Acronyms Used in the Instruction Set Comparison Table

| Symbol | Description                       | Symbol                    | Description                        |
|--------|-----------------------------------|---------------------------|------------------------------------|
| lk     | 16-bit immediate value            | INTM                      | Interrupt mask bit                 |
| k      | 8-bit immediate value             | INTR                      | Interrupt mode bit                 |
| {ind}  | Indirect address                  | OV                        | Overflow bit                       |
| ACC    | Accumulator                       | Р                         | Program bus                        |
| ACCB   | Accumulator buffer                | PA                        | Port address                       |
| AR     | Auxiliary register                | PC                        | Program counter                    |
| ARCR   | Auxiliary register compare        | РМ                        | Product shifter mode               |
| ARP    | Auxiliary register pointer        | pma                       | Program-memory address             |
| BMAR   | Block move address register       | RPTC                      | Repeat counter                     |
| BRCR   | Block repeat count register       | shift, shift <sub>n</sub> | Shift value                        |
| С      | Carry bit                         | src                       | Source address                     |
| DBMR   | Dynamic bit manipulation register | ST                        | Status register                    |
| dma    | Data-memory address               | SXM                       | Sign-extension mode bit            |
| DP     | Data-memory page pointer          | тс                        | Test/control bit                   |
| dst    | Destination address               | т                         | Temporary register                 |
| FO     | Format status list                | TREGn                     | TMS320C5x temporary register (0–2) |
| FSX    | External framing pulse            | ТХМ                       | Transmit mode status register      |
| IMR    | Interrupt mask register           | XF                        | XF pin status bit                  |

Based on the device, this is how the indirect addressing operand {ind} is interpreted:

{ind} 'C1x: { \* | \*+ | \*- } 'C2x: { \* | \*+ | \*- | \*0+ | \*0- | \*BR0+ | \*BR0- } 'C2xx: { \* | \*+ | \*- | \*0+ | \*0- | \*BR0+ | \*BR0- } 'C5x: { \* | \*+ | \*- | \*0+ | \*0- | \*BR0+ | \*BR0- }

where the possible options are separated by vertical bars (|). For example:

ADD {ind}

is interpreted as:

| 'C1x devices  | ADD { *   *+   *- }                             |
|---------------|-------------------------------------------------|
| 'C2x devices  | ADD { *   *+   *-   *0+   *0-   *BR0+   *BR0- } |
| 'C2xx devices | ADD { *   *+   *-   *0+   *0-   *BR0+   *BR0- } |
| 'C5x devices  | ADD { *   *+   *-   *0+   *0-   *BR0+   *BR0- } |

Based on the device, these are the sets of values for shift, shift<sub>1</sub>, and shift<sub>2</sub>:

| shift              | 'C1x:                             | 0–15 (shift of 0–15 bits)                                                                  |
|--------------------|-----------------------------------|--------------------------------------------------------------------------------------------|
|                    | 'C2x:                             | 0–15 (shift of 0–15 bits)                                                                  |
|                    | 'C2xx:                            | 0–16 (shift of 0–16 bits)                                                                  |
|                    | 'C5x:                             | 0–16 (shift of 0–16 bits)                                                                  |
| shift <sub>1</sub> | 'C1x:<br>'C2x:<br>'C2xx:<br>'C5x: | n/a<br>0–15 (shift of 0–15 bits)<br>0–16 (shift of 0–16 bits)<br>0–16 (shift of 0–16 bits) |
| shift <sub>2</sub> | 'C1x:<br>'C2x:<br>'C2xx:<br>'C5x: | n/a<br>n/a<br>0–15 (shift of 0–15 bits)<br>0–15 (shift of 0–15 bits)                       |

In some cases, the sets are smaller; in these cases, the valid sets are given in the *Description* column of the table.

### A.2 Enhanced Instructions

An enhanced instruction is a single mnemonic that performs the functions of several similar instructions. For example, the enhanced instruction ADD performs the ADD, ADDH, ADDK, and ADLK functions and replaces any of these other instructions at assembly time. For example, when a program using ADDH is assembled for the 'C2xx or 'C5x, ADDH is replaced by an ADD instruction that performs the same function. These enhanced instructions are valid for TMS320C2x, TMS320C2xx, and TMS320C5x devices (not TMS320C1x).

Table A–2 summarizes the enhanced instructions and the functions that the enhanced instructions perform (based on TMS320C1x/2x mnemonics).

| Enhanced<br>Instruction | Includes These Operations                                                 |
|-------------------------|---------------------------------------------------------------------------|
| ADD                     | ADD, ADDH, ADDK, ADLK                                                     |
| AND                     | AND, ANDK                                                                 |
| BCND                    | BBNZ, BBZ, BC, BCND, BGEZ, BGZ, BIOZ, BLEZ, BLZ, BNC,<br>BNV, BNZ, BV, BZ |
| BLDD                    | BLDD, BLKD                                                                |
| BLDP                    | BLDP, BLKP                                                                |
| CLRC                    | CLRC, CNFD, EINT, RC, RHM, ROVM, RSXM, RTC, RXF                           |
| LACC                    | LAC, LACC, LALK, ZALH                                                     |
| LACL                    | LACK, LACL, ZAC, ZALS                                                     |
| LAR                     | LAR, LARK, LRLK                                                           |
| LDP                     | LDP, LDPK                                                                 |
| LST                     | LST, LST1                                                                 |
| MAR                     | LARP, MAR                                                                 |
| MPY                     | MPY, MPYK                                                                 |
| OR                      | OR, ORK                                                                   |
| RPT                     | RPT, RPTK                                                                 |
| SETC                    | CNFP, DINT, SC, SETC, SHM, SOVM, SSXM, STC, SXF                           |
| SUB                     | SUB, SUBH, SUBK                                                           |

Table A-2. Summary of Enhanced Instructions

PRELIMINARY

TMS320C1x/C2x/C24x/C5x Instruction Set Comparison A-5

# A.3 Instruction Set Comparison Table

Table A–3 contains a comparison of the TMS320C1x, TMS320C2x, TMS320C2xx, and TMS320C5x instructions alphabetically.

| Syntax                                                            | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------------|--------------|--------------|--------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ABS                                                               | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Absolute Value of Accumulator                                                                                                                                                                                                                                                                      |
|                                                                   |              |              |              |              | If the contents of the accumulator are less than 0, replace the contents with the 2s complement of the contents. If the contents are $\geq 0$ , the accumulator is not affected.                                                                                                                   |
| ADCB                                                              |              |              |              | $\checkmark$ | Add ACCB to Accumulator With Carry                                                                                                                                                                                                                                                                 |
|                                                                   |              |              |              |              | Add the contents of the ACCB and the value of the carry bit to the accumulator. If the result of the addition generates a carry from the accumulator's MSB, the carry bit is set to 1.                                                                                                             |
| ADD dma [, shiff]                                                 | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Add to Accumulator With Shift                                                                                                                                                                                                                                                                      |
| ADD {ind} [, shift [, next ARP]]<br>ADD #k<br>ADD # lk [, shift2] | V            | V            | <br>         | <br>         | TMS320C1x and TMS320C2x devices: Add the contents of the addressed data-memory location to the accumulator; if a shift is specified, left shift the contents of the location before the add. During shifting, low-order bits are zero filled, and high-order bits are sign extended.               |
|                                                                   |              |              |              |              | TMS320C2xx and TMS320C5x devices: Add the contents of the addressed data-memory location or an immediate value to the accumulator; if a shift is specified, left shift the data before the add. During shifting, low-order bits are zero filled, and high-order bits are sign extended if SXM = 1. |
| ADDB                                                              |              |              |              | $\checkmark$ | Add ACCB to Accumulator                                                                                                                                                                                                                                                                            |
|                                                                   |              |              |              |              | Add the contents of the ACCB to the accumulator.                                                                                                                                                                                                                                                   |
| ADDC dma                                                          |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Add to Accumulator With Carry                                                                                                                                                                                                                                                                      |
| ADDC {ind} [, next ARP]                                           |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Add the contents of the addressed data-memory loca-<br>tion and the carry bit to the accumulator.                                                                                                                                                                                                  |
| ADDH dma                                                          | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Add High to Accumulator                                                                                                                                                                                                                                                                            |
| ADDH {ind} [, next ARP]                                           | V            | V            | $\checkmark$ | V            | Add the contents of the addressed data-memory loca-<br>tion to the 16 MSBs of the accumulator. The LSBs are<br>not affected. If the result of the addition generates a<br>carry, the carry bit is set to 1.                                                                                        |
|                                                                   |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x de-<br>vices: If the result of the addition generates a carry<br>from the accumulator's MSB, the carry bit is set to 1.                                                                                                                                       |

Table A–3. Instruction Set Comparison

| Syntax                  | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                          |
|-------------------------|--------------|--------------|--------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADDK #k                 |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Add to Accumulator Short Immediate                                                                                                                                                                                                                                                                                                   |
|                         |              |              |              |              | TMS320C1x devices: Add an 8-bit immediate value to the accumulator.                                                                                                                                                                                                                                                                  |
|                         |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x de-<br>vices: Add an 8-bit immediate value, right justified, to<br>the accumulator with the result replacing the accumu-<br>lator contents. The immediate value is treated as an<br>8-bit positive number; sign extension is suppressed.                                                        |
| ADDS dma                | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Add to Accumulator With Sign Extension                                                                                                                                                                                                                                                                                               |
| ADDS {ind} [, next ARP] | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Suppressed                                                                                                                                                                                                                                                                                                                           |
|                         |              |              |              |              | Add the contents of the addressed data-memory loca-<br>tion to the accumulator. The value is treated as a 16-bit<br>unsigned number; sign extension is suppressed.                                                                                                                                                                   |
| ADDT dma                |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Add to Accumulator With Shift Specified by                                                                                                                                                                                                                                                                                           |
| ADDT {ind} [, next ARP] |              | $\checkmark$ | $\checkmark$ |              | T Register                                                                                                                                                                                                                                                                                                                           |
|                         |              |              |              |              | Left shift the contents of the addressed data-memory<br>location by the value in the four LSBs of the T register;<br>add the result to the accumulator. If a shift is specified,<br>left shift the data before the add. During shifting, low-<br>order bits are zero filled, and high-order bits are sign<br>extended if $SXM = 1$ . |
|                         |              |              |              |              | TMS320C2xx and TMS320C5x devices: If the result of the addition generates a carry from the accumulator's MSB, the carry bit is set to 1.                                                                                                                                                                                             |
| ADLK #lk [, shift]      |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Add to Accumulator Long Immediate With Shift                                                                                                                                                                                                                                                                                         |
|                         |              |              |              |              | Add a 16-bit immediate value to the accumulator; if a shift is specified, left shift the value before the add. During shifting, low-order bits are zero filled, and high-order bits are sign extended if $SXM = 1$ .                                                                                                                 |
| ADRK #k                 |              | $\checkmark$ | $\checkmark$ |              | Add to Auxiliary Register Short Immediate                                                                                                                                                                                                                                                                                            |
|                         |              |              |              |              | Add an 8-bit immediate value to the current auxiliary register.                                                                                                                                                                                                                                                                      |

| Table A–3. Instruction Set Comparison (Continued) |
|---------------------------------------------------|
|---------------------------------------------------|

| Syntax                                        | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------------------------|--------------|--------------|--------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AND dma                                       | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | AND With Accumulator                                                                                                                                                                                                                                                                                                                                              |
| AND {ind} [, next ARP]<br>AND #lk [, shift]   | $\checkmark$ | V            |              |              | TMS320C1x and TMS320C2x devices: AND the contents of the addressed data-memory location with the 16 LSBs of the accumulator. The 16 MSBs of the accumulator are ANDed with 0s.                                                                                                                                                                                    |
|                                               |              |              |              |              | TMS320C2xx and TMS320C5x devices: AND the contents of the addressed data-memory location or a 16-bit immediate value with the contents of the accumulator. The 16 MSBs of the accumulator are ANDec with 0s. If a shift is specified, left shift the constant before the AND. Low-order bits below and high-order bits above the shifted value are treated as 0s. |
| ANDB                                          |              |              |              | $\checkmark$ | AND ACCB to Accumulator                                                                                                                                                                                                                                                                                                                                           |
|                                               |              |              |              |              | AND the contents of the ACCB to the accumulator.                                                                                                                                                                                                                                                                                                                  |
| ANDK #lk [, shift]                            |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | AND Immediate With Accumulator With Shift                                                                                                                                                                                                                                                                                                                         |
|                                               |              |              |              |              | AND a 16-bit immediate value with the contents of the accumulator; if a shift is specified, left shift the constant before the AND.                                                                                                                                                                                                                               |
| APAC                                          | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Add P Register to Accumulator                                                                                                                                                                                                                                                                                                                                     |
|                                               |              |              |              |              | Add the contents of the P register to the accumulator.                                                                                                                                                                                                                                                                                                            |
|                                               |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x<br>devices: Before the add, left shift the contents of the<br>P register as defined by the PM status bits.                                                                                                                                                                                                                   |
| APL [#/k] ,dma APL [#/k, ] {ind} [, next ARP] |              |              |              | √<br>√       | AND Data-Memory Value With DBMR or Long<br>Constant                                                                                                                                                                                                                                                                                                               |
| [", , , ( , , , , , ]                         |              |              |              |              | AND the data-memory value with the contents of the DBMR or a long constant. If a long constant is specified, it is ANDed with the contents of the data-memory location. The result is written back into the data-memory location previously holding the first operand. If the result is 0, the TC bit is set to 1; otherwise, the TC bit is cleared.              |
| B pma                                         | $\checkmark$ |              |              |              | Branch Unconditionally                                                                                                                                                                                                                                                                                                                                            |
| B pma [, {ind} [, next ARP]]                  |              | $\checkmark$ | $\checkmark$ |              | Branch to the specified program-memory address.                                                                                                                                                                                                                                                                                                                   |
|                                               |              |              |              |              | TMS320C2x and TMS320C2xx devices: Modify the<br>current AR and ARP as specified.                                                                                                                                                                                                                                                                                  |

| Syntax                                  | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                 |
|-----------------------------------------|--------------|--------------|--------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>B</b> [D] pma [, {ind} [, next ARP]] |              |              |              |              | Branch Unconditionally With Optional Delay                                                                                                                                                                                                                                                                  |
|                                         |              |              |              |              | Modify the current auxiliary register and ARP as speci-<br>fied and pass control to the designated program-<br>memory address. If you specify a delayed branch<br>(BD), the next two instruction words (two 1-word<br>instructions or one 2-word instruction) are fetched and<br>executed before branching. |
| BACC                                    |              | $\checkmark$ | $\checkmark$ |              | Branch to Address Specified by Accumulator                                                                                                                                                                                                                                                                  |
|                                         |              |              |              |              | Branch to the location specified by the 16 LSBs of the accumulator.                                                                                                                                                                                                                                         |
| BACC[D]                                 |              |              |              | $\checkmark$ | Branch to Address Specified by Accumulator<br>With Optional Delay                                                                                                                                                                                                                                           |
|                                         |              |              |              |              | Branch to the location specified by the 16 LSBs of the accumulator.                                                                                                                                                                                                                                         |
|                                         |              |              |              |              | If you specify a delayed branch (BACCD), the next two instruction words (two 1-word instructions or one 2-word instruction) are fetched and executed before branching.                                                                                                                                      |
| BANZ pma                                | $\checkmark$ |              |              |              | Branch on Auxiliary Register Not Zero                                                                                                                                                                                                                                                                       |
| BANZ pma[, {ind} [, next ARP]]          |              | $\checkmark$ | V            |              | If the contents of the nine LSBs of the current auxiliary register (TMS320C1x) or the contents of the entire current auxiliary register (TMS320C2x) are $\neq$ 0, branch to the specified program-memory address.                                                                                           |
|                                         |              |              |              |              | TMS320C2x and TMS320C2xx devices: Modify the current AR and ARP (if specified) or decrement the current AR (default). TMS320C1x devices: Decrement the current AR.                                                                                                                                          |
| BANZ[D] pma [, {ind} [, next<br>ARP]]   |              |              |              | $\checkmark$ | Branch on Auxiliary Register Not Zero With<br>Optional Delay                                                                                                                                                                                                                                                |
|                                         |              |              |              |              | If the contents of the current auxiliary register are $\neq 0$ ,<br>branch to the specified program-memory address.<br>Modify the current AR and ARP as specified, or decre-<br>ment the current AR.                                                                                                        |
|                                         |              |              |              |              | If you specify a delayed branch (BANZD), the next two<br>instruction words (two 1-word instructions or one<br>2-word instruction) are fetched and executed before<br>branching.                                                                                                                             |

| Table A–3. Instruction Set Comparison (Continued) |
|---------------------------------------------------|
|---------------------------------------------------|

#### Instruction Set Comparison Table

| Syntax                                                                              | 1x | 2x           | 2xx          | 5x           | Description                                                                                                                                                                     |
|-------------------------------------------------------------------------------------|----|--------------|--------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BBNZ pma [, {ind} [, next ARP]]                                                     |    | $\checkmark$ | $\checkmark$ | $\checkmark$ | Branch on Bit ≠ Zero                                                                                                                                                            |
|                                                                                     |    |              |              |              | If the TC bit = 1, branch to the specified program-<br>memory address.                                                                                                          |
|                                                                                     |    |              |              |              | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                                  |
|                                                                                     |    |              |              |              | TMS320C2xx and TMS320C5x devices: If the –p port-<br>ing switch is used, modify the current AR and ARP as<br>specified.                                                         |
| <b>BBZ</b> pma[, {ind} [, next ARP]]                                                |    | $\checkmark$ | $\checkmark$ | $\checkmark$ | Branch on Bit = Zero                                                                                                                                                            |
| BBZ pma                                                                             |    |              |              | $\checkmark$ | If the TC bit = 0, branch to the specified program-<br>memory address.                                                                                                          |
|                                                                                     |    |              |              |              | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                                  |
|                                                                                     |    |              |              |              | TMS320C2xx and TMS320C5x devices: Modify the current AR and ARP as specified when the –p porting switch is used.                                                                |
| BC pma[, {ind} [, next ARP]]                                                        |    | $\checkmark$ |              | $\checkmark$ | Branch on Carry                                                                                                                                                                 |
| BC pma                                                                              |    |              | $\checkmark$ | $\checkmark$ | If the C bit = 1, branch to the specified program-<br>memory address.                                                                                                           |
|                                                                                     |    |              |              |              | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                                  |
|                                                                                     |    |              |              |              | TMS320C2xx and TMS320C5x devices: Modify the current AR and ARP as specified when the –p porting switch is used.                                                                |
| <b>BCND</b> <i>pma</i> , <i>cond</i> <sub>1</sub> [, <i>cond</i> <sub>2</sub> ] [,] |    |              | $\checkmark$ |              | Branch Conditionally                                                                                                                                                            |
|                                                                                     |    |              |              |              | Branch to the program-memory address if the speci-<br>fied conditions are met. Not all combinations of condi-<br>tions are meaningful.                                          |
| BCND[D] pma, cond <sub>1</sub>                                                      |    |              |              | $\checkmark$ | Branch Conditionally With Optional Delay                                                                                                                                        |
| [, cond <sub>2</sub> ] [,]                                                          |    |              |              |              | Branch to the program-memory address if the speci-<br>fied conditions are met. Not all combinations of condi-<br>tions are meaningful.                                          |
|                                                                                     |    |              |              |              | If you specify a delayed branch (BCNDD), the next two<br>instruction words (two 1-word instructions or one<br>2-word instruction) are fetched and executed before<br>branching. |

# Table A–3. Instruction Set Comparison (Continued)

| Syntax                                                          | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                          |
|-----------------------------------------------------------------|--------------|--------------|--------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BGEZ pma                                                        | $\checkmark$ |              | $\checkmark$ | $\checkmark$ | Branch if Accumulator ≥ Zero                                                                                                                                         |
| BGEZ pma[, {ind} [, next ARP]]                                  |              | V            |              | V            | If the contents of the accumulator $\ge 0$ , branch to the specified program-memory address.                                                                         |
|                                                                 |              |              |              |              | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                       |
|                                                                 |              |              |              |              | TMS320C2xx and TMS320C5x devices: Modify the current AR and ARP as specified when the –p porting switch is used.                                                     |
| BGZ pma                                                         | $\checkmark$ |              | $\checkmark$ | $\checkmark$ | Branch if Accumulator > Zero                                                                                                                                         |
| <b>BGZ</b> pma[, {ind} [, next ARP]]                            |              | $\checkmark$ |              | $\checkmark$ | If the contents of the accumulator are > 0, branch to the specified program-memory address.                                                                          |
|                                                                 |              |              |              |              | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                       |
|                                                                 |              |              |              |              | TMS320C2xx and TMS320C5x devices: Modify the current AR and ARP as specified when the –p porting switch is used.                                                     |
| BIOZ pma                                                        | $\checkmark$ |              | $\checkmark$ | $\checkmark$ | Branch on I/O Status = Zero                                                                                                                                          |
| BIOZ pma [, {ind} [, next ARP]]                                 |              | $\checkmark$ |              | $\checkmark$ | If the $\overline{\text{BIO}}$ pin is low, branch to the specified programmemory address.                                                                            |
|                                                                 |              |              |              |              | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                       |
|                                                                 |              |              |              |              | TMS320C2xx and TMS320C5x devices: Modify the current AR and ARP as specified when the –p porting switch is used.                                                     |
| BIT dma, bit code                                               |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Test Bit                                                                                                                                                             |
| <b>BIT</b> { <i>ind</i> }, <i>bit code</i> [, <i>next ARP</i> ] |              | $\checkmark$ | V            | $\checkmark$ | Copy the specified bit of the data-memory value to the TC bit in ST1.                                                                                                |
| BITT dma                                                        |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Test Bit Specified by T Register                                                                                                                                     |
| <b>BITT</b> { <i>ind</i> } [, <i>next</i> ARP]                  |              | V            | $\checkmark$ | $\checkmark$ | TMS320C2x and TMS320C2xx devices: Copy the specified bit of the data-memory value to the TC bit in ST1. The four LSBs of the T register specify which bit is copied. |
|                                                                 |              |              |              |              | TMS320C5x devices: Copy the specified bit of the data-memory value to the TC bit in ST1. The four LSBs of the TREG2 specify which bit is copied.                     |

#### Instruction Set Comparison Table

| Syntax                                                                                                                                                                        | 1x           | 2x | 2xx          | 5x                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|--------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BLDD #lk, dma                                                                                                                                                                 |              |    |              | $\checkmark$         | Block Move From Data Memory to Data Memory                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| BLDD #lk, {ind} [, next ARP]<br>BLDD dma, #lk                                                                                                                                 |              |    |              | √<br>√               | Copy a block of data memory into data memory. The block of data memory is pointed to by <i>src</i> , and the destination block of data memory is pointed to by <i>dst</i> .                                                                                                                                                                                                                                                                                                     |
| <ul> <li>BLDD {ind}, #lk [, next ARP]</li> <li>BLDD BMAR, dma</li> <li>BLDD BMAR, {ind} [, next ARP]</li> <li>BLDD dma BMAR</li> <li>BLDD {ind}, BMAR [, next ARP]</li> </ul> |              |    | 1            | $\frac{1}{\sqrt{2}}$ | TMS320C2xx devices: The word of the source and/or<br>the destination space can be pointed to with a long im-<br>mediate value or a data-memory address. You can use<br>the RPT instruction with BLDD to move consecutive<br>words, pointed to indirectly in data memory, to contigu-<br>ous program-memory spaces. The number of words to<br>be moved is 1 greater than the number contained in the<br>RPTC at the beginning of the instruction.                                |
|                                                                                                                                                                               |              |    |              |                      | TMS320C5x devices: The word of the source and/or<br>the destination space can be pointed to with a long im-<br>mediate value, the contents of the BMAR, or a data-<br>memory address. You can use the RPT instruction with<br>BLDD to move consecutive words, pointed to indirectly<br>in data memory, to a contiguous program-memory<br>space. The number of words to be moved is 1 greater<br>than the number contained in the RPTC at the begin-<br>ning of the instruction. |
| BLDP dma                                                                                                                                                                      |              |    |              | $\checkmark$         | Block Move From Data Memory to Program<br>Memory                                                                                                                                                                                                                                                                                                                                                                                                                                |
| BLDP {ind} [, next ARP]                                                                                                                                                       |              |    |              | V                    | Copy a block of data memory into program memory<br>pointed to by the BMAR. You can use the RPT instruc-<br>tion with BLDP to move consecutive words, indirectly<br>pointed to in data memory, to a contiguous program-<br>memory space pointed to by the BMAR.                                                                                                                                                                                                                  |
| BLEZ pma                                                                                                                                                                      | $\checkmark$ |    |              | $\checkmark$         | Branch if Accumulator ≤ Zero                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| BLEZ pma [, {ind} [, next ARP]]                                                                                                                                               |              | V  | $\checkmark$ | V                    | If the contents of the accumulator are $\leq$ 0, branch to the specified program-memory address.                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                               |              |    |              |                      | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                               |              |    |              |                      | TMS320C2xx and TMS320C5x devices: Modify the current AR and ARP as specified when the –p porting switch is used.                                                                                                                                                                                                                                                                                                                                                                |

# Table A–3. Instruction Set Comparison (Continued)

| Syntax                                                     | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------------------------|--------------|--------------|--------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BLKD dma1, dma2                                            |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Block Move From Data Memory to Data Memory                                                                                                                                                                                                                                                                                                                                                  |
| BLKD dma1, {ind} [, next ARP]                              |              | √            | V            | 1            | Move a block of words from one location in data mem-<br>ory to another location in data memory. Modify the cur-<br>rent AR and ARP as specified. RPT or RPTK must be<br>used with BLKD, in the indirect addressing mode, if<br>more than one word is to be moved. The number of<br>words to be moved is 1 greater than the number<br>contained in RPTC at the beginning of the instruction. |
| BLKP pma, dma BLKP pma, {ind} [, next ARP]                 |              |              |              | √<br>√       | Block Move From Program Memory to Data<br>Memory                                                                                                                                                                                                                                                                                                                                            |
|                                                            |              |              |              |              | Move a block of words from a location in program<br>memory to a location in data memory. Modify the cur-<br>rent AR and ARP as specified. RPT or RPTK must be<br>used with BLKD, in the indirect addressing mode, if<br>more than one word is to be moved. The number of<br>words to be moved is 1 greater than the number<br>contained in RPTC at the beginning of the instruction.        |
| BLPD #pma, dma                                             |              |              | V            | $\checkmark$ | Block Move From Program Memory to Data                                                                                                                                                                                                                                                                                                                                                      |
| BLPD #pma, {ind} [, next ARP]                              |              |              | $\checkmark$ | $\checkmark$ | Memory                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>BLPD</b> BMAR, dma <b>BLPD</b> BMAR, {ind} [, next ARP] |              |              |              |              | Copy a block of program memory into data memory.<br>The block of program memory is pointed to by <i>src</i> , and<br>the destination block of data memory is pointed to by<br><i>dst</i> .                                                                                                                                                                                                  |
|                                                            |              |              |              |              | TMS320C2xx devices: The word of the source space<br>can be pointed to with a long immediate value. You can<br>use the RPT instruction with BLPD to move consecu-<br>tive words that are pointed at indirectly in data memory<br>to a contiguous program-memory space.                                                                                                                       |
|                                                            |              |              |              |              | TMS320C5x devices: The word of the source space<br>can be pointed to with a long immediate value or the<br>contents of the BMAR. You can use the RPT instruc-<br>tion with BLPD to move consecutive words that are<br>pointed at indirectly in data memory to contiguous pro-<br>gram-memory spaces.                                                                                        |
| BLZ pma                                                    | $\checkmark$ |              | $\checkmark$ | $\checkmark$ | Branch if Accumulator < Zero                                                                                                                                                                                                                                                                                                                                                                |
| <b>BLZ</b> pma [, {ind} [, next ARP]]                      |              | V            | $\checkmark$ |              | If the contents of the accumulator are < 0, branch to the specified program-memory address.                                                                                                                                                                                                                                                                                                 |
|                                                            |              |              |              |              | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                                                                                                                                                                                                                                              |
|                                                            |              |              |              |              | TMS320C2xx and TMS320C5x devices: Modify the current AR and ARP as specified when the –p porting switch is used.                                                                                                                                                                                                                                                                            |

| Syntax                                                        | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                         |
|---------------------------------------------------------------|--------------|--------------|--------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BNC pma[, {ind} [, next ARP]]                                 |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Branch on No Carry                                                                                                                                                  |
|                                                               |              |              |              |              | If the C bit = 0, branch to the specified program-<br>memory address.                                                                                               |
|                                                               |              |              |              |              | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                      |
|                                                               |              |              |              |              | TMS320C2xx and TMS320C5x devices: Modify the<br>current AR and ARP as specified when the –p porting<br>switch is used.                                              |
| BNV pma[, {ind} [, next ARP]]                                 |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Branch if No Overflow                                                                                                                                               |
|                                                               |              |              |              |              | If the OV flag is clear, branch to the specified program-<br>memory address.                                                                                        |
|                                                               |              |              |              |              | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                      |
|                                                               |              |              |              |              | TMS320C2xx and TMS320C5x devices: Modify the<br>current AR and ARP as specified when the –p porting<br>switch is used.                                              |
| BNZ pma                                                       | $\checkmark$ |              |              |              | Branch if Accumulator ≠ Zero                                                                                                                                        |
| <b>BNZ</b> <i>pma</i> [, { <i>ind</i> } [, <i>next ARP</i> ]] |              | V            | V            | V            | If the contents of the accumulator $\neq$ 0, branch to the specified program-memory address.                                                                        |
|                                                               |              |              |              |              | TMS320C2x devices: Modify the current AR and ARP as specified.                                                                                                      |
|                                                               |              |              |              |              | TMS320C2xx and TMS320C5x devices: Modify the current AR and ARP as specified when the –p porting switch is used.                                                    |
| BSAR [shift]                                                  |              |              |              | $\checkmark$ | Barrel Shift                                                                                                                                                        |
|                                                               |              |              |              |              | In a single cycle, execute a 1- to 16-bit right arithmetic barrel shift of the accumulator. The sign extension is determined by the sign-extension mode bit in ST1. |
| BV pma                                                        | $\checkmark$ |              |              |              | Branch on Overflow                                                                                                                                                  |
| BV pma [, {ind} [, next ARP]]                                 |              | V            | V            | V            | If the OV flag is set, branch to the specified program-<br>memory address and clear the OV flag.                                                                    |
|                                                               |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x de-<br>vices: Modify the current AR and ARP as specified.                                                                      |
|                                                               |              |              |              |              | TMS320C2xx and TMS320C5x devices: To modify the AR and ARP, use the –p porting switch.                                                                              |

| Syntax                                                       | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                |
|--------------------------------------------------------------|--------------|--------------|--------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BZ pma                                                       | $\checkmark$ |              | $\checkmark$ | $\checkmark$ | Branch if Accumulator = Zero                                                                                                                                                                                                                                                               |
| <b>BZ</b> <i>pma</i> [, { <i>ind</i> } [, <i>next ARP</i> ]] |              | V            |              |              | If the contents of the accumulator = 0, branch to the specified program-memory address.                                                                                                                                                                                                    |
|                                                              |              |              |              |              | TMS320C2x, TMS320C2xx and TMS320C5x devices: Modify the current AR and ARP as specified.                                                                                                                                                                                                   |
|                                                              |              |              |              |              | TMS320C2xx and TMS320C5x devices: To modify the AR and ARP, use the $-p$ porting switch.                                                                                                                                                                                                   |
| CALA                                                         | $\checkmark$ | $\checkmark$ | $\checkmark$ |              | Call Subroutine Indirect                                                                                                                                                                                                                                                                   |
|                                                              |              |              |              |              | The contents of the accumulator specify the address<br>of a subroutine. Increment the PC, push the PC onto<br>the stack, then load the 12 (TMS320C1x) or 16<br>(TMS320C2x/C2xx) LSBs of the accumulator into the<br>PC.                                                                    |
| CALA[D]                                                      |              |              |              | $\checkmark$ | Call Subroutine Indirect With Optional Delay                                                                                                                                                                                                                                               |
|                                                              |              |              |              |              | The contents of the accumulator specify the address<br>of a subroutine. Increment the PC and push it onto the<br>stack; then load the 16 LSBs of the accumulator into<br>the PC.                                                                                                           |
|                                                              |              |              |              |              | If you specify a delayed branch (CALAD), the next two<br>instruction words (two 1-word instructions or one<br>2-word instruction) are fetched and executed before<br>the call.                                                                                                             |
| CALL pma                                                     | $\checkmark$ |              |              |              | Call Subroutine                                                                                                                                                                                                                                                                            |
| CALL pma [,{ind} [, next ARP]]                               |              | V            | $\checkmark$ |              | The contents of the addressed program-memory loca-<br>tion specify the address of a subroutine. Increment the<br>PC by 2, push the PC onto the stack, then load the<br>specified program-memory address into the PC.                                                                       |
|                                                              |              |              |              |              | TMS320C2x and TMS320C2xx devices: Modify the current AR and ARP as specified.                                                                                                                                                                                                              |
| CALL[D] pma [, {ind} [, next                                 |              |              |              | $\checkmark$ | Call Unconditionally With Optional Delay                                                                                                                                                                                                                                                   |
| ARP]]                                                        |              |              |              |              | The contents of the addressed program-memory loca-<br>tion specify the address of a subroutine. Increment the<br>PC and push the PC onto the stack; then load the<br>specified program-memory address (symbolic or<br>numeric) into the PC. Modify the current AR and ARP<br>as specified. |
|                                                              |              |              |              |              | If you specify a delayed branch (CALLD), the next two instruction words (two 1-word instructions or one 2-word instruction) are fetched and executed before the call.                                                                                                                      |

# Table A–3. Instruction Set Comparison (Continued)

| Syntax                                                                                         | 1x | 2x           | 2xx          | 5x           | Description                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------|----|--------------|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CC</b> <i>pma, cond</i> <sub>1</sub> [ <i>, cond</i> <sub>2</sub> ] [ <i>,</i> ]            |    |              | $\checkmark$ |              | Call Conditionally                                                                                                                                                          |
|                                                                                                |    |              |              |              | If the specified conditions are met, control is passed to<br>the pma. Not all combinations of conditions are mean-<br>ingful.                                               |
| <b>CC</b> [ <i>D</i> ] <i>pma</i> , <i>cond</i> <sub>1</sub> [, <i>cond</i> <sub>2</sub> ] [,] |    |              |              | $\checkmark$ | Call Conditionally With Optional Delay                                                                                                                                      |
|                                                                                                |    |              |              |              | If the specified conditions are met, control is passed to<br>the pma. Not all combinations of conditions are mean-<br>ingful.                                               |
|                                                                                                |    |              |              |              | If you specify a delayed branch (CCD), the next two in-<br>struction words (two 1-word instructions or one 2-word<br>instruction) are fetched and executed before the call. |
| CLRC control bit                                                                               |    |              | $\checkmark$ | $\checkmark$ | Clear Control Bit                                                                                                                                                           |
|                                                                                                |    |              |              |              | Set the specified control bit to a logic 0. Maskable inter-<br>rupts are enabled immediately after the CLRC instruc-<br>tion executes.                                      |
| CMPL                                                                                           |    | $\checkmark$ | $\checkmark$ | $\checkmark$ | Complement Accumulator                                                                                                                                                      |
|                                                                                                |    |              |              |              | Complement the contents of the accumulator (1s complement).                                                                                                                 |
| CMPR CM                                                                                        |    | $\checkmark$ | $\checkmark$ | $\checkmark$ | Compare Auxiliary Register With AR0                                                                                                                                         |
|                                                                                                |    |              |              |              | Compare the contents of the current auxiliary register to AR0, based on the following cases:                                                                                |
|                                                                                                |    |              |              |              | If $CM = 00$ , test whether $AR(ARP) = AR0$ .                                                                                                                               |
|                                                                                                |    |              |              |              | If $CM = 01$ , test whether $AR(ARP) < AR0$ .                                                                                                                               |
|                                                                                                |    |              |              |              | If $CM = 10$ , test whether $AR(ARP) > AR0$ .                                                                                                                               |
|                                                                                                |    |              |              |              | If CM = 11, test whether AR(ARP) $\neq$ AR0.                                                                                                                                |
|                                                                                                |    |              |              |              | If the result is true, load a 1 into the TC status bit; otherwise, load a 0 into the TC bit. The comparison does not affect the tested registers.                           |
|                                                                                                |    |              |              |              | TMS320C5x devices: Compare the contents of the auxiliary register with the ARCR.                                                                                            |
| CNFD                                                                                           |    | $\checkmark$ | $\checkmark$ | $\checkmark$ | Configure Block as Data Memory                                                                                                                                              |
|                                                                                                |    |              |              |              | Configure on-chip RAM block B0 as data memory.<br>Block B0 is mapped into data-memory locations<br>512h-767h.                                                               |
|                                                                                                |    |              |              |              | TMS320C5x devices: Block B0 is mapped into data-<br>memory locations 512h–1023h.                                                                                            |

| Syntax                                                         | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                       |
|----------------------------------------------------------------|--------------|--------------|--------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CNFP                                                           |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Configure Block as Program Memory                                                                                                                                                                                                                                                                 |
|                                                                |              |              |              |              | Configure on-chip RAM block B0 as program memory.<br>Block B0 is mapped into program-memory locations<br>65280h–65535h.                                                                                                                                                                           |
|                                                                |              |              |              |              | TMS320C5x devices: Block B0 is mapped into data-<br>memory locations 65024h-65535h.                                                                                                                                                                                                               |
| CONF 2-bit constant                                            |              | $\checkmark$ |              |              | Configure Block as Program Memory                                                                                                                                                                                                                                                                 |
|                                                                |              |              |              |              | Configure on-chip RAM block B0/B1/B2/B3 as program memory. For information on the memory mapping of B0/B1/B2/B3, see the <i>TMS320C2x User's Guide</i> .                                                                                                                                          |
| CPL [#lk,] dma                                                 |              |              |              | $\checkmark$ | Compare DBMR or Immediate With Data Value                                                                                                                                                                                                                                                         |
| <b>CPL</b> [# <i>lk</i> ,] { <i>ind</i> } [, <i>next ARP</i> ] |              |              |              | V            | Compare two quantities: If the two quantities are equal, set the TC bit to 1; otherwise, clear the TC bit.                                                                                                                                                                                        |
| CRGT                                                           |              |              |              | $\checkmark$ | Test for ACC > ACCB                                                                                                                                                                                                                                                                               |
|                                                                |              |              |              |              | Compare the contents of the ACC with the contents of<br>the ACCB, then load the larger signed value into both<br>registers and modify the carry bit according to the com-<br>parison result. If the contents of ACC are greater than<br>or equal to the contents of ACCB, set the carry bit to 1. |
| CRLT                                                           |              |              |              | $\checkmark$ | Test for ACC < ACCB                                                                                                                                                                                                                                                                               |
|                                                                |              |              |              |              | Compare the contents of the ACC with the contents of<br>the ACCB, then load the smaller signed value into both<br>registers and modify the carry bit according to the com-<br>parison result. If the contents of ACC are less than the<br>contents of ACCB, clear the carry bit.                  |
| DINT                                                           | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Disable Interrupts                                                                                                                                                                                                                                                                                |
|                                                                |              |              |              |              | Disable all interrupts; set the INTM to 1. Maskable<br>interrupts are disabled immediately after the DINT<br>instruction executes. <u>DINT</u> does not disable the<br>unmaskable interrupt RS; DINT does not affect the<br>IMR.                                                                  |
| DMOV dma                                                       |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Data Move in Data Memory                                                                                                                                                                                                                                                                          |
| <b>DMOV</b> { <i>ind</i> } [, <i>next ARP</i> ]                | $\checkmark$ | $\checkmark$ | $\checkmark$ | V            | Copy the contents of the addressed data-memory location into the next higher address. DMOV moves data only within on-chip RAM blocks.                                                                                                                                                             |
|                                                                |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x devices: The on-chip RAM blocks are B0 (when configured as data memory), B1, and B2.                                                                                                                                                                         |

| Syntax                    | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                         |
|---------------------------|--------------|--------------|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EINT                      | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Enable Interrupts                                                                                                                                                                                                                                   |
|                           |              |              |              |              | Enable all interrupts; clear the INTM to 0. Maskable interrupts are enabled immediately after the EINT instruction executes.                                                                                                                        |
| EXAR                      |              |              |              | $\checkmark$ | Exchange ACCB With ACC                                                                                                                                                                                                                              |
|                           |              |              |              |              | Exchange the contents of the ACC with the contents of the ACCB.                                                                                                                                                                                     |
| FORT 1-bit constant       |              | $\checkmark$ |              |              | Format Serial Port Registers                                                                                                                                                                                                                        |
|                           |              |              |              |              | Load the FO with a 0 or a 1. If FO = 0, the registers are configured to receive/transmit 16-bit words. If FO = 1, the registers are configured to receive/transmit 8-bit bytes.                                                                     |
| IDLE                      |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Idle Until Interrupt                                                                                                                                                                                                                                |
|                           |              |              |              |              | Forces an executing program to halt execution and<br>wait until it receives a reset or an interrupt. The device<br>remains in an idle state until it is interrupted.                                                                                |
| IDLE2                     |              |              |              | $\checkmark$ | Idle Until Interrupt — Low-Power Mode                                                                                                                                                                                                               |
|                           |              |              |              |              | Removes the functional clock input from the internal<br>device; this allows for an extremely low-power mode.<br>The IDLE2 instruction forces an executing program to<br>halt execution and wait until it receives a reset or<br>unmasked interrupt. |
| IN dma, PA                | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Input Data From Port                                                                                                                                                                                                                                |
| IN {ind}, PA [, next ARP] | $\checkmark$ | V            | $\checkmark$ | $\checkmark$ | Read a 16-bit value from one of the external I/O ports into the addressed data-memory location.                                                                                                                                                     |
|                           |              |              |              |              | TMS320C1x devices: This is a 2-cycle instruction.<br>During the first cycle, the port address is sent to ad-<br>dress lines A2/PA2–A0/PA0; DEN goes low, strobing<br>in the data that the addressed peripheral places on<br>data bus D15–D0.        |
|                           |              |              |              |              | TMS320C2x devices: The IS line goes low to indicate<br>an I/O access, and the STRB, R/W, and READY tim-<br>ings are the same as for an external data-memory<br>read.                                                                                |
|                           |              |              |              |              | TMS320C2xx and TMS320C5x devices: The IS line<br>goes low to indicate an I/O access, and the STRB, RD,<br>and READY timings are the same as for an external<br>data-memory read.                                                                    |

| Syntax                                                                             | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------------------------------------------|--------------|--------------|--------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INTR K                                                                             |              |              | $\checkmark$ | $\checkmark$ | Soft Interrupt                                                                                                                                                                                                                                                                                                                                         |
|                                                                                    |              |              |              |              | Transfer program control to the program-memory address specified by $K$ (an integer from 0 to 31). This instruction allows you to use your software to execute any interrupt service routine. The interrupt vector locations are spaced apart by two addresses (0h, 2h, 4h,, 3Eh), allowing a 2-word branch instruction to be placed at each location. |
| LAC dma [, shift]                                                                  | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load Accumulator With Shift                                                                                                                                                                                                                                                                                                                            |
| LAC {ind} [, shift [, next ARP]]                                                   | V            | V            | V            | V            | Load the contents of the addressed data-memory<br>location into the accumulator. If a shift is specified, left<br>shift the value before loading it into the accumulator.<br>During shifting, low-order bits are zero filled, and high-<br>order bits are sign extended if SXM = 1.                                                                    |
| LACB                                                                               |              |              |              | $\checkmark$ | Load Accumulator With ACCB                                                                                                                                                                                                                                                                                                                             |
|                                                                                    |              |              |              |              | Load the contents of the accumulator buffer into the accumulator.                                                                                                                                                                                                                                                                                      |
| LACC dma [, shift <sub>1</sub> ]                                                   |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load Accumulator With Shift                                                                                                                                                                                                                                                                                                                            |
| LACC {ind} [, shift <sub>1</sub> [, next ARP]]<br>LACC #lk [, shift <sub>2</sub> ] |              |              | √<br>√       |              | Load the contents of the addressed data-memory<br>location or the 16-bit constant into the accumulator. If<br>a shift is specified, left shift the value before loading it<br>into the accumulator. During shifting, low-order bits are<br>zero filled, and high-order bits are sign extended if<br>SXM = 1.                                           |
| LACK 8-bit constant                                                                | $\checkmark$ | $\checkmark$ | $\checkmark$ |              | Load Accumulator Immediate Short                                                                                                                                                                                                                                                                                                                       |
|                                                                                    |              |              |              |              | Load an 8-bit constant into the accumulator. The 24 MSBs of the accumulator are zeroed.                                                                                                                                                                                                                                                                |
| LACL dma                                                                           |              |              | $\checkmark$ | $\checkmark$ | Load Low Accumulator and Clear High                                                                                                                                                                                                                                                                                                                    |
| LACL {ind} [, next ARP]                                                            |              |              | $\checkmark$ | $\checkmark$ | Accumulator                                                                                                                                                                                                                                                                                                                                            |
| LACL #k                                                                            |              |              | V            | $\checkmark$ | Load the contents of the addressed data-memory<br>location or zero-extended 8-bit constant into the<br>16 LSBs of the accumulator. The MSBs of the accumu-<br>lator are zeroed. The data is treated as a 16-bit<br>unsigned number.                                                                                                                    |
|                                                                                    |              |              |              |              | TMS320C2xx: A constant of 0 clears the contents of the accumulator to 0 with no sign extension.                                                                                                                                                                                                                                                        |

Table A–3. Instruction Set Comparison (Continued)

| Syntax                           | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------|--------------|--------------|--------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LACT dma LACT {ind} [, next ARP] |              | √<br>√       | √<br>√       | √<br>√       | Load Accumulator With Shift Specified by T<br>Register                                                                                                                                                                                                                                                                                                                 |
|                                  |              | v            | v            | v            | Left shift the contents of the addressed data-memory<br>location by the value specified in the four LSBs of the<br>T register; load the result into the accumulator. If a shift<br>is specified, left shift the value before loading it into the<br>accumulator. During shifting, low-order bits are zero<br>filled, and high-order bits are sign extended if SXM = 1. |
| LALK #lk[, shift]                |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load Accumulator Long Immediate With Shift                                                                                                                                                                                                                                                                                                                             |
|                                  |              |              |              |              | Load a 16-bit immediate value into the accumulator. If<br>a shift is specified, left shift the constant before loading<br>it into the accumulator. During shifting, low-order bits<br>are zero filled, and high-order bits are sign extended if<br>SXM = 1.                                                                                                            |
| LAMM dma LAMM {ind} [, next ARP] |              |              |              |              | Load Accumulator With Memory-Mapped<br>Register                                                                                                                                                                                                                                                                                                                        |
|                                  |              |              |              | v            | Load the contents of the addressed memory-mapped<br>register into the low word of the accumulator. The nine<br>MSBs of the data-memory address are cleared,<br>regardless of the current value of DP or the nine MSBs<br>of AR (ARP).                                                                                                                                  |
| LAR AR, dma                      | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load Auxiliary Register                                                                                                                                                                                                                                                                                                                                                |
| LAR AR, {ind} [, next ARP]       | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | TMS320C1x and TMS320C2x devices: Load the con-                                                                                                                                                                                                                                                                                                                         |
| LAR AR, #k                       |              |              | $\checkmark$ | $\checkmark$ | tents of the addressed data-memory location into the designated auxiliary register.                                                                                                                                                                                                                                                                                    |
| LAR AR, #lk                      |              |              | V            | V            | TMS320C25, TMS320C2xx, and TMS320C5x de-<br>vices: Load the contents of the addressed data-<br>memory location or an 8-bit or 16-bit immediate value<br>into the designated auxiliary register.                                                                                                                                                                        |
| LARK AR, 8-bit constant          | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load Auxiliary Register Immediate Short                                                                                                                                                                                                                                                                                                                                |
|                                  |              |              |              |              | Load an 8-bit positive constant into the designated auxiliary register.                                                                                                                                                                                                                                                                                                |
| LARP 1-bit constant              | $\checkmark$ |              |              |              | Load Auxiliary Register Pointer                                                                                                                                                                                                                                                                                                                                        |
| LARP 3-bit constant              |              | $\checkmark$ | $\checkmark$ | V            | TMS320C1x devices: Load a 1-bit constant into the auxiliary register pointer (specifying AR0 or AR1).                                                                                                                                                                                                                                                                  |
|                                  |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x de-<br>vices: Load a 3-bit constant into the auxiliary register<br>pointer (specifying AR0–AR7).                                                                                                                                                                                                                                  |

| Syntax                           | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                                    |
|----------------------------------|--------------|--------------|--------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LDP dma                          | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load Data-Memory Page Pointer                                                                                                                                                                                                                                                                                                                  |
| LDP {ind} [, next ARP]<br>LDP #k | $\checkmark$ | $\checkmark$ |              |              | TMS320C1x devices: Load the LSB of the contents of the addressed data-memory location into the DP register. All high-order bits are ignored. DP = 0 defines page 0 (words $0-127$ ), and DP = 1 defines page 1 (words $128-143/255$ ).                                                                                                         |
|                                  |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x de-<br>vices: Load the nine LSBs of the addressed data-<br>memory location or a 9-bit immediate value into the DP<br>register. The DP and 7-bit data-memory address are<br>concatenated to form 16-bit data-memory addresses.                                                                             |
| LDPK 1-bit constant              | $\checkmark$ |              |              |              | Load Data-Memory Page Pointer Immediate                                                                                                                                                                                                                                                                                                        |
| LDPK 9-bit constant              |              | V            | V            | $\checkmark$ | TMS320C1x devices: Load a 1-bit immediate value<br>into the DP register. $DP = 0$ defines page 0<br>(words 0–127), and $DP = 1$ defines page 1<br>(words 128–143/255).                                                                                                                                                                         |
|                                  |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x devices: Load a 9-bit immediate into the DP register. The DP and 7-bit data-memory address are concatenated to form 16-bit data-memory addresses. DP $\ge$ 8 specifies external data memory. DP = 4 through 7 specifies on-chip RAM blocks B0 or B1. Block B2 is located in the upper 32 words of page 0. |
| LMMR dma, #lk                    |              |              |              | $\checkmark$ | Load Memory-Mapped Register                                                                                                                                                                                                                                                                                                                    |
| LMMR {ind}, #lk [, next ARP]     |              |              |              | V            | Load the contents of the memory-mapped register<br>pointed at by the seven LSBs of the direct or indirect<br>data-memory value into the long immediate addressed<br>data-memory location. The nine MSBs of the data-<br>memory address are cleared, regardless of the current<br>value of DP or the nine MSBs of AR (ARP).                     |
| LPH dma                          |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load High P Register                                                                                                                                                                                                                                                                                                                           |
| LPH {ind} [, next ARP]           |              | $\checkmark$ | V            | V            | Load the contents of the addressed data-memory location into the 16 MSBs of the P register; the LSBs are not affected.                                                                                                                                                                                                                         |
| LRLK AR, Ik                      |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load Auxiliary Register Long Immediate                                                                                                                                                                                                                                                                                                         |
|                                  |              |              |              |              | Load a 16-bit immediate value into the designated auxiliary register.                                                                                                                                                                                                                                                                          |
| LST dma                          | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load Status Register                                                                                                                                                                                                                                                                                                                           |
| LST {ind} [, next ARP]           | $\checkmark$ | $\checkmark$ | $\checkmark$ | V            | Load the contents of the addressed data-memory location into the ST (TMS320C1x) or into ST0 (TMS320C2x/2xx/5x).                                                                                                                                                                                                                                |

Table A–3. Instruction Set Comparison (Continued)

| Syntax                            | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                            |
|-----------------------------------|--------------|--------------|--------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LST #n, dma                       |              |              | $\checkmark$ |              | Load Status Register n                                                                                                                                                                                                                                                                                                 |
| LST #n, {ind} [, next ARP]        |              | V            | V            | $\checkmark$ | Load the contents of the addressed data-memory location into ST <i>n</i> .                                                                                                                                                                                                                                             |
| LST1 dma                          |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load ST1                                                                                                                                                                                                                                                                                                               |
| LST1 {ind} [, next ARP]           |              | V            | $\checkmark$ | $\checkmark$ | Load the contents of the addressed data-memory location into ST1.                                                                                                                                                                                                                                                      |
| LT dma                            | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load T Register                                                                                                                                                                                                                                                                                                        |
| LT {ind} [, next ARP]             | $\checkmark$ | V            | V            | $\checkmark$ | Load the contents of the addressed data-memory location into the T register (TMS320C1x/2x/2xx) or TREG0 (TMS320C5x).                                                                                                                                                                                                   |
| LTA dma<br>LTA {ind} [, next ARP] | $\checkmark$ | لا<br>لا     |              |              | Load T Register and Accumulate Previous<br>Product                                                                                                                                                                                                                                                                     |
|                                   | v            | v            | v            | v            | Load the contents of the addressed data-memory<br>location into T register (TMS320C1x/2x/2xx) or<br>TREG0 (TMS320C5x) and add the contents of the<br>P register to the accumulator.                                                                                                                                    |
|                                   |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x devices: Before the add, shift the contents of the P register as specified by the PM status bits.                                                                                                                                                                                 |
| LTD dma<br>LTD {ind} [, next ARP] | $\checkmark$ | V<br>V       | √<br>√       |              | Load T Register, Accumulate Previous Product, and Move Data                                                                                                                                                                                                                                                            |
|                                   | v            | v            | v            | v            | Load the contents of the addressed data-memory location into the T register (TMS320C1x/2x/2xx) or TREG0 (TMS320C5x), add the contents of the P register to the accumulator, and copy the contents of the specified location into the next higher address (both data-memory locations must reside in on-chip data RAM). |
|                                   |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x devices: Before the add, shift the contents of the P register as specified by the PM status bits.                                                                                                                                                                                 |
| LTP dma                           |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load T Register, Store P Register in Accumulator                                                                                                                                                                                                                                                                       |
| LTP {ind} [, next ARP]            |              | $\checkmark$ | V            | V            | Load the contents of the addressed data-memory location into the T register (TMS320C1x/2x/2xx) or TREG0 (TMS320C5x). Store the contents of the product register into the accumulator.                                                                                                                                  |

Table A–3. Instruction Set Comparison (Continued)

| Syntax                              | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                          |
|-------------------------------------|--------------|--------------|--------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LTS dma                             |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load T Register, Subtract Previous Product                                                                                                                                                                                                                                                           |
| LTS {ind} [, next ARP]              |              | $\checkmark$ | V            | $\checkmark$ | Load the contents of the addressed data-memory location into the T register (TMS320C1x/2x/2xx) or TREG0 (TMS320C5x). Shift the contents of the P register as specified by the PM status bits, and subtract the result from the accumulator.                                                          |
| MAC pma, dma                        |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Multiply and Accumulate                                                                                                                                                                                                                                                                              |
| MAC pma, {ind} [, next ARP]         |              | V            | $\checkmark$ | $\checkmark$ | Multiply a data-memory value by a program-memory value and add the previous product (shifted as specified by the PM status bits) to the accumulator.                                                                                                                                                 |
| MACD dma, pma                       |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Multiply and Accumulate With Data Move                                                                                                                                                                                                                                                               |
| MACD pma, {ind} [, next ARP]        |              | V            | V            | V            | Multiply a data-memory value by a program-memory<br>value and add the previous product (shifted as speci-<br>fied by the PM status bits) to the accumulator. If the<br>data-memory address is in on-chip RAM block B0, B1,<br>or B2, copy the contents of the address to the next<br>higher address. |
| MADD dma<br>MADD {ind} [, next ARP] |              |              |              |              | Multiply and Accumulate With Data Move and<br>Dynamic Addressing                                                                                                                                                                                                                                     |
|                                     |              |              |              | v            | Multiply a data-memory value by a program-memory<br>value and add the previous product (shifted as defined<br>by the PM status bits) into the accumulator. The<br>program-memory address is contained in the BMAR;<br>this allows for dynamic addressing of coefficient<br>tables.                   |
|                                     |              |              |              |              | MADD functions the same as MADS, with the addition of data move for on-chip RAM blocks.                                                                                                                                                                                                              |
| MADS dma<br>MADS {ind} [, next ARP] |              |              |              | √<br>√       | Multiply and Accumulate With Dynamic<br>Addressing                                                                                                                                                                                                                                                   |
| _ () [,                             |              |              |              |              | Multiply a data-memory value by a program-memory<br>value and add the previous product (shifted as defined<br>by the PM status bits) into the accumulator. The<br>program-memory address is contained in the BMAR;<br>this allows for dynamic addressing of coefficient<br>tables.                   |
| MAR dma                             | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Modify Auxiliary Register                                                                                                                                                                                                                                                                            |
| MAR {ind} [, next ARP]              | $\checkmark$ | $\checkmark$ | V            | $\checkmark$ | Modify the current AR or ARP as specified. MAR acts as NOP in indirect addressing mode.                                                                                                                                                                                                              |

| Table A–3. | Instruction | Set Com  | parison | (Continued) | ) |
|------------|-------------|----------|---------|-------------|---|
| 100101101  |             | 001 0011 | pancon  |             | · |

| Syntax                                         | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                |
|------------------------------------------------|--------------|--------------|--------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MPY dma                                        | $\checkmark$ | $\checkmark$ |              |              | Multiply                                                                                                                                                                                                                                                                                   |
| MPY {ind} [, next ARP]<br>MPY #k<br>MPY #lk    | $\checkmark$ | $\checkmark$ | イ<br>イ<br>イ  | <br>         | TMS320C1x and TMS320C2x devices: Multiply the contents of the T register by the contents of the addressed data-memory location; place the result in the P register.                                                                                                                        |
|                                                |              |              |              |              | TMS320C2xx and TMS320C5x devices: Multiply the contents of the T register (TMS320C2xx) or TREG0 (TMS320C5x) by the contents of the addressed data-<br>memory location or a 13-bit or 16-bit immediate value; place the result in the P register.                                           |
| MPYA dma                                       |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Multiply and Accumulate Previous Product                                                                                                                                                                                                                                                   |
| <b>MPYA</b> { <i>ind</i> } [, <i>next</i> ARP] |              | $\checkmark$ | V            | V            | Multiply the contents of the T register (TMS320C2x/<br>2xx) or TREG0 (TMS320C5x) by the contents of the<br>addressed data-memory location; place the result in<br>the P register. Add the previous product (shifted as<br>specified by the PM status bits) to the accumulator.             |
| MPYK 13-bit constant                           | $\checkmark$ |              | $\checkmark$ | $\checkmark$ | Multiply Immediate                                                                                                                                                                                                                                                                         |
|                                                |              |              |              |              | Multiply the contents of the T register (TMS320C2x/<br>2xx) or TREG0 (TMS320C5x) by a signed 13-bit<br>constant; place the result in the P register.                                                                                                                                       |
| MPYS dma                                       |              | $\checkmark$ | $\checkmark$ |              | Multiply and Subtract Previous Product                                                                                                                                                                                                                                                     |
| <b>MPYS</b> { <i>ind</i> } [, <i>next</i> ARP] |              | V            | V            | V            | Multiply the contents of the T register (TMS320C2x/<br>2xx) or TREG0 (TMS320C5x) by the contents of the<br>addressed data-memory location; place the result in<br>the P register. Subtract the previous product (shifted<br>as specified by the PM status bits) from the accumula-<br>tor. |
| MPYU dma                                       |              |              | $\checkmark$ |              | Multiply Unsigned                                                                                                                                                                                                                                                                          |
| <b>MPYU</b> { <i>ind</i> } [, <i>next</i> ARP] |              | V            | V            | V            | Multiply the unsigned contents of the T register (TMS320C2x/2xx) or TREG0 (TMS320C5x) by the unsigned contents of the addressed data-memory location; place the result in the P register.                                                                                                  |
| NEG                                            |              | $\checkmark$ |              |              | Negate Accumulator                                                                                                                                                                                                                                                                         |
|                                                |              |              |              |              | Negate (2s complement) the contents of the accumu-<br>lator.                                                                                                                                                                                                                               |
| NMI                                            |              |              |              |              | Nonmaskable Interrupt                                                                                                                                                                                                                                                                      |
|                                                |              |              |              |              | Force the program counter to the nonmaskable inter-<br>rupt vector location 24h. NMI has the same effect as a<br>hardware nonmaskable interrupt.                                                                                                                                           |

| Syntax                                                         | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------------------|--------------|--------------|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NOP                                                            | $\checkmark$ | $\checkmark$ | $\checkmark$ |              | No Operation                                                                                                                                                                                                                                                                                                    |
|                                                                |              |              |              |              | Perform no operation.                                                                                                                                                                                                                                                                                           |
| NORM                                                           |              | $\checkmark$ | $\checkmark$ |              | Normalize Contents of Accumulator                                                                                                                                                                                                                                                                               |
| NORM {ind}                                                     |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Normalize a signed number in the accumulator.                                                                                                                                                                                                                                                                   |
| OPL [#lk,] dma                                                 |              |              |              | $\checkmark$ | OR With DBMR or Long Immediate                                                                                                                                                                                                                                                                                  |
| <b>OPL</b> [# <i>lk</i> ,] { <i>ind</i> } [, <i>next ARP</i> ] |              |              |              | $\checkmark$ | If a long immediate is specified, OR it with the value at<br>the specified data-memory location; otherwise, the<br>second operand of the OR operation is the contents of<br>the DBMR. The result is written back into the data-<br>memory location previously holding the first operand.                        |
| OR dma                                                         | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | OR With Accumulator                                                                                                                                                                                                                                                                                             |
| <pre>OR {ind} [, next ARP] OR #lk [, shift]</pre>              | V            | V            |              |              | TMS320C1x and TMS320C2x devices: OR the 16 LSBs of the accumulator with the contents of the addressed data-memory location. The 16 MSBs of the accumulator are ORed with 0s.                                                                                                                                    |
|                                                                |              |              |              |              | TMS320C2xx and TMS320C5x devices: OR the<br>16 LSBs of the accumulator or a 16-bit immediate val-<br>ue with the contents of the addressed data-memory<br>location. If a shift is specified, left-shift before ORing.<br>Low-order bits below and high-order bits above the<br>shifted value are treated as 0s. |
| ORB                                                            |              |              |              | $\checkmark$ | OR ACCB With Accumulator                                                                                                                                                                                                                                                                                        |
|                                                                |              |              |              |              | OR the contents of the ACCB with the contents of the accumulator. ORB places the result in the accumulator.                                                                                                                                                                                                     |
| ORK #lk [, shiff]                                              |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | OR Immediate With Accumulator with Shift                                                                                                                                                                                                                                                                        |
|                                                                |              |              |              |              | OR a 16-bit immediate value with the contents of the accumulator. If a shift is specified, left-shift the constant before ORing. Low-order bits below and high-order bits above the shifted value are treated as 0s.                                                                                            |

#### Instruction Set Comparison Table

| Syntax                                                    | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                             |
|-----------------------------------------------------------|--------------|--------------|--------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OUT dma, PA                                               | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Output Data to Port                                                                                                                                                                                     |
| <b>OUT</b> { <i>ind</i> }, <i>PA</i> [, <i>next ARP</i> ] | $\checkmark$ | $\checkmark$ | $\checkmark$ | V            | Write a 16-bit value from a data-memory location to the specified I/O port.                                                                                                                             |
|                                                           |              |              |              |              | TMS320C1x devices: The first cycle of this instruction places the port address onto address lines A2/PA2–A0/PA0. During the same cycle, WE goes low and the data word is placed on the data bus D15–D0. |
|                                                           |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x de-<br>vices: The IS line goes low to indicate an I/O access;<br>the STRB, R/W, and READY timings are the same as<br>for an external data-memory write.            |
| PAC                                                       | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Load Accumulator With P Register                                                                                                                                                                        |
|                                                           |              |              |              |              | Load the contents of the P register into the accumula-<br>tor.                                                                                                                                          |
|                                                           |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x de-<br>vices: Before the load, shift the P register as specified<br>by the PM status bits.                                                                         |
| POP                                                       |              |              | $\checkmark$ |              | Pop Top of Stack to Low Accumulator                                                                                                                                                                     |
|                                                           |              |              |              |              | Copy the contents of the top of the stack into the 12 (TMS320C1x) or 16 (TMS320C2x/2xx/5x) LSBs of the accumulator and then pop the stack one level. The MSBs of the accumulator are zeroed.            |
| POPD dma                                                  |              | $\checkmark$ | $\checkmark$ |              | Pop Top of Stack to Data Memory                                                                                                                                                                         |
| <b>POPD</b> { <i>ind</i> } [, <i>next ARP</i> ]           |              | V            | $\checkmark$ | V            | Transfer the value on the top of the stack into the addressed data-memory location and then pop the stack one level.                                                                                    |
| PSHD dma                                                  |              | $\checkmark$ | $\checkmark$ |              | Push Data-Memory Value Onto Stack                                                                                                                                                                       |
| <b>PSHD</b> { <i>ind</i> } [, <i>next</i> ARP]            |              | $\checkmark$ | $\checkmark$ | V            | Copy the addressed data-memory location onto the<br>top of the stack. The stack is pushed down one level<br>before the value is copied.                                                                 |
| PUSH                                                      | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Push Low Accumulator Onto Stack                                                                                                                                                                         |
|                                                           |              |              |              |              | Copy the contents of the 12 (TMS320C1x) or 16 (TMS320C2x/2xx/5x) LSBs of the accumulator onto the top of the hardware stack. The stack is pushed down one level before the value is copied.             |
| RC                                                        |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Reset Carry Bit                                                                                                                                                                                         |
|                                                           |              |              |              |              | Reset the C status bit to 0.                                                                                                                                                                            |

Table A–3. Instruction Set Comparison (Continued)

| Syntax                                                       | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------------------------------------|--------------|--------------|--------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RET                                                          | $\checkmark$ | $\checkmark$ | $\checkmark$ |              | Return From Subroutine                                                                                                                                                                                                                                                                                                                                                                             |
|                                                              |              |              |              |              | Copy the contents of the top of the stack into the PC and pop the stack one level.                                                                                                                                                                                                                                                                                                                 |
| <b>RET</b> [ <i>D</i> ]                                      |              |              |              | $\checkmark$ | Return From Subroutine With Optional Delay                                                                                                                                                                                                                                                                                                                                                         |
|                                                              |              |              |              |              | Copy the contents of the top of the stack into the PC and pop the stack one level.                                                                                                                                                                                                                                                                                                                 |
|                                                              |              |              |              |              | If you specify a delayed branch (RETD), the next two<br>instruction words (two 1-word instructions or one<br>2-word instruction) are fetched and executed before<br>the return.                                                                                                                                                                                                                    |
| <b>RETC</b> cond <sub>1</sub> [, cond <sub>2</sub> ] [,]     |              |              | $\checkmark$ |              | Return Conditionally                                                                                                                                                                                                                                                                                                                                                                               |
|                                                              |              |              |              |              | If the specified conditions are met, RETC performs a standard return. Not all combinations of conditions are meaningful.                                                                                                                                                                                                                                                                           |
| <b>RETC</b> [D] cond <sub>1</sub> [, cond <sub>2</sub> ] [,] |              |              |              | $\checkmark$ | Return Conditionally With Optional Delay                                                                                                                                                                                                                                                                                                                                                           |
|                                                              |              |              |              |              | If the specified conditions are met, RETC performs a standard return. Not all combinations of conditions are meaningful.                                                                                                                                                                                                                                                                           |
|                                                              |              |              |              |              | If you specify a delayed branch (RETCD), the next two<br>instruction words (two 1-word instructions or one<br>2-word instruction) are fetched and executed before<br>the return.                                                                                                                                                                                                                   |
| RETE                                                         |              |              |              | $\checkmark$ | Enable Interrupts and Return From Interrupt                                                                                                                                                                                                                                                                                                                                                        |
|                                                              |              |              |              |              | Copy the contents of the top of the stack into the PC<br>and pop the stack one level. RETE automatically<br>clears the global interrupt enable bit and pops the<br>shadow registers (stored when the interrupt was tak-<br>en) back into their corresponding strategic registers.<br>The following registers are shadowed: ACC, ACCB,<br>PREG, ST0, ST1, PMST, ARCR, INDX, TREG0,<br>TREG1, TREG2. |
| RETI                                                         |              |              |              | $\checkmark$ | Return From Interrupt                                                                                                                                                                                                                                                                                                                                                                              |
|                                                              |              |              |              |              | Copy the contents of the top of the stack into the PC<br>and pop the stack one level. RETI also pops the values<br>in the shadow registers (stored when the interrupt was<br>taken) back into their corresponding strategic regis-<br>ters. The following registers are shadowed: ACC,<br>ACCB, PREG, ST0, ST1, PMST, ARCR, INDX,<br>TREG0, TREG1, TREG2.                                          |

| Syntax                                        | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                           |
|-----------------------------------------------|--------------|--------------|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RFSM                                          |              | $\checkmark$ |              |              | Reset Serial Port Frame Synchronization Mode                                                                                                                                                                          |
|                                               |              |              |              |              | Reset the FSM status bit to 0.                                                                                                                                                                                        |
| RHM                                           |              | $\checkmark$ |              | $\checkmark$ | Reset Hold Mode                                                                                                                                                                                                       |
|                                               |              |              |              |              | Reset the HM status bit to 0.                                                                                                                                                                                         |
| ROL                                           |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Rotate Accumulator Left                                                                                                                                                                                               |
|                                               |              |              |              |              | Rotate the accumulator left one bit.                                                                                                                                                                                  |
| ROLB                                          |              |              |              | $\checkmark$ | Rotate ACCB and Accumulator Left                                                                                                                                                                                      |
|                                               |              |              |              |              | Rotate the ACCB and the accumulator left by one bit; this results in a 65-bit rotation.                                                                                                                               |
| ROR                                           |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Rotate Accumulator Right                                                                                                                                                                                              |
|                                               |              |              |              |              | Rotate the accumulator right one bit.                                                                                                                                                                                 |
| RORB                                          |              |              |              | $\checkmark$ | Rotate ACCB and Accumulator Right                                                                                                                                                                                     |
|                                               |              |              |              |              | Rotate the ACCB and the accumulator right one bit; this results in a 65-bit rotation.                                                                                                                                 |
| ROVM                                          | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Reset Overflow Mode                                                                                                                                                                                                   |
|                                               |              |              |              |              | Reset the OVM status bit to 0; this disables overflow mode.                                                                                                                                                           |
| RPT dma                                       |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Repeat Next Instruction                                                                                                                                                                                               |
| <b>RPT</b> { <i>ind</i> } [, <i>next</i> ARP] |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | TMS320C2x devices: Load the eight LSBs of the                                                                                                                                                                         |
| RPT #k<br>RPT #lk                             |              |              | √<br>√       |              | addressed value into the RPTC; the instruction follow-<br>ing RPT is executed the number of times indicated by<br>RPTC + 1.                                                                                           |
|                                               |              |              |              |              | TMS320C2xx and TMS320C5x devices: Load the eight LSBs of the addressed value or an 8-bit or 16-bit immediate value into the RPTC; the instruction following RPT is repeated <i>n</i> times, where <i>n</i> is RPTC+1. |
| RPTB pma                                      |              |              |              | $\checkmark$ | Repeat Block                                                                                                                                                                                                          |
|                                               |              |              |              |              | RPTB repeats a block of instructions the number of times specified by the memory-mapped BRCR without any penalty for looping. The BRCR must be loaded before RPTB is executed.                                        |
| RPTK #k                                       |              | V            | V            | V            | Repeat Instruction as Specified by Immediate Value                                                                                                                                                                    |
|                                               |              |              |              |              | Load the 8-bit immediate value into the RPTC; the instruction following RPTK is executed the number of times indicated by RPTC + 1.                                                                                   |

| Syntax                                                          | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------------------------------|--------------|--------------|--------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RPTZ #/k                                                        |              |              |              | V            | Repeat Preceded by Clearing the Accumulator<br>and P Register                                                                                                                                                                                                                                                  |
|                                                                 |              |              |              |              | Clear the accumulator and product register and repeat the instruction following RPTZ <i>n</i> times, where $n = lk+1$ .                                                                                                                                                                                        |
| RSXM                                                            |              | $\checkmark$ |              |              | Reset Sign-Extension Mode                                                                                                                                                                                                                                                                                      |
|                                                                 |              |              |              |              | Reset the SXM status bit to 0; this suppresses sign<br>extension on shifted data values for the following arith-<br>metic instructions: ADD, ADDT, ADLK, LAC, LACT,<br>LALK, SBLK, SUB, and SUBT.                                                                                                              |
| RTC                                                             |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Reset Test/Control Flag                                                                                                                                                                                                                                                                                        |
|                                                                 |              |              |              |              | Reset the TC status bit to 0.                                                                                                                                                                                                                                                                                  |
| RTXM                                                            |              | $\checkmark$ |              |              | Reset Serial Port Transmit Mode                                                                                                                                                                                                                                                                                |
|                                                                 |              |              |              |              | Reset the TXM status bit to 0; this configures the serial port transmit section in a mode where it is controlled by an FSX.                                                                                                                                                                                    |
| RXF                                                             |              | $\checkmark$ |              |              | Reset External Flag                                                                                                                                                                                                                                                                                            |
|                                                                 |              |              |              |              | Reset XF pin and the XF status bit to 0.                                                                                                                                                                                                                                                                       |
| SACB                                                            |              |              |              | $\checkmark$ | Store Accumulator in ACCB                                                                                                                                                                                                                                                                                      |
|                                                                 |              |              |              |              | Copy the contents of the accumulator into the ACCB.                                                                                                                                                                                                                                                            |
| SACH dma [, shiff]                                              | $\checkmark$ | $\checkmark$ |              |              | Store High Accumulator With Shift                                                                                                                                                                                                                                                                              |
| <b>SACH</b> { <i>ind</i> } [, <i>shift</i> [, <i>next</i> ARP]] | V            | V            | V            | $\checkmark$ | Copy the contents of the accumulator into a shifter.<br>Shift the entire contents by zero, one, or four bits<br>(TMS320C1x) or from zero to seven bits<br>(TMS320C2x/2xx/5x), and then copy the 16 MSBs of<br>the shifted value into the addressed data-memory<br>location. The accumulator is not affected.   |
| SACL dma                                                        | $\checkmark$ |              |              |              | Store Low Accumulator With Shift                                                                                                                                                                                                                                                                               |
| SACL dma [, shiff]                                              | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | TMS320C1x devices: Store the 16 LSBs of the accu-                                                                                                                                                                                                                                                              |
| <b>SACL</b> { <i>ind</i> } [, <i>shift</i> [, <i>next</i> ARP]] |              | V            | V            | $\checkmark$ | mulator into the addressed data-memory location. A shift value of 0 must be specified if the ARP is to be changed.                                                                                                                                                                                             |
|                                                                 |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x devices: Store the 16 LSBs of the accumulator into the addressed data-memory location. If a shift is specified, shift the contents of the accumulator before storing. Shift values are zero, one, or four bits (TMS320C20) or from zero to seven bits (TMS320C2x/2xx/5x). |

| Syntax                     | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                               |
|----------------------------|--------------|--------------|--------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SAMM dma                   |              |              |              | $\checkmark$ | Store Accumulator in Memory-Mapped Register                                                                                                                                                                                               |
| SAMM {ind} [, next ARP]    |              |              |              | V            | Store the low word of the accumulator in the addressed<br>memory-mapped register. The upper nine bits of the<br>data address are cleared, regardless of the current val-<br>ue of DP or the nine MSBs of AR (ARP).                        |
| SAR AR, dma                | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Store Auxiliary Register                                                                                                                                                                                                                  |
| SAR AR, {ind} [, next ARP] | $\checkmark$ | V            | $\checkmark$ | $\checkmark$ | Store the contents of the specified auxiliary register in the addressed data-memory location.                                                                                                                                             |
| SATH                       |              |              |              | $\checkmark$ | Barrel-Shift Accumulator as Specified<br>by T Register 1                                                                                                                                                                                  |
|                            |              |              |              |              | If bit 4 of TREG1 is a 1, barrel-shift the accumulator right by 16 bits; otherwise, the accumulator is unaffected.                                                                                                                        |
| SATL                       |              |              |              | $\checkmark$ | Barrel-Shift Low Accumulator as Specified by T Register 1                                                                                                                                                                                 |
|                            |              |              |              |              | Barrel-shift the accumulator right by the value speci-<br>fied in the four LSBs of TREG1.                                                                                                                                                 |
| SBB                        |              |              |              | $\checkmark$ | Subtract ACCB From Accumulator                                                                                                                                                                                                            |
|                            |              |              |              |              | Subtract the contents of the ACCB from the accumula-<br>tor. The result is stored in the accumulator; the accu-<br>mulator buffer is not affected.                                                                                        |
| SBBB                       |              |              |              | $\checkmark$ | Subtract ACCB From Accumulator With Borrow                                                                                                                                                                                                |
|                            |              |              |              |              | Subtract the contents of the ACCB and the logical inversion of the carry bit from the accumulator. The result is stored in the accumulator; the accumulator buffer is not affected. Clear the carry bit if the result generates a borrow. |
| SBLK #lk [, shiff]         |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Subtract From Accumulator Long Immediate<br>With Shift                                                                                                                                                                                    |
|                            |              |              |              |              | Subtract the immediate value from the accumulator. If a shift is specified, left shift the value before subtracting. During shifting, low-order bits are zero filled, and high-order bits are sign extended if $SXM = 1$ .                |
| SBRK #k                    |              | V            | V            | V            | Subtract From Auxiliary Register Short<br>Immediate                                                                                                                                                                                       |
|                            |              |              |              |              | Subtract the 8-bit immediate value from the designated auxiliary register.                                                                                                                                                                |
| SC                         |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Set Carry Bit                                                                                                                                                                                                                             |
|                            |              |              |              |              | Set the C status bit to 1.                                                                                                                                                                                                                |

| Syntax                       | 1x | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                             |
|------------------------------|----|--------------|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SETC control bit             |    |              | $\checkmark$ | $\checkmark$ | Set Control Bit                                                                                                                                                                                                                                                                                                                         |
|                              |    |              |              |              | Set the specified control bit to a logic 1. Maskable interrupts are disabled immediately after the SETC instruction executes.                                                                                                                                                                                                           |
| SFL                          |    | $\checkmark$ | $\checkmark$ | $\checkmark$ | Shift Accumulator Left                                                                                                                                                                                                                                                                                                                  |
|                              |    |              |              |              | Shift the contents of the accumulator left one bit.                                                                                                                                                                                                                                                                                     |
| SFLB                         |    |              |              | $\checkmark$ | Shift ACCB and Accumulator Left                                                                                                                                                                                                                                                                                                         |
|                              |    |              |              |              | Shift the concatenation of the accumulator and the ACCB left one bit. The LSB of the ACCB is cleared to 0, and the MSB of the ACCB is shifted into the carry bit.                                                                                                                                                                       |
| SFR                          |    | $\checkmark$ | $\checkmark$ | $\checkmark$ | Shift Accumulator Right                                                                                                                                                                                                                                                                                                                 |
|                              |    |              |              |              | Shift the contents of the accumulator right one bit. If $SXM = 1$ , SFR produces an arithmetic right shift. If $SXM = 0$ , SFR produces a logic right shift.                                                                                                                                                                            |
| SFRB                         |    |              |              | $\checkmark$ | Shift ACCB and Accumulator Right                                                                                                                                                                                                                                                                                                        |
|                              |    |              |              |              | Shift the concatenation of the accumulator and the ACCB right 1 bit. The LSB of the ACCB is shifted into the carry bit. If $SXM = 1$ , SFRB produces an arithmetic right shift. If $SXM = 0$ , SFRB produces a logic right shift.                                                                                                       |
| SFSM                         |    | $\checkmark$ |              |              | Set Serial Port Frame Synchronization Mode                                                                                                                                                                                                                                                                                              |
|                              |    |              |              |              | Set the FSM status bit to 1.                                                                                                                                                                                                                                                                                                            |
| SHM                          |    | $\checkmark$ |              | $\checkmark$ | Set Hold Mode                                                                                                                                                                                                                                                                                                                           |
|                              |    |              |              |              | Set the HM status bit to 1.                                                                                                                                                                                                                                                                                                             |
| SMMR dma, #lk                |    |              |              | $\checkmark$ | Store Memory-Mapped Register                                                                                                                                                                                                                                                                                                            |
| SMMR {ind}, #lk [, next ARP] |    |              |              | V            | Store the memory-mapped register value, pointed at<br>by the seven LSBs of the data-memory address, into<br>the long immediate addressed data-memory location.<br>The nine MSBs of the data-memory address of the<br>memory-mapped register are cleared, regardless of<br>the current value of DP or the upper nine bits of<br>AR(ARP). |
| SOVM                         |    | $\checkmark$ | $\checkmark$ | $\checkmark$ | Set Overflow Mode                                                                                                                                                                                                                                                                                                                       |
|                              |    |              |              |              | Set the OVM status bit to 1; this enables overflow mode. (The ROVM instruction clears OVM.)                                                                                                                                                                                                                                             |

| Syntax                                         | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                         |
|------------------------------------------------|--------------|--------------|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPAC                                           | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Subtract P Register From Accumulator                                                                                                                                                                                                                                                                |
|                                                |              |              |              |              | Subtract the contents of the P register from the contents of the accumulator.                                                                                                                                                                                                                       |
|                                                |              |              |              |              | TMS320C2x, TMS320C2xx, and TMS320C5x de-<br>vices: Before the subtraction, shift the contents of the<br>P register as specified by the PM status bits.                                                                                                                                              |
| SPH dma                                        |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Store High P Register                                                                                                                                                                                                                                                                               |
| <b>SPH</b> { <i>ind</i> } [, <i>next</i> ARP]  |              | $\checkmark$ | V            | $\checkmark$ | Store the high-order bits of the P register (shifted as specified by the PM status bits) at the addressed data-<br>memory location.                                                                                                                                                                 |
| SPL dma                                        |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Store Low P Register                                                                                                                                                                                                                                                                                |
| <b>SPL</b> { <i>ind</i> } [, <i>next ARP</i> ] |              | $\checkmark$ | V            | $\checkmark$ | Store the low-order bits of the P register (shifted as specified by the PM status bits) at the addressed data-<br>memory location.                                                                                                                                                                  |
| SPLK #lk, dma                                  |              |              | $\checkmark$ |              | Store Parallel Long Immediate                                                                                                                                                                                                                                                                       |
| SPLK #lk, {ind} [, next ARP]                   |              |              |              | V            | Write a full 16-bit pattern into a memory location. The parallel logic unit (PLU) supports this bit manipulation independently of the ALU, so the accumulator is unaffected.                                                                                                                        |
| SPM 2-bit constant                             |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Set P Register Output Shift Mode                                                                                                                                                                                                                                                                    |
|                                                |              |              |              |              | Copy a 2-bit immediate value into the PM field of ST1.<br>This controls shifting of the P register as shown below:                                                                                                                                                                                  |
|                                                |              |              |              |              | PM = 00Multiplier output is not shifted.PM = 01Multiplier output is left shifted one place<br>and zero filled.                                                                                                                                                                                      |
|                                                |              |              |              |              | PM = 10Multiplier output is left shifted four places<br>and zero filled.PM = 11Multiplier output is right shifted six places                                                                                                                                                                        |
|                                                |              |              |              |              | and sign extended; the LSBs are lost.                                                                                                                                                                                                                                                               |
| SQRA dma                                       |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Square and Accumulate Previous Product                                                                                                                                                                                                                                                              |
| SQRA {ind} [, next ARP]                        |              | V            | V            | V            | Add the contents of the P register (shifted as specified<br>by the PM status bits) to the accumulator. Then load<br>the contents of the addressed data-memory location<br>into the T register (TMS320C2x/2xx) or TREG0<br>(TMS320C5x), square the value, and store the result<br>in the P register. |

| Syntax                                                | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                         |
|-------------------------------------------------------|--------------|--------------|--------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SQRS dma                                              |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Square and Subtract Previous Product                                                                                                                                                                                                                                                                                |
| SQRS {ind} [, next ARP]                               |              | $\checkmark$ | V            | $\checkmark$ | Subtract the contents of the P register (shifted as specified by the PM status bits) to the accumulator. Then load the contents of the addressed data-memory location into the T register (TMS320C2x/2xx) or TREG0 (TMS320C5x), square the value, and store the result in the P register.                           |
| SST dma                                               | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Store Status Register                                                                                                                                                                                                                                                                                               |
| SST {ind} [, next ARP]                                | V            | V            | V            | V            | Store the contents of the ST (TMS320C1x) or ST0 (TMS320C2x/2xx/5x) in the addressed data-memory location.                                                                                                                                                                                                           |
| SST #n, dma                                           |              |              | $\checkmark$ | $\checkmark$ | Store Status Register n                                                                                                                                                                                                                                                                                             |
| SST #n, {ind} [, next ARP]                            |              |              | $\checkmark$ | $\checkmark$ | Store ST <i>n</i> in data memory.                                                                                                                                                                                                                                                                                   |
| SST1 dma                                              |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Store Status Register ST1                                                                                                                                                                                                                                                                                           |
| SST1 {ind} [, next ARP]                               |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Store the contents of ST1 in the addressed data-<br>memory location.                                                                                                                                                                                                                                                |
| SSXM                                                  |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Set Sign-Extension Mode                                                                                                                                                                                                                                                                                             |
|                                                       |              |              |              |              | Set the SXM status bit to 1; this enables sign extension.                                                                                                                                                                                                                                                           |
| STC                                                   |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Set Test/Control Flag                                                                                                                                                                                                                                                                                               |
|                                                       |              |              |              |              | Set the TC flag to 1.                                                                                                                                                                                                                                                                                               |
| STXM                                                  |              | $\checkmark$ |              |              | Set Serial Port Transmit Mode                                                                                                                                                                                                                                                                                       |
|                                                       |              |              |              |              | Set the TXM status bit to 1.                                                                                                                                                                                                                                                                                        |
| SUB dma [, shift]                                     | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Subtract From Accumulator With Shift                                                                                                                                                                                                                                                                                |
| SUB {ind} [, shift [, next ARP]]                      | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | TMS320C1x and TMS320C2x devices: Subtract the                                                                                                                                                                                                                                                                       |
| SUB #k                                                |              |              | $\checkmark$ | $\checkmark$ | contents of the addressed data-memory location from<br>the accumulator. If a shift is specified, left shift the                                                                                                                                                                                                     |
| <b>SUB</b> # <i>lk</i> [, <i>shift</i> <sub>2</sub> ] |              |              | $\checkmark$ | V            | value before subtracting. During shifting, low-order bits are zero filled, and high-order bits are sign extended if $SXM = 1$ .                                                                                                                                                                                     |
|                                                       |              |              |              |              | TMS320C2xx and TMS320C5x devices: Subtract the contents of the addressed data-memory location or an 8- or 16-bit constant from the accumulator. If a shift is specified, left shift the data before subtracting. During shifting, low-order bits are zero filled, and high-order bits are sign extended if SXM = 1. |

| Syntax                           | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------|--------------|--------------|--------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SUBB dma                         |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Subtract From Accumulator With Borrow                                                                                                                                                                                                                                                                                                                 |
| SUBB {ind} [, next ARP]          |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Subtract the contents of the addressed data-memory location and the value of the carry bit from the accumulator. The carry bit is affected in the normal manner.                                                                                                                                                                                      |
| SUBC dma                         | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Conditional Subtract                                                                                                                                                                                                                                                                                                                                  |
| SUBC {ind} [, next ARP]          | $\checkmark$ | V            | V            | $\checkmark$ | Perform conditional subtraction. SUBC can be used for division.                                                                                                                                                                                                                                                                                       |
| SUBH dma                         | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Subtract From High Accumulator                                                                                                                                                                                                                                                                                                                        |
| SUBH {ind} [, next ARP]          | $\checkmark$ | V            |              | V            | Subtract the contents of the addressed data-memory location from the 16 MSBs of the accumulator. The 16 LSBs of the accumulator are not affected.                                                                                                                                                                                                     |
| SUBK #k                          |              | $\checkmark$ | $\checkmark$ | $\checkmark$ | Subtract From Accumulator Short Immediate                                                                                                                                                                                                                                                                                                             |
|                                  |              |              |              |              | Subtract an 8-bit immediate value from the accumula-<br>tor. The data is treated as an 8-bit positive number;<br>sign extension is suppressed.                                                                                                                                                                                                        |
| SUBS dma                         | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Subtract From Low Accumulator With Sign                                                                                                                                                                                                                                                                                                               |
| SUBS {ind} [, next ARP]          | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Extension Suppressed                                                                                                                                                                                                                                                                                                                                  |
|                                  |              |              |              |              | Subtract the contents of the addressed data-memory location from the accumulator. The data is treated as a 16-bit unsigned number; sign extension is suppressed.                                                                                                                                                                                      |
| SUBT dma SUBT {ind} [, next ARP] |              |              | V<br>V       | √<br>√       | Subtract From Accumulator With Shift Specified by T Register                                                                                                                                                                                                                                                                                          |
|                                  |              |              |              |              | Left shift the data-memory value as specified by the four LSBs of the T register (TMS320C2x/2xx) or TREG1 (TMS320C5x), and subtract the result from the accumulator. If a shift is specified, left shift the data-memory value before subtracting. During shifting, low-order bits are zero filled, and high-order bits are sign extended if SXM = 1. |
| SXF                              |              | $\checkmark$ |              | $\checkmark$ | Set External Flag                                                                                                                                                                                                                                                                                                                                     |
|                                  |              |              |              |              | Set the XF pin and the XF status bit to 1.                                                                                                                                                                                                                                                                                                            |
| TBLR dma                         | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Table Read                                                                                                                                                                                                                                                                                                                                            |
| TBLR {ind} [, next ARP]          | V            | $\checkmark$ | $\checkmark$ | V            | Transfer a word from program memory to a data-<br>memory location. The program-memory address is in<br>the 12 (TMS320C1x) or 16 (TMS320C2x/2xx/5x)<br>LSBs of the accumulator.                                                                                                                                                                        |

| Syntax                                                            | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------------------------------------------------|--------------|--------------|--------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TBLW dma                                                          | $\checkmark$ |              | $\checkmark$ |              | Table Write                                                                                                                                                                                                                                                                                                                                                                                                         |
| TBLW {ind} [, next ARP]                                           | V            | V            | $\checkmark$ | V            | Transfer a word from data-memory to a program-<br>memory location. The program-memory address is in<br>the 12 (TMS320C1x) or 16 (TMS320C2x/2xx/5x)<br>LSBs of the accumulator.                                                                                                                                                                                                                                      |
| TRAP                                                              |              |              | $\checkmark$ | $\checkmark$ | Software Interrupt                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                   |              |              |              |              | The TRAP instruction is a software interrupt that trans-<br>fers program control to program-memory address 30h<br>(TMS320C2x) or 22h (TMS320C2xx/5x) and pushes<br>the PC + 1 onto the hardware stack. The instruction at<br>address 30h or 22h may contain a branch instruction<br>to transfer control to the TRAP routine. Putting the<br>PC + 1 on the stack enables an RET instruction to pop<br>the return PC. |
| <b>XC</b> <i>n</i> , cond <sub>1</sub> [, cond <sub>2</sub> ] [,] |              |              |              | $\checkmark$ | Execute Conditionally                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                   |              |              |              |              | Execute conditionally the next $n$ instruction words where $1 \le n \le 2$ . Not all combinations of conditions are meaningful.                                                                                                                                                                                                                                                                                     |
| XOR dma                                                           | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Exclusive-OR With Accumulator                                                                                                                                                                                                                                                                                                                                                                                       |
| XOR {ind} [, next ARP]<br>XOR #lk [, shift]                       | $\checkmark$ | V            |              |              | TMS320C1x and TMS320C2x devices: Exclusive-OR the contents of the addressed data-memory location with 16 LSBs of the accumulator. The MSBs are not affected.                                                                                                                                                                                                                                                        |
|                                                                   |              |              |              |              | TMS320C2xx and TMS320C5x devices: Exclusive-<br>OR the contents of the addressed data-memory loca-<br>tion or a 16-bit immediate value with the accumulator.<br>If a shift is specified, left shift the value before perform-<br>ing the exclusive-OR operation. Low-order bits below<br>and high-order bits above the shifted value are treated<br>as 0s.                                                          |
| XORB                                                              |              |              |              | $\checkmark$ | Exclusive-OR of ACCB With Accumulator                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                   |              |              |              |              | Exclusive-OR the contents of the accumulator with the contents of the ACCB. The results are placed in the accumulator.                                                                                                                                                                                                                                                                                              |
| <b>XORK #</b> <i>lk</i> [, shiff]                                 |              | V            | V            | V            | Exclusive-OR Immediate With Accumulator With Shift                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                   |              |              |              |              | Exclusive-OR a 16-bit immediate value with the accu-<br>mulator. If a shift is specified, left shift the value before<br>performing the exclusive-OR operation. Low-order<br>bits below and high-order bits above the shifted value<br>are treated as 0s.                                                                                                                                                           |

| Syntax                                                        | 1x           | 2x           | 2xx          | 5x           | Description                                                                                                                                                                                                                                                            |
|---------------------------------------------------------------|--------------|--------------|--------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>XPL</b> [#/k,] dma<br><b>XPL</b> [#/k,] {ind} [, next ARP] |              |              |              | √<br>√       | Exclusive-OR of Long Immediate or DBMR<br>With Addressed Data-Memory Value                                                                                                                                                                                             |
|                                                               |              |              |              |              | If a long immediate value is specified, exclusive OR it<br>with the addressed data-memory value; otherwise,<br>exclusive OR the DBMR with the addressed data-<br>memory value. Write the result back to the data-<br>memory location. The accumulator is not affected. |
| ZAC                                                           | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | Zero Accumulator                                                                                                                                                                                                                                                       |
|                                                               |              |              |              |              | Clear the contents of the accumulator to 0.                                                                                                                                                                                                                            |
| ZALH dma ZALH {ind} [, next ARP]                              |              |              | √<br>√       | √<br>√       | Zero Low Accumulator and Load High<br>Accumulator                                                                                                                                                                                                                      |
|                                                               |              | v            | v            | v            | Clear the 16 LSBs of the accumulator to 0 and load the contents of the addressed data-memory location into the 16 MSBs of the accumulator.                                                                                                                             |
| ZALR dma                                                      |              |              | √<br>√       | √<br>√       | Zero Low Accumulator, Load High Accumulator<br>With Rounding                                                                                                                                                                                                           |
| <b>ZALR</b> { <i>ind</i> } [, <i>next ARP</i> ]               |              | V            | v            | v            | Load the contents of the addressed data-memory location into the 16 MSBs of the accumulator. The value is rounded by $1/2$ LSB; that is, the 15 LSBs of the accumulator (0–14) are cleared and bit 15 is set to 1.                                                     |
| ZALS dma                                                      | √<br>√       | √<br>√       | √<br>√       | √<br>√       | Zero Accumulator, Load Low Accumulator With Sign Extension Suppressed                                                                                                                                                                                                  |
| <b>ZALS</b> { <i>ind</i> } [, <i>next ARP</i> ]               | v            | v            | v            | v            | Load the contents of the addressed data-memory location into the 16 LSBs of the accumulator. The 16 MSBs are zeroed. The data is treated as a 16-bit unsigned number.                                                                                                  |
| ZAP                                                           |              |              |              |              | Zero the Accumulator and Product Register                                                                                                                                                                                                                              |
|                                                               |              |              |              |              | The accumulator and product register are zeroed. The ZAP instruction speeds up the preparation for a repeat multiply/accumulate.                                                                                                                                       |
| ZPR                                                           |              |              |              | $\checkmark$ | Zero the Product Register                                                                                                                                                                                                                                              |
|                                                               |              |              |              |              | The product register is cleared.                                                                                                                                                                                                                                       |

Table A–3. Instruction Set Comparison (Continued)

# Appendix B

# Submitting ROM Codes to TI

The size of a printed circuit board is a consideration in many DSP applications. To make full use of the board space, Texas Instruments offers a ROM code option that reduces the chip count and provides a single-chip solution. This option allows you to use a code-customized processor for a specific application while taking advantage of:

- Greater memory expansion
- Lower system cost
- Less hardware and wiring
- Smaller PCB

If a routine or algorithm is used often, it can be programmed into the on-chip ROM of a TMS320 DSP. TMS320 programs can also be expanded by using external memory; this reduces chip count and allows for a more flexible program memory. Multiple functions are easily implemented by a single device, thus enhancing system capabilities.

TMS320 development tools are used to develop, test, refine, and finalize the algorithms. The microprocessor/microcomputer (MP/MC) mode is available on all ROM-coded TMS320 DSP devices when accesses to either on-chip or off-chip memory are required. The microprocessor mode is used to develop, test, and refine a system application. In this mode of operation, the TMS320 acts as a standard microprocessor by using external program memory. When the algorithm has been finalized, the code can be submitted to Texas Instruments for masking into the on-chip program ROM. At that time, the TMS320 becomes a microcomputer that executes customized programs from the on-chip ROM. Should the code need changing or upgrading, the TMS320 can once again be used in the microprocessor mode. This shortens the field-upgrade time and prevents the possibility of inventory obsolescence.

Figure B–1 illustrates the procedural flow for developing and ordering TMS320 masked parts. When ordering, there is a one-time, nonrefundable charge for mask tooling. A minimum production order per year is required for any masked-ROM device. ROM codes will be deleted from the TI system one year after the final delivery.



Figure B-1. TMS320 ROM Code Procedural Flow Chart

The TMS320 ROM code may be submitted in one of the following forms:

- □ 3-1/2-in floppy: COFF format from macro-assembler/linker (preferred)
- Modem (BBS): COFF format from macro-assembler/linker
- EPROM (others): TMS27C64
- PROM: TBP28S166, TBP28S86

When code is submitted to TI for masking, the code is reformatted to accommodate the TI mask-generation system. System-level verification by the customer is, therefore, necessary to ensure the reformatting remains transparent and does not affect the execution of the algorithm. The formatting changes involve the removal of address-relocation information (the code address begins at the base address of the ROM in the TMS320 device and progresses without gaps to the last address of the ROM) and the addition of data in the reserved locations of the ROM for device ROM test. Because these changes have been made, a checksum comparison is not a valid means of verification.

With each masked-device order, the customer must sign a disclaimer that states:

The units to be shipped against this order were assembled, for expediency purposes, on a prototype (that is, nonproduction qualified) manufacturing line, the reliability of which is not fully characterized. Therefore, the anticipated inherent reliability of these prototype units cannot be expressly defined.

and a release that states:

Any masked ROM device may be resymbolized as TI standard product and resold as though it were an unprogrammed version of the device, at the convenience of Texas Instruments.

The use of the ROM-protect feature does not hold for this release statement. Additional risk and charges are involved when the ROM-protect feature is selected. Contact the nearest TI Field Sales Office for more information on procedures, leadtimes, and cost associated with the ROM-protect feature.

# Appendix C

# Design Considerations for Using the XDS510 Emulator

This appendix assists you in meeting the design requirements of the Texas Instruments XDS510<sup>TM</sup> emulator for IEEE-1149.1 designs and discusses the XDS510 cable (manufacturing part number 2617698-0001). This cable is identified by a label on the cable pod marked *JTAG 3/5V* and supports both standard 3-V and 5-V target system power inputs.

The term *JTAG*, as used in this book, refers to TI scan-based emulation, which is based on the IEEE 1149.1 standard.

For more information concerning the IEEE 1149.1 standard, contact IEEE Customer Service:

| Address: | IEEE Customer Service                                                           |          |        |  |  |  |
|----------|---------------------------------------------------------------------------------|----------|--------|--|--|--|
|          | 445 Hoes Lane, PO Box 1331                                                      |          |        |  |  |  |
|          | Piscataway, NJ 08                                                               | 855-1331 |        |  |  |  |
| Phone:   | (800) 678–IEEE in the US and Canada<br>(908) 981–1393 outside the US and Canada |          |        |  |  |  |
| FAX:     | (908) 981–9667                                                                  | Telex:   | 833233 |  |  |  |

#### Topic

#### Page

| C.1 | Designing Your Target System's Emulator Connector<br>(14-Pin Header)C-2 |
|-----|-------------------------------------------------------------------------|
| C.2 | Bus ProtocolC-4                                                         |
| C.3 | Emulator Cable PodC-5                                                   |
| C.4 | Emulator Cable Pod Signal TimingC-6                                     |
| C.5 | Emulation Timing CalculationsC-7                                        |
| C.6 | Connections Between the Emulator and the Target System C-10             |
| C.7 | Physical Dimensions for the 14-Pin Emulator ConnectorC-14               |
| C.8 | Emulation Design ConsiderationsC-16                                     |

#### C.1 Designing Your Target System's Emulator Connector (14-Pin Header)

JTAG target devices support emulation through a dedicated emulation port. This port is accessed directly by the emulator and provides emulation functions that are a superset of those specified by IEEE 1149.1. To communicate with the emulator, *your target system must have a 14-pin header* (two rows of seven pins) with the connections that are shown in Figure C–1. Table C–1 describes the emulation signals.

Although you can use other headers, the recommended unshrouded, straight header has these DuPont connector systems part numbers:

- 65610–114
   65611–114
   67996–114
- 67997-114

Figure C–1. 14-Pin Header Signals and Header Dimensions

| TMS                     | 1  | 2  | TRST          |
|-------------------------|----|----|---------------|
| TDI                     | 3  | 4  | GND           |
| $PD\left(V_{CC}\right)$ | 5  | 6  | no pin (key)† |
| TDO                     | 7  | 8  | GND           |
| TCK_RET                 | 9  | 10 | GND           |
| TCK                     | 11 | 12 | GND           |
| EMU0                    | 13 | 14 | EMU1          |

Header Dimensions: Pin-to-pin spacing, 0.100 in. (X,Y) Pin width, 0.025-in. square post Pin length, 0.235-in. nominal

<sup>†</sup> While the corresponding female position on the cable connector is plugged to prevent improper connection, the cable lead for pin 6 is present in the cable and is grounded, as shown in the schematics and wiring diagrams in this appendix.

| Signal               | Description                                                                                                                                           | Emulator <sup>†</sup><br>State | Target <sup>†</sup><br>State |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------------------------|
| EMU0                 | Emulation pin 0                                                                                                                                       | I                              | I/O                          |
| EMU1                 | Emulation pin 1                                                                                                                                       | I                              | I/O                          |
| GND                  | Ground                                                                                                                                                |                                |                              |
| PD(V <sub>CC</sub> ) | Presence detect. Indicates that the emulation cable is connected and that the target is powered up. PD must be tied to $V_{CC}$ in the target system. | I                              | Ο                            |
| тск                  | Test clock. TCK is a 10.368-MHz clock<br>source from the emulation cable pod. This<br>signal can be used to drive the system test<br>clock.           | 0                              | Ι                            |
| TCK_RET              | Test clock return. Test clock input to the emu-<br>lator. May be a buffered or unbuffered version of TCK.                                             | I                              | 0                            |
| TDI                  | Test data input                                                                                                                                       | 0                              | I                            |
| TDO                  | Test data output                                                                                                                                      | I                              | 0                            |
| TMS                  | Test mode select                                                                                                                                      | 0                              | I                            |
| TRST‡                | Test reset                                                                                                                                            | 0                              | I                            |

|  | Table C–1. | 14-Pin | Header | Signal | Descri | otions |
|--|------------|--------|--------|--------|--------|--------|
|--|------------|--------|--------|--------|--------|--------|

 $^{\dagger}$ I = input; O = output

<sup>‡</sup> Do not use <u>pullup</u> resistors on TRST: it has an internal pulldown device. In a low-noise environment, TRST can be left floating. In a high-noise environment, an additional pulldown resistor may be needed. (The size of this resistor should be based on electrical current considerations.)

#### C.2 Bus Protocol

The IEEE 1149.1 specification covers the requirements for the test access port (TAP) bus slave devices and provides certain rules, summarized as follows:

- The TMS and TDI inputs are sampled on the rising edge of the TCK signal of the device.
- The TDO output is clocked from the falling edge of the TCK signal of the device.

When these devices are daisy-chained together, the TDO of one device has approximately a half TCK cycle setup time before the next device's TDI signal. This timing scheme minimizes race conditions that would occur if both TDO and TDI were timed from the same TCK edge. The penalty for this timing scheme is a reduced TCK frequency.

The IEEE 1149.1 specification does not provide rules for bus master (emulator) devices. Instead, it states that the device expects a bus master to provide bus slave compatible timings. The XDS510 provides timings that meet the bus slave rules.

#### C.3 Emulator Cable Pod

Figure C–2 shows a portion of the emulator cable pod. The functional features of the pod are:

- □ TDO and TCK\_RET can be parallel-terminated inside the pod if required by the application. By default, these signals are not terminated.
- TCK is driven with a 74LVT240 device. Because of the high-current drive (32-mA I<sub>OL</sub>/I<sub>OH</sub>), this signal can be parallel-terminated. If TCK is tied to TCK\_RET, you can use the parallel terminator in the pod.
- TMS and TDI can be generated from the falling edge of TCK\_RET, according to the IEEE 1149.1 bus slave device timing rules.
- TMS and TDI are series terminated to reduce signal reflections.
- A 10.368-MHz test clock source is provided. You can also provide your own test clock for greater flexibility.





<sup>†</sup> The emulator pod uses TCK\_RET as its clock source for internal synchronization. TCK is provided as an optional target system test clock source.

#### PRELIMINARY

Design Considerations for Using the XDS510 Emulator C-5

#### C.4 Emulator Cable Pod Signal Timing

Figure C–3 shows the signal timings for the emulator cable pod. Table C–2 defines the timing parameters illustrated in the figure. These timing parameters are calculated from values specified in the standard data sheets for the emulator and cable pod and are for reference only. Texas Instruments does not test or guarantee these timings.

The emulator pod uses TCK\_RET as its clock source for internal synchronization. TCK is provided as an optional target system test clock source.

Figure C-3. Emulator Cable Pod Timings



Table C-2. Emulator Cable Pod Timing Parameters

| No. | Parameter            | Description                                  | Min | Max | Unit |
|-----|----------------------|----------------------------------------------|-----|-----|------|
| 1   | t <sub>c(TCK)</sub>  | Cycle time, TCK_RET                          | 35  | 200 | ns   |
| 2   | <sup>t</sup> w(TCKH) | Pulse duration, TCK_RET high                 | 15  |     | ns   |
| 3   | <sup>t</sup> w(TCKL) | Pulse duration, TCK_RET low                  | 15  |     | ns   |
| 4   | <sup>t</sup> d(TMS)  | Delay time, TMS or TDI valid for TCK_RET low | 6   | 20  | ns   |
| 5   | t <sub>su(TDO)</sub> | Setup time, TDO to TCK_RET high              | 3   |     | ns   |
| 6   | t <sub>h(TDO)</sub>  | Hold time, TDO from TCK_RET high             | 12  |     | ns   |

#### C.5 Emulation Timing Calculations

The examples in this section help you calculate emulation timings in your system. For actual target timing parameters, see the appropriate data sheet for the device you are emulating.

The examples use the following assumptions:

| t <sub>su(TTMS)</sub>             | Setup time, target TMS or TDI to TCK high                                                                          | 10 ns        |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------|--------------|
| td(TTDO)                          | Delay time, target TDO from TCK low                                                                                | 15 ns        |
| t <sub>d(bufmax)</sub>            | Delay time, target buffer maximum                                                                                  | 10 ns        |
| t <sub>d(bufmin)</sub>            | Delay time, target buffer minimum                                                                                  | 1 ns         |
| <sup>t</sup> bufskew <sup>′</sup> | Skew time, target buffer between two devices in the same package:<br>$[t_{d(bufmax)} - t_{d(bufmin)}] \times 0.15$ | 1.35 ns      |
| <sup>t</sup> TCKfactor            | Duty cycle, assume a 40/60% duty cycle clock                                                                       | 0.4<br>(40%) |
|                                   |                                                                                                                    |              |

Also, the examples use the following values from Table C–2 on page C-6:

| t <sub>d(TMSmax)</sub>  | Delay time, emulator TMS or TDI from<br>TCK_RET low, maximum | 20 ns |
|-------------------------|--------------------------------------------------------------|-------|
| t <sub>su(TDOmin)</sub> | Setup time, TDO to emulator TCK_RET high, minimum            | 3 ns  |

There are two key timing paths to consider in the emulation design:

- TheTCK\_RET-to-TMSorTDIpath,calledtpd(TCK\_RET-TMS/TDI)(propagation delay time)
- □ The TCK\_RET-to-TDO path, called tpd(TCK\_RET-TDO)

In the examples, the worst-case path delay is calculated to determine the maximum system test clock frequency.

#### Example C–1. Key Timing for a Single-Processor System Without Buffers

The following example calculates key timing for a single-processor system without buffers.

$$t_{pd(TCK\_RET-TMS/TDI)} = \frac{\left[ \frac{t_{d(TMSmax)} + t_{su(TTMS)} \right]}{t_{TCKfactor}}$$
$$= \frac{(20 \text{ ns} + 10 \text{ ns})}{0.4}$$
$$= 75 \text{ ns, or } 13.3 \text{ MHz}$$
$$t_{pd(TCK\_RET-TDO)} = \frac{\left[ \frac{t_{d}(TTDO) + t_{su}(TDOmin)}{t_{TCKfactor}} \right]}{t_{TCKfactor}}$$
$$= \frac{(15 \text{ ns} + 3 \text{ ns})}{0.4}$$
$$= 45 \text{ ns, or } 22.2 \text{ MHz}$$

In the preceding example, the TCK\_RET-to-TMS/TDI path is the limiting factor because it requires more time to complete.

☐ The following example calculates key timing for a single- or multiple-processor system with buffered input and output:

$$t_{pd (TCK\_RET-TMS/TDI)} = \frac{\left[ \frac{t_{d (TMSmax)} + t_{su (TTMS)} + t_{bufskew} \right]}{t_{TCKfactor}}$$
$$= \frac{(20 \text{ ns} + 10 \text{ ns} + 1.35 \text{ ns})}{0.4}$$
$$= 78.4 \text{ ns, or } 12.7 \text{ MHz}$$
$$t_{pd (TCK\_RET-TDO)} = \frac{\left[ \frac{t_{d (TTDO)} + t_{su (TDOmin)} + t_{d (bufmax)} \right]}{t_{TCKfactor}}$$
$$= \frac{(15 \text{ ns} + 3 \text{ ns} + 10 \text{ ns})}{0.4}$$
$$= 70 \text{ ns, or } 14.3 \text{ MHz}$$

In the preceding example, the TCK\_RET-to-TMS/TDI path is the limiting factor becaise it requires more time to complete.

In a multiprocessor application, it is necessary to ensure that the EMU0 and EMU1 lines can go from a logic-low level to a logic-high level in less than 10  $\mu$ s, this parameter is called rise time, t<sub>r</sub>. This can be calculated as follows:

$$t_r = 5(R_{pullup} \times N_{devices} \times C_{load\_per\_device})$$
  
= 5(4.7 k\Omega × 16 × 15 pF)

= 
$$5(4.7 \times 10^3 \Omega \times 16 \times 15 = \text{no} - 12 \text{ F})$$

$$= 5(1128 \times 10^{-9})$$

= 5.64 μs

#### C.6 Connections Between the Emulator and the Target System

It is extremely important to provide high-quality signals between the emulator and the JTAG target system. You must supply the correct signal buffering, test clock inputs, and multiple processor interconnections to ensure proper emulator and target system operation.

Signals applied to the EMU0 and EMU1 pins on the JTAG target device can be either input or output. In general, these two pins are used as both input and output in multiprocessor systems to handle global run/stop operations. EMU0 and EMU1 signals are applied only as inputs to the XDS510 emulator header.

#### C.6.1 Buffering Signals

If the distance between the emulation header and the JTAG target device is greater than 6 inches, the emulation signals must be buffered. If the distance is less than 6 inches, no buffering is necessary. Figure C–4 shows the simpler, no-buffering situation.

The distance between the header and the JTAG target device must be no more than 6 inches. The EMU0 and EMU1 signals must have pullup resistors connected to  $V_{CC}$  to provide a signal rise time of less than 10 µs. A 4.7-k $\Omega$  resistor is suggested for most applications.

#### Figure C–4. Emulator Connections Without Signal Buffering



Figure C–5 shows the connections necessary for buffered transmission signals. The distance between the emulation header and the processor is greater than 6 inches. Emulation signals TMS, TDI, TDO, and TCK\_RET are buffered through the same device package.



#### Figure C–5. Emulator Connections With Signal Buffering

The EMU0 and EMU1 signals must have pullup resistors connected to V<sub>CC</sub> to provide a signal rise time of less than 10  $\mu$ s. A 4.7-k $\Omega$  resistor is suggested for most applications.

The input buffers for TMS and TDI should have pullup resistors connected to  $V_{CC}$  to hold these signals at a known value when the emulator is not connected. A resistor value of 4.7 k $\Omega$  or greater is suggested.

To have high-quality signals (especially the processor TCK and the emulator TCK\_RET signals), you may have to employ special care when routing the printed wiring board trace. You also may have to use termination resistors to match the trace impedance. The emulator pod provides optional internal parallel terminators on the TCK\_RET and TDO. TMS and TDI provide fixed series termination.

Because TRST is an asynchronous signal, it should be buffered as needed to ensure sufficient current to all target devices.

#### C.6.2 Using a Target-System Clock

Figure C–6 shows an application with the system test clock generated in the target system. In this application, the emulator's TCK signal is left unconnected.





**Note:** When the TMS and TDI lines are buffered, pullup resistors must be used to hold the buffer inputs at a known level when the emulator cable is not connected.

There are two benefits in generating the test clock in the target system:

- The emulator provides only a single 10.368-MHz test clock. If you allow the target system to generate your test clock, you can set the frequency to match your system requirements.
- In some cases, you may have other devices in your system that require a test clock when the emulator is not connected. The system test clock also serves this purpose.

#### C.6.3 Configuring Multiple Processors

Figure C–7 shows a typical daisy-chained multiprocessor configuration that meets the minimum requirements of the IEEE 1149.1 specification. The emulation signals are buffered to isolate the processors from the emulator and provide adequate signal drive for the target system. One of the benefits of this interface is that you can slow down the test clock to eliminate timing problems. Follow these guidelines for multiprocessor support:

- □ The processor TMS, TDI, TDO, and TCK signals must be buffered through the same physical device package for better control of timing skew.
- □ The input buffers for TMS, TDI, and TCK must have pullup resistors connected to  $V_{CC}$  to hold these signals at a known value when the emulator is not connected. A resistor value of 4.7 k $\Omega$  or greater is suggested.
- Buffering EMU0 and EMU1 is optional but highly recommended to provide isolation. These are not critical signals and do not have to be buffered through the same physical package as TMS, TCK, TDI, and TDO.

Figure C–7. Multiprocessor Connections



#### C.7 Physical Dimensions for the 14-Pin Emulator Connector

The JTAG emulator target cable consists of a 3-foot section of jacketed cable that connects to the emulator, an active cable pod, and a short section of jacketed cable that connects to the target system. The overall cable length is approximately 3 feet 10 inches. Figure C–8 and Figure C–9 show the physical dimensions for the target cable pod and short cable. The cable pod box is non-conductive plastic with four recessed metal screws.

Figure C–8. Pod/Connector Dimensions



**Note:** All dimensions are in inches and are nominal dimensions, unless otherwise specified. Pin-to-pin spacing on the connector is 0.100 inches in both the X and Y planes.



Figure C–9. 14-Pin Connector Dimensions

**Note:** All dimensions are in inches and are nominal dimensions, unless otherwise specified. Pin-to-pin spacing on the connector is 0.100 inches in both the X and Y planes.

#### C.8 Emulation Design Considerations

This section describes the use and application of the scan path linker (SPL), which can simultaneously add all four secondary JTAG scan paths to the main scan path. It also describes the use of the emulation pins and the configuration of multiple processors.

#### C.8.1 Using Scan Path Linkers

You can use the TI ACT8997 scan path linker (SPL) to divide the JTAG emulation scan path into smaller, logically connected groups of 4 to 16 devices. As described in the *Advanced Logic and Bus Interface Logic Data Book*, the SPL is compatible with the JTAG emulation scanning. The SPL is capable of adding any combination of its four secondary scan paths into the main scan path.

A system of multiple, secondary JTAG scan paths has better fault tolerance and isolation than a single scan path. Since an SPL has the capability of adding all secondary scan paths to the main scan path simultaneously, it can support global emulation operations, such as starting or stopping a selected group of processors.

TI emulators do not support the nesting of SPLs (for example, an SPL connected to the secondary scan path of another SPL). However, you can have multiple SPLs on the main scan path.

Scan path selectors are not supported by this emulation system. The TI ACT8999 scan path selector is similar to the SPL, but it can add only one of its secondary scan paths at a time to the main JTAG scan path. Thus, global emulation operations are not assured with the scan path selector.

You can insert an SPL on a backplane so that you can add up to four device boards to the system without the jumper wiring required with nonbackplane devices. You connect an SPL to the main JTAG scan path in the same way you connect any other device. Figure C–10 shows how to connect a secondary scan path to an SPL.



Figure C–10. Connecting a Secondary JTAG Scan Path to a Scan Path Linker

The TRST signal from the main scan path drives all devices, even those on the secondary scan paths of the SPL. The TCK signal on each target device on the secondary scan path of an SPL is driven by the SPL's DTCK signal. The TMS signal on each device on the secondary scan path is driven by the respective DTMS signals on the SPL.

DTDO0 on the SPL is connected to the TDI signal of the first device on the secondary scan path. DTDI0 on the SPL is connected to the TDO signal of the last device in the secondary scan path. Within each secondary scan path, the TDI signal of a device is connected to the TDO signal of the device before it. If the SPL is on a backplane, its secondary JTAG scan paths are on add-on boards; if signal degradation is a problem, you may need to buffer both the TRST and DTCK signals. Although degradation is less likely for DTMS*n* signals, you may also need to buffer them for the same reasons.

#### C.8.2 Emulation Timing Calculations for a Scan Path Linker (SPL)

The examples in this section help you to calculate the key emulation timings in the SPL secondary scan path of your system. For actual target timing parameters, see the appropriate device data sheet for your target device.

The examples use the following assumptions:

| t <sub>su(TTMS)</sub>  | Setup time, target TMS/TDI to TCK high                                                                           | 10 ns        |
|------------------------|------------------------------------------------------------------------------------------------------------------|--------------|
| td(TTDO)               | Delay time, target TDO from TCK low                                                                              | 15 ns        |
| t <sub>d(bufmax)</sub> | Delay time, target buffer, maximum                                                                               | 10 ns        |
| td(bufmin)             | Delay time, target buffer, minimum                                                                               | 1 ns         |
| <sup>t</sup> (bufskew) | Skew time, target buffer, between two devices in the same package: $[t_{d(bufmax)} - t_{d(bufmin)}] \times 0.15$ | 1.35 ns      |
| t(TCKfactor)           | Duty cycle, TCK assume a 40/60% clock                                                                            | 0.4<br>(40%) |

Also, the examples use the following values from the SPL data sheet:

| t <sub>d(DTMSmax)</sub>  | Delay time, SPL DTMS/DTDO from TCK low, maximum | 31 ns |
|--------------------------|-------------------------------------------------|-------|
| t <sub>su(DTDLmin)</sub> | Setup time, DTDI to SPL TCK high, minimum       | 7 ns  |
| <sup>t</sup> d(DTCKHmin) | Delay time, SPL DTCK from TCK high, minimum     | 2 ns  |
| t <sub>d(DTCKLmax)</sub> | Delay time, SPL DTCK from TCK low, maximum      | 16 ns |

There are two key timing paths to consider in the emulation design:

□ The TCK-to-DTMS/DTDO path, called t<sub>pd(TCK-DTMS)</sub>

The TCK-to-DTDI path, called tpd(TCK-DTDI)

In the following two examples, the worst-case path delay is calculated to determine the maximum system test clock frequency.

Example C–2. Key Timing for a Single-Processor System Without Buffering (SPL)

-

☐ The following example calculates key timing for a single-processor system without buffering (SPL):

$$t_{pd(TCK-DTMS)} = \frac{\left[ t_{d(DTMSmax)} + t_{d(DTCKHmin)} + t_{su(TTMS)} \right]}{t_{TCKfactor}}$$
$$= \frac{(31 \text{ ns} + 2 \text{ ns} + 10 \text{ ns})}{0.4}$$
$$= 107.5 \text{ ns, or } 9.3 \text{ MHz}$$
$$t_{pd(TCK-DTDI)} = \frac{\left[ t_{d(TTDO)} + t_{d(DTCKLmax)} + t_{su(DTDLmin)} \right]}{t_{TCKfactor}}$$
$$= \frac{(15 \text{ ns} + 16 \text{ ns} + 7 \text{ ns})}{0.4}$$
$$= 9.5 \text{ ns. or } 10.5 \text{ MHz}$$

In the preceding example, the TCK-to-DTMS/DTDL path is the limiting factor.

The following example calculates key timing for a single- or multiprocessorsystem with buffered input and output (SPL):

$$t_{pd(TCK-TDMS)} = \frac{\left[t_{d(DTMSmax)} + t_{(DTCKHmin)} + t_{su(TTMS)} + t_{(bufskew)}\right]}{t_{TCKfactor}}$$
  
=  $\frac{(31 \text{ ns} + 2 \text{ ns} + 10 \text{ ns} + 1.35 \text{ ns})}{0.4}$   
= 110.9 ns, or 9.0 MHz  
$$t_{pd(TCK-DTDI)} = \frac{\left[t_{d(TTDO)} + t_{d(DTCKLmax)} + t_{su(DTDLmin)} + t_{d(bufskew)}\right]}{t_{TCKfactor}}$$
  
=  $\frac{(15 \text{ ns} + 15 \text{ ns} + 7 \text{ ns} + 10 \text{ ns})}{0.4}$   
= 120 ns, or 8.3 MHz

In the preceding example, the TCK-to-DTDI path is the limiting factor.

PRELIMINARY

Design Considerations for Using the XDS510 Emulator C-19

#### C.8.3 Using Emulation Pins

The EMU0/1 pins of TI devices are bidirectional, 3-state output pins. When in an inactive state, these pins are at high impedance. When the pins are active, they provide one of two types of output:

- Signal event. The EMU0/1 pins can be configured via software to signal internal events. In this mode, driving one of these pins low can cause devices to signal such events. To enable this operation, the EMU0/1 pins function as open-collector sources. External devices such as logic analyzers can also be connected to the EMU0/1 signals in this manner. If such an external source is used, it must also be connected via an open-collector source.
- External count. The EMU0/1 pins can be configured via software as totempole outputs for driving an external counter. If the output of more than one device is configured for totem-pole operation, then these devices can be damaged. The emulation software detects and prevents this condition. However, the emulation software has no control over external sources on the EMU0/1 signal. Therefore, all external sources must be inactive when any device is in the external count mode.

TI devices can be configured by software to halt processing if their EMU0/1 pins are driven low. This feature combined with the signal event output, allows one TI device to halt all other TI devices on a given event for system-level debugging.

If you route the EMU0/1 signals between multiple boards, they require special handling because they are more complex than normal emulation signals. Figure C–11 shows an example configuration that allows any processor in the system to stop any other processor in the system. Do not tie the EMU0/1 pins of more than 16 processors together in a single group without using buffers. Buffers provide the crisp signals that are required during a RUNB (run benchmark) debugger command or when the external analysis counter feature is used.



#### Figure C–11. EMU0/1 Configuration to Meet Timing Requirements of Less Than 25 ns

- Notes: 1) The low time on EMU0/1-IN must be at least one TCK cycle and less than 10 μs. Software sets the EMU0/1-OUT pin to a high state.
  - 2) To enable the open-collector driver and pullup resistor on EMU1 to provide rise/fall times of less than 25 ns, the modification shown in this figure is suggested. Rise times of more than 25 ns can cause the emulator to detect false edges during the RUNB command or when the external counter selected from the debugger analysis menu is used.

These seven important points apply to the circuitry shown in Figure C–11 and the timing shown in Figure C–12:

- Open-collector drivers isolate each board. The EMU0/1 pins are tied together on each board.
- ☐ At the board edge, the EMU0/1 signals are split to provide both input and output connections. This is required to prevent the open-collector drivers from acting as latches that can be set only once.
- ☐ The EMU0/1 signals are bused down the backplane. Pullup resistors must be installed as required.

Design Considerations for Using the XDS510 Emulator C-21

- The bused EMU0/1 signals go into a programmable logic array device PAL<sup>®</sup>, whose function is to generate a low pulse on the EMU0/1-IN signal when a low level is detected on the EMU0/1-OUT signal. This pulse must be longer than one TCK period to affect the devices but less than 10 μs to avoid possible conflicts or retriggering once the emulation software clears the device's pins.
- During a RUNB debugger command or other external analysis count, the EMU0/1 pins on the target device become totem-pole outputs. The EMU1 pin is a ripple carry-out of the internal counter. EMU0 becomes a processor-halted signal. During a RUNB or other external analysis count, the EMU0/1-IN signal to all boards must remain in the high (disabled) state. You must provide some type of external input (XCNT\_ENABLE) to the PAL<sup>®</sup> to disable the PAL<sup>®</sup> from driving EMU0/1-IN to a low state.
- If you use sources other than TI processors (such as logic analyzers) to drive EMU0/1, their signal lines must be isolated by open-collector drivers and be inactive during RUNB and other external analysis counts.
- You must connect the EMU0/1-OUT signals to the emulation header or directly to a test bus controller.







#### Figure C–13. EMU0/1 Configuration With Additional AND Gate to Meet Timing Requirements of Greater Than 25 ns

Notes: 1) The low time on EMU0/1-IN must be at least one TCK cycle and less than 10 μs. Software sets the EMU0/1-OUT pin to a high state.

2) To enable the open-collector driver and pullup resistor on EMU1 to provide rise/fall time of greater than 25 ns, the modification shown in this figure is suggested. Rise times of more than 25 ns can cause the emulator to detect false edges during the RUNB command or when the external counter selected from the debugger analysis menu is used.

You do not need to have devices on one target board stop devices on another target board using the EMU0/1 signals (see the circuit in Figure C–14). In this configuration, the global-stop capability is lost. It is important not to overload EMU0/1 with more than 16 devices.





**Note:** The open-collector driver and pullup resistor on EMU1 must be able to provide rise/fall times of less than 25 ns. Rise times of more than 25 ns can cause the emulator to detect false edges during the RUNB command or when the external counter selected from the debugger analysis menu is used. If this condition cannot be met, then the EMU0/1 signals from the individual boards must be ANDed together (as shown in Figure C–14) to produce an EMU0/1 signal for the emulator.

#### C.8.4 Performing Diagnostic Applications

For systems that require built-in diagnostics, it is possible to connect the emulation scan path directly to a TI ACT8990 test bus controller (TBC) instead of the emulation header. The TBC is described in the Texas Instruments Advanced Logic and Bus Interface Logic Data Book. Figure C–15 shows the scan path connections of n devices to the TBC.





In the system design shown in Figure C–15, the TBC emulation signals TCKI, TDO, TMS0, TMS2/EVNT0, TMS3/EVNT1, TMS5/EVNT3, TCKO, and TDI0 are used, and TMS1, TMS4/EVNT2, and TDI1 are not connected. The target devices' EMU0 and EMU1 signals are connected to  $V_{CC}$  through pullup resistors and tied to the TBC's TMS2/EVNT0 and TMS3/EVNT1 pins, respectively. The TBC's TCKI pin is connected to a clock generator. The TCK signal for the main JTAG scan path is driven by the TBC's TCKO pin.

On the TBC, the TMS0 pin drives the TMS pins on each device on the main JTAG scan path. TDO on the TBC connects to TDI on the first device on the main JTAG scan path. TDI0 on the TBC is connected to the TDO signal of the last device on the main JTAG scan path. Within the main JTAG scan path, the TDI signal of a device is connected to the TDO signal of the device before it. TRST for the devices can be generated either by inverting the TBC's TMS5/EVNT3 signal for software control or by logic on the board itself.

Appendix D

# Glossary

### Α

- **A0–A15:** Collectively, the external address bus; the 16 pins are used in parallel to address external data memory, program memory, or I/O space.
- ACC: See accumulator.
- ACCH: Accumulator high word. The upper 16 bits of the accumulator. See also accumulator.
- ACCL: Accumulator low word. The lower 16 bits of the accumulator. See also accumulator.
- **accumulator:** A 32-bit register that stores the results of operations in the central arithmetic logic unit (CALU) and provides an input for subsequent CALU operations. The accumulator also performs shift and rotate operations.
- address: The location of program code or data stored in memory.
- **addressing mode:** A method by which an instruction interprets its operands to acquire the data it needs. See also *direct addressing*; *immediate addressing*; *indirect addressing*.
- **analog-to-digital (A/D) converter:** A circuit that translates an analog signal to a digital signal.
- AR: See auxiliary register.
- **AR0–AR7:** Auxiliary registers 0 through 7. See auxiliary register.
- **ARAU:** See auxiliary register arithmetic unit (ARAU).
- **ARB:** See auxiliary register pointer buffer (ARB).
- **ARP:** See auxiliary register pointer (ARP).
- **auxiliary register:** One of eight 16-bit registers (AR7–AR0) used as pointers to addresses in data space. The registers are operated on by the auxiliary register arithmetic unit (ARAU) and are selected by the auxiliary register pointer (ARP).

- **auxiliary register arithmetic unit (ARAU):** A 16-bit arithmetic unit used to increment, decrement, or compare the contents of the auxiliary registers. Its primary function is manipulating auxiliary register values for indirect addressing.
- **auxiliary register pointer (ARP):** A 3-bit field in status register ST0 that points to the current auxiliary register.
- **auxiliary register pointer buffer (ARB):** A 3-bit field in status register ST1 that holds the previous value of the auxiliary register pointer (ARP).
- **B0:** An on-chip block of dual-access RAM that can be configured as either data memory or program memory, depending on the value of the CNF bit in status register ST1.
- B1: An on-chip block of dual-access RAM available for data memory.
- B2: An on-chip block of dual-access RAM available for data memory.
- **BIO pin:** A general-purpose input pin that can be tested by conditional instructions that cause a branch when an external device drives BIO low.
- **bit-reversed indexed addressing**: A method of indirect addressing that allows efficient I/O operations by resequencing the data points in a radix-2 fast Fourier transform (FFT) program. The direction of carry propagation in the ARAU is reversed.
- **boot loader:** A built-in segment of code that transfers code from an 8-bit external source to a 16-bit external program destination at reset.
- **BOOT pin:** The pin that enables the on-chip boot loader. When BOOT is held low, the processor executes the boot loader program after a hardware reset. When BOOT is held high, the processor skips execution of the boot loader and accesses off-chip program-memory at reset.
- **BR:** Bus request pin. This pin is tied to the BR signal, which is asserted when a global data memory access is initiated.
- **branch:** A switching of program control to a nonsequential programmemory address.

### С

**C bit:** See *carry bit.* 

- **CALU:** See central arithmetic logic unit (CALU).
- **carry bit:** Bit 9 of status register ST1; used by the CALU for extended arithmetic operations and accumulator shifts and rotates. The carry bit can be tested by conditional instructions.
- central arithmetic logic unit (CALU): The 32-bit wide main arithmetic logic unit for the 'C24x CPU that performs arithmetic and logic operations. It accepts 32-bit values for operations, and its 32-bit output is held in the accumulator.
- **CLK register:** *CLKOUT1-pin control register.* Bit 0 of determines whether the CLKOUT1 signal is available at the CLKOUT1 pin.
- **CLKIN:** Input clock signal. A clock source signal supplied to the on-chip clock generator at the CLKIN/X2 pin or generated internally by the on-chip oscillator. The clock generator divides or multiplies CLKIN to produce the CPU clock signal, CLKOUT1.
- **CLKOUT1:** *Master clock output signal.* The output signal of the on-chip clock generator. The CLKOUT1 high pulse signifies the CPU's logic phase (when internal values are changed), and the CLKOUT1 low pulse signifies the CPU's latch phase (when the values are held constant).
- CLKOUT1 cycle: See CPU cycle.
- CLKOUT1-pin control register: See CLK register.
- **clock mode (clock generator):** One of the modes which sets the internal CPU clock frequency to a fraction or multiple of the frequency of the input clock signal CLKIN.
- **CNF bit:** DARAM configuration bit. Bit 12 in status register ST1. CNF is used to determine whether the on-chip RAM block B0 is mapped to program space or data space.
- **codec:** A device that codes in one direction of transmission and decodes in another direction of transmission.
- **COFF:** Common object file format. A system of files configured according to a standard developed by AT&T. These files are relocatable in memory space.

PRELIMINARY

Glossary D-3

- **context saving/restoring**: Saving the system status when the device enters a subroutine (such as an interrupt service routine) and restoring the system status when exiting the subroutine. On the 'C24x, only the program counter value is saved and restored automatically; other context saving and restoring must be performed by the subroutine.
- **CPU:** Central processing unit. The 'C24x CPU is the portion of the processor involved in arithmetic, shifting, and Boolean logic operations, as well as the generation of data- and program-memory addresses. The CPU includes the central arithmetic logic unit (CALU), the multiplier, and the auxiliary register arithmetic unit (ARAU).
- **CPU cycle:** The time required for the CPU to go through one logic phase (during which internal values are changed) and one latch phase (during which the values are held constant).
- current AR: See current auxiliary register.
- **current auxiliary register:** The auxiliary register pointed to by the auxiliary register pointer (ARP). The auxiliary registers are AR0 (ARP = 0) through AR7 (ARP = 7). See also *auxiliary register*, *next auxiliary register*.
- **current data page:** The data page indicated by the content of the data page pointer (DP). See also *data page*; *DP*.
- **D0–D15:** Collectively, the external data bus; the 16 pins are used in parallel to transfer data between the 'C24x and external data memory, program memory, or I/O space.
- **DARAM:** *Dual-access RAM.* RAM that can be accessed twice in a single CPU clock cycle. For example, your code can read from and write to DARAM in the same clock cycle.
- DARAM configuration bit (CNF): See CNF bit.
- **data-address generation logic:** Logic circuitry that generates the addresses for data memory reads and writes. This circuitry, which includes the auxiliary registers and the ARAU, can generate one address per machine cycle. See also *program-address generation logic*.
- **data page:** One block of 128 words in data memory. Data memory contains 512 data pages. Data page 0 is the first page of data memory (addresses 0000h–007Fh); data page 511 is the last page (addresses FF80h–FFFFh). See also *data page pointer (DP)*; *direct addressing*.

- **data page 0:** Addresses 0000h–007Fh in data memory; contains the memory-mapped registers, a reserved test/emulation area for special information transfers, and the scratch-pad RAM block (B2).
- **data page pointer (DP):** A 9-bit field in status register ST0 that specifies which of the 512 data pages is currently selected for direct address generation. When an instruction uses direct addressing to access a datamemory value, the DP provides the nine MSBs of the data-memory address, and the instruction provides the seven LSBs.
- data-read address bus (DRAB): A 16-bit internal bus that carries the address for each read from data memory.
- **data read bus (DRDB):** A 16-bit internal bus that carries data from data memory to the CALU and the ARAU.
- data-write address bus (DWAB): A 16-bit internal bus that carries the address for each write to data memory.
- data write bus (DWEB): A 16-bit internal bus that carries data to both program memory and data memory.
- **decode phase:** The phase of the pipeline in which the instruction is decoded. See also *pipeline*; *instruction-fetch phase*; *operand-fetch phase*; *instruction-execute phase*.
- **direct addressing:** One of the methods used by an instruction to address data-memory. In direct addressing, the data-page pointer (DP) holds the nine MSBs of the address (the current data page), and the instruction word provides the seven LSBs of the address (the offset). See also *indirect addressing*.
- **DIV2/DIV1:** Two pins used together to determine the clock mode of the 'C24x clock generator ( $\div$ 2,  $\times$ 1,  $\times$ 2, or  $\times$ 4).
- **DP:** See data page pointer (DP).
- **DRAB:** See data-read address bus (DRAB).
- DRDB: See data read bus (DRDB).
- **DS:** Data memory select pin. The 'C24x asserts DS to indicate an access to external data memory (local or global).
- **DSWS:** Data-space wait-state bit(s). A value in the wait-state generator control register (WSGR) that determines the number of wait states applied to reads from and writes to off-chip data space.

Glossary D-5

dual-access RAM: See DARAM.

- **dummy cycle:** A CPU cycle in which the CPU intentionally reloads the program counter with the same address.
- **DWAB:** See data-write address bus (DWAB).
- **DWEB:** See data write bus (DWEB).

- **execute phase:** The fourth phase of the pipeline; the phase in which the instruction is executed. See also *pipeline*; *instruction-fetch phase*; *instruction-decode phase*; *operand-fetch phase*.
- **external interrupt:** A hardware interrupt triggered by an external event sending an input through an interrupt pin.
- **FIFO buffer:** *First-in, first-out buffer.* A portion of memory in which data is stored and then retrieved in the same order in which it was stored. The synchronous serial port has two four-word-deep FIFO buffers: one for its transmit operation and one for its receive operation.
- flash memory: Electronically erasable and programmable, nonvolatile (read-only) memory.
- **general-purpose input/output pins:** Pins that can be used to accept input signals and/or send output signals but are not linked to specific uses. These pins are the input pin BIO, the output pin XF, and the input/output pins IO0, IO1, IO2, and IO3.
- **global data space**: One of the four 'C24x address spaces. The global data space can be used to share data with other processors within a system and can serve as additional data space. See also *local data space*.
- **GREG:** *Global memory allocation register.* A memory-mapped register used for specifying the size of the global data memory. Addresses not allocated by the GREG for global data memory are available for local data memory.

G

### Η

- **hardware interrupt:** An interrupt triggered through physical connections with on-chip peripherals or external devices.
- **HOLD:** An input signal that allows external devices to request control of the external buses. If an external device drives the HOLD/INT1 pin low and the CPU sends an acknowledgement at the HOLDA pin, the external device has control of the buses until it drives HOLD high or a nonmaskable hardware interrupt is generated. If HOLD is not used, it should be pulled high.
- **HOLDA:** HOLD acknowledge signal. An output signal sent to the HOLDA pin by the CPU in acknowledgement of a properly initiated HOLD operation. When HOLDA is low, the processor is in a holding state and the address, data, and memory-control lines are available to external circuitry.
- **HOLD operation:** An operation on the 'C24x that allows for direct memory access of external memory and I/O devices. A HOLD operation is initiated by a HOLD/INT1 interrupt. When the corresponding interrupt service routine executes an IDLE instruction, the external buses enter the high-impedance state and the HOLDA signal is asserted. The buses return to their normal state, and the HOLD operation is concluded, when the processor exits the IDLE state.

- **IACK:** See interrupt acknowledge signal (IACK).
- **ICR:** See interrupt control register (ICR).
- **IFR:** See interrupt flag register (IFR).
- **immediate addressing:** One of the methods for obtaining data values used by an instruction; the data value is a constant embedded directly into the instruction word; data memory is not accessed.
- **immediate operand/immediate value:** A constant given as an operand in an instruction that is using immediate addressing.
- IMR: See interrupt mask register (IMR).
- **indirect addressing:** One of the methods for obtaining data values used by an instruction. When an instruction uses indirect addressing, data memory is addressed by the current auxiliary register. See also *direct addressing*.

input clock signal: See CLKIN.

- **input shifter:** A 16- to 32-bit left barrel shifter that shifts incoming 16-bit data from 0 to 16 positions left relative to the 32-bit output.
- **instruction-decode phase:** The second phase of the pipeline; the phase in which the instruction is decoded. See also *pipeline*; *instruction-fetch phase*; *operand-fetch phase*; *instruction-execute phase*.
- **instruction-execute phase:** The fourth phase of the pipeline; the phase in which the instruction is executed. See also *pipeline*; *instruction-fetch phase*; *instruction-decode phase*; *operand-fetch phase*.
- **instruction-fetch phase:** The first phase of the pipeline; the phase in which the instruction is fetched from program-memory. See also *pipeline*; *instruction-decode phase*; *operand-fetch phase*; *instruction-execute phase*.
- **instruction register (IR):** A 16-bit register that contains the instruction being executed.
- **instruction word:** A 16-bit value representing all or half of an instruction. An instruction that is fully represented by 16 bits uses one instruction word. An instruction that must be represented by 32 bits uses two instruction words (the second word is a constant).
- INT1–INT3: Three external pins used to generate general-purpose hardware interrupts.
- internal interrupt: A hardware interrupt caused by an on-chip peripheral.
- interrupt: A signal sent to the CPU that (when not masked or disabled) forces the CPU into a subroutine called an interrupt service routine (ISR). This signal can be triggered by an external device, an on-chip peripheral, or an instruction (INTR, NMI, or TRAP).
- **interrupt acknowledge signal (IACK):** An output signal that indicates an interrupt has been received and that the program counter is fetching the interrupt vector that will force the processor into the appropriate interrupt service routine.
- **INT2** and **INT1** and to individually mask and flag **INT2** and **INT3**.
- **interrupt flag register (IFR):** A 16-bit memory-mapped register that indicates pending interrupts. Read the IFR to identify pending interrupts and write to the IFR to clear selected interrupts. Writing a 1 to any IFR flag bit clears that bit to 0.

- **interrupt latency:** The delay between the time an interrupt request is made and the time it is serviced.
- **interrupt mask register (IMR):** A 16-bit memory-mapped register used to mask external and internal interrupts. Writing a 1 to any IMR bit position enables the corresponding interrupt (when INTM = 0).
- interrupt mode bit (INTM): Bit 9 in status register ST0; either enables all maskable interrupts that are not masked by the IMR or disables all maskable interrupts.
- **interrupt service routine (ISR)**: A module of code that is executed in response to a hardware or software interrupt.
- interrupt trap: See interrupt service routine (ISR).
- **interrupt vector:** A branch instruction that leads the CPU to an interrupt service routine (ISR).
- interrupt vector location: An address in program memory where an interrupt vector resides. When an interrupt is acknowledged, the CPU branches to the interrupt vector location and fetches the interrupt vector.
- **INTM bit:** See interrupt mode bit (INTM).
- I/O-mapped register: One of the on-chip registers mapped to addresses in I/O (input/output) space. These registers, which include the registers for the on-chip peripherals, must be accessed with the IN and OUT instructions. See also *memory-mapped register*.
- **IR:** See instruction register (IR).
- **IS:** *I/O space select pin.* The 'C24x asserts **IS** to indicate an access to external I/O space.
- **ISR:** See interrupt service routine (ISR).
- **ISWS:** *I/O-space wait-state bit(s).* A value in the wait-state generator control register (WSGR) that determines the number of wait states applied to reads from and writes to off-chip I/O space.

- **latch phase:** The phase of a CPU cycle during which internal values are held constant. See also *logic phase*; *CLKOUT1*.
- **local data space:** The portion of data-memory addresses that are not allocated as global by the global memory allocation register (GREG). If none of the data-memory addresses are allocated for global use, all of data space is local. See also *global data space*.

- **logic phase:** The phase of a CPU cycle during which internal values are changed. See also *latch phase*; *CLKOUT1*.
- **long-immediate value:** A 16-bit constant given as an operand of an instruction that is using immediate addressing.
- **LSB**: *Least significant bit.* The lowest order bit in a word. When used in plural form (LSBs), refers to a specified number of low-order bits, beginning with the lowest order bit and counting to the left. For example, the four LSBs of a 16-bit value are bits 0 through 3. See also *MSB*.

IVI

machine cycle: See CPU cycle.

- **maskable interrupt**: A hardware interrupt that can be enabled or disabled through software. See also *nonmaskable interrupt*.
- master clock output signal: See CLKOUT1.
- master phase: See logic phase.
- **memory-mapped register:** One of the on-chip registers mapped to addresses in data memory. See also *I/O-mapped register*.
- **microcomputer mode:** A mode in which the on-chip ROM or flash memory is enabled. This mode is selected with the MP/MC pin. See also MP/MC pin; microprocessor mode.
- **microprocessor mode:** A mode in which the on-chip ROM or flash memory is disabled. This mode is selected with the MP/MC pin. See also MP/MC pin; microcomputer mode.
- **microstack (MSTACK):** A register used for temporary storage of the program counter (PC) value when an instruction needs to use the PC to address a second operand.
- **MIPS:** Million instructions per second.
- **MODE bit:** Bit 4 of the interrupt control register (ICR); determines whether the HOLD/INT1 pin is only negative-edge sensitive or both negative- and positive-edge sensitive.
- **MP/MC pin**: A pin that indicates whether the processor is operating in microprocessor mode or microcomputer mode. MP/MC high selects microprocessor mode; MP/MC low selects microcomputer mode.
- **MSB:** Most significant bit. The highest order bit in a word. When used in plural form (MSBs), refers to a specified number of high-order bits, beginning with the highest order bit and counting to the right. For example, the eight MSBs of a 16-bit value are bits 15 through 8. See also *LSB*.

**MSTACK:** See *microstack*.

**multiplier:** A part of the CPU that performs 16-bit × 16-bit multiplication and generates a 32-bit product. The multiplier operates using either signed or unsigned 2s-complement arithmetic.

## Ν

**next AR:** See next auxiliary register.

- **next auxiliary register:** The register that is pointed to by the auxiliary register pointer (ARP) when an instruction that modifies ARP is finished executing. See also *auxiliary register*, *current auxiliary register*.
- **NMI:** A hardware interrupt that uses the same logic as the maskable interrupts but cannot be masked. It is often used as a soft reset. See also *maskable interrupt*; *nonmaskable interrupt*.
- **nonmaskable interrupt:** An interrupt that can be neither masked by the interrupt mask register (IMR) nor disabled by the INTM bit of status register ST0.
- **NPAR:** Next program address register. Part of the program-address generation logic. This register provides the address of the next instruction to the program counter (PC), the program address register (PAR), the micro stack (MSTACK), or the stack.

## 0

- **operand:** A value to be used or manipulated by an instruction; specified in the instruction.
- **operand-fetch phase:** The third phase of the pipeline; the phase in which an operand or operands are fetched from memory. See also *pipeline*; *instruction-fetch phase*; *instruction-decode phase*; *instruction-execute phase*.
- **output shifter:** 32- to 16-bit barrel left shifter. Shifts the 32-bit accumulator output from 0 to 7 bits left for quantization management, and outputs either the 16-bit high or low half of the shifted 32-bit data to the data write bus (DWEB).
- **OV bit:** Overflow flag bit. Bit 12 of status register ST0; indicates whether the result of an arithmetic operation has exceeded the capacity of the accumulator.

- **overflow (in a register):** A condition in which the result of an arithmetic operation exceeds the capacity of the register used to hold that result.
- **overflow mode:** The mode in which an overflow in the accumulator causes the accumulator to be loaded with a preset value. If the overflow is in the positive direction, the accumulator is loaded with its most positive number. If the overflow is in the negative direction, the accumulator is filled with its most negative number.
- **OVM bit:** Overflow mode bit. Bit 11 of status register ST0; enables or disables overflow mode. See also overflow mode.

- **PAB:** See program address bus (PAB).
- **PAR:** *Program address register.* A register that holds the address currently being driven on the program address bus for as many cycles as it takes to complete all memory operations scheduled for the current machine cycle.
- PC: See program counter (PC).
- PCB: Printed circuit board.
- **pending interrupt:** A maskable interrupt that has been successfully requested but is awaiting acknowledgement by the CPU.
- **pipeline**: A method of executing instructions in an assembly line fashion. The 'C24x pipeline has four independent phases. During a given CPU cycle, four different instructions can be active, each at a different stage of completion. See also *instruction-fetch phase*; *instruction-decode phase*; *operand-fetch phase*; *instruction-execute phase*.
- PLL: Phase lock loop circuit.
- **PM bits:** See product shift mode bits (PM).
- **power-down mode:** The mode in which the processor enters a dormant state and dissipates considerably less power than during normal operation. This mode is initiated by the execution of an IDLE instruction. During a power-down mode, all internal contents are maintained so that operation continues unaltered when the power-down mode is terminated. The contents of all on-chip RAM also remains unchanged.
- **PRDB:** See program read bus (PRDB).

- **PREG:** See product register (PREG).
- **product register (PREG):** A 32-bit register that holds the results of a multiply operation.
- **product shifter:** A 32-bit shifter that performs a 0-, 1-, or 4-bit left shift, or a 6-bit right shift of the multiplier product based on the value of the product shift mode bits (PM).
- **product shift mode:** One of four modes (no-shift, shift-left-by-one, shift-left-by-four, or shift-right-by-six) used by the product shifter.
- **product shift mode bits (PM):** Bits 0 and 1 of status register ST1; they identify which of four shift modes (no-shift, left-shift-by-one, left-shift-by-four, or right-shift-by-six) will be used by the product shifter.
- program address bus (PAB): A 16-bit internal bus that provides the addresses for program-memory reads and writes.
- **program-address generation logic:** Logic circuitry that generates the addresses for program memory reads and writes, and an operand address in instructions that require two registers to address operands. This circuitry can generate one address per machine cycle. See also *data-address generation logic.*
- **program control logic:** Logic circuitry that decodes instructions, manages the pipeline, stores status of operations, and decodes conditional operations.
- **program counter (PC):** A register that indicates the location of the next instruction to be executed.
- **program read bus (PRDB):** A 16-bit internal bus that carries instruction code and immediate operands, as well as table information, from program memory to the CPU.
- **PS:** *Program select pin.* The 'C24x asserts PS to indicate an access to external program memory.
- **PSLWS:** Lower program-space wait-state bits. A value in the wait-state generator control register (WSGR) that determines the number of wait states applied to reads from and writes to off-chip lower program space (addresses 0000h–7FFFh). See also *PSUWS*.
- **PSUWS:** Upper program-space wait-state bits. A value in the wait-state generator control register (WSGR) that determines the number of wait states applied to reads from and writes to off-chip upper program space (addresses 8000h–FFFFh). See also *PSLWS*.

R

- **RAMEN:** *RAM enable pin.* This pin enables or disables on-chip single-access RAM.
- **RD:** *Read select pin.* The 'C24x asserts RD to request a read from external program, data, or I/O space. RD can be connected directly to the output enable pin of an external device.
- **READY:** External device ready pin. Used to create wait states externally. When this pin is driven low, the 'C24x waits one CPU cycle and then tests READY again. After READY is driven low, the 'C24x does not continue processing until READY is driven high.
- **repeat counter (RPTC):** A 16-bit register that counts the number of times a single instruction is repeated. RPTC is loaded by an RPT instruction.
- **reset:** A way to bring the processor to a known state by setting the registers and control bits to predetermined values and signaling execution to start at address 0000h.
- reset pin (RS): A pin that causes a reset.
- reset vector: The interrupt vector for reset.
- **return address:** The address of the instruction to be executed when the CPU returns from a subroutine or interrupt service routine.
- **RPTC:** See repeat counter (RPTC).
- **RS:** *Reset pin.* When driven low, causes a reset on any 'C24x device.
- **R**/**W**: *Read/write pin.* Indicates the direction of transfer between the 'C24x and external program, data, or I/O space.

- **SARAM:** Single-access RAM. RAM that can accessed (read from or written to) once in a single CPU cycle.
- scratch-pad RAM: Another name for DARAM block B2 in data space (32 words).
- **short-immediate value:** An 8-, 9-, or 13-bit constant given as an operand of an instruction that is using immediate addressing.
- **sign bit:** The MSB of a value when it is seen by the CPU to indicate the sign (negative or positive) of the value.

- **sign extend:** Fill the unused high order bits of a register with copies of the sign bit in that register.
- sign-extension mode (SXM) bit: Bit 10 of status register ST1; enables or disables sign extension in the input shifter. It also differentiates between logic and arithmetic shifts of the accumulator.
- single-access RAM: See SARAM.
- slave phase: See *latch phase*.
- **software interrupt:** An interrupt caused by the execution of an INTR, NMI, or TRAP instruction.
- **software stack:** A program control feature that allows you to extend the hardware stack into data memory with the PSHD and POPD instructions. The stack can be directly stored and recovered from data memory, one word at time. This feature is useful for deep subroutine nesting or protection against stack overflow.
- **ST0 and ST1:** See status registers ST0 and ST1.
- **stack:** A block of memory reserved for storing return addresses for subroutines and interrupt service routines. The 'C24x stack is 16 bits wide and eight levels deep.
- status registers ST0 and ST1: Two 16-bit registers that contain bits for determining processor modes, addressing pointer values, and indicating various processor conditions and arithmetic logic results. These registers can be stored into and loaded from data memory, allowing the status of the machine to be saved and restored for subroutines.
- **STRB:** *External access active strobe.* The 'C24x asserts STRB during accesses to external program, data, or I/O space.
- **SXM bit:** See sign-extension mode bit (SXM).

- **TC bit:** *Test/control flag bit.* Bit 11 of status register ST1; stores the results of test operations done in the central arithmetic logic unit (CALU) or the auxiliary register arithmetic unit (ARAU). The TC bit can be tested by conditional instructions.
- **temporary register (TREG):** A 16-bit register that holds one of the operands for a multiply operation; the dynamic shift count for the LACT, ADDT, and SUBT instructions; or the dynamic bit position for the BITT instruction.

V

W

Χ

Ζ

| TF | <ul> <li><b>DS:</b> Top of stack. Top level of the 8-level last-in, first-out hardware stack.</li> <li><b>REG:</b> See temporary register (TREG).</li> <li><b>TL:</b> Transistor-to-transistor logic.</li> </ul>                       |
|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | ector: See interrupt vector.<br>ector location: See interrupt vector location.                                                                                                                                                         |
|    | ait state: A CLKOUT1 cycle during which the CPU waits when reading from or writing to slower external memory.                                                                                                                          |
| Wa | ait-state generator: An on-chip peripheral that generates a limited<br>number of wait states for a given off-chip memory space (program, data,<br>or I/O). Wait states are set in the wait-state generator control register<br>(WSGR). |
| W  | <b>E:</b> Write enable pin. The 'C24x asserts WE to request a write to external program, data, or I/O space.                                                                                                                           |
| w  | <b>'SGR:</b> <i>Wait-state generator control register.</i> This register, which is mapped to I/O memory, controls the wait-state generator.                                                                                            |
| XF | <b>F bit:</b> XF-pin status bit. Bit 4 of status register ST1 that is used to read or change the logic level on the XF pin.                                                                                                            |
| XF | <b>F pin:</b> <i>External flag pin.</i> A general-purpose output pin whose status can be read or changed by way of the XF bit in status register ST1.                                                                                  |
| ze | ero fill: A way to fill the unused low or high order bits in a register by insert-<br>ing 0s.                                                                                                                                          |

### Appendix E

# Summary of Updates in This Document

This appendix provides a summary of the updates in this version of the document. Updates within paragraphs appear in a **bold typeface**.

#### Page: Change or Add:

- 4–5 Changed Figure 4–2, *Data Memory Map for 'C24x.* The word count for DARAM (B0) and DARAM (B1) was changed to : 256/512, device dependent.
- 6–5 Changed Figure 6–2, *System Control Register* (*SYSCR*). The CLKSRC1 and CLKSRC0 read/write notation was changed to : R/W–1\*, not affected by reset. Set to 1 by power-on reset.
- 6–37 Changed Figure 6–10, *External Interrupt Control Registers*. The alpha suffix CR was added to each register designation. At address 7072h, Type A was changed to Type A–NMI.
- 8–49 Changed the text note in the center of the page to : BLDD does not work with core memory-mapped registers **such as IMR, IFR, and GREG**.

# Index

'C2xx, features, emulation 2-11
\* operand 7-10
\*- operand 7-10
\*0- operand 7-10
\*0- operand 7-10
\*BR0+ operand 7-10
\*BR0- operand 7-10
14-pin connector, dimensions C-15
14-pin header header signals C-2 JTAG C-2
4-level pipeline operation 5-7

### A

ABS instruction 8-20 absolute value (ABS instruction) 8-20 accumulator definition D-1 description 3-9 introduction 2-8 shifting and storing high and low words, diagrams 3-11 accumulator instructions absolute value of accumulator (ABS), 8-20 add PREG to accumulator (APAC), 8-36 add PREG to accumulator and load TREG (LTA) 8-92 add PREG to accumulator and multiply (MPYA) 8-115 add PREG to accumulator and square specified value (SQRA) 8-167 accumulator instructions (continued) add PREG to accumulator, load TREG, and move data (LTD) 8-94

add PREG to accumulator, load TREG, and multiply (MAC) 8-101 add PREG to accumulator, load TREG, multiply, and move data (MACD) 8-105 add value plus carry to accumulator (ADDC), 8-26 add value to accumulator (ADD) 8-22 add value to accumulator with shift specified by TREG (ADDT) 8-30 add value to accumulator with sign extension suppressed (ADDS), 8-28 AND accumulator with value (AND) 8-33 branch to location specified by accumulator (BACC) 8-39 call subroutine at location specified by accumulator (CALA) 8-57 complement accumulator (CMPL) 8-63 divide using accumulator (SUBC) 8-179 load accumulator (LACC) 8-71 load accumulator using shift specified by TREG (LACT) 8-77 load accumulator with PREG (PAC) 8-133 load accumulator with PREG and load TREG (LTP) 8-97 load high bits of accumulator with rounding (ZALR) 8-195 load low bits and clear high bits of accumulator (LACL) 8-74 negate accumulator (NEG) 8-121 normalize accumulator (NORM) 8-125 OR accumulator with value (OR) 8-128 pop top of stack to low accumulator bits (POP) 8-134 push low accumulator bits onto stack (PUSH) 8-140 rotate accumulator left by one bit (ROL) 8-143 rotate accumulator right by one bit (ROR) 8-144 accumulator instructions (continued) shift accumulator left by one bit (SFL) 8-156 shift accumulator right by one bit (SFR) 8-157

#### PRELIMINARY

store high byte of accumulator to data memory (SACH) 8-147 store low byte of accumulator to data memory (SACL) 8-149 subtract conditionally from accumulator (SUBC) 8-179 subtract PREG from accumulator (SPAC) 8-159 subtract PREG from accumulator and load TREG (LTS) 8-99 subtract PREG from accumulator and multiply (MPYS) 8-117 subtract PREG from accumulator and square specified value (SQRS 8-169 subtract value and logical inversion of carry bit from accumulator (SUBB) 8-177 subtract value from accumulator (SUB) 8-173 subtract value from accumulator with shift specified by TREG (SUBT) 8-183 subtract value from accumulator with sign extension suppressed (SUBS) 8-181 XOR accumulator with data value (XOR) 8-192 ADD instruction 8-22 ADDC instruction 8-26 address generation data memory direct addressing 7-4 immediate addressing 7-2 indirect addressing 7-9 program memory 5-2 hardware 5-3 address map, local data memory, data page 0 4-7 addressing bit-reversed indexed 7-10, D-2 global data memory 4-11 addressing modes definition D-1 direct description 7-4 examples 7-6 figure 7-5 opcode format 7-5 to 7-7 role of data page pointer (DP) 7-4 immediate 7-2 indirect description 7-9

addressing modes (continued) effects on auxiliary register pointer (ARP) 7-13 to 7-15 effects on current auxiliary register 7-13 to 7-15 examples 7-14 modifying auxiliary register content 7-16 opcode format 7-12 to 7-14 operands 7-9 operation types 7-13 to 7-15 options 7-9 possible opcodes 7-13 to 7-15 overview 7-1 ADDS instruction 8-28 ADDT instruction 8-30 ADRK instruction 8-32 AND instruction 8-33 APAC instruction 8-36 ARAU (auxiliary register arithmetic unit) 3-12 introduction 2-9 ARAU and related logic, block diagram 3-12 ARB (auxiliary register pointer buffer) 3-16 architecture internal memory 2-5 to 2-7 on-chip peripherals 2-11 arithmetic logic unit, central (CALU) 3-9 ARP (auxiliary register pointer) 3-16 auxiliary register arithmetic unit (ARAU), description 3-12 auxiliary register instructions add short immediate value to current auxiliary register (ADRK) 8-32 branch if current auxiliary register not zero (BANZ) 8-40 compare current auxiliary register with AR0 (CMPR) 8-64 load specified auxiliary register (LAR) 8-79 modify auxiliary register pointer (MAR) 8-110 modify current auxiliary register (MAR) 8-110 store specified auxiliary register (SAR) 8-151 subtract short immediate value from current auxiliary register (SBRK) 8-153 auxiliary register pointer (ARP) 3-16, D-2 auxiliary register pointer buffer (ARB) 3-16, D-2 auxiliary register update (ARU) code 7-12 auxiliary registers, introduction 2-9

PRELIMINARY

auxiliary registers (AR0–AR7) block diagram 3-12 current auxiliary register 7-9 *role in indirect addressing 7-9 to 7-16 update code (ARU) 7-12* description 3-12 to 3-14 general uses for 3-14 instructions that modify content 7-16 next auxiliary register 7-11 used in indirect addressing 3-12

### Β

B instruction 8-38 BACC instruction 8-39 BANZ instruction 8-40 BCND instruction 8-42 BIT instruction 8-44 bit-reversed indexed addressing 7-10, D-2 BITT instruction 8-46 BLDD instruction 8-48 block diagrams ARAU and related logic 3-12 arithmetic logic section of CPU 3-8 auxiliary registers (AR0-AR7) and ARAU 3-12 CPU (selected sections) 3-2 input scaling section of CPU 3-3 multiplication section of CPU 3-5 program-address generation 5-2 block move instructions block move from data memory to data memory (BLDD) 8-48 block move from program memory to data memory (BLPD) 8-53 BLPD instruction 8-53 Boolean logic instructions AND 8-33 CMPL (complement/NOT) 8-63 OR 8-128 XOR (exclusive OR) 8-192 branch instructions branch conditionally (BCND) 8-42 branch if current auxiliary register not zero (BANZ) 8-40 branch to location specified by accumulator (BACC) 8-39 branch to NMI interrupt vector location (NMI) 8-123

branch instructions (continued) branch to specified interrupt vector location (INTR) 8-70 branch to TRAP interrupt vector location (TRAP) 8-191 branch unconditionally (B) 8-38 call subroutine at location specified by accumulator (CALA) 8-57 call subroutine conditionally (CC) 8-59 call subroutine unconditionally (CALL) 8-58 conditional, overview 5-11 return conditionally from subroutine (RETC) 8-142 return unconditionally from subroutine (RET) 8-141 unconditional, overview 5-8 buffered signals, JTAG C-10 buffering C-10 bus devices C-4 bus protocol in emulator system C-4 buses data read bus (DRDB) 2-4 data write bus (DWEB) 2-4 data-read address bus (DRAB) 2-4 data-write address bus (DWAB) 2-4 program address bus (PAB) 2-4 used in program-memory address generation 5-3 program read bus (PRDB) 2-4

### С

C (carry bit) affected during SFL and SFR instructions 8-156 to 8-158 definition 3-16 involved in accumulator events 3-10 used during ROL and ROR instructions 8-143 to 8-145 cable, target system to emulator C-1 to C-25 cable pod C-5, C-6 CALA instruction 8-57 CALL instruction 8-58 call instructions call subroutine at location specified by accumulator (CALA) 8-57 call subroutine conditionally (CC) 8-59 call subroutine unconditionally (CALL) 8-58 conditional, overview 5-12 unconditional, overview 5-8

CALU (central arithmetic logic unit) definition D-3 description 3-9 introduction 2-8 carry bit (C) affected during SFL and SFR instructions 8-156 to 8-158 definition 3-16 involved in accumulator events 3-10 used during ROL and ROR instructions 8-143 to 8-145 CC instruction 8-59 central arithmetic logic section of CPU 3-8 CHAR LEN2-0 bits 6-17, 6-18 character length 6-17, 6-18 CLKOUT1 signal, definition D-3 CLRC instruction 8-61 CMPL instruction 8-63 CMPR instruction 8-64 CNF (DARAM configuration bit) 3-16 codec, definition D-3 communication control register (SCInCCR) 6-40, 6-42, 6-44, 6-45, 6-46 conditional instructions 5-10 to 5-13 conditional branch 5-11 to 5-13 conditional call 5-12 to 5-13 conditional return 5-12 to 5-13 conditions that may be tested 5-10 stabilization of conditions 5-11 using multiple conditions 5-10 configuration DARAM, 'C203, 4-3 global data memory 4-9 multiprocessor C-13 SARAM, 'C209, 4-4, 4-8 connector 14-pin header C-2 dimensions, mechanical C-14 DuPont C-2 contacting Texas Instruments, x control bits CHAR LEN2-0, 6-17, 6-18 PARITY ENABLE 6-17, 6-19 STOP BITS 6-17, 6-19, 6-40, 6-41, 6-42, 6-43, 6-44, 6-45, 6-46, 6-47

#### CPU

accumulator 3-9 arithmetic logic section 3-8 auxiliary register arithmetic unit (ARAU) 3-12 block diagram (partial) 3-2 CALU (central arithmetic logic unit) 3-9 central arithmetic logic unit (CALU) 3-9 components 3-1 definition D-4 input scaling section/input shifter 3-3 introduction 3-1 to 3-18 multiplication section 3-5 output shifter 3-11 overview 2-8 product shifter 3-6 product shift modes 3-7 program control 2-10 status registers ST0 and ST1, 3-15 current auxiliary register 7-9 add short immediate value to (ADRK instruction) 8-32 branch if not zero (BANZ instruction) 8-40 compare with AR0 (CMPR instruction) 8-64 increment or decrement (MAR instruction) 8-110 role in indirect addressing 7-9 to 7-16 subtract short immediate value from (SBRK instruction) 8-153 update code (ARU) 7-12

### D

D0–D15 (external data bus), definition D-4 DARAM 2-5 configuration, 'C203, 4-3 DARAM configuration bit (CNF) 3-16 data memory data page pointer (DP) 3-16 global data memory 4-9 local data memory 4-5 on-chip registers 4-7 data page 0 address map 4-7 on-chip registers 4-7 RAM block B2 (scratch-pad RAM) 4-7 data page pointer (DP) caution about initializing DP 7-5 definition 3-16 load (LDP instruction) 8-82 role in direct addressing 7-4

PRELIMINARY

data read bus (DRDB) 2-4 data write bus (DWEB) 2-4 data-read address bus (DRAB) 2-4 data-scaling shifter at input of CALU 3-3 at output of CALU 3-11 data-write address bus (DWAB) 2-4 device reset 6-37, 6-48 diagnostic applications C-24 dimensions 12-pin header C-20 14-pin header C-14 mechanical 14-pin header C-14 direct addressing description 7-4 examples 7-6 figure 7-5 opcode format 7-5 to 7-7 role of data page pointer (DP) 7-4 DIV1 and DIV2 pins D-5 divide (SUBC instruction) 8-179 DMOV instruction 8-65 DP (data page pointer) caution about initializing DP 7-5 definition 3-16 load (LDP instruction) 8-82 role in direct addressing 7-4 DRAB (data-read address bus) 2-4 DRDB (data read bus) 2-4 dual-access RAM 2-5 configuration, 'C203, 4-3 dual-access RAM (DARAM) D-4 DuPont connector C-2 DWAB (data-write address bus) 2-4 DWEB (data write bus) 2-4

### Ξ

EMU0/1 configuration C-21, C-23, C-24 emulation pins C-20 IN signals C-21 rising edge modification C-22 EMU0/1 signals C-2, C-3, C-6, C-7, C-13, C-18

#### PRELIMINARY

emulation configuring multiple processors C-13 JTAG cable C-1 pins C-20 serial-scan 2-11 timing calculations C-7 to C-9, C-18 to C-26 using scan path linkers C-16 emulation timing C-7 emulator cable pod C-5 connection to target system, JTAG mechanical dimensions C-14 to C-25 designing the JTAG cable C-1 emulation pins C-20 pod interface C-5 pod timings C-6 signal buffering C-10 to C-13 target cable, header design C-2 to C-3 enabling, parity 6-17, 6-19 enhanced instructions A-5

### F

features, emulation 2-11 flow charts, TMS320 ROM code procedural B-2

## G

global data memory 4-9 address generation 4-11 configuration 4-9 global memory allocation register (GREG) 4-9 global memory allocation register (GREG) 4-9 GREG 4-9

# Η

hardware interrupts, nonmaskable external RS 6-37, 6-48 RS ('C209) 6-37, 6-48 hardware reset 6-37, 6-48 effects 6-39 to 6-45, 6-49 to 6-52 hardware stack, overflow, ISRs within ISRs 6-32 header 14-pin C-2 dimensions 14-pin C-2

I/O space, instructions transfer data from data memory to I/O space (OUT) 8-131 transfer data from I/O space to data memory (IN) 8-68 IDLE instruction 8-67 IEEE 1149.1 specification, bus slave device rules C-4 IFR 6-16 to 6-58 immediate addressing 7-2 IMR 6-18 to 6-58 IN instruction 8-68 indirect addressing description 7-9 effects on auxiliary register pointer (ARP) 7-13 to 7-15 effects on current auxiliary register 7-13 to 7-15 examples 7-14 modifying auxiliary register content 7-16 opcode format 7-12 to 7-14 operands 7-10 operation types 7-13 to 7-15 options 7-9 possible opcodes 7-13 to 7-15 input scaling section of CPU 3-3 input shifter 3-3 instruction register (IR), definition D-8 instructions 8-1 to 8-19 Boolean logic AND 8-33 CMPL (complement/NOT) 8-63 OR 8-128 XOR (exclusive OR) 8-192 compared with those of other TMS320 devices A-1 to A-36 conditional 5-10 to 5-13 branch (BCND) 8-42 call (CC) 8-59 conditions that may be tested 5-10 return (RETC) 8-142 stabilization of conditions 5-11 using multiple conditions 5-10 CPU halt until hardware interrupt (IDLE) 8-67 delay/no operation (NOP) 8-124 descriptions 8-19 how to use 8-12

instructions (continued) enhanced A-5 idle until hardware interrupt (IDLE) 8-67 interrupt branch to NMI interrupt vector location (NMI) 8-123 branch to specified interrupt vector location (INTR) 8-70 branch to TRAP interrupt vector location (TRAP) 8-191 negate accumulator (NEG) 8-121 no operation (NOP) 8-124 normalize (NORM) 8-125 OR 8-128 power down until hardware interrupt (IDLE) 8-67 repeat next instruction n times description (RPT) 8-145 introduction 5-14 stack pop top of stack to data memory (POPD) 8-136 pop top of stack to low accumulator bits (POP) 8-134 push data memory value onto stack (PSHD) 8-138 push low accumulator bits onto stack (PUSH) 8-140 status registers ST0 and ST1 clear control bit (CLRC) 8-61 load (LST) 8-86 load data page pointer (LDP) 8-82 modify auxiliary register pointer (MAR) 8-110 set control bit (SETC) 8-154 set product shift mode (SPM) 8-166 store (SST) 8-171 summary 8-2 to 8-11 test bit specified by TREG (BITT) 8-46 test specified bit (BIT) 8-44 INT1 interrupt priority, 'C203, 6-10 vector location, 'C203, 6-10 INT10 interrupt, vector location, 'C203, 6-10 INT11 interrupt, vector location, 'C203, 6-10 INT12 interrupt, vector location, 'C203, 6-10 INT13 interrupt, vector location, 'C203, 6-10 INT14 interrupt, vector location, 'C203, 6-10 INT15 interrupt, vector location, 'C203, 6-10 INT16 interrupt, vector location, 'C203, 6-10

PRELIMINARY

INT2 interrupt priority, 'C203, 6-10 vector location, 'C203, 6-10 INT20 interrupt, vector location, 'C203, 6-10 INT21 interrupt, vector location, 'C203, 6-10 INT22 interrupt, vector location, 'C203, 6-10 INT23 interrupt, vector location, 'C203, 6-10 INT24 interrupt, vector location, 'C203, 6-11 INT25 interrupt, vector location, 'C203, 6-11 INT26 interrupt, vector location, 'C203, 6-11 INT27 interrupt, vector location, 'C203, 6-11 INT28 interrupt, vector location, 'C203, 6-11 INT29 interrupt, vector location, 'C203, 6-11 INT3 interrupt priority, 'C203, 6-10 vector location, 'C203, 6-10 INT30 interrupt, vector location, 'C203, 6-11 INT31 interrupt, vector location, 'C203, 6-11 INT8 interrupt, vector location, 'C203, 6-10 to 6-12 INT9 interrupt, vector location, 'C203, 6-10 internal memory dual-access RAM 2-5 configuration, 'C203, 4-3 organization 2-5 ROM, configuration, 'C209, 4-4 single-access RAM 2-6 configuration, 'C209, 4-4, 4-8 interrupt definitions D-8 interrupt mode bit (INTM) 3-16 maskable interrupt, interrupt mode bit (INTM) 3-16 interrupt flag register (IFR) 6-16 to 6-58 interrupt latency, definition D-9 interrupt mask register (IMR) 6-18 to 6-58 interrupt mode bit (INTM) 3-16 interrupt service routines (ISRs) definition D-9 ISRs within ISRs 6-32 interrupts 6-9 to 6-47 hardware nonmaskable external RS 6-37, 6-48 RS ('C209) 6-37, 6-48 priorities 'C203, 6-22

'C24x 6-10 interrupts (continued) IMR register 6-18 interrupt mask register 6-18 interrupt service routines (ISRs), ISRs within ISRs 6-32 latency 6-33 to 6-34 after execution of RET 6-34 during execution of CLRC INTM 6-34 factors 6-33 to 6-34 minimum latency 6-33 masking, interrupt mask register (IMR) 6-18 to 6-58 nonmaskable, reset, effects 6-39 to 6-45, 6-49 to 6-52 pending, interrupt flag register (IFR) 6-16 to 6-58 saving data 6-31 vector locations, 'C203, 6-22 INTM (interrupt mode bit) 3-16 INTR instruction 8-70 introduction, TMS320 family overview 1-2 IR (instruction register), definition D-8 ISR, ISRs within ISRs 6-32 ISR (interrupt service routine), definition D-9

## J

JTAG C-16 JTAG emulator buffered signals C-10 connection to target system C-1 to C-25 no signal buffering C-10

LACC instruction 8-71 LACL instruction 8-74 LACT instruction 8-77 LAR instruction 8-79 latch phase of CPU cycle D-9 latency, interrupt 6-33 to 6-34 after execution of RET 6-34 during execution of CLRC INTM 6-34 factors 6-33 minimum latency 6-33 LDP instruction 8-82

local data memory 4-5 off-chip 4-8 on-chip 4-8 logic instructions AND 8-33 CMPL (complement/NOT) 8-63 OR 8-128 XOR (exclusive OR) 8-192 logic phase of CPU cycle D-10 long immediate addressing 7-2 LPH instruction 8-84 LST instruction 8-86 LT instruction 8-90 LTA instruction 8-92 LTD instruction 8-94 LTP instruction 8-97 LTS instruction 8-99

# Ν

MAC instruction 8-101 MACD instruction 8-105 MAR instruction 8-110 memory address map, data page 0, 4-7 buses 4-2 configuration global data memory 4-9 to 4-10 local data 4-8 off-chip local data memory 4-8 on-chip local data memory 4-8 data page pointer (DP) 3-16 dual-access RAM 2-5 configuration, 'C203, 4-3 global data memory 4-9 to 4-10 address generation 4-11 local data 4-5 to 4-8 on-chip, advantages 4-2 organization 2-5, 4-2 program 4-3 to 4-4 configuration, 'C203, 4-3 program memory address generation logic 5-2 address sources 5-3 ROM, configuration, 'C209, 4-4 segments 4-2 single-access RAM 2-6 configuration, 'C209, 4-4, 4-8

total address range 4-1 memory instructions block move from data memory to data memory (BLDD) 8-48 block move from program memory to data memory (BLPD) 8-53 move data after add PREG to accumulator, load TREG, and multiply (MACD) 8-105 move data to next higher address in data memory (DMOV) 8-65 move data, load TREG, and add PREG to accumulator (LTD) 8-94 store long immediate value to data memory (SPLK) 8-164 table read (TBLR) 8-185 table write (TBLW) 8-188 transfer data from data memory to I/O space (OUT) 8-131 transfer data from I/O space to data memory (IN) 8-68 transfer word from data memory to program memory (TBLW) 8-188 transfer word from program memory to data memory (TBLR) 8-185 microstack (MSTACK) 5-6 MPY instruction 8-112 MPYA instruction 8-115 MPYS instruction 8-117 MPYU instruction 8-119 MSTACK (microstack) 5-6 multiplication section of CPU 3-5 multiplier description 3-5 introduction 2-9 multiply instructions multiply (include load to TREG) and accumulate previous product (MAC) 8-101 multiply (include load to TREG), accumulate previous product, and move data (MACD) 8-105 multiply (MPY) 8-112 multiply and accumulate previous product (MPYA) 8-115 multiply and subtract previous product (MPYS) 8-117 multiply unsigned (MPYU) 8-119 square specified value after accumulating previous product (SQRA) 8-167 square specified value after subtracting previous product from accumulator (SQRS) 8-169

PRELIMINARY

### Ν

NEG instruction 8-121 next auxiliary register 7-11 next program address register (NPAR) definition D-11 shown in figure 5-2 NMI instruction 8-123 vector location, 'C203, 6-10 NMI interrupt, vector location, 'C203, 6-10 nonmaskable interrupts, external RS 6-37, 6-48 RS ('C209) 6-37, 6-48 NOP instruction 8-124 NORM instruction 8-125 NPAR (next program address register) definition D-11 shown in figure 5-2

# 0

off-chip memory, configuration, local data 4-8 on-chip memory advantages 4-2 configuration 4-8 on-chip peripherals, overview 2-11 on-chip RAM dual-access 2-5 configuration, 'C203, 4-3 single-access 2-6 configuration, 'C209, 4-4, 4-8 on-chip ROM B-1 factory-masked, configuration, 'C209, 4-4 opcode format direct addressing 7-5 immediate addressing 7-2 indirect addressing 7-12 OR instruction 8-128 OUT instruction 8-131 output modes external count C-20 signal event C-20 output shifter 3-11 OV (overflow flag bit) 3-16

overflow in accumulator detecting (OV bit) 3-16 enabling/disabling overflow mode (OVM bit) 3-17 overflow mode bit (OVM) 3-17 effects on accumulator 3-10 overview, TMS320 family 1-2

### Ρ

PAB (program address bus) 2-4 used in program-memory address generation 5-3 PAC instruction 8-133 pages of data memory, figure 7-4 PAL C-21, C-22, C-24 PAR (program address register) definition D-12 shown in figure 5-2 PARITY ENABLE bit 6-17, 6-19 PC (program counter) 5-3 description 5-3 loading 5-4 shown in figure 5-2 peripherals, on-chip, overview 2-11 pipeline, operation 5-7 PM (product shift mode bits) 3-17 POP instruction 8-134 pop operation (diagram) 5-6 POPD instruction 8-136 power, lowering requirements 6-51 power-down mode 6-51 PRDB (program read bus) 2-4 PREG (product register) 3-6 PREG instructions add PREG to accumulator (APAC) 8-36 add PREG to accumulator and load TREG (LTA) 8-92 add PREG to accumulator and multiply (MPYA) 8-115 add PREG to accumulator and square specified value (SQRA) 8-167 add PREG to accumulator, load TREG, and move data (LTD) 8-94 add PREG to accumulator, load TREG, and multiply (MAC) 8-101 add PREG to accumulator, load TREG, multiply, and move data (MACD) 8-105

Index-9

load high bits of PREG (LPH) 8-84 PREG instructions (continued) set PREG output shift mode (SPM) 8-166 store high word of PREG to data memory (SPH) 8-160 store low word of PREG to data memory (SPL) 8-162 store PREG to accumulator (PAC instruction) 8-133 store PREG to accumulator and load TREG (LTP) 8-97 subtract PREG from accumulator (SPAC) 8-159 subtract PREG from accumulator and load TREG (LTS) 8-99 subtract PREG from accumulator and multiply (MPYS) 8-117 subtract PREG from accumulator and square specified value (SQRS) 8-169 product register (PREG) 3-6 product shift mode bits (PM) 3-17 product shift modes 3-7 product shifter 3-6 program address bus (PAB) 2-4 used in program-memory address generation 5-3 program address register (PAR) definition D-12 shown in figure 5-2 program control 2-10 interrupts 6-9 to 6-47 power-down mode 6-51 program control features address generation, program memory 5-2 branch instructions conditional 5-11 unconditional 5-8 call instructions conditional 5-12 unconditional 5-8 conditional instructions 5-10 to 5-13 conditions that may be tested 5-10 to 5-13 stabilization of conditions 5-11 to 5-13 using multiple conditions 5-10 pipeline operation 5-7 program counter (PC) 5-3 loading 5-4 repeating a single instruction 5-14 return instructions conditional 5-12

unconditional 5-9 program control features (continued) stack 5-4 status registers ST0 and ST1, 3-15 bits 3-15 program counter (PC) 5-3 description 5-3 loading 5-4 shown in figure 5-2 program memory 4-3 address generation logic 5-2 microstack (MSTACK) 5-6 program counter (PC) 5-3 stack 5-4 address sources 5-3 configuration, 'C203, 4-3 program read bus (PRDB) 2-4 program-address generation (diagram) 5-2 protocol, bus, in emulator system C-4 PSHD instruction 8-138 PUSH instruction 8-140 push operation (diagram) 5-5

### R

RAM dual-access on-chip 2-5 configuration, 'C203, 4-3 single-access on-chip 2-6 configuration, 'C209, 4-4, 4-8 registers auxiliary registers current auxiliary register 7-12 introduction 2-9 auxiliary registers (AR0-AR7) current auxiliary register 7-9 next auxiliary register 7-11 interrupt flag register (IFR) 6-16 to 6-58 interrupt mask register (IMR) 6-18 to 6-58 mapped to data page 0, 4-7 SCInCCR (communication control) 6-40, 6-42, 6-44, 6-45, 6-46 status registers ST0 and ST1, 3-15 system control (SYSCR) 6-5 system interrupt vector register (SYSIVR) 6-8 system status (SYSSR) 6-6 repeat (RPT) instruction description 8-145 introduction 5-14

Index-10

repeat counter (RPTC) 5-14 repeating a single instruction 5-14 reset 6-37, 6-48 'C203 (RS), effects 6-39 to 6-45, 6-49 to 6-52 'C209 (RS or RS), effects 6-39 to 6-45, 6-49 to 6-52 effects 6-39 to 6-45, 6-49 to 6-52 priority, 'C203, 6-10 vector location, 'C203, 6-10 RET instruction 8-141 RETC instruction 8-142 return instructions conditional, overview 5-12 return conditionally from subroutine (RETC) 8-142 return unconditionally from subroutine (RET) 8-141 unconditional, overview 5-9 ROL instruction 8-143 ROM configuration, 'C209, 4-4 customized B-1 to B-4 ROM codes, submitting to Texas Instruments B-1 to B-4 ROR instruction 8-144 RPT instruction 8-145 RPTC (repeat counter) 5-14 RS 6-37, 6-48 effects 6-39 to 6-45, 6-49 to 6-52 priority, 'C203, 6-10 vector location, 'C203, 6-10 RS ('C209) 6-37, 6-48 run/stop operation C-10 RUNB, debugger command C-20, C-21, C-22, C-23, C-24 RUNB ENABLE, input C-22

### S

SACH instruction 8-147 SACL instruction 8-149 SAR instruction 8-151 SARAM 2-6 configuration, 'C209, 4-4, 4-8 SARAM (single-access RAM), definition D-14 SBRK instruction 8-153 scaling shifters input shifter 3-3 introduction 2-8 output shifter 3-11 product shifter 3-6 product shift modes 3-7 scan path linkers C-16 secondary JTAG scan chain to an SPL C-17 suggested timings C-22 usage C-16 scan paths, TBC emulation connections for JTAG scan paths C-25 SCInCCR register (communication control) 6-40, 6-42, 6-44, 6-45, 6-46 serial-scan emulation 2-11 SETC instruction 8-154 SFL instruction 8-156 SFR instruction 8-157 shifters input shifter 3-3 introduction 2-8 output shifter 3-11 product shifter 3-6 product shift modes 3-7 short immediate addressing 7-2 signal descriptions 14-pin header C-3 signals buffered C-10 buffering for emulator connections C-10 to C-13 description 14-pin header C-3 timing C-6 sign-extension mode bit (SXM) definition 3-17 effect on CALU (central arithmetic logic unit) 3-9 effect on input shifter 3-4 single-access RAM 2-6 configuration, 'C209, 4-4, 4-8 single-access RAM (SARAM), definition D-14 slave devices C-4 SPAC instruction 8-159 SPH instruction 8-160 SPL instruction 8-162 SPLK instruction 8-164 SPM instruction 8-166 SQRA instruction 8-167 SQRS instruction 8-169 SST instruction 8-171

stack 5-4 overflow. ISRs within ISRs 6-32 pop top of stack to data memory (POPD instruction) 8-136 pop top of stack to low accumulator bits (POP instruction) 8-134 push data memory value onto stack (PSHD instruction) 8-138 push low accumulator bits onto stack (PUSH instruction) 8-140 status registers ST0 and ST1 bits 3-15 clear control bit (CLRC instruction) 8-61 introduction 3-15 load (LST instruction) 8-86 load data page pointer (LDP instruction) 8-82 modify auxiliary register pointer (MAR instruction) 8-110 set control bit (SETC instruction) 8-154 set product shift mode (SPM instruction) 8-166 store (SST instruction) 8-171 stop bits (1 or 2) 6-17, 6-19, 6-40, 6-41, 6-42, 6-43, 6-44, 6-45, 6-46, 6-47 SUB instruction 8-173 SUBB instruction 8-177 SUBC instruction 8-179 SUBS instruction 8-181 SUBT instruction 8-183 SXM (sign-extension mode bit) definition 3-17 effect on CALU (central arithmetic logic unit) 3-9 effect on input shifter 3-4 system control register (SYSCR) 6-5 system interrupt vector register (SYSIVR) 6-8 system status register (SYSSR) 6-6

# Т

target cable C-14 target system, connection to emulator C-1 to C-25 target system emulator connector, designing C-2 target-system clock C-12 TBLR instruction 8-185 TBLW instruction 8-188 TC (test/control flag bit) 3-17 response to accumulator event 3-10 response to auxiliary register compare 3-14 TCK signal C-2, C-3, C-4, C-6, C-7, C-13, C-17, C-18, C-25 TDI signal C-2, C-3, C-4, C-5, C-6, C-7, C-8, C-13, C-18 TDO signal C-4, C-5, C-8, C-19, C-25 temporary register (TREG) 3-6 test bus controller C-22, C-24 test clock C-12 diagram C-12 test/control flag bit (TC) 3-17 response to accumulator event 3-10 response to auxiliary register compare 3-14 timing calculations C-7 to C-9, C-18 to C-26 TMS signal C-2, C-3, C-4, C-5, C-6, C-7, C-8, C-13, C-17, C-18, C-19, C-25 TMS/TDI inputs C-4 TMS320 family 1-2 to 1-6 advantages 1-2 development 1-2 history 1-2 overview 1-2 TMS320 ROM code procedure, flow chart B-2 TMS320C1x/C2x/C2xx/C5x instruction set comparisons A-1 to A-36 TMS320C24x, features CPU 1-7 emulation 1-8 event manager 1-8 instruction set 1-7 memory 1-7 power 1-7 program control 1-7 speed 1-8 TMS320C2xx, features, emulation 2-11 TRAP instruction 8-191 vector location, 'C203, 6-10 TREG (temporary register) 3-6 **TREG** instructions load accumulator using shift specified by TREG (LACT) 8-77 load TREG (LT) 8-90 load TREG and add PREG to accumulator (LTA) 8-92 load TREG and store PREG to accumulator (LTP) 8-97

PRELIMINARY

#### Index

TREG instructions (continued)

load TREG and subtract PREG from accumulator (LTS) 8-99

load TREG, add PREG to accumulator, and move data (LTD) 8-94

load TREG, add PREG to accumulator, and multiply (MAC) 8-101

load TREG, add PREG to accumulator, multiply, and move data (MACD) 8-105

TRST signal C-2, C-3, C-6, C-7, C-13, C-17, C-18, C-25



unconditional instructions unconditional branch 5-8 unconditional call 5-8 unconditional return 5-9

## W

wait states, definition D-16



XF bit (XF pin status bit) 3-17 XOR instruction 8-192



ZALR instruction 8-195

#### Index

#### **IMPORTANT NOTICE**

Texas Instruments (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 the specifications applicable at the time of sale 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.

Certain applications using semiconductor products may involve potential risks of death, personal injury, or severe property or environmental damage ("Critical Applications").

TI SEMICONDUCTOR PRODUCTS ARE NOT DESIGNED, INTENDED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT APPLICATIONS, DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS.

Inclusion of TI products in such applications is understood to be fully at the risk of the customer. Use of TI products in such applications requires the written approval of an appropriate TI officer. Questions concerning potential risk applications should be directed to TI through a local SC sales office.

In order to minimize risks associated with the customer's applications, adequate design and operating safeguards should be provided by the customer to minimize inherent or procedural hazards.

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 © 1996, Texas Instruments Incorporated