



# User's Guide

**Digital Signal Processing Products** 

1991

## TMS320C4x User's Guide

2564090-9721 revision A May 1991



#### **IMPORTANT NOTICE**

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

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

TI assumes no liability for TI applications assistance, customer product design, software performance, or infringement of patents or services described herein. Nor does TI warrant or represent that 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 © 1991, Texas Instruments Incorporated

### Preface

## **Read This First**

The purpose of this user's guide is to serve as a reference book for the TMS320C40 and TMS320C40-40 digital signal processors. Throughout the book, all references to the TMS320C40 apply to the TMS320C40-40 as well, unless an exception is noted. This document provides information to assist managers and hardware/software engineers in application development.

#### How to Use This Manual

This document contains the following chapters:

Chapter 1 Introduction

A general description of the TMS320C40, its key features, and typical applications.

Chapter 2 Architectural Overview Functional block diagrams. TMS320C40 design description, hardware components, and device operation. Instruction set summary.

Chapter 3 CPU Registers, Memory, and Cache Description of the registers in the CPU primary register file and expansion register file. Memory maps. Instruction cache architecture, algorithm, and control bits.

#### Chapter 4 Data Formats and Floating-Point Operation Description of signed and unsigned integer and floating-point formats. Discussion of floating-point multiplication, addition, subtraction, normalization, rounding, conversions, and reciprocals.

#### Chapter 5 Addressing

Addressing types. Operation, encoding, and implementation of addressing modes. Format descriptions. Circular and bit-reversed addressing. System stack management.

#### Chapter 6 Program Flow Control

Software control of program flow using repeat modes, different types of branching, traps, interrupts, and interlocked operations. Reset operation, including resulting values in registers and on pins.

#### Chapter 7 External Bus Operation

Discussion of the two 80-pin local and global memory interfaces. Programmable wait-states. Memory access timing. Signal group control. Interlocked instructions. Interrupt acknowledge timing.

#### Chapter 8 Communication Ports

Description of the six, bidirectional, 160-megabit-per-second (at 40-ns cycle time) communication ports designed for sharing tasks between processors. Memory maps of the ports and their registers. Port operation and coordination of port activity with CPU and DMA coprocessors.

#### Chapter 9 DMA Coprocessors and 'C40 Timers

DMA coprocessor operation. Description of coprocessor registers (channel control, channel address, index, transfer count, and link pointer). Use in unified and split mode. Priority and CPU/DMA arbitration. Autoinitialization and interrupts. Operation of the 'C40 timers; their registers (global control, timer counter, and period).

#### Chapter 10 Pipeline Operation

Discussion of 'C40 pipeline operations. This includes pipeline conflicts and methods for resolving these. Clocking of memory accesses.

#### Chapter 11 Assembly Language Instructions

Functional listing of instructions. Condition code definitions (for conditional instructions such as branch conditional). Alphabetized individual instruction descriptions with examples.

#### Chapter 12 Software Applications

Software application examples for using various TMS320C40 instruction-set and programming features. Code listings enhance explanations.

#### **Chapter 13 Hardware Applications**

Hardware design techniques and application examples for interfacing to memories, peripherals, or other microcomputers/microprocessors. Code listings, schematics, and timing diagrams facilitate explanations.

#### Chapter 14 TMS320C4x Signal Descriptions and Electrical Characteristics

Pin locations and pin descriptions. 'C40 dimensions and package description. Electrical characteristics. Signal timing and characteristics.

#### Appendix A TMS320C40 Sockets

Two sockets available for the TMS320C40.

#### Appendix B XDS510 Design Considerations

Considerations for designing your TMS320C40 target system for use with the XDS510 emulator.

#### References

The publications in the following reference list contain useful information regarding functions, operations, and applications of digital signal processing. These books also provide other references to many useful technical papers. The reference list is organized into categories of general DSP, speech, image processing, and digital control theory, and is alphabetized by author.

#### **General Digital Signal Processing:**

Antoniou, Andreas, *Digital Filters: Analysis and Design*. New York, NY: McGraw-Hill Company, Inc., 1979.

Brigham, E. Oran, *The Fast Fourier Transform*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1974.

Burrus, C.S., and Parks, T.W., *DFT/FFT and Convolution Algorithms*. New York, NY: John Wiley and Sons, Inc., 1984.

*Digital Signal Processing Applications with the TMS320 Family.* Texas Instruments, 1986; Prentice-Hall, Inc., 1987.

Gold, Bernard, and Rader, C.M., *Digital Processing of Signals*. New York, NY: McGraw-Hill Company, Inc., 1969.

Hamming, R.W., *Digital Filters*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1977.

IEEE ASSP DSP Committee (Editor), *Programs for Digital Signal Processing*. New York, NY: IEEE Press, 1979.

Jackson, Leland B., *Digital Filters and Signal Processing*. Hingham, MA: Kluwer Academic Publishers, 1986.

Jones, D.L., and Parks, T.W., *A Digital Signal Processing Laboratory Using the TMS32010*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1987.

Lim, Jae, and Oppenheim, Alan V. (Editors), *Advanced Topics in Signal Processing*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1988.

Morris, L. Robert, *Digital Signal Processing Software*. Ottawa, Canada: Carleton University, 1983.

Meyer, Riamund and Schwartz, Karl, FFT Implementation on DSP Chips — Theory and Practice, Proceedings of ICAASP 90, vol. 3, 1990

Oppenheim, Alan V. (Editor), *Applications of Digital Signal Process-ing.* Englewood Cliffs, NJ: Prentice-Hall, Inc., 1978.

Oppenheim, Alan V., and Schafer, R.W., *Digital Signal Processing*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1975.

Oppenheim, Alan V., and Willsky, A.N., with Young, I.T., *Signals and Systems*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1983.

Parks, T.W., and Burrus, C.S., *Digital Filter Design*. New York, NY: John Wiley and Sons, Inc., 1987.

Rabiner, Lawrence R., and Gold, Bernard, *Theory and Application of Digital Signal Processing*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1975.

Sorensen, Henrik V., Jones, Douglas, Heideman, M.T., and Burris, C.S., *Real-Valued Fast Fourier Transform Algorithms,* IEEE Transactions on Acoustics, Speech, and Signal Processing, vol. ASSP–35, no. 6, June 1987.

Treichler, J.R., Johnson, Jr., C.R., and Larimore, M.G., *Theory and Design of Adaptive Filters*. New York, NY: John Wiley and Sons, Inc., 1987.

#### **G** Speech:

Gray, A.H., and Markel, J.D., *Linear Prediction of Speech*. New York, NY: Springer-Verlag, 1976.

Jayant, N.S., and Noll, Peter, *Digital Coding of Waveforms*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1984.

Papamichalis, Panos, *Practical Approaches to Speech Coding*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1987.

Rabiner, Lawrence R., and Schafer, R.W., *Digital Processing of Speech Signals*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1978.

#### Image Processing:

Andrews, H.C., and Hunt, B.R., *Digital Image Restoration*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1977.

Gonzales, Rafael C., and Wintz, Paul, *Digital Image Processing*. Reading, MA: Addison-Wesley Publishing Company, Inc., 1977.

Pratt, William K., *Digital Image Processing*. New York, NY: John Wiley and Sons, 1978.

#### **Digital Control Theory:**

Jacquot, R., *Modern Digital Control Systems*. New York, NY: Marcel Dekker, Inc., 1981.

Katz, P., *Digital Control Using Microprocessors*. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1981.

Kuo, B.C., *Digital Control Systems*. New York, NY: Holt, Reinholt and Winston, Inc., 1980.

Moroney, P., *Issues in the Implementation of Digital Feedback Compensators.* Cambridge, MA: The MIT Press, 1983.

Phillips, C., and Nagle, H., *Digital Control System Analysis and De*sign. Englewood Cliffs, NJ: Prentice-Hall, Inc., 1984.

#### Style and Symbol Conventions

This document uses the following conventions:

Program listings, program examples, interactive displays, file names, and symbol names are shown in a special font. Examples use a bold version of the special font for emphasis. Here is a sample program listing:

| 0011 | 0005 | 0001 | .field | 1, | 2 |
|------|------|------|--------|----|---|
| 0012 | 0005 | 0003 | .field | з, | 4 |
| 0013 | 0005 | 0006 | .field | 6, | 3 |
| 0014 | 0006 |      | .even  |    |   |

In syntax descriptions, the instruction, command, or directive is in a **bold face font** and parameters are in *italics*. Portions of a syntax that are in **bold face** should be entered as shown; portions of a syntax that are in *italics* describe the *type* of information that should be entered. Here is an example of an instruction:

#### CMPF3 src2, src3

Note: Although the instruction mnemonic (CMPF3 in this example) is in capital letters, the 'C40 assembler **is not case sensitive** — it can assemble mnemonics entered in either upper or lower case.

**CMPF3** is the instruction mnemonic. This instruction has two parameters, indicated by *src2* and *src3*.

Square brackets ([and]) identify an optional parameter. If you use an optional parameter, you must specify the information within the brackets; however, you don't enter the brackets themselves. Here's an example of an instruction that has an optional parameter:

#### LDP src [,DP]

The **LDP** instruction is shown with two parameters; one is optional. The first parameter, *src*, is required. The second parameter, *DP*, is optional. As this syntax shows, if you use the optional second parameter, you must precede it with a comma.

Braces ( { and } ) indicate a list. The symbol | (read as or) separates items within the list. Here's an example of a list:

{ \* | \*+ | \*- }

This provides three choices: \*, \*+, or \*-.

Unless the list is enclosed in square brackets, you must choose one item from the list.

The following is the format for a varying number of parameters. For example, the .byte directive can have up to 100 parameters. The syntax for this directive is

**.byte** value<sub>1</sub> [, ... , value<sub>n</sub>]

This syntax shows that .byte must have at least one value parameter, but you have the option of supplying additional value parameters separated by commas.

#### Information About Cautions and Warnings

A caution describes a situation that could potentially damage your software or equipment.



A warning describes a situation that could potentially cause harm to you.



Please read each caution or warning carefully. The information is provided for your protection.

#### Trademarks

ABEL is a trademark of the Data I/O Corporation.

SPOX is a trademark of Spectron Microsystems, Inc.



## Contents

| 1 | Intro | duction  |                                                                 |
|---|-------|----------|-----------------------------------------------------------------|
|   | 1.1   | The T    | MS320 Family                                                    |
|   | 1.2   |          | el Processing                                                   |
|   | 1.3   |          | 20C4x Features                                                  |
|   |       | 1.3.1    | TMS320C40 Device Key Features 1-4                               |
|   |       | 1.3.2    | Communication Port Benefits 1-7                                 |
|   |       | 1.3.3    | DMA Coprocessor Benefits 1-8                                    |
|   |       | 1.3.4    | TMS320C40 Parallel Processing Development Tools<br>Key Features |
|   | 1.4   | Applica  | ations 1-11                                                     |
| 2 | Archi | itectura | l Overview                                                      |
|   | 2.1   | Centra   | Il Processing Unit (CPU)                                        |
|   |       | 2.1.1    | Multiplier 2-4                                                  |
|   |       | 2.1.2    | Arithmetic Logic Unit (ALU) 2-4                                 |
|   |       | 2.1.3    | Auxiliary Register Arithmetic Units (ARAUs) 2-6                 |
|   |       | 2.1.4    | CPU Primary Register File 2-6                                   |
|   |       | 2.1.5    | CPU Expansion Register File 2-9                                 |
|   | 2.2   | Memo     | ry Organization 2-10                                            |
|   |       | 2.2.1    | RAM, ROM, and Cache 2-10                                        |
|   |       | 2.2.2    | Memory Maps                                                     |
|   |       | 2.2.3    | Memory Addressing Modes 2-15                                    |
|   | 2.3   | Instruc  | tion Set Summary                                                |
|   | 2.4   |          | al Bus Operation                                                |
|   | 2.5   |          | al Bus Operation                                                |
|   |       | 2.5.1    | Interrupts                                                      |
|   |       | 2.5.2    | Interlocked Instructions                                        |
|   | 2.6   | Periph   | erals                                                           |
|   |       | 2.6.1    | Communication Ports 2-29                                        |
|   |       | 2.6.2    | Direct Memory Access (DMA) 2-29                                 |
|   |       | 2.6.3    | Timers                                                          |
| 3 | CPU   | Registe  | ers, Memory, and Cache                                          |
|   | 3.1   |          | Primary Register File                                           |

|   |      | 3.1.1    | Extended-Precision Registers (R0–R11)                                           | 3-4    |
|---|------|----------|---------------------------------------------------------------------------------|--------|
|   |      | 3.1.2    | Auxiliary Registers (AR0–AR7)                                                   | 3-5    |
|   |      | 3.1.3    | Data-Page Pointer (DP)                                                          | 3-5    |
|   |      | 3.1.4    | Index Registers (IR0, IR1)                                                      | 3-5    |
|   |      | 3.1.5    | Block-Size Register (BK)                                                        | 3-5    |
|   |      | 3.1.6    | System Stack Pointer (SP)                                                       | 3-5    |
|   |      | 3.1.7    | Status Register (ST)                                                            | 3-5    |
|   |      | 3.1.8    | DMA Coprocessor Interrupt Enable Register (DIE)                                 | 3-8    |
|   |      | 3.1.9    | CPU Internal Interrupt Enable Register (IIE)                                    | . 3-10 |
|   |      | 3.1.10   | IIOF Flag Register (IIF) Controls External Pins IIOF(3 – 0),<br>Timer/DMA Flags | . 3-12 |
|   |      | 3.1.11   | Block-Repeat (RS, RE) and Repeat-Count (RC) Registers                           | . 3-14 |
|   |      | 3.1.12   | Program Counter (PC)                                                            | . 3-14 |
|   |      | 3.1.13   | Reserved Bits and Compatibility                                                 | . 3-14 |
|   | 3.2  | CPU E    | xpansion Register File                                                          |        |
|   | 3.3  | RESET    | Vector Mapping                                                                  | . 3-17 |
|   | 3.4  | Memor    | у                                                                               | . 3-18 |
|   |      | 3.4.1    | Overall Memory Map                                                              | . 3-19 |
|   |      | 3.4.2    | Peripheral Bus Memory Map                                                       | . 3-20 |
|   | 3.5  | Instruct | tion Cache Architecture                                                         | . 3-25 |
|   |      | 3.5.1    | Cache Algorithm                                                                 | . 3-27 |
|   |      | 3.5.2    | Cache and System Memory                                                         | . 3-28 |
|   |      | 3.5.3    | Cache Control Bits                                                              | . 3-29 |
| 4 | Data | Formate  | s and Floating-Point Operation                                                  | 4-1    |
|   | 4.1  | Signed   | Integer Formats                                                                 | 4-3    |
|   |      | 4.1.1    | Short Integer Format                                                            |        |
|   |      | 4.1.2    | Single-Precision Integer Format                                                 | 4-3    |
|   | 4.2  | Unsign   | ed-Integer Formats                                                              | 4-4    |
|   |      | 4.2.1    | Short Unsigned-Integer Format                                                   | 4-4    |
|   |      | 4.2.2    | Single-Precision Unsigned-Integer Format                                        | 4-4    |
|   | 4.3  | Floatin  | g-Point Formats                                                                 |        |
|   |      | 4.3.1    | Short Floating-Point Format                                                     | 4-6    |
|   |      | 4.3.2    | Single-Precision Floating-Point Format                                          |        |
|   |      | 4.3.3    | Extended-Precision Floating-Point Format                                        | 4-8    |
|   |      | 4.3.4    | Conversion Between Floating-Point Formats                                       | 4-9    |
|   | 4.4  | Floatin  | g-Point Conversions (IEEE Std. 754/'C4x)                                        | . 4-11 |
|   |      | 4.4.1    | Converting IEEE Format to Twos-Complement<br>Floating-Point Format              |        |
|   |      | 4.4.2    | Converting Twos-Complement Floating-Point Format to IEEE Format                 | . 4-13 |

|   | 4.5   | Floating | g-Point Multiplication                            | 4-15  |
|---|-------|----------|---------------------------------------------------|-------|
|   | 4.6   | Floating | g-Point Addition and Subtraction                  | 4-20  |
|   | 4.7   | Normal   | ization (NORM Instruction)                        | 4-24  |
|   | 4.8   |          | ng (RND Instruction)                              |       |
|   | 4.9   |          | g-Point-to-Integer Conversion (FIX Instruction)   |       |
|   | 4.10  |          | -to-Floating-Point Conversion (FLOAT Instruction) |       |
|   | 4.11  | Recipro  | ocal (RCPF Instruction)                           |       |
|   |       | 4.11.1   | ····F·································            |       |
|   | 4.12  | Recipro  | cal Square Root (RSQRF Instruction)               | 4-33  |
|   |       |          | Reciprocal Square Root Algorithm                  |       |
|   |       | 4.12.2   | Background on the Reciprocal Square Root          | 4-35  |
| 5 | Addre | essing . |                                                   | . 5-1 |
|   | 5.1   | Types of | of Addressing                                     | . 5-2 |
|   |       | 5.1.1    | Register Addressing                               | . 5-3 |
|   |       | 5.1.2    | Direct Addressing                                 | . 5-4 |
|   |       | 5.1.3    | Indirect Addressing                               | . 5-5 |
|   |       | 5.1.4    | Immediate Addressing                              | 5-17  |
|   |       | 5.1.5    | PC-Relative Addressing                            | 5-17  |
|   | 5.2   | Groups   | s of Addressing Modes                             | 5-19  |
|   |       | 5.2.1    | General Addressing Modes                          | 5-19  |
|   |       | 5.2.2    | Three-Operand Addressing Modes                    | 5-20  |
|   |       | 5.2.3    | Parallel Addressing Modes                         | 5-23  |
|   |       | 5.2.4    | Conditional-Branch Addressing Modes               | 5-24  |
|   | 5.3   | Circula  | r Addressing                                      | 5-25  |
|   | 5.4   | Bit-Rev  | versed Addressing                                 | 5-30  |
|   | 5.5   | System   | and User Stack Management                         | 5-31  |
|   |       | 5.5.1    | Stacks                                            | 5-32  |
|   |       | 5.5.2    | Queues and Dequeues                               | 5-33  |
| 6 | Progr | am Flov  | w Control                                         | . 6-1 |
|   | 6.1   | Repeat   | : Modes                                           | . 6-2 |
|   |       | 6.1.1    |                                                   |       |
|   |       | 6.1.2    | RPTB and RPTBD Initialization                     | . 6-3 |
|   |       | 6.1.3    | RPTS Initialization                               | . 6-4 |
|   |       | 6.1.4    | Repeat-Mode Operation                             | . 6-4 |
|   | 6.2   | Delaye   | d Branches                                        | . 6-7 |
|   | 6.3   | Calls, T | raps, Branches, Jumps, and Returns                | . 6-9 |
|   | 6.4   | Unifying | g Traps and Interrupts                            | 6-11  |
|   |       | 6.4.1    | Initialization                                    | 6-11  |
|   |       | 6.4.2    | Operation                                         | 6-11  |

|   | 6.5<br>6.6<br>6.7 | Reset C<br>Interrup<br>6.7.1 | ked Operations       6-13         operation       6-18         ts       6-23         Interrupt Control Bits       6-24         Prioritization and Control       6-24 |
|---|-------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 |                   |                              | Operation                                                                                                                                                            |
|   | 7.1               | •                            | and Local) Memory Interface Control Signals                                                                                                                          |
|   | 7.2               | •                            | Interface Control Registers                                                                                                                                          |
|   | 7.3               |                              | he Global Memory Interface Registers                                                                                                                                 |
|   |                   |                              | Mapping Addresses to Strobes                                                                                                                                         |
|   | -                 |                              | Page Size Operation                                                                                                                                                  |
|   | 7.4               | -                            | nmable Wait States                                                                                                                                                   |
|   | 7.5               |                              | 7-17                                                                                                                                                                 |
|   | 7.6<br>7.7        |                              | nabled Signals to Control Signal Group                                                                                                                               |
|   | 7.7<br>7.8        |                              | ked-Instructions Definition and Bus Timing       7-39         ming       7-47                                                                                        |
|   | 7.0               | IACK II                      | ming                                                                                                                                                                 |
| 8 | Comn              | nunicati                     | on Ports                                                                                                                                                             |
|   | 8.1               | Introduc                     | stion                                                                                                                                                                |
|   | 8.2               | Commu                        | nication Port Features                                                                                                                                               |
|   | 8.3               | Operatio                     | onal Overview                                                                                                                                                        |
|   | 8.4               | Commu                        | nication Port Memory Map and Registers                                                                                                                               |
|   |                   | 8.4.1                        | Communication Port Control Registers (CPCRs) 8-9                                                                                                                     |
|   |                   | 8.4.2                        | Input Port Register                                                                                                                                                  |
|   |                   | 8.4.3                        | Output Port Register 8-9                                                                                                                                             |
|   | 8.5               | Commu                        | nication Port Operation                                                                                                                                              |
|   |                   | 8.5.1                        | Port Arbitration Units (PAUs)                                                                                                                                        |
|   |                   | 8.5.2                        | Module Reset                                                                                                                                                         |
|   |                   | 8.5.3                        | Halting of Input and Output FIFOs 8-15                                                                                                                               |
|   | 8.6               | Coordin                      | ating Communication Port Activity With CPU and DMA                                                                                                                   |
|   | 8.7               | •                            | nication Port Timing                                                                                                                                                 |
|   | 0.7               |                              | Timing Table and Figures                                                                                                                                             |
|   |                   |                              | Synchronizer Timing                                                                                                                                                  |
| • | <b>B</b> 144      |                              |                                                                                                                                                                      |
| 9 |                   | -                            | essor and 'C40 Timers                                                                                                                                                |
|   | 9.1               |                              | 22 stion                                                                                                                                                             |
|   | 9.2               |                              | oprocessor Functional Description                                                                                                                                    |
|   | 9.3               |                              | oprocessor Registers                                                                                                                                                 |
|   |                   | 9.3.1                        | DMA Channel Control Register                                                                                                                                         |
|   |                   | 9.3.2                        | DMA Channel Address and Index Registers                                                                                                                              |

|    |        | 9.3.3   | DMA Channel Transfer-Counter and Auxiliary-Transfer-Count Registers | 9-18   |
|----|--------|---------|---------------------------------------------------------------------|--------|
|    |        | 9.3.4   | DMA-Channel Link-Pointer and Auxiliary-Link-Pointer<br>Registers    | 0_10   |
|    | 9.4    |         | hannels in Unified and Split Modes                                  |        |
|    | 9.5    |         | oprocessor Internal Priority Schemes                                |        |
|    | 0.0    | 9.5.1   | Fixed Priority Scheme                                               |        |
|    |        | 9.5.2   | Rotating Priority Scheme                                            |        |
|    |        | 9.5.3   | Split Mode and DMA Channel Arbitration                              |        |
|    | 9.6    |         | nd DMA Coprocessor Arbitration                                      |        |
|    | 9.7    |         | ransfer Modes                                                       |        |
|    | •••    | 9.7.1   | Running Under TRANSFER MODE = 002                                   |        |
|    |        | 9.7.2   | Running Under TRANSFER MODE = $01_2$                                |        |
|    |        | 9.7.3   | Running Under TRANSFER MODE = 102                                   |        |
|    |        | 9.7.4   | Running Under TRANSFER MODE = 112                                   |        |
|    | 9.8    | Autoini | tialization                                                         |        |
|    |        | 9.8.1   | Fun With Link Pointers                                              | 9-38   |
|    | 9.9    | DMA C   | oprocessor and Interrupts                                           | 9-40   |
|    |        | 9.9.1   | Interrupts and Synchronization of DMA Channels                      | 9-41   |
|    | 9.10   | TMS32   | 0C40 Timers                                                         |        |
|    |        | 9.10.1  | Timer Global-Control Register                                       | 9-47   |
|    |        | 9.10.2  | Timer Period and Counter Registers                                  | 9-50   |
|    |        | 9.10.3  | Timer Pulse Generation                                              | 9-50   |
|    |        | 9.10.4  | Timer Operation Modes                                               | 9-52   |
| 10 | Pipeli | ne Ope  | ration                                                              | 10-1   |
|    | 10.1   | Pipelin | e Structure                                                         | 10-2   |
|    | 10.2   | Pipelin | e Conflicts                                                         | 10-4   |
|    |        | 10.2.1  | Branch Conflicts                                                    | 10-4   |
|    |        | 10.2.2  | Register Conflicts                                                  | 10-8   |
|    |        | 10.2.3  | Memory Conflicts                                                    | 10-11  |
|    | 10.3   | Resolv  | ing Memory Conflicts                                                | 10-18  |
|    | 10.4   | Clockin | ng of Memory Accesses                                               | 10-20  |
|    |        | 10.4.1  | Program Fetches                                                     | 10-20  |
|    |        | 10.4.2  | Data Loads and Stores                                               | 10-21  |
| 11 | Assei  | nbly La | Inguage Instructions                                                | . 11-1 |
|    | 11.1   | Assem   | bly Language Instructions — Instruction Set                         |        |
|    |        | 11.1.1  | Load-and-Store Instructions                                         |        |
|    |        | 11.1.2  | Two-Operand Instructions                                            | . 11-4 |
|    |        | 11.1.3  | Three-Operand Instructions                                          | . 11-6 |

|    |       | 11.1.4  | Program Control Instructions                             |         |
|----|-------|---------|----------------------------------------------------------|---------|
|    |       | 11.1.5  | Interlocked Operations Instructions                      | 11-7    |
|    |       | 11.1.6  | Parallel Operations Instructions                         | 11-8    |
|    | 11.2  |         | on Codes and Flags                                       |         |
|    | 11.3  |         | al Instructions                                          |         |
|    |       | 11.3.1  | Symbols and Abbreviations                                |         |
|    |       | 11.3.2  | Optional Assembler Syntaxes                              |         |
|    |       | 11.3.3  | Individual Instruction Descriptions                      | . 11-17 |
| 12 | Softw | are App | lications                                                | 12-1    |
|    | 12.1  | Process | sor Initialization                                       | 12-3    |
|    |       | 12.1.1  | Reset Process                                            | 12-3    |
|    |       | 12.1.2  | Initialization                                           | 12-3    |
|    | 12.2  | Program | m Control                                                | 12-9    |
|    |       | 12.2.1  | Subroutines                                              | 12-9    |
|    |       | 12.2.2  | Software Stack                                           |         |
|    |       | 12.2.3  | Interrupt Service Routines                               | . 12-14 |
|    |       | 12.2.4  | Delayed Branches                                         | . 12-22 |
|    |       | 12.2.5  | Repeat Modes                                             |         |
|    |       | 12.2.6  | Computed GOTOs to Select Subroutines at Runtime          | . 12-27 |
|    | 12.3  | •       | and Arithmetic Operations                                |         |
|    |       | 12.3.1  | Bit Manipulation                                         | . 12-28 |
|    |       | 12.3.2  | Block Moves                                              |         |
|    |       | 12.3.3  | Byte and Half-Word Manipulation                          | . 12-30 |
|    |       | 12.3.4  | Bit-Reversed Addressing                                  | . 12-31 |
|    |       | 12.3.5  | Integer and Floating-Point Division                      | . 12-33 |
|    |       | 12.3.6  | Square Root                                              |         |
|    |       | 12.3.7  | Extended-Precision Arithmetic                            | . 12-41 |
|    |       | 12.3.8  | Floating-Point Format Conversion: IEEE to/from TMS320C40 | 12-12   |
|    | 12.4  | Applica | tion-Oriented Operations                                 |         |
|    | 16.7  | 12.4.1  | Companding                                               |         |
|    |       |         | FIR, IIR, and Adaptive Filters                           |         |
|    |       |         | Matrix-Vector Multiplication                             |         |
|    |       |         | Fast Fourier Transforms (FFT)                            |         |
|    |       | 12.4.5  | Lattice Filters                                          |         |
|    | 12.5  |         | mming Tips                                               |         |
|    | 12.0  |         | C-Callable Routines                                      |         |
|    |       | 12.5.2  | Hints for Optimizing Assembly Code                       |         |
|    | 12.6  |         | erals                                                    |         |
|    |       |         |                                                          |         |
|    |       |         |                                                          |         |

|    |      | 12.6.2   | Communication Ports                                            | 12-98  |
|----|------|----------|----------------------------------------------------------------|--------|
|    |      | 12.6.3   | Direct Memory Access                                           | 12-101 |
|    |      |          |                                                                |        |
| 13 |      |          | plications                                                     |        |
|    | 13.1 | •        | Configuration Options Overview                                 |        |
|    |      |          | Categories of Interfaces on the TMS320C40                      |        |
|    | 13.2 |          | bader Description and External ROM Interfacing                 |        |
|    |      | 13.2.1   | TMS320C40 Boot Loader Description/Operation                    |        |
|    |      | 13.2.2   | Boot Load Sequence                                             |        |
|    |      | 13.2.3   |                                                                |        |
|    |      | 13.2.4   | Communication Port Loading                                     |        |
|    |      | 13.2.5   | External ROM Interfacing to the TMS320C40                      |        |
|    |      | 13.2.6   | IIOF(3–1) Pin Loading                                          |        |
|    |      | 13.2.7   | TMS320C40 Boot Loader Source Program                           |        |
|    | 13.3 |          | and Local Bus Interface                                        |        |
|    |      | 13.3.1   | Zero Wait-State Interface to RAMs                              |        |
|    | 13.4 |          | ates and Ready Generation                                      |        |
|    |      | 13.4.1   | ORing of the Ready Signals (STRBx SWW = 10)                    |        |
|    |      | 13.4.2   |                                                                |        |
|    |      | 13.4.3   |                                                                |        |
|    |      | 13.4.4   | Ready Control Logic                                            | 13-30  |
|    |      | 13.4.5   | Example Circuit                                                | 13-31  |
|    |      | 13.4.6   | Page Switching Techniques                                      | 13-32  |
|    | 13.5 | Paralle  | I Processing Interfaces                                        | 13-37  |
|    |      | 13.5.1   | Message Broadcasting From One TMS320C40<br>to Many TMS320C40's | 13-37  |
|    |      | 13.5.2   | Shared Global Memory Interface With Fair Bus Arbitration       | 13-38  |
|    |      | 13.5.3   | Shared Bus Interface Overview                                  | 13-43  |
|    | 13.6 | Bus Art  | pitration                                                      | 13-48  |
|    |      | 13.6.1   | Arbitration Implementation                                     | 13-48  |
|    |      | 13.6.2   | Arbitration Alternatives                                       | 13-70  |
|    |      | 13.6.3   | Global Bus Arbitration and Transfer Timing                     | 13-70  |
|    |      | 13.6.4   | Arbitration Protocol Limitations                               |        |
|    | 13.7 | Reset S  | Signal Generation Control Function                             | 13-75  |
| 14 | TMS3 | 20C4x S  | Signal Descriptions and Electrical Characteristics             | . 14-1 |
|    | 14.1 |          | and Pin Assignments                                            |        |
|    | 14.2 | Signal I | Descriptions                                                   | . 14-7 |
|    | 14.3 |          | 0C4x Mechanical Data                                           |        |
|    | 14.4 |          | al Specifications                                              |        |
|    |      |          | Transition Levels                                              |        |

|     | 14.6 | Timing                                  | 15  |
|-----|------|-----------------------------------------|-----|
| A   | TMS3 | 20C4x Sockets                           | -1  |
|     | A.1  | Tool-Activated ZIF PGA Socket (TAZ) A   | -2  |
|     | A.2  | Handle-Actuated ZIF PGA Socket (HAZ) A  |     |
| в   | XDS5 | 10 Design Considerations B              | -1  |
|     | B.1  | Header and Header Signals B             | -2  |
|     | B.2  | Bus Protocol                            | -3  |
|     | B.3  | Cable Pod B                             | -4  |
|     | B.4  | Test Clock Generated in Target System B | -7  |
|     | B.5  | Multiprocessor Configuration            |     |
|     | B.6  | Emulation Timing Calculations B-        |     |
| Ind | ex   | Index                                   | :-1 |

# Figures

| 1—1  | TMS320 Family of Devices 1-2                                  |
|------|---------------------------------------------------------------|
| 1–2  | TMS320C40 Throughput Increases Use of Communication Ports 1-7 |
| 1–3  | TMS320C40 Throughput Increases Use of DMA Coprocessor         |
| 1-4  | Matrix of TMS320 DSP Applications                             |
| 2-1  | TMS320C40 Block Diagram                                       |
| 2-2  | Central Processing Unit (CPU)                                 |
| 2–3  | Memory Organization                                           |
| 2–4  | Memory Maps                                                   |
| 2–5  | Peripheral Memory Map 2-14                                    |
| 2–6  | Peripheral Modules                                            |
| 3–1  | Extended-Precision Register Floating-Point Format             |
| 3–2  | Extended-Precision Register Integer Format                    |
| 3–3  | Status Register                                               |
| 3–4  | DMA Interrupt Enable Register Bit Functions                   |
| 3–5  | Internal Interrupt Enable Register (IIE)                      |
| 3–6  | Interrupt Flag Register (IIF)                                 |
| 3–7  | Trap Vector Table (TVT)                                       |
| 3–8  | Interrupt-Vector Table (IVT)                                  |
| 3–9  | Memory Maps                                                   |
| 3–10 | Peripheral Memory Map 3-20                                    |
| 3–11 | Memory Interface Control Registers                            |
| 3–12 | Analysis Module Registers                                     |
| 3–13 | Timer Registers                                               |
| 3–14 | Communication Port Memory Map 3-23                            |
| 3–15 | DMA Coprocessor Memory Map 3-24                               |
| 3–16 | Address Partitioning for Cache Control Algorithm              |
| 3–17 | Instruction Cache Architecture                                |
| 4—1  | Short Integer Format and Sign Extension of Short Integer      |
| 4–2  | Single-Precision Integer Format                               |

| 4-3        | Short Unsigned-Integer Format and Zero Fill                            | . 4-4 |
|------------|------------------------------------------------------------------------|-------|
| 4-4        | Single-Precision Unsigned-Integer Format                               | . 4-4 |
| 4-5        | Generic Floating-Point Format                                          |       |
| 46         | Short Floating-Point Format                                            | . 4-6 |
| 4-7        | Single-Precision Floating-Point Format                                 | . 4-7 |
| 48         | Extended-Precision Floating-Point Format                               | . 4-8 |
| 49         | IEEE Single-Precision Std. 754 Floating-Point Format                   | 4-11  |
| 4–10       | TMS320C4x Single-Precision Twos-Complement Floating-Point<br>Format    | 1-11  |
| 4-11       | Flowchart for Floating-Point Multiplication                            |       |
| 4-12       | Flowchart for Floating-Point Addition                                  |       |
| 4-13       | Flowchart for NORM Instruction Operation                               |       |
| 4-14       | Flowchart for Floating-Point Rounding by the RND Instruction           |       |
| 4-15       | Flowchart for Floating-Point-to-Integer Conversion by FIX Instructions |       |
| 4-16       | Flowchart for Integer-to-Floating-Point Conversion by FLOAT            | 0     |
|            | Instructions                                                           | 4-30  |
| 4–17       | RCPF Instruction Algorithm                                             | 4-31  |
| 4–18       | Newton-Raphson Algorithm for Computing the Reciprocal                  | 4-32  |
| 4–19       | RSQRF Instruction Algorithm                                            | 4-33  |
| 4-20       | Newton-Raphson Algorithm for Computing the Reciprocal                  |       |
|            | Square Root                                                            |       |
| 5-1        | Direct Addressing                                                      |       |
| 5–2        | Encoding for 24-Bit PC-Relative Addressing Mode                        |       |
| 53         | Encoding for General Addressing Modes                                  | 5-20  |
| 5-4        | Encoding for Type 1 Three-Operand Addressing Modes<br>('C30 and 'C40)  | E 00  |
| 5-5        | Encoding for Type 2 Three-Operand Addressing Modes ('C40 Only)         |       |
| 5-6        | Encoding for Parallel Addressing Modes                                 |       |
| 5–0<br>5–7 | Encoding for Conditional-Branch Addressing Modes                       |       |
| 58         | Flowchart for Circular Addressing                                      |       |
| 5-0<br>5-9 | Circular Buffer Implementation                                         |       |
| 5–10       |                                                                        |       |
| 5-10       | Circular Addressing Example                                            |       |
|            | Data Structure for FIR Filters                                         |       |
| 5-12       | FIR Filter Code Using Circular Addressing                              |       |
| 5-13       | Bit-Reversed Addressing Example                                        |       |
| 5–14       | System Stack Configuration                                             | 5-31  |

| 5–15 | Implementations of High-to-Low Memory Stacks                                                                    |
|------|-----------------------------------------------------------------------------------------------------------------|
| 5–16 | Implementations of Low-to-High Memory Stacks                                                                    |
| 6—1  | Repeat-Mode Control Algorithm                                                                                   |
| 6–2  | CALL Response Timing                                                                                            |
| 6–3  | Unified Flow of Traps and Interrupts                                                                            |
| 64   | Multiple TMS320C40s Sharing Global Memory                                                                       |
| 6–5  | Interrupt-Vector Table (IVT)                                                                                    |
| 6–6  | Interrupt Processing                                                                                            |
| 7–1  | Global and Local Memory Interface Control Signals                                                               |
| 7-2  | Format for the Memory-Interface Control Registers                                                               |
| 7–3  | Effects of STRB ACTIVE on Global Memory Bus Memory Map                                                          |
| 7–4  | STRBx PAGESIZE Fields Example                                                                                   |
| 7–5  | STRB and RDY Timing                                                                                             |
| 7–6  | Read Same Page, Read Same Page, Write Same Page Sequence 7-18                                                   |
| 7–7  | Write Same Page, Write Same Page, Read Same Page Sequence 7-19                                                  |
| 7–8  | Read Same Page, Read Different Page, Read Same Page Sequence 7-20                                               |
| 7–9  | Write Same Page, Write Different Page, Write Same Page Sequence 7-21                                            |
| 7–10 | Write Same Page, Read Different Page, Write Different Page<br>Sequence                                          |
| 7–11 | Read Different Page, Read Different Page, Write Same Page                                                       |
|      | Sequence                                                                                                        |
| 7–12 | Write Different Page, Write Different Page, Read Same Page      Sequence      7-24                              |
| 7–13 | Read Same Page, Write Different Page, Read Different Page                                                       |
|      | Sequence                                                                                                        |
| 7–14 | Read Same Page, Idle One Cycle, Read Same Page Sequence                                                         |
| 7–15 | Write Same Page, Idle One Cycle, Write Different Page Sequence 7-27                                             |
| 7–16 | Idle, Read Different Page, Idle Sequence                                                                        |
| 7–17 | Idle, Write Same Page, Idle Sequence                                                                            |
| 7–18 | Write Different or Same Page, Idle, Idle Sequence                                                               |
| 7–19 | Read Same Page on STRB1, Read Same Page on STRB0, Read<br>Same Page on STRB1 Sequence When STRB SWITCH = 0      |
| 7–20 | Read Same Page on STRB1, Read Same Page on STRB0, Read<br>Same Page on STRB1 Sequence When STRB SWITCH = 1      |
| 7–21 | Read Same Page on STRB1, Read Same Page on STRB0, Read<br>Different Page on STRB1 Sequence When STRB SWITCH = 0 |

| 7–22 | Read Same Page on STRB1, Read Same Page on STRB0,<br>Read Different Page on STRB1 Sequence When STRB SWITCH = $1 \dots 7-34$                   |
|------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–23 | Write Same Page on STRB1, Write Same Page on STRB0,Read Same Page on STRB1 Sequence7-35                                                        |
| 7–24 | Read With One Wait State                                                                                                                       |
| 7–25 | Write With One Wait State                                                                                                                      |
| 7–26 | Using Enabled Signals to Put Signal Groups in a High-Impedance<br>State                                                                        |
| 7–27 | LDII or LDFI External Access                                                                                                                   |
| 7–28 | STII or STFI External Access                                                                                                                   |
| 7–29 | SIGI External Access Timing                                                                                                                    |
| 7–30 | SIGI When LOCK Is Already Low                                                                                                                  |
| 7–31 | IACK Timing         7-48                                                                                                                       |
| 8—1  | Communication Port Block Diagram                                                                                                               |
| 8–2  | TMS320C40 Communication-Port Interface-Connection Example                                                                                      |
| 8–3  | Communication Port Memory Map 8-8                                                                                                              |
| 8-4  | Communication Port Control Register (CPCR)                                                                                                     |
| 8–5  | Communication Port Arbitration Unit State Diagram                                                                                              |
| 86   | Signal-Naming Example                                                                                                                          |
| 8–7  | Token Transfer Sequence    8-23                                                                                                                |
| 8–8  | End of Token Transfer Sequence Followed by a Word Transfer and the Beginning of a Second Word Transfer                                         |
| 8–9  | End of a Word Transfer Followed by a Word Transfer                                                                                             |
| 8–10 | End of a Word Transfer Followed by an Idle State and Token Transfer 8-26                                                                       |
| 8–11 | End of a Word Transfer Followed by an Overlapping Token Transfer 8-27                                                                          |
| 8–12 | End of the Transfer of the Last Word in an Output FIFO Followed by<br>an Idle Condition Until Another Word Is Available to Be Transferred 8-28 |
| 8–13 | End of a Word Transfer Followed by a Not Ready Due to the Input FIFO<br>Becoming Full, Continuing Once the Input FIFO Is No Longer Full 8-29   |
| 8–14 | Post-Reset State for an Output Port                                                                                                            |
| 8–15 | Post-Reset State for an Input Port                                                                                                             |
| 8–16 | Type-One Synchronizer Minimum Delay         8-31                                                                                               |
| 8–17 | Type-One Synchronizer Maximum Delay    8-31                                                                                                    |
| 8–18 | Type-Two Synchronizer Minimum Delay    8-32                                                                                                    |
| 8–19 | Type-Two Synchronizer Maximum Delay                                                                                                            |
| 9–1  | DMA Coprocessor Memory Map                                                                                                                     |

| 9–2              | Subsections Where DMA Channel Registers Are Described                                                                     | 9-5  |
|------------------|---------------------------------------------------------------------------------------------------------------------------|------|
| 9–3              | DMA Channel Control Register                                                                                              | 9-8  |
| 9-4              | DMA-Coprocessor Address Generation                                                                                        | 9-17 |
| 95               | DMA Coprocessor Transfer-Count Registers                                                                                  | 9-18 |
| 96               | DMA Coprocessor Link Pointer Registers                                                                                    | 9-19 |
| <del>9</del> –7  | Typical Unified Mode DMA Channel Configuration                                                                            | 9-21 |
| 98               | Typical Split-Mode DMA Configuration                                                                                      | 9-21 |
| 9–9              | Rotating Priority Mode Example of the DMA Coprocessor                                                                     | 9-23 |
| 9–10             | DMA Read and Write Sequence Example                                                                                       | 9-23 |
| 9–11             | Example of a Priority Wheel                                                                                               | 9-24 |
| 9–12             | Example of a Channel Priority Scheme in Split Mode                                                                        | 9-25 |
| 9–13             | Service Sequence for Split Mode Priority Example                                                                          | 9-26 |
| 9–14             | Running a DMA Channel Under Transfer Mode 10 <sub>2</sub>                                                                 | 9-29 |
| 9–15             | Running a DMA Channel Under Transfer Mode 11 <sub>2</sub>                                                                 | 9-30 |
| 9–16             | Store New Values of DMA Channel Registers in Memory (SPLIT MODE = 0)                                                      | 9-32 |
| 9–17             | Store New Values of DMA Channel Registers in Memory (SPLIT MODE = 1)                                                      |      |
| 9–18             | Store New Values of DMA Channel Registers in Memory<br>(SPLIT MODE = 1 and Auxiliary Transfer Counter = 0)                |      |
| 9–19             | DMA Channel Control Register Bits That Can Be Modified by<br>Autoinitialization Under Unified Mode                        |      |
| <del>9–</del> 20 | DMA Channel Control Register Bits That Can Be Modified by<br>Autoinitialization of the Primary Channel Under Split Mode   |      |
| 9–21             | DMA Channel Control Register Bits That Can Be Modified by<br>Autoinitialization of the Auxiliary Channel Under Split Mode |      |
| 9–22             | Self-Referential Link Pointer                                                                                             |      |
| 9–23             | Referring to a New Link Pointer                                                                                           |      |
| 9-24             | No DMA Synchronization                                                                                                    |      |
| 925              | DMA Source Synchronization                                                                                                |      |
| 9–26             | DMA Destination Synchronization                                                                                           |      |
| 9–27             | DMA Source and Destination Synchronization                                                                                |      |
| 9-28             | Timer Block Diagram                                                                                                       |      |
| 9-29             | Memory-Mapped Timer Locations                                                                                             |      |
| 9–30             | Timer Global-Control Register                                                                                             |      |
| 9-31             | Timer Timing                                                                                                              |      |

| 9–32  | Timer I/O Port Configurations                                               |
|-------|-----------------------------------------------------------------------------|
| 9–33  | Timer Modes as Defined by CLKSRC and FUNC                                   |
| 10-1  | TMS320C40 Pipeline Structure         10-3                                   |
| 10–2  | Two-Operand Instruction Word 10-21                                          |
| 10–3  | Three-Operand Instruction Word 10-21                                        |
| 10-4  | Multiply or CPU Operation With a Parallel Store                             |
| 10–5  | Two Parallel Stores 10-23                                                   |
| 10-6  | Parallel Multiplies and Adds 10-24                                          |
| 11-1  | Status Register 11-11                                                       |
| 12–1  | Data Memory Organization for an FIR Filter                                  |
| 12–2  | Data Memory Organization for a Single Biquad 12-54                          |
| 12–3  | Data Memory Organization for N Biquads 12-56                                |
| 12-4  | Data Memory Organization for Matrix-Vector Multiplication 12-61             |
| 12–5  | Structure of the Inverse Lattice Filter 12-89                               |
| 12–6  | Data Memory Organization for Inverse Lattice Filters                        |
| 12–7  | Structure of the (Forward) Lattice Filter 12-92                             |
| 13–1  | External Interfaces to the TMS320C40 13-3                                   |
| 13–2  | Possible System Configurations 13-4                                         |
| 13–3  | Circuit for Generation of a Low IIOF Signal for Boot Loader Selection 13-14 |
| 13–4  | Boot Loader Source Program                                                  |
| 13–5  | TMS320C40 Interface to Zero-Wait-State SRAM                                 |
| 13–6  | Consecutive Reads Followed by a Write                                       |
| 13–7  | Consecutive Writes Followed by a Read 13-24                                 |
| 13-8  | TMS320C40 Interface to Zero-Wait-State SRAMs, Two Strobes 13-26             |
| 13–9  | Logic for Generation of 0, 1, or 2 Wait States for Multiple Devices 13-31   |
| 13–10 | State Machine and Equation for the 16R4 PLD                                 |
| 13–11 | Page Switching for the Cypress Semiconductor CY7C185 13-35                  |
| 13-12 | Timing for Read Operations Using Bank Switching                             |
| 13–13 | Message Broadcasting by One 'C40 to Many 'C40s 13-38                        |
| 13–14 | TMS320C40 Parallel DSP System Architectures                                 |
| 13–15 | TMS320C40 Shared Memory Interface                                           |
| 13–16 | TMS320C40 Shared Memory and Bus Controller Interface                        |
| 13–17 | Successful TMS320C40 Arbitration and Data Read From Shared                  |
|       | Bus Memory Followed by an Unsuccessful Arbitration Contest 13-47            |
| 13–18 | Shared Bus Interface PLD State Machine                                      |

| 13–19 | PLD Equations for Programming the 16R4 PLD (First-Level Logic) 13-51                                                           |
|-------|--------------------------------------------------------------------------------------------------------------------------------|
| 13–20 | PLD Equations for Programming the 16R4 PLD 13-60                                                                               |
| 13–21 | Global Bus Controllor PLD (Rotating Priority Mode Only) 13-62                                                                  |
| 13–22 | PLD Equations for Programming the 16R8 PLD 13-63                                                                               |
| 13–23 | PLD Equations for Programming the 16R6 PLD 13-68                                                                               |
| 13–24 | Successful TMS320C40 Arbitration; Data Read; Data Read 13-72                                                                   |
| 13–25 | Successful TMS320C40 Arbitration and Data Write From Shared Bus<br>Memory Followed by an Unsuccessful Arbitration Contest      |
| 13–26 | Successful 'C40 Arbitration; Consecutive Data Writes; Arbitration Win<br>Followed by Successive Writes and an Arbitration Loss |
| 13–27 | Reset Circuit                                                                                                                  |
| 13–28 | Voltage on the TMS320C40 RESET Pin                                                                                             |
| 14–1  | TMS320C40 Pinout (Bottom View)                                                                                                 |
| 14–2  | TMS320C40 325-Pin PGA Dimensions                                                                                               |
| 14–3  | Test Load Circuit                                                                                                              |
| 14-4  | TTL-Level Outputs 14-14                                                                                                        |
| 14–5  | TTL-Level Inputs 14-14                                                                                                         |
| 14–6  | X2/CLKIN Timing                                                                                                                |
| 14–7  | H1/H3 Timing                                                                                                                   |
| 14–8  | Memory ((L)STRB = 0) Read                                                                                                      |
| 14–9  | Memory ((L)STRB = 0) Write                                                                                                     |
| 14–10 | DE, AE, and CE Enable Timing 14-19                                                                                             |
| 14–11 | Timing for (L)LOCK When Executing LDFI or LDII                                                                                 |
| 14–12 | Timing for (L)LOCK When Executing a STFI or STII                                                                               |
| 14–13 | Timing for (L)LOCK When Executing SIGI                                                                                         |
| 14–14 | Timing Parameters for (L)PAGE(0,1) 14-23                                                                                       |
| 14–15 | Timing for Loading IIF Register (IIOF Pins) When Configured as an<br>Output Pin                                                |
| 14–16 | Change of IIOF From Output to Input Mode                                                                                       |
| 14–17 |                                                                                                                                |
| 14–18 | RESET Timing         14-27                                                                                                     |
| 14–19 | IOOF(3 — 0) Response Timing                                                                                                    |
| 14–20 | IACK Timing         14-30                                                                                                      |
| 14–21 | Communication-Port Word-Transfer Cycle Timing                                                                                  |
| 14-22 | Communication Port Byte Timing (Write and Read) 14-32                                                                          |
| 14–23 | Communication Token Transfer Sequence From an Input to an                                                                      |
|       | Output Port 14-33                                                                                                              |

| 14-24 | Communication Token Transfer Sequence From an Output |       |
|-------|------------------------------------------------------|-------|
|       | to an Input Port                                     | 14-35 |
| 14–25 | Timer Pin Timings                                    | 14-37 |
| 14–26 | JTAG Emulation Timings                               | 14-38 |
| A-1   | Tool-Activated ZIF Socket                            | A-2   |
| A-2   | Handle-Activated ZIF Socket                          | A-3   |
| B-1   | 14-pin Header Signals and Header Dimensions          | B-2   |
| B–2   | Emulator Pod Interface                               | B-5   |
| B–3   | Emulator Pod Timings                                 | B-6   |
| B4    | Target-System Generated Test Clock                   | B-7   |
| B–5   | Multiprocessor Connections                           | B-8   |
| B6    | Unbuffered Signals                                   | В-9   |
| B7    | Buffered Signals                                     | В-9   |

## **Tables**

| 2–1 | CPU Primary Registers                                                                          |
|-----|------------------------------------------------------------------------------------------------|
| 2–2 | Instruction Set Summary 2-16                                                                   |
| 2–3 | Parallel Instruction Set Summary 2-23                                                          |
| 3—1 | CPU Primary Register File                                                                      |
| 3–2 | Status Register Bits Summary                                                                   |
| 3–3 | DMA Channels 0 and 1 Synchronization Interrupts (DMA0 and DMA1) 3-9                            |
| 3–4 | DMA Channels 2 to 5 Synchronization Interrupts (DMA2 to DMA5) 3-9                              |
| 3–5 | Summary of Interrupt Enable Register Bits (IIE)                                                |
| 3–6 | IIF Register Bits Summary 3-13                                                                 |
| 3–7 | CPU Expansion Registers 3-15                                                                   |
| 3–8 | Four RESET Vector Locations Chosen by Values on Pins<br>RESETLOC(1,0)                          |
| 3–9 | Combined Effect of the CE and CF Bits                                                          |
| 4–1 | Rules for Converting IEEE Format to Twos-Complement         Floating-Point Format         4-12 |
| 4–2 | Rules for Converting Twos-Complement Floating-Point Format to IEEE Format                      |
| 5–1 | CPU Register/Assembler Syntax and Function                                                     |
| 5–2 | Indirect Addressing 5-6                                                                        |
| 5–3 | Three-Operand Instruction Address Forms                                                        |
| 5–4 | Index Steps and Bit-Reversed Addressing                                                        |
| 6—1 | Repeat-Mode Registers 6-2                                                                      |
| 6–2 | Interlocked Operations 6-13                                                                    |
| 6–3 | Pin Operation at Reset 6-18                                                                    |
| 7–1 | Global Memory Interface Control Signals                                                        |
| 7–2 | Global Memory Port Status for STRB0 and STRB1 Accesses                                         |
| 7–3 | Bit Definitions for Both Memory Interface Control Registers                                    |
| 7-4 | Page Size as Defined by STRB0/1 PAGESIZE Bits                                                  |

| 7–5   | Address Ranges Specified by STRB ACTIVE Bits                          |
|-------|-----------------------------------------------------------------------|
| 76    | Address Ranges Specified by LSTRB ACTIVE Bits                         |
| 7–7   | Wait-State Generation for Each Value of SWW                           |
| 8–1   | CPCR Bit Functions                                                    |
| 8–2   | PAU State Definitions                                                 |
| 8–3   | Summary of Input and Output FIFO Halting                              |
| 8–4   | Handshaking Events in Communication Port Intercommunication 8-20      |
| 8–5   | Communication Port Signals and Synchronizer Delays                    |
| 9–1   | DMA Channel Control Register Bit Definitions                          |
| 9–2   | DMA PRI Bits and CPU/DMA Arbitration Rules                            |
| 93    | TRANSFER MODE and AUX TRANSFER MODE Field Description 9-14            |
| 9–4   | SYNCH MODE Field Description                                          |
| 9–5   | START and AUX START Field Description                                 |
| 9–6   | STATUS and AUX STATUS Field Description                               |
| 9–7   | DMA PRI Bits and CPU/DMA Arbitration Rules                            |
| 9–8   | TRANSFER MODE Field Description Summary                               |
| 9–9   | Effect of SYNC MODE and AUTOINIT MODE Bits in Autoinitialization 9-37 |
| 9–10  | Timer Global-Control Register Bits Summary                            |
| 9—11  | Result of a Write of Specified Values of GO and HLD                   |
| 10–1  | One Program Fetch and One Data Access for Maximum Performance . 10-18 |
| 10–2  | One Program Fetch and Two Data Accesses for Maximum Performance 10-19 |
| 11–1  | Load-and-Store Instructions 11-4                                      |
| 11–2  | Two-Operand Instructions 11-5                                         |
| 11–3  | Three-Operand Instructions 11-6                                       |
| 11–4  | Program Control Instructions 11-7                                     |
| 11–5  | Interlocked Operations Instructions 11-7                              |
| 11–6  | Parallel Instructions 11-8                                            |
| 11–7  | Output Value Formats                                                  |
| 11–8  | Condition Codes and Flags 11-12                                       |
| 11–9  | Instruction Symbols 11-14                                             |
| 11–10 | CPU Register Syntax 11-17                                             |
| 12-1  | Relationship of RESETLOC(1,0) Pins to RESET Vector Location 12-3      |
| 12–2  | TMS320C40 FFT Timing Benchmarks 12-88                                 |
| 13–1  | Boot Loader Mode Selection Using Pins IIOF(3-1) 13-5                  |

| 13–2  | Structure of Source Program Data Stream                                                 |
|-------|-----------------------------------------------------------------------------------------|
| 13–3  | Page Switching Interface Timing 13-36                                                   |
| 14–1  | TMS320C40 Pin Assignments Sorted by Signal Name 14-3                                    |
| 14–2  | TMS320C40 Pin Assignments Sorted by Pin Number 14-5                                     |
| 14–3  | TMS320C40 Signal Descriptions 14-7                                                      |
| 14–4  | Absolute Maximum Ratings Over Specified Temperature Range 14-12                         |
| 14–5  | Recommended Operating Conditions 14-12                                                  |
| 14–6  | Electrical Characteristics Over Specified Free-Air Temperature Range . 14-13            |
| 14–7  | Timing Parameters for CLKIN, H1, H3 (Figure 14-6 and Figure 14-7) 14-16                 |
| 14–8  | Timing Parameters for a Memory (L) STRB = 0) Read/Write 14-17                           |
| 14–9  | DE, AE, and CE Enable Timing 14-19                                                      |
| 14–10 | Timing Parameters for (L)LOCK When Executing LDFI or LDII 14-20                         |
| 14–11 | Timing Parameters for (L)LOCK When Executing STFI or STII 14-21                         |
| 14–12 | Timing Parameters for (L)LOCK When Executing SIGI                                       |
| 14–13 | Timing Parameters for (L)PAGE(0,1) During Memory Accesses to aDifferent Page14-23       |
| 14–14 | Timing Parameters for Loading IIF Register When Configured as an<br>Output Pin          |
| 14–15 | Timing Parameters of IIOF Changing From Output to Input Mode 14-25                      |
| 14–16 | Timing Parameters of IIOF Changing From Input to Output Mode 14-26                      |
| 14–17 | Timing Parameters for RESET (Figure 14–18)                                              |
| 14–18 | Timing Parameters for IOOF(3–0) 14-29                                                   |
| 14–19 | Timing Parameters for IACK                                                              |
| 14–20 | Communication-Port Word-Transfer Cycle Timing                                           |
| 14–21 | Communication-Port Byte Timing (Write and Read) 14-32                                   |
| 14-22 | Communication Token Transfer Sequence From an Input to an<br>Output Port (Figure 14–23) |
| 14–23 | Communication Token Transfer Sequence From an Output to an<br>Input Port (Figure 14–24) |
| 14–24 | Timing Parameters for Timer Pin 14-37                                                   |
| 14–25 | Timing Parameters for JTAG Emulation                                                    |
| B–1   | 14-Pin Header Signal Description                                                        |
| B–2   | Emulator Pod Timing Parameters                                                          |
|       |                                                                                         |

## **Examples**

| ********************* |                                                                  |            |
|-----------------------|------------------------------------------------------------------|------------|
| 4-1                   | Floating-Point Multiply (Both Mantissas = -2.0)                  | 18         |
| 4-2                   | Floating-Point Multiply (Both Mantissas = 1.5) 4-                | 18         |
| 4–3                   | Floating-Point Multiply (Both Mantissas = 1.0) 4-                |            |
| 44                    | Floating-Point Multiply Between Positive and Negative Numbers 4- | 19         |
| 45                    | Floating-Point Multiply by Zero 4-                               | 19         |
| 4-6                   | Floating-Point Addition 4-                                       | 22         |
| 4–7                   | Floating-Point Subtraction 4-                                    | 22         |
| 48                    | Floating-Point Addition With a 32-Bit Shift 4-                   | 23         |
| 4–9                   | Floating-Point Addition/Subtraction and Zero 4-                  | 23         |
| 4–10                  | NORM Instruction 4-                                              | 25         |
| 5–1                   | Direct Addressing 5                                              | <u>5-4</u> |
| 5–2                   | Auxiliary Register Indirect 5                                    | 5-8        |
| 5-3                   | Indirect With Predisplacement Add 5                              | 5-8        |
| 5-4                   | Indirect With Predisplacement Subtract 5                         | 5-9        |
| 5–5                   | Indirect With Predisplacement Add and Modify 5                   | 5-9        |
| 5–6                   | Indirect With Predisplacement Subtract and Modify                | 10         |
| 57                    | Indirect With Postdisplacement Add and Modify 5-                 | 10         |
| 58                    | Indirect With Postdisplacement Subtract and Modify 5-            | ·11        |
| 59                    | Indirect With Postdisplacement Add and Circular Modify 5-        | ·11        |
| 5–10                  | Indirect With Postdisplacement Subtract and Circular Modify 5-   | 12         |
| 5–11                  | Indirect With Preindex Add 5-                                    | 12         |
| 5–12                  | Indirect With Preindex Subtract 5-                               | 13         |
| 5–13                  | Indirect With Preindex Add and Modify 5-                         | 13         |
| 5–14                  | Indirect With Preindex Subtract and Modify5-                     | ·14        |
| 5–15                  | Indirect With Postindex Add and Modify 5-                        | ·14        |
| 5–16                  | Indirect With PostiIndex Subtract and Modify                     | 15         |
| 5–17                  | Indirect With Postindex Add and Circular Modify                  | ·15        |
| 5–18                  | Indirect With Postindex Subtract and Circular Modify             | -16        |

| 5–19  | Indirect With Postindex Add and Bit-Reversed Modify 5-16     |
|-------|--------------------------------------------------------------|
| 5–20  | Immediate Addressing 5-17                                    |
| 5–21  | PC-Relative Addressing 5-17                                  |
| 6–1   | RPTB Operation                                               |
| 6–2   | Incorrectly Placed Standard Branch                           |
| 6–3   | Incorrectly Placed Delayed Branch                            |
| 64    | Incorrectly Placed Delayed Branches                          |
| 65    | Busy-Waiting Loop 6-15                                       |
| 66    | Task Counter Manipulation    6-15                            |
| 6–7   | Implementation of V(S) 6-16                                  |
| 6–8   | Implementation of P(S) 6-16                                  |
| 10–1  | Standard Branch 10-5                                         |
| 10–2  | Delayed Branch 10-6                                          |
| 10–3  | Using BcondAF and BcondAT Instructions                       |
| 10–4  | Write to an AR Followed by an AR for Address Generation 10-9 |
| 10–5  | A Read of ARs Followed by ARs for Address Generation         |
| 10–6  | Program Wait Until CPU Data Access Completes                 |
| 10–7  | Program Wait Due to Multicycle Access                        |
| 10–8  | Multicycle Program Memory Fetches                            |
| 10–9  | Single Store Followed by Two Reads                           |
| 10–10 | Parallel Store Followed by Single Read                       |
| 10–11 | Busy External Port                                           |
| 10–12 | Multicycle Data Reads                                        |
| 10–13 | Conditional Calls and Traps 10-17                            |
| 12–1  | Processor Initialization Example 12-4                        |
| 12–2  | Regular Subroutine Call (Dot Product)                        |
| 12–3  | Zero-Overhead Subroutine Call (Dot Product)                  |
| 12–4  | Use of Interrupts for Software Polling                       |
| 12–5  | Context-Save for the TMS320C40 12-17                         |
| 12–6  | Context-Restore for the TMS320C40 12-18                      |
| 12–7  | Use of One Interrupt Signal for Two Different Services       |
| 128   | Interrupt Service Routine                                    |
| 12–9  | Delayed Branch Execution 12-23                               |
| 12–10 | Use of Block Repeat to Find a Maximum or a Minimum 12-23     |

| 12–11 | Loop Using Delayed Block Repeat 12-25                                  |
|-------|------------------------------------------------------------------------|
| 12–12 | Loop Using Single Repeat 12-26                                         |
| 12–13 | Computed GOTO 12-27                                                    |
| 12-14 | Use of TSTB for Software-Controlled Interrupt 12-28                    |
| 12–15 | Copy a Bit From One Location to Another                                |
| 12–16 | Block Move Under Program Control 12-30                                 |
| 12–17 | Use of Packing Data From Half-Word FIFO to 32-Bit Data Memory 12-30    |
| 12-18 | Use of Unpacking 32-Bit Data Into Four-Byte-Wide Data Array 12-31      |
| 12-19 | Bit-Reversed Addressing 12-32                                          |
| 12–20 | Integer Division                                                       |
| 12–21 | Inverse of a Floating-Point Number With 32-Bit Mantissa Accuracy 12-37 |
| 12-22 | Reciprocal of the Square Root of a Positive Floating-Point             |
| 12–23 | 64-Bit Addition                                                        |
| 12–24 | 64-Bit Subtraction                                                     |
| 12–25 | 32-Bit by 32-Bit Multiplication                                        |
| 12–26 | IEEE to TMS320C40 Conversion Within Block Memory Transfer 12-45        |
| 12–27 | TMS320C40 to IEEE Conversion Within Block Memory Transfer 12-45        |
| 12–28 | μ-Law Compression                                                      |
| 12–29 | μ-Law Expansion                                                        |
| 12–30 | A-Law Compression 12-49                                                |
| 12–31 | A-Law Expansion                                                        |
| 12–32 | FIR Filter                                                             |
| 12–33 | IIR Filter (One Biquad) 12-54                                          |
| 12–34 | IIR Filters (N > 1 Biquads) 12-56                                      |
| 12–35 | Adaptive FIR Filter (LMS Algorithm) 12-59                              |
| 12–36 | Matrix Times a Vector Multiplication 12-62                             |
| 12–37 | Complex, Radix-2, DIF FFT 12-65                                        |
| 12–38 | Table With Twiddle Factors for a 64-Point FFT         12-68            |
| 12–39 | Complex, Radix-4, DIF FFT 12-70                                        |
| 12-40 | Real, Radix-2 FFT 12-75                                                |
| 12-41 | Faster Version Complex, Radix-2 DIT FFT 12-78                          |
| 12-42 | Inverse Lattice Filter 12-90                                           |
| 12–43 | Lattice Filter                                                         |
| 12–44 | Maximum Frequency Timer Clock Setup 12-98                              |

| 12–45 | Read Data From Communication Port With CPU ICFULL Interrupt 12-100     |
|-------|------------------------------------------------------------------------|
| 12–46 | Write Data to Communication Port With Polling Method                   |
| 12–47 | Array Initialization With DMA 12-102                                   |
| 12–48 | DMA Transfer With Communication Port ICRDY Synchronization 12-103      |
| 12–49 | DMA Split-Mode Transfer With External Interrupt Synchronization 12-104 |
| 12–50 | DMA Autoinitialization With Communication Port ICRDY 12-106            |
| 12–51 | Single-Interrupt-Driven DMA Transfer 12-107                            |
| 13–1  | Byte-Wide Configured Memory 13-10                                      |
| 13–2  | 16-Bits-Wide Configured Memory 13-12                                   |
| 13–3  | 32-Bits-Wide Configured Memory 13-13                                   |



### **Chapter 1**

### Introduction

Texas Instruments' TMS320C4x generation floating-point processors are designed specifically to meet the needs of parallel processing and other real-time embedded applications. TMS320C4x products consist of both parallel processing devices and development tools. With world-class parallel-processing development tools, designers are able to fully utilize the immense performance of 275 MOPS (millions of operations per second) and 320 Mbytes per second throughput made available by the TMS320C4x generation.

This chapter provides a brief overview of the TMS320C4x generation. Major topics covered are as follows:

| Section |                           | Page   |  |
|---------|---------------------------|--------|--|
| 1.1     | The TMS320 Family         | . 1-2  |  |
| 1.2     | Parallel Processing       | . 1-3  |  |
| 1.3     | The TMS320C40x Generation | . 1-4  |  |
| 1.4     | Applications              | . 1-11 |  |

### 1.1 The TMS320 Family

The TMS320C4x is one of five generations in the TMS320 family of digital signal processors. The TMS320C1x, TMS320C2x, and TMS320C5x offer designers a complete line of general-purpose and application-specific fixed-point DSPs. The TMS320C3x and TMS320C4x generations round out the TMS320 family, providing an ensemble of floating-point DSPs. The TMS320 family has blossomed from a single device introduced in 1982, the TMS32010, to nearly thirty different products across five CPU architectures. On-chip hardware multipliers, register files, barrel shifters, ALUs, ROM, RAM, caches, and I/O peripherals along with massive internal busing (all within a product as programmable as a general-purpose microprocessor), make TI's TMS320 devices ideal for the gamut of computer-intensive applications.





,

1

Introduction

### 1.2 Parallel Processing

The need for parallel processing is quickly growing. As floating-point performance requirements grow exponentially, semiconductor manufacturers can no longer meet the need with single processing elements. Processors not designed for parallel processing are inadequate for the task, as interprocessor communication quickly saturates device I/O and adversely affects computing efficiency. Products in the TMS320C3x generation made the first step in addressing the need for parallel processing by providing designers with two external interface ports, each with a comprehensive memory interface. This yields an immense amount of I/O bandwidth. Devices in the TMS320C4x generation go several steps further by incorporating on-chip hardware to facilitate high-speed interprocessor communication and concurrent I/O without degrading CPU performance. These features, coupled with a host of sophisticated parallel processing development tools, make the TMS320C4x generation of floating-point processors ideal for realtime embedded applications.

#### 1.3 TMS320C4x Features

The TMS320C4x generation consists of two equally important aspects, parallel processing devices and parallel processing development tools.

#### 1.3.1 TMS320C40 Device Key Features

The Primary features of the TMS320C4x devices are:

- Six communication ports for high speed interprocessor communication. Communication port key features include:
  - 20-Mbytes/sec asynchronous transfer rate at each port for maximum data throughput
  - Direct (glueless) processor-to-processor communication for ease of use
  - Bidirectional transfers for maximum communication flexibility
- Six-channel DMA coprocessor for concurrent I/O and CPU operation, thereby maximizing sustained CPU performance by alleviating the CPU of burdensome I/O. DMA coprocessor key features include:
  - Concurrent data transfers and CPU operation for sustained CPU performance
  - Self-programming (autoinitialize) capability for each channel, thereby not requiring the CPU for initialization, maximizing sustained CPU performance
  - Data transfers to and from anywhere in the processor's memory map for maximum flexibility
- High-performance DSP CPU capable of 275 MOPS and 320 Mbytes/ sec. CPU key features include:
  - Eleven operations per cycle throughput, resulting in massive computing parallelism and sustained CPU performance
  - 40-ns and 50-ns instruction cycle times
  - 40/32-bit single-cycle floating-point/integer multiplier for high performance in computationally intensive algorithms
  - Single-cycle IEEE floating-point conversion for efficient interface to IEEE-compatible processors
  - Hardware divide and inverse square root support for high performance
  - Byte and half-word manipulation capabilities for fast data (un)packing

- Source code compatible with TMS320C3x generation for easy upward and downward mobility
- Support for linear, circular, and bit-reversed addressing for high performance
- Single-cycle branches, calls, and returns for fast program control
- Single-cycle barrel shifter for 0–31 single-cycle right or left shifts for fast bit manipulation
- Relocatable reset and interrupt vectors for easy integration into parallel processing systems
- Two identical external data and address buses supporting shared memory systems and high data rate, single-cycle transfers. Key features include:
  - High port data-transfer rate of 100 Mbytes/sec
  - 16-Gbyte continuous program/data/peripheral address space for maximum design flexibility
  - Status pins that signal type of memory access requested for fast, intelligent bus arbitration in shared memory systems
  - Separate address, data, and control-enable pins for high-speed bus arbitration
  - Four sets of memory-control signals support different speed memories in hardware, enabling efficient use of low- and highspeed memories
- On-chip analysis module supporting efficient, state of the art parallel processing debug. Key features include:
  - Separate breakpoint comparators for program, data, and DMA accesses, providing onchip hardware breakpoint capabilities for fast debug and development
  - Discontinuity stack for hardware trace, facilitating fast debug and development
  - Event counter for accurate benchmarking and profiling
  - JTAG interface for standard system connection

- On-chip program cache and dual-access/single-cycle RAM for increased memory access performance. On-chip memory key features include:
  - 512-byte instruction cache for increased system performance
  - 8K-bytes of single-cycle dual access program or data RAM for increased system performance and lower system cost
  - Bootloader (ROM based) supporting program bootup via 8-, 16- or 32-bit memories over any one of the communication ports
- Separate internal program, data, and DMA coprocessor buses for support of massive concurrent I/O of program and data throughput, thereby maximizing sustained CPU performance.

Summed up, the total device performance is 275 MOPS and 320 Mbytes/ sec as noted below.



#### TMS320C40 Performance

Introduction

### **1.3.2 Communication Port Benefits**

Without the six communication ports, 120 Mbytes/sec of processor throughput must be squeezed over one or both of the external memory interfaces, thereby saturating processor throughput, likewise turning the system into a complex shared memory architecture. With the communication ports, bandwidth is plentiful (illustrated in Figure 1–2).



Figure 1–2. TMS320C40 Throughput Increases Use of Communication Ports

### 1.3.3 DMA Coprocessor Benefits

Without the DMA coprocessor, the CPU would have to use computational MOPS to transfer data within the processor's memory map. With the DMA coprocessor, the CPU can focus its entire 200 MOPS of performance on quality computational tasks while the DMA coprocessor takes care of the burdensome I/O. This is illustrated in Figure 1–3.



Figure 1–3. TMS320C40 Throughput Increases Use of DMA Coprocessor

### 1.3.4 TMS320C40 Parallel Processing Development Tools Key Features

The primary TMS320C4x development tools are as follows:

- Parallel processing in-circuit emulator (XDS510)
  - Able to debug both C and assembly code simultaneously using the graphical user-interface based source-level debugger
  - Can debug any number of TMS320C4x devices in a system with a single XDS510 controller card
  - Can globally stop, start and single step all or any combination of 'C40s in a system.
- Parallel processing development system
  - Host-independent evaluation board with four 'C40s
  - Each 'C40 connected to every other 'C40 via their communication ports, enabling designers to efficiently test different system topologies
  - Interfaces directly to XDS510 emulator, creating a complete parallel processing development environment.
- Parallel processing optimizing ANSI C compiler
  - Parallel runtime support library for easy implementation of data and message passing between tasks (or processors) in parallel processing systems
  - C-source and target-specific optimizations for dense, optimal code
  - Plum-Hall validated to ANSI standard for maximum code portability
- SPOX parallel processing DSP operating system
  - Parallel processing support for easy message passing within a multitasking environment
  - Communication port, DMA coprocessor, and memory interface drivers for fast development of C code without detailed knowledge of the hardware
  - Multitasking real-time kernel for fast implementation of multitasking system
  - DSP math library for fast development of DSP applications (using optimized assembly language routines)
- Parallel processing assembler/linker
  - Directives to map program and data code on specific processors for fast integration and debug of parallel processing code
  - Relocatable modules for maximum code flexibility

Hardware verification and full functional models

- Simulation of multiple 'C40's and associated logic for accurate development (via software simulation) of parallel processing systems
- Accurate simulation of device bus cycles and functional execution for fast development of product hardware
- Supports various workstation and PC environments
- □ State accurate simulator
  - Provides cycle-by-cycle simulation of all aspects of the TMS320C4x
  - Low-cost way to simulate key software kernels
  - Supported on a host of workstation and PC platforms

### 1.4 Applications

Below is a list of classical DSP applications along with a number of embedded real-time applications which need the computational performance offered by TMS320 devices. The real time performance, low device costs, and comprehensive development tools are the primary aspects that which make Texas Instruments TMS320 devices the preferred solution in the following applications:

| Figure 1–4. | Matrix of TMS320 DSP Applications |
|-------------|-----------------------------------|
|-------------|-----------------------------------|

| General-Purpose DSP                                                                                                                                                                               | Graphics/Imaging                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Instrumentation                                                                                                                                                             |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Digital Filtering<br>Convolution<br>Correlation<br>Hilbert Transforms<br>Fast Fourier Transforms<br>Adaptive Filtering<br>Windowing<br>Waveform Generation                                        | 3-D Transformations Rendering<br>Robot Vision<br>Image Transmission/Compression<br>Pattern Recognition<br>Image Enhancement<br>Homomorphic Processing<br>Workstations<br>Animation/Digital Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Spectrum Analysis<br>Function Generation<br>Pattern Matching<br>Seismic Processing<br>Transient Analysis<br>Digital Filtering<br>Phase-Locked Loops                         |
| No. No. No. No. ConcerSpeech                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Military                                                                                                                                                                    |
| Voice Mail<br>Speech Vocoding<br>Speech Recognition<br>Speaker Verification<br>Speech Enhancement<br>Speech Synthesis<br>Text-to-Speech<br>Neural Networks                                        | Disk Control<br>Servo Control<br>Robot Control<br>Laser Printer Control<br>Engine Control<br>Motor Control<br>Kalman Filtering                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Secure Communications<br>Radar Processing<br>Sonar Processing<br>Image Processing<br>Navigation<br>Missile Guidance<br>Radio Frequency Modems<br>Sensor Fusion              |
| Telecomm                                                                                                                                                                                          | unications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Automotive                                                                                                                                                                  |
| Echo Cancellation<br>ADPCM Transcoders<br>Digital PBXs<br>Line Repeaters<br>Channel Multiplexing<br>1200- to 19200-bps Modems<br>Adaptive Equalizers<br>DTMF Encoding/Decoding<br>Data Encryption | FAX<br>Cellular Telephones<br>Speaker Phones<br>Digital Speech Interpolation (DSI)<br>X.25 Packet Switching<br>Video Conferencing<br>Spread Spectrum<br>Communications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Engine Control<br>Vibration Analysis<br>Antiskid Brakes<br>Adăptive Ride Control<br>Global Positioning Navigation<br>Voice Commands<br>Digital Radio<br>Cellular Telephones |
| Consumer Market                                                                                                                                                                                   | harden and the second and the second se | Medical                                                                                                                                                                     |
| Radar Detectors<br>Power Tools<br>Digital Audio/TV<br>Music Synthesizer<br>Toys and Games<br>Solid-State Answering Machines                                                                       | Robotics<br>Numeric Control<br>Security Access<br>Power Line Monitors<br>Visual Inspection<br>Lathe Control<br>CAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Hearing Aids<br>Patient Monitoring<br>Ultra Sound Equipment<br>Diagnostic Tools<br>Prosthetics<br>Fetal Monitors<br>MR Imaging                                              |



## **Chapter 2**

Page

# **Architectural Overview**

The TMS320C40's high performance is achieved through the precision and wide dynamic range of the floating-point units, large on-chip memory, a high degree of parallelism, and the six-channel DMA coprocessor. Figure 2–1, beginning on the next page, is a block diagram of the TMS320C40.

This chapter gives an architectural overview of the TMS320C40 processor. Major areas of discussion are listed below.

#### Section

| 2.1 | Central Processing Unit (CPU) 2-4                             | ŀ  |
|-----|---------------------------------------------------------------|----|
|     | ■ Floating-point/integer multiplier 2-4                       | ŀ  |
|     | ALU for floating-point, integer, and logical operations . 2-4 | ŀ  |
|     | ■ 32-bit barrel shifter 2-4                                   | ŀ  |
|     | ■ Internal buses (CPU1/CPU2 and REG1/REG2) 2-4                | ŀ  |
|     | Auxiliary register arithmetic units (ARAUs) 2-6               | ;  |
|     | Primary register file 2-6                                     | 5  |
|     | ■ CPU expansion register file 2-9                             | )  |
| 2.2 | Memory Organization) 2-1                                      | 0  |
|     | RAM, ROM, and cache                                           | 0  |
|     | Memory maps                                                   | 2  |
|     | Memory addressing modes 2-1                                   | 5  |
| 2.3 | Instruction Set Summary 2-1                                   | 6  |
| 2.4 | Internal Bus Operation 2-2                                    | 26 |
| 2.5 | External Bus Operation 2-2                                    | 27 |
| 2.6 | Peripherals 2-2                                               | 28 |
|     | Communication ports 2-2                                       | 29 |
|     | ■ Direct memory access (DMA) coprocessor 2-2                  | 29 |
|     | ■ Timers 2-2                                                  | bg |







Figure 2–1. TMS320C40 Block Diagram (Concluded)



### 2.1 Central Processing Unit (CPU)

The TMS320C40 has a register-based CPU architecture. The CPU comprises the following components:

- Floating-point/integer multiplier
- ALU for performing arithmetic: floating-point, integer, and logical operations
- 32-bit barrel shifter
- □ Internal buses (CPU1/CPU2 and REG1/REG2)
- Auxiliary register arithmetic units (ARAUs)
- CPU register file

Figure 2–2 shows the various CPU components that are discussed in the succeeding subsections.

#### 2.1.1 Multiplier

The multiplier performs single-cycle multiplications on 32-bit integer and 40-bit floating-point values. The TMS320C40 implementation of floating-point arithmetic allows for floating-point operations at fixed-point speeds via a 40-ns instruction cycle and a high degree of parallelism. To gain even higher throughput, you can use parallel instructions to perform a multiply and ALU operation in a single cycle.

When the multiplier performs floating-point multiplication, the inputs are 40-bit floating-point numbers, and the result is a 40-bit floating-point number. When the multiplier performs integer multiplication, the input data is 32 bits and yields either the 32 most significant bits or 32 least significant bits of the resulting 64-bit product. Refer to Chapter 4 for detailed information on data formats and floating-point operation.

#### 2.1.2 Arithmetic Logic Unit (ALU)

The ALU performs single-cycle operations on 32-bit integer, 32-bit logical, and 40-bit floating-point data, including single-cycle integer and floating-point conversions. Results of the ALU are always maintained in 32-bit integer or 40-bit floating-point formats. The barrel shifter is used to shift up to 32 bits left or right in a single cycle.

Internal buses, CPU1/CPU2 and REG1/REG2, carry two operands from memory and two operands from the register file, thus allowing parallel multiplies and adds/subtracts on four integer or floating-point operands in a single cycle.

Figure 2–2. Central Processing Unit (CPU)



\* Disp = an 8-bit integer displacement carried in a program control instruction

#### 2.1.3 Auxiliary Register Arithmetic Units (ARAUs)

Two auxiliary register arithmetic units (ARAU0 and ARAU1) can generate two addresses in a single cycle. The ARAUs operate in parallel with the multiplier and ALU. They support addressing with displacements, index registers (IR0 and IR1), and circular and bit-reversed addressing. Refer to Chapter 5 for a description of addressing modes.

#### 2.1.4 CPU Primary Register File

The TMS320C40 primary register file provides 32 registers in a multiport register file that is tightly coupled to the CPU. Table 2–1 lists register names and functions, followed by the section number and page of each description. (The expansion register file is described in subsection 2.1.5 on page 2-9.)

All of the primary register file registers can be operated upon by the multiplier and ALU, and can be used as general-purpose registers. However, the registers also have some special functions. For example, the 12 extended-precision registers are especially suited for maintaining floating-point results. The eight auxiliary registers support a variety of indirect addressing modes and can be used as general-purpose 32-bit integer and logical registers. The remaining registers provide system functions such as addressing, stack management, processor status, interrupts, and block repeat. Refer to Chapter 3 for detailed information on the CPU registers. Refer to Chapter 5 for register usage in addressing.

The **extended-precision registers (R0–R11)** are capable of storing and supporting operations on 32-bit integer and 40-bit floating-point numbers. Any instruction that assumes the operands are floating-point numbers uses bits 39–0. If the operands are either signed or unsigned integers, only bits 31–0 are used, and bits 39–32 remain unchanged. This is true for all shift operations. Refer to Chapter 4 for extended-precision register formats for floating-point and integer numbers.

The 32-bit **auxiliary registers (AR0–AR7)** can be accessed by the CPU and modified by the two auxiliary register arithmetic units (ARAUs). The primary function of the auxiliary registers is the generation of 32-bit addresses. They can also be used as loop counters or as 32-bit general-purpose registers that can be modified by the multiplier and ALU. Refer to Chapter 5 for detailed information and examples of the use of auxiliary registers in addressing.

Table 2–1. CPU Primary Registers

| Assembler<br>Syntax                                  | Assigned Function Name                                                                                                                                                                                                                | For Fur<br>Descriptio<br>Paragraph                                                     |                                                             |
|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------|
| R0<br>R1<br>R2<br>R3<br>R4                           | Extended-precision register 0<br>Extended-precision register 1<br>Extended-precision register 2<br>Extended-precision register 3<br>Extended-precision register 4                                                                     | 3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1                                     | 3-4<br>3-4<br>3-4<br>3-4<br>3-4                             |
| R5<br>R6<br>R7<br>R8<br>R9<br>R10<br>R11             | Extended-precision register 5<br>Extended-precision register 6<br>Extended-precision register 7<br>Extended-precision register 8<br>Extended-precision register 9<br>Extended-precision register 10<br>Extended-precision register 11 | 3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1                   | 3-4<br>3-4<br>3-4<br>3-4<br>3-4<br>3-4<br>3-4<br>3-4        |
| AR0<br>AR1<br>AR2<br>AR3<br>AR4<br>AR5<br>AR6<br>AR7 | Auxiliary register 0<br>Auxiliary register 1<br>Auxiliary register 2<br>Auxiliary register 3<br>Auxiliary register 4<br>Auxiliary register 5<br>Auxiliary register 6<br>Auxiliary register 7                                          | 3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2 | 3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5 |
| DP<br>IR0<br>IR1<br>BK<br>SP                         | Data-page pointer<br>Index register 0<br>Index register 1<br>Block-size register<br>System stack pointer                                                                                                                              | 3.1.3<br>3.1.4<br>3.1.4<br>3.1.5<br>3.1.6                                              | 3-5<br>3-5<br>3-5<br>3-5<br>3-5                             |
| ST<br>DIE<br>IIE<br>IIF                              | Status register<br>DMA Coprocessor interrupt enable<br>Internal-interrupt enable register<br>IIOF flag register                                                                                                                       | 3.1.7<br>3.1.8<br>3.1.9<br>3.1.10                                                      | 3-5<br>3-8<br>3-10<br>3-12                                  |
| RS<br>RE<br>RC                                       | Repeat start address<br>Repeat end address<br>Repeat counter                                                                                                                                                                          | 3.1.11<br>3.1.11<br>3.1.11                                                             | 3-14<br>3-14<br>3-14                                        |

The **data page pointer (DP)** is a 32-bit register. The 16 LSBs of the data page pointer are used by the direct addressing mode as a pointer to the page of data being addressed. The 'C40 can address up to 64K pages, each page containing 64K words. The data page pointer is illustrated in Figure 5–1 on page 5-4.

The 32-bit **index registers** contain the value used by the auxiliary register arithmetic unit (ARAU) to compute an indexed address. Refer to Chapter 5 for examples of the use of index registers in addressing (see subsection 5.1.3, page 5-5, and Section 5.4, page 5-30.

The ARAU uses the 32-bit **block size register (BK)** in circular addressing to specify the data block size. (Circular addressing is described in Section 5.3 on page 5-25.)

The **system stack pointer (SP)** is a 32-bit register that contains the address of the top of the system stack. The SP always points to the last element pushed onto the stack. A push performs a preincrement, and a pop performs a postdecrement of the system stack pointer. The SP is manipulated by interrupts, traps, calls, returns, and the PUSH and POP instructions. Refer to Section 5.5, page 5-31, for information about system stack management.

The **status register (ST)** contains global information relating to the state of the CPU. Typically, operations set the condition flags of the status register according to whether the result is zero, negative, etc. This includes register load and store operations as well as arithmetic and logical functions. When the status register is loaded, however, a bit-for-bit replacement is performed with the contents of the source operand, regardless of the status of the status register are identically equal to the contents of the source operand. This allows the status register to be easily saved and restored. See Table 3–2 on page 3-6 for definitions of the status register bits.

The **DMA coprocessor interrupt enable register (DIE)** is a 32-bit register containing 2- and 3-bit fields to designate the interrupt synchronization scheme for each of the six DMA channels. It allows each DMA channel to service a corresponding input communication port and output communication port. Also, each DMA channel can be synchronized with external interrupts or the on-chip timers. This register is described in subsection 3.1.8 on page 3-8.

The **CPU internal interrupt enable register (IIE)** is also a 32-bit register (described in subsection 3.1.9 on page 3-10). This register enables/disables interrupts for the six communication ports, both timers, and the six DMA coprocessor channels.

The **IIOF flag register (IIF)** controls the function (general-purpose I/O or interrupt) of the four external pins (IIOF0 to IIOF3). Interrupts can be level or edge triggered. Subsection 3.1.10 on page 3-12 provides further description.

The 32-bit **repeat counter (RC)** register specifies the number of times a block of code is to be repeated when performing a block repeat. When the processor is operating in the repeat mode, the 32-bit **repeat start address register (RS)** contains the starting address of the block of program memory to be repeated, and the 32-bit **repeat end address register (RE)** contains the ending address of the block to be repeated. Further information is in subsection 3.1.11 on page 3-14.

The **program counter (PC)** is a 32-bit register containing the address of the next instruction to be fetched. Although the PC is not part of the CPU register

file, it is a register that can be modified by instructions that modify the program flow.

#### 2.1.5 CPU Expansion Register File

Besides the CPU primary register file (just covered in subsection 2.1.4, starting on page 2-6), the expansion register file contains two special registers that act as pointers:

- □ IVTP register (points to the interrupt-vector table, which is shown in Figure 3–8 on page 3-16),
- TVTP register (points to the trap vector table (TVT), which defines vectors for 512 interrupts. This is described in Figure 3–7 on page 3-15).

These two registers are fully described in Section 3.2 on page 3-15.

### 2.2 Memory Organization

The total memory reach of the TMS320C40 is 4G (giga or billion) 32-bit words (4 Gbytes). Program memory (on-chip RAM or ROM and external memory) as well as registers affecting timers, communication ports, and DMA channels are contained within this space. This allows tables, coefficients, program code, and data to be stored in either RAM or ROM. Thus, memory usage is maximized, and memory space allocated as desired.

By manipulating one external pin (ROMEN, pin AK4), the first one-megaword area of memory (0000 0000h to 000F FFFFh) can be configured to be part of the local address bus *or* configured to address the on-chip ROM when using the boot loader (with remaining space reserved). (This is further discussed in Section 3.4 on page 3-18.)

#### 2.2.1 RAM, ROM, and Cache

Figure 2–3 shows how the memory is organized on the TMS320C40. RAM blocks 0 and 1 are 4K bytes (1K x 32 bits) each. The ROM block is reserved and contains a boot loader. Each RAM and ROM block is capable of supporting two accesses in a single cycle. The separate program buses, data buses, and DMA buses allow for parallel program fetches, data reads and writes, and DMA operations. For example: the CPU can access two data values in one RAM block and perform an external program fetch in parallel with the DMA coprocessor loading another RAM block, all within a single cycle.

The reserved ROM block (upper right in Figure 2–3) contains a boot loader. This loader supports loading of program and data at reset time. Loading is from 8-, 16-, or 32-bit wide memories or any one of the six communication ports. Section 13.2 (page 13-5) explains the boot loader in detail.

A 128 x 32-bit instruction cache is provided to store often-repeated sections of code, thus greatly reducing the number of needed off-chip accesses. This allows for code to be stored off-chip in slower, lower-cost memories. The external buses are also freed for use by the DMA, external memory fetches, or other devices in the system.

For further information about the memory and instruction cache, refer to Section 3.4 (memory organization — page 3-18) and Section 3.5 (cache memory — page 3-25).





#### 2.2.2 Memory Maps

Two memory maps are available as shown in Figure 2–4; the one selected depends upon the level at external pin ROMEN. Both maps in the figure illustrate the 4-gigaword reach of the 'C40; however, they differ in the first 1 megaword of memory in which:

- A one at external pin ROMEN (pin AK4) causes internal ROM to be enabled at 0000h with the one-megaword space reserved (0000 0000h 000F FFFFh). This is shown in the right side of the figure.
- □ A zero at ROMEN causes addresses 0000 0000h 000F FFFFh to be accessible on the local bus. This is shown in the left side of the figure.

The rest of the memory map is the same for either level of ROMEN:

- The second megaword of memory is devoted to peripherals (as shown in Figure 2–5).
- The third megaword of memory contains the two 1K (4K-byte) blocks of RAM (BLK0 and BLK1 as shown at 002F F800h – 002F FFFFh).
- The rest of the first 2 gigawords (0030 0000h 7FFF FFFFh) is on the local bus (external).
- □ The second 2 gigawords (8000 0000h FFFF FFFFh) are on the global bus (external).

Section 3.4 (page 3-18) describes the memory maps in greater detail. Sections 7.1, 7.2, and 7.3, beginning on page 7-3, discuss the local and global interfaces to these memories. The peripheral bus map and the vector locations for reset, interrupts, and traps are also explained.



2-13

### Figure 2–5. Peripheral Memory Map

| 0010 0000h<br>0010 000Fh | Local and Global Port Control (16 words)<br>(See paragraph 3,4,2,1, Figure 3–11) |
|--------------------------|----------------------------------------------------------------------------------|
|                          |                                                                                  |
| 0010 0010h<br>0010 001Fh | Analysis Block Registers (16 words)<br>(See paragraph 3.4.2.2, Figure 3–12)      |
| 0010 0020h               | Timer () Bedisters (16 words)                                                    |
| 0010 002Fh               | Timer 0, Registers (16 words)<br>(See paragraph 3.4.2.3, Figure 3–13, page 3-22) |
| 0010 0030h               | Timer 1 Registers. (16 words)<br>(See paragraph 3.4:2:3, Figure 3–13, page 3-22) |
| 0010 003Fh               | (See paragraph 3.4.2.3, Figure 3-13, page 3-22)                                  |
| 0010 0040h               | Communication Port 0 (16 words)                                                  |
| 0010 004Fh               | (See paragraph 3.4.2.4, Figure 3–14, page 3-23)                                  |
| 0010 0050h               | Communication Port 1_(16 words)                                                  |
| 0010 005Fh               | (See paragraph 3.4.2.4, Figure 3–14, page 3-23)                                  |
| 0010 0060h               | Communication Port 2_(16 words)                                                  |
| 0010 006Fh               | (See paragraph 3.4.2.4, Figure 3–14, page 3-23)                                  |
| 0010 0070h               | Communication Port 3 (16 words)                                                  |
| 0010 007Fh               | (See paragraph 3.4.2.4, Figure 3-14, page 3-23)                                  |
| 0010 0080h               | Communication Port 4_(16 words)                                                  |
| 0010 008Fh               | (See paragraph 3.4.2.4, Figure 3–14, page 3-23)                                  |
| 0010 0090h               | Communication Port 5 (16 words)                                                  |
| 0010 009Fh               | (See paragraph 3.4.2.4, Figure 3–14, page 3-23)                                  |
| 0010 00A0h               | DMA Coprocessor Channel 0 (16 words)                                             |
| 0010 00AFh               | (See paragraph 3.4.2.5, Figure 3–15, page 3-24.)                                 |
| 0010 00B0h               | DMA Coprocessor Channel 1 (16 words)                                             |
| 0010 00BFh               | (See paragraph 3.4.2.5, Figure 3–15, page 3-24.)                                 |
| 0010 00C0h               | DMA Coprocessor Channel 2 (16 words)                                             |
| 0010 00CFh               | (See paragraph 3.4.2.5, Figure 3–15, page 3-24.)                                 |
| 0010 00006               | DMA Coprocessor Channel 3 (16 words)                                             |
| 0010 00D0h<br>0010 00DFh | (See paragraph 3.4.2.5, Figure 3–15, page 3-24.)                                 |
|                          |                                                                                  |
| 0010 00E0h               | DMA Coprocessor Channel 4 (16 words)                                             |
| 0010 00EFh               | (See paragraph 3.4.2.5, Figure 3–15, page 3-24.)                                 |
| 0010 00F0h               | DMA Coprocessor Channel 5 (16 words)                                             |
| 0010 00FFh               | (See paragraph 3.4.2.5, Figure 3–15, page 3-24.)                                 |
|                          |                                                                                  |

### 2.2.3 Memory Addressing Modes

The TMS320C40 supports a base set of general-purpose instructions as well as arithmetic-intensive instructions that are particularly suited for digital signal processing and other numeric-intensive applications. Refer to Chapter 5 for detailed information on addressing.

Four groups of addressing modes are provided on the TMS320C40 (major headings below). Each group uses two or more of several different addressing types, as shown for each group in the following list:

- 1) General addressing modes:
  - Register. The operand is a CPU register.
  - Immediate. The operand is a 16-bit immediate value.
  - Direct. The operand is the contents of a 32-bit address (concatenation of 16 bits of the data page pointer and a 16-bit operand).
  - Indirect. A 32-bit auxiliary register indicates the address of the operand.
- 2) Three-operand addressing modes:
  - Register (same as for general addressing mode).
  - Indirect (same as for general addressing mode).
  - Immediate (same as for general addressing mode).
- 3) Parallel addressing modes:
  - Register. The operand is an extended-precision register.
  - Indirect (same as for general addressing mode).
- 4) Branch addressing modes:
  - Register (same as for general addressing mode).
  - PC-relative. A signed 16-bit displacement or a 24-bit displacement is added to the PC.

### 2.3 Instruction Set Summary

Table 2–2 lists the TMS320C40 instruction set in alphabetical order. Each table entry shows the instruction mnemonic, description, and operation. Refer to Chapter 11 for a functional listing of the instructions and individual instruction descriptions.

| Mnemonic | Description                               | Operation                                                                                                                                       |
|----------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| ABSF     | Absolute value of a floating-point number | $ src  \rightarrow Rn$                                                                                                                          |
| ABSI     | Absolute value of an integer              | $ src  \rightarrow \text{Dreg}$                                                                                                                 |
| ADDC     | Add integers with carry                   | $src$ + Dreg + C $\rightarrow$ Dreg                                                                                                             |
| ADDC3    | Add integers with carry (3-operand)       | $src1 + src2 + C \rightarrow Dreg$                                                                                                              |
| ADDF     | Add floating-point values                 | $src + Rn \rightarrow Rn$                                                                                                                       |
| ADDF3    | Add floating-point values (3-operand)     | $src1 + src2 \rightarrow Rn$                                                                                                                    |
| ADDI     | Add integers                              | $src$ + Dreg $\rightarrow$ Dreg                                                                                                                 |
| ADD13    | Add integers (3-operand)                  | $src1 + src2 + \rightarrow Dreg$                                                                                                                |
| AND      | Bitwise logical-AND                       | Dreg AND $src \rightarrow$ Dreg                                                                                                                 |
| AND3     | Bitwise logical-AND (3-operand)           | src1 AND src2 $\rightarrow$ Dreg                                                                                                                |
| ANDN     | Bitwise logical-AND with complement       | Dreg AND $\overline{src} \rightarrow$ Dreg                                                                                                      |
| ANDN3    | Bitwise logical-ANDN (3-operand)          | src1 AND $\overline{src2} \rightarrow \text{Dreg}$                                                                                              |
| ASH      | Arithmetic shift                          | If count ≥ 0:<br>(Shifted Dreg left by count) → Dreg<br>Else:<br>(Shifted Dreg right by  count ) → Dreg                                         |
| ASH3     | Arithmetic shift (3-operand)              | If count $\ge$ 0:<br>(Shifted <i>src</i> left by count) $\rightarrow$ Dreg<br>Else:<br>(Shifted <i>src</i> right by  count ) $\rightarrow$ Dreg |

| Table 2–2. | Instruction Set | t Summarv |
|------------|-----------------|-----------|
|------------|-----------------|-----------|

#### LEGEND:

| src   | general addressing modes               | Dreg  | register address (any register)  |
|-------|----------------------------------------|-------|----------------------------------|
| src1  | three-operand addressing modes         | Rn    | register address (R0 — R11)      |
| src2  | three-operand addressing modes         | Daddr | destination memory address       |
| Csrc  | conditional-branch addressing modes    | ARn   | auxiliary register n (AR0 - AR7) |
| Sreg  | register address (any register)        | cond  | condition code (see Table 11-8)  |
| count | shift value (general addressing modes) | ST    | status register                  |
| SP    | stack pointer                          | RE    | repeat interrupt register        |
| GIE   | global interrupt enable register       | RS    | repeat start register            |
| RM    | repeat mode bit                        | PC    | program counter                  |
| TOS   | top of stack                           | С     | carry bit                        |

Architectural Overview

### Table 2–2.Instruction Set Summary (Continued)

| Mnemonic         | Description                                       | Operation                                                                                                                                                                                                                                                                       | 2 |
|------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Bcond            | Branch conditionally (standard)                   | If cond = true:<br>If Csrc is a register, $Csrc \rightarrow PC$<br>If Csrc is a value, $Csrc + PC + 1 \rightarrow PC$<br>Else: $PC + 1 \rightarrow PC$                                                                                                                          |   |
| B <i>cond</i> AF | Branch conditionally delayed and annul if false   | If cond is true:<br>If src is a register:<br>$src \rightarrow PC$<br>If src is a displacement:<br>$src + PC$ of branch + 3 $\rightarrow PC$<br>Else: If cond is false, annul execute phase re-<br>sults of next 3 instructions and continue                                     |   |
| B <i>cond</i> AT | Branch conditionally delayed and annul if<br>true | If cond is true:<br>If src is a register:<br>$src \rightarrow PC$<br>annul execute phase results of next 3<br>instructions<br>If src is a displacement:<br>$src + PC$ of branch + 3 $\rightarrow$ PC<br>annul execute phase results of next 3<br>instructions<br>Else: continue |   |
| BcondD           | Branch conditionally (delayed)                    | If cond = true:<br>If Csrc is a register, Csrc $\rightarrow$ PC<br>If Csrc is a value, Csrc + PC + 3 $\rightarrow$ PC<br>Else: PC + 1 $\rightarrow$ PC                                                                                                                          |   |
| BR               | Branch unconditionally (standard)                 | $Csrc + PC + 1 \rightarrow PC$                                                                                                                                                                                                                                                  | • |
| BRD              | Branch unconditionally (delayed)                  | $Csrc + PC + 3 \rightarrow PC$                                                                                                                                                                                                                                                  |   |
| CALL             | Call subroutine                                   | $PC + 1 \rightarrow TOS$<br>$Csrc + PC + 1 \rightarrow PC$                                                                                                                                                                                                                      |   |
| CALLcond         | Call subroutine conditionally                     | If cond = true:<br>PC + 1 $\rightarrow$ TOS<br>If Csrc is a register, Csrc $\rightarrow$ PC<br>If Csrc is a value, Csrc + PC $\rightarrow$ PC<br>Else: PC + 1 $\rightarrow$ PC                                                                                                  |   |
| CMPF             | Compare floating-point values                     | Set flags on Rn – <i>src</i>                                                                                                                                                                                                                                                    |   |
| CMPF3            | Compare floating-point values<br>(3-operand)      | Set flags on <i>src</i> 1 – <i>src</i> 2                                                                                                                                                                                                                                        |   |
| CMPI             | Compare integers                                  | Set flags on Dreg – <i>src</i>                                                                                                                                                                                                                                                  |   |
| CMPI3            | Compare integers (3-operand)                      | Set flags on <i>src</i> 1 – <i>src</i> 2                                                                                                                                                                                                                                        |   |
| DBcond           | Decrement and branch conditionally<br>(standard)  | ARn – 1 → ARn<br>If <i>cond</i> = true and ARn ≥ 0:<br>If <i>Csrc</i> is a register, <i>Csrc</i> → PC<br>If <i>Csrc</i> is a value, <i>Csrc</i> + PC + 1 → PC<br>Else: PC + 1 → PC                                                                                              |   |

### Table 2–2. Instruction Set Summary (Continued)

2

| Mnemonic        | Description                                                         | Operation                                                                                                                                                                                                                                                     |
|-----------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DB <i>condD</i> | Decrement and branch conditionally<br>(delayed)                     | ARn – 1 → ARn<br>If <i>cond</i> = true and ARn ≥ 0:<br>If <i>Csrc</i> is a register, <i>Csrc</i> → PC<br>If <i>Csrc</i> is a value, <i>Csrc</i> + PC + 3 → PC<br>Else: PC + 1 → PC                                                                            |
| FIX             | Convert floating-point value to integer                             | Fix ( <i>src</i> ) $\rightarrow$ Dreg                                                                                                                                                                                                                         |
| FLOAT           | Convert integer to floating-point value                             | $Float(src) \rightarrow Rn$                                                                                                                                                                                                                                   |
| FRIEEE          | Convert from IEEE format                                            | Convert <i>src</i> from IEEE format $\rightarrow$ Dreg                                                                                                                                                                                                        |
| IACK            | Interrupt acknowledge                                               | Perform a dummy read with $\overline{IACK} = 0$<br>At end of dummy read, set IACK = 0                                                                                                                                                                         |
| IDLE            | Idle until interrupt                                                | PC + 1 $\rightarrow$ PC, then Idle until next interrupt                                                                                                                                                                                                       |
| LATcond         | Link and trap conditionally                                         | If cond is true:<br>$ST(GIE) \rightarrow ST(PGIE)$<br>$ST(CF) \rightarrow ST(PCF)$<br>$0 \rightarrow ST(GIE)$<br>$1 \rightarrow ST(CF)$<br>PC of LAcond + 4 $\rightarrow$ R11<br>trap vector N $\rightarrow$ PC<br>Else: continue                             |
| LAJ             | Link and jump                                                       | $PC + 4 \rightarrow R11$ $PC \text{ of } LAJ + 3 + src \rightarrow PC$                                                                                                                                                                                        |
| LAJcond         | Link and jump conditional                                           | If cond is true and src is a gegister:<br>PC of LAJcond + 4 $\rightarrow$ R11 & src $\rightarrow$ PC<br>If cond is true and src is a displacement::<br>PC of LAJcond + 4 $\rightarrow$ R11, & src + PC of<br>LAJcond + 3 + $\rightarrow$ PC<br>Else, continue |
| LBb             | Load byte                                                           | Sgn extended byte (byte 3,2,1,0) of $src \rightarrow Dreg$                                                                                                                                                                                                    |
| LBUb            | Load byte unsigned                                                  | Unsigned byte (byte 3,2,1,0) of $src \rightarrow Dreg$                                                                                                                                                                                                        |
| LDA             | Load address register                                               | $src \rightarrow Dreg$                                                                                                                                                                                                                                        |
| LDE             | Load floating-point exponent                                        | <i>src</i> (exponent) $\rightarrow$ Rn(exponent)                                                                                                                                                                                                              |
| LDEP            | Load integer from exppansion register file to primary register file | $src \rightarrow Dreg$                                                                                                                                                                                                                                        |

#### LEGEND:

| EGEND:<br>SrC<br>SrC1<br>SrC2<br>CsrC<br>Sreg<br>Count<br>SP<br>GIE<br>BM | general addressing modes<br>three-operand addressing modes<br>three-operand addressing modes<br>conditional-branch addressing modes<br>register address (any register)<br>shift value (general)addressing modes)<br>stack pointer<br>global interrupt enable register | Dreg<br>Rn<br>Daddr<br>ARn<br>cond<br>ST<br>RE<br>RS<br>RS | register address (any register)<br>register address (R0 — R11)<br>destination memory address<br>auxiliary register n (AR0 — AR7)<br>condition code (see Table 11–8)<br>status register<br>repeat interrupt register<br>repeat start register |
|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GIE<br>RM                                                                 | global interrupt enable register<br>repeat mode bit                                                                                                                                                                                                                   | RS<br>PC                                                   | repeat start register<br>program counter                                                                                                                                                                                                     |
| TOS                                                                       | top of stack                                                                                                                                                                                                                                                          | . •                                                        | P.09                                                                                                                                                                                                                                         |

Architectural Overview

| Mnemonic | Description                                                        | Operation                                                                                                                                          |
|----------|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| LDF      | Load floating-point value                                          | $src \rightarrow Rn$                                                                                                                               |
| LDFcond  | Load floating-point value conditionally                            | If <i>cond</i> = true, <i>src</i> $\rightarrow$ Rn<br>Else: Rn is not changed                                                                      |
| LDFI     | Load floating-point value, interlocked                             | Signal interlocked operation $src \rightarrow Rn$                                                                                                  |
| LDHI     | Load 16 MSBs with 16-bit immediate                                 | $src \rightarrow 16$ MSBs of Dreg                                                                                                                  |
| LDI      | Load integer                                                       | $src \rightarrow Dreg$                                                                                                                             |
| LDIcond  | Load integer conditionally                                         | If $cond = true, src \rightarrow Dreg$<br>Else: Dreg is not changed                                                                                |
| LDII     | Load integer, interlocked                                          | Signal interlocked operation $src \rightarrow$ Dreg                                                                                                |
| LDM      | Load floating-point mantissa                                       | <i>src</i> (mantissa) $\rightarrow$ Rn (mantissa)                                                                                                  |
| LDP      | Load data page pointer                                             | src  ightarrow data page pointer                                                                                                                   |
| LDPE     | Load integer from primary register file to expansion register file | $src \rightarrow \text{Dreg}$                                                                                                                      |
| LDPK     | Load data page pointer immediate                                   | $src \rightarrow \text{DP}$                                                                                                                        |
| LHw      | Load half word                                                     | Sign-extended half word of $src \rightarrow Dreg$                                                                                                  |
| LHUw     | Load half word unsigned                                            | Unsigned half word of $src \rightarrow Dreg$                                                                                                       |
| LSH      | Logical shift                                                      | If count ≥ 0:<br>(Dreg left-shifted by count) → Dreg<br>Else:<br>(Dreg right-shifted by  count ) → Dreg                                            |
| LSH3     | Logical shift (3-operand)                                          | If count $\geq$ 0:<br>( <i>src</i> left-shifted by count) $\rightarrow$ Dreg<br>Else:<br>( <i>src</i> right-shifted by  count ) $\rightarrow$ Dreg |
| LWLct    | Load word, left shifted                                            | src << (0,1,2,3) bytes and merged with Dreg $\rightarrow$ Dreg                                                                                     |
| LWRct    | Load word, right shifted                                           | src>> (0,1,2,3) bytes and merged with Dreg $\rightarrow$ Dreg                                                                                      |
| MBct     | Merge byte, left shifted                                           | 8 LSBs of src << (0,1,2,3) bytes and merged with Dreg $\rightarrow$ Dreg                                                                           |
| MHct     | Merge half word, left shifted                                      | 16 LSBs of src << (0,1) half words and merged with Dreg $\rightarrow$ Dreg                                                                         |
| MPYF     | Multiply floating-point values                                     | $src \times Rn \rightarrow Rn$                                                                                                                     |
| MPYF3    | Multiply floating-point value (3-operand)                          | $src1 \times src2 \rightarrow Rn$                                                                                                                  |
| MPYI     | Multiply integers                                                  | $src \times Dreg \rightarrow Dreg$                                                                                                                 |
| MPYI3    | Multiply integers (3-operand)                                      | $src1 \times src2 \rightarrow Dreg$                                                                                                                |

Table 2–2.Instruction Set Summary (Continued)

| Table 2–2. | Instruction Set Summary | (Continued) |
|------------|-------------------------|-------------|
|            |                         |             |

| Mnemonic         | Description                                               | Operation                                                                   |
|------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------|
| MPYSHI           | Multiply signed integer and produce 32<br>MSBs            | dst 	imes src  ightarrow Dreg                                               |
| MPYSHI3          | Multiply signed integer and produce 32<br>MSBs, 3 operand | $src1 	imes src2 \rightarrow \text{Dreg}$                                   |
| MPYUHI           | Multiply unsigned integer and produce 32 MSBs             | $Dreg \times src \rightarrow Dreg$                                          |
| МРҮՍНІЗ          | Multiply unsigned integer and produce 32 MSBs, 3 operand  | $src1 	imes src2 \rightarrow Dreg$                                          |
| NEGB             | Negate integer with borrow                                | $0 - src - C \rightarrow Dreg$                                              |
| NEGF             | Negate floating-point value                               | $0 - src \rightarrow Rn$                                                    |
| NEGI             | Negate integer                                            | $0 - src \rightarrow Dreg$                                                  |
| NOP              | No operation                                              | Modify ARn if specified                                                     |
| NORM             | Normalize floating-point value                            | Normalize ( <i>src</i> ) $\rightarrow$ Rn                                   |
| NOT              | Bitwise logical-complement                                | $\overline{src} \rightarrow \text{Dreg}$                                    |
| OR               | Bitwise logical-OR                                        | Dreg OR $src \rightarrow$ Dreg                                              |
| OR3              | Bitwise logical-OR (3-operand)                            | src1 OR src2 $\rightarrow$ Dreg                                             |
| POP              | Pop integer from stack                                    | *SP- – $\rightarrow$ Dreg                                                   |
| POPF             | Pop floating-point value from stack                       | *SP→Rn                                                                      |
| PUSH             | Push integer on stack                                     | Sreg $\rightarrow$ *++ SP                                                   |
| PUSHF            | Push floating-point value on stack                        | Rn → *++ SP                                                                 |
| RCPF             | Reciprocal floating point                                 | 16-bit reciprocal of $src \rightarrow dst$                                  |
| RETS <i>cond</i> | Return from subroutine conditionally                      | If <i>cond</i> = true or missing:<br>*SP $\rightarrow$ PC<br>Else: continue |
| RND              | Round floating-point value                                | Round ( <i>src</i> ) $\rightarrow$ Rn                                       |

### LEGEND:

| EGEND: |                                        |       |                                  |
|--------|----------------------------------------|-------|----------------------------------|
| src    | general addressing modes               | Dreg  | register address (any register)  |
| src1   | three-operand addressing modes         | Rn    | register address (R0 - R11)      |
| src2   | three-operand addressing modes         | Daddr | destination memory address       |
| Csrc   | conditional-branch addressing modes    | ARn   | auxiliary register n (AR0 - AR7) |
| Sreg   | register address (any register)        | cond  | condition code (see Table 11-8)  |
| count  | shift value (general addressing modes) | ST    | status register                  |
| SP     | stack pointer                          | RE    | repeat interrupt register        |
| GIE    | global interrupt enable register       | RS    | repeat start register            |
| RM     | repeat mode bit                        | PC    | program counter                  |
| TOS    | top of stack                           | С     | carry bit                        |
|        |                                        |       |                                  |

2-20

Architectural Overview

| Mnemonic | Description                               | Operation                                                                                                                                                                                        |
|----------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ROL      | Rotate left                               | Dreg rotated left 1 bit $ ightarrow$ Dreg                                                                                                                                                        |
| ROLC     | Rotate left through carry                 | Dreg rotated left 1 bit through carry $ ightarrow$ Dreg                                                                                                                                          |
| ROR      | Rotate right                              | Dreg rotated right 1 bit $\rightarrow$ Dreg                                                                                                                                                      |
| RORC     | Rotate right through carry                | Dreg rotated right 1 bit through carry $ ightarrow$ Dreg                                                                                                                                         |
| RPTB     | Repeat block of instructions              | $src \rightarrow RE$<br>1 $\rightarrow$ ST (RM)<br>Next PC $\rightarrow$ RS                                                                                                                      |
| RPTBD    | Repeat block delayed                      | If <i>src</i> is an immediate value (displacement)<br><i>src</i> + PC +3 $\rightarrow$ RE<br>Else:<br><i>src</i> $\rightarrow$ RE<br>1 $\rightarrow$ ST (RM)<br>PC of RPTBD + 4 $\rightarrow$ RS |
| RPTS     | Repeat single instruction                 | $src \rightarrow RC$<br>$1 \rightarrow ST (RM)$<br>Next PC $\rightarrow RS$<br>Next PC $\rightarrow RE$                                                                                          |
| RSQRF    | Reciprocal of square root floating point  | 16-bit reciprocal of square root of $src \rightarrow Dreg$                                                                                                                                       |
| SIGI     | Signal, interlocked                       | Signal interlocked operation<br>Wait for interlock acknowledge<br>Clear interlock                                                                                                                |
| STF      | Store floating-point value                | $Rn \rightarrow Daddr$                                                                                                                                                                           |
| STFI     | Store floating-point value, interlocked   | $Rn \rightarrow Daddr$<br>Signal end of interlocked operation                                                                                                                                    |
| STI      | Store integer                             | Sreg $\rightarrow$ Daddr                                                                                                                                                                         |
| STII     | Store integer, interlocked                | Sreg $\rightarrow$ Daddr<br>Signal end of interlocked operation                                                                                                                                  |
| STIK,    | Store integer immediate value             | $src \rightarrow Dreg$                                                                                                                                                                           |
| SUBB     | Subtract integers with borrow             | $Dreg - src - C \rightarrow Dreg$                                                                                                                                                                |
| SUBB3    | Subtract integers with borrow (3-operand) | $src1 - src2 - C \rightarrow Dreg$                                                                                                                                                               |
| SUBC     | Subtract integers conditionally           | If Dreg – $src \ge 0$ :<br>[(Dreg – $src$ ) << 1] OR 1 → Dreg<br>Else: Dreg << 1 → Dreg                                                                                                          |

 Table 2–2.
 Instruction Set Summary (Continued)

| Mnemonic         | Description                                | Operation                                                                                                                                          |
|------------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| SUBF             | Subtract floating-point values             | $Rn - src \rightarrow Rn$                                                                                                                          |
| SUBF3            | Subtract floating-point values (3-operand) | $src1 - src2 \rightarrow Rn$                                                                                                                       |
| SUBI             | Subtract integers                          | $Dreg - src \rightarrow Dreg$                                                                                                                      |
| SUB13            | Subtract integers (3-operand)              | $src1 - src2 \rightarrow Dreg$                                                                                                                     |
| SUBRB            | Subtract reverse integer with borrow       | $src$ – Dreg – C $\rightarrow$ Dreg                                                                                                                |
| SUBRF            | Subtract reverse floating-point value      | $src - Rn \rightarrow Rn$                                                                                                                          |
| SUBRI            | Subtract reverse integer                   | $src$ – Dreg $\rightarrow$ Dreg                                                                                                                    |
| SWI              | Software interrupt                         | Perform emulator interrupt sequence                                                                                                                |
| TOIEEE           | Convert to IEEE format                     | Convert <i>src</i> to IEEE format $\rightarrow dst$                                                                                                |
| TRAP <i>cond</i> | Trap conditionally                         | If <i>cond</i> = true or missing:<br>Next PC $\rightarrow$ * ++ SP<br>Trap vector N $\rightarrow$ PC<br>0 $\rightarrow$ ST (GIE)<br>Else: continue |
| TSTB             | Test bit fields                            | Dreg AND src                                                                                                                                       |
| ТЅТВЗ            | Test bit fields (3-operand)                | src1 AND src2                                                                                                                                      |
| XOR              | Bitwise exclusive-OR                       | Dreg XOR $src \rightarrow$ Dreg                                                                                                                    |
| XOR3             | Bitwise exclusive-OR (3-operand)           | src1 XOR src2 → Dreg                                                                                                                               |

### Table 2–2. Instruction Set Summary (Concluded)

#### LEGEND:

| general addressing modes               | Dreg                                                                                                                                                                                                                                                         | register address (any register)                                                                                                                                                                                                                                        |
|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| three-operand addressing modes         | Rn                                                                                                                                                                                                                                                           | register address (R0 R11)                                                                                                                                                                                                                                              |
|                                        | Daddr                                                                                                                                                                                                                                                        | destination memory address                                                                                                                                                                                                                                             |
|                                        | ARn                                                                                                                                                                                                                                                          | auxiliary register n (AR0 — AR7)                                                                                                                                                                                                                                       |
|                                        | addr                                                                                                                                                                                                                                                         | 24-bit immediate address (label)                                                                                                                                                                                                                                       |
| shift value (general addressing modes) | cond                                                                                                                                                                                                                                                         | condition code (see Table 11–8)                                                                                                                                                                                                                                        |
| stack pointer                          | ST                                                                                                                                                                                                                                                           | status register                                                                                                                                                                                                                                                        |
| global interrupt enable register       | RE                                                                                                                                                                                                                                                           | repeat interrupt register                                                                                                                                                                                                                                              |
| repeat mode bit                        | RS                                                                                                                                                                                                                                                           | repeat start register                                                                                                                                                                                                                                                  |
| top of stack                           | PC                                                                                                                                                                                                                                                           | program counter                                                                                                                                                                                                                                                        |
| •                                      | С                                                                                                                                                                                                                                                            | carry bit                                                                                                                                                                                                                                                              |
|                                        | three-operand addressing modes<br>three-operand addressing modes<br>conditional-branch addressing modes<br>register address (any register)<br>shift value (general addressing modes)<br>stack pointer<br>global interrupt enable register<br>repeat mode bit | three-operand addressing modesRnthree-operand addressing modesDaddrconditional-branch addressing modesARnregister address (any register)addrshift value (general addressing modes)condstack pointerSTglobal interrupt enable registerRErepeat mode bitRStop of stackPC |

| Mnemonic                                    | Description                        | Operation                                                                                                                                                                        |  |  |
|---------------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Parallel Arithmetic With Store Instructions |                                    |                                                                                                                                                                                  |  |  |
| ABSF<br>   STF                              | Absolute value of a floating-point | $ src2  \rightarrow dst1$<br>   src3 $\rightarrow$ dst2                                                                                                                          |  |  |
| ABSI<br>   STI                              | Absolute value of an integer       | $ src2  \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                                                                                                          |  |  |
| ADDF3<br>   STF                             | Add floating-point                 | $src1 + src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                                                                                                     |  |  |
| ADDI3<br>   STI                             | Add integer                        | $src1 + src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                                                                                                     |  |  |
| AND3<br>   STI                              | Bitwise logical-AND                | src1 AND src2 $\rightarrow$ dst1<br>   src3 $\rightarrow$ dst2                                                                                                                   |  |  |
| ASH3                                        | Arithmetic shift                   | If count $\geq$ 0:<br>$src2 \ll \text{count} \rightarrow dst1$<br>$   src3 \rightarrow dst2$<br>Else:<br>$src2 >>  \text{count}  \rightarrow dst1$<br>$   src3 \rightarrow dst2$ |  |  |
| FIX<br>   STI                               | Convert floating-point to integer  | $Fix(src2) \rightarrow dst1$    src3 $\rightarrow$ dst2                                                                                                                          |  |  |
| FLOAT<br>   STF                             | Convert integer to floating-point  | Float(src2) $\rightarrow$ dst1<br>   src3 $\rightarrow$ dst2                                                                                                                     |  |  |
| FRIEEE<br>   STF                            | Parallel FRIEEE and STF            | Convert <i>src2</i> from IEEE format $\rightarrow$ <i>dst1</i><br>in parallel with <i>src3</i> $\rightarrow$ <i>dst2</i>                                                         |  |  |
| LDF<br>   STF                               | Load floating-point                | $src2 \rightarrow dst1$<br>   src3 $\rightarrow dst2$                                                                                                                            |  |  |
| LDI<br>   STI                               | Load integer                       | $src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                                                                                                            |  |  |
| LSH3                                        | Logical shift                      | If count $\geq$ 0:<br>$src2 \ll \text{count} \rightarrow dst1$<br>$   src3 \rightarrow dst2$<br>Else:<br>$src2 >>  \text{count}  \rightarrow dst1$<br>$   src3 \rightarrow dst2$ |  |  |

Table 2–3.Parallel Instruction Set Summary

#### **LEGEND** (for parallel instructions):

| src1 | register addr (R0 — R11)   | src2 | indirect addr (disp = 0, 1, IR0, IR1)    |
|------|----------------------------|------|------------------------------------------|
| src3 | register addr (R0 — R11)   | src4 | indirect addr (disp = $0, 1, IR0, IR1$ ) |
| dst1 | register addr (R0 — R11)   | dst2 | indirect addr (disp = 0, 1, IR0, IR1)    |
| ор3  | - register addr (R0 or R1) | op6  | register addr (R2 or R3)                 |

op1,op2,op4,op5 - Two of these operands must be specified using register addr, and two must be specified using indirect.

| Mnemonic        | Description                           | Operation                                                                                             |
|-----------------|---------------------------------------|-------------------------------------------------------------------------------------------------------|
| MPYF3<br>   STF | Multiply floating-point and store     | $src1 \times src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                     |
| MPYI3<br>   STI | Multiply integer                      | $src1 \times src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                     |
| NEGF<br>   STF  | Negate floating-point                 | $\begin{array}{l} 0- \ src2 \rightarrow dst1 \\    \ src3 \rightarrow dst2 \end{array}$               |
| TOIEE<br>   STF | Convert to IEEE floating point format | convert <i>src2</i> to IEEE format $\rightarrow$ <i>dst1</i>    <i>src3</i> $\rightarrow$ <i>dst2</i> |
|                 | Parallel Arithmetic With Store Inst   | tructions (Concluded)                                                                                 |
| NEGI<br>   STI  | Negate integer                        | $\begin{array}{c} 0 - src2 \rightarrow dst1 \\    src3 \rightarrow dst2 \end{array}$                  |
| NOT<br>   STI   | Complement                            | $\overline{src1} \rightarrow dst1$    $src3 \rightarrow dst2$                                         |
| OR3<br>   STI   | Bitwise logical-OR                    | $src1 \text{ OR } src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                |
| STF<br>   STF   | Store floating-point                  | $src1 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                                 |
| STI<br>   STI   | Store integer                         | $src1 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                                 |
| SUBF3<br>   STF | Subtract floating-point               | $src1 - src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                          |
| SUBI3<br>   STI | Subtract integer                      | $src1 - src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                          |
| XOR3<br>   STI  | Bitwise exclusive-OR                  | $src1 \text{ XOR } src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                               |

 Table 2–3.
 Parallel Instruction Set Summary (Continued)

#### LEGEND (for parallel instructions):

| src1 | register addr (R0 - R11) |
|------|--------------------------|
| src3 | register addr (R0 — R11) |
| dott | register eddr /D0 D11)   |

dst1 register addr (R0 — R11) op3 register addr (R0 or R1) 
 src2
 indirectaddr (disp = 0, 1, IR0, IR1)

 src4
 indirect addr (disp = 0, 1, IR0, IR1)

 dst2
 indirect addr (disp = 0, 1, IR0, IR1)

 op6
 register addr (R2 or R3)

op1,op2,op4,op5 – Two of these operands must be specified using register addr, and two must be specified using indirect.

| Mnemonic          | Description                                     | Operation                                                                                                                           |  |  |
|-------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                   | Parallel Load Instru                            | ctions                                                                                                                              |  |  |
| LDF<br>   LDF     | Load floating-point                             | $src2 \rightarrow dst1$<br>   $src4 \rightarrow dst2$                                                                               |  |  |
| LDF<br>   STF     | Load floating point and store floating point    | $src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                                                               |  |  |
| LDI<br>   LDI     | Load integer                                    | src2 → dst1<br>   src4 → dst2                                                                                                       |  |  |
| LSH3<br>   STI    | Logical shift, 3 operand, and store integer     | If $count \ge 0$ :<br>$src2 << count \rightarrow dst1$<br>Else:<br>$src2 >>  count  \rightarrow dst1$<br>$   src3 \rightarrow dst2$ |  |  |
| LSH3<br>   STI    | Logical shift 3 and store integer               | $src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                                                               |  |  |
|                   | Parallel Multiply And Add/Subtract Instructions |                                                                                                                                     |  |  |
| MPYF3<br>   ADDF3 | Multiply and add floating-point                 | op1 x op2 → op3<br>   op4 + op5 → op6                                                                                               |  |  |
| MPYF3<br>   SUBF3 | Multiply and subtract floating-point            | op1 x op2 → op3<br>   op4 – op5 → op6                                                                                               |  |  |
| MPYI3<br>   ADDI3 | Multiply and add integer                        | op1 x op2 → op3<br>   op4 + op5 → op6                                                                                               |  |  |
| MPYI3<br>   SUBI3 | Multiply and subtract integer                   | op1 x op2 → op3<br>   op4 – op5 → op6                                                                                               |  |  |

Table 2–3.Parallel Instruction Set Summary (Concluded)

#### **LEGEND** (for parallel instructions):

| src1 | register addr (R0 - R11)   | src2 | indirectaddr (disp = 0, 1, IR0, IR1)  |
|------|----------------------------|------|---------------------------------------|
| src3 | register addr (R0 — R11)   | src4 | indirect addr (disp = 0, 1, IR0, IR1) |
| dst1 | register addr (R0 — R11)   | dst2 | indirect addr (disp = 0, 1, IR0, IR1) |
| op3  | - register addr (R0 or R1) | op6  | register addr (R2 or R3)              |

op1,op2,op4,op5 - Two of these operands must be specified using register addr, and two must be specified using indirect.

# 2.4 Internal Bus Operation

A large portion of the TMS320C40's high performance is due to internal busing and parallelism. Separate buses allow for parallel program fetches, data accesses, and DMA accesses:

- **program buses** PADDR and PDATA
- data buses DADDR1, DADDR2, and DDATA
- DMA buses DMAADDR and DMADATA

These buses connect all of the physical spaces (on-chip memory, off-chip memory, and on-chip peripherals) supported by the TMS320C40. Figure 2–3 shows these internal buses and their connection to on-chip and off-chip memory blocks.

The program counter (PC) is connected to the 32-bit program address bus (PADDR). The instruction register (IR) is connected to the 32-bit program data bus (PDATA). These buses can fetch a single instruction word every machine cycle.

The 32-bit data address buses (DADDR1 and DADDR2) and the 32-bit data data bus (DDATA) support two data memory accesses every machine cycle. The DDATA bus carries data to the CPU over the CPU1 and CPU2 buses. The CPU1 and CPU2 buses can carry two data memory operands to the multiplier, ALU, and register file every machine cycle. Also internal to the CPU are register buses REG1 and REG2, which can carry two data values from the register file to the multiplier and ALU every machine cycle. Figure 2–2 shows the buses internal to the CPU section of the processor.

The DMA controller is supported with a 32-bit address bus (DMAADDR) and a 32-bit data bus (DMADATA). These buses allow the DMA to perform memory accesses in parallel with the memory accesses occurring from the data and program buses.

# 2.5 External Bus Operation

The TMS320C40 provides two identical external interfaces: the global memory interface and the local memory interface. Each consists of a 32-bit data bus, a 31-bit address bus, and two sets of control signals. Both buses can be used to address external program/data memory or I/O space. The buses also have external RDY signals for wait-state generation with wait states inserted under software control. Chapter 7 covers external bus operation.

# 2.5.1 Interrupts

The TMS320C40 supports four external interrupts (IIOF3–0), a number of internal interrupts, a nonmaskable, external NMI interrupt, and a nonmaskable external RESET signal, which sets the processor to a known state. The DMA and communication ports have their own internal interrupts. When the CPU responds to the interrupt, the IACK pin can be used to signal an external interrupt acknowledge. Section 6.7 (beginning on page 6-23) covers RESET and interrupt processing.

# 2.5.2 Interlocked Instructions

In order for multiple processors to access global memory and share data in a coherent manner, arbitration is necessary. This arbitration (handshaking) is the purpose of the TMS320C40's interlocked operations, handled through the Interlocked instructions (explained in Section 6.4 on page 6-11).

# 2.6 Peripherals

2

All TMS320C40 peripherals are controlled through memory-mapped registers on a dedicated peripheral bus. This peripheral bus is composed of a 32-bit data bus and a 32-bit address bus. This peripheral bus permits straightforward communication to the peripherals. The TMS320C40 peripherals include two timers and two serial ports. Figure 2–6 shows the peripherals with associated buses and signals.



*Figure 2–6. Peripheral Modules* 

# 2.6.1 Communication Ports

Six high-speed communication ports provide rapid processor-to-processor communication through each port's dedicated communication interfaces. Coupled with the 'C40's two memory interfaces (global and local), this allows you to construct a parallel processor system that attains optimum system performance by the distributing of tasks among several processors. Each 'C40 can pass the results of its work to another, enabling each 'C40 to continue working. Chapter 8 explains communication port operation in detail.

Communication port features:

- 160-megabit per second (20-Mbytes or 5-Mwords per second) bidirectional data transfer operations (at 40-ns cycle time)
- direct (glueless) processor-to-processor communication via eight data lines and four control lines
- buffering of all data transfers, both input and output
- automatic arbitration provided to ensure communication synchronization
- synchronization between the CPU or direct-memory access (DMA) coprocessor and the six communication ports via internal interrupts and internal ready signals.

# 2.6.2 Direct Memory Access (DMA)

The six channels of the on-chip Direct Memory Access (DMA) coprocessor can read from or write to any location in the memory map without interfering with the operation of the CPU. This allows interfacing to slow external memories and peripherals without reducing throughput to the CPU. The DMA coprocessor contains its own address generators, source and destination registers, and transfer counter. Dedicated DMA address and data buses allow for minimization of conflicts between the CPU and the DMA coprocessor. A DMA operation consists of a block or single-word transfer to or from memory. A key feature of the DMA coprocessor is its ability to automatically reinitialize each channel following a data transfer. Refer to Chapter 9 for detailed information on the DMA coprocessor.

# 2.6.3 Timers

The two timer modules are general-purpose 32-bit timer/event counters with two signaling modes and internal or external clocking. They can signal internally to the 'C40 or externally to the outside world at specified intervals, or they can count external events. Each timer has an I/O pin that can be used as an input clock to the timer, as an output signal driven by the timer, or as a general-purpose I/O pin. Timers are described in detail in Section 9.10 on page 9-45.



# **CPU Registers, Memory, and Cache**

The CPU **primary register file** contains 32 registers that can be used as operands by the multiplier and ALU (arithmetic logic unit). The register file includes the auxiliary registers, extended-precision registers, and index registers. These registers support addressing, floating-point/integer operations, stack management, processor status, block repeats, branching, and interrupts.

The CPU **expansion register file** contains two registers — the interrupt vector table pointer (IVTP) and the trap vector table pointer (TVTP).

The TMS320C40 accesses a total memory space of 4G (giga = 1 billion) 32-bit words (16 gigabytes) of program, data, and I/O space. Two internal RAM blocks of  $1K \times 32$  bits each (4K bytes) and an internal ROM block containing a boot loader permit two accesses per block in a single cycle.

A 128  $\times$  32-bit instruction cache stores often-repeated sections of code. The cache greatly reduces the number of off-chip accesses, allowing code to be stored off-chip in slower, lower-cost memories without degrading performance. The cache also speeds data fetches to the same physical space as the program by not burdening the bus with program instruction fetches. Three bits in the CPU status register control the clear, enable, or freeze of the cache.

This chapter describes in detail each of the CPU registers, the memory maps, and the instruction cache. Major topics are as follows:

|     |                                         | <u> </u> |
|-----|-----------------------------------------|----------|
| 3.1 | CPU Primary Register File 3             | -3       |
|     | Extended-Precision Registers (R0–R11) 3 | -4       |
|     | Auxiliary Registers (AR0–AR7) 3         | -5       |
|     | Data-Page Pointer (DP) 3                | -5       |
|     | Index Registers (IR0, IR1)              | -5       |
|     | Block-Size Register (BK) 3              | -5       |
|     | System Stack Pointer (SP) 3             | -5       |
|     |                                         |          |

#### Section

3-1

Page

| 3 |  |  |
|---|--|--|

| Sectio | n in the second s | Page |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|        | Status Register (ST)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3-5  |
|        | ■ DMA Interrupt Enable Register (DIE)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 3-8  |
|        | Internal Interrupt Enable Register (IIE)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 3-10 |
|        | Interrupt Flag Register (IIF) Controls External Pins<br>IIOF(3 – 0),Timer/DMA Flags                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3-12 |
|        | <ul> <li>Block-Repeat (RS, RE) and<br/>Repeat-Count (RC) Registers</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 3-14 |
|        | Program Counter (PC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3-14 |
|        | Reserved Bits and Compatibility                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 3-14 |
| 3.2    | CPU Expansion Register File                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 3-15 |
|        | CPU Expansion Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 3-15 |
|        | Trap Vector Table (TVT)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 3-15 |
| 3.3    | Reset Vector Mapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3-17 |
| 3.4    | Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 3-18 |
|        | Memory Maps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 3-19 |
|        | Peripheral Bus Memory Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 3-20 |
| 3.5    | Instruction Cache Architecture                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3-25 |
|        | Cache Algorithm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 3-27 |
|        | Cache and System Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 3-28 |
|        | Cache Control Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 3-29 |

# 3.1 CPU Primary Register File

The TMS320C40 provides 32 registers in a multiport register file that is tightly coupled to the CPU. **The PC (program counter) is not included in the 32 registers.** The registers' names and assigned function are listed in Table 3–1.

All of these registers can be used as operands by the multiplier and ALU, and can be used as general-purpose 32-bit registers. However, the registers also have some special functions for which they are particularly appropriate. For example, the 12 extended-precision registers are especially

Table 3–1.CPU Primary Register File

| Assembler<br>Syntax                                  | Register<br>Machine<br>Value (hex)           | Assigned Function Name                                                                                                                                                                       | See<br>Paragraph                                                                       | On<br>Page                                                  |
|------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------|
| R0<br>R1                                             | 00<br>01                                     | Extended-precision register 0<br>Extended-precision register 1                                                                                                                               | 3.1.1<br>3.1.1                                                                         | 3-4<br>3-4                                                  |
| R2                                                   | 02                                           | Extended-precision register 2                                                                                                                                                                | 3.1.1                                                                                  | 3-4                                                         |
| R3<br>R4                                             | 03<br>04                                     | Extended-precision register 3<br>Extended-precision register 4                                                                                                                               | 3.1.1<br>3.1.1                                                                         | 3-4<br>3-4                                                  |
| R5                                                   | 05                                           | Extended-precision register 5                                                                                                                                                                | 3.1.1                                                                                  | 3-4                                                         |
| R6                                                   | 06                                           | Extended-precision register 6                                                                                                                                                                | 3.1.1                                                                                  | 3-4                                                         |
| R7                                                   | 07                                           | Extended-precision register 7                                                                                                                                                                | 3.1.1                                                                                  | 3-4                                                         |
| R8                                                   | 10                                           | Extended-precision register 8                                                                                                                                                                | 3.1.1                                                                                  | 3-4                                                         |
| R9<br>R10                                            | 1D<br>1E                                     | Extended-precision register 9<br>Extended-precision register 10                                                                                                                              | 3.1.1<br>3.1.1                                                                         | 3-4<br>3-4                                                  |
| R10                                                  | 1F                                           | Extended-precision register 11                                                                                                                                                               | 3.1.1                                                                                  | 3-4                                                         |
| AR0<br>AR1<br>AR2<br>AR3<br>AR4<br>AR5<br>AR6<br>AR7 | 08<br>09<br>0A<br>0B<br>0C<br>0D<br>0E<br>0F | Auxiliary register 0<br>Auxiliary register 1<br>Auxiliary register 2<br>Auxiliary register 3<br>Auxiliary register 4<br>Auxiliary register 5<br>Auxiliary register 6<br>Auxiliary register 7 | 3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2 | 3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5 |
| DP<br>IR0<br>IR1<br>BK<br>SP                         | 10<br>11<br>12<br>13<br>14                   | Data-page pointer<br>Index register 0<br>Index register 1<br>Block-size register<br>System stack pointer                                                                                     | 3.1.3<br>3.1.4<br>3.1.4<br>3.1.5<br>3.1.6                                              | 3-5<br>3-5<br>3-5<br>3-5<br>3-5                             |
| ST<br>DIE<br>IIE<br>IIF                              | 15<br>16<br>17<br>18                         | Status register<br>DMA coprocessor interrupt enable<br>Internal-interrupt enable register<br>IIOF flag register (IIOF3-0, timers, DMA)                                                       | 3.1.7<br>3.1.8<br>3.1.9<br>3.1.10                                                      | 3-5<br>3-8<br>3-10<br>3-12                                  |
| RS<br>RE<br>RC                                       | 19<br>1A<br>1B                               | Repeat start address<br>Repeat end address<br>Repeat counter                                                                                                                                 | 3.1.11<br>3.1.11<br>3.1.11                                                             | 3-14<br>3-14<br>3-14                                        |

well suited for maintaining extended-precision floating-point results. The eight auxiliary registers support a variety of indirect addressing modes and can be used as general-purpose 32-bit integer and logical registers. The remaining registers provide system functions such as addressing, stack management, processor status, interrupts, and block repeat. Refer to Chapter 5 for detailed information and examples of the use of CPU registers in addressing.

#### 3.1.1 Extended-Precision Registers (R0–R11)

The 12 extended-precision registers (R0–R11) can store and support operations on 32-bit integer and 40-bit floating-point numbers. These registers consist of two separate and distinct regions:

- bits 39–32: dedicated to storage of the exponent (*e*) of the floating-point number.
- bits 31–0: store the mantissa of the floating-point number:
  - bit 31: sign bit (s),
  - bits 30–0: the fraction (f).

Any instruction that assumes the operands are floating-point numbers uses bits 39–0. Figure 3–1 illustrates the storage of 40-bit floating-point numbers in the extended-precision registers.

#### Figure 3–1. Extended-Precision Register Floating-Point Format



For integer operations, bits 31–0 of the extended-precision registers contain the integer (signed or unsigned). Any instruction that assumes the operands are either signed or unsigned integers uses only bits 31–0. Bits 39–32 remain unchanged. This is true for all shift operations. The storage of 32-bit integers in the extended-precision registers is shown in Figure 3–2.

Figure 3–2. Extended-Precision Register Integer Format

| 39 32     | 31        |                  | 0 |
|-----------|-----------|------------------|---|
| unchanged | signed or | unsigned integer |   |

# 3.1.2 Auxiliary Registers (AR0–AR7)

The eight 32-bit auxiliary registers (AR0–AR7) can be accessed by the CPU and modified by the two auxiliary register arithmetic units (ARAUs). The primary function of the auxiliary registers is the generation of 32-bit addresses. However, they can also operate as loop counters in indirect addressing or as 32-bit general-purpose registers that can be modified by the multiplier and ALU. Refer to Chapter 5 for detailed information and examples of the use of auxiliary registers in addressing.

# 3.1.3 Data-Page Pointer (DP)

The data-page pointer (DP) is a 32-bit register whose 16 LSBs are used by the direct addressing mode as a pointer to the page of data being addressed. Data pages are 64K words long with a total of 64K (65,536) pages. Bits 31–16 are reserved; they are always read as zeroes and **should not be modified by writing to the register**. The DP can be loaded by using the LDP pseudo-instruction or the LDI instruction. Figure 5–1 on page 5-4 describes this register's function.

# 3.1.4 Index Registers (IR0, IR1)

The 32-bit index registers (IR0 and IR1) are used by the auxiliary register arithmetic unit (ARAU) for indexing the address. IR0 is also used for bit-reversed addressing. Refer to Chapter 5 for detailed information and examples of the use of index registers in addressing. (Subsection 5.1.3 on page 5-5 covers use of the IR in indirect addressing; see the examples starting on page 5-12. Section 5.4 on page 5-30 describes using it with bit-reversed addressing).

# 3.1.5 Block-Size Register (BK)

The 32-bit block-size register (BK) is used by the ARAU in circular addressing to specify the data block size (see Section 5.3 on page 5-25).

# 3.1.6 System Stack Pointer (SP)

The system stack pointer (SP) is a 32-bit register that contains the address of the top of the system stack. The SP always points to the last element pushed onto the stack. The SP is manipulated by interrupts, traps, calls, returns, and the PUSH, PUSHF, POP, and POPF instructions. Pushes and pops of the stack perform preincrement and postdecrement, respectively, on all 32 bits of the SP. Refer to Section 5.5 on page 5-31 for information about system stack management.

# 3.1.7 Status Register (ST)

The status register (ST) contains global information relating to the CPU state. Typically, operations set the condition flags of the status register ac-

cording to whether the result is zero, negative, etc. This includes register load and store operations as well as arithmetic and logical functions. However, when the ST is loaded, the contents of the load instruction's source operand replace the ST current contents bit for bit, regardless of the state of any bit(s) in the source operand. Therefore, following an ST load, the contents of the ST are identical to the contents of the source operand. This allows the status register to be saved easily and restored. At system reset, 0 is written to this register.

The format of the status register is shown in Figure 3–3. Table 3–2 defines the status register bits, their names, and functions.

Figure 3–3. Status Register

| 31  | 30   | 29  | 28  | 27   | 26  | 25  | 24  | 23  | 22  | 21  | 20   | 19  | 18  | 17  | 16   |
|-----|------|-----|-----|------|-----|-----|-----|-----|-----|-----|------|-----|-----|-----|------|
| XX  | xx   | xx  | xx  | xx   | xx  | xx  | xx  | xx  | xx  | XX  | xx   | xx  | xx  | xx  | Anyl |
| R   | R    | R   | R   | R    | R   | R   | R   | R   | R   | R   | R    | R   | R   | R   | R    |
| 15  | 14   | 13  | 12  | 11   | 10  | 9   | 8   | 7   | 6   | 5   | 4    | 3   | 2   | 1   | 0    |
| SC  | PGIE | GIE | сс  | ÇE   | CF  | PCF | RM  | OVM | LUF | LV  | UF   | N   | Z   | v   | С    |
| DAN | DAM  | DAN | DAM | DAAL | DAN | DAM | DAM | DAN | DAM | DAM | DAAL | DAM | DAM | DAM | DAM  |

R = read, W = write.

 Table 3–2.
 Status Register Bits Summary

| Bit | Bit Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0†  | С                 | Carry condition flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1†  | V                 | Overflow condition flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2†  | Z                 | Zero condition flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3†  | N                 | Negative condition flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4†  | UF                | Floating-point underflow condition flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5†  | LV                | Latched overflow condition flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6†  | LUF               | Latched floating-point underflow condition flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7   | OVM               | <ul> <li>Overflow mode flag. This flag affects only integer operations.</li> <li>If OVM = 0, the overflow mode is turned off; integer results that overflow are treated in no special way.</li> <li>If OVM = 1, <ul> <li>a) integer results overflowing in the positive direction are set to the most positive 32-bit twos-complement number (7FFF FFFFh).</li> <li>b) integer results overflowing in the negative direction are set to the most negative 32-bit twos-complement number (8000 0000h).</li> </ul> </li> <li>Note that the functions of bits V and LV are independent of the setting of OVM.</li> </ul> |
| 8   | RM                | Repeat mode flag. If RM = 1, the PC is being modified in either the repeat-<br>block or repeat-single mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

<sup>†</sup> The seven condition flags (ST bits 0 – 6) are defined in Section 11.2 on page 11-10.

| Bit     | Bit Field<br>Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9       | PCF               | Previous state of bit CF. When a trap executes or an interrupt is taken, bit CF is set to 1. When this occurs, the PCF bit is set to the CF bit's value before the trap or interrupt. Note that the RETI and RETID instructions copy PCF to the CF bit.                                                                                                                                                                                                                                                                                                                |
| . 10    | CF                | Cache freeze. Set CF = 1 to freeze cache (cache is not updated) including LRU (least recently used) stack manipulation. If the cache is enabled (CE = 1), fetches from the cache are allowed, but modification of the cache contents is not allowed. Cache clearing (CC=1) is allowed. At reset, this bit is set to zero. When CF=0, cache clearing (CC=1) is allowed. CF is set to one when a trap or interrupt is taken. Also, the RETI and RETID instructions copy PCF to the CF bit.                                                                               |
| 11      | CE                | Cache enable. Set CE = 1 to enable the cache, allowing the cache to be usedaccording to the LRU (least recently used) cache algorithm. Set CE = 0 to disablethe cache; preventing cache updates or modifications (thus, no cache fetchescan be made). At reset, 0 is written to this bit. Cache clearing (CC = 1) is allowedwhen CE=0. The following describe the combination of the CE and CF bits:CECF00Cache not enabled0110111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111 </td                                   |
| 12      | сс                | Cache clear. CC = 1 invalidates all entries in the cache (contents not guaranteed, "garbage"). This bit is always cleared after it is written to and thus always read as 0. At reset, 0 is written to this bit. All cache P flags = 0 when cache is cleared.                                                                                                                                                                                                                                                                                                           |
| 13      | GIE               | Global interrupt enable. If GIE = 1, the CPU responds to an enabled interrupt. If GIE = 0, the CPU does not respond to an enabled interrupt (when a trap executes or an interrupt is taken, bit GIE is set to 0). This bit does not affect interrupts on the NMI pin. The IDLE, LAT, RETI, RETID, and TRAP instructions affect this bit's value.                                                                                                                                                                                                                       |
| 14      | PGIE              | Previous state of bit GIE. When a trap executes or an interrupt is taken, bit GIE is set to 0. When this occurs, the PGIE bit is set to the GIE bit's value before the trap or interrupt. Note that the RETI <i>cond</i> and RETI <i>cond</i> D instructions copy PGIE to the GIE bit. At reset, this bit is set to 0.                                                                                                                                                                                                                                                 |
| 15      | SET COND          | <ul> <li>This bit determines how condition flags (ST bits 0 – 6) are set:</li> <li>If SET COND = 0, condition-flags are set if the operation's target is any extended-precision register (R0 – R11) compatible with the TMS320C30. This bit is set to 0 at reset.</li> <li>If SET COND = 1, condition flags are set if the target of the operation is <i>any</i> register in the primary register files <i>except</i> the status register.</li> <li>Condition flags are always set when a CMPF, CMPL, CMPF3, CMPI3, TSTB, or TSTB3 instruction is executed.</li> </ul> |
| 16      | ANALYSIS          | In analysis mode — state information for emulation. Read only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 17 – 31 | Reserved          | Value undefined. Read only. Reserved for an identification value. This value is set by Texas Instruments (e.g., to identify device types and revisions).                                                                                                                                                                                                                                                                                                                                                                                                               |

Table 3–2. Status Register Bits Summary (Continued)

# 3.1.8 DMA Coprocessor Interrupt Enable Register (DIE)

DMA Interrupt Enable Register Bit Functions

The 32-bit DMA interrupt enable register (DIE), shown in Figure 3–4, is broken into six subfields that determine which interrupts can be used to control the synchronization for each of the six DMA coprocessor channels. At reset, all zeroes are written to the register.

|   | •        |         |       | •    | •       |       |      |         |     |     |         |     |
|---|----------|---------|-------|------|---------|-------|------|---------|-----|-----|---------|-----|
|   | 31       |         | 29    | 28   |         | 26    | 25   |         | 23  | 22  |         | 20  |
|   | DN       | 1A5 WRI | TE    | D    | MA5 REA | ۱D    | DN   | /A4 WRI | TE  | DI  | MA4 REA | ١D  |
|   | R/W      | R/W     | R/W   | R/W  | R/W     | R/W   | R/W  | R/W     | R/W | R/W | R/W     | R/W |
|   | 19       |         | 17    | 16   |         | 14    | 13   |         | 11  | 10  |         | 8   |
|   | DN       | AA3 WRI | TE    | DI   | AA3 REA | AD .  | DN   | AA2 WRI | TE  | DI  | MA2 REA | D   |
|   | R/W      | R/W     | R/W   | R/W  | R/W     | R/W   | R/W  | R/W     | R/W | R/W | R/W     | R/W |
|   | 7        | 6       | 5     | 4    | 3       | 2     | 1    | 0       |     |     |         |     |
| • | DMA1     | WRITE   | DMA1  | READ | DMA0    | WRITE | DMA0 | READ    |     |     |         |     |
|   | R/W      | R/W     | R/W   | R/W  | R/W     | R/W   | R/W  | R/W     | -   |     |         |     |
| 1 | R = Read | d W=V   | Vrite |      |         |       |      |         |     |     |         |     |

Table 3–3 summarizes the interrupt activity for each of the four possible combinations of two-bit values in DMA0 and DMA1 (bottom of Figure 3–4). Likewise, Table 3–4 (page 3-9) summarizes the interrupts enabled by three-bit values in DMA2 through DMA5.

#### Note: DMA Coprocessor Uses Signals to Synchronize

The interrupts in Table 3–3 and Table 3–4 (ICRDYx, OCRDYx, TIM0, etc.) *are not vectored*. The DMA uses these as signals to synchronize DMA coprocessor transfers. This is explained in Section 9.9 on page 9-40.

3

Fiaure 3-4.

| Bit Value            | Interr        | upt Enabled   | at DMA0 or   | Interrupt Source for |                                |  |
|----------------------|---------------|---------------|--------------|----------------------|--------------------------------|--|
| (in DMA0<br>or DMA1) | DMA0<br>Read  | DMA0<br>Write | DMA1<br>Read | DMA1<br>Write        | DMA Synchronization            |  |
| 00                   | None          | None          | None         | None                 |                                |  |
| 01                   | ICRDY0        | OCRDY0        | ICRDY1       | OCRDY1               | From communication port        |  |
| 10                   | <b>IIOF</b> 0 | IIOF1         | IIOF2        | IIOF3                | From external pins IIOF0-IIOF3 |  |
| 11                   | TIMO          | TIMO          | TIMO         | TIMO                 | From timer TIM0                |  |

| Table 3–3. | DMA Channels 0 and 1 | Synchronization Interru | pts (DMA0 and DMA1) |
|------------|----------------------|-------------------------|---------------------|
|            |                      |                         |                     |

This interrupt synchronization scheme allows each DMA channel to service a corresponding input communication port and output communication port. Also, each DMA channel can be synchronized with external interrupts and the on-chip timers.

| Table 3–4. | DMA Channels 2 to 5 | Svnchronization | Interrupts | (DMA2 to DMA)5 |
|------------|---------------------|-----------------|------------|----------------|
|            |                     |                 |            |                |

| Bit Value        | Interrupt Enabled  | at DMA2–DMA5†       | Interrupt Source for      |  |  |  |
|------------------|--------------------|---------------------|---------------------------|--|--|--|
| (in DMA2 to DMA5 | †DMA <i>x</i> Read | †DMA <i>x</i> Write | DMA Synchronization       |  |  |  |
| 000              | None               | None                |                           |  |  |  |
| 001              | †ICRDY <i>x</i>    | †OCRDYx             | From communication port   |  |  |  |
| 010              | IIOF0              | IIOF0               | $\mathbf{N}$              |  |  |  |
| 011              | IIOF1              | IIOF1               | From external pins        |  |  |  |
| 100              | ĪIOF2              | IIOF2               | INTO – INT3               |  |  |  |
| 101              | IIOF3              | IIOF3               |                           |  |  |  |
| 110              | TIM0               | TIMO                |                           |  |  |  |
| 111              | TIM1               | TIM1                | From timers TIM0 and TIM1 |  |  |  |

<sup>†</sup> The *x* in DMA*x* is the DMA channel number, which is also the number for the corresponding ICRDY*x* and OCRDY*x* interrupts. For example, an 001<sub>2</sub> in both DMA2 READ and DMA5 WRITE would enable interrupts ICRDY2 and OCRDY5, respectively. All other viable bit values (010<sub>2</sub> to 111<sub>2</sub>) are the same (as shown in the table) for DMA2 through DMA5.

Note that each DMA channel looks not only at the DMA synchronous interrupts selected but also at the synchronization mode that the channel is currently using (see Table 9–4 on page 9-15). The synchronization mode is specified by the DMA channel control registers located in the DMA coprocessor.

3-9

# 3.1.9 CPU Internal Interrupt Enable Register (IIE)

The 32-bit internal interrupt enable register, shown in Figure 3–5, enables/ disables the following interrupts for the CPU:

Timers 0 and 1,

- □ For communication ports 0–5:
  - Input-buffer full,
  - Input-buffer ready,
  - Output-buffer ready,
  - Output-buffer empty.

DMA coprocessor channels 0–5.

Figure 3–5 shows the IIE register bits, and Table 3–5 describes the interrupt enabled, depending on the bit value. A 1 read means the corresponding interrupt is enabled; a 0 indicates disabled. At reset, all zeroes are written to the register.

| 1 | i iguic o o    |               | nai miton u   |              |              | gioter      |              |   |               |              |               |        |
|---|----------------|---------------|---------------|--------------|--------------|-------------|--------------|---|---------------|--------------|---------------|--------|
|   | 31             | 30            | 29            | 28           |              | 27          | 26           |   | 25            |              |               |        |
|   | ETINT1         | EDMA-<br>INT5 | EDMA-<br>INT4 | EDM/<br>INT: |              | DMA<br>INT2 | EDM/<br>INT1 |   | EDMA-<br>INTO |              |               |        |
|   | R/W            | R/W           | R/W           | R/W          | 1            | R/W         | R/W          | 1 | R/W           |              |               |        |
|   | 24             | 23            | 22            |              | 21           | 2           | 20           |   | 19            | 18           | 17            |        |
|   | EOC-<br>EMPTY5 | EOC-<br>RDY5  |               |              | EIC-<br>ULL5 |             | DC-<br>PTY4  |   | OC-<br>DY4    | EIC<br>RDY4  | EIC-<br>FULL4 |        |
|   | R/W            | R/W           | R/W           |              | R/W          | R           | /W           | I | R/W           | R/W          | R/W           |        |
|   | 16             | 15            | 14            |              | 13           | 1           | 2            |   | 11            | 10           | 9             | _      |
|   | EOC-<br>EMPTY3 | EOC-<br>RDY3  | EIC-<br>RDY3  |              | EIC<br>ULL3  |             | C-<br>PTY2   |   | OC<br>DY2     | EIC-<br>RDY2 | EIC-<br>FULL2 |        |
|   | R/W            | R/W           | R/W           |              | R/W          | R           | W            | F | R/W           | R/W          | R/W           |        |
|   | 8              | 7             | 6             |              | 5            | 4           | 4            |   | 3             | 2            | 1             | 0      |
|   | EOC-<br>EMPTY1 | EOC-<br>RDY1  | EIC-<br>RDY   |              | EIC<br>ULL1  |             | C-<br>PTY0   | _ | OC-<br>DY0    | EIC-<br>RDY0 | EIC<br>FULL0  | ETINT0 |
|   | R/W            | R/W           | R/W           |              | R/W          | R           | W            | F | R/W           | R/W          | R/W           | R/W    |
|   |                |               |               |              |              |             |              |   |               |              |               |        |

Figure 3–5. Internal Interrupt Enable Register (IIE)

R = Read, W = Write, R/W = Read/Write

| Table 3–5. | Summary of Interrupt Enable Register Bits (IIE) |
|------------|-------------------------------------------------|
| 14010 0 0. |                                                 |

|                    |    | 11 | E Bit | Num | nbers |    | Port No.<br>Enables/Disables(note 1)       |
|--------------------|----|----|-------|-----|-------|----|--------------------------------------------|
| IIE Bit Field Name | 0  | 1  | 2     | 3   | 4     | 5  | Enables/Disables(note 1)                   |
| EICFULLx (Note 2)  | 1  | 5  | 9     | 13  | 17    | 21 | Comm. port x input-buffer full interrupt   |
| EICRDYx (Note 2)   | 2  | 6  | 10    | 14  | 18    | 22 | Comm. port x input-buffer ready interrupt  |
| EOCRDYx (Note 2)   | 3  | 7  | 14    | 15  | 19    | 23 | Comm. port x output-buffer ready interrupt |
| EOCEMPTYx (Note 2) | 4  | 8  | 12    | 16  | 20    | 24 | Comm. port x output-buffer empty interrupt |
| EDMAINTx (Note 2)  | 25 | 26 | 27    | 28  | 29    | 30 | DMA coprocessor channel x interrupt        |
| ETINTO             | 0  |    |       |     |       |    | Timer 0 interrupt                          |
| ETINT1             | 31 |    |       |     |       |    | Timer 1 interrupt                          |

- NOTES: 1 The x represents a corresponding communication port number (0 5) or DMA coprocessor chanel number (0 5). For example, ones in bits 5 and 25 enable interrupts for (a) input-buffer full at communication port 1 and for (b) DMA coprocessor channel 0. (A 1 enables the interrupt; a 0 disables it.)
  - 2. Communication port bits are shaded according to communication port number. For example, communication port 0's bit numbers are in the first group of vertical shading. Thus, communication port 0's bits are 1, 2, 3, 4; communication-port 1's bits are 5, 6, 7, 8; etc. The DMA coprocessor channel interrupts are shown the same way (e.g., EDMAINT0 at bit 25, EDMAINT1 at bit 26, etc.).

# 3.1.10 IIOF Flag Register (IIF) Controls External Pins IIOF(3 – 0), Timer/DMA Flags

The IIF register controls the external interrupt pins IIOF(3 - 0). Use it to specify:

- which IIOF pins are used for general-purpose I/O and which are used for interrupts,
- whether a general-purpose pin is input (read only) or output (read/ write),
- whether an interrupt pin is for edge-triggered or level-triggered interrupts,
- if an interrupt is enabled or disabled.

Figure 3–6 depicts the IIF register bits. Table 3–6 (page 3-13) explains these bits in detail. Interrupt traps are shownin Figure 3–7 (page 3-15). Interrupts are further explained in Section 6.7 on page 6-23.

Figure 3–6. Interrupt Flag Register (IIF)

|   | 31     | 30      | 29      | 28      | 27      | 26      | 25      | 24    |
|---|--------|---------|---------|---------|---------|---------|---------|-------|
| Γ | TINT1  | DMAINT5 | DMAINT4 | DMAINT3 | DMAINT2 | DMAINT1 | DMAINT0 | TINT0 |
|   | R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W   |
|   | 23     | 22      | 21      | 20      | 19      | 18      | 17      | 16    |
|   | xx     | xx      | XX      | xx      | XX      | XX      | XX      | NMI   |
| _ | R      | R       | R       | R       | R       | R       | R       | R     |
|   | 15     | 14      | 13      | 12      | 11      | 10      | 9       | 8     |
| Γ | EIIOF3 | FLAG3   | TYPE3   | FUNC3   | EIIOF2  | FLAG2   | TYPE2   | FUNC2 |
|   | R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W   |
|   | 7      | 6       | 5       | 4       | 3       | 2       | 1       | 0     |
|   | EllOF1 | FLAG1   | TYPE1   | FUNC1   | EIIOF0  | FLAG0   | TYPE0   | FUNC0 |
| - | R/W    | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W   |
|   |        |         |         |         |         |         |         |       |

R = Read (only), R/W = Read/Write, xx = Reserved, read as 0

CPU Registers, Memory, and Cache

| Bit Field<br>Name          | IIF Bit N<br>0 1 2 | os.<br>3 1 | Function (Note 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------|--------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FUNC <i>x</i><br>(note 2)  | 048                |            | Mode of pin IIOF <i>x</i> :<br>If FUNC <i>x</i> = 0, pin IIOF <i>x</i> is a <b>general-purpose I/O (R/W) pin</b> .<br>If FUNC <i>x</i> = 1, pin IIOF <i>x</i> is an i <b>nterrupt (R) pin</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| TYPE <i>x</i><br>(note 2)  | 159                | 13         | Type of function for pin IIOF <i>x</i> :<br>If pin IIOF <i>x</i> is a general-purpose I/O pin (FUNC <i>x</i> = 0):<br>TYPE <i>x</i> = 0 makes IIOF <i>x</i> an <b>Input</b> pin.<br>TYPE <i>x</i> = 1 makes IIOF <i>x</i> an <b>output</b> pin<br>If pin IIOF <i>x</i> is an interrupt pin (FUNC <i>x</i> = 1):<br>TYPE <i>x</i> = 0 makes IIOF <i>x</i> an <b>edge-triggered latched</b> interrupt,<br>TYPE <i>x</i> = 1 makes IIOF <i>x</i> a <b>level-triggered unlatched</b> interrupt.                                                                                                                                                                                                       |
| FLAG <i>x</i><br>(note 2)  | 2 6 10             | 14         | Flag for pin IIOF <i>x</i> :<br>If pin IIOF <i>x</i> is a general-purpose <b>input</b> pin (FUNC $x = 0$ , TYPE $x = 0$ ),<br>FLAG $x =$ the value of pin IIOF $x$ and is <b>read only</b> .<br>If pin IIOF $x$ is a general-purpose <b>output</b> pin (FUNC $x = 0$ , TYPE $x = 1$ ),<br>FLAG $x =$ the value on pin IIOF $x$ and is <b>R</b> / <b>W</b> .<br>If pin IIOF $x$ is an interrupt pin (FUNC $x = 1$ ):<br>FLAG $x = 0$ if interrupt is <b>not asserted</b> .<br>FLAG $x = 1$ if interrupt <b>is asserted</b> .<br>If 0 (zero) is written to FLAG $x$ , the corresponding interrupt is<br>cleared unless an interrupt is on the same pin; in that case,<br>the interrupt will be set. |
| EIIOF <i>x</i><br>(note 2) | 3 7 11             | 15         | Disable/enable external interrupt:<br>EIIOF $x = 0$ disables external interrupts at pin IIFO $x$ .<br>EIIOF $x = 1$ enables external interrupts at pin IIFO $x$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| NMI                        | 16                 | *          | Nonmaskable Interrupt flag (NMI). The NMI interrupt (on the external $\overline{\text{NMI}}$ pin)<br>behaves like other interrupts, except it cannot be masked (disabled) by the GIE<br>bit (ST bit 13) or by writing to the NMI bit itself. It is temporarily masked during<br>delayed branches and multicycle CPU operations. At reset, this bit is cleared.<br>An asserted interrupt is cleared only by servicing the interrupt. NMI is a negati-<br>ve-going, edge-triggered, latched interrupt. It is read only.<br>Reading NMI as 0 indicates the interrupt is not asserted.<br>Reading NMI as 1 indicates the interrupt is asserted.                                                       |
| Reserved                   | 17 – 23            | }          | Reserved; read as zeroes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| TINTO<br>TINT1             | 24<br>31           |            | Timer interrupt flags 0 and 1:<br>Reading TINT <i>x</i> as 0 indicates the timer interrupt is not asserted.<br>Reading TINT <i>x</i> as 1 indicates the timer interrupt is asserted.<br>A zero written to this bit clears the interrupt unless the interrupt is<br>asserted at the same time; in that case, the interrupt will be shown<br>as asserted.                                                                                                                                                                                                                                                                                                                                           |
| DMAINT <i>x</i>            | 25 –30             |            | Interrupt flag for DMA coprocessor channels 0 to 5.<br>Reading DMAINTx as 0 indicates the channel interrupt is not asserted.<br>Reading DMAINTx as 1 indicates the channel interrupt is asserted.<br>A zero written to this bit clears the interrupt unless the interrupt is<br>asserted at the same time; in that case, the interrupt will be<br>shown as asserted.<br>the corresponding IIOF interrupt pin (IIOF3–IIOF0). R = Read, /W = Read/Write                                                                                                                                                                                                                                             |

Table 3–6.IIF Register Bits Summary

ES: 1 The *x* represents the corresponding IIOF interrupt pin (IIOF3–IIOF0). R = Read, /W = Read/Write
2. Shading organizes each communication port's bits the same as shown for the IIE register inTable 3–5 (see note 2) on page 3-11. For example, bits 0, 1, 2, 3 apply to pin IIOF0; bits 4, 5, 6, 7 apply to IIOF1, etc.

# 3.1.11 Block-Repeat (RS, RE) and Repeat-Count (RC) Registers

The 32-bit repeat start address register (RS) contains the starting address of the block of program memory to be repeated when operating in the repeat mode.

The 32-bit repeat end address register (RE) contains the ending address of the block of program memory to be repeated when operating in the repeat mode.

The repeat-count register (RC) is a 32-bit register used to specify the number of times a block of code is to be repeated when performing a block repeat. If RC contains the number n, the loop will be executed n + 1 times.

#### 3.1.12 Program Counter (PC)

The program counter (PC) is a 32-bit register containing the address of the next instruction to be fetched. While the program counter is not part of the CPU register file, it is a register that can be modified by instructions that modify the program flow.

#### 3.1.13 Reserved Bits and Compatibility

In order to retain compatibility with future members of the TMS320C4x family of microprocessors, reserved bits that are read as zero must be written as zero. Reserved bits that have an undefined value *must not* have their current value modified. In other cases, maintain the reserved bits as specified.

CPU Registers, Memory, and Cache

# 3.2 CPU Expansion Register File

This expansion register file contains two special control registers:

- Interrupt-vector table pointer register (IVTP),
- Trap-vector table pointer (TVTP).

 Table 3–7.
 CPU Expansion Registers

| Assembler Syntax | Function Name                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------|
| IVTP             | Interrupt-vector table pointer. Points to start of interrupt-vector table (shown in Figure 3–8).    |
| TVTP             | Trap-vector table pointer. Points to start of the 512-trap-<br>vector table (shown at page bottom). |

Use the **LDEP instruction** to load (copy) an expansion register to a primary register (e.g., to any of the auxiliary registers AR0 – AR7, see Table 3–1 on page 3-3). For example:

Likewise, use the **LDPE instruction** to load (copy) *a primary register to an expansion register*. Neither of these instructions affects the status register condition flags.

```
LDPE AR5, IVTP ; AR5 contents to IVTP
```

Note that both the interrupt-vector table and the trap-vector table **are required to lie on a 512–word boundary**; thus, the **nine least-significant bits of these pointers are zeroes** (i.e., 10 0000 0000<sub>2</sub> = 512 = 200h). Write only zeroes to these bits (though the register forces these to zeroes).

The 32-bit **IVTP register** points to (is essentially the base address for) the interrupt-vector table (IVT) in memory. The contents of this table are depicted in Figure 3–8 on page 3-16.

The 32-bit **TVTP register** is essentially the base address for the trap-vector table (TVT) in memory. This table, depicted below, contains the vectors for the TRAP instruction's 512–trap addresses (TRAP0–TRAP511).

The interrupt (including RESET — see Section 3.3) and trap maps can be configured to overlap. At reset, IVTP and TVTP are set to all zeroes.

Figure 3–7. Trap Vector Table (TVT)

| TVTP + 000h | TRAP0   |
|-------------|---------|
| TVTP + 001h | TRAP1   |
| •           | ТО      |
| ě           | TRAP509 |
| TVTP + 1FEh | TRAP510 |
| TVTP + 1FFh | TRAP511 |

| -iç | gure 3–8. | Inter | rupt-Vector Table (IVT) |         |        |      |                                                                               |        |
|-----|-----------|-------|-------------------------|---------|--------|------|-------------------------------------------------------------------------------|--------|
|     | IVTP +    | 000h  | Reserved                | Note 1  | IVTP + | 01Dh | ICFULL4                                                                       |        |
|     | IVTP +    | 001h  | NMI                     | Note 2  | IVTP + | 01Eh | ICRDY4                                                                        |        |
|     | IVTP +    | 002h  | TINTO                   | Note 3  | IVTP + | 01Fh | OCRDY4                                                                        |        |
|     | IVTP +    | 003h  | IIOF0                   | )       | IVTP + | 020h | OCEMPTY4                                                                      |        |
|     | IVTP +    | 004h  | IIOF1                   | Note 4  | IVTP + | 021h | ICFULL5                                                                       | Note 5 |
|     | IVTP +    | 005h  | IIOF2                   |         | IVTP + | 022h | ICRDY5                                                                        |        |
|     | IVTP +    | 006h  | IIOF3                   | J       | IVTP + | 023h | OCRDY5                                                                        |        |
|     | IVTP +    | 007h  | Unused                  |         | IVTP + | 024h | OCEMPTY5                                                                      |        |
|     | IVTP +    |       | linused                 |         | IVTP + | 025h | DMA INTO                                                                      | )      |
|     | IVTP +    | 00Ch  | <b>Oneso</b>            |         | IVTP + | 026h | DMA INT1                                                                      |        |
|     | IVTP +    | 00Dh  | ICFULL0                 |         | IVTP + | 027h | DMA INT2                                                                      |        |
|     | IVTP +    | 00Eh  | ICRDY0                  |         | IVTP + | 028h | DMA INT3                                                                      | Note 6 |
|     | IVTP +    | 00Fh  | OCRDY0                  |         | IVTP + | 029h | DMA INT4                                                                      |        |
|     | IVTP +    | 010h  | OCEMPTY0                |         | IVTP + | 02Ah | DMA INT5                                                                      |        |
|     | IVTP +    | 011h  | ICFULL1                 |         | IVTP + | 02Bh | TINT1                                                                         | Note 3 |
|     | IVTP +    | 012h  | ICRDY1                  |         | IVTP + | 02Ch |                                                                               |        |
|     | IVTP +    | 013h  | OCRDY1                  |         | IVTP + |      |                                                                               |        |
|     | IVTP +    | 014h  | OCEMPTY1                | Note 5  | IVTP + |      |                                                                               |        |
|     | IVTP +    | 015h  | ICFULL2                 | INDIE 5 | IVTP + | •    | Unused                                                                        |        |
|     | IVTP +    | 016h  | ICRDY2                  |         | IVTP + |      |                                                                               |        |
|     | IVTP +    | 017h  | OCRDY2                  |         | IVTP + | •    | an an<br>Dhuan an |        |
|     | IVTP +    | 018h  | OCEMPTY2                |         | IVTP + | ٠    |                                                                               |        |
|     | IVTP +    | 019h  | ICFULL3                 |         | IVTP + |      |                                                                               |        |
|     | IVTP +    | 01Ah  | ICRDY3                  |         | IVTP + |      |                                                                               |        |
|     | IVTP +    | 01Bh  | OCRDY3                  |         | IVTP + | 03Eh |                                                                               |        |
|     | IVTP +    | 01Ch  | OCEMPTY3                | )       | IVTP + | 03Fh | Reserved                                                                      |        |
|     |           |       |                         |         |        |      |                                                                               |        |

Notes: 1) Reserved for the **reset** vector when IVTP = 0000 0000h and RESETLOC(1,0) =  $0.0_2$  or when IVTP=08000 0000h and RESETLOC(1,0) = 1 02. See Table 3-8.

NMI (nonmaskable interrupt) is discussed in Section 9.9, page 9-40. 2)

3) Timer interrupts TINT0 and TINT1 are enabled and programmed by the IIE register (subection 3.1.9, page 3-10) and monitored at the IIF register (subection 3.1.10, page 3-12).

- External pins IIOF0-IIOF5 are programmed in the DIE register (subsection 3.1.8, page 3-8) 4) and IIF register.
- 5) The communication port I/O buffers full/ready interrupts are enabled by the DIE and IIE registers and also discussed in Table 8-1, page 8-10 (OUTPUT LEVEL & INPUT LEVEL bits).
- 6) DMA interrupts are enabled at the IIE register and DMA channel control register (at bits TCC and AUX TCC explained in Table 9-1 on page 9-8).

3

CPU Registers, Memory, and Cache

# 3.3 **RESET Vector Mapping**

The 'C40s RESET vector can reside in any one of four memory locations. The value on two external pins (RESETLOC(1,0)) determines the RESET vector location as shown in the following table.

 Table 3–8.
 Four RESET Vector Locations Chosen by Values on Pins RESETLOC(1,0)

| Value at RES | ETLOCx Pin | Get RESET Vector         |            |
|--------------|------------|--------------------------|------------|
| RESETLOC1    | RESETLOC0  | From Memory Address      | Comment    |
| 0            | 0          | 00000 0000 <sub>16</sub> | Local Bus  |
| 0            | 1          | 07FFF FFFF <sub>16</sub> | Local Bus  |
| 1            | 0          | 08000 0000 <sub>16</sub> | Global Bus |
| 1            | 1          | OFFFF FFFF <sub>16</sub> | Global Bus |

Note that if pin ROMEN = 1 and the vector at 0000 0000h is enabled (pins RESETLOC(1,0) = 00), then the vector is mapped to address 0 of internal ROM.

This mapping scheme of the RESET vector allows the TMS320C40 to be integrated easily into systems having other processors with fixed RESET vector locations. It also allows you to make the RESET vector either external or internal (on-chip ROM) to the processor.

# 3.4 Memory

The TMS320C40's memory space of 4 giga words (4 billion  $\times$  32 bits where 1 G = 2<sup>30</sup>) is shown in the two memory maps in Figure 3–9. These maps differ only by the makeup of the lowest address space at 0000 0000h to 0000 0FFFh. This makeup is configured by the value at pin ROMEN (onchip — reserved — ROM enable, pin AK4):

- ROMEN = 1. Addresses 0000h 0FFFh are an accessible onchip ROM block (reserved), and 0000 1000h – 000F FFFFh are reserved
- **ROMEN = 0.** The on-chip (reserved) ROM is disabled, and addresses 0000 0000h 000F FFFFh are accessible over the local bus.

Memory in both maps starting at 10 0000h is not affected by ROMEN (as described for addresses 00000h – FFFFFh above). A general summary of address ranges:

- O000 0000h 000F FFFFh: Can be local bus or on-chip (reserved) ROM, depending on the value of pin ROMEN.
- O010 0000h 0010 00FFh: Internal peripherals (DMA coprocessor, communications ports, timers, etc.)
- O010 0100h 001F FFFFh: Internal peripheral region.

Instructions cannot be accessed in these 3 areas.

- **0020 0000h 002F F7FFh:** Reserved.
- **002F F800h 002F FBFFh:** 1K RAM Block 0.
- **002F FC00h 002F FFFFh:** 1K RAM Block 1.
- 0030 0000h 07FFF FFFFh: Local bus. If ROMEN = 1, another part of the local bus is at 00 0000h – 0F FFFFh. These addresses activate the local bus.
- **08000 0000h 0FFFF FFFFh:** Global bus.

CPU data accesses and DMA accesses can be made from any unreserved part of the 'C40 memory map. Instruction fetches can take place at any unreserved area of the 'C40 memory map except at the peripheral space (addresses 0010 0000h - 0010 00FFh).

The 'C40's internal ROM is currently reserved for TI internal use only.

# 3.4.1 Overall Memory Map





# 3.4.2 Peripheral Bus Memory Map

This map resides in addresses  $0010\ 0000h - 0010\ 00FFh$  as shown in the memory map, Figure 3–9. Each peripheral requires a 16-word area.

Figure 3–10. Peripheral Memory Map

| 0010 0000h               | Local and Global Port Control (16 words)                                                                                                                                                                                                                                                   |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0010 000Fh               | (See subsection 3.4.2.1 and Figure 3-11)                                                                                                                                                                                                                                                   |
| 0010 0010h               | Analysis Module Block Registers (16 words)                                                                                                                                                                                                                                                 |
| 0010 001Fh               | (See subsection 3.4.2.2 and Figure 3–12)                                                                                                                                                                                                                                                   |
| 0010 0020h               | Timer 0 Registers (16 words)                                                                                                                                                                                                                                                               |
| 0010 002Fh               | (See subsection 3.4.2.3 and Figure 3–13)                                                                                                                                                                                                                                                   |
| 0010 0030h               | Timer 1 Registers (16 words)                                                                                                                                                                                                                                                               |
| 0010 003Fh               | (See subsection 3.4.2.3 and Figure 3-13)                                                                                                                                                                                                                                                   |
| 0010 0040h               | Communication Port 0 (16 words)                                                                                                                                                                                                                                                            |
| 0010 004Fh               | (See subsection 3.4.2.4 and Figure 3–14)                                                                                                                                                                                                                                                   |
| 0010 0050h               | Communication Port 1 (16 words)                                                                                                                                                                                                                                                            |
| 0010 005Fh               | (See subsection 3.4.2.4 and Figure 3–14)                                                                                                                                                                                                                                                   |
| 0010 0060h               | Communication Port 2 (16 words)                                                                                                                                                                                                                                                            |
| 0010 006Fh               | (See subsection 3.4.2.4 and Figure 3-14)                                                                                                                                                                                                                                                   |
| 0010 0070h               | Communication Port 3 (16 words)                                                                                                                                                                                                                                                            |
| 0010 007Fh               | (See subsection 3.4.2.4 and Figure 3–14)                                                                                                                                                                                                                                                   |
| 0010 0080h               | Communication Port 4 (16 words)                                                                                                                                                                                                                                                            |
| 0010 008Fh               | (See subsection 3.4.2.4 and Figure 3–14)                                                                                                                                                                                                                                                   |
| 0010 0090h               | Communication Port 5 (16 words)                                                                                                                                                                                                                                                            |
| 0010 009Fh               | (See subsection 3.4.2.4 and Figure 3-14)                                                                                                                                                                                                                                                   |
| 0010 00A0h               | DMA Coprocessor Channel 0 (16 words)                                                                                                                                                                                                                                                       |
| 0010 00AFh               | (See subsection 3.4.2.5 and Figure 3–15 page 3-24.)                                                                                                                                                                                                                                        |
| 0010 00B0h               | DMA Coprocessor Channel 1 (16 words)                                                                                                                                                                                                                                                       |
| 0010 00BFh               | (See subsection 3.4.2.5 and Figure 3–15, page 3-24.)                                                                                                                                                                                                                                       |
| 0010 00C0h<br>0010 00CFh | DMA Coprocessor Channel 0 (16 words)<br>(See subsection 3.4.2.5 and Figure 3–15, page 3.24)<br>DMA Coprocessor Channel 1 (16 words)<br>(See subsection 3.4.2.5 and Figure 3–15, page 3-24)<br>DMA Coprocessor Channel 2 (16 words)<br>(See subsection 3.4.2.5 and Figure 3–15, page 3-24.) |
| 0010 00D0h               | DMA Coprocessor Channel 3. (16 words)                                                                                                                                                                                                                                                      |
| 0010 00DFh               | (See subsection 3.4.2.5 and Figure 3–15: page 3-24.)                                                                                                                                                                                                                                       |
| 0010 00E0h<br>0010 00EFh | (3ee subsection 3.4.2.5 and Figure 3-15, page 3-24.)                                                                                                                                                                                                                                       |
| 0010 00F0h<br>0010 00FFh | DMA Coprocessor Channel 4 (16 words)<br>(See subsection 3.4.2.5 and Figure 3–15, page 3-24.)<br>DMA Coprocessor Channel 5 (16 words)<br>(See subsection 3.4.2.5 Figure 3–15, page 3-24.)                                                                                                   |
|                          |                                                                                                                                                                                                                                                                                            |

#### 3.4.2.1 Local and Global Memory Interface Control Registers

These registers control the local and global memory interfaces. They occupy the first 16-word block of the peripheral bus memory map, shown in Figure 3–10. The registers themselves are shown in Figure 3–11. Chapter 7 covers the operation of these registers. A detailed description of these is shown in Figure 7–2 and Table 7–3 (pages 7-7 and 7-8).

These registers define:

- the page sizes used for the two strobes of each port,
- address ranges over which the strobes are active,
- wait states, and
- other similar operations that compose the memory interfaces.

Figure 3–11. Memory Interface Control Registers



#### 3.4.2.2 Analysis Module Registers

These registers, the second 16-word block in the peripheral bus memory Map (Figure 3–10), are shown below in Figure 3–12. These registers are reserved for emulation functions.

*Figure 3–12. Analysis Module Registers* 

| 0010 0010h | - |  |  |  | 111   | 111   | ate |   | <b>?e</b> |        | 111   | 101  |     |  |  |  |  |
|------------|---|--|--|--|-------|-------|-----|---|-----------|--------|-------|------|-----|--|--|--|--|
| 0010 0011h |   |  |  |  | - lii | - III | ntr |   | 111       | .1111. | lill. | 1111 | 111 |  |  |  |  |
| 0010 0012h |   |  |  |  | VJ.   | Sta   | atı | S | Re        | эç     | iis   | te   | r   |  |  |  |  |
| 0010 0013h |   |  |  |  | Ta    | 25    | k I | D | R         | eç     | jis   | te   | r   |  |  |  |  |

#### **Timer Registers** 3.4.2.3

This group of registers occupies the 0010 0020h - 0010 003Fh range in the peripheral bus memory map, Figure 3-10, on page 3-20. Timers and their registers are covered in detail in Section 9.10 on page 9-45.



# 3.4.2.4 Communication Port Memory Map

The communication-port control registers (CPCR) and input and output FIFO buffers are illustrated below in Figure 3–14. This is the central group of registers in the peripheral bus memory map, Figure 3–10, on page 3-20. These are described in more detail in Chapter 8.





#### 3.4.2.5 DMA Coprocessor Registers

The DMA registers (shown below) are the bottom block of registers in the peripheral bus memory map (Figure 3–10 on page 3-20). These registers are described in Chapter 9. Figure 9–2, page 9-5, is an index to subjects.

Figure 3–15. DMA Coprocessor Memory Map



CPU Registers, Memory, and Cache

# 3.5 Instruction Cache Architecture

The  $128 \times 32$ -bit instruction cache speeds instruction fetches and lowers system cost. The instruction cache allows the use of slow external memories while still achieving single-cycle access performance. The cache also frees the external bus from program fetches, thus, allowing the use of these buses for DMA or other system needs. The cache can operate in a completely automatic fashion without the need for external intervention. It uses a form of the LRU (least recently used) cache update algorithm.

The instruction cache (see Figure 3–17 on page 3-26) contains 128 32-bit words of RAM, enough to hold 128 words of program memory. It is divided into four 32-word segments. Associated with each segment is a 27-bit segment start address (SSA) register. For each word in the cache, there is a corresponding single-bit present (P) flag.

When the CPU requests an instruction word, a check is made to determine whether the word is already in the instruction cache. The partitioning of an instruction address as used by the cache control algorithm is shown in Figure 3–16. The 27 most significant bits (MSBs) of the instruction address select the segment, and the 5 least significant bits define the address of the instruction word within the pertinent segment. The 27 MSBs of the instruction address are compared with the four SSA registers. If a match is found, the relevant P flag is checked. The **P flag** indicates whether or not the word within a particular segment is already present in cache memory:

 $\square$  P = 1: the word is already present in cache memory.

 $\square$  P = 0: location in cache is invalid (e.g., contains garbage).

## Figure 3–16. Address Partitioning for Cache Control Algorithm

| 31           |         | 4 0                   |
|--------------|---------|-----------------------|
| segment star | address | instruction word      |
| (SSA         | ) a     | ddress within segment |

If there is no match, one of the segments must be replaced by the new data. The segment replaced in this circumstance is determined by the LRU (least recently used) algorithm. The LRU stack (see upper right of Figure 3–17 on page 3-26) is maintained for this purpose.

#### Figure 3–17. Instruction Cache Architecture



CPU Registers, Memory, and Cache

The LRU stack keeps track of which segment (0 - 3) qualifies as the least recently used after each access to the cache. Each time a segment is accessed, its segment number is removed from the LRU stack and pushed onto the top of the LRU stack. Therefore, the number at the top of the stack is the most recently used segment number, and the number at the bottom of the stack is the least recently used segment number.

At RESET, the following occur in the instruction cache:

- all P flags are set to zero, and
- the LRU stack is initialized with segment no. 0 at the top followed by 1, 2, and 3 at the bottom. If any two SSA registers are equal (due to RE-SET conditions) and a cache hit occurs, the instruction word is fetched from the most recently used segment.

When a replacement is necessary, the least recently used segment is selected for replacement. Also, the 32 P flags for the segment to be replaced are set to 0, and the segment's SSA register is replaced with the 27 MSBs of the instruction address.

# 3.5.1 Cache Algorithm

When the TMS320C40 requests an instruction word from external memory, the two possible actions are a *cache hit* or a *cache miss*.

- **Cache Hit.** The cache contains the requested instruction, and the following actions occur:
  - The instruction word is read from the cache.
  - The number of the segment containing the word is removed from the LRU stack and pushed to the top of the LRU stack (if not already at the top), thus moving the other segment numbers toward the bottom of the stack.
- □ Cache Miss. The cache does not contain the instruction. Types of cache misses are
  - Subsegment miss. The segment address register matches the instruction address, but the relevant P flag is not set. The following actions occur:
    - The instruction word is read from memory and copied into the cache.
    - The number of the segment containing the word is removed from the LRU stack and pushed to the top of the LRU stack (if not already at the top), thus moving the other segment numbers toward the bottom of the stack.
    - The relevant P flag is set.

- Segment miss. None of the segment addresses matches the instruction address. The following actions occur:
  - The least recently used segment is selected for replacement. The P flags for all 32 words are cleared.
  - The SSA register for the selected segment is loaded with the 27 MSBs of the address of the requested instruction word.
  - The instruction word is fetched and copied into the cache. It goes into the appropriate word of the least recently used segment. The P flag for that word is set to 1.
  - The number of the segment containing the instruction word is removed from the LRU stack and pushed to the top of the LRU stack, thus moving the other segment numbers toward the bottom of the stack.

#### 3.5.2 Cache and System Memory

Only instructions may be fetched from the program cache. All reads and writes of data in memory bypass the cache. Program fetches from internal memory do not modify the cache and do not generate cache hits or misses. The program cache is a single-access memory block. Dummy program fetches (i.e., following a branch) can generate cache misses and cache updates.

**Avoid using self-modifying code.** If an instruction resides in cache and the corresponding location in primary memory is modified, the copy of the instruction in cache is not modified.

**Cache can be used more efficiently** by aligning program code on 32-word address boundaries. Do this by using the ALIGN directive when coding assembly language.

# 3.5.3 Cache Control Bits

Four cache control bits are located in the CPU status register: the cache clear bit (**CC**), the cache enable bit (**CE**), the cache freeze bit (**CF**), and the previous cache freeze bit (**PCF**) as shown in Figure 3–3 on page 3-6. The definitions of these bits are repeated below from Table 3–2.

- **Cache Clear Bit (CC)**. Set CC = 1 to invalidate all entries in the cache (contents not guaranteed, "garbage"). This bit is always cleared after it is written to; thus, it is always read as 0. At reset, 0 is written to this bit. The cache P flag = 0 when cache is cleared.
- **Cache Enable Bit (CE).** Set CE = 1 to enable the cache, allowing the cache to be used according to the LRU (least recently used) cache algorithm. Set CE = 0 to disable the cache; this prevents cache updates or modifications (thus no cache fetches can be made). At reset, 0 is written to this bit. Cache clearing (CC = 1) is allowed when CE=0.
- Cache Freeze Bit (CF). Set CF = 1 to freeze the cache (cannot be written to) including freezing of LRU (least recently used) stack manipulation. If the cache is enabled (CE = 1), fetches from the cache are allowed, but modification of the cache contents is not allowed. Cache clearing (CC=1) is allowed. At reset, this bit is set to zero. When CF=0, cache clearing (CC=1) is allowed. CF is set to one when a trap or interrupt is taken. Also, the RETI and RETID instructions copy PCF to the CF bit.

Table 3–9 defines the effect of the CE and CF bits used in combination.

 Table 3–9.
 Combined Effect of the CE and CF Bits

| CE | CF | Effect                       |
|----|----|------------------------------|
| 0  | 0  | Cache not enabled            |
| 0  | 1  | Cache not enabled            |
| 1  | 0  | Cache enabled and not frozen |
| 1  | 1  | Cache enabled and frozen     |

Previous Cache Freeze Bit (PCF). When an interrupt or trap vector is taken, the CF value is copied to the PCF bit and the CF bit is set to 1. This protects the cache during interrupt processing and is particularly useful when code loops are interrupted. The interrupt service routine may optionally use the cache under software control. Interrupts may also be nested, providing that the status register is saved prior to enabling the interrupts. When the instructions RETI*cond* and RETI*cond*D are executed to complete interrupt processing, the contents of the PCF bit are copied to the CF bit.



# **Chapter 4**

# Data Formats and Floating-Point Operation

# In the TMS320C40 architecture, data is organized into three fundamental types: integer, unsigned-integer, and floating-point. Note that the terms, integer and signed-integer, are considered to be equivalent. The TMS320C40 supports short and single-precision formats for signed and unsigned integers. It also supports short, single-precision and extended-precision formats for floating-point data.

Floating-point operations make fast, trouble-free, accurate, and precise computations. Specifically, the TMS320C40 implementation of floating-point arithmetic facilitates floating-point operations at integer speeds while preventing problems with overflow, operand alignment, and other burdensome tasks common in integer operations.

This chapter discusses in detail the data formats and floating-point operations supported on the TMS320C40. Major topics in this section are as follows:

| Sectio | n                                          | Page  |
|--------|--------------------------------------------|-------|
| 4.1    | Signed Integer Formats                     | . 4-3 |
|        | Short Integer Format                       | . 4-3 |
|        | Single-Precision Integer Format            | . 4-3 |
| 4.2    | Unsigned-Integer Formats                   | . 4-4 |
|        | Short Unsigned-Integer Format )            | . 4-4 |
|        | ■ Single-Precision Unsigned-Integer Format | . 4-4 |
| 4.3    | Floating-Point Formats                     | . 4-5 |
|        | Short Floating-Point Format                | . 4-6 |
|        | ■ Single-Precision Floating-Point Format   | . 4-7 |

| Sectio | n                                                                                       | Page   |
|--------|-----------------------------------------------------------------------------------------|--------|
|        | Extended-Precision Floating-Point Format                                                | 4-8    |
|        | Conversion Between Floating-Point Formats                                               | 4-9    |
| 4.4    | Floating-Point Conversions, IEEE/'C4x                                                   | 4-11   |
|        | Converting IEEE Format to Twos Complement<br>Floating-Point Format                      | 4-12   |
|        | <ul> <li>Converting Twos Complement Floating-Point<br/>Format to IEEE Format</li> </ul> | 4-13   |
| 4.5    | Floating-Point Multiplication                                                           | 4-15   |
| 4.6    | Floating-Point Addition and Subtraction                                                 | 4-20   |
| 4.7    | Normalization, (NORM Instruction)                                                       | 4-24   |
| 4.8    | Rounding, (RND Instruction)                                                             | .4-26  |
| 4.9    | Floating-Point to Integer Conversions,<br>FIX Instruction                               | 4-28   |
| 4.10   | Integer to Floating-Point Conversion,<br>FLOAT Instruction                              | 4-30   |
| 4.11   | Reciprocal of Number, RCPF Instruction                                                  | 4-31   |
| 4.12   | Reciprocal of Square Root, RSQRF Instruction                                            | . 4-33 |

Data Formats and Floating-Point Operation

## 4.1 Signed Integer Formats

The TMS320C40 supports two integer formats: a 16-bit short integer format and a 32-bit single-precision integer format. When extended-precision registers are used as integer operands, only bits 31-0 are used; bits 39-32remain unchanged and unused.

## 4.1.1 Short Integer Format

The short integer format is a 16-bit twos-complement integer format used for immediate integer operands. For those instructions that assume integer operands, this format is sign extended to 32 bits (see Figure 4–1). The range of an integer *si*, represented in the short integer format, is:

$$-2^{15} \le si \le 2^{15} - 1$$

#### In Figure 4–1 and other figures in this chapter, s = sign bit.

#### Figure 4–1. Short Integer Format and Sign Extension of Short Integer



(b) Sign Extension of a Short Integer

### 4.1.2 Single-Precision Integer Format

In the single-precision integer format, the integer is represented in twos-complement notation. The range of an integer *sp*, represented in the single-precision integer format, is  $-2^{31} \le sp \le 2^{31} - 1$ . Figure 4–2 shows the single-precision integer format.

#### Figure 4–2. Single-Precision Integer Format



## 4.2 Unsigned-Integer Formats

Two unsigned-integer formats are supported on the TMS320C40: a 16-bit short format and a 32-bit single-precision format. In extended-precision registers, the unsigned-integer operands use only bits 31-0; bits 39-32 remain unchanged.

#### 4.2.1 Short Unsigned-Integer Format

Figure 4–3 shows the 16-bit, short, unsigned-integer format used for immediate unsigned-integer operands. For those instructions that assume unsigned-integer operands, this format is zero filled to 32 bits. In Figure 4–3 below, x = MSB (1 or 0).

Figure 4–3. Short Unsigned-Integer Format and Zero Fill



(a) Short Unsigned-Integer Format





#### 4.2.2 Single-Precision Unsigned-Integer Format

In the single-precision unsigned-integer format, the number is represented as a 32-bit value, as shown in Figure 4–4.

Figure 4–4. Single-Precision Unsigned-Integer Format



4-4

## 4.3 Floating-Point Formats

All TMS320C40 floating-point formats consist of three fields: **an exponent field** (*e*), **a single-bit sign field** (*s*), and a fraction field (*f*). These are stored as shown in Figure 4–5. The exponent field is a twos-complement number. The sign field and fraction field may be considered as one unit and referred to as the **mantissa field** (man). The mantissa is used to represent a normalized twos-complement number. In a normalized representation, a most significant nonsign bit is implied, thus providing an additional bit of precision. The value of a floating-point number *x* as a function of the fields *e*, *s*, and *f* is given as

$$x = 01.f \times 2^e$$
if  $s = 0$  $x = 10.f \times 2^e$ if  $s = 1$  $x = 0$ if  $e$  = most negative twos-complementvalue or the specified exponent field width

#### Figure 4–5. Generic Floating-Point Format



#### Three floating-point formats are supported on the TMS320C40:

- a short floating-point format (for immediate floating-point operands) consisting of a 4-bit exponent, 1 sign bit, and an 11-bit fraction,
- a single-precision format consisting of an 8-bit exponent, 1 sign bit, and a 23-bit fraction, and
- an extended-precision format consisting of an 8-bit exponent, 1 sign bit, and a 31-bit fraction.

#### 4.3.1 Short Floating-Point Format

In the short floating-point format, floating-point numbers are represented by a twos-complement 4-bit exponent field (*e*) and a twos-complement 12-bit mantissa field (*man*) with an implied most significant nonsign bit.

Figure 4–6. Short Floating-Point Format



Operations are performed with an implied binary point between bits 11 and 10. When the implied most significant nonsign bit is made explicit, it is located to the immediate left of the binary point. The floating-point twos-complement number x in the short floating-point format is given by

| $x = 01.f \times 2^{e}$ | if $s = 0$                      |
|-------------------------|---------------------------------|
| $x = 10.f \times 2^{e}$ | if <i>s</i> = 1                 |
| <i>x</i> = 0            | if $e = -8$ , $s = 0$ , $f = 0$ |

You must use the following reserved values to represent zero in the short floating-point format:

$$e = -8$$
$$s = 0$$
$$f = 0$$

The following examples illustrate the range and precision of the short floating-point format:

| Most Positive:  | $x = (2 - 2^{-11}) \times 2^7 = 2.5594 \times 10^2$         |
|-----------------|-------------------------------------------------------------|
| Least Positive: | $x = 1 \times 2^{-7} = 7.8125 \times 10^{-3}$               |
| Least Negative: | $x = (-1 - 2^{-11}) \times 2^{-7} = -7.8163 \times 10^{-3}$ |
| Most Negative:  | $x = -2 \times 2^7 = -2.5600 \times 10^{-2}$                |

## 4.3.2 Single-Precision Floating-Point Format

In the single-precision format, the floating-point number is represented by an 8-bit exponent field (*e*) and a twos-complement 24-bit mantissa field (*man*) with an implied most significant nonsign bit.

Operations are performed with an implied binary point between bits 23 and 22. When the implied most significant nonsign bit is made explicit, it is located to the immediate left of the binary point. The floating-point number x is given by

 $\begin{array}{ll} x = 01.f \times 2^{e} & \text{if } s = 0 \\ x = 10.f \times 2^{e} & \text{if } s = 1 \\ x = 0 & \text{if } e = -128, \ s = 0, \ f = 0 \end{array}$ 





You must use the following reserved values to represent zero in the singleprecision floating-point format:

The following examples illustrate the range and precision of the single-precision floating-point format.

| Most Positive:  | $x = (2 - 2^{-23}) \times 2^{127} = 3.4028234 \times 10^{38}$     |
|-----------------|-------------------------------------------------------------------|
| Least Positive: | $x = 1 \times 2^{-127} = 5.8774717 \times 10^{-39}$               |
| Least Negative: | $x = (-1 - 2^{-23}) \times 2^{-127} = -5.8774724 \times 10^{-39}$ |
| Most Negative:  | $x = -2 \times 2^{127} = -3.4028236 \times 10^{38}$               |

### 4.3.3 Extended-Precision Floating-Point Format

In the extended-precision format, the floating-point number is represented by an 8-bit exponent field (*e*) and a 32-bit mantissa field (*man*) with an implied most significant nonsign bit.

Operations are performed with an implied binary point between bits 31 and 30. When the implied most significant nonsign bit is made explicit, it is located to the immediate left of the binary point. The floating-point number x is given by:

| $x = 01.f \times 2^{\Theta}$ | if $s = 0$                        |
|------------------------------|-----------------------------------|
| $x = 10.f \times 2^{e}$      | if <i>s</i> = 1                   |
| x = 0                        | if $e = -128$ , $s = 0$ , $f = 0$ |





You must use the following reserved values to represent zero in the extended-precision floating-point format:

The following examples illustrate the range and precision of the extended-precision floating-point format:

| Most Positive:  | $x = (2 - 2^{-31}) \times 2^{127} = 3.4028236683 \times 10^{38}$ |
|-----------------|------------------------------------------------------------------|
| Least Positive: | $x = 1 \times 2^{-127} = 5.8774717541 \times 10^{-39}$           |
| Least Negative: | $x = (-1-2^{-31})x2^{-127} = -5.8774717569 \times 10^{-39}$      |
| Most Negative:  | $x = -2 \times 2^{127} = -3.4028236691 \times 10^{38}$           |

## 4.3.4 Conversion Between Floating-Point Formats

Floating-point operations assume several different formats for inputs and outputs. These formats often require conversion from one floating-point format to another (e.g., short floating-point format to extended-precision floating-point format). Format conversions occur automatically in hardware, with no overhead, as a part of the floating-point operations. Examples of the four conversions are shown below. When a floating-point format zero is converted to a greater precision format, it is always converted to a valid representation of zero in that format. In the figures below, s = sign bit of the exponent.

# Short floating-point format conversion to single-precision floating-point format.



(a) Short Floating-Point Format

| 31 | 27    | 24 23   | 22 | 12 11 | 0 |
|----|-------|---------|----|-------|---|
|    | sssx) | ( x   y | у  | VI 0  | 0 |

(b) Single-Precision Floating-Point Format

In this format, the exponent field is sign extended and the fraction field filled with zeros.

□ Short floating-point format conversion to extended-precision floating-point format.



(a) Short Floating-Point Format

| 39    | 35   | 32 31 | 30 | 20 | 19 | 0 |
|-------|------|-------|----|----|----|---|
| 5 S S | sxx. | x x y | v  | у  | 0  | 0 |

(b) Extended-Precision Floating-Point Format

The exponent field in this format is sign extended and the fraction field filled with zeros.

# □ Single-precision floating-point format conversion to extended precision floating-point format.



(a) Single-Precision Floating-Point Format

| 39 | 32 31 | 1 30 | 8 7 | 0 |
|----|-------|------|-----|---|
| X  | x y   | y    | V O | 0 |

(b) Extended-Precision Floating-Point Format

The fraction field is filled with zeros.

Extended-precision floating-point format conversion to singleprecision floating-point format.

| 39 | 32 31 | 30 | 8 | 7   | 0 |
|----|-------|----|---|-----|---|
|    | x y   | у  |   | 1 L | Z |

(a) Extended-Precision Floating-Point Format



(b) Single-Precision Floating-Point Format

The fraction field is truncated.

Data Formats and Floating-Point Operation

## 4.4 Floating-Point Conversions (IEEE Std. 754/'C4x)

Figure 4–9. IEEE Single-Precision Std. 754 Floating-Point Format



This IEEE format is depicted in Figure 4–9 above. The following five cases define the value v of a number expressed in this format:

| 1) | lf | <i>e</i> = 255          | and | <i>f</i> ≠ 0, | then | v = NaNt                                              |
|----|----|-------------------------|-----|---------------|------|-------------------------------------------------------|
| 2) | lf | <i>e</i> = 255          | and | f = 0,        | then | v = (–1) <sup>s</sup> infinite                        |
| 3) | lf | 0 < <i>e &lt; 255</i> , |     |               | then | v = (−1) <sup>s</sup> × 2 <i>°</i> −127(1. <i>f</i> ) |
| 4) | lf | <i>e</i> = 0            | and | f ≠ 0,        | then | $v = (-1)^{s} \times 2^{-126}(0.f)$                   |
| 5) | lf | <i>e</i> = 0            | and | f = 0,        | then | <b>∨ = (−1)<sup>s</sup>0</b> (zero).                  |

where s = sign bit; e = the exponent field; f = the fraction field.

For the above five representations, *e* is treated as an unsigned integer. Case 1 generates NaN (not an number) and is primarily used for software signaling. Case 4 represents a denormalized number. Case 5 represents positive and negative zero.

#### Figure 4–10. TMS320C4x Single-Precision Twos-Complement Floating-Point Format ‡



In comparison, Figure 4–10 shows the the 'C40 twos-complement floatingpoint format. In this format, two cases can be used to define value v of a number:



where s = sign bit; e = the exponent field; f = the fraction field.

- † NaN = not a number
- ‡ Same format as for the TMS320C3x

For this representation, *e* is treated as a twos-complement integer. The fraction and sign bit form a normalized twos-complement mantissa.

#### Note: Symbols to Differentiate Between IEEE and 'C40 Formats

In order to differentiate between the symbols used to define these two formats, all IEEE fields are subscripted with an IEEE (e.g.,  $e_{IEEE}$ ,  $s_{IEEE}$ , etc.). Similarly, all twos-complement fields are subscripted with a two (i.e.,  $e_{two}$ ,  $s_{two}$ ,  $f_{two}$ ).

## 4.4.1 Converting IEEE Format to Twos-Complement Floating-Point Format

The most common conversion is the IEEE to twos-complement format. This conversion is done according to rules in the following table:

Table 4–1. Rules for Converting IEEE Format to Twos-Complement Floating-Point Format

|      | If These Value                      | es Are Pi | resent                  | Then These Values Equal      |                  |                             |       |  |
|------|-------------------------------------|-----------|-------------------------|------------------------------|------------------|-----------------------------|-------|--|
| Case | eieee                               | SIEEE     | <i>f<sub>IEEE</sub></i> | e <sub>two</sub>             | s <sub>two</sub> | f <sub>two</sub>            | SIEEE |  |
| 1    | 255                                 | 1         |                         | 7Fh                          | 1                | 00 0000h                    |       |  |
| 2    | 255                                 | 0         |                         | 7Fh                          | 0                | 7F FFFFh                    |       |  |
| 3    | 0< <i>e<sub>lEEE</sub> &lt;</i> 255 | 0         |                         | <i>e<sub>lEEE</sub>-</i> 7Fh |                  | <i><sup>†</sup>IEEE</i>     | 0     |  |
| 4    | 0< <i>e<sub>lEEE</sub> &lt;</i> 255 | 1         | ≠0                      | <i>e<sub>lEEE</sub></i> –7Fh |                  | <i>Ī<sub>IEEE</sub>+1</i> † | 1     |  |
| 5    | 0< e <sub>IEEE</sub> <255           | 1         | 0                       | elEEE-80h                    |                  | 0                           | 1     |  |
| 6    | 0                                   |           |                         | 80h                          | 0                | 00 0000h                    |       |  |

 $\overline{f}_{IEEE}$  = ones complement of  $f_{IEEE}$ .

**Case 1** maps the IEEE positive NaNs and positive infinity to the single-precision twos-complement most positive number. Overflow is also signaled to allow you to check for these special cases.

**Case 2** maps the IEEE negative NaNs and negative infinity to the singleprecision twos-complement most negative number. Overflow is also signaled to allow you to check for these special cases.

**Case 3** maps the IEEE positive normalized numbers to the identical value in the twos-complement positive number.

**Case 4** maps the IEEE negative normalized numbers with a nonzero fraction to the identical value in the twos-complement negative number.

**Case 5** maps the IEEE negative normalized numbers with a zero fraction to the identical value in the twos-complement negative number.

**Case 6** maps the IEEE positive and negative denormalized numbers and positive and negative zeroes to a twos-complement zero.

The TMS320C40 assumes that the IEEE numbers are stored as an integer in memory or in a register. When converted, they are always placed in an extended-precision register by using the exponent and fraction fields of these registers. Any arithmetic operations that are performed on the fraction field of the IEEE number should be performed **only** on the IEEE **fraction field**. The eight LSBs of the extended-precision register are set to zero.

# 4.4.2 Converting Twos-Complement Floating-Point Format to IEEE Format

This conversion is done according to rules in the following table:

Table 4–2. Rules for Converting Twos-Complement Floating Point Format to IEEE Format

|      | If These Values Are Present                |      |      | Then These Values Equal     |       |                      |
|------|--------------------------------------------|------|------|-----------------------------|-------|----------------------|
| Case | etwo                                       | Stwo | ftwo | <i>e</i> IEEE               | SIEEE | fIEEE                |
| 1    | -128                                       |      |      | 00h                         | 0     | 00 0000h             |
| 2    | -127                                       |      |      | 00h                         | 0     | 00 0000h             |
| 3    | <i>–</i> 126≤ <i>e<sub>two</sub> ≤</i> 127 | 0    |      | <i>e<sub>two</sub></i> +7Fh | 0     | f <sub>two</sub>     |
| 4    | –126≤ <i>e<sub>two</sub> ≤</i> 127         | 1    | ≠0   | <i>e<sub>two</sub></i> +7Fh | 0     | Ī <sub>two</sub> +1† |
| 5    | –126≤ e <sub>two</sub> ≤127                | 1    | 0    | <i>e<sub>two</sub></i> +7Eh | 1     | 00 0000h             |
| 6    | 127                                        | 1    | 0    | FFh                         | 1     | 00 0000h             |

†  $f_{two}$  = ones complement of  $f_{two}$ .

**Case 1** maps a twos-complement zero to a positive IEEE zero.

**Case 2** maps the twos-complement numbers that are too small to be represented as normalized IEEE numbers to a positive IEEE zero.

**Case 3** maps the positive twos-complement numbers that are not covered by case 2 into the identically valued IEEE number.

**Case 4** maps the negative twos-complement numbers with a nonzero fraction that are not covered in case 2 into the identically valued IEEE number.

**Case 5** maps all the negative twos-complement numbers with a zero fraction, except for the most negative twos-complement number and those that are not covered in case 2, into the identically valued IEEE number.

**Case 6** maps the most negative twos-complement number to the IEEE negative infinity.

TheTMS320C4x assumes that the twos-complement numbers are in memory or are in an extended-precision register using the exponent and fraction field of the register (shown in Figure 4–10 on page 4-11). If the value is in an extended-precision register, then only the 24 MSBs of the fraction field are manipulated as the fraction field and for detection of the special cases. The result of the conversion goes to a register as an integer.

## 4.5 Floating-Point Multiplication

A floating-point number  $\alpha$  can be written in floating-point format as in the following formula, where  $\alpha(man)$  is the mantissa and  $\alpha(exp)$  is the exponent.

 $\alpha = \alpha(man) \times 2^{\alpha(exp)}$ 

The product of  $\alpha$  and b is c, defined as

 $c = \alpha \times b = \alpha(man) \times b(man) \times 2(\alpha(exp)+b(exp))$ 

 $c(man) = \alpha(man) \times b(man)$ 

 $c(exp) = \alpha(exp) + b(exp)$ 

During floating-point multiplication, source operands are always assumed to be in the extended-precision floating-point format:

If the source of the operands is in **short floating-point format**, it is *extended* to the extended-precision floating-point format.

If the source of the operands is in **single-precision floating-point format**, it is *extended* to extended-precision format.

These conversions occur automatically in hardware with no overhead. All results of floating-point multiplications are in the extended-precision format. These multiplications occur in a single cycle.





Figure 4–11 is a flowchart showing floating-point multiplication:

- In step 1 (steps are shown as numbers in parentheses), the 32-bit source operand mantissas are multiplied, producing a 64-bit result c(*man*). (Note that input and output data are always represented as normalized numbers.)
- 2) In step 2, the exponents are added, yielding c(*exp*).
- 3) Steps 3 through 6 check for special cases.
- 4) Step 3 checks for whether c(man) in extended-precision format is equal to zero. If c(man) is zero, step 7 sets c(exp) to -128, thus yielding the representation for zero.

- 5) **Steps 4 and 5** normalize the result.
- If a right shift of one is necessary, then in step 8, c(man) is right-shifted one bit, and one is added to c(exp).
- 7) If a right shift of two is necessary, then in step 9, c(man) is right-shifted two bits, and two is added to c(exp). Step 6 occurs when the result is normalized.
- 8) In step 10, c(man) is set in the extended-precision floating-point format.
- 9) Steps 11 through 16 check for special cases of c(*exp*).
- In step 14, if c(*exp*) has overflowed (step 11) in the positive direction, then c(*exp*) is set to the most positive extended-precision format value. If c(*exp*) has overflowed in the negative direction, then c(*exp*) is set to the most negative extended-precision format value.
- 11) If c(exp) has underflowed (step 12), then c is set to zero (step 15); i.e., c(man) = 0 and c(exp) = -128.

The following examples illustrate how floating-point multiplication is performed on the TMS320C40. For these examples, the implied most significant nonsign bit is made explicit.

Example 4–1. Floating-Point Multiply (Both Mantissas = -2.0)

Let

where a and b are both represented in binary form according to the normalized single-precision floating-point format. Then

4

To place this number in the proper normalized format, it is necessary to shift the mantissa two places to the right and add two to the *exp*onent. This yields

In floating-point multiplication, the exponent of the result may overflow. This can occur when the exponents are initially added or when the exponent is modified during normalization.

Example 4–2. Floating-Point Multiply (Both Mantissas = 1.5)

Let

where  $\alpha$  and b are both represented in binary form according to the single-precision float-ing-point format. Then

 $01.1000000000000000000 \times 2^{\alpha(exp)}$ 

 $\times$  01.100000000000000000000  $\times$  2<sup>b(*exp*)</sup>

To place this number in the proper normalized format, it is necessary to shift the mantissa one place to the right and add one to the exponent. This yields

 $01.100000000000000000000000 \times 2^{\alpha(exp)}$ 

Example 4–3. Floating-Point Multiply (Both Mantissas = 1.0)

Let

where a and b are both represented in binary form according to the single-precision floating-point format. Then

This number is in the proper normalized format. Therefore, no shift of the mantissa or modification of the exponent is necessary.

These examples have shown cases where the product of two normalized numbers can be normalized with a shift of zero, one, or two. For all normalized inputs with the floating-point format used by the TMS320C40, a normalized result can be produced by a shift of zero, one, or two.

Example 4–4. Floating-Point Multiply Between Positive and Negative Numbers

Let

Then

The result is  $c = -2.0 \times 2(\alpha(exp) + b(exp))$ 

Example 4–5. Floating-Point Multiply by Zero

All multiplications by a floating-point zero yield a result of zero (f=0, s=0, and exp=-128).

### 4.6 Floating-Point Addition and Subtraction

In floating-point addition and subtraction, two floating-point numbers  $\boldsymbol{\alpha}$  and  $\boldsymbol{b}$  can be defined as

 $\alpha = \alpha(man) \times 2 \alpha(exp)$ 

 $b = b(man) \times 2^{b(exp)}$ 

The sum (or difference) of  $\alpha$  and b can be defined as

 $c = \alpha \pm b$ =  $(\alpha(man) \pm (b(man) \times 2^{-(\alpha(exp)-b(exp))})) \times 2^{\alpha(exp)},$ if  $\alpha(exp) \ge b(exp)$ =  $((\alpha(man) \times 2^{-(b(exp)-\alpha(exp))}) \pm b(man)) \times 2^{b(exp)},$ if  $\alpha(exp) < b(exp)$ 

Figure 4–12 is the flowchart for floating-point addition. Since this flowchart assumes signed data, it is also appropriate for floating-point subtraction. In this figure, it is assumed that  $\alpha(exp) \leq b(exp)$ . In step 1 (steps are numbers in parentheses), the source exponents are compared, and c(exp) is set equal to the largest of the two source exponents. In step 2, d is set to the difference of the two exponents. In step 3, the mantissa with the smallest exponent, in this case  $\alpha(man)$ , is right shifted d bits in order to align the mantissas. After the mantissas have been aligned, they are added (step 4).

Steps 5 through 7 check for a special case of c(man). If c(man) is zero (step 5), then c(exp) is set to its most negative value (step 8) to yield the correct representation of zero. If c(man) has overflowed c (step 6), then in step 9, c(man) is right shifted one bit, and one is added to c(exp). In step 10, the result is normalized. In steps 11 and 12, special cases of c(exp) are tested. If c(exp) has overflowed, then c is set to the most positive extended-precision value if it is positive; otherwise, it is set to the most negative extended-precision value.

Figure 4–12. Flowchart for Floating-Point Addition



The following examples describe the floating-point addition and subtraction operations. It is assumed that the data is in the extended-precision floating-point format.

#### *Example 4–6. Floating-Point Addition*

In the case of two normalized numbers to be summed, let

It is necessary to shift b to the right by one so that  $\alpha$  and b have the same exponent. This yields

Then

As in the case of multiplication, it is necessary to shift the binary point one place to the left and to add one to the exponent. This yields

#### Example 4–7. Floating-Point Subtraction

A subtraction is performed in this example. Let

The operation to be performed is  $\alpha$  – b. The mantissas are already aligned because the two numbers have the same exponent. The result is a large cancellation of the upper bits, as shown below.

The result must be normalized. In this case, a left shift of 31 is required. The exponent of the result is modified accordingly. The result is

#### Example 4–8. Floating-Point Addition With a 32-Bit Shift

This example illustrates a situation where a full 32-bit shift is necessary to normalize the result. Let

The operation to be performed is  $\alpha$  + b.

| ~     |                                        | 88       |
|-------|----------------------------------------|----------|
| 011   | 111111111111111111111111111111111111   | <u> </u> |
| • • • |                                        | × .      |
|       |                                        | ×.       |
| + 100 | 000000000000000000000000000000000000   | 38E -    |
|       |                                        | æ.       |
|       |                                        | 222C -   |
|       |                                        | 3000 -   |
|       | 11111111111111111111111111111111111111 | ۳.       |

Normalizing the result requires a left shift of 32 and a subtraction of 32 from the exponent. The result is

#### Example 4–9. Floating-Point Addition/Subtraction and Zero

When floating-point addition and subtraction are performed with a floating-point 0, the following identities are satisfied:

$$\alpha \pm 0 = \alpha \ (\alpha \neq 0)$$
  

$$0 \pm 0 = 0$$
  

$$0 -\alpha = -\alpha \ (\alpha \neq 0)$$

### 4.7 Normalization (NORM Instruction)

The NORM instruction normalizes an extended-precision floating-point number that is assumed to be unnormalized. Since the number is assumed to be unnormalized, no implied most significant nonsign bit is assumed. The NORM instruction executes the following three steps:

- 1) Locates the most significant nonsign bit of the floating-point number.
- 2) Left shifts to normalize the number.
- 3) Adjusts the exponent.

Given the extended-precision floating-point value  $\alpha$  to be normalized, the normalization, norm (), is performed as shown in Figure 4–13.





#### Example 4–10. NORM Instruction

Assume that an extended-precision register contains the value

When the normalization is performed on a number assumed to be unnormalized, the binary point is assumed to be

This number is then sign extended one bit so that the mantissa contains 33 bits.

The intermediate result after the most significant nonsign bit is located and the shift performed is:

The final 32-bit value output after removing the redundant bit is:

man = 0000000000001000000000000000000000, *exp* = -19

The NORM instruction is useful for counting the number of leading zeros or leading ones in a 32-bit field. If the exponent is initially zero, the absolute value of the final value of the exponent is the number of leading ones or zeros. This instruction is also useful for manipulating unnormalized float-ing-point numbers.

## 4.8 Rounding (RND Instruction)

The RND instruction rounds a number from the extended-precision floating-point format to the single-precision floating-point format. Rounding is similar to floating-point addition. Given the number  $\alpha$  to be rounded, the following operation is performed first.

 $c = \alpha(man) \times 2^{\alpha(exp)} + (1 \times 2^{\alpha(exp)-24})$ 

Next, a conversion from extended-precision floating-point to single-precision floating-point format is performed. Given the extended-precision floating-point value, the rounding, rnd(), is performed as shown in Figure 4–14.

Figure 4–14. Flowchart for Floating-Point Rounding by the RND Instruction



## 4.9 Floating-Point-to-Integer Conversion (FIX Instruction)

Floating-point to integer conversion, using the FIX instructions, allows extended-precision floating-point numbers to be converted to single-precision integers in a single cycle. The floating-point to integer conversion of the value x is referred to here as fix(x). The conversion does not overflow if  $\alpha$ , the number to be converted, is in the range

 $-2^{31} \le \alpha \le 2^{31} - 1$ 

First, you must be certain that

$$\alpha(exp) \leq 30$$

If these bounds are not met, an overflow occurs. If an overflow occurs in the positive direction, the output is the most positive integer. If an overflow occurs in the negative direction, the output is the most negative integer. If  $\alpha(exp)$  is within the valid range, then  $\alpha(man)$ , with implied bit included, is sign-extended and right-shifted (rs) by the amount

$$rs = 31 - \alpha(exp)$$

This right shift (rs) shifts out those bits corresponding to the fractional part of the mantissa. For example:

If  $0 \le x < 1$ , then fix(x) = 0. If  $-1 \le x < 0$ , then fix(x) = -1.

The flowchart for the floating-point to integer conversion is shown in Figure 4–15.

Figure 4–15. Flowchart for Floating-Point-to-Integer Conversion by FIX Instructions



## 4.10 Integer-to-Floating-Point Conversion (FLOAT Instruction)

Integer to floating-point conversion, using the FLOAT instruction, allows single-precision integers to be converted to extended-precision float-ing-point numbers. The flowchart for this conversion is shown in Figure 4–16.

α

Figure 4–16. Flowchart for Integer-to-Floating-Point Conversion by FLOAT Instructions



4

Data Formats and Floating-Point Operation

## 4.11 Reciprocal (RCPF Instruction)

The RCPF instruction generates a satisfactory estimate of the reciprocal of a floating-point number. The estimate has the correct exponent, and the mantissa is often accurate to the eighth binary position (mantissa error is thus  $< 2^{-8}$ ). Also, this estimate may be used as a seed for an algorithm to compute the reciprocal to even greater accuracy. (The Newton–Raphson algorithm, described in this section, is one such case.)

Figure 4-17 below depicts the algorithm used by instruction RCPF.

- **u** The input is assumed to be  $v = vman \times 2^{vexp}$ .
- **u** The output is assumed to be  $x = xman \times 2^{xexp}$ .
- *vexp* is negated.
- □ If *vexp* = −128, the result is saturated to the most positive number, and the overflow flag is set. The N condition flag is set to the same sign as *vsign*.





The look-up table is addressed by forming a nine-bit address consisting of *vsign* and bits 22–15 of *vfrac*. The eight-bit output of the lookup table is forms bits 22–15 of *xfrac*. Bits 14–0 of xfrac are set to zero. *xsign* is set to *vsign*.

The lookup-table values are generated from simulation results.

#### 4.11.1 Reciprocal Algorithm

The RCPF instruction provides the reciprocal of a number. The estimate has the correct exponent and a mantissa accurate to the eighth binary place (i.e., the error of the mantissa is  $< 2^{-8}$ ). The **Newton–Raphson algorithm** (shown below) may be used to further extend the mantissa's precision:

x[n+1] = x[n](2 - vx[n])

where v = the number whose reciprocal is to be found.

x[0], the seed for the algorithm, is given by RCPF. For each iteration of the algorithm, the number of accurate bits in the mantissa doubles. Using RCPF, you can start with an estimate accurate to eight bits. With one iteration, accuracy is 16 bits in the mantissa, and with a second iteration, accuracy is 32 bits.

The TMS320C4x program to implement this algorithm is shown in Figure 4–18. Each step of the algorithm is labeled along with the corresponding accuracy achieved at the end of the step. The algorithm takes only seven machine cycles.

*Figure 4–18. Newton–Raphson Algorithm for Computing the Reciprocal* 

| RCPF     | R0,R1    | ; $R0 = v$ , $R1 = x[0]$                    |
|----------|----------|---------------------------------------------|
| <b>,</b> |          |                                             |
| MPYF     | RI,R0,R2 |                                             |
| SUBRF    | 2.0,R2   |                                             |
| MPYF     | R2,R1    | ; end of first iteration (16-bit accuracy)  |
| ;        |          |                                             |
| MPYF     | R1,R0,R2 |                                             |
| SUBRF    | 2.0,R2   |                                             |
| MPYF     | R2,R1    | ; end of second iteration (32-bit accuracy) |
| ;        |          |                                             |
| ;        |          | ; R1 = 1/v                                  |
| ;        |          |                                             |
|          |          |                                             |

Data Formats and Floating-Point Operation

## 4.12 Reciprocal Square Root (RSQRF Instruction)

The RSQRF instruction generates an estimated reciprocal of the square root of a floating-point number. It parallels some of the operational characteristics of the RCPF instruction (Section 4.11) in that the RSQRF:

- it generates an estimate (in this case the reciprocal of the square root of a floating-point number),
- the mantissa is accurate to the eighth binary place (mantissa error is  $< 2^{-8}$ ), and
- often, this is a satisfactory estimate of the reciprocal of a number's square root; in other cases, it may be used as a seed for an algorithm that computes the reciprocal square root to an even greater accuracy.

Figure 4–19 depicts the RSQRF algorithm.

- The input is assumed to be  $v = vman \times 2^{vexp}$ .
- **u** The output is assumed to be  $x = xman \times 2^{xexp}$ .
- $\Box$  vexp + 1 is negated and shifted right one bit with sign extension.
- If vexp = -128, the result is saturated to the most positive number, and the overflow flag is set.





The look-up table is addressed by forming a nine-bit address consisting of the least significant bit of *vexp* and bits 22 - 15 of *vfrac*. The eight-bit output of the look-up table is used to form bits 22 - 15 of xfrac. Bits 14 - 0 of xfrac are set to zero. xsign is set to 0. There is no provision for negative values of *v*.

The look-up-table values are generated from simulation results.

Of course, given the result of this algorithm, division is performed by a simple multiplication: y/v = yx[n] where x[n] is the estimate of 1/v as determined by the Newton–Raphson algorithm or an other algorithm.

#### 4.12.1 Reciprocal Square Root Algorithm

The RSQRF instruction provides the reciprocal of the square root of a number. The estimate has the correct exponent and a mantissa accurate to the eighth binary place (i.e., the error of the mantissa is  $< 2^{-8}$ ). The **Newton– Raphson algorithm** (shown below) may be used to further extend the mantissa's precision:

x[n+1] = x[n] (1.5-(v/2) x[n] x[n])

where v = the number whose reciprocal is to be found.

The seed for the algorithm, x[0], is given by RSQRF. For each iteration of the algorithm, the number of accurate bits in the mantissa doubles. Using RSQRF, you can start with an estimate having an accuracy to eight bits. With one iteration, accuracy is 16 bits in the mantissa, and with a second iteration, accuracy is 32 bits.

|  | Figure 4–20. | Newton-Raphson Algorit | thm for Computing the F | Reciprocal Square Root |
|--|--------------|------------------------|-------------------------|------------------------|
|--|--------------|------------------------|-------------------------|------------------------|

|   | RCPF  | R0,R1    | ; $R0 = v$ , $R1 = x[0]$                    |
|---|-------|----------|---------------------------------------------|
|   | MPYF  | 0.5,R0   | ; R0 = v/2                                  |
| ; |       |          |                                             |
|   | MPYF  | R1,R1,R2 |                                             |
|   | MPYF  | R0,R2    |                                             |
|   | SUBRF | 1.5,R2   |                                             |
|   | MPYF  | R2,R1    | ; end of first iteration (16-bit accuracy)  |
| ; |       |          |                                             |
|   | MPYF  | R1,R1,R2 |                                             |
|   | MPYF  | R0,R2    |                                             |
|   | SUBRF | 1.5,R2   |                                             |
|   | MPYF  | R2,R1    | ; end of second iteration (32-bit accuracy) |
| ; |       |          |                                             |
| ; |       |          | ; $R1 = 1/(v^{*}0.5)$                       |
| ; |       |          |                                             |

The TMS320C4x program to implement this algorithm is shown in Figure 4–20. Each step of the algorithm is labeled, and the corresponding accuracy achieved is noted at the end of the step. The algorithm takes only ten machine cycles (compared to 30 cycles on the 'C3x without a look-up table).

#### 4.12.2 Background on the Reciprocal Square Root

In many applications, normalization of data values is necessary. Often, the normalizing factor is the square root of another quantity. For example, when one vector is given, the unit vector in the same direction as the original vector can be found by normalizing the original vector by the length of the vector. This involves division by a square root. The 'C40 provides a simple way to directly determine this quantity, instead of going through a two-step approach of finding the square root and then finding the reciprocal of the square root.

Of course, given the result of this algorithm, the square root is found by a simple multiplication:

$$v = v x[n]$$

where x[n] is the estimate of  $1/\sqrt{v}$  as determined by the Newton–Raphson algorithm or some other algorithm.



## **Chapter 5**

# Addressing

The TMS320C40 supports five groups of powerful addressing modes. Six types of addressing may be used within the groups, which facilitates access of data from memory, registers, and the instruction word. This chapter details the operation, encoding, and implementation of the addressing modes. It also discusses the management of system stacks, queues, and deques in memory. The major topics in this chapter:

#### Section

| 5.1 | Types of Addressing  Register Direct Indirect Immediate                                                                                                      | 5-3<br>5-4<br>5-5    |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
|     | PC-Relative                                                                                                                                                  | 5-17                 |
| 5.2 | Groups of Addressing Modes<br>General Addressing Modes<br>Three-Operand Addressing Modes<br>Parallel Addressing Modes<br>Conditional-Branch Addressing Modes | 5-19<br>5-20<br>5-23 |
| 5.3 | Circular Addressing                                                                                                                                          | 5-25                 |
| 5.4 | Bit-Reversed Addressing                                                                                                                                      | 5-30                 |
| 5.5 | System Stack Management                                                                                                                                      | 5-31                 |

Page

### 5.1 Types of Addressing

Five **types of addressing** allow access of data from memory, registers, and the instruction word:

|                        | Sub–<br><u>section</u> | Page |
|------------------------|------------------------|------|
| Register addressing    | 5.1.1                  | 5-3  |
| Direct addressing      | 5.1.2                  | 5-4  |
| Indirect addressing    | 5.1.3                  | 5-5  |
| Immediate addressing   | 5.1.4                  | 5-17 |
| PC Relative addressing | 5.1.5                  | 5-17 |

Some types of addressing are appropriate for some instructions and not others. For this reason, the types of addressing are used in the four different **groups of addressing modes** as follows:

| 5 |                                                                                                                          | Sub-<br>section | Page |
|---|--------------------------------------------------------------------------------------------------------------------------|-----------------|------|
|   | <ul> <li>General addressing modes (G):</li> <li>Register</li> <li>Direct</li> <li>Indirect</li> <li>Immediate</li> </ul> | 5.2.1           | 5-19 |
|   | <ul> <li>Three-operand addressing modes (T):</li> <li>Register</li> <li>Immediate</li> <li>Indirect</li> </ul>           | 5.2.2           | 5-20 |
| Q | Parallel addressing modes (P):<br>Register<br>Indirect                                                                   | 5.2.3           | 5-23 |
|   | Conditional-branch addressing modes (B):<br>Register<br>PC-relative                                                      | 5.2.4           | 5-24 |

The six types of addressing are discussed first (subsections 5.1.1 through 5.1.5, beginning on the next page), followed by the five groups of addressing modes (section 5.2, beginning on page 5-19).

### 5.1.1 Register Addressing

In register addressing, a CPU register contains the operand, as shown in this example:

ABSF R1 ; R1 = |R1|

The syntax for the CPU registers, the assembler syntax, and the assigned function for those registers are listed in Table 5–1.

 Table 5–1.
 CPU Register/Assembler Syntax and Function

| Register Machine                                                                 | Assembler                                                              | Assigned                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Value                                                                            | Syntax                                                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 00h<br>01h<br>02h<br>03h<br>04h<br>05h<br>06h<br>07h<br>1Ch<br>1Dh<br>1Eh<br>1Fh | R0<br>R1<br>R2<br>R3<br>R4<br>R5<br>R6<br>R7<br>R8<br>R9<br>R10<br>R11 | Extended-precision register<br>Extended-precision register |
| 08h                                                                              | AR0                                                                    | Auxiliary register 0                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 09h                                                                              | AR1                                                                    | Auxiliary register 1                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0Ah                                                                              | AR2                                                                    | Auxiliary register 2                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0Bh                                                                              | AR3                                                                    | Auxiliary register 3                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0Ch                                                                              | AR4                                                                    | Auxiliary register 4                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0Dh                                                                              | AR5                                                                    | Auxiliary register 5                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0Eh                                                                              | AR6                                                                    | Auxiliary register 6                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0FH                                                                              | AR7                                                                    | Auxiliary register 7                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10h                                                                              | DP                                                                     | Data-page pointer                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11h                                                                              | IR0                                                                    | Index register 0                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 12h                                                                              | IR1                                                                    | Index register 1                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 13h                                                                              | BK                                                                     | Block-size register                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 14h                                                                              | SP                                                                     | Active stack pointer                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15h                                                                              | ST                                                                     | Status register                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 16h                                                                              | DIE                                                                    | DMA coprocessor interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17h                                                                              | IIE                                                                    | Internal interrupt enable register                                                                                                                                                                                                                                                                                                                                                                                                             |
| 18h                                                                              | IIF                                                                    | IIOF pins and interrupt flag register                                                                                                                                                                                                                                                                                                                                                                                                          |
| 19h                                                                              | RS                                                                     | Repeat start address                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1Ah                                                                              | RE                                                                     | Repeat end address                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1Bh                                                                              | RC                                                                     | Repeat counter                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 5.1.2 Direct Addressing

In direct addressing, the data address is formed by the concatenation of the 16 least significant bits of the data page pointer (DP) with the 16 least significant bits of the instruction word (expr). This results in 65536 pages (64K words per page), giving you a large address space without requiring a change of the page pointer. The syntax and operation for direct addressing are listed below.

Syntax: @expr

**Operation:** address = DP concatenated with expr

Figure 5–1 shows the formation of the data address. Example 5–1 gives an instruction example with data before and after instruction execution.



#### Example 5–1. Direct Addressing

ADDI @OBCDEh,R7

#### **Before Instruction:**

DP = 108Ah

R7 = 11h

Data at 108A BCDEh = 1234 5678h

#### **After Instruction:**

DP = 108Ah R7 = 1234 5689h Data at 108A BCDEh = 1234 5678h

### 5.1.3 Indirect Addressing

Indirect addressing is used to specify the address of an operand in memory through the contents of an auxiliary register, optional displacements, and index registers. This arithmetic is performed by the auxiliary register arithmetic units (ARAUs) and is unsigned. (All 32 bits of the auxiliary and index registers are used in indirect addressing.)

The flexibility of indirect addressing is possible because the ARAUs on the TMS320C40 are used to modify auxiliary registers in parallel with operations within the main CPU. Indirect addressing is specified by a five-bit field in the instruction word, referred to as the **mod field** (in the left side of Table 5–2 on page 5-6 as well as in the examples that follow). A **displacement** is either an explicit unsigned 5-bit or 8-bit integer contained in the instruction word or an implicit displacement of one. Two index registers, IR0 and IR1, can also be used in indirect addressing, enabling the use of 32-bit indirect displacements. In some cases, an addressing scheme using circular or bit-reversed addressing is optional. The mechanism for generating addresses in circular addressing is discussed in Section 5.3, bit-reversed in Section 5.4.

Table 5–2 lists the various kinds of indirect addressing, along with the value of the modification (mod) field, assembler syntax, operation, and function for each. The succeeding 18 examples show the operation for each kind of indirect addressing.

| Mod Field                             | Syntax           | Operation                             | Description                                           |  |  |
|---------------------------------------|------------------|---------------------------------------|-------------------------------------------------------|--|--|
| Indirect Addressing with Displacement |                  |                                       |                                                       |  |  |
| 00000                                 | *+ARn(disp)      | addr = ARn + disp                     | With predisplacement add                              |  |  |
| 00001                                 | *– ARn(disp)     | addr = ARn – disp                     | With predisplacement subtract                         |  |  |
| 00010                                 | *++ARn(disp)     | addr = ARn + disp<br>ARn = ARn + disp | With predisplacement add and modify                   |  |  |
| 00011                                 | *– – ARn(disp)   | addr = ARn – disp<br>ARn = ARn – disp | With predisplacement subtract and modify              |  |  |
| 00100                                 | *ARn++(disp)     | addr = ARn<br>ARn = ARn + disp        | With postdisplacement add and modify                  |  |  |
| 00101                                 | *ARn – – (disp)  | addr = ARn<br>ARn = ARn – disp        | With postdisplacement subtract and modify             |  |  |
| 00110                                 | *ARn++(disp)%    | addr = ARn<br>ARn = circ(ARn + disp)  | With postdisplacement add and circular modify         |  |  |
| 00111                                 | *ARn – – (disp)% | add = ARn<br>ARn = circ(ARn – disp)   | With postdisplacement subtract and<br>circular modify |  |  |
|                                       | Indi             | irect Addressing with Ind             | ex Register IRO                                       |  |  |
| 01000                                 | *+ARn(IR0)       | addr = ARn + IR0                      | With preindex (IR0) add                               |  |  |
| 01001                                 | * ARn(IR0)       | addr = ARn – IR0                      | With preindex (IR0) subtract                          |  |  |
| 01010                                 | *++ARn(IR0)      | addr = ARn + IR0<br>ARn = ARn + IR0   | With preindex (IR0) add and modify                    |  |  |
| 01011                                 | * ARn(IR0)       | addr = ARn – IR0<br>ARn = ARn – IR0   | With preindex (IR0) subtract and modify               |  |  |
| 01100                                 | *ARn++(IR0)      | addr = ARn<br>ARn = ARn + IR0         | With postindex (IR0) add and modify                   |  |  |
| 01101                                 | *ARn (IR0)       | addr= ARn<br>ARn = ARn – IR0          | With postindex (IR0) subtract and modify              |  |  |
| 01110                                 | *ARn++(IR0)%     | addr = ARn<br>ARn = circ(ARn + IR0)   | With postindex (IR0) add and circular modify          |  |  |
| 01111                                 | *ARn (IR0)%      | addr = ARn<br>ARn = circ(ARn) – IR0   | With postindex (IR0) subtract and circular modify     |  |  |

### Table 5–2. Indirect Addressing

### LEGEND:

| addr   | = memory address                                            |
|--------|-------------------------------------------------------------|
| ARn    | <ul> <li>auxiliary register AR0 – AR7</li> </ul>            |
| IRn    | <ul> <li>index register IR0 or IR1</li> </ul>               |
| disp   | <ul> <li>displacement (5 bits or 8 bits on 'C40)</li> </ul> |
| ++     | <ul> <li>add and modify</li> </ul>                          |
|        | <ul> <li>subtract and modify</li> </ul>                     |
| circ() | <ul> <li>address in circular addressing</li> </ul>          |
| %      | <ul> <li>where circular addressing is performed</li> </ul>  |

| Mod Field | Syntax                                      | Operation                           | Description                                          |  |  |  |
|-----------|---------------------------------------------|-------------------------------------|------------------------------------------------------|--|--|--|
|           | Indirect Addressing with Index Register IR1 |                                     |                                                      |  |  |  |
| 10000     | *+ ARn(IR1)                                 | addr = ARn + IR1                    | With preindex (IR1) add                              |  |  |  |
| 10001     | * – ARn(IR1)                                | addr = ARn - IR1                    | With preindex (IR1) subtract                         |  |  |  |
| 10010     | * ++ ARn(IR1)                               | addr = ARn + IR1<br>ARn = ARn + IR1 | With preindex (IR1) add<br>and modify                |  |  |  |
| 10011     | * ARn(IR1)                                  | addr = ARn – IR1<br>ARn = ARn – IR1 | With preindex (IR1) subtract<br>and modify           |  |  |  |
| 10100     | * ARn ++ (IR1)                              | addr = ARn<br>ARn = ARn + IR1       | With postindex (IR1) add<br>and modify               |  |  |  |
| 10101     | *ARn (IR1)                                  | addr = ARn<br>ARn = ARn - IR1       | With postindex (IR1) subtract<br>and modify          |  |  |  |
| 10110     | * ARn ++ (IR1)%                             | addr = ARn<br>ARn = circ(ARn + IR1) | With postindex (IR1) add<br>and circular modify      |  |  |  |
| 10111     | * ARn – – (IR1)%                            | addr = ARn<br>ARn = circ(ARn - IR1) | With postindex (IR1) subtract<br>and circular modify |  |  |  |
|           | Indirect Addressing (Special Cases)         |                                     |                                                      |  |  |  |
| 11000     | *ARn                                        | addr = ARn                          | Indirect                                             |  |  |  |
| 11001     | *ARn ++ (IR0)B                              | addr = ARn<br>ARn = B(ARn + IR0)    | With postindex (IR0) add<br>and bit-reversed modify  |  |  |  |

### Table 5-2. Indirect Addressing (Concluded)

#### LEGEND:

%

в

| ARn | = | auxiliary | register | AR0 – AR7 |
|-----|---|-----------|----------|-----------|

IRn = index register IR0 or IR1

disp = displacement

++ = add and modify

-- = subtract and modify

circ() = address in circular addressing

= where circular addressing is performed

= where bit-reversed addressing is performed

### Example 5–2. Auxiliary Register Indirect

An auxiliary register (ARn) contains the address of the operand to be fetched.





#### Example 5–3. Indirect With Predisplacement Add

The address of the operand to be fetched is the sum of an auxiliary register (ARn) and the displacement (disp). The displacement is either a 5-bit or 8-bit unsigned integer contained in the instruction word or an implied value of 1.

Operation: Assembler Syntax: Modification Field: operand address = AR*n*+ disp \*+AR*n*(disp) 00000



### Example 5–4. Indirect With Predisplacement Subtract

The address of the operand to be fetched is the contents of an auxiliary register (ARn) minus the displacement (disp). The displacement is either an 8-bit unsigned integer contained in the instruction word or an implied value of 1.



Example 5–5. Indirect With Predisplacement Add and Modify

The address of the operand to be fetched is the sum of an auxiliary register (ARn) and the displacement (disp). The displacement is either an 8-bit unsigned integer contained in the instruction word or an implied value of 1. After the data is fetched, the auxiliary register is updated with the address generated.



#### Example 5–6. Indirect With Predisplacement Subtract and Modify

The address of the operand to be fetched is the contents of an auxiliary register (ARn) minus the displacement (disp). The displacement is either an 8-bit unsigned integer contained in the instruction word or an implied value of 1. After the data is fetched, the auxiliary register is updated with the address generated.



#### Example 5–7. Indirect With Postdisplacement Add and Modify

The address of the operand to be fetched is the contents of an auxiliary register (ARn). After the operand is fetched, the displacement (disp) is added to the auxiliary register. The displacement is either an 8-bit unsigned integer contained in the instruction word or an implied value of 1.



Addressing

### Example 5–8. Indirect With Postdisplacement Subtract and Modify

The address of the operand to be fetched is the contents of an auxiliary register (ARn). After the operand is fetched, the displacement (disp) is subtracted from the auxiliary register. The displacement is either an 8-bit unsigned integer contained in the instruction word or an implied value of 1.



#### Example 5–9. Indirect With Postdisplacement Add and Circular Modify

The address of the operand to be fetched is the contents of an auxiliary register (ARn). After the operand is fetched, the displacement (disp) is added to the contents of the auxiliary register using circular addressing. This result is used to update the auxiliary register. The displacement is either an 8-bit unsigned integer contained in the instruction word or an implied value of 1.



### Example 5–10. Indirect With Postdisplacement Subtract and Circular Modify

The address of the operand to be fetched is the contents of an auxiliary register (ARn). After the operand is fetched, the displacement (disp) is subtracted from the contents of the auxiliary register through circular addressing. This result is used to update the auxiliary register. The displacement is either an 8-bit unsigned integer contained in the instruction word or an implied value of 1.



#### Example 5–11. Indirect With Preindex Add

The address of the operand to be fetched is the sum of an auxiliary register (ARn) and an index register (IR0 or IR1).

| Operation:                 | operand address = $ARn + IRm$ |  |  |
|----------------------------|-------------------------------|--|--|
| Assembler Syntax:          | *+ AR <i>n</i> (IR <i>m</i> ) |  |  |
| <b>Modification Field:</b> | 01000 if m = 0                |  |  |
|                            | 10000 if m = 1                |  |  |





The address of the operand to be fetched is the difference between an auxiliary register (ARn) and an index register (IR0 or IR1).



Example 5–13. Indirect With Preindex Add and Modify

The address of the operand to be fetched is the sum of an auxiliary register (ARn) and an index register (IR0 or IR1). After the data is fetched, the auxiliary register is updated with the address generated.



### Example 5–14. Indirect With Preindex Subtract and Modify

The address of the operand to be fetched is the difference between an auxiliary register (ARn) and an index register (IR0 or IR1). The resulting address becomes the new contents of the auxiliary register.



#### Example 5–15. Indirect With Postindex Add and Modify

The address of the operand to be fetched is the contents of an auxiliary register (ARn). After the operand is fetched, the index register (IR0 or IR1) is added to the auxiliary register.



Addressing

### Example 5–16. Indirect With PostiIndex Subtract and Modify

The address of the operand to be fetched is the contents of an auxiliary register (ARn). After the operand is fetched, the index register (IR0 or IR1) is subtracted from the auxiliary register.



### Example 5–17. Indirect With Postindex Add and Circular Modify

The address of the operand to be fetched is the contents of an auxiliary register (ARn). After the operand is fetched, the index register (IR0 or IR1) is added to the auxiliary register. This value is evaluated using circular addressing and replaces the contents of the auxiliary register.

| Operation:          | operand address = AR <i>n</i><br>AR <i>n</i> = circ(AR <i>n</i> + IR <i>m</i> ) |  |  |
|---------------------|---------------------------------------------------------------------------------|--|--|
| Assembler Syntax:   | *AR <i>n</i> ++ (IR <i>m</i> )%                                                 |  |  |
| Modification Field: | 01110 if m = 0                                                                  |  |  |
|                     | 10110 if m =1                                                                   |  |  |



#### Example 5–18. Indirect With Postindex Subtract and Circular Modify

The address of the operand to be fetched is the contents of an auxiliary register (ARn). After the operand is fetched, the index register (IR0 or IR1) is subtracted from the auxiliary register. This result is evaluated through circular addressing and replaces the contents of the auxiliary register.



#### Example 5–19. Indirect With Postindex Add and Bit-Reversed Modify

The address of the operand to be fetched is the contents of an auxiliary register (ARn). After the operand is fetched, the index register (IR0) is added to the auxiliary register. This addition is performed with a reverse-carry propagation and can be used to yield a bit-reversed (B) address. This value replaces the contents of the auxiliary register.



Addressing

### 5.1.4 Immediate Addressing

In immediate addressing, the operand is a 16-bit immediate value contained in the 16 least significant bits of the instruction word (expr). Depending upon the data types assumed for the instruction, the immediate operand may be a twos-complement integer, an unsigned integer, or a floatingpoint number. This is the syntax for this mode:

Syntax: expr

Example 5–20 gives an instruction example with before- and after-instruction data.

Example 5–20. Immediate Addressing

| Instruction |           | <b>Before Instruction:</b> | After Instruction: |
|-------------|-----------|----------------------------|--------------------|
| SUBI        | 1,R0      | R0 = 0h                    | R0 = 00 FFFF FFFFh |
| LDI         | OFFFFh,R0 | R0 = 0h                    | R0 = 00 FFFF FFFFh |
| LDF         | 5.0,R0    | R0 = 0h                    | R0 = 02 2000 0000h |
| OR          | OFFFFh,RO | R0 = 0h                    | R0 = 00 0000 FFFFh |

### 5.1.5 PC-Relative Addressing

PC-relative addressing is used for branching. Instructions of this type include B*cond*, B*cond*D, B*cond*AF, B*condAT*, DB*cond* and DB*condD* (repeat block), and LAJ (link and jump). It replaces the value of the PC with the contents of the 16 or 24 least significant bits of the instruction word. The assembler takes the *src* (a label or address) specified by the user and generates a displacement. If the branch is a standard branch, this displacement is equal to [label - (PC +1)]. If the branch is a delayed branch, this displacement is equal to [label - (PC + 3)].

The displacement is stored as a 16-bit signed integer in the least significant bits of the instruction word.

Syntax: expr

Example 5–21 gives an instruction example with before- and after-instruction data.

Example 5–21. PC-Relative Addressing

BU NEWPC ; pc=1,NEWPC= 5,displacement= 3

**Before Instruction**: PC = 1h After Instruction: PC = 5h

The 24-bit addressing mode is used to encode the program control instructions (e.g., BR, BRD, CALL, RPTB, RPTBD, LAJ). Depending on the instruction, the new PC value is derived by adding a 24-bit signed value in the instruction word with the present PC value. Bit 24 determines the type of branch (D=0 for a standard branch or D=1 for a delayed branch). Some of these instructions are encoded in Figure 5–2.

| Figure 5–2. | Encodina | for 24-Bit | PC-Relative | Addressina | Mode |
|-------------|----------|------------|-------------|------------|------|
|             |          |            |             |            |      |

| (a)                | ) | BR        | , Bl | RD     | unconditional branches (delayed and not delayed)                          |   |
|--------------------|---|-----------|------|--------|---------------------------------------------------------------------------|---|
| 31                 |   |           | 25   | 5      | 23                                                                        | 0 |
| 0 1 1              | 0 | 0 0       | 0    | D      | src                                                                       |   |
| (b)                | ) | СА        | LL:  | un     | conditional subroutine call                                               |   |
| 31                 |   |           |      |        | 23                                                                        | 0 |
| 0 1 1              | 0 | 0 0       | 1    | 0      | SIC                                                                       |   |
|                    |   |           |      |        |                                                                           |   |
| (C)                |   | RP        | TB   | R      | PRBD: repeat block (not delayed and delayed)                              | • |
| (C)<br>31          | ) |           |      |        | PRBD: repeat block (not delayed and delayed)<br>23                        | 0 |
|                    | 1 | RP<br>1 0 |      | R<br>D |                                                                           | 0 |
| 31<br>0 1 1<br>(d) | 1 | 1 0       | 0    | D      | 23<br>src<br>and jump (return address in extended-precision register R11) |   |
| 31<br>0 1 1        | 1 | 1 0       | 0    | D      | 23<br>src                                                                 | 0 |

### 5.2 Groups of Addressing Modes

Six types of addressing (covered in Section 5.1, beginning on page 5-2) form these four groups of addressing modes:

|                                         | Subsection | Page |
|-----------------------------------------|------------|------|
| General addressing modes (G)            | 5.2.1      | 5-19 |
| Three-operand addressing modes (T)      | 5.2.2      | 5-20 |
| Parallel addressing modes (P)           | 5.2.3      | 5-23 |
| Conditional-branch addressing modes (B) | 5.2.4      | 5-24 |

### 5.2.1 General Addressing Modes

Instructions that use the general addressing modes are general-purpose instructions, such as ADDI, MPYF, and LSH. Such instructions usually have this form:

### dst operation $src \rightarrow dst$

where the destination operand is signified by dst and the source operand by src; operation defines an operation to be performed with the general addressing modes to specify certain operands. Bits 31 – 29 are zero, indicating general addressing mode instructions. Bits 22 and 21 specify the general addressing mode (G) field, which defines how bits 15 through 0 are to be interpreted for addressing the *src* operand.

Options for bits 22 and 21 (G field) are as follows:

- 0 0 register (all CPU registers unless specified otherwise)
- 0 1 direct
- 1 0 indirect
- 1 1 immediate

If the *src* and *dst* fields contain register specifications, the value in these fields contains the CPU register addresses as defined by Table 5–1. For the general addressing modes, the following values of ARn are valid for indirect addressing:

$$\mathsf{ARn}, 0 \leq \mathsf{n} \leq 7$$

Figure 5–3 shows the encoding for the general addressing modes. The notation modn indicates the modification field that goes with the ARn field. Refer to Table 5–2 for further information.

| 31 |   | 29 | 28 2      | 3 22 | 21 2 | 0           | 16 15 | 11 10 | 87      | 54      | C   |
|----|---|----|-----------|------|------|-------------|-------|-------|---------|---------|-----|
| 0  | 0 | 0  | operation | 0    | 0    | dst         | 000   | 0000  | 000     | 0       | SIC |
| 0  | 0 | 0  | operation | 0    | 1    | dst         |       |       | dire    | ect     | ·   |
| 0  | 0 | 0  | operation |      |      | dst         | modn  | AR    | n       | disp    |     |
| 0  | 0 | 0  | operation | 0    | 1    | dst         |       |       | imme    | diate   |     |
|    |   |    |           |      | G    | Destination |       | S     | ource O | perands |     |

### Figure 5–3. Encoding for General Addressing Modes

### 5.2.2 Three-Operand Addressing Modes

The 19 three-operand instructions on the 'C40 use the eight address forms listed in Table 5–3:

 Table 5–3.
 Three-Operand Instruction Address Forms

### Type 1†

| Τ  | <i>src</i> 1 addressing modes         | <i>src</i> 2 addressing modes         | dst‡ |
|----|---------------------------------------|---------------------------------------|------|
| 00 | register mode (any CPU register)      | register mode (any CPU register)      | Rx   |
| 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      | Rx   |
| 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) | Rx   |
| 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) | Rx   |

#### Type 21

| Т  | <i>src</i> 1 addressing modes                          | <i>src</i> 2 addressing modes                          | dst‡ |
|----|--------------------------------------------------------|--------------------------------------------------------|------|
| 00 | register mode (any CPU register)                       | 8-bit signed immediate                                 | Rx   |
| 01 | register mode (any CPU register)                       | indirect mode *+ARn(5-bit unsigned<br>displacement)    | Rx   |
| 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)    | 8-bit signed immediate                                 | Rx   |
| 11 | indirect mode *+ARn1(5-bit un-<br>signed displacement) | indirect mode *+ARn2(5-bit un-<br>signed displacement) | Rx   |

<sup>†</sup> The 'C40 recognizes either type 1 or type 2 instructions; the 'C30 recognizes only type 1.

<sup>‡</sup> Rx = any register in the CPU (primary) register file for the respective processor.

The object values differ for three-operand instructions, depending on the assembler used:

- the TMS320C3x assembler recognizes only type 1 formats and sets bits 31–28 to **0010**<sub>2</sub>.
- the TMS320C4x assembler recognizes both types and sets bits 31–28 to 0010<sub>2</sub> for type 1 and to 0011<sub>2</sub> for type 2.

The 'C4x processor executes both types (1 and 2). The 'C30 executes only the type 1 format. The three-operand instructions MPYSHI3 and MPYUHI3 are unique to the 'C40.

All instructions **except four** can use all four of the type 2 address forms shown in Table 5–3. These exceptions, which can use only address forms 2 and 4 in type 2, are the floating-point instructions ADDF3, CMPF3, MPYF3, and SUBF3.

The remaining 15 three-operand instructions are ADDC3, ADDI3, AND3, ANDN3, ASH3, CMPI3, LSH3, MPYI3, MPYSHI3, MPYUHI3, OR3, SUBB3, SUBI3, TSTB3, and XOR3.

Note that the 3 can be omitted from a three-operand instruction mnemonic.

Bits 22 and 21 specify the three-operand addressing mode (T) field, which defines how bits 15 - 0 are to be interpreted for addressing the *src* operands. Bits 15 - 8 define the *src1* address, and bits 7 - 0 define the *src2* address.

Figure 5–4 and Figure 5–5 show the encoding for 'C4x three-operand addressing (the 'C30 recognizes only the format in Figure 5–4). The notation **modm** or **modn** indicate that the modification field goes with the ARm or ARn field, respectively. Refer to Table 5–2 (page 5-6) for further information.

The 8-bit signed immediate value supports left shifts, right shifts, and memory increment and decrement operations. The immediate value is not available for floating-point operations.

These instructions greatly help reduce code size, both assembled and compiled. They also give noticeable performance improvements in DSP and other computationally intensive applications and general-purpose code.

| 31 |   |   | 28 | 27 23     | 22 | 21 | 20  | 16 | 15  | 13  | 12 | 11 | 10  | 8 | 7 |   | 5   | 4    | 3  | 2  | 0  |
|----|---|---|----|-----------|----|----|-----|----|-----|-----|----|----|-----|---|---|---|-----|------|----|----|----|
| 0  | 0 | 1 | 0  | operation | 0  | 0  | dst |    | 0 0 | 0 ( |    | SI | rc1 |   | 0 | 0 | 0   |      | sr | c2 |    |
| 0  | 0 | 1 | 0  | operation | 0  | 1  | dst |    |     | mo  | dn |    | ARn |   | 0 | 0 | 0   |      | sr | c2 |    |
| 0  | 0 | 1 | 0  | operation | 1  | 0  | dst |    | 0 0 | 0 ( |    | SI | rc1 |   |   |   | mod | dn   |    | AF | In |
| 0  | 0 | 1 | 0  | operation | 1  | 1  | dst |    |     | mo  | dn |    | ARn |   |   | ſ | noc | lm   |    | AR | m  |
|    |   |   |    |           | 1  | Г  | ]   |    |     |     | sr | c1 |     |   |   |   |     | srca | 2  |    |    |

Figure 5–4. Encoding for Type 1 Three-Operand Addressing Modes ('C30 and 'C40)

| Figure 5–5. Encod | ing for Type 2 Three- | Operand Addressing N | Nodes ('C40 Only) |
|-------------------|-----------------------|----------------------|-------------------|
|-------------------|-----------------------|----------------------|-------------------|

| ; | 31 |   |   |   | 28 | 27       | 23 | 22 | 21 | 20 | 1   | 16 | 15 |     | 13   | 12   | 10  | 8  | 7 | 32        | 0   |
|---|----|---|---|---|----|----------|----|----|----|----|-----|----|----|-----|------|------|-----|----|---|-----------|-----|
|   | 0  | 0 | • | 1 | 1  | operatio | n  | 0  | 0  | ľ  | dst |    | 0  | 0   | 0    |      | Rn  |    |   | immediate |     |
|   | 0  | 0 | • | 1 | 1  | operatio | n  | 0  | 1  |    | dst |    | 0  | 0   | 0    |      | Rn  |    |   | disp      | ARn |
|   | 0  | 0 | • | 1 | 1  | operatio | on | 1  | 0  |    | dst |    |    | . 1 | disp |      | AF  | ٦n |   | immediate |     |
|   | 0  | 0 |   | 1 | 1  | operatio | on | 1  | 1  |    | dst |    |    |     | disp |      | AF  | Rn |   | disp      | ARm |
| - |    |   |   |   |    | -        |    | -  | r  | .  |     |    |    |     |      | src1 | · . | 1  |   | src2      |     |

### 5.2.3 Parallel Addressing Modes

Instructions that use parallel addressing, indicated by || (two vertical bars), allow for the greatest amount of parallelism possible. The destination operands are indicated as d1 and d2, signifying dst1 and dst2, respectively (see Figure 6-4). The source operands, signified by src1 and src2, use the extended-precision registers. The parallel operation to be performed is called operation.

| Figure 5–6. | Encoding | for H | Parallel Add | dressing M | odes  |       |
|-------------|----------|-------|--------------|------------|-------|-------|
| 31 30 29    | 26 25 24 | 23    | 22 21        | 19 18      | 16 15 | 11 10 |

| 31 | 30 | 29 2      | 6 25 24 | 23 | 22 | 21 19        | <b>€ 18</b> 1 | 16 15 | 11 10 | 87   | 32 0 |
|----|----|-----------|---------|----|----|--------------|---------------|-------|-------|------|------|
| 1  | 0  | operation | Р       | d1 | d2 | <i>src</i> 1 | src2          | mod   | n ARn | modm | ARm  |
|    |    |           |         |    |    |              |               |       | src3  | s    | rc4  |

The parallel addressing mode (P) field specifies how the operands are to be used, i.e., whether they are source or destination. The specific relationship between the P field and the operands is detailed in the description of the individual parallel instructions (see Chapter 11). However, the operands are always encoded in the same way. Bits 31 and 30 are set to the value of 10, indicating parallel addressing mode instructions. Bits 25 and 24 specify the parallel addressing mode (P) field, which defines how bits 21 - 0 are to be interpreted for addressing the src operands. Bits 21 – 19 are used to define the *src1* address, bits 18 – 16 to define the *src2* address, bits 15 – 8 the src3 address, and bits 7 - 0 the src 4 address. The notations modn and modm indicate which modification field goes with which ARn or ARm (auxiliary register) field, respectively. The parallel addressing operands are listed below.

| src1 = Rn | $(0 \le n \le 7$ for extended-precision registers R0 – R7) |
|-----------|------------------------------------------------------------|
| src2 = Rn | $(0 \le n \le 7$ for extended-precision registers R0 – R7) |
| d1        | If 0, <i>dst1</i> is R0. If 1, <i>dst1</i> is R1.          |
| d2        | If 0, <i>dst2</i> is R2. If 1, <i>dst2</i> is R3.          |
| Ρ         | 0 ≤ P ≤ 3                                                  |
| src3      | indirect (disp = 0, 1, IR0, IR1)                           |
| src4      | indirect (disp = 0, 1, IR0, IR1)                           |

As in the three-operand addressing mode, indirect addressing in the parallel addressing mode allows for displacements of 0 or 1 and the use of the index registers (IR0 and IR1). The displacement of 1 is implied and is not explicitly coded in the instruction word.

In the encoding shown for this mode in Figure 5–6, if the src3 and src4 fields use the same auxiliary register, both addresses are correctly generated, but only the value created by the *src3* field is saved in the auxiliary register specified. The assembler issues a warning if you specify this condition is specified by the user.

### 5.2.4 Conditional-Branch Addressing Modes

Instructions using the conditional-branch addressing modes (B*cond*, B*cond*D, CALL*cond*, DB*cond*, and DB*cond*D) can perform a variety of conditional operations. Bits 31 - 27 are set to the value of 01101, indicating conditional-branch addressing mode instructions. Bit 26 is set to 0 or 1; the former selects DB*cond*, the latter B*cond*. Selection of bit 25 determines the conditional-branch addressing mode (B). If B = 0, register addressing is used; if B = 1, PC-relative addressing is used. Selection of bit 21 sets the type of branch: D = 0 for a standard branch or D = 1 for a delayed branch. The condition field(*cond*) specifies the condition checked to determine what action to take, i.e., whether or not to branch (see Table 11–8 on page 11-12 for a list of condition codes). Figure 6–6 shows the encoding for conditional-branch addressing.

Figure 5–7. Encoding for Conditional-Branch Addressing Modes

| D  | 3 <i>c</i> a | onc  | 1 (D | ): |         |         |    |           |           |    |              |    |           |   |   |   |   |    |     |    |      |     |     |        |            |                |   |
|----|--------------|------|------|----|---------|---------|----|-----------|-----------|----|--------------|----|-----------|---|---|---|---|----|-----|----|------|-----|-----|--------|------------|----------------|---|
| 31 |              |      |      |    | 26      | 25      | 24 | 22        | 2 21      | 20 |              | 16 | 15        |   |   |   |   |    |     |    |      |     |     | 5      | 4          |                | 0 |
| 0  | 1            | 1    | 0    | 1  | 1       | В       | A  | Rn        | D         |    | cond         |    | 0         | 0 | 0 | 0 | 0 | 0  | 0   | (  | ) (  | )   | 0   | 0      |            | <i>src</i> reg |   |
| 0  | 1            | 1    | 0    | 1  | 1       | в       | A  | Rn        | D         |    | cond         |    |           |   |   |   |   | in | nme | ed | liat | e ( | (PC | ) rel  | ative      | )              |   |
| Вс | on           | nd ( | D):  |    |         |         |    |           |           |    |              |    |           |   |   |   |   |    |     |    |      |     |     |        |            |                |   |
| 31 |              | - 1  |      |    | 26      | 25      | 24 | 2         | 2 21      | 20 |              | 16 | 15        |   |   |   |   |    |     |    |      |     |     | 5      | 4          |                | 0 |
|    | 1            | 1    | 0    | 1  | 26<br>0 | 25<br>B | _  | 2:<br>0 0 | 2 21<br>D | 20 | cond         | 16 | 15<br>0   |   | 0 | 0 | 0 | 0  | 0   | (  | ) (  | )   | 0   | 5<br>0 | 4          | <i>src</i> reg |   |
| 31 | 1            | 1    |      | 1  | -       |         | 0  |           | 1         | 20 | cond<br>cond | 16 | · · · · · |   | 0 | 0 |   |    |     | -  |      |     | -   | 0      | 4<br>ative |                | 0 |

| 31 |   |   |   |   | 20 | 25 | 24 |     | 22 6 | 1 20 | 10   |   | ) |   |   |   |    |    |     |     |     | <u> </u> | 4 0            |
|----|---|---|---|---|----|----|----|-----|------|------|------|---|---|---|---|---|----|----|-----|-----|-----|----------|----------------|
| 0  | 1 | 1 | 1 | 0 | 0  | В  | 0  | 0 ( | 0    | 5    | cond | 0 | 0 | 0 | 0 | 0 | 0  | 0  | 0   | 0   | 0   | 0        | <i>src</i> reg |
| 0  | 1 | 1 | 1 | 0 | 0  | В  | 0  | 0 ( | 0    | 0    | cond |   |   |   |   |   | im | me | dia | ate | (PC | rel      | ative)         |

### 5.3 Circular Addressing

Many algorithms, such as convolution and correlation, require the implementation of a circular buffer in memory. In convolution and correlation, the circular buffer is used to implement a sliding window that contains the most recent data to be processed. As new data is brought in, the new data overwrites the oldest data. The key to the implementation of a circular buffer is the implementation of a circular addressing mode. This section describes the circular addressing mode of the TMS320C40.

The block-size register (BK) specifies the size of the circular buffer. The bottom of the circular buffer is specified by the first 1 (one) bit (counting from the most significant bit to the least significant bit) in the lower 16 bits of the BK register, plus a user-selected auxiliary register (ARn). With the location of the first 1 bit specified as bit N, the address at the top of the buffer is referred to as the effective base (EB) and is equal to bits 31 through (N+1) of ARn with bits N through 0 of EB being zero.

Figure 5–8 illustrates the relationships among the block-size register (BK), the auxiliary registers (ARn), the bottom of the circular buffer, the top of the circular buffer, and the index into the circular buffer.





Addressing

In circular addressing, index refers to the N LSBs of the auxiliary register selected, and step is the quantity being added to or subtracted from the auxiliary register. Follow these two rules when you use circular addressing:

- The step used must be less than or equal to the block-size.
- The first time the circular queue is addressed, the auxiliary register must be pointing to an element in the circular queue.

The algorithm for circular addressing is as follows:

If  $0 \le index + step < BK$ : index = index + step.

Else if index + step  $\ge$  BK: index = index + step - BK.

Else if index + step < 0: index = index + step + BK.

Figure 5–9 shows how the circular buffer is implemented. It illustrates the relationship of the quantities generated and the elements in the circular buffer.





Figure 5–10 gives an example of the operation of circular addressing. Assuming that all ARs are four bits, let  $AR0 = 0000_2$ , and  $BK = 0110_2$  (block-size of 6). This example shows a sequence of modifications and the resulting value of AR0. It also shows how the pointer steps through the circular queue with a variety of step sizes (both incrementally and decrementally).

### Figure 5–10. Circular Addressing Example

| *AR0 ++ (5)%  | ; | AR0 = | 0 | (0th value) |
|---------------|---|-------|---|-------------|
| *AR0 ++ (2)%  | ; | AR0 = | 5 | (1st value) |
| *AR0 – – (3)% | ; | AR0 = | 1 | (2nd value) |
| *AR0++(6)%    | ; | AR0 = | 4 | (3rd value) |
| *AR0 – – %    | ; | AR0 = | 4 | (4th value) |
| *AR0          | ; | AR0 = | 3 | (5th value) |



Circular addressing is especially useful for the implementation of FIR filters. Figure 5–11 shows one possible data structure for FIR filters. Note that the initial value of AR0 points to h(N - 1), and the initial value of AR1 points to x(0). Circular addressing is used in the TMS320C40 code for the FIR filter shown in Figure 5–12.







Input Samples

| ×(N -1) |  |
|---------|--|
| x(N-2)  |  |
| •       |  |
| :       |  |
| x(2)    |  |
| ×(1)    |  |
| x(0)    |  |

← AR1

5

### Figure 5–12. FIR Filter Code Using Circular Addressing

```
*
  Initialization
*
           N, BK
                         ; Load block size.
    LDI
    LDI
           H,ARO
                         ; Load pointer to impulse response.
    LDI
           X,AR1
                         ; Load pointer to bottom of input
*
                         ; sample buffer.
*
TOP
           IN, R3
                         ; Read input sample.
    LDF
    STF
           R3,*AR1++%
                         ; Store with other samples.
                         ; and point to top of buffer.
                         ; Initialize R0.
    LDF
           0,R0
    LDF
           0,R2
                          ; Initialize R2.
*
*
    Filter
*
    RPTS
           N - 1
                          ; Repeat next instruction.
    MPYF3
           *AR0++%, *AR1++%, R0
    ADDF3
           R0,R2,R2
                         ; Multiply and accumulate.
11
    ADDF
           R0,R2
                         ; Last product accumulated.
*
    STF
           R2,Y
                          ; Save result.
    в
           TOP
                         ; Repeat.
```

5-29

### 5.4 Bit-Reversed Addressing

Bit-reversed addressing on the TMS320C40 enhances execution speed and program memory for FFT algorithms that use a variety of radices. One auxiliary register points to the physical location of a data value. IR0 specifies one-half the size of the FFT; e.g., the value contained in IR0 must be equal to  $2^{n-1}$  where n is an integer and the FFT size is  $2^n$ . When you add IR0 to the auxiliary register by using bit-reversed addressing, addresses are generated in a bit-reversed fashion. The largest index for bit reversed is 00FF FFFFh.

To illustrate this kind of addressing, assume 8-bit auxiliary registers. Let AR2 contain the value  $0110\ 0000_2\ (96_{10})$ . This is the base address of the data in memory. Let IR0 contain the value  $0000\ 1000_2\ (8)$ . Figure 5–13 shows a sequence of modifications of AR2 and the resulting values of AR2.

*Figure 5–13. Bit-Reversed Addressing Example* 

| *AR2++(IR0)B | ; | AR2 | = | 0110 | 0000 | (Oth value) |  |
|--------------|---|-----|---|------|------|-------------|--|
| *AR2++(IR0)B | ; | AR2 | = | 0110 | 1000 | (1st value) |  |
| *AR2++(IR0)B | ; | AR2 | = | 0110 | 0100 | (2nd value) |  |
| *AR2++(IR0)B | ; | AR2 | = | 0110 | 1100 | (3rd value) |  |
| *AR2++(IR0)B | ; | AR2 | = | 0110 | 0010 | (4th value) |  |
| *AR2++(IR0)B | ; | AR2 | = | 0110 | 1010 | (5th value) |  |
| *AR2++(IR0)B | ; | AR2 | = | 0110 | 0110 | (6th value) |  |
| *AR2         | ; | AR2 | = | 0110 | 1110 | (7th value) |  |

Table 5–4 shows the relationship of the index steps and the four LSBs of AR2. As you can see, you can find the four LSBs by reversing the bit pattern of the steps.

| •      |             | 0                       |                      |
|--------|-------------|-------------------------|----------------------|
| Step   | Bit Pattern | Bit-Reversed<br>Pattern | Bit-Reversed<br>Step |
| 0      | 0000        | 0000                    | 0                    |
| 1      | 0001        | 1000                    | 8                    |
| 2<br>3 | 0010        | 0100                    | 4                    |
| 3      | 0011        | 1100                    | 12                   |
| 4      | 0100        | 0010                    | 2                    |
| 5      | 0101        | 1010                    | 10                   |
| 6      | 0110        | 0110                    | 6                    |
| 7      | 0111        | 1110                    | 14                   |
| 8      | 1000        | 0001                    | 1                    |
| 9      | 1001        | 1001                    | 9                    |
| 10     | 1010        | 0101                    | 5                    |
| 11     | 1011        | 1101                    | 13                   |
| 12     | 1100        | 0011                    | 3                    |
| 13     | 1101        | 1011                    | 11                   |
| 14     | 1110        | 0111                    | 7                    |
| 15     | 1111        | 1111                    | 15                   |

#### Table 5–4. Index Steps and Bit-Reversed Addressing

Addressing

### 5.5 System and User Stack Management

The TMS320C40 provides a dedicated system stack pointer (SP) for building stacks in memory. The auxiliary registers can also be used to build a variety of more general linear lists. This section discusses the implementation of the following types of linear lists:

- Stack A linear list for which all insertions and deletions are made at one end of the list.
- **Queue** A linear list for which all insertions are made at one end of the list, and all deletions are made at the other end.
- **Dequeue** A double-ended queue linear list for which insertions and deletions are made at either end of the list.

The system stack pointer (SP) is a 32-bit register that contains the address of the top of the system stack. The system stack fills from low-memory address to high-memory address (see Figure 5–14). The SP always points to the last element pushed onto the stack. A push performs a preincrement, and a pop performs a postdecrement of the system stack pointer.

The program counter is pushed onto the system stack on subroutine calls, traps, and interrupts. It is popped from the system stack on returns. The system stack can be pushed and popped with the PUSH, POP, PUSHF, and POPF instructions.



Figure 5–14. System Stack Configuration

High Memory

.

### 5.5.1 Stacks

Stacks can be built from low to high memory or high to low memory. Two cases for each type of stack are shown. You can build stacks by using the preincrement/decrement and postincrement/decrement modes of modifying the auxiliary registers (AR). You can implement stack growth from high to low memory in two ways:

**Case 1**: Store to memory using \*- - ARn to push data onto the stack and reads from memory using \*ARn ++ to pop data off the stack.

**Case 2**: Store to memory using \*ARn - - to push data onto the stack and read from memory using \* + + ARn to pop data off the stack.

Figure 5–15 illustrates these two cases. The only difference is that in case 1, the AR always points to the top of the stack, and in case 2, the AR always points to the next free location on the stack.

#### Figure 5–15. Implementations of High-to-Low Memory Stacks



You can implement stack growth from low to high memory in two ways:

**Case 3**: Store to memory using \*++ ARn to push data onto the stack and reads from memory using \*ARn - - to pop data off the stack.

**Case 4**: Stores to memory using \*ARn ++ to push data onto the stack and reads from memory using \*-- ARn to pop data off the stack.

Figure 5–16 shows these two cases. In the case 3, the AR always points to the top of the stack. In case 4, the AR always points to the next free location on the stack.





### 5.5.2 Queues and Dequeues

The implementations of queues and dequeues is based upon the manipulation of the auxiliary registers for user stacks. For queues, two auxiliary registers are used: one to mark the front of the queue from which data is popped and the other to mark the rear of the queue where data is pushed.

For dequeues, two auxiliary registers are also necessary. One is used to mark one end of the dequeue, and the other is used to mark the other end. Data can be popped or pushed from either end.



## **Chapter 6**

# **Program Flow Control**

The TMS320C40 provides a complete set of constructs that facilitate software and hardware control of the program flow. Software control includes repeats, branches, calls, traps, and returns. Hardware control includes reset and interrupts. Because programming includes a variety of constructs, you can select the one suited for your particular application.

Several interlocked operations instructions provide flexible multiprocessor support and, through the use of external signals, a powerful means of synchronization. They also guarantee the integrity of the communication and result in a high-speed operation.

The TMS320C40 supports a nonmaskable external reset signal and a number of internal and external interrupts. These functions can be programmed for a particular application.

This chapter discusses the following major topics:

### Section

| 6.1 | Repeat Modes 6-2                           |
|-----|--------------------------------------------|
|     | ■ Initialization                           |
|     | Operation                                  |
| 6.2 | Delayed Branches 6-7                       |
| 6.3 | Calls, Traps, Branches, Jumps, and Returns |
| 6.4 | Unifying Traps and Interrupts              |
| 6.5 | Interlocked Operations 6-13                |
| 6.6 | Reset Operation                            |
| 6.7 | Interrupts                                 |
|     | Interrupt Control Bits                     |
|     | Prioritization and Control                 |

Page

### 6.1 Repeat Modes

The repeat modes of the TMS320C40 can implement zero-overhead looping. For many algorithms, most execution time is spent in an inner kernel of code. Using the repeat modes allows these time-critical sections of code to be executed in the shortest possible time.

The TMS320C40 provides three instructions to support zero-overhead looping: RPTB, RPTBD (repeat a block of code/delayed) and RPTS (repeat a single instruction):

- RPTB and RBTBD causes a block of code to be repeated a specified number of times, and
- RPTS causes a single instruction to be repeated a number of times and reduces the bus traffic by fetching the instruction only once.

Three registers (RS, RE, and RC) are associated with the updating of the program counter when it is updated in a repeat mode, as described in Table 6–1 below.

| Iable 6–1. Repeat-Mode Register | Table 6–1. | Repeat-Mode Registers |
|---------------------------------|------------|-----------------------|
|---------------------------------|------------|-----------------------|

| Register | Function                                                                                                       |
|----------|----------------------------------------------------------------------------------------------------------------|
| RS       | Repeat start address register. Holds the address of the first instruction of the block of code to be repeated. |
| RE       | Repeat end address register. Holds the address of the last instruction of the block of code to be repeated.    |
| RC       | Repeat-count register. Contains one less than the number of times the block remains to be repeated.            |

### 6.1.1 Repeat-Mode Initialization

Two bits are important to the operation of RPTB, RPTBD and RPTS: the RM and S bits.

- □ The **RM** (repeat-mode flag) bit in the status register specifies whether the processor is running in the repeat mode.
  - If RM = 0, fetches are not made in repeat mode.
  - If RM = 1, fetches are made in repeat mode.
- The S bit is internal to the processor and cannot be programmed, but this bit is necessary to fully describe the operation of RPTB and RPTS.
  - If RM = 1 and S = 0, RPTB or RPTBD is executing. Program fetches are from memory.
  - If RM = 1 and S = 1, RPTS is executing. After the first fetch (from memory), program fetches are from the instruction register (IR).

6-2

The correct operation of the repeat modes requires that all of the above registers and status register fields be initialized correctly. The RPTB, RPTBD, and RPTS instructions perform this initialization in slightly different ways (see subsections 6.1.2 and 6.1.3).

### 6.1.2 RPTB and RPTBD Initialization

The execution sequence of RPTB *src* or RPTBD *src* is nearly the same:

- 1) Loads the start address of the block into RS (repeat start address register).
  - a) For **RPTB**, this is the next address following the instruction: PC of RPTB + 1  $\rightarrow$  RS

or

- b) For **RPTBD**, this is the fourth address following the instruction: PC of RPTBD  $+ 4 \rightarrow RS$
- Loads the end address of the block into RE (repeat end address register).
  - a) In *PC-relative mode*, the 24-bit *src* operand plus RS is the end address:

For RPTB,

 $src + PC \text{ of } RPTB + 1 \rightarrow RE$ 

or

For RPTBD,

 $src + PC \text{ of } RPTBD + 3 \rightarrow RE$ 

- b) In *register mode*, the contents of the *src* register is the end address: contents of *src* register  $\rightarrow RE$
- 3) Sets the status register to indicate the repeat mode of operation.
  - $1 \rightarrow RM$  status register bit (repeat mode flag)
- 4) Indicates that this is the repeat block mode of operation.

 $0 \rightarrow S$  bit (bit is internal to processor; not programmable)

The last bit of information required is the number of times to repeat the block. The value is determined by properly initializing the RC (repeat count) register. Because the execution of RPTB and RPTBD does not load the RC, you must load this register yourself. A typical setup of the block repeat operation is shown below.

|     |    | Ι    |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
|-----|----|------|---|--|------|---|-----|---|-----|--|-----|----|----|-------|----------|----------|---|---|----|-------|----|----------|----|----|---|----|---|------------|----|---|-----|---|----|-----|---|---|----|---|---|---|----------|-----|----------|---|-----|----------|-------|------------|--|
|     |    |      |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
|     |    |      |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
|     |    |      |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
|     |    |      |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
|     |    |      |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
|     |    |      |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
|     |    |      |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
|     |    |      |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
|     |    |      |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
|     |    | 100  |   |  |      |   |     |   |     |  |     |    |    |       |          |          |   |   |    |       |    |          |    |    |   |    |   |            |    |   |     |   |    |     |   |   |    |   |   |   |          |     |          |   |     |          |       |            |  |
| -   | -  | ~~~~ |   |  | - 10 |   | ÷., | - |     |  |     |    |    | : 14a |          | <u> </u> | ~ | - |    | 1.6.5 | ÷. | ۰.<br>سو |    | -  |   | -  | - | 4.1.2      |    |   |     |   |    | 1.4 | - | ~ |    |   |   |   |          | -   |          |   | ÷ 2 | <u></u>  |       | ~ `        |  |
| Th. | n, | ΠT   | 5 |  | Ť    | 2 | 5   | ń | - 3 |  | 0.0 | 20 |    | ंग    | ٠,       | J.       | 2 | D |    |       | x  | ٦r       | эπ |    |   | 'n | r | ÷.,-       | 11 | 1 | 177 |   | 18 | 1   |   | c |    | 1 |   |   | 1        | D I | <b>۸</b> |   | 1   | ٦Ü       | 5.1   | <b>~</b> ` |  |
| P   | D  | ΤŤ   | 2 |  | T.   | n | n   | D | - 3 |  | •   | 29 | 19 | ी     | 1.0      | ni       | 2 | D | ί. |       | 2  | T        | 21 | 7  |   | D  | C | 0          | +  | 1 | Ľ   | _ | 1  | 1   |   | C |    | 1 | 1 |   | 7.       | RI  | M        |   | 1   | ٦        | <br>5 | c i        |  |
| R   | P  | ΤĪ   | 3 |  | Τ.   | 0 | O)  | P | 2   |  | •   | ¥1 |    | ា     | .(       | C        | 0 | Ρ | ί. |       | >  | I        | RF | Ζ. |   | P  | C | ١.,        | +  | 1 |     | - | -> | 1   | R | S | ÷  | 1 |   | _ | •        | RI  | M        |   | .(  | )        | <br>• | S          |  |
| R   | P  | ΤI   | 3 |  | L    | 0 | 0   | Ρ | 2   |  | ;   | 21 |    | ្ប    | <u> </u> | C        | 0 | Ρ |    |       | >  | I        | R  | Ξ, | , | P  | C | <u>е</u> , | +  | ] | Ľ   | - | -> |     | R | S | ï  | 1 |   | _ | •        | RI  | Μ        | , | .(  | <u>כ</u> | <br>• | S          |  |
| R   | P  | ΤI   | 3 |  | L    | 0 | 0   | P | 2   |  | ;   |    |    | 1     | ),       | C        | 0 | P |    |       | >  | I        | R  | Ξ, | , | P  | C | <u>а</u> . | t  | ] | Ľ   | - | )  |     | R | S | i. | 1 |   | _ | ÷        | RJ  | Μ        | , | (   | )        | <br>• | S          |  |
| R   | P  | ΤI   | 3 |  | L    | 0 | 0   | P |     |  | ;   | 1  | 2  | 1     | <u>,</u> | C        | 0 | P | ŀ  |       | >  | I        | R  | Ξ, |   | P  | C | <u>а</u> , | t  | ] | Ľ   | - | )  |     | R | S | ,  | 1 |   | _ | <b>}</b> | RJ  | Μ        | , | (   | )        | <br>• | S          |  |

The repeat modes repeat a block of code at least once in a typical operation. The repeat counter should be loaded with one less than the number of times to execute the block; i.e., an RC value of 0 executes the block of code one time, or an RC value of 4 would execute the block five times. All block repeats initiated by RPTB or RPTBD can be interrupted.

#### 6.1.3 **RPTS** Initialization

When RPTS *src* is executed, the following sequence of operations occurs:

- 1)  $PC + 1 \rightarrow RS$
- 2)  $PC + 1 \rightarrow RE$
- 3)  $1 \rightarrow RM$  status register bit
- 4)  $1 \rightarrow S$  bit
- 5)  $src \rightarrow RC$  (repeat count register)

The RPTS instuction loads all registers and mode bits necessary for the operation of the single instruction repeat mode. Step 1 loads the start address of the block into RS. Step 2 loads the end address into the RE (end address of the block). Since this is a repeat of a single instruction, the start address and the end address are the same. Step 3 sets the status register to indicate the repeat mode of operation. Step 4 indicates that this is the repeat singleinstruction mode of operation. Step 5 loads *src* into RC.

Repeats of a single instruction initiated by RPTS are not interruptible, because the RPTS fetches the instruction word only once and then keeps it in the instruction register for reuse. An interrupt would cause the instruction word to be lost. The refetching of the instruction word from the instruction register reduces memory accesses and, in effect, acts as a one-word program cache. If it is necessary to have a single instruction that is repeatable and interruptible, you can use the RPTB instruction.

#### 6.1.4 Repeat-Mode Operation

Information in the repeat-mode registers and associated control bits is used to control the modification of the PC when the fetches are being made in repeat mode. The repeat modes compare the contents of the RE register (repeat end address register) with the program counter (PC). If they match and the repeat counter is nonnegative, the repeat counter is decremented, the PC is loaded with the repeat start address, and the processing continues. The fetches and appropriate status bits are modified as necessary. Note that the repeat counter (RC) is never modified when the repeat-mode flag (RM) is 0. The maximum number of repeats occurs when  $RC = 0.8000\,0001h$ . This will result in 0.8000 0001h repetitions. The detailed algorithm for the update of the PC is shown in Figure 6–1.

The RPTB and RPTS are four-cycle instructions. These four cycles of overhead are incurred only on the first pass through the loop. All subsequent passes through the loop are accomplished with zero cycles of overhead. In Example 6–1, the block of code from STLOOP to ENDLOP is repeated sixteen times.

Example 6–1. RPTB Operation

| LI     | ) 15,RC ;    | Load repeat cour | nter with 15    |
|--------|--------------|------------------|-----------------|
| RI     | PTB ENDLOP ; | Execute the bloc |                 |
| STLOOP | ;            | from STLOOP to   | ENDLOP 16 times |
| •      |              |                  |                 |
| •      |              |                  |                 |
|        |              |                  |                 |
| ENDLOP |              |                  |                 |

Figure 6–1. Repeat-Mode Control Algorithm

| if RM == 1<br>if S == 1       | ; If in repeat mode (RPTB or RPTS)<br>; If RPTS |
|-------------------------------|-------------------------------------------------|
| if first time through         | ; If this is the first fetch                    |
| fetch instruction from memory | ; Fetch instruction from memory                 |
| else                          | : If not the first fetch                        |
| fetch instruction from IR     | ; Fetch instruction from IR                     |
| $RC - 1 \rightarrow RC$       | ; Decrement RC                                  |
| if RC < 0                     | ; If RC is negative                             |
|                               | ; Repeat single mode completed                  |
| $0 \rightarrow ST(RM)$        | ; Turn off repeat mode bit                      |
| $0 \rightarrow s$             | ; Clear S                                       |
| $PC + 1 \rightarrow PC$       | ; Increment PC                                  |
| else if S == 0                | ; If RPTB                                       |
| fetch instruction from memory | ; Fetch instruction from memory                 |
| if PC == RE                   | ; If this is the end of the block               |
| $RC - 1 \rightarrow RC$       | ; Decrement RC                                  |
| if RC $\geq$ 0                | ; If RC is not negative                         |
| $RS \rightarrow PC$           | ; Set PC to start of block                      |
| else if RC < 0                | ; If RC is negative                             |
| $0 \rightarrow ST (RM)$       | ; Turn off repeat mode bits                     |
| $0 \rightarrow s$             | ; Clear S                                       |
| $PC + 1 \rightarrow PC$       | ; Increment PC                                  |

Using the repeat block mode of modifying the PC facilitates analysis of what would happen in the case of branches within the block. Assume that the next value of the PC will be either PC + 1 or the contents of the RS register. It is thus apparent that this method of block repeat allows branching within the repeated block. Execution can go anywhere within the user's code via interrupts, subroutine calls, etc. For proper modification of the loop counter, the last instruction of the loop must be fetched. By writing a 0 into the repeat counter or writing 0 into the RM bit of the status register, you can stop the repeating of the loop prior to completion.

Since the block repeat modes modify the program counter, other instructions cannot modify the program counter at the same time. **Two rules** apply:

**Rule 1:** The last instruction in the block (or the only instruction in a block of size one) cannot be a B*cond*, DB*cond*, CALL, CALL*cond*, TRAP*cond*, RETI*cond*, RETS*cond*, IDLE, RPTB, or RPTS. Example 6–2 shows an incorrectly placed standard branch.

**Rule 2:** None of the last four instructions from the bottom of the block (or the only instruction in a block of size one) can be a B*cond* D, BRD, or DB*cond*D, RPTBD, LAJ, LAJ*cond*, LAT*cond*, B*cond*AF, B*cond*AT, or RETI*cond*. Example 6–3 shows an incorrectly placed delayed branch.

#### If either of these rules is violated, the PC will be undefined.



| LD 15.RC       | ; Load repeat counter with 15                                                                                   |
|----------------|-----------------------------------------------------------------------------------------------------------------|
|                | , Hoad Tepeat Counter with 15                                                                                   |
| RPTB ENDLOP    | ; Execute block of code                                                                                         |
| REIB ENDLOF    | , Elecule Diock of Code                                                                                         |
| COL OOD        | from CHIOOD to ENDLOD 16 times                                                                                  |
| _ STLOOP       | ; from STLOOP to ENDLOP 16 times                                                                                |
|                | an ann an an ann an Arthur Maraile an ann an ann an an an an an an an an a                                      |
| •              |                                                                                                                 |
|                | 이번 이 것은 이 가지 않는 것은 것을 수 없는 것이라. 여러는 것이 가지 않는 것이 있는 것이 있는 것이 같이 많은 것을 수 없다.                                      |
|                | - 2011년 - 2011년 1985년 1985년 1987년 1971년 - 2012년 1971년 197 |
|                |                                                                                                                 |
|                | 방법이 그 사람이 가지 아파 방법에 대중하지 않는 것이 가지는 것이 가지만 있는 것이 방법에 많은 것이라. 방법했다.                                               |
| •              |                                                                                                                 |
| ENDLOP BR OOPS | ; This branch violates rule 1                                                                                   |
|                | , into pranen viotaceo faie i                                                                                   |



|        | LD   | 15,RC  | ; | Load  | repeat | coun  | ter w | ith : | 15        |    |
|--------|------|--------|---|-------|--------|-------|-------|-------|-----------|----|
|        | RPTB | ENDLOP | ; | Execu | te blo | ck of | code  |       | d v delad |    |
| STLOOP |      |        | ; | from  | STLOOP | to E  | NDLOP | 16    | times     |    |
|        | •    |        |   |       |        |       |       |       |           | 26 |
|        | •    |        |   |       |        |       |       |       |           |    |
|        | •    |        |   |       |        |       |       |       |           |    |
|        | BRD  | OOPS   | ; | This  | branch | viol  | ates  | rule  | 2         |    |
|        | ADDF |        |   |       |        |       |       |       |           |    |
|        | MPYF |        |   |       |        |       |       |       |           |    |
| ENDLOP | SUBF |        |   |       |        |       |       |       |           |    |

Block repeats (RPTB and RPTBD) are nestable. Since all of the control is defined by the RS, RE, RC, and ST registers, these registers must be saved and stored in order to nest block repeats. The status register RM bit can be used to determine whether the block repeat mode is active. For example, if you write an interrupt service routine that requires the use of RPTB or RPTBD, it is possible that the interrupt associated with the routine may occur during another block repeat. The interrupt service routine can check the RM bit. If this bit is set, the interrupt routine saves RS, RE, RC, and ST. The interrupt routine can then perform a block repeat. Before returning to the interrupted routine, the interrupt routine restores RS, RE, RC, and ST. If the RM bit is not set, you don't need to save and restore these registers.

Program Flow Control

### 6.2 Delayed Branches

The TMS320C40 offers two main types of branching: standard and delayed. **Standard branches** empty the pipeline before performing the branch; this guarantees correct management of the program counter and results in a TMS320C40 branch taking four cycles. Included in this class are repeats, calls, returns, and traps.

**Delayed branches** without annulling do not empty the pipeline but, rather, guarantee that the next three instructions will execute before the program counter is modified by the branch. Delayed branches with annulling may conditionally annul the next three instructions. The result is a branch that requires only a single cycle, thus making the speed of the delayed branch very close to the optimal block repeat modes of the TMS320C40. However, unlike block repeat modes, delayed branches may be used in situations other than looping. Every delayed branch has a standard branch counterpart that is used when a delayed branch cannot be used. The delayed branches without annulling are BcondD, BRD, and DBcondD. Those with annulling are BcondAF.

Conditional delayed branches use the conditions, reflected in the status register, that existed at the end of the instruction preceding the branch. They do not depend upon the instructions following the delayed branch. Delayed branches without annulling guarantee that the next three instructions will execute, regardless of other pipeline conflicts.

When a delayed branch is fetched, it remains pending until the three instructions that follow are executed. None of the three instructions immediately after a delayed branch can be any of the following (see Example 6–4):

| Bcond             | BRD              | IDLE             | RETI <i>cond</i> D |
|-------------------|------------------|------------------|--------------------|
| B <i>cond</i> D   | DBcond           | LAJ              | RETScond           |
| B <i>cond</i> AF† | DB <i>cond</i> D | LAJ <i>cond</i>  | RPTB               |
| B <i>cond</i> AT† | CALL             | LAT <i>cond</i>  | RPTBD              |
| BR                | CALLcond         | RETI <i>cond</i> | RPTS               |
|                   |                  |                  | TRA <i>Pcond</i>   |

<sup>†</sup> BcondAF and BcondAT are described in Section 6.3 on page 6-9.

#### Incorrectly used delayed branches can leave the PC undefined.

Delayed branches disable interrupts until the three instructions following the delayed branch are completed. This is independent of whether or not the branch is taken.



| BD<br>NOP                              | Ll                                    |                                  |        |                                             |                           |                                                                                                                                                                                                                                   |                           |
|----------------------------------------|---------------------------------------|----------------------------------|--------|---------------------------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| NOP<br>B                               | L2                                    |                                  | Thie b | vranch                                      | ie inco                   | rrectly                                                                                                                                                                                                                           | nlaced                    |
| <br>NOP                                | 712                                   | <u>e i e 600 e e fer 2 i i i</u> |        |                                             |                           | TIECCLY                                                                                                                                                                                                                           |                           |
| NOP<br>NOP                             |                                       |                                  |        |                                             |                           |                                                                                                                                                                                                                                   |                           |
| •                                      |                                       |                                  |        |                                             |                           |                                                                                                                                                                                                                                   |                           |
| •                                      |                                       |                                  |        |                                             |                           |                                                                                                                                                                                                                                   |                           |
| 20000000000000000000000000000000000000 | Sel el competencia de la competencia. |                                  |        | 1919-90-1919-1919<br>1919-90-1919-1919-1919 | anna fa she a she she she | an an tha an<br>Tha an tha an | n ja tu punyan subar sati |

- □ The BcondAT and BcondAF instructs both branch if conditions are true, but
  - BcondAT executes but annuls (cancels effect of except for time delay) the execute phase of the next three instructions following BcondAT. Then it takes the branch. If cond is false, execution continues immediately after the BcondAT.
  - BcondAF first executes the next three instructions following the BcondAF.Then it takes the branch. If cond is false, execution continues immediately after the BcondAF but the execution phase of the first three instructions are annulled.

Program Flow Control

## 6.3 Calls, Traps, Branches, Jumps and Returns

Calls and traps provide a means of executing a subroutine or function while providing a return to the calling routine.

The CALL, CALL*cond*, and TRAP*cond* instructions store the value of the PC on the stack before changing the PC's contents. The RETS*cond* or RE-TI*cond* (standard or delayed) instructions return execution from traps and calls using the value on the stack.

- CALL places the next PC value on the stack and places the *src* (source) operand into the PC. The *src* is a 24-bit PC-relative or register value. Figure 6–2 shows CALL response timing.
- CALLcond is similar to the CALL instruction (above) except that (1) it executes only if a specific condition is true (the 20 conditions including unconditional are listed in Section 11.2 on page 11-10) and (2) the *src* is either a PC-relative displacement or in register addressing mode.
- TRAPcond also executes only if a specific condition is true (same conditions as for the CALLcond instruction). When it executes, (1) interrupts are disabled with 0 written to bit GIE of the ST, (2) the next PC value is stored on the stack, and (3) a vector is retrieved from one of the addresses from 20h to 3Fh and loaded into the PC. The particular address corresponds to a trap number in the instruction. Using RETIcond or RETIcondD to return re-enables interrupts if the status register's GIE bit was set previously.
- RETScond returns execution from any of the above three instructions by popping the top of the stack to the PC. For RETScond to execute, the specified condition must be true. Conditions are the same as for the CALLcond instruction.
- RETIcond returns from traps or calls in the same way as the RETScond (above) does with the addition that RETIcond also copies the PGIE and PCF bit values into the GIE and CF bits of the status register. Conditions are the same as for the CALLcond instruction.
- RETIcondD returns from traps or calls the same way as the RETIcond (above) does with the addition that RETIcondD also first executes the next three instructions immediately following the RETIcondD. Conditions are the same as for the CALLcond instruction.
- Link and jump (LAJ), link and jump conditional (LAJcond), and link and trap conditional (LATcond) each provide a return address in extendedprecision register R11.
  - After it executes the three instructions that follow it, LAJ jumps to an address derived by the concatenation of the most significant 8 bits of the PC and the 24-bit *src* address in the instruction.

- LAJcond destination address is either PC-relative (a displacement) or the contents of a specified register. If the condition is true, LAJcond first executes the three instructions following the LAJcond before making the jump. If the condition is not true, execution continues immediately after the LAJcond instruction.
- After it executes the three instructions that follow it, LAT cond calls one of the 512 available trap vectors pointed to by the trap vector table pointer (TVTP) in Section 3.2 on page 3-15. The vector value is loaded into the PC.

*Functionally, calls and traps accomplish the same task:* namely, a subfunction is called and executed, and control is then returned to the calling function. *Traps offer several advantages:* 

- Interrupts are automatically disabled when a trap is executed. This allows critical code to execute without risk of being interrupted. Thus, traps are usually terminated with a RETIcond or RETIcond D instruction to re-enable interrupts if the status register GIE bit was set previously.
- 2) You can use traps to indirectly call functions. This is particularly beneficial when a kernel of code contains the basic subfunctions to be used by applications. In this case, the functions in the kernel can be modified and relocated without recompiling each application.



Figure 6–2. CALL Response Timing

#### Program Flow Control

## 6.4 Unifying Traps and Interrupts

Traps and interrupts on the TMS320C4x are unified in all forms of operation *except initialization*.

## 6.4.1 Initialization

At initialization:

- □ **Traps** are always triggered by a software mechanism, either with TRAP*cond* (conditional trap) or LAT*cond* (link and trap conditionally delayed).
- □ **Interrupts** are triggered by hardware events (i.e., external interrupts, DMA interrupts, or communication channel interrupts).

## 6.4.2 Operation

Figure 6–3 shows the unified flow of traps and interrupts.

For an **interrupt**, step (1) in the figure happens after completion of the last instruction that was fetched before completion of the interrupt flush. This guarantees later restoration of correct flag values.





**LAT***cond* (link and trap conditionally) is a delayed instruction that provides a single-cycle trap that is very useful for error detection and correction. Since LAT*cond* is a delayed instruction, the three instructions following LAT*cond* should not modify the GIE or CF status register bits (this could result in storing incorrect values of these two bits).

The **RETI**cond and **RETI**condD instructions manipulate the status flags as shown in step (3) in the figure. RETIcondD provides a delayed return from a trap or interrupt. Since traps and interrupts are unified, the RETIcond provides a return from either.

In general, you should not directly modify the PGIE or PCF status register bits except when putting the status register on a stack for recursive interrupts or traps.

## 6.5 Interlocked Operations

One of the most common parallel processing configurations is the sharing of global memory by multiple processors. In order for multiple processors to access this global memory and share data in a coherent manner, some sort of arbitration or handshake is necessary. The TMS320C40 interlocked operations meet this requirement for arbitration. More details are given in Section 7.7 on page 7-39. Examples in this section show you how interlocked operations can be used to implement:

- A busy-waiting loop used to synchronize processors at the software level (Example 6–5, page 6-15),
- A counter shared between cooperative processors defining the number of times a task should be done by the processors (Example 6–6 on page 6-15),
- Semaphores used to ease the programming of critical sections (Example 6–7 and Example 6–8 on page 6-16).

The TMS320C40 has five instructions referred to as interlocked operations. Through the use of external signals, these instructions provide powerful synchronization mechanisms. They also guarantee the integrity of the communication and result in a high-speed operation. The interlocked-operation instruction group is listed in Table 6–2.

| Instruction | Description                                                                                             | Operation                                |
|-------------|---------------------------------------------------------------------------------------------------------|------------------------------------------|
| LDFI        | Load floating-point value from memory into a register, interlocked when <i>external</i> memory accessed | Signal interlocked src $\rightarrow$ dst |
| LDII        | Load integer from memory into a register, interlocked when <i>external</i> memory accessed              | Signal interlocked src $\rightarrow$ dst |
| SIGI        | Load floating-point value from memory into a register, interlocked when <i>external</i> memory accessed | Signal interlocked<br>Clear interlock    |
| STFI        | Store floating-point value from a register to memory, interlocked when <i>external</i> memory accessed  | src $\rightarrow$ dst<br>Clear interlock |
| STII        | Store integer from a register to memory, interlocked when <i>external</i> memory accessed               | src → dst<br>Clear interlock             |

Table 6–2. Interlocked Operations

The interlocked operations use the global- and local-bus signals, LOCK and LLOCK, to reflect a currently executing interlocked operation. This signal is active (low) when any of the interlocked instructions in Table 6–2 are executing.

The external timing for the interlocked loads and stores is the same as for standard load and stores. You can extend the interlocked loads and stores like standard accesses by using the appropriate ready signal ( $\overline{RDY}x$  or  $\overline{LRDY}x$ ).

The LDFI and LDII instructions perform the following actions:

- 1) Pull (L)LOCK low.
- 2) Execute an LDF or LDI instruction.
- 3) Extend the read cycle until the appropriate ready signal is received. Complete the instruction.
- 4) Leave (L)LOCK active low until changed by an STFI, STII, or SIGI.

The read/write operation is identical to any other read/write cycle except for the special use of  $\overline{(L)LOCK}$ . The *src* operand for LDFI and LDII is always a direct or indirect memory address.  $\overline{(L)LOCK}$  is set to 0 only if the *src* is located off-chip (i.e., STRB or LSTRB, is active). If on-chip memory is accessed, then  $\overline{(L)LOCK}$  is not asserted, and the operation is as an LDF or LDI from internal memory.

The **STFI** and **STII** instructions perform the following operations:

- Begin a write cycle. The state of (L)LOCK does not change. If it is low, an interlocked operation occurs. If high, the operation is as if an STF or STI is performed (not interlocked).
- 2) Execute an STF or STI instruction and extend the write cycle until the appropriate ready is signaled.
- 3) After the write cycle, bring (L)LOCK inactive (high).

As in the case for LDFI and LDII, the *dst* of STFI and STII affects (L)LOCK. If *dst* is located off-chip (STRB(0,1) or LSTRB(0,1) is active), (L)LOCK is set to a 1. If on-chip memory is accessed, then (L)LOCK is not asserted, and the operations are as a STF or STI to internal memory.

The **SIGI** instruction functions as follows:

- 1) Pulls (L)LOCK low.
- 2) Executes an LDI instruction.
- Extends the read cycle until the appropriate ready signal is received. Completes the instruction.
- 4) Brings (L)LOCK back inactive high.

Interlocked operations can be used to implement a busy-waiting loop, to manipulate a multiprocessor counter, to implement a simple semaphore mechanism, or to perform synchronization between two TMS320C40s. The following examples illustrate the usefulness of the interlocked operations instructions.

6-14

Example 6–5 shows the implementation of a busy-waiting loop. If location LOCK is the interlock for a critical section of code, and a nonzero means the lock is busy, the algorithm for a busy-waiting loop can be used as shown.

Example 6–5. Busy-Waiting Loop

| LDI 1.RO            |                                 |
|---------------------|---------------------------------|
|                     | Put 1 in R0                     |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
| L1: LDII @LOCK.R1 : | Load lock value into R1         |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
| STII RO,@LOCK ;     | Set lock value to 1             |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     | If lock is not 0, read it again |
| BNZ L1              |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |
|                     |                                 |

Example 6–6 shows how a location COUNT may contain a count of the number of times a particular operation needs to be performed. This operation may be performed by any processor in the system. If the count is zero, the processor waits until it is nonzero before beginning processing. The example also shows the algorithm for modifying COUNT correctly.

#### Example 6–6. Task Counter Manipulation

| LDI 0.RO                                            | SASSES -    |
|-----------------------------------------------------|-------------|
|                                                     | 988 B 888 - |
|                                                     | 200000000   |
|                                                     | 233333333   |
| WAIT LDII @COUNT,R1 ; Read current value of counter | 303333333   |
| , neua carrent varac or councer                     |             |
|                                                     | 8833333     |
|                                                     |             |
| BZD WAIT ; If COUNT = 0, try again                  |             |
| BDD MILL , IL COOMI O, CLY UGULA                    | 200200338   |
|                                                     | 200000338   |
|                                                     |             |
| LDNZ 1,R0 ; If COUNT not zero, decrement it         |             |
|                                                     |             |
|                                                     | 8000000     |
|                                                     | S2229393    |
| SUBI RO.R1                                          | 0.00000000  |
|                                                     | 2010-000    |
|                                                     |             |
| STII R1,@COUNT ; Update COUNT                       |             |
| SIII RI, @COUNI ; UDdate COUNI                      |             |
| a na            | 39922402    |
|                                                     | 20000000    |
|                                                     |             |

Figure 6–4 illustrates multiple TMS320C40s sharing global memory and using the interlocked instructions as in Example 6–7 and Example 6–8.





Example 6–7. Implementation of V(S)

| V: LDII @S,R1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| ADDI 1,R0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| • Second second second and the second s<br>second second s<br>Second second s<br>Second second seco |  |
| OF TT DO DO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| STII RO,@S ; S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |

Example 6–8. Implementation of P(S)

| LDI 0.RO                                       |          |
|------------------------------------------------|----------|
|                                                |          |
|                                                |          |
|                                                |          |
|                                                |          |
|                                                |          |
| P: LDII @S,R1 ; Read semaphore's current value |          |
|                                                |          |
|                                                |          |
| BZD P ; If S = 0, go to P and try again        |          |
|                                                |          |
|                                                |          |
|                                                |          |
|                                                |          |
| LDNZ 1,R0 ; If S is not 0, decrement it        |          |
|                                                |          |
|                                                |          |
|                                                |          |
|                                                |          |
|                                                |          |
| 5051 KU-KI                                     |          |
| SUBI RO,R1                                     | 33.      |
|                                                | <u>8</u> |
|                                                | 8        |
|                                                |          |
|                                                |          |
|                                                |          |
|                                                |          |

**Program Flow Control** 

Sometimes it may be necessary for several processors to access some shared data or other common resources. The portion of code that must access the shared data is called a *critical section*.

To ease the programming of critical sections, semaphores may be used. Semaphores are variables that can take only nonnegative integer values. Two primitive, indivisible operations are defined on semaphores (with S being a semaphore):

V(S):  $S + 1 \rightarrow S$ P(S): P: if (S == 0), go to P else S - 1  $\rightarrow$  S

Indivisibility of V(S) and P(S) means that when these processes access and modify the semaphore S, they are the only processes doing so.

To enter a critical section, a P operation is performed on a common semaphore, e.g., S (S is initialized to 1). The first processor performing P(S) will be able to enter its critical section. All other processors are blocked because S has become 0. After leaving its critical section, the processor performs a V(S), thus allowing another processor to execute P(S) successfully.

The TMS320C40 code for V(S) is shown in Example 6-7, and code for P(S) is shown in Example 6-8. Compare the code in Example 6-8 to the code in Example 6-6.

## 6.6 Reset Operation

The TMS320C40 supports a nonmaskable external reset signal (RESET), which is used to perform system reset. This section discusses the reset operation.

At powerup, the state of the TMS320C40 processor is undefined. You can use the RESET signal to place the processor in a known state. This signal must be asserted low for 10 or more H1 clock cycles to guarantee a system reset. H1 is an output clock signal generated by the TMS320C40 (see Chapter 13 for more information).

Reset affects the other pins on the device in either a synchronous or asynchronous manner. The synchronous reset is gated by the TMS320C40s internal clocks. The asynchronous reset directly affects the pins, and it is faster than the synchronous reset. Table 6–3 shows the state of the TMS320C40s pins after  $\overrightarrow{RESET} = 0$ . Each pin is described according to whether the pin is reset synchronously or asynchronously.

Table 6–3. Pin Operation at Reset

| Signal                                  | Pins | Туре  | Description                                        |  |  |
|-----------------------------------------|------|-------|----------------------------------------------------|--|--|
| Global Bus External Interface (80 pins) |      |       |                                                    |  |  |
| D(31– 0)                                | 32   | I/O/T | Synchronous reset. Placed in high-impedance state. |  |  |
| DE                                      | 1    | 1     | Reset has no effect.                               |  |  |
| A(30 – 0)                               | 31   | O/T   | Synchronous reset. Placed in high-impedance state. |  |  |
| ĀĒ                                      | 1    | 1     | Reset has no effect.                               |  |  |
| STAT(3 - 0)                             | 4    | 0     | Synchronous reset. Set to all ones.                |  |  |
| LOCK                                    | 1    | 0     | Synchronous reset. Set to one.                     |  |  |
| STRB0                                   | 1    | O/T   | Synchronous reset. Set to one.                     |  |  |
| R/W0                                    | 1    | O/T   | Synchronous reset. Set to one.                     |  |  |
| PAGE0                                   | 1    | O/T   | Synchronous reset. Set to zero.                    |  |  |
| RDY0                                    | 1    | 1     | Reset has no effect.                               |  |  |
| CE0                                     | 1    |       | Reset has no effect.                               |  |  |
| STRB1                                   | 1    | 0/Т   | Synchronous reset. Set to one.                     |  |  |
| R/W1                                    | 1    | O/T   | Synchronous reset. Set to one.                     |  |  |
| PAGE1                                   | 1    | 0/Т   | Synchronous reset. Set to zero.                    |  |  |
| RDY1                                    | 1    | 1     | Reset has no effect.                               |  |  |
| CE1                                     | 1    | 1     | Reset has no effect.                               |  |  |

Table Continued on Next Page

Program Flow Control

| Signal                                 | Pins | Туре  | Description                                         |
|----------------------------------------|------|-------|-----------------------------------------------------|
| Local Bus External Interface (80 pins) |      |       |                                                     |
| LD(31-0)                               | 32   | I/O/T | Synchronous reset. Placed in high-impedance state.  |
| LDE                                    | 1    | I     | Reset has no effect.                                |
| LA(30 - 0)                             | 31   | O/T   | Synchronous reset. Placed in high-impedance state.  |
| LAE                                    | 1    | I     | Reset has no effect.                                |
| LSTAT(3 - 0)                           | 4    | 0     | Synchronous reset. Set to all ones.                 |
| LLOCK                                  | 1    | 0     | Synchronous reset. Set to one.                      |
| LSTRB0                                 | 1    | 0/Т   | Synchronous reset. Set to one.                      |
| LR/W0                                  | 1    | O/T   | Synchronous reset. Set to one.                      |
| LPAGE0                                 | 1    | 0/Т   | Synchronous reset. Set to zero.                     |
| LRDY0                                  | 1    | 1     | Reset has no effect.                                |
| LCE0                                   | 1    | I     | Reset has no effect.                                |
| LSTRB1                                 | 1    | O/T   | Synchronous reset. Set to one.                      |
| LR/W1                                  | 1    | O/T   | Synchronous reset. Set to one.                      |
| LPAGE1                                 | 1    | 0/Т   | Synchronous reset. Set to zero.                     |
| LRDY1                                  | 1    | I     | Reset has no effect.                                |
| LCE1                                   | 1    | 1 .   | Reset has no effect.                                |
|                                        |      | Con   | nmunication Port 0 Interface (12 pins)              |
| C0D(7-0)                               | 8    | 1/0   | Synchronous reset. Placed in high-impedance state.  |
| CREQ0                                  | 1    | 1/0   | Asynchronous reset. Placed in high-impedance state. |
| CACK0                                  | 1    | I/O   | Asynchronous reset. Placed in high-impedance state. |
| CSTRB0                                 | 1    | I/O   | Asynchronous reset. Placed in high-impedance state. |
| CRDY0                                  | 1    | 1/0   | Asynchronous reset. Placed in high-impedance state. |

 Table 6–3.
 Pin Operation at Reset (Continued)

Table Continued on Next Page

| Signal        | Pins | Туре       | Description                                         |
|---------------|------|------------|-----------------------------------------------------|
|               |      | Con        | nmunication Port 1 Interface (12 pins)              |
| C1D(7-0)      | 8    | 1/O        | Synchronous reset. Placed in high-impedance state.  |
| CREQ1         | 1    | <u>l/O</u> | Asynchronous reset. Placed in high-impedance state. |
| CACK1         | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
| CSTRB1        | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
| CRDY1         | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
|               |      | Con        | nmunication Port 2 Interface (12 pins)              |
| C2D(7-0)      | 8    | I/O        | Synchronous reset. Placed in high-impedance state.  |
| CREQ2         | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
| CACK2         | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
| CSTRB2        | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
| CRDY2         | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
|               |      | Con        | nmunication Port 3 Interface (12 pins)              |
| C3D(7-0)      | 8    | 1/0        | Synchronous reset. Placed in high-impedance state.  |
| CREQ3         | 1    | 1/0        | Asynchronous reset. Placed in high-impedance state. |
| <b>CACK</b> 3 | 1    | 1/0        | Asynchronous reset. Placed in high-impedance state. |
| CSTRB3        | 1    | 1/0        | Asynchronous reset. Placed in high-impedance state. |
| CRDY3         | 1    | 1/0        | Asynchronous reset. Placed in high-impedance state. |
|               |      | Con        | nmunication Port 4 Interface (12 pins)              |
| C4D(7-0)      | 8    | I/O        | Synchronous reset. Placed in high-impedance state.  |
| CREQ4         | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
| CACK4         | 1    | 1/0        | Asynchronous reset. Placed in high-impedance state. |
| CSTRB4        | 1    | 1/0        | Asynchronous reset. Placed in high-impedance state. |
| CRDY4         | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
|               |      | Con        | nmunication Port 5 Interface (12 pins)              |
| C5D(7-0)      | 8    | I/O        | Synchronous reset. Placed in high-impedance state.  |
| CREQ5         | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
| CACK5         | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
| CSTRB5        | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |
| CRDY5         | 1    | I/O        | Asynchronous reset. Placed in high-impedance state. |

### Table 6–3. Pin Operation at Reset (Continued)

Table Concluded on Next Page

| Signal        | Pins                                          | Туре | Description                                                                                                     |  |  |
|---------------|-----------------------------------------------|------|-----------------------------------------------------------------------------------------------------------------|--|--|
|               | Interrupts, I/O Flags, Reset, Timer (12 pins) |      |                                                                                                                 |  |  |
| IIOF(0 – 3)   | 4                                             | I/O  | Asynchronous reset. Placed in high-impedance state.                                                             |  |  |
| NMI           |                                               | I    | Reset has no effect.                                                                                            |  |  |
| IACK          | 1                                             | I    | Synchronous reset.                                                                                              |  |  |
| RESET         | <u> </u>                                      | I    | RESET input pin                                                                                                 |  |  |
| RESETLOC(1,0) | 2                                             | 1    | Reset has no effect.                                                                                            |  |  |
| ROMEN         | 1                                             | l    | Reset has no effect.                                                                                            |  |  |
| TCLK0         | 1                                             | 1/0  | Asynchronous reset. Placed in high-impedance state.                                                             |  |  |
| TCLK1         | 1                                             | I/O  | Asynchronous reset. Placed in high-impedance state.                                                             |  |  |
|               |                                               | ,    | Clock and Power (4 pins)                                                                                        |  |  |
| X1            | 1                                             | 0    | Reset has no effect.                                                                                            |  |  |
| X2/CLKIN      | 1                                             | 1    | Reset has no effect.                                                                                            |  |  |
| H1            | 1                                             | I    | Synchronous reset. Will go to its initial state when RESET makes a 1 to 0 transition.                           |  |  |
| НЗ            | 1                                             | I    | Synchronous reset. Will go to its initial state when $\overrightarrow{\text{RESET}}$ makes a 1 to 0 transition. |  |  |
|               |                                               |      | Emulation (7 pins)                                                                                              |  |  |
| ТСК           | 1                                             | 1    | Reset has no effect.                                                                                            |  |  |
| TDO           | 1                                             | 0    | Reset has no effect.                                                                                            |  |  |
| TDI           | 1                                             | 1    | Reset has no effect.                                                                                            |  |  |
| TMS           | 1                                             | 1    | Reset has no effect.                                                                                            |  |  |
| TRST          | 1                                             | I    | Reset has no effect.                                                                                            |  |  |
| EMU0          | 1                                             | 1/0  | Undefined.                                                                                                      |  |  |
| EMU1          | 1                                             | I/O  | Undefined.                                                                                                      |  |  |

## Table 6–3. Pin Operation at Reset (Concluded)

At system reset, the following additional operations are performed:

- Timer registers (Section 9.10 on page 9-45) are set.
  - Timer global control register set to zero except that bit DATIN is set to the value on pin TCLK.
  - Timer counter and timer period registers set to zeroes.
- Communications port control registers (subsection 8.4.1 on page 8-9) set to zeroes.
- External memory interface control registers (Section 7.2 on page 7-6) are set to 3E39 FFF0h.
- DMA channel control register, DMA transfer counter, and DMA auxiliary transfer counter (subsection 9.3.1 on page 9-7) are set to zeroes.
- □ The following CPU registers are loaded with zeroes (each described in Chapter 3):
  - ST (CPU status register)
  - IIE (CPU internal interrupt enable register)
  - IIF (interrupt flag register; controls pins IIOF(3–0))
  - DIE (DMA internal enable register)
  - IVTP (interrupt-vector table pointer)
  - TVTP (trap-vector table pointer)
- □ Then the reset vector is read from its location and loaded into the PC. This vector contains the start address of the system reset routine.
- Execution begins. Refer to Section 12.1 on page 12-3 for an example of a processor initialization routine.

Multiple TMS320C40s driven by the same system clock may be reset and synchronized. When the 1-to-0 transition of RESET occurs, the processor is placed on a well-defined internal phase, and all of the TMS320C40s will come up on the same internal phase.

## 6.7 Interrupts

The TMS320C40 supports multiple internal and external interrupts, which can be used for a variety of applications. This section discusses the operation of these interrupts. Additional information regarding internal interrupts can be found in Section 8.4 (page 8-8), Section 8.6 (page 8-17), Table 8–1 (communication ports on page 8-10), Section 9.9 (DMA on page 9-40), and Section 9.10 (timers on page 9-45).

The four external interrupts (IIOF0–IIOF3 as shown in Figure 6–6) are enabled at the **IIE register** (subsection 3.1.9, page 3-10). They are synchronized internally. They are sampled on the falling edge of H1 and passed through a series of H1/H3 delays internally. Once synchronized, the interrupt input will set the corresponding interrupt flag register (IIF) bit if the interrupt is active. These are the external interrupts and their corresponding interrupt vectors (the latter shown in Figure 6–6 on page 6-27):

| IIOF Pin &<br>Interrupt | Interrupt<br>Vector Location |
|-------------------------|------------------------------|
| IIOF0                   | IVTP + 003h                  |
| IIOF1                   | IVTP + 004h                  |
| IIOF2                   | IVTP + 005h                  |
| IIOF3                   | IVTP + 006h                  |

These interrupts are prioritized in that one is selected over the other if both come on the same clock cycle (IIOF0 the highest, IIOF1 next, etc.). When an interrupt is taken, the status register ST(GIE) bit is reset to 0, disabling any other incoming interrupt (except NMI — nonmaskable interrupt). This prevents any other interrupt (IIOF0–3) from assuming program control until the ST(GIE) bit is set back to 1. The NMI (an incoming low on pin AJ5, signal  $\overline{NMI}$ ) is not masked by the ST(GIE) bit. On a return from an interrupt routine, the RETI and RETI*cond* instructions place the value that is in the ST(PGIE) bit into the ST(GIE) bit, returning it to its value before the context switch.

Even though the **NMI** is nonmaskable, it is temporarily masked during delayed branches and multicycle CPU operations. NMI is a negative-going, edge-triggered, latched interrupt.

External interrupts can be effectively either edge- or level-triggered, depending on how the TYPE fields are set in the **IIF register** (see Table 3–6 on page 3-13). An external interrupt must be held low for at least one H1/H3 cycle to be recognized by the TMS320C40. For level-triggered interrupts, if the interrupt is held low for between one and two cycles, then only one interrupt is recognized. If the interrupt is held low two or more cycles, more than one interrupt may be recognized, depending on how rapidly interrupts are serviced.

#### 6.7.1 Interrupt Control Bits

When a particular interrupt is processed by the CPU or DMA controller, the corresponding interrupt flag bit is cleared by the internal interrupt acknowledge signal. It should be noted, however, that for level-triggered interrupts, if IIOFn is still low when the interrupt acknowledge signal occurs, the interrupt flag bit will be cleared for only one cycle and then set again because IIOFn is still low. Accordingly, it is theoretically possible that, depending on when the **IIF register** (described in subsection 3.1.10 on page 3-12) is read, this bit may be zero even though IIOFn is zero. When the TMS320C40 is reset, zero is written to the interrupt flag register, thereby clearing all pending interrupts.

The interrupt flag register bits may be read and written to under software control. If, at the IIF register, FUNCx = 0 and TYPEx = 1, then external pin IIOFx can be written to. Writing a 1 to the IIF register FLAGx bit has the same effect as an incoming interrupt received on the corresponding pin. In this way, all interrupts may be triggered and/or cleared through software. Since the interrupt bits also may be read (TYPEx = 0), the interrupt pins may be polled in software when an interrupt-driven interface is not required.

Internal interrupts operate in a similar manner. In the IIF register, the bit corresponding to an internal interrupt (e.g., TINT0, TINT1) may be read and written to through software. Writing a 1 sets the interrupt latch, and writing a 0 clears it. All internal interrupts are one H1/H3 cycle in length.

The CPU global interrupt enable bit (GIE), located in the CPU status register (ST), controls all CPU interrupts. All DMA interrupts are controlled by the DMA enable register bits and the SYNC bits of the DMA channel control registers (described in Figure 9–2 and Table 9–1 on page 9-8). The DMA interrupts are not dependent upon ST(GIE) and are local to the DMA.

To provide for maximum performance in servicing interrupts, the interrupt acknowledge (IACK) instruction is provided. IACK drives the IACK pin and performs a dummy read. The read is performed from the address specified by the IACK instruction operand. When IACK is used, it typically is placed in the early portion of an interrupt service routine. For certain applications, it may be better suited at the end of the interrupt service routine or be totally unnecessary.

#### 6.7.2 Prioritization and Control

The prioritization of interrupts is handled by the CPU according to the interrupt vector table shown in Figure 6–6. Prioritization is according to position in the table — those with displacements closest to the IVTP base address are higher in priority (i.e., NMI is higher than TINTO, which is higher than

6-24

IIOF0, etc.). Note that interrupt TINT0 is located at IVTP + 2 while the TINT1 vector is after the communication port and DMA coprocessor interrupts at IVTP + 2Bh.

*Prioritization* means an interrupt in a higher position in the interrupt vector table (Figure 6–6) will be accepted over one in a lower position *when both are received in the same clock cycle*. It *does not* mean, for example, that IIOF3 must wait until service routines for IIOF2, IIOF1, and IIOF0 are completed (when ST(GIE) = 1).

If the DMA coprocessor is not using interrupts for synchronization of transfers, it will not be affected by the processing of the CPU interrupts. If the CPU is involved in a pipeline conflict (branch, register, or memory), it will not respond to the interrupts until that conflict is resolved. It is therefore possible to interrupt the CPU and DMA coprocessor simultaneously with the same or different interrupts and, in effect, synchronize their activities. For example, it may be necessary to cause a high-priority DMA coprocessor transfer that avoids but conflicts with the CPU, i.e., makes the DMA coprocessor a higher priority than the CPU. This may be accomplished by using an interrupt that causes the CPU to trap to an interrupt routine that contains an IDLE instruction. Then, if the same interrupt is used to synchronize DMA coprocessor transfers, the DMA coprocessor transfer counter can be used to generate an interrupt and, thus, return control to the CPU following the DMA coprocessor transfer.

Since the DMA coprocessor and CPU share the same set of interrupt flags, the DMA coprocessor may clear an interrupt flag before the CPU can respond to it. For example, if the CPU interrupts are disabled, the DMA coprocessor can respond to interrupts and thus clear the associated interrupt flags.

Note the following situations:

- □ If there is a delayed branch in the pipeline, interrupts are held pending until after the branch.
- If the interrupt occurs in the first cycle of the fetch of an instruction, the fetched instruction is discarded (not executed), and the address of that instruction is pushed to the top of the system stack.
- □ If the interrupt occurs after first cycle of the fetch (in the case of a multicycle fetch due to wait states), that instruction is executed, and the address of the next instruction to be fetched is pushed to the top of the system stack.

If no program fetch is occurring, then no new fetch is performed.

After the address of the appropriate instruction has been pushed, the interrupt vector is fetched and loaded into the PC, and executed continues.

| Figure 6 | -5.        | Inter | rupt-Vector Table (IVT) |          |        |      |          |        |
|----------|------------|-------|-------------------------|----------|--------|------|----------|--------|
| IVTF     | '+         | 000h  | Reserved                | Note 1   | IVTP + | 01Dh | ICFULL4  |        |
| IVTF     | '+         | 001h  | NMI                     | Note 2   | IVTP + | 01Eh | ICRDY4   |        |
| IVTF     | ' +        | 002h  | TINT0                   | Note 3   | IVTP + | 01Fh | OCRDY4   |        |
| IVTF     | '+         | 003h  | IIOF0                   | )        | IVTP + | 020h | OCEMPTY4 |        |
| IVTF     | '+         | 004h  | IIOF1                   | Note 4   | IVTP + | 021h | ICFULL5  | Note 5 |
| IVTF     | <b>)</b> + | 005h  | IIOF2                   | > Note 4 | IVTP + | 022h | ICRDY5   |        |
| IVTF     | ' +        | 006h  | IIOF3                   | J        | IVTP + | 023h | OCRDY5   |        |
| IVTF     | '+         | 007h  | Unused<br>ICFULL0       |          | IVTP + | 024h | OCEMPTY5 | J      |
| IVTP     | +          |       | Unused                  |          | IVTP + | 025h | DMA INTO |        |
| IVTF     | '+         | 00Ch  |                         |          | IVTP + | 026h | DMA INT1 |        |
| IVTP     | +          | 00Dh  | ICFULL0                 |          | IVTP + | 027h | DMA INT2 |        |
| IVTP     | +          | 00Eh  | ICRDY0                  |          | IVTP + | 028h | DMA INT3 | Note 6 |
| IVTP     | +          | 00Fh  | OCRDY0                  |          | IVTP + | 029h | DMA INT4 |        |
| IVTP     | '+         | 010h  | OCEMPTY0                | _        | IVTP + | 02Ah | DMA INT5 | J      |
| IVTP     | +          | 011h  | ICFULL1                 |          | IVTP + | 02Bh | TINT1    | Note 3 |
| IVTP     | +          | 012h  | ICRDY1                  |          | IVTP + | 02Ch |          |        |
| IVTP     | '+         | 013h  | OCRDY1                  |          | IVTP + |      |          |        |
| IVTF     | '+         | 014h  | OCEMPTY1                | Note 5   | IVTP + |      |          |        |
| IVTF     | '+         | 015h  | ICFULL2                 | / Note 5 | IVTP + | •    | Unused   |        |
| IVTF     | ' +        | 016h  | ICRDY2                  |          | IVTP + |      |          |        |
| IVTF     | '+         | 017h  | OCRDY2                  |          | IVTP + | •    |          |        |
| IVTF     | '+         | 018h  | OCEMPTY2                |          | IVTP + | •    |          |        |
| IVTF     | '+         | 019h  | ICFULL3                 |          | IVTP + |      |          |        |
| IVTF     | '+         | 01Ah  | ICRDY3                  |          | IVTP + |      |          |        |
| IVTF     | '+         | 01Bh  | OCRDY3                  |          | IVTP + | 03Eh |          |        |
| IVTF     | <b>)</b> + | 01Ch  | OCEMPTY3                | )        | IVTP + | 03Fh | Reserved |        |

Reserved for the **reset** vector when IVTP = 0000 0000h and RESETLOC(1,0) =  $0.0_{2}$  or Notes: 1) when IVTP=08000 0000h and RESETLOC(1,0) = 1 0<sub>2</sub>. See Table 3-8.

NMI (non-maskable interrupt) is discussed in Section 9.9, page 9-40. 2)

Timer interrupts TINT0 and TINT1 are enabled and programmed by the IIE register (subection 3) 3.1.9, page 3-10) and monitored at the IIF register (subection 3.1.10, page 3-12).

- External **pins IIOF0**—**IIOF5** are programmed in the **DIE** register (subsection 3.1.8, page 3-8) 4) and the IIF register (subection 3.1.10, page 3-12).
- The communication port I/O buffers full/ready interrupts are enabled by the DIE and IIE re-5) gisters and also discussed in Table 8-1, page 8-10 (OUTPUT LEVEL & INPUT LEVEL bits).
- DMA interrupts are enabled at the IIE register and DMA channel control register (at bits TCC 6) and AUX TCC explained in Table 9-1 on page 9-8).

The TMS320C40 allows the CPU and DMA coprocessor to respond to and process interrupts in parallel. Figure 6–6 shows interrupt processing flow. The interrupts are polled, and the CPU and DMA coprocessor begin processing them. In the interrupt flow pertaining to the CPU (left side of figure), the interrupt flag corresponding to the highest priority enabled interrupt is cleared, and GIE is set to 0. The CPU completes all fetched instructions. The interrupt vector is fetched and loaded into the PC, and the CPU continues execution. The DMA coprocessor cycle (right side of figure) is similar to that for the CPU. After the pertinent interrupt flag is cleared, the DMA coprocessor proceeds according to the status of the SYNCH bits in the DMA coprocessor global control register.

#### Figure 6–6. Interrupt Processing





## **Chapter 7**

# **External Bus Operation**

The TMS320C40 has two identical 80-pin parallel external interfaces: the **global memory interface** and the **local memory interface**. Each interface has the following features:

- separate 80-pin configurations, each with its own 32-bit data bus and 31-bit address bus,
- □ single-cycle reads and pipelined writes,
- independent enable signals for data, address, and control lines,
- bus-request and bus-lock signaling for share memory parallel processing,
- user-controlled mapping of addresses to either of two sets of independent strobes for different speed memories,
- look-ahead bus status signals for defining current and requested bus operations for parallel processing arbitration,
- selectable wait states (both software- and hardware-controlled),
- signals that indicate when memory page boundaries are crossed. Thissupports
  - page-mode and static-column decode DRAMs,
  - high-speed SRAM banks, and
  - slower-speed memory banks and I/O devices.

#### Note: Description Covers Both Interfaces in this Chapter

This chapter covers both the global memory interface and the local memory interface. However, only the global memory interface is shown throughout this chapter because it is identical in every way to the local memory interface except that (1) they have different positions in the memory map, and (2) the control signals for the local memory interface have an additional "L" prefix (as described in Figure 7–1 on page 7-3).

Principal headings within this chapter:

### Section

| ectio | on                                                  | Page |
|-------|-----------------------------------------------------|------|
| 7.1   | Global (and Local) Memory Interface Control Signals | 7-3  |
| 7.2   | Memory Interface Control Registers                  | 7-6  |
| 7.3   | Use of the Global Memory Interface Registers        | 7-12 |
| 7.4   | Programmable Wait States                            | 7-15 |
| 7.5   | Timing                                              | 7-17 |
| 7.6   | Using Enabled Signals to Control Signal Group       | 7-38 |
| 7.7   | Interlocked-Instructions Definition and Timing      | 7-39 |
| 7.8   |                                                     | 7-47 |
|       |                                                     |      |

## 7.1 Global (and Local) Memory Interface Control Signals

As explained in the Note on page 7–1, this text covers the global memory interface control signals; it also applies to the local memory interface control signals (with the exceptions stated in the note).

Figure 7–1. Global and Local Memory Interface Control Signals



As shown in Figure 7–1, the global memory interface has two sets of control signals, STRB0 and STRB1. The global memory port control registers (Section 7.2 on page 7-6) define which set of registers is active.

| Signal <sup>†</sup> | Type§ | Description                                                                                                                                                                                                                          |
|---------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R/W(0,1)            | O/Z   | Specifies memory read (active high) or write (active low) mode.                                                                                                                                                                      |
| STRB(0,1)           | O/Z   | Interface access strobe.                                                                                                                                                                                                             |
| PAGE(0,1)           | O/Z   | Memory-page enable signal for STRB(0,1) accesses.                                                                                                                                                                                    |
| RDY(0,1)            | I     | Indicates external memory is ready to be accessed.                                                                                                                                                                                   |
| CE(0,1)             | I     | Control signal enable for $R/Wx$ , $\overline{STRBx}$ , and $PAGEx$ signals. When high (a one), it places the corresponding $R/Wx$ , $\overline{STRBx}$ , and $PAGEx$ signals in high-impedance state (x=0 for CE0 and x=1 for CE1). |
| DE                  | 1     | When high (a one), places data lines $D31 - 0$ in high-impedance state.                                                                                                                                                              |
| ĀĒ                  | I     | When high (a one), places address lines A30 – 0 in high-impedance state.                                                                                                                                                             |
| STAT(3 – 0)‡        | 0     | Four lines to define status or function of the memory port as shown in Table 7–2 (next page).                                                                                                                                        |
| LOCK‡               | 0     | Indicates if an interlocked access is underway (0 = access underway;<br>1 = access not underway). LOCK is changed <i>only</i> by the interlocked in-<br>structions.                                                                  |

#### Table 7–1. Global Memory Interface Control Signals

This table applies to both the global memory interface and local memory interface (local memory interface signals have an additional "L" prefix). The numbers in parentheses mean that <u>either</u> a 0 (zero) or a 1 can follow the prefix shown to the left of the parentheses. A zero indicates STRB0 control signals (shown in Figure 7–1), and a one indicates STRB1 control signals.

§ O = output; I = input; Z = high impedance (three-stated).

STAT (3 - 0) and LOCK cannot be placed in the high-impedance state by an external control signal.

Table 7–2 on the next page shows how pins STAT3 to STAT0 define the current status of the global memory port. For many bus accesses, these signals provide information about the access that is about to begin. The code for a SIGI instruction read is useful for distinguishing between a SIGI read and a LDII or LDFI read.

The **bus idle** status code is 1111<sub>2</sub> (bottom of Table 7–2), which simplifies modular shared-bus multiprocessor interfaces, because pull-up resistors can be used to signal the idle condition when processor cards are not attached to the shared bus.

|       | Value a | <b>t Pins</b> † |       |                                       |
|-------|---------|-----------------|-------|---------------------------------------|
| STAT3 | STAT2   | STAT1           | STAT0 | Status                                |
| 0     | 0       | 0               | 0     | STRB0 access, program read            |
| 0     | 0       | 0               | 1     | STRB0 access, data read               |
| 0     | 0       | 1               | 0     | STRB0 access, DMA read                |
| 0     | 0       | 1               | 1     | STRB0 access, SIGI (instruction) read |
| 0     | 1       | 0               | 0     | Reserved                              |
| 0     | 1       | 0               | 1     | STRB0 access, data write              |
| 0     | 1       | 1               | 0     | STRB0 access, DMA write               |
| 0     | 1       | 1               | 1     | Reserved                              |
| •     | 0       | ÷.              | 9     | STRB1 access, program read            |
| •     | 0       | 0               | 1     | STRB1 access, data read               |
| 1     | 0       | 1               | 0     | STRB1 access, DMA read                |
| 1     | 0       | 1               | 1     | STRB1 access, SIGI (instruction) read |
| 1     | 1       | 0               | 0     | Reserved                              |
| 1     | 1       | 0               | 1     | STRB1 access, data write              |
| 1     | 1       | 1               | 0     | STRB1 access, DMA write               |
| •     | 1       | •               | •     | idie                                  |

Table 7–2. Global Memory Port Status for STRB0 and STRB1 Accesses

<sup>†</sup> This table applies to both the global memory interface and local memory interface (for local memory interface signals, add an additional "L" prefix such as LSTAT3, LSTAT2, etc.).

#### 7.2 Memory Interface Control Registers

As explained in the Note on page 7–1, this text covers the global memory interface control signals; it also applies to the local memory interface control signals (with the exceptions stated in the note).

Figure 7–2 shows the memory map for both the global and local memory interface control registers. Each register can be programmed to control its respective memory interface by defining:

- page sizes for the two strobes,
- u when strobes are active,
- u wait states,
- other operations that control the memory interface.

Table 7–3 (on page 7-8) describes the fields in these registers.

At **reset**, the binary values shown above each bit in Figure 7–1 are written to the global memory interface control register. Values in bits 3 - 0 are the values at these bits' respective pins ( $\overline{AE}$ ,  $\overline{DE}$ ,  $\overline{CE1}$ , and  $\overline{CE0}$ ). This reset condition has the following effects (for the local and global bus):

- □ STRB0 and STRB1 (LSTRB0 and LSTRB1) page sizes are set to 00111<sub>2</sub> (256 words).
- STRB0 and STRB1 (LSTRB0 and LSTRB1) wait states are set to 7 cycles.
- STRB0 and STRB1 (LSTRB0 and LSTRB1) accesses require an external ready signal and an internal ready signal generated by the software wait-state generator.
- STRB0 (LSTRB0) is active for all addresses over the global (local) memory interface.
- Back-to-back reads that switch from STRB0 to STRB1 (or STRB1 to STRB0) result in the insertion of a single cycle between these reads.

As shown in Figure 7–2, fields STRB1 SWW and STRB0 WW are both set to  $11_2$  to allow the internal ready signal to be generated by RDY<sub>wtcnt</sub> (onchip wait-state counter) and external RDY

Figure 7–2. Format for the Memory-Interface Control Registers



- NOTES: 1. The register cell figure (immediately above) contains global memory interface control register mnemonics. However, local memory interface control register mnemonics can be visualized by adding an "L" prefix to each mnemonic in the figure (e.g., LSTRB SWW, LCE0, etc.).
  - The 1s and 0s above each bit are the binary values written to the register at reset. <u>The values at bits 3</u> – 0 are defined by the values of their respective external pins (AE, DE, CE1, and CE0).
  - 3. These registers are shown in the overall memory map in Figure 3–9 and Figure 3–10 on pages 3-19 and 3-20, respectively.
  - 4. RW = read/write; R = read.

| Bit No. | Mnemonic <sup>†</sup> | Description <sup>†</sup>                                                                                                                                                                                            |
|---------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | CE0                   | Value of external pin CE0 (after it passes through an inter-<br>nal synchronizer). The value is not latched.                                                                                                        |
| 1       | CE1                   | Value of external pin CE1 (after it passes through an inter-<br>nal synchronizer). The value is not latched.                                                                                                        |
| 2       | DE                    | Value of external pin DE (after it passes through an internal synchronizer). The value is not latched.                                                                                                              |
| 3       | ĀĒ                    | Value of external pin AE (after it passes through an internal synchronizer). The value is not latched.                                                                                                              |
| 4 – 5   | STRB0 SWW             | <b>Software wait states for STRB0 access.</b> In conjunction with STRB0 WTCNT, this field defines the mode of wait-state generation. Actual wait states are explained in Section 7.4 and in Table 7–7 on page 7-16. |
| 6 – 7   | STRB1 SWW             | <b>Software wait states for STRB1 access.</b> In conjunction with STRB1 WTCNT, this field defines the mode of wait-state generation. Actual wait states are explained in Section 7.4 and in Table 7–7 on page 7-16. |
| 8 – 10  | STRB0 WTCNT           | <b>Software wait-state count for STRB0 accesses.</b> Specifies the number of cycles to use when software wait states are active. Three-bit range is from 000 <sub>2</sub> (zero) to 111 <sub>2</sub> (seven).       |
| 11 – 13 | STRB1 WTCNT           | <b>Software wait-state count for STRB1 accesses.</b> Specifies the number of cycles to use when software wait states are active. Three-bit range is from 000 <sub>2</sub> (zero) to 111 <sub>2</sub> (seven).       |
| 14 – 18 | STRB0 PAGESIZE        | <b>Page size for STRB0 accesses.</b> Specifies number of MSBs of the address to use to define the bank size for STRB0 accesses. See range table in Table 7–4 on page 7-9.                                           |
| 19 – 23 | STRB1 PAGESIZE        | <b>Page size for STRB1 accesses.</b> Specifies number of MSBs of the address to use to define the bank size for STRB1 accesses. See range table in Table 7–4 on page 7-9.                                           |
| 24 – 28 | STRB ACTIVE           | Specifies <b>address ranges</b> over which STRB0t and STRB1t are active. See ranges in Table 7–5 on page 7-10 for <b>STRB ACTIVE</b> and Table 7–6 on page 7-11 for <b>LSTRB ACTIVE</b> .                           |
| 29      | STRB SWITCH           | <b>Inserts a single cycle between back-to-back reads</b> that<br>switch from STRB0 to STRB1 (or vice versa).<br>When a <b>1</b> , insert cycle.<br>When a <b>0</b> , <i>don't</i> insert cycle.                     |
| 30 - 31 | Reserved              | Read as zeroes.                                                                                                                                                                                                     |

#### Table 7–3. Bit Definitions for Both Memory Interface Control Registers

† Mnemonics used are for the global memory interface control register. For the local memory interface control register, add the prefix "L" to each mnemonic (e.g., LCEO, LCE1, LSTRB1, etc.). The description remains the same for the local memory interface control register.

| STRBx<br>PAGESIZE<br>Field‡ | External Address Bus<br>Bits Defining the<br>Current Page | External Address Bus<br>Bits Defining<br>Address on a Page | Page Size<br>(32-Bit Wds) |
|-----------------------------|-----------------------------------------------------------|------------------------------------------------------------|---------------------------|
| 00000–<br>00110             | Reserved                                                  | Reserved                                                   | Reserved                  |
| 00111                       | 30 — 8                                                    | 7 — 0                                                      | 2 <sup>8</sup> = 256      |
| 01000                       | 30 — 9                                                    | 8-0                                                        | 2 <sup>9</sup> = 512      |
| 01001                       | 30 — 10                                                   | 9 — 0                                                      | 2 <sup>10</sup> = 1K      |
| 01010                       | 30 — 1 1                                                  | 10 — 0                                                     | 2 <sup>11</sup> = 2K      |
| 01011                       | 30 — 12                                                   | 11 — 0                                                     | 2 <sup>12</sup> = 4K      |
| 01100                       | 30 — 13                                                   | 12 — 0                                                     | 2 <sup>13</sup> = 8K      |
| 01101                       | 30 — 14                                                   | 13 — 0                                                     | 2 <sup>14</sup> = 16K     |
| 01110                       | 30 — 15                                                   | 14 — 0                                                     | 2 <sup>15</sup> = 32K     |
| 01111                       | 30 — 16                                                   | 15 — 0                                                     | 2 <sup>16</sup> = 64K     |
| 10000                       | 30 — 17                                                   | 16 — 0                                                     | 2 <sup>17</sup> = 128K    |
| 10001                       | 30 — 18                                                   | 17 — 0                                                     | 2 <sup>18</sup> = 256K    |
| 10010                       | 30 — 19                                                   | 18 — 0                                                     | 2 <sup>19</sup> = 512K    |
| 10011                       | 30 — 20                                                   | 19 — 0                                                     | 2 <sup>20</sup> = 1M      |
| 10100                       | 30 — 21                                                   | 20 — 0                                                     | 2 <sup>21</sup> = 2M      |
| 10101                       | 30 — 22                                                   | 21 — 0                                                     | 2 <sup>22</sup> = 4M      |
| 10110§                      | 30 — 23                                                   | 22 — 0                                                     | 2 <sup>23</sup> = 8M      |
| 10111                       | 30 — 24                                                   | 23 — 0                                                     | 2 <sup>24</sup> = 16M     |
| 11000                       | 30 — 25                                                   | 24 — 0                                                     | 2 <sup>25</sup> = 32M     |
| 11001                       | 30 — 26                                                   | 25 — 0                                                     | 2 <sup>26</sup> = 64M     |
| 11010                       | 30 — 27                                                   | 26 — 0                                                     | 2 <sup>27</sup> = 128M    |
| 11011                       | 30 — 28                                                   | 27 — 0                                                     | 2 <sup>28</sup> = 256M    |
| 11100                       | 30 — 29                                                   | 28 — 0                                                     | 2 <sup>29</sup> = 512M    |
| 11101                       | 30                                                        | 29 — 0                                                     | 2 <sup>30</sup> = 1G      |
| 11110                       | None                                                      | 30 — 0                                                     | 2 <sup>31</sup> = 2G      |
| 11111                       | Reserved                                                  | Reserved                                                   | Reserved                  |

Table 7–4. Page Size as Defined by STRB0/1 PAGESIZE Bits<sup>†</sup>

† Mnemonics used are for the global memory interface control register. For the local memory interface control register, add the prefix "L" to each mnemonic (e.g., LSTRB0 PAGESIZE, LSTRB1 PAGESIZE, etc.). The description remains the same for the local memory interface control register.

<sup>‡</sup> The "x" in STRBx means that the data in the columns are for STRB0 or STRB1 as well as for LSTRB0 and LSTRB1, as explained in the note above.

\$ An STRBx PAGESIZE field of 101102 is depicted in Figure 7-4 on page 7-13.

7.

| STRB ACTIVE<br>Field | STRB0 Active<br>Address Range | STRB0 Active<br>Address<br>Range Size | STRB1 Active<br>Address Range |
|----------------------|-------------------------------|---------------------------------------|-------------------------------|
| 00000-<br>01110      | Reserved                      | Reserved                              | Reserved                      |
| 01111                | 8000 0000 — 8000 FFFF         | 2 <sup>16</sup> = 64K                 | 8001 0000 — FFFF FFFF         |
| 10000                | 8000 0000 — 8001 FFFF         | 2 <sup>17</sup> = 128K                | 8002 0000 — FFFF FFFF         |
| 10001                | 8000 0000 — 8003 FFFF         | 2 <sup>18</sup> = 256K                | 8004 0000 — FFFF FFFF         |
| 10010                | 8000 0000 — 8007 FFFF         | 2 <sup>19</sup> = 512K                | 8008 0000 — FFFF FFFF         |
| 10011                | 8000 0000 — 800F FFFF         | 2 <sup>20</sup> = 1M                  | 8010 0000 — FFFF FFFF         |
| 10100                | 8000 0000 — 801F FFFF         | $2^{21} = 2M$                         | 8020 0000 — FFFF FFFF         |
| 10101                | 8000 0000 — 803F FFFF         | $2^{22} = 4M$                         | 8040 0000 — FFFF FFFF         |
| 10110                | 8000 0000 — 807F FFFF         | $2^{23} = 8M$                         | 8080 0000 — FFFF FFFF         |
| 10111                | 8000 0000 — 80FF FFFF         | 2 <sup>24</sup> = 16M                 | 8100 0000 — FFFF FFFF         |
| 11000                | 8000 0000 — 81FF FFFF         | 2 <sup>25</sup> = 32M                 | 8200 0000 — FFFF FFFF         |
| 11001                | 8000 0000 — 83FF FFFF         | 2 <sup>26</sup> = 64M                 | 8400 0000 — FFFF FFFF         |
| 11010                | 8000 0000 — 87FF FFFF         | 2 <sup>27</sup> = 128M                | 8800 0000 — FFFF FFFF         |
| 11011                | 8000 0000 — 8FFF FFFF         | 2 <sup>28</sup> = 256M                | 9000 0000 — FFFF FFFF         |
| 11100                | 8000 0000 — 9FFF FFFF         | 2 <sup>29</sup> = 512M                | A000 0000 — FFFF FFFF         |
| 11101                | 8000 0000 — BFFF FFFF         | 2 <sup>30</sup> = 1G                  | C000 0000 — FFFF FFFF         |
| 11110                | 8000 0000 — FFFFFFFF          | 2 <sup>31</sup> = 2G                  | None                          |
| 11111                | Reserved                      | Reserved                              | Reserved                      |

.

| Table 7–5. | Address Ranges Specified by STRB ACTIVE Bits † |
|------------|------------------------------------------------|
|------------|------------------------------------------------|

† Address ranges specified by the LSTRB ACTIVE bits are listed in Table 7–6.

External Bus Operation

| LSTRB AC-<br>TIVE Field | LSTRB0 Active<br>Address Range | LSTRB0 Active<br>Address<br>Range Size | LSTRB1 Active<br>Address Range |
|-------------------------|--------------------------------|----------------------------------------|--------------------------------|
| 00000-<br>01110         | Reserved                       | Reserved                               | Reserved                       |
| 01111                   | 0000 0000 — 0000FFFF           | 2 <sup>16</sup> = 64K                  | 0001 0000 — 7FFFFFFF           |
| 10000                   | 0000 0000 — 0001 FFFF          | 2 <sup>17</sup> = 128K                 | 0002 0000 — 7FFFFFF            |
| 10001                   | 0000 0000 — 0003FFFF           | 2 <sup>18</sup> = 256K                 | 0004 0000 — 7FFFFFF            |
| 10010                   | 0000 0000 — 0007FFFF           | 2 <sup>19</sup> = 512K                 | 0008 0000 — 7FFFFFF            |
| 10011                   | 0000 0000 — 000FFFFF           | 2 <sup>20</sup> = 1M                   | 0010 0000 — 7FFFFFF            |
| 10100                   | 0000 0000 — 001FFFFF           | 2 <sup>21</sup> = 2M                   | 0020 0000 — 7FFFFFF            |
| 10101                   | 0000 0000 — 003FFFFF           | 2 <sup>22</sup> = 4M                   | 0040 0000 — 7FFFFFF            |
| 10110                   | 0000 0000 — 007FFFFF           | 2 <sup>23</sup> = 8M                   | 0080 0000 — 7FFFFFF            |
| 10111                   | 0000 0000 — 00FFFFF            | 2 <sup>24</sup> = 16M                  | 0100 0000 — 7FFFFFF            |
| 11000                   | 0000 0000 — 01FFFFF            | $2^{25} = 32M$                         | 0200 0000 — 7FFFFFF            |
| 11001                   | 0000 0000 — 03FFFFFF           | 2 <sup>26</sup> = 64M                  | 0400 0000 — 7FFFFFF            |
| 11010                   | 0000 0000 — 07FFFFF            | 2 <sup>27</sup> = 128M                 | 0800 0000 — 7FFFFFF            |
| 11011                   | 0000 0000 — 0FFFFFF            | 2 <sup>28</sup> = 256M                 | 1000 0000 — 7FFFFFF            |
| 11100                   | 0000 0000 — 1FFFFFF            | 2 <sup>29</sup> = 512M                 | 2000 0000 — 7FFFFFF            |
| 11101                   | 0000 0000 — 3FFFFFF            | 2 <sup>30</sup> = 1G                   | 4000 0000 — 7FFFFFF            |
| 11110                   | 0000 0000 — 7FFFFFF            | $2^{31} = 2G$                          | None                           |
| 11111                   | Reserved                       | Reserved                               | Reserved                       |

Table 7–6. Address Ranges Specified by LSTRB ACTIVE Bits<sup>†</sup>

<sup>†</sup> Address ranges specified by the STRB ACTIVE bits are listed in Table 7–5.

## 7.3 Use of the Global Memory Interface Registers

#### 7.3.1 Mapping Addresses to Strobes

Figure 7–3 demonstrates the relationship between the STRB ACTIVE bits (defined in Table 7–3, page 7-8) and the address ranges over which signals  $\overline{\text{STRB0}}$  and  $\overline{\text{STRB1}}$  are active. Note that the address ranges of  $\overline{\text{STRBx}}$  and  $\overline{\text{LSTRBx}}$  **also govern the ranges of their associated signals**  $\overline{\text{RDYx}}$ ,  $\overline{\text{LRDYx}}$ ,  $\overline{\text{R/Wx}}$ ,  $\overline{\text{LR/Wx}}$ ,  $\overline{\text{PAGEx}}$ ,  $\overline{\text{LPAGEx}}$ , etc. (where x = 1 or 0).





Example (a) of Figure 7–3 shows the reset condition (STRB ACTIVE =  $11110_2$ ). In this case, signal STRB0 is active over the entire address range of the global memory bus (see Table 7–4 for lookup table of STRBACTIVE).

External Bus Operation

Example (b) of Figure 7–3 shows the global memory bus memory map when STRB ACTIVE =  $10101_2$ . In this case, STRB0 is active from addresses 8000 0000h – 803F FFFFh, and STRB1 is active from addresses 80400000h – FFFFFFFh (as shown in Table 7–4 for an STRB ACTIVE of 10101<sub>2</sub>).

#### 7.3.2 Page Size Operation





The TMS320C40 external interface allows you to specify (using a 31-bit address) independent page sizes for the different sets of external strobes. This capability, shown in the example in Figure 7–4, gives you a great deal of flexibility in the design of external high-speed, high-density memory systems and the use of slower external peripheral devices.

The STRB0 PAGESIZE and STRB1 PAGESIZE fields in the memory interface control register (shown in Figure 7–2 on page 7-7) work in the same manner to specify the page size for the corresponding strobe. Table 7–4 (page 7-9) illustrates the relationship between the PAGESIZE field and the bits of the address used to define the current page and the resulting page size. Page size begins at 256 words (with external address-bus bits 7 – 0 defining the address on a page, and ranges up to 2G words with external address bus bits 30 – 0 defining the location on a page. The example in Figure 7–4 shows how a pagesize field value of 10110<sub>2</sub> is translated into bits 30 – 23 defining the current page and bits 22 – 0 defining address on a page.

Changing from one page to another causes a cycle to be inserted in the external access sequence in order for external logic to reconfigure itself appropriately. The memory interface control logic keeps track of the address used for the last access for each STRB. When an access begins, the PAGE signal corresponding to the active STRB goes inactive (high) if the access is to a new page. The PAGE0 and PAGE1 signals are independent of one another, each having its own page-size logic.

At reset, the page-control logic is initialized so that the extra cycle is inserted for the first access to the two strobe interfaces.

The local memory interface has a similar set of control registers.

## 7.4 Programmable Wait States

Control wait-state generation by manipulating memory-mapped control registers associated with both the global and local interfaces. Use the STRBx WTCNT field to load an internal timer, and use the STRBx SWW field to select one of the following four modes of wait-state generation:

- External RDY
- WTCNT-generated RDY<sub>wtcnt</sub>
- Logical-AND of RDY and RDYwtcnt
- □ Logical-OR of RDY and RDY<sub>wtcnt</sub>

Application of wait states and ready are covered in Section 13.4 on page 13-27.

The four modes are used to generate the internal ready signal,  $\overline{\text{RDY}}_{int}$ , that controls accesses. As long as  $\overline{\text{RDY}}_{int} = 1$ , the current external access is extended. When  $\overline{\text{RDY}}_{int} = 0$ , the current access completes. Since the use of programmable wait states for both external interfaces is identical, only the global bus interface is described in the following paragraphs.

 $\overline{\text{RDY}}_{\text{wtcnt}}$  is an internally generated ready signal. When an external access is begun, the value in WTCNT is loaded into a counter. WTCNT may be any value from 0 through 7. The counter is decremented every H1/H3 clock cycle until it becomes 0. Once the counter is set to 0, it remains set to 0 until the next access. While the counter is nonzero,  $\overline{\text{RDY}}_{\text{wtcnt}} = 1$ . While the counter is 0,  $\overline{\text{RDY}}_{\text{wtcnt}} = 0$ .

Table 7–7 is the truth table for each value of SWW, showing the different values at  $\overline{\text{RDY}}$ ,  $\overline{\text{RDY}}_{\text{wtcnt, and }} \overline{\text{RDY}}_{\text{int}}$ .

| SWW<br>Value         | RDY              | RDYwtcnt         | <b>RDY</b> int   | RDY <sub>int</sub>                                                                                                                                                      |
|----------------------|------------------|------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00<br>00<br>00<br>00 | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | 0<br>0<br>1<br>1 | $\overline{\text{RDY}}_{int}$ is dependent only upon $\overline{\text{RDY}}$ .<br>RDY <sub>wtcnt</sub> is ignored.                                                      |
| 01<br>01<br>01<br>01 | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | 0<br>1<br>0<br>1 | RDY <sub>int</sub> is dependent only upon<br>RDY <sub>wtcnt</sub> . RDY is ignored.                                                                                     |
| 10<br>10<br>10<br>10 | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | 0<br>0<br>0<br>1 | $\overline{\text{RDY}}_{int}$ is the logical-OR (electrical-<br>AND, since these signals are low true) of $\overline{\text{RDY}}$ and $\overline{\text{RDY}}_{wtcnt}$ . |
| 11<br>11<br>11<br>11 | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | 0<br>1<br>1<br>1 | $\overline{\text{RDY}}_{int}$ is the logical-AND (electrical-OR, since these signals are low true) of RDY and $\overline{\text{RDY}}_{wtcnt}$ .                         |

 Table 7–7.
 Wait-State Generation for Each Value of SWW

### 7.5 Timing





**Note:** Dotted lines emphasize the relationships between signals that is further explained in the accompaning text below.

Throughout this chapter, no distinction is made between global and local interface signals and between STRB0 and STRB1, except for clarity.

As shown in Figure 7–5, STRB changes on the falling edge of H1, and RDY is sampled on the falling edge of H1. Throughout the other timing diagrams in this section, **the following general rules** apply to the logical timing of the parallel external interfaces:

- 1) Changes of  $R/\overline{W}$  are always framed by  $\overline{STRB}$ .
- 2) A page boundary crossing for a particular STRB results in the corresponding PAGE signal going high for one cycle.
- 3)  $R/\overline{W}$  transitions are always on an H1 rising.
- 4) STRB transitions are always on an H1 falling.
- 5) RDY is always sampled on an H1 falling.
- 6) On a read, data is always sampled on an H1 falling.
- 7) On a write, data is always driven out on H1 falling.
- 8) On a write, data is always stopped from being driven on H1 rising.
- 9) Following a read, the status, and PAGE signal change on H1 falling. The address changes on H1's falling edge.
- 10) Following a write, status and PAGE signals change on H1 falling; the address changes on H1 rising.

- 11) The fetch of an interrupt vector over an external interface is identified by the status signals for that interface (STAT or LSTAT) as a data read.
- 12) The interlocked operation status signals (LOCK and LLOCK) have the same timing as the STAT and LSTAT status signals, respectively.
- 13) Any time PAGE goes high, STRB goes high.

Figure 7–6 illustrates a read, read, write sequence. This figures assumes that all three accesses are to the same page and that they are  $\overline{\text{STRB1}}$  accesses. This timing diagram illustrates that back-to-back reads to the same page are single-cycle accesses. When the transition from a read to a write is done,  $\overline{\text{STRB}}$  goes high for one cycle in order to frame the R/W signal changing.





Figure 7–7 shows that  $\overline{\text{STRB}}$  goes high between back-to-back writes. As in Figure 7–6,  $\overline{\text{STRB}}$  goes high between a write and a read, and it frames the R/W transition.





#### Note: Strobe and Ready Further Defined

Strobe and ready are discussed from the application viewpoint in Sections 13.3 (page 13-20) and 13.4 (page 13-27) respectively.

Figure 7–8 shows that going from one page to another on back-to-back reads causes an extra cycle to be inserted, and the transition is signaled by PAGE going high for one cycle. Also, STRB1 goes high for one cycle.



Figure 7–8. Read Same Page, Read Different Page, Read Same Page Sequence

External Bus Operation

Figure 7–9 shows that on back-to-back writes, when a page switch occurs, it is signaled with PAGE going high for one cycle.







Figure 7–10. Write Same Page, Read Different Page, Write Different Page Sequence

External Bus Operation



Figure 7–11. Read Different Page, Read Different Page, Write Same Page Sequence



Figure 7–12. Write Different Page, Write Different Page, Read Same Page Sequence



Figure 7–13. Read Same Page, Write Different Page, Read Different Page Sequence

7-25

Figure 7–14 to Figure 7–18 illustrate the idle bus cycles. Idle bus cycle timing is similar to read cycle timing. The primary differences are that no data is read, STRB is held high, and RDY is ignored.





External Bus Operation







Figure 7–16. Idle, Read Different Page, Idle Sequence

Figure 7–17. Idle, Write Same Page, Idle Sequence





Figure 7–18. Write Different or Same Page, Idle, Idle Sequence

Figure 7–19 illustrates an  $\overline{\text{STRB1}}$  read followed by an  $\overline{\text{STRB0}}$  read when  $\overline{\text{STRB}}$  SWITCH = 0. This mode allows the reads to be back to back, with no cycles inserted between the reads when the back-to-back reads are activating different strobes.

Figure 7–19. Read Same Page on STRB1, Read Same Page on STRB0, Read Same Page on STRB1 Sequence When STRB SWITCH = 0



Figure 7–20 illustrates an  $\overline{\text{STRB1}}$  read followed by an  $\overline{\text{STRB0}}$  read when  $\overline{\text{STRB}}$  SWITCH = 1. In this mode, a cycle is inserted between back-to-back reads that activate different strobes. If your system memory configuration is such that bus conflicts can occur during back-to-back reads on different strobes, this mode provides one cycle between these strobe transitions to avoid the bus conflicts.





External Bus Operation

Figure 7–21 is similar to Figure 7–19 except that the second read using STRB1 is to a different page than the first read (using STRB1).

Figure 7–21. Read Same Page on STRB1, Read Same Page on STRB0, Read Different Page on STRB1 Sequence When STRB SWITCH = 0



Figure 7–22 is similar to Figure 7–20 except that the second read using STRB1 is to a different page than the first read (using STRB1).













Figure 7–25. Write With One Wait State



## 7.6 Using Enabled Signals to Control Signal Group

Figure 7–26. Using Enabled Signals to Put Signal Groups in a High-Impedance State



Figure 7–26 shows the use of an enable signal to control the corresponding signal group. For example, signal  $\overline{\text{DE}}$  controls the global external-interface signals D31–D0. The enable signals are unsynchronized inputs that turn off the corresponding output buffers. Some time period (shown by period (1) in Figure 7–26) after the enable signal goes high, the corresponding signal group goes into a high-impedance state. Then, some time period after the enable signal goes low (period (2) in Figure 7–26), the signal group comes out of a high-impedance state. Of course, if the signal group is already in a high-impedance state before the enable signal goes high, the group will come out of the high-impedance state (when the enable signal goes low ) only if the signal group is in a state requiring it to do so. For example, a data bus that was not being driven will be driven after being enabled if an access is pending for the data bus.

If you intend to use internally generated wait states, be certain that nothing inappropriate occurs when a bus is disabled. This is because it is possible to have a bus in a high-impedance state and with internally generated wait states. In this case, data that is written will not be seen externally, and data that is **read** will be whatever value is sampled on the high-impedance bus.

## 7.7 Interlocked-Instructions Definition and Bus Timing

The LOCK and LLOCK bus-lock signals are manipulated by the interlocked instructions LDII, LDFI, ,STII, STFI, and SIGI. As noted, the timing of the LOCK and LLOCK pins is the same as pins STAT(3 — 0)andLSTAT(3 — 0). Instructions LDII, LDFI, ,STII, STFI, and SIGI manipulate the bus-lock signals *only* when an external memory access is made.

Except for the manipulation of the bus-locked signals, the LDII (Load Integer Interlocked) and LDFI (Load Floating Point Interlocked) instructions are like (in all ways) the comparable LDI (Load Integer) and LDF (Load Floating Point) in terms of the operation performed and the bus operation. LDII and LDFI perform as follows:

- 1) The read cycle is begun, and the appropriate bus-lock signal is placed in the active-low state.
- 2) The read cycle is extended until the appropriate ready signal is active.
- Throughout the read cycle and to its conclusion, the bus-lock signal is kept in an active-low state until modified by a subsequent STII, STFI, or SIGI instruction.

Figure 7–27 is an example of an LDII or LDFI external access.





Except for manipulation of the bus-locked signals, the STII (Store Integer Interlocked) and STFI (Store Floating Point, Interlocked) instructions are the same as the comparable STI (Store Integer) and STF(Store Floating Point) in terms of execution and bus operation. STII and STFI operate as follows:

- The store cycle is begun, and the appropriate bus-lock signal is kept in its current state. In most cases, the interlocked store is preceded by an interlocked load, and the bus-lock signal is kept low. Otherwise, the buslock signal is high, and the interlocked store looks like a not-interlocked store.
- 2) The store cycle is extended until the appropriate ready signal is active.
- 3) When the corresponding STRB goes high at the end of the store cycle (the corresponding STAT(0–3) also changes at this time), the corresponding bus-lock signal also goes high.

An STII or STFI instruction to internal memory has no effect on the bus-lock signals.

Figure 7–28 is an example of an STII or STFI external access following the previous interlocked load (shown in Figure 7–27) and an idle cycle. This is the timing for an interlocked load/interlocked store sequence.





External Bus Operation

The SIGI instruction (signal interlocked) is similar to the LDII and LDIF instructions. The SIGI functions as follows:

- 1) The read cycle is begun, and the appropriate bus-lock signal is placed in the active-low state.
- 2) The read cycle is extended until the appropriate ready signal is active.
- 3) When the read operation is complete, the bus-lock signal is brought high with the same timing as the status signals changing.

Figure 7–29 is an example of a SIGI external access.



Figure 7–29. SIGI External Access Timing

The SIGI instruction can be used in a variety of ways. In some applications, you may wish to externally modify semaphores, perhaps with special-purpose logic. If so, SIGI can be used to perform a single-cycle interlocked access of the semaphore. The SIGI instruction can also be used simply to perform an external read and to signal that a particular point in your code has been reached.

Figure 7–30 illustrates timing for SIGI if the  $\overline{LOCK}$  signal is already low. This could happen when a SIGI follows an LDII instruction. Since  $\overline{LOCK}$  is already low, the only effect SIGI has on  $\overline{LOCK}$  is to bring it high.





External Bus Operation

## 7.8 IACK Timing

The IACK pin is affected by the IACK (interrupt acknowledge) instruction. The timing of the pin is similar to that of the LOCK pin when used by the SIGI instruction. In all respects (timing, extension with wait states, etc.) the IACK behaves like a LOCK or STAT signal. The only difference is that there is only one IACK pin.

The timing for the IACK pin is shown in Figure 7–31. Like the interlocked instructions, the IACK instruction affects IACK *only* for an external access. Figure 7–31. IACK Timing



7

External Bus Operation

## **Chapter 8**

Page

# **Communication Ports**

This chapter provides technical information for the communication ports of the TMS320C40 digital signal processor (DSP). This chapter is divided into the following major sections:

Section

|     | -                                                                         |
|-----|---------------------------------------------------------------------------|
| 8.1 | Introduction                                                              |
| 8.2 | Communication Port Features                                               |
| 8.3 | Operational Overview                                                      |
| 8.4 | Communication Port Memory Map and Registers                               |
|     | ■ Communication Port Control Register (CPCRs) 8-9                         |
|     | Input Port Register                                                       |
|     | Output Port Register                                                      |
| 8.5 | Communication Port Operation                                              |
|     | Port Arbitration Units (PAUs)                                             |
|     | Module Reset 8-14                                                         |
|     | Halting of Input and Output FIFOs                                         |
| 8.6 | Coordinating Communication Port Activity<br>with CPU and DMA Coprocessors |
| 8.7 | Communication Port Timing 8-18                                            |
|     | Timing Table and Figures 8-18                                             |
|     | Synchronizer Timing 8-31                                                  |

#### 8.1 Introduction

A parallel processor system supports optimum system performance by distributing tasks between two or more processors. This sharing of tasks between two or more TMS320C40 DSPs requires that each be able to pass the results of its work to another; passing of results enables both DSPs to continue working. Processor-to-processor communication is critical in multiprocessor-system design.

High-performance multiprocessing requires rapid transfer of data between processors. To ensure this rapid transfer of data, the TMS320C40 provides the following:

- Shared memory The 'C40 global- and local-memory interfaces enable easy construction of efficient multiprocessor-based shared memory systems.
- High-speed communication ports The 'C40's six high-speed bidirectional communication ports provide rapid processor-to-processor communication on six dedicated communication interfaces.

Although memory sharing has advantages in some applications, a shared bus seriously limits processor communication bandwidth for many applications. Using the high-speed communication ports eliminates this obstacle.

## 8.2 Communication Port Features

Key features of each TMS320C40 communication port:

- 160-megabit per second (5-megaword per second) bidirectional data transfer operations (at 40-ns cycle time)
- direct (glueless) processor-to-processor communication via eight data lines and four control lines
- buffering of all data transfers, both input and output
- automatic arbitration and handshaking to ensure communication synchronization
- synchronization between the CPU or direct-memory access (DMA) coprocessor and the six communication ports via internal interrupts and internal ready signals
- support of a wide variety of multiprocessor architectures, including rings, trees, hypercubes, bidirectional pipelines, two-dimensional Euclidean grids, hexagonal grids, and three-dimensional grids.





## 8.3 Operational Overview

The 'C40 contains six identical high-speed communication ports, each of which provides a bidirectional communication interface to an external device. Figure 8–1 shows the internal architecture of a single communication port. Each port contains the following components:

- Input FIFO channel provides an 8-level, 32-bit wide first-in-first-out (FIFO) input buffer that isolates the 'C40 from the port communication data bus and buffers data received from an external device via the bus.
- Output FIFO channel provides an 8-level, 32-bit wide FIFO output buffer that Isolates the 'C40 from the port communication data bus and buffers data to be sent to an external device via the bus.
- Port arbitration unit (PAU) handles the arbitration tasks associated with the movement of data between a 'C40 and an external device via the port communication data bus. Signals arbitrated and controlled by the PAU are shown in Figure 8–2. The PAU is described in detail in subsection 8.5.1 on page 8-12.
- Communication port control register (CPCR) allows you to control the communication port functions and data transfer operations between a 'C40 and an external device via the communication port data bus.



Figure 8–2. TMS320C40 Communication-Port Interface-Connection Example

Figure 8–2 is an example of two 'C40 DSPs connected via their communication ports. This simple communication interface consists of the following bidirectional control and data lines:

CREQx— communication port token request. A 'C40 activates this signal to request the use of the communication port data bus.

- CACKx communication port token acknowledge. A 'C40 activates this signal to relinquish ownership of the communication port data bus upon receiving a CREQx from another 'C40.
- CSTRBx communication port strobe. A sending 'C40 activates this signal to indicate that it has placed valid data on the communication port data bus.
- CRDYx communication port ready. A receiving 'C40 activates this signal to indicate that it has received data via the communication port data bus.
- CxD(7–0) communication port data bus. This bus carries data bidirectionally between two 'C40s or between a 'C40 and some other device.

Figure 8–2 shows two 'C40s connected via their communication ports. The communication port data bus, CD(7–0), and its associated control signals transfer data in either direction between 'C40s A and B. The PAUs in the two 'C40s cooperate to generate the signals and control sequences necessary to ensure orderly data transfers at the highest possible rate. To avoid conflicts on the bus, these PAUs arbitrate bus ownership, allowing only one DSP to transmit at any given time. Either of the PAUs can relinquish bus ownership when the other DSP has data to send.

Signals CREQx and CACKx handle the handshaking arbitration between the two DSPs:

- The PAU that does not own the data bus (CxD(7–0)) activates CREQx to request bus ownership.
- 2) The PAU owning the bus then activates CACKx to acknowledge the request and relinquish bus ownership to the requesting PAU.
- 3) In this manner, these signals transfer a token (or priority) from one PAU to another, and the PAU receiving the token gains ownership of the bus.

During a data transfer operation:

- 1) The CPU or DMA coprocessor of the sending DSP writes data to the output FIFO (of a communication port) via a memory-mapped address (listed in Figure 8–3).
- The communication port then places the data on CxD(7–0) and activates CSTRBx to signal the receiving communication port that the bus contains valid data.
- 3) Upon receiving the data in its input FIFO, the receiving communication port activates CRDYx to indicate that it has received the data.
- The CPU or DMA coprocessor of the receiving DSP may then read the data from the input FIFO via a memory-mapped address (listed in Figure 8–3).

Each of the input and output FIFOs can buffer a maximum of eight 32-bit words.

Buffering provided by the input and output FIFOs is very important. This buffering allows for a high degree of decoupling of computation and communication overhead. When 'C40s A and B are connected via their communication ports, the effective length of the FIFOs becomes 16 levels. This is because the output path from A to B is the concatenation of the eight levels of the output FIFO of A with the eight levels of the input FIFO of B. This also applies for the output path from B to A.

#### 8.4 Communication Port Memory Map and Registers

Figure 8–3 shows the memory map for the 'C40 communication port control registers (CPCRs) and their associated input FIFOs and output FIFOs. The lowest three addresses of each port's 16-address block are mapped to a CPCR and its associated input and output FIFOs. Fields (bits) within a CPCR are shown in Figure 8–4.

Figure 8–3. Communication Port Memory Map



Communication Ports

For example, the addresses for **communication port 0** point to (see Figure 8–3):

- □ address 00010 0040h: CPCR 0
- address 00010 0041h: input port register 0, FIFO level 0
- address 00010 0042h : output port register 0, FIFO level 7
- address range 00010 0043h-00010 004Fh: reserved.

#### 8.4.1 Communication Port Control Registers (CPCRs)

Figure 8–4 shows the format of a TMS320C40 CPCR, which contains control and status bits for its associated communication port. Table 8–1 lists the CPCR bits and fields and describes their functions. Figure 8–3 lists the memory locations of the CPCRs.

If an output port that is full is written to, the peripheral bus interface latches the word written. On subsequent accesses to the peripheral bus, a *not ready* is given. This condition goes away when an empty position appears in the output FIFO. This results in the peripheral bus input latch being transferred to the output buffer at the communication port.

#### 8.4.2 Input Port Register

This read-only register contains the contents of position 0 of the input FIFO, the oldest value in the FIFO. If this register is written to, its contents remain unchanged.

#### 8.4.3 Output Port Register

This write-only register interfaces to position 7 of the output FIFO (level 7 — the newest value in the FIFO). If this register is read, its contents remain unchanged, and the value read is undefined (garbage).



Figure 8–4. Communication Port Control Register (CPCR)

Table 8–1. CPCR Bit Functions

| Bit<br>Nos. | Field Name | Function                                                                                                                                                                                                                                                                                                   |
|-------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0—1         | Reserved   | Undefined                                                                                                                                                                                                                                                                                                  |
| 2           | PORT DIR   | <ul> <li>Port Direction. Bit determines the direction of data transfer operations for the communication port.</li> <li>PORT DIR = 0: port is in the output mode</li> <li>PORT DIR = 1: port is in the input mode.</li> </ul>                                                                               |
| 3           | ЮН         | <ul> <li>Input Channel Halt.</li> <li>Write a 1 to ICH to halt the input channel. When the input channel is halted, PORT DIR is set to zero.</li> <li>Set ICH to 0 when the input channel is to be unhalted; otherwise, the input channel cannot signal externally when it is ready to receive.</li> </ul> |
| 4           | осн        | <ul> <li>Output Channel Halt.</li> <li>Write a 1 to this bit to immediately halt the output channel.<br/>However, the communication port is still able to accept a token<br/>request from the input channel.</li> <li>Set this bit to 0 to allow the output channel to transfer data.</li> </ul>           |

(Table concluded on next page)

| Bit<br>Nos. | Field Name  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5–8         | OUTPUTLEVEL | <b>Output FIFO Level</b> . Contents of this 4-bit field:<br>• $0000_2$ (0): indicates an empty output FIFO.<br>• $0001_2$ (1): through $0111_2$ (7): indicates the number of<br>full positions in the output FIFO.<br>• $1111_2$ (15): indicates a full output FIFO<br>An empty output buffer (OUTPUT LEVEL = $0000_2$ ) causes an un-<br>latched, positive level-triggered interrupt (OCEMPTY = 1) to be<br>sent to the CPU. When the CPU or DMA coprocessor writes to<br>the empty output FIFO, OCEMPTY is set to 0, and it remains in<br>that state until the buffer is again empty. An output FIFO with one<br>or more empty levels also causes an unlatched, positive level-<br>triggered interrupt (OCRDY = 1) to be sent to the CPU and the<br>DMA coprocessor. This condition causes a READY/NOT READY<br>signal to be generated when the CPU or DMA coprocessor at-<br>tempts to write to the output FIFO.               |
| 9–12        | INPUT LEVEL | <ul> <li>Input FIFO level. Contents of this 4-bit field:</li> <li>0000<sub>2</sub> (0): indicates an empty input FIFO.</li> <li>0001<sub>2</sub> (1): through 0111<sub>2</sub> (7): indicates the number of full positions in the input FIFO.</li> <li>1111<sub>2</sub> (15): indicates a full input FIFO.</li> <li>A full input FIFO (INPUT LEVEL = 1111<sub>2</sub>) causes an unlatched, positive level-triggered interrupt (ICFULL = 1) to be sent to the CPU. When the CPU or DMA coprocessor reads from the full input FIFO, ICFULL is set to 0 and remains in that state until the FIFO is again full. An input FIFO with one or more full levels also causes an unlatched, positive level-triggered interrupt (ICRDY = 1) to be sent to the CPU and the DMA coprocessor. This condition causes a READY/NOT READY signal to be generated when the CPU or DMA coprocessor attempts to read from the output FIFO.</li> </ul> |
| 13–31       | Reserved    | Undefined                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

 Table 8–1.
 CPCR Bit Functions (Concluded)

## 8.5 Communication Port Operation

#### 8.5.1 Port Arbitration Units (PAUs)

The PAU is responsible for arbitrating between two devices to determine which device has possession of the communication port data bus at any given time. This arbitration allows the bus ownership token to be passed back and forth between two devices connected via their communication ports. During this arbitration process, the PAU is in one of the four states listed in Table 8–2.

Table 8–2.PAU State Definitions

| Summary                                                                                                                     | PAU<br>State | PAU Status                                                                                                                                                                                                                                             |
|-----------------------------------------------------------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ol> <li>PAU has token<br/>(PORT DIR = 0)</li> <li>Channel not in use</li> </ol>                                            | 00           | The PAU currently has possession of the bus owner-<br>ship token, and its associated communication chan-<br>nel is not in use. Under this condition, the PORT DIR<br>bit of the associated CPCR is 0 (output).                                         |
| <ol> <li>PAU does not have token<br/>(PORT DIR = 1).</li> <li>Token not requested by PAU<br/>(OUTPUT LEVEL = 0).</li> </ol> | 0 1          | The PAU currently does not have possession of the<br>bus ownership token and has not requested the to-<br>ken. Under this condition, the PORT DIR bit equals 1<br>(input), and the OUTPUT LEVEL field equals 0<br>(empty output FIFO).                 |
| <ol> <li>PAU has token<br/>(PORT DIR = 0).</li> <li>Channel is in use (OUTPUT<br/>LEVEL ≠ 0).</li> </ol>                    | 10           | The PAU currently has possession of the bus owner-<br>ship token, and its associated communication chan-<br>nel is in use. Under this condition, the PORT DIR bit<br>equals 0 (output), and the OUTPUT LEVEL field <i>does</i><br><i>not</i> equal 0). |
| <ol> <li>PAU does not have token<br/>(PORT DIR = 1).</li> <li>Token requested by PAU<br/>(OUTPUT LEVEL ≠ 0).</li> </ol>     | 11           | The PAU currently does not have possession of the bus ownership token but has requested the token. Under this condition, the PORT DIR bit equals 1 (input), and the OUTPUT LEVEL field <i>does not</i> equal 0.                                        |

Figure 8–5 shows the state diagram and controlling equations for the PAU state transitions. The figure also includes comments describing how the state transitions correspond to various system-level processes.

To place data on the communication port data bus, the PAU must arbitrate between:

- on-chip requests to output data on the communication channel data bus (CD(7-0))
- □ external requests received via the CREQ line

This arbitration is accomplished by passing the bus-ownership token between PAUs associated with different communication ports. The PAU containing the token has ownership of the communication port data bus. At system reset, half of the communication channels associated with a particular

**Communication Ports** 

'C40 have token ownership (communication ports 0, 1, 2), and the other half (communication ports 3, 4, 5) do not. This token passing is done via the CREQ and CACK lines.

#### *Figure 8–5. Communication Port Arbitration Unit State Diagram*



To help understand the port arbitration scheme represented in Figure 8–5, consider a data transfer operation from 'C40 A to 'C40 B. The transfer begins with PAU A in state  $00_2$  and PAU B in state  $01_2$ . If PAU A receives a request (BUSRQ = 1) from its output buffer to use the communication port data bus, it allows the output buffer to transmit one word immediately and enter state  $10_2$ . After the output buffer transmits one word, it removes the bus request (BUSRQ = 0), and PAU A returns to state  $00_2$ .

If PAU B receives a request from its output buffer to use the bus, it activates CREQ to request the token from PAU A. PAU A detects this request via the state variable TOKRQ and then activates the CACK line to transfer the bus ownership token to PAU B. PAU B then generates an internal bus acknowledge (BUSACK) to indicate that it has gained bus ownership. As a result of this token transfer operation, PAU A enters state 01<sub>2</sub>, and PAU B enters state 10<sub>2</sub>.

Because a PAU always returns to state  $00_2$  after transmitting a single word, token passing can be accomplished by 'C40s A and B alternately transmitting single words. This process provides a fair means of bus arbitration that prevents either of the output buffers (A's or B's) from being continually blocked.

If an input buffer becomes full, it will not activate  $\overline{CRDY}$  at the beginning of the transmission of the first byte that would overflow the buffer. This condition prevents data transfer operations in either direction until the situation is resolved. This can be done by reading data from the full input buffer.

#### 8.5.2 Module Reset

At system reset, the input and output channels both assume an empty state, causing all values in the input and output buffers to be lost. The CREQ, CACK, CSTRB, and CRDY signals assume an inactive (high) state and CxD(7-0) enters its tristate mode (see Figure 8–14 and Figure 8–15 on page 8-30). These signals remain in these states as long as system reset is active and, following system reset, the value placed on CxD(7-0) by the communication port that is configured for output is undefined.

At system reset, communication ports 0, 1, and 2 assume the following states:

- □ **PAU is reset to state 00**<sub>2</sub>: The PAU has possession of the bus ownership token, and the channel is not in use.
- **ICRDY = 0**: The input channel is empty and is not ready to be read from.
- **ICH = 0**: The input channel is not in its halted state.
- OCRDY = 1: The output channel is not full and is ready to be written to.
- **OCH = 0**: The output channel is not in its halted state.
- **PORT DIR = 0**: The communication port is configured for output operation.
- **INPUT LEVEL = 0**: The input channel is empty.
- **OUTPUT LEVEL = 0**: The output channel is empty.

At system reset, communication ports 3, 4, and 5 assume the following states:

- □ **PAU reset to state 01**<sub>2</sub>: The PAU does not have possession of the bus ownership token, and the token is not requested.
- **ICRDY = 0**: The input channel is empty and is not ready to be read from.

- **ICH = 0**: The input channel is not in its halted state.
- OCRDY = 1: The output channel is not full and is ready to be written to.
- **OCH = 0**: The output channel is not in its halted state.
- **PORT DIR = 1**: The communication port is configured for input operation.
- **INPUT LEVEL = 0**: The input channel is empty.
- **OUTPUT LEVEL = 0**: The output channel is empty.

Based on these reset conditions, ports 0, 1, and 2 of one DSP should be connected to ports 3, 4, and 5 of the other.

Connect Ports to Opposite Input/Output Reset Mode

At reset, ports 0, 1, and 2 are configured as output ports (PORT DIR = 0) and ports 3, 4, and 5 are configured as input ports (PORT DIR = 1). When connecting ports, connect each to a port that would be in the *opposite* direction at reset (any of 0, 1, or 2 connected to any of 3, 4, or 5).

#### 8.5.3 Halting of Input and Output FIFOs

The halting of the input and output FIFOs of a communication channel is controlled by the ICH and OCH bits (input-channel and output-channel halt bits) of the communication port control register (Figure 8–4 on page 8-10). The goal of input FIFO halting is to halt the input FIFO as soon as possible, but without the loss of data being input. A summary of the halt/unhalted conditions is provided in Table 8–3 on page 8-16.

When the input FIFO is halted, it will not signal a ready when the first incoming byte is received. At that point, the data transfer is frozen until the input FIFO is unhalted or a system reset occurs. If the input FIFO is unhalted later, the transfer will continue without any loss of data.

A communication port with an FIFO that is either halted or is full and inactive will not acknowledge a token request. This assures that the communication port's output channel remains open.

If a communication port's input FIFO is halted during a token request from the communication port to which it is connected, then the token request is acknowledged before halting.

| Halted/Unhalted                 | If the Port Has Token                                                                                                                                                                    | If the Port Does Not Have Token                                                                                                                                                                                                  |
|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input halted<br>Output unhalted | a. Won't release token<br>b. Will transmit data                                                                                                                                          | <ul> <li>a. Won't signal ready when first byte is received (transfer frozen)</li> <li>b. If halted after first byte is received, it will receive rest of word (will signal ready and then halt the input)</li> </ul>             |
| Input unhalted<br>Output halted | <ul> <li>a. Won't transmit data</li> <li>b. If halted after first byte<br/>sent, will complete word<br/>transfer and then halt the<br/>output</li> <li>c. Will release token</li> </ul>  | a. Will receive data<br>b. Will not request token                                                                                                                                                                                |
| Input halted<br>Output halted   | <ul> <li>a. Won't release token</li> <li>b. Won't transmit data</li> <li>c. If halted after first byte<br/>sent, will complete word<br/>transfer and then halt<br/>the output</li> </ul> | <ul> <li>a. Won't signal ready when first byte is received (transfer frozen)</li> <li>b. If halted after first byte received, it will receive rest of word and then halt the input</li> <li>c. Will not request token</li> </ul> |

 Table 8–3.
 Summary of Input and Output FIFO Halting

Output FIFO halting is analogous to input FIFO halting. Assume that DSP A output FIFO has OCH = 1. Then the output FIFO will be halted, based upon its current state.

- □ If communication port A *does not have the token*, the output FIFO is halted, and no request is made for the token.
- □ If communication port A has the token and is currently transmitting a word, then after the word is transmitted, no new transfers will be begun.
- □ If communication port A has the token **and** the input FIFO is not halted **and** the output FIFO is halted, then *it will transfer the token* when requested by communication port B.
- If communication port A has the token and the input FIFO is halted and the output FIFO is halted, then *it will not transfer the token* when requested by communication port B.
- When coming out of the halted state, if the communication channel still has the token, it may transmit data if necessary. If it needs the token, it will arbitrate for the token as usual.

## 8.6 Coordinating Communication Port Activity With CPU and DMA Coprocessors

The communication ports support several principle modes of synchronization:

- a ready/not ready signal that can halt CPU and DMA accesses to a communication port
- interrupts that can be used to signal the CPU and DMA

The most basic synchronization mechanism is based on a ready/not-ready signal. If the DMA or CPU attempt to read an empty input FIFO or write to a full output FIFO, a not-ready signal is returned and the DMA or CPU continues to read or write until a ready signal is received. The ready signal for the output channel is OCRDY (output channel ready), which is also an interrupt signal. The ready signal for the input channel is ICRDY (input channel ready), which is also an interrupt signal.

Interrupts are often a useful form of synchronization. Each communication port generates four different interrupt signals, as listed below (interrupt traps for these are shown in Figure 3–8 on page 3-16):

- □ ICFULL (input channel full)
- □ ICRDY (input channel ready)
- OCRDY (output channel ready)
- OCEMPTY (output channel empty)

The CPU can respond to all four of these interrupt signals. The DMA coprocessor can respond to the ICRDY and OCRDY interrupt signals.

## 8.7 Communication Port Timing

In order to accurately describe the timing of the operation of the communication ports, it is important to differentiate between the internal signals applied to the pins and the external signal seen. All signals are buffered and can be placed in a high-impedance state. See Figure 8–6.

In this discussion, internal signals applied to a buffer are identified by suffixes:

- a suffix 'a' for processor A (for example, CSTRBa)
- a suffix 'b' for processor B (for example, CSTRBb)
- a suffix 'ab' for the external signal between the two connected communication ports (for example CSTRBab and CREQab)
- a suffix followed by a single quote for the value that the processor sees by sampling the input pad (for example CPTRa')





#### 8.7.1 Timing Table and Figures

Table 8–4 and the timing figures that follow depict timing sequences in communication between TMS320C40s using their communication ports. Table 8–4 lists handshaking and communication during this intercommunication. Steps in the table are shown by numbers in the figures. Events 1 through 36 in the table compose a token request and token transfer sequence.

Figure 8–7 Token Transfer Sequence (page 8-23).

- 1) At the start, the communication port on processor A has the token and is idle.
- 2) The communication port on processor B requests the token and, after receiving the token, transfers a word, one byte at a time:
  - a) the first byte is bits 7–0
  - b) the second is bits 15-8
  - c) the third is bits 23-16
  - d) the fourth is 31–24
- 3) Once a token-requesting communication port receives the token request acknowledge, it will always transmit a word.

**Figure 8–8** End of Token Transfer Sequence Followed by a Word Transfer and the Beginning of a Second Word Transfer (page 8-24).

**Figure 8–9** End of a Word Transfer Followed by a Word Transfer (page 8-25).

**Figure 8–10** End of a Word Transfer Followed by an Idle State and Token Transfer (page 8-26).

- 1) The communication port data bus becomes idle because the output FIFO on processor B is empty.
- 2) The communication port on processor A requests the token, which is then transferred to it by the communication port on processor B.

**Figure 8–11** End of a Word Transfer Followed by an Overlapping Token Transfer (page 8-27).

- 1) As shown, the token request is received by the communication port on processor B.
- 2) The communication port on processor B sees the ready signal for the last byte of the word being transmitted.
- 3) Then the communication port releases the token.
- 4) However, the communication port will not release the token if the token request is received by the processor port B after the processor port B sees the ready signal for the last byte of the word being transmitted.
- 5) If the communication port on processor B does not have another word in the output FIFO to transmit, it will release the token.

**Figure 8–12** End of the Transfer of the Last Word in an Output FIFO Followed by an Idle Condition Until Another Word Is Available to Be Transferred (page 8-28). This begins with a word transfer followed by an idle state due to an empty output FIFO. Then a word is written to the output FIFO and transferred.

**Figure 8–13** End of a Word Transfer Followed by a Not Ready Due to the Input FIFO Becoming Full, Continuing Once the Input FIFO Is No Longer Full (page 8-29). This shows the use of the ready line to generate wait states.

- 1) In this case, a word is transferred that fills the input FIFO of the communication port of processor A.
- 2) At the beginning of transmission of the next word, the communication port on processor A does not signal that it is ready until the input FIFO is no longer full.

Table 8–4. Handshaking Events in Communication Port Intercommunication

| †Event<br>No. | Description                                                                                 |
|---------------|---------------------------------------------------------------------------------------------|
| 1             | B requests the token by bringing CREQb low.                                                 |
| 2             | A sees the token request when CREQa' goes low.                                              |
| 3             | After a type 1 delay from CREQa' falling, A acknowledges the request by bringing CACKa low. |
| 4             | B sees the acknowledgement from A when CACKb' goes low.                                     |
| 5             | A switches CRDYa from tristate to high on the first H1 rising after CACKa falling.          |
| 6             | A tristates CaD(7–0) on the first H1 rising after CACKa falling.                            |
| 7             | B switches CSTRBb from tristate to high after CACKb' falling.                               |
| 8             | B brings CREQb high after a type 1 delay from CACKb' falling.                               |
| 9             | A sees CREQa' go high.                                                                      |
| 10            | A brings CACKa high after CREQa' goes high.                                                 |
| 11            | A tristates CSTRBa after CACKa goes high.                                                   |
| 12            | A tristates CACKa after CREQa' goes high and after CACKa goes high.                         |
| 13            | A switches CREQa from tristate to high after CREQa' goes high.                              |
| 14            | B tristates CREQb after CREQb goes high.                                                    |
| 15            | B switches CACKb from tristate to high after CREQb goes high.                               |
| 16            | B tristates CRDYb on H1 rising after CREQb goes high.                                       |
| 17            | B drives the first byte onto CbD(7–0) on H1 rising after CREQb goes high.                   |
| 18            | A sees the first byte on Ca'D(7–0).                                                         |
| 19            | B brings CSTRBb low on the second H1 rising after CREQb rising.                             |
| 20            | A sees CSTRBa' go low, signaling valid data.                                                |
| 21            | A reads the data and brings CRDY a low                                                      |
| 22            | B sees CRDYb' go low, signaling data has been read,                                         |
| 23            | B drives the second byte on CbD(7–0) after $\overline{CRDY}$ b' goes low.                   |
| 24            | A sees the second byte on Ca'D(7–0).                                                        |

<sup>†</sup> Event No. corresponds to numbers in the timing diagrams that follow.

Table Continued on Next Page

**Communication Ports** 

| †Event<br>No. | Description                                                              |
|---------------|--------------------------------------------------------------------------|
| 25            | B brings CSTRBb high after CRDYb' goes low.                              |
| 26            | A sees CSTRBa' go high.                                                  |
| 27            | A brings CRDYa high after CSTRBa' goes high.                             |
| 28            | B sees CRDYb' go high.                                                   |
| 29            | B brings CSTRBb low after CRDYb' goes high.                              |
| 30            | A sees CSTRBa' go low, signaling valid data.                             |
| 31            | A reads the data and brings CRDYa low.                                   |
| 32            | B sees CRDYb' go low, signaling data has been read.                      |
| 33            | B drives the third byte on CbD(7–0) after $\overline{CRDY}$ b' goes low. |
| 34            | A sees the third byte on CaD(7–0).                                       |
| 35            | B brings CSTRBb high after CRDYb' goes low.                              |
| 36            | A sees CSTRBa' go high.                                                  |
| 37            | A brings CRDYa high after CSTRBa' goes high.                             |
| 38            | B sees CRDYb go high.                                                    |
| 39            | B brings CSTRBb low after CRDYb' goes high.                              |
| 40            | A sees CSTRBa' go low, signaling valid data.                             |
| 41            | A reads the data and brings CRDYa low.                                   |
| 42            | B sees CRDYb' go low, signaling data has been read.                      |
| 43            | B drives the fourth byte on CbD(7–0) after CRDYb' goes low.              |
| 44            | A sees the fourth byte on CaD(7–0).                                      |
| 45            | B brings CSTRBb high after CRDYb' goes low.                              |
| 46            | A sees CSTRBa' go high.                                                  |
| 47            | A brings CRDYa high after CSTRBa' goes high.                             |
| 48            | B sees CRDYb' go high.                                                   |
| 49            | B brings CSTRBb low after CRDYb' goes high.                              |
| 50            | A sees CSTRBa' go low, signaling valid data.                             |
| 51            | A reads the data and brings CRDYa low.                                   |
| 52            | B sees CRDYb' go low, signaling data has been read.                      |
| 53            | B brings CSTRBb high after CRDYb' goes low.                              |

Table 8–4. Handshaking Events in Communication Port Intercommunication (Continued)

t Event No. corresponds to numbers in the timing diagrams that follow.

Table Concluded on Next Page

| Table 8-4. | Handshaking Events in Communication Port Intercommunication | (Concluded) |
|------------|-------------------------------------------------------------|-------------|
|            |                                                             |             |

| †Event<br>No. | Description                                                                                                  |
|---------------|--------------------------------------------------------------------------------------------------------------|
| 54            | A sees CSTRBa' go high.                                                                                      |
| 55            | A brings CRDYa high after CSTRBa' goes high.                                                                 |
| 56            | B sees CRDYb' go high.                                                                                       |
| 57            | <u>B drives the first byte of the next word onto CbD(7–0) after a type 2 delay from CRDYb' falling (52).</u> |
| 58            | A sees the first byte of the next word on CaD(7–0).                                                          |
| 59            | B lowers CSTRBb after a type 2 delay from CRDYb' falling.                                                    |

t Event No. corresponds to numbers in the timing diagrams that follow.

These events are identified by event number in the following figures that describe the communication port timing.



Figure 8–7. Token Transfer Sequence



Figure 8–8. End of Token Transfer Sequence Followed by a Word Transfer and the Beginning of a

Communication Ports



Figure 8–9. End of a Word Transfer Followed by a Word Transfer



Figure 8–10. End of a Word Transfer Followed by an Idle State and Token Transfer

Communication Ports



Figure 8–11. End of a Word Transfer Followed by an Overlapping Token Transfer

NOTE: Events 1 - 25 are complements to the description in Table 8-4 on page 8-20 (i.e., if "a" is in the description, substitute "b" and vice versa, - CDa' becomes CDb'; CDb' becomes CBa').





**Communication Ports** 





Figure 8–14 illustrates the state of the signals of a communication port initialized by a reset as an output port (ports 0, 1, and 2 are configured as output ports at reset). For this case, CREQ and CRDY are in a high-impedance state. CACK and CSTRB are high, and undefined values are on CD(7-0).



Figure 8–14. Post-Reset State for an Output Port

Figure 8–15 illustrates the state of the signals of a communication port initialized by a reset as an input port (ports 3, 4, and 5 are configured as input ports at reset). For this case, CREQ and CRDY are high. CACK, CSTRB, and CD(7–0) are all in a high-impedance state.



Figure 8–15. Post-Reset State for an Input Port



### 8.7.2 Synchronizer Timing

The synchronizers used in the port arbitration unit are of two types. Typeone synchronizers cause delays that vary from 1 to 2 machine clocks from the receiving of an input on a pin until the response on output pin (ignoring analog delays). Type-two synchronizer delays range from 1.5 to 2.5 machine clocks delay.

**Type-one synchronizers** recognize an input when H1 is high, then pass it through an *H3-high/H1-high* series of delays. The response is at the start of the following H3 high.

The **minimum** type-one synchronizer **delay** of one machine clock will occur when the input changes just before H1 goes low. This delay is shown in Figure 8–16.

The **maximum** type-one synchronizer **delay** of two machine clocks will occur when the input changes just after H1 goes low. This delay is shown in Figure 8–17.









**Type-two synchronizers** first recognize an input when H1 is high, then pass it through an *H3-high/H1-high/H3-high* series of delays. The response is at the start of the following H1 high.

The **minimum** type-two synchronizer **delay** of 1.5 machine clocks occurs when the input changes just before H1 goes low. This delay is shown in Figure 8–18.

The **maximum** type-two synchronizer **delay** of 2.5 machine clocks occurs when the input changes just after H1 goes low. This delay is shown in Figure 8–19.

Using these two types of synchronizers, the synchronizer delays for the communication port signals are tabulated in Table 8–5.









 Table 8–5.
 Communication Port Signals and Synchronizer Delays

| Input Signal to Output Signal                                 | Delay<br>Type | Min. Delay<br>(clock cycles) | Max. Delay<br>(clock cycles) |
|---------------------------------------------------------------|---------------|------------------------------|------------------------------|
| CREQ↓ to CACK↓                                                | One           | 1                            | 2                            |
| CACK↓ to CREQ↑                                                | One           | 1                            | 2                            |
| $\overline{\text{CRDY}}\downarrow$ to CD valid for a new word | Two           | 1.5                          | 2.5                          |
| CACK↓ to CSTRB active                                         |               | 0.5                          | 1.5                          |
| CRDY↓ to CSTRB↓ between<br>back-to-back word transfers        | Two           | 1.5                          | 2.5                          |

## **Chapter 9**

# **DMA Coprocessor and 'C40 Timers**

This chapter provides technical information for two important TMS320C40 ('C40) functions: the direct memory access (DMA) coprocessor and the timers. Both are on-chip parts of the 'C40 digital signal processor (DSP). The first nine major sections of this chapter cover the DMA coprocessor; the last section covers the timers.

Section

| Jectio | raye                                                    |  |
|--------|---------------------------------------------------------|--|
| 9.1    | Introduction                                            |  |
| 9.2    | DMA Coprocessor Functional Description                  |  |
| 9.3    | DMA Coprocessor Registers 9-7                           |  |
|        | DMA Channel Control Register                            |  |
|        | DMA Channel Address and Index Registers                 |  |
|        | DMA Channel Transfer-Counter Register                   |  |
|        | DMA Channel Link-Pointer Register                       |  |
| 9.4    | DMA Coprocessor Channels in Unified and Split Mode 9-20 |  |
| 9.5    | DMA Coprocessor Internal Priority Schemes               |  |
| 9.6    | CPU and DMA Coprocessor Arbitration                     |  |
| 9.7    | Data Transfer Modes                                     |  |
| 9.8    | Autoinitialization                                      |  |
| 9.9    | DMA Coprocessor and Interrupts                          |  |
| 9.10   | TMS320C40 Timers                                        |  |

#### Note: DMA Programming Examples in Chapter 12

Besides the descriptions of DMA operation in this section, programming examples and explanations are provided in Chapter 12.

Dana

#### 9.1 Introduction

The primary benefit of the DMA coprocessor is to maximize sustained CPU performance by completely alleviating the CPU of burdensome I/O duties.

The DMA coprocessor supports six DMA channels that perform transfers to and from anywhere in the processor's memory map. For example, transfers can be made to/from on-chip memory, off-chip memory, and any of the six on-chip communication ports. The DMA coprocessor can automatically reinitialize its registers via linked lists stored in memory, allowing the DMA to run continuously without any intervention by the central processor unit (CPU). The DMA coprocessor can build up circular buffers in memory and perform linear and bit-reversed addressing.

The DMA coprocessor provides you with an unprecedented level of performance and flexibility for a DSP on-chip DMA coprocessor. The key features of the 'C40 DMA coprocessor are:

- six DMA channels for memory-to-memory transfers under unified mode; a special split mode supporting 12 DMA channels for communication port to/from memory transfers
- autoinitialization of DMA channel control registers, via linked lists stored in memory, at the start of a block transfer
- concurrent CPU and DMA coprocessor operation with DMA transfers at the same rate as the CPU (supported by separate internal DMA address and data buses)
- source and destination address registers with variable indices allowing stepping through matrices by row or column
- bit-reversed addressing for FFTs
- synchronization of data transfers via external and internal interrupts

DMA Coprocessors and Timers

### 9.2 DMA Coprocessor Functional Description

The TMS320C40 DMA coprocessor improves data transfer rates in systems that must perform:

- memory to memory transfers
- data transfers from an I/O device to memory
- data transfers from memory to an I/O device
- transfers of data between the on-chip communication ports and memory.
- data transfer of a single value to a block of memory for memory fill and initialization.

The DMA coprocessor can transfer data in a linear fashion or in a bit-reversed fashion for FFT applications; it can transfer matrix data in a row or column fashion.

The DMA coprocessor is a self-programming device that allows data transfers to occur *without any intervention from the CPU*. This allows data to be moved onto and off of the 'C40 without any CPU distraction. The result is a processor which has a concurrent I/O rate that can keep up with the CPU's high computation rate. The address map of the DMA coprocessor registers is shown in Figure 9–1. The major registers of the DMA coprocessor are:

- control register
- source register
- □ source index register
- destination register
- destination index register
- **u** transfer counter register
- □ link pointer register

Subsections that describe these are listed in Figure 9–2 and in Section 9.3.

The DMA coprocessor has dedicated on-chip DMA address and DMA data buses. All accesses made by the six DMA channels are arbitrated in the DMA coprocessor and take place over these dedicated buses. The DMA channels can run constantly or may be triggered by an external or internal interrupt, including an interrupt generated by the on-chip timers and communication ports.



#### Figure 9–1. DMA Coprocessor Memory Map

#### EXPLODED VIEW OF EACH CHANNEL REGISTER



- x = channel number (e.g., a 1 for all registers in channel 1, a 2 for all registers in channel 2, etc.).
- z = corresponding hexadecimal digit for channel address (e.g., subst tute an "A" for DMA channel 0; "B" for DMA channel 1, etc.).

The subsections describing these registers are listed in Figure 9–2 and in Section 9.3 on page 9-7.

| Memory<br><u>Address</u> | DMA Register                 |     | Described<br>in Section | <u>On Page</u> |
|--------------------------|------------------------------|-----|-------------------------|----------------|
| 010 00z0h                | DMA Ch. Control Register x   | T   | 9.3.1                   | 9-7            |
| 010 00z1h                | Source Address x             |     | 9.3.2                   | 9-16           |
| 010 00z2h                | Source Address Index x       |     | 9.3.2                   | 9-16           |
| 010 00z3h                | Transfer Counter x           | DMA | 9.3.3                   | 9-18           |
| 010 00z4h                | Destination Address x        | Ch. | 9.3.2                   | 9-16           |
| 010 00z5h                | Destination Address Index x  | х   | 9.3.2                   | 9-16           |
| 010 00z6h                | Link Pointer x               |     | 9.3.4                   | 9-19           |
| 010 00z7h                | Auxiliary Transfer Counter x |     | 9.3.3                   | 9-18           |
| 010 00z8h                | Auxiliary Link Pointer x     |     | 9.3.4                   | 9-19           |

| Figure 9–2. Subsections Where DMA Channel Registers Are Descri |
|----------------------------------------------------------------|
|----------------------------------------------------------------|

x = channel number (e.g., all are 1 for channel 1, all 2 for channel 2, etc.).

z = corresponding hexadecimal digit for channel address (e.g., substitute "A" for DMA channel 0; "B" for DMA channel 1, etc. See Figure 9–1).

For example, if a block of data is to be transferred from one region in memory to another region in memory:

- 1) The **source address register** of a DMA channel is loaded with the address of the source memory location.
- 2) The **destination address register** of the same DMA channel is loaded with the address of the destination memory location.
- 3) The **transfer counter** is loaded with the number of words to be transferred.
- 4) If sequential memory accesses are required, the **source address index register** as well as the **destination address index register** would be set to 1.
- 5) The appropriate modes can be set up to synchronize the DMA coprocessor reads and writes to interrupts via the DMA channel control register.
- 6) Then, the DMA coprocessor can be started via the DMA START field in the DMA channel control register.

### A DMA transfer consists of two steps:

- 1) The source data value is **read** by the DMA channel and stored in a temporary register.
- 2) The temporary register value is written to the destination address.

During every data write, the transfer counter is decremented. The block transfer can be terminated when the transfer counter goes to zero *and* the write of the last transfer is complete.

After a read by the DMA channel, the source-index register is added to the source-address register. After a write by the DMA channel, the destination-

index register is added to the destination-address register. (Both index registers contain signed values.) This allows for variable step sizes or continual reads and/or writes from/to memory. In the case of an index register equaling zero, the DMA coprocessor transfers data from/to a fixed location.

At the completion of a block transfer, the DMA coprocessor can be programmed to do several things:

- most importantly, autoinitialize itself at the start of the next block transfer. Each DMA channel can read new control register values from memory (as well as the other registers in Figure 9–2), load these values into its register block, and, according to the values loaded, begin another block transfer. This autoinitialization is done without any intervention by the CPU.
- generated an interrupt to signal that the block transfer is complete
- stop until reprogrammed

A special split-mode allows the DMA channels to have the source and destination paths split and bound to a communication port. In this mode, the **DMA-channel source path** (source-address register, source-index register, transfer-counter register, and link-pointer register) forms the *primary* split channel and is used to move data from a location in the processor's memory map to a communication port. The **DMA-channel destination path** (destination-address register, destination-index register, auxiliary transfer-counter register, and auxiliary link-pointer register) is the *auxiliary* split channel and is used to move data from the same communication port to a location in the processor's memory map.

#### Note: DMA Coprocessor Programming Examples in Chapter 12

Besides the descriptions of DMA coprocessor operation in this section, programming examples and explanations are provided in Chapter 12.

# 9.3 DMA Coprocessor Registers

The DMA coprocessor has nine registers designated as follows (for location, see Figure 9–2 on page 9-5):

- DMA channel control register (subsection 9.3.1)
- DMA-channel source-address register (subsection 9.3.2, page 9-16)
- DMA-channel source-address-index register (subsection 9.3.2, page 9-16)
- DMA-channel destination-address register (subsection 9.3.2, page 9-16)
- DMA-channel destination-address-index register (subsection 9.3.2, page 9-16)
- DMA-channel transfer-count register (subsection 9.3.3 on page 9-18)
- DMA-channel auxiliary-transfer-count register (subsection 9.3.3 on page 9-18)
- DMA-channel link-pointer register (subsection 9.3.4 on page 9-19)
- DMA-channel auxiliary-link-pointer register (subsection 9.3.4 on page 9-19)

Each DMA channel has one of each of these registers, discussed in the following paragraphs.

## 9.3.1 DMA Channel Control Register

The format of the DMA channel control register is shown in Figure 9–3. Table 9–1 defines the register bits, the bit names, and the bit functions.

At reset, the DMA channel control register is set to zero. This makes the DMA channel lower priority than the CPU, sets up the source address and destination address to be calculated via linear addressing, and configures the DMA channel in the unified mode.

When an external interrupt is used for DMA coprocessor transfer synchronization, the CPU is responsible for configuring external interrupts as edgeor level-triggered interrupts (as set in the applicable FUNCx and TYPEx bits of the interrupt flag register (subsection 3.1.10 on page 3-12)).



#### Figure 9–3. DMA Channel Control Register

- W Bit may be written.
- S Bit is shadowed during autoinitialization (no changes take affect until autoinitialization is complete.)
- A Bit is auxiliary for autoinitialization.

xx - Reserved.

| Table 9–1. | DMA Channel Control Register Bit Definitions |  |
|------------|----------------------------------------------|--|
|            |                                              |  |

| Bit<br>Nos. | Mnemonic             | Read/<br>Write | Description                                                                                                                                                                                                                       |
|-------------|----------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 — 1       | DMA PRI              | R/W            | DMA coprocessor priority. Defines the arbitration rules<br>to be used when a DMA channel and the CPU are re-<br>questing the same resource. Affects all DMA coproces-<br>sor modes. Rules listed in <b>Table 9–2, page 9-14</b> . |
| 2-3         | TRANSFER MODE        | R/W            | Defines the transfer mode used by the DMA channel. Af-<br>fects unified mode and the primary channel in split mode.<br>Bits defined in <b>Table 9–3 on page 9-14</b> .                                                            |
| 4 – 5       | AUX TRANSFER<br>MODE | R/W            | Defines the transfer mode used by the DMA channel. Affects the <i>auxiliary</i> channel in split mode only. Bits defined in <b>Table 9–3 on page 9-14</b> .                                                                       |

Table continued on next page

| Bit<br>Nos. | Mnemonic               | Read/<br>Write | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |                        |                | Determines the mode of synchronization to be used when performing data transfers, as shown in <b>Table 9–4</b> on page 9-15.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6 – 7       | SYNC MODE              | R/W            | <b>Note:</b> If a DMA channel is interrupt driven for both reads<br>and writes, <i>and</i> the interrupt for the write comes before<br>the interrupt for the read, the interrupt for the write is<br>latched by the DMA channel. After the read is complete,<br>the write can be executed.                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8           | AUTOINIT STATIC        | R/W            | <ul> <li>If bit = 0, the link pointer is incremented during autoinitialization.</li> <li>If bit = 1, the link pointer is <i>not</i> incremented (it is static) during autoinitialization.</li> <li>This affects unified mode and primary channel in split mode. It is useful to keep the auxiliary link pointer constant when autoinitializing from the on-chip communication ports or other stream-oriented devices (such as first-in first-out (FIFO) memory buffers).</li> </ul>                                                                                                                                                                                                         |
| 9           | AUX AUTOINIT<br>STATIC | R/W            | Acts the same as for the AUTOINIT STATIC mode above, except that this affects the auxiliary channel in split mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10          | AUTOINIT SYNC          | R/W            | <ul> <li>Has an effect only in the DMA coprocessor sync mode (bits 6–7 above). Affects the interrupt that is enabled by the DMA interrupt enable register (see Figure 3–4, page 3-8) used for DMA reads:</li> <li>If bit = 0, the interrupt is ignored, and the autoinitialization reads are not synchronized with any interrupt signals.</li> <li>If bit = 1, then the interrupt is recognized and is also used to synchronize the autoinitialization reads.</li> <li>This affects the unified mode and the primary channel in split mode (see bit 14, SPLIT MODE). The effect of this bit and the SYNC MODE bit in autoinitialization is summarized in Table 9–9 on page 9-37.</li> </ul> |
| 11          | AUX AUTOINIT<br>SYNC   | R/W            | Acts the same as the AUTOINIT SYNC bit above except<br>that it affects DMA-coprocessor write autoinitialization<br>sync in unified mode and the auxiliary channel in split<br>mode. The effect of this bit and the SYNC MODE bits in<br>autoinitialization is summarized in Table 9–9 on page<br>9-37.                                                                                                                                                                                                                                                                                                                                                                                      |

| Table 9–1. DMA Channel Control Register Bit Definitions (Continued) | Table 9-1. | DMA Channel Control Register Bit Definitions ( | (Continued) |
|---------------------------------------------------------------------|------------|------------------------------------------------|-------------|
|---------------------------------------------------------------------|------------|------------------------------------------------|-------------|

Table continued on next page

| Bit<br>Nos. | Mnemonic      | Read/<br>Write | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|---------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12          | READ BIT REV  | R/W            | <ul> <li>If bit = 0, the source address is modified using 32-bit linear addressing.</li> <li>If bit = 1, the source address is modified using 24-bit bit-reversed addressing.</li> <li>Affects unified mode and primary channel in split mode.</li> </ul>                                                                                                                                                                                                                                                                                                                |
| 13          | WRITE BIT REV | R/W            | <ul> <li>If bit = 0, the destination address is modified using 32-bit linear addressing.</li> <li>If bit=1, the destination address is modified using 24-bit bit–reversed addressing.</li> <li>Affects unified mode and auxiliary channel in split mode.</li> </ul>                                                                                                                                                                                                                                                                                                      |
| 14          | SPLIT MODE    | R/W            | <ul> <li>This controls the DMA coprocessor mode of operation.</li> <li>If bit = 0, DMA transfers are memory to memory. This is referred to as unified mode.</li> <li>If bit = 1, split mode is entered with the DMA split into two channels, allowing a single DMA channel to perform memory-to-communication-port and communication-port-to-memory transfers.</li> <li>The split mode may be modified by autoinitialization in unified mode or by autoinitialization by the auxiliary channel in split mode. Split mode is further described in Section 9.4.</li> </ul> |
| 15 – 17     | COM PORT      | R/W            | <ul> <li>These bits define a communication port (000<sub>2</sub> to 101<sub>2</sub>) to be used for DMA transfers.</li> <li>If SPLIT MODE = 0, then COM PORT has no affect on the operation of the DMA channel.</li> <li>If SPLIT MODE = 1, then COM PORT defines which of the six communication ports to use with the DMA channel.</li> <li>The COM PORT may be modified by autoinitialization in unified mode or by autoinitialization by the auxiliary channel in split mode.</li> </ul>                                                                              |

| Table 9-1. | DMA Channel Control Register Bit Definiti | ons (Continued) |
|------------|-------------------------------------------|-----------------|
|            |                                           |                 |

Table continued on next page

| Bit<br>Nos. | Mnemonic   | Read/<br>Write. | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18          | тсс        | R/W             | <ul> <li>Transfer counter interrupt control.</li> <li>If TCC = 1, a DMA channel interrupt pulse is sent to the CPU after the transfer counter makes a transition to zero and the write of the last transfer is complete. If enabled, the corresponding DMA interrupt (DMA INT0—INT5) occurs as shown in Figure 3–8, p. 3-16.</li> <li>If TCC = 0, a DMA channel interrupt pulse is not sent to the CPU when the transfer counter makes a transition to zero.</li> <li>Affects unified mode and the primary channel in split mode. DMA channel interrupts to the CPU are edge triggered.</li> </ul> |
| 19          | AUX TCC    | R/W             | <ul> <li>Auxiliary transfer counter interrupt control.</li> <li>If bit = 1, a DMA channel interrupt pulse is sent to the CPU after the auxiliary transfer counter makes a transition to zero and the write of the last transfer is complete. If enabled, the corresponding DMA interrupt (DMA INTO-INT5) occurs as shown in Figure 3-8, p. 3-16.</li> <li>If bit = 0, a DMA channel interrupt pulse is not sent to the CPU when the auxiliary transfer counter makes a transition to zero.</li> <li>Affects the auxiliary channel in split mode only.</li> </ul>                                   |
| 20          | TCINT FLAG | R               | Transfer counter interrupt flag.<br>This flag is set to 1 whenever the transfer counter makes<br>a transition to zero and the write of the last transfer is<br>completed. Whenever the DMA channel control register<br>is read, this flag is cleared <i>unless</i> the flag is being set by<br>the DMA in the same cycle as the read (in such case,<br>TCINT is not cleared).<br>The TCINT FLAG is affected by the unified mode and the<br>primary channel in split mode.                                                                                                                          |

| <i>Table 9–</i> 1. | DMA ( | Channel | Control | Register | Bit Defin | nitions | (Continued) |
|--------------------|-------|---------|---------|----------|-----------|---------|-------------|
|--------------------|-------|---------|---------|----------|-----------|---------|-------------|

Table continued on next page

| Bit Nos. | Mnemonic          | Read/<br>Write | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21       | AUX TCINT<br>FLAG | R              | Auxiliary transfer counter interrupt flag.<br>This flag is set to 1 whenever the auxiliary transfer<br>counter makes a transition to zero and the write of the<br>last transfer is completed. Whenever the DMA control<br>register is read, this flag is cleared <i>unless</i> the flag is be-<br>ing set by the DMA coprocessor in the same cycle as the<br>read (in such case AUX TCINT is not cleared). The AUX<br>TCINT FLAG is affected by the auxiliary channel in split<br>mode.<br><i>Since only one DMA-channel interrupt is available for a<br/>DMA channel, you can determine what event had set the<br/>interrupt by examining the</i> TCINT FLAG and the AUX<br>TCINT FLAG.                                                                                                   |
| 22– 23   | START             | R/W            | Starts and stops the DMA channel in several different<br>ways (listed in <b>Table 9–5</b> , <b>page 9-15</b> ). START affects<br>the unified mode and the primary channel in split mode.<br>If used to hold a channel in the middle of an autoinit se-<br>quence, the START and AUX START bits will hold the<br>autoinit sequence.<br>If the START or AUX START bits are being modified by<br>the DMA channel (for example, to force a halt code of<br>$10_2$ on a transfer-counter terminated block transfer) and<br>a write is being performed by an external source to the<br>DMA channel control register, <b>internal modification of</b><br><b>the START or AUX START bits by the DMA channel</b><br><b>has priority</b> . See TRANSFER MODE bits value of $01_2$ ,<br>(Table 9–3,). |
| 24 – 25  | AUX START         | R/W            | Starts and stops the DMA channel in several different ways (listed in <b>Table 9–5, page 9-15</b> ) AUX START affects the auxiliary channel in split mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 26 – 27  | STATUS            | R              | Indicates the status of the DMA channel as listed in <b>Table 9–6, page 9-16</b> . STATUS is updated in the unified mode and by the primary channel in the split mode. Updates are done every cycle.<br>The STATUS and AUX STATUS bits (Table 9–6) are used to determine the current status of the DMA channels and to determine if the DMA channel has halted or has been reset after writing to the START or AUX START bits.                                                                                                                                                                                                                                                                                                                                                             |

| Table 9–1. | DMA Channel Control Register Bit Definitions (Continued) |
|------------|----------------------------------------------------------|
| 10010 0 1. |                                                          |

Table concluded on next page

9-12

| Bit Nos. | Mnemonic         | Read/<br>Write | Description                                                                                                                                                                                                    |
|----------|------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28– 29   | AUX STATUS       | R              | Indicates the status of the DMA channel as listed in <b>Table 9–6, page 9-16</b> . STATUS is updated by the auxiliary channel in split mode only. Updates are done every cycle.                                |
| 30       | PRIORITY<br>MODE | R/W            | Priority mode of DMA channel access:<br>0 = Rotating priority as shown in Section 9.5 (on<br>page 9-22).<br>1 = Fixed priority as shown in Section 9.5.<br>This bit is available only at DMA channel 0 (zero). |
| 31       |                  |                | Reserved.                                                                                                                                                                                                      |

| DMA PRI<br>Bit Nos:<br>1 – 0 | Effect                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 0                          | DMA coprocessor access is <i>lower</i> priority than the CPU access. If the DMA channel and the CPU are requesting the same resource, then the CPU will proceed. Bits are set this way at reset.                                                                                                                                                                                                                     |
| 0 1                          | If the DMA channel and the CPU are requesting the same resource,<br>then the <i>CPU will proceed</i> . Then, <b>after</b> the CPU access is <b>complete</b> , if<br>the DMA coprocessor and CPU are <b>again</b> requesting the same re-<br>source, the <i>DMA coprocessor will proceed</i> . This priority rule provides a<br>fair arbitration scheme by alternating CPU accesses with a DMA chan-<br>nel's access. |
| 1 0                          | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1 1                          | DMA coprocessor access is <i>higher</i> priority than the CPU access. If the DMA channel and the CPU are requesting the same resource, then the DMA will proceed.                                                                                                                                                                                                                                                    |

# Table 9–2. DMA PRI Bits and CPU/DMA Arbitration Rules

| TADIE 9–3. TRANSFER MODE AND AUX TRANSFER MODE FIELD DESCRIDIO | Table 9–3. | TRANSFER MODE and AUX TRANSFER MODE Field Description |
|----------------------------------------------------------------|------------|-------------------------------------------------------|
|----------------------------------------------------------------|------------|-------------------------------------------------------|

| TRANSFER MODE<br>Bit Nos:<br>3 – 2<br>5 – 4 | Effect                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 0                                         | Transfers are <i>not</i> terminated by the transfer counter, and <i>no</i> autoinitialization is performed. TCINT (transfer counter interrupt) can still be used to cause an interrupt when the transfer counter makes a transition to zero. The DMA channel continues to run. Note that the address continues incrementing while the transfer count rolls over to its maximum value of 0FFFF FFFFh.        |
| 0 1                                         | Transfers are terminated by the transfer counter. No autoinitialization is performed. A halt code of $10_2$ is placed in the START field when transfers are completed.                                                                                                                                                                                                                                      |
| 1 0                                         | Autoinitialization is performed when the transfer counter goes to zero without waiting for CPU intervention.                                                                                                                                                                                                                                                                                                |
| 1 1                                         | The DMA channel is autoinitialized when the CPU restarts the DMA coprocessor by using the DMA register in the CPU. When the transfer counter goes to zero, operation is halted until the CPU starts the DMA coprocessor by using the START field in the DMA channel control register (bits 22–23 and 24–25, Table 9–5). A halt code of 10 <sub>2</sub> is placed in the START field by the DMA coprocessor. |

| SYNCH MODE<br>Bit Nos:<br>7 - 6 |   | Effect                                                                                                                                                                                                                                                                                                                       |
|---------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                               | 0 | No synchronization. Interrupts are ignored.                                                                                                                                                                                                                                                                                  |
| 0                               | 1 | Source synchronization. A read will not be performed until an enabled interrupt occurs.                                                                                                                                                                                                                                      |
| 1                               | 0 | Destination synchronization. A write will not be performed until an enabled interrupt occurs.                                                                                                                                                                                                                                |
| 1                               | 1 | Source and destination synchronization. A read is performed when an en-<br>abled interrupt occurs. Then, a write is performed when an enabled inter-<br>rupt occurs. The interrupts used are specified by the DMA READ and DMA<br>WRITE fields of the DMA interrupt enable (DIE) register (subsection 3.1.8<br>on page 3-8). |

# Table 9–4. SYNCH MODE Field Description

| START<br>Bit Nos:<br>23 – 22<br>25 – 24 | Effect                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 0                                     | DMA channel reset. DMA channel read or write cycles in progress are com-<br>pleted (not aborted); any data read is ignored. Any pending (not started)<br>read or write is canceled. The DMA channel is reset so that when it starts,<br>a new transaction begins; that is, a read is performed. In this start mode,<br>stopping is immediate with no other registers loaded.                                                       |
| 0 1                                     | Halts the DMA channel on the first available read or write boundary. If the read or write has begun, the read or write is completed before stopping (i.e., in the middle or at the end of a DMA channel transfer). If a read or write has not begun, no read or write is started. In this start mode, stopping is immediate with no other registers loaded).                                                                       |
| 1 0                                     | Halts the DMA channel on the first available transfer boundary. If a DMA transfer has begun, the entire transfer is completed, including both cycles (both read and write operations), before stopping. If a transfer has not begun, none is started. In this start mode, stopping is immediate with no other registers loaded.                                                                                                    |
| 1 1                                     | DMA start. Writing $11_2$ to this field starts the DMA process using the values<br>in the channel's DMA channel registers (Figure 9–1). If the DMA is in auto-<br>initialization, all DMA registers are loaded before starting the operation.<br>The DMA coprocessor starts from reset if previously reset (START bits =<br>$00_2$ ) or restarts from the previous state if previously halted (START bits =<br>$01_2$ or $10_2$ ). |

| STATUS<br>Bit Nos:<br>27 – 26<br>29 – 28 | Meaning                                                                                                                                                                                      |
|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 0                                      | DMA process is in the middle of the DMA transfer (between the write and read operations). This is the value at RESET, after a halt on a transfer boundary, <i>or</i> after a block transfer. |
| 0 1                                      | DMA process is being held (for any reason) in the middle of a DMA transfer; that is, in the middle of the read/write operation.                                                              |
| 1 0                                      | Reserved.                                                                                                                                                                                    |
| 1 1                                      | DMA channel is not being held or reset.                                                                                                                                                      |

### Table 9–6. STATUS and AUX STATUS Field Description

### 9.3.2 DMA Channel Address and Index Registers

As shown in Figure 9–4, both the DMA coprocessor source-address and destination-address registers have an associated index register. After each DMA channel read (source address) or write (destination address), the corresponding (source or destination) address generator adds the index register to the address register *and places the result in the address register*. In this way, the address register acts as accumulator because it retains the sum of itself and its index register.

#### Address Register + Index Register $\rightarrow$ Address Register

The values in these registers are undefined at reset.

Depending upon bits 12 and 13 (READ BIT REV and WRITE BIT REV) of the DMA channel control register, the addition may be either:

- linear (normal addition): READ BIT REV = 0 or WRITE BIT REV = 0, or
- □ **bit reversed** (reverse carry propagation): READ BIT REV = 1 or WRITE BIT REV = 1.

Both index values (source or destination) are *signed* values.

Figure 9–4. DMA-Coprocessor Address Generation



(a) Source Address Register Operation



(b) Destination Address Register Operation

## 9.3.3 DMA Channel Transfer-Counter and Auxiliary-Transfer-Count Registers

These registers contain the number of words to be transmitted.

Figure 9–5 shows the six transfer counters and the six auxiliary transfer counters. Each auxiliary transfer counter is used when the DMA channel is in split mode (described in Section 9.4 on page 9-20). The values in these registers are set to zero at reset.

The counters are decremented after completing the address fetch for the write portion of a transfer. The TCINT FLAG and AUX TCINT FLAG (bits 20 and 21 of the DMA channel control register, Figure 9–3 on page 9-8) are not set *until* the counter is decremented and the write of the last transfer is completed. Correspondingly, the interrupt will not be seen by the CPU interrupt controller until the transfer counter is decremented and the write of the last transfer is last transfer is completed.

The decrementer checks for equality with zero after the decrement is performed. As a result, if the count register has a value of 1, then the DMA channel can be halted after only one transfer is performed. The count is treated as an unsigned integer. *Transfers may be halted when a zero count is detected after a decrement. If the DMA coprocessor channel is not halted after the transfer reaches zero, the counter will continue decrementing below zero.* 

Figure 9–5. DMA Coprocessor Transfer-Count Registers



† x = DMA channel number (0–5)

9-18

# 9.3.4 DMA-Channel Link-Pointer and Auxiliary-Link-Pointer Registers

The link pointers specify the address from which to load the new DMA channel register values when autoinitialization is performed. When a channel has exhausted its counter, it will (if appropriately configured) use the link pointer to reload itself. Figure 9–6 illustrates the DMA coprocessor link address registers. The values in these registers are undefined at reset.

For example, under autoinitialization, the steps to load the channel registers for DMA channel 0 (as shown in Figure 9–1 on page 9-4) would be:

- 1) Get link pointer for next DMA operation. Pointer is memory address containing contents of **first** DMA channel 0 register (channel control register as shown in Figure 9–1 on page 9-4).
- 2) Bring in contents pointed to by pointer and write to address 010 00A0h (first word of DMA channel 0 registers as shown in Figure 9–1).
- 3) Increment link pointer. (Skip this step if AUTOINIT STATIC bit = 1.)
- 4) Bring in next word and write to address 010 00A1h.
- 5) Repeat until entire block of registers is loaded for DMA channel 0.





# 9.4 DMA Channels in Unified and Split Modes

Unified and split mode are depicted in separate diagrams (Figure 9–7 and Figure 9–8 on the next page). The split mode transforms one DMA channel into two DMA channels:

- Primary Channel: one dedicated to reading data from a location in the memory map (external/internal) and writing it to a communication port
- Auxiliary Channel: one dedicated to receiving data from a communication port and writing it to a location in the memory map

To accommodate the six communication ports, all six DMA channels can support this split mode (DMA channels 0–5).

The SPLIT MODE bit (bit 14 of the DMA channel control register, Figure 9–3) controls the DMA unified or split mode:

- □ For **unified mode** (Figure 9–7): Set SPLIT MODE bit to 0 (zero)
- For **split mode** (Figure 9–8): Set SPLIT MODE bit to 1

The COM PORT field of the DMA channel control register (bits 15-17 as shown in Figure 9–3) defines which communication port is used (port 0–5). Figure 9–8 shows typical operations using one communication port.

- The **transfer counter register** controls the primary channel transfers.
- □ The **auxiliary transfer counter register** controls the auxiliary channel transfers (both these registers shown in Figure 9–1, page 9-4).

DMA channel arbitration in split mode is described in subsection 9.5.3 on page 9-24.

Figure 9–7. Typical Unified Mode DMA Channel Configuration



Memory Pointed to by DMA Destination Address Register

Figure 9–8. Typical Split-Mode DMA Configuration



## 9.5 DMA Coprocessor Internal Priority Schemes

Within the DMA coprocessor, two priority schemes are used to designate which channel is serviced next:

- a fixed priority scheme with channel 0 always having the highest priority and channel 5 the lowest,
- a rotating priority scheme which places the just-serviced channel at the bottom of the priority list.

Select the desired scheme by setting bit 30 (PRIORITY MODE) of DMA channel 0's DMA channel control register (Figure 9–3 and Table 9–1 on page 9-8):

- □ PRIORITY MODE = 0 = rotating priority
- PRIORITY MODE = 1 = fixed priority

## 9.5.1 Fixed Priority Scheme

This scheme provides a fixed priority (unchanging) for each channel as follows:

> Highest priority 0 1 2 3 4 Lowest priority 5

To set up this scheme, set the PRIORITY MODE bit (bit 30) of **channel 0's** DMA channel control register to 1 (one).

### 9.5.2 Rotating Priority Scheme

In a rotating priority scheme, the last channel serviced becomes the lowest priority channel. The other channels sequentially rotate through the priority list with the next lowest channel from the just-serviced channel becoming the highest priority on the following request. The priority rotates every time the most-recent priority-granted channel completes its access. Figure 9–9 and Figure 9–11 illustrate the rotation of priority across several DMA co-processor accesses. At system reset, the channels are ordered from highest to lowest priority (0, 1, 2, 3, 4, 5).

To set up this scheme, set the PRIORITY MODE bit (bit 30) of **channel 0's** DMA control register to 0 (zero).

The DMA coprocessor handles channel arbitration on an access-by-access basis; that is, a DMA channel must contend for both the read and the write access in unified mode.

| S                                           | ervice                                  | <u>Service</u>                                                 | Service                                    | <u>Service</u>                |
|---------------------------------------------|-----------------------------------------|----------------------------------------------------------------|--------------------------------------------|-------------------------------|
| Highest priority ch.<br>Lowest priority ch. | 0<br>1<br>t2- service-<br>3<br>t4<br>t5 | 3<br>t4 ← service<br>t5<br>0<br>1<br>+2                        | t5 ← service-<br>0<br>1<br>t2<br>3<br>→ t4 | 0<br>1<br>+2<br>3<br>+4<br>+5 |
| Each s                                      |                                         | ting an access<br>ad access or write a<br>mple of a read/write |                                            |                               |

Figure 9–9. Rotating Priority Mode Example of the DMA Coprocessor

At the start of the example in Figure 9–9, channels 2, 4, and 5 are requesting service. Since channel 2 has the highest priority, it is serviced first. It then becomes the lowest priority channel. The highest priority channel then becomes channel three. On the following services, channels 4 and 5 are taken care of in a similar fashion. Each service means one read access or one write access. Figure 9–10 shows the entire read and write sequence.

### Figure 9–10. DMA Read and Write Sequence Example

1st 3rd 4th 5th 6th 7th 2nd Service Service Service **Service Service** Service Service 🕳 DMA DMA 0 **†5** 0 0 3 3 **†5** Rd Wr DMA 1 0 DMA 0 1 †**4** 1 DMA **†4** DMA Rd Wr †2~ Rd 1 †2- Wr 1 t2 **†5 †5** 3 3 3 0 **†2** 0 **†2 †4** 3 †4 3 †**4** 1 1 **†5 †4 †2 †5 †2 †4 †5** † DMA channel requesting an access

Another way to visualize the rotation of priorities is shown in Figure 9–11. This example shows the same results as in Figure 9–9. It helps to make clear the rotating nature of the priority scheme. Priority decreases from highest to lowest in a clockwise direction. The priority rotates in a counter clockwise direction with the most recently serviced channel ending up in the lowest priority position.

#### Figure 9–11. Example of a Priority Wheel



With the rotating priority scheme, any DMA channel requesting service is guaranteed to be recognized after a number of higher priority requests have been serviced. The maximum number of requests are:

- G five in unified mode
- eleven in split mode

This provides a fair means of preventing a channel from monopolizing the system.

DMA channels that are running and are not synchronized via interrupts are always requesting service.

## 9.5.3 Split Mode and DMA Channel Arbitration

When a DMA channel is running in split mode, arbitration between channels is similar to that just discussed. The split-mode DMA channel has the same priority as the unified DMA channel. The only issue is how to arbitrate between the primary split channel and the auxiliary split channel. Both split channels alternate priorities via a rotating priority scheme between each other.

When a DMA channel is in split mode and both paths are simultaneously reset via the START and AUX START bits, the output (primary) channel has priority over the input (auxiliary) channel. Both the START and AUX START bits must be written at the same time in order to achieve this reset condition.

The priority scheme for channels is slightly different than the scheme for primary and auxiliary channels within a channel:

- for channels, priority changes after a read or a write
- □ for the primary and auxiliary channels within a channel, priority changes after a complete read and write.

Figure 9–12 is an example of two channels contending for the DMA bus: channel 2 (a split channel) and channel 4. In this case:

- only channel 2 (i.e., *not* channel 4) is being run in split mode
- its primary channel is identified as 2pri
- its auxiliary channel is identified as 2aux
- □ the paths requesting service are identified with a <sup>†</sup>

In the example described below, channel 4 will do one complete transfer (read and write) for each complete transfer of either channel 2pri or 2aux.

Figure 9–12. Example of a Channel Priority Scheme in Split Mode

| Highest priority channel | 0                 |
|--------------------------|-------------------|
| • • •                    | 1                 |
|                          | ‡[†2pri           |
|                          | ‡[†2pri<br>†2aux] |
|                          | 3                 |
|                          | †4                |
| Lowest priority channel  | 5                 |

DMA channel requesting an access
Split channels requesting access
2pri = the primary split channel of channel 2
2aux = the auxiliary split channel of channel 2

The channel priority scheme in Figure 9–12 is further shown sequentially in Figure 9–13 (on the next page):

- 1) The **first** service is a request by the primary split channel of channel 2 (2pri). 2pri reads, and then channel 2 is moved to the lowest priority level, but 2pri remains the higher priority channel of channel 2.
- 2) On the **second** service, channel 4, now a higher priority than channel 2, reads its source address.
- 3) On the third service, the value read by 2pri is written to its destination address, and channel 2 is moved to the lowest priority level. Also, 2pri is moved to a lower priority than 2aux, channel 2's auxiliary channel. Note that the split channel that just completed a read retains a higher priority than the other split channel until the data is written to the destination address.

 On the **fourth** service, the value read by channel 4 in service 2 is now written to its destination address and the channel becomes the lowest priority.



Figure 9–13. Service Sequence for Split Mode Priority Example

- 5) In the **fifth** service, 2aux is read and channel 2 becomes the lowest priority.
- 6) On the **sixth** service, channel 4 is read again, and it becomes the lowest priority.
- 7) On the **seventh** and **eighth** services, the 2aux and channel 4 values that were read in services 5 and 6 are now written to their destination addresses. After the channel is written, it assumes the lowest priority.
- 8) In the **ninth** service, 2pri is read again as in the **first** service, and the read/write cycle continues as begun in the **first** service.

# 9.6 CPU and DMA Coprocessor Arbitration

The DMA coprocessor has its own internal buses for transferring data. Only when a resource conflict exists between the DMA coprocessor and the CPU is it necessary for arbitration between these two.

When the CPU and DMA coprocessor arbitrate for memory access, the memory address along with the channel's DMA PRI bits (bits 0 and 1 of the channel control register) are used in this arbitration scheme. These bits are described in Table 9–7 below. Higher priority DMA channels will be serviced before lower priority DMA channels whose requested address does not conflict with a CPU access or who have higher priority than the CPU.

The DMA PRI bits of the channel control register (of the DMA channel arbitrating with the CPU) define the arbitration rules. These rules apply whenever the CPU and the highest priority requesting channel request the same resource. Otherwise, the CPU and DMA coprocessor access may proceed in parallel.

All arbitration between the CPU and the DMA coprocessor is on an access basis; that is, the DMA coprocessor must contend for the read and the write accesses of a DMA transfer in unified mode and split mode.

| Table 9–7. | DMA PRI | Bits and CPU/DMA | Arbitration Rules |
|------------|---------|------------------|-------------------|
|------------|---------|------------------|-------------------|

| DMA PRI<br>(Bits 1–0) | Effect                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 0 <sub>2</sub>      | DMA access is lower priority than the CPU access. If the DMA channel and the CPU are requesting the same resource, then the CPU will proceed. (DMA PRI bits are set to $00_2$ at reset.)                                                                                                                                                                                     |
| 0 1 <sub>2</sub>      | If the DMA channel and the CPU are requesting the same resource,<br>then the CPU will proceed. Then, after the CPU access is complete,<br>if the DMA coprocessor and CPU are again requesting the same re-<br>source, the DMA coprocessor will proceed. This priority rule provides<br>a fair arbitration scheme by alternating CPU accesses with a DMA<br>channel's access. |
| 1 0 <sub>2</sub>      | Reserved                                                                                                                                                                                                                                                                                                                                                                     |
| 11                    | DMA access is higher priority than the CPU access. If the DMA chan-<br>nel and the CPU are requesting the same resource, <i>the DMA will pro-</i><br><i>ceed</i> .                                                                                                                                                                                                           |

# 9.7 Data Transfer Modes

Each DMA channel can operate in four types of data transfer modes. These modes differ on:

- u whether or not they use autoinitialization
- how they operate if autoinitialization is in effect or not.

Table 9–8 and the following paragraphs describe these data transfers.

| Table 9–8. Ti | RANSFER MODE | Field Descri | ption Summary |
|---------------|--------------|--------------|---------------|
|---------------|--------------|--------------|---------------|

| TRANSFER<br>MODE<br>(Bits 3-2<br>and 5-4) | Transfer Mode Summary                                                                                                                                                                                                                                                                                                                                                | Sub-<br>section |
|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 0 0 <sub>2</sub>                          | Transfers are not terminated by the transfer counter. No<br>autoinitialization is performed. The TCINT (transfer count inter-<br>rupt) bits can still be used to cause an interrupt when the transfer<br>counter makes a transition to zero. The DMA channel continues to<br>run.                                                                                    | 9.7.1           |
| 0 1 <sub>2</sub>                          | Transfers are terminated by the transfer counter.No autoinitializa-<br>tion is performed. A half code of $10_2$ is placed in the START field<br>(bits 22–23 and bits 24–25 of the DMA channel control register<br>when transfers are complete).                                                                                                                      |                 |
| 1 0 <sub>2</sub>                          | Autoinitialization is performed when the transfer counter goes to zero without waiting for CPU intervention.                                                                                                                                                                                                                                                         | 9.7.3           |
| 1 1 <sub>2</sub>                          | The DMA channel is autoinitialized when the CPU restarts the DMA coprocessor by using the DMA channel control register in the CPU. When the transfer counter goes to zero, operation is halted until the CPU starts the DMA coprocessor by using the START field in the DMA channel control register. A halt code of $10_2$ is placed in the START field by the DMA. | 9.7.4           |

## 9.7.1 Running Under TRANSFER MODE = 00<sub>2</sub>

When TRANSFER MODE =  $00_2$ , transfers are not terminated when the transfer counter goes to zero, and no autoinitialization is performed. Even though the transfer counter does not halt transfers, an interrupt can be generated on the transfer counter transition to zero, causing TCINT FLAG bit = 1. If the DMA coprocessor channel is not halted after the transfer reaches zero, the counter will continue decrementing below zero.

# 9.7.2 Running Under TRANSFER MODE = 01<sub>2</sub>

When TRANSFER MODE =  $01_2$ , transfers are terminated when the transfer counter goes to zero, and no autoinitialization is performed. When the transfer counter goes to zero, the DMA channel is halted by forcing  $10_2$  into the START or AUX START field.

# 9.7.3 Running Under TRANSFER MODE = 102

This transfer mode allows the DMA channel to take care of itself. It can run continuously, change pointers and synchronization by the autoinitialization procedure, and turn itself off.

This mode always starts with the DMA channel reset (START or AUX START a  $00_2$ ) or halted (these bits  $01_2$  or  $10_2$ ) and the transfer counter at 0. This occurs after a system reset, after the DMA channel is software reset ( $00_2$  written to the START or AUX START bits), or after the channel is halted ( $01_2$  or  $10_2$  written to these bits). The process for setting up and running a DMA channel under transfer mode  $10_2$  is summarized in Figure 9–14.

- After placing the DMA channel in the reset or halted state and the transfer counter at 0, initialize the channel for the desired operation. In this case, set the transfer mode bits to **10**<sub>2</sub>. Since the DMA channel autoinitializes itself when started under this mode, the CPU needs only to initialize the DMA channel control register and the DMA channel link pointer. The other DMA channel registers are automatically set up by the autoinitialization process. Synchronization of reads and writes is allowed.
- 2) After initializing the DMA channel, the channel can be started by writing  $11_2$  to the START or AUX START bits.
- 3) After this, the DMA channel will perform the sequence: *autoinitialize and do a block transfer*.

Figure 9–14. Running a DMA Channel Under Transfer Mode 102



# 9.7.4 Running Under TRANSFER MODE = 11<sub>2</sub>

This transfer mode, besides having all of the advantages of autoinitialization, allows the CPU to very easily coordinate its operation with the operation of the DMA channels.

Like transfer mode (see subsection 9.7.3), this mode always starts out with the DMA channel reset or halted and the transfer count = 0. This occurs after a system reset, after the DMA channel is reset by writing  $00_2$  to the START or AUX START bits in the DMA channel control register, or after the channel is halted by writing  $01_2$  or  $10_2$  to these bits. The process for setting up and running a DMA channel under transfer mode  $11_2$  is summarized in Figure 9–15.

- After placing the DMA channel in the halted or reset state and the transfer counter = 0, initialize the channel for the desired mode of operation. In this case, set the TRANSFER MODE bits to 11<sub>2</sub>. Since the DMA channel autoinitializes itself when started under this mode, the CPU needs to initialize only the DMA channel control register and the DMA channel link pointers. The other DMA channel registers are set up by the autoinitialization procedure.
- 2) After initializing the DMA channel, the channel can be started by writing 11<sub>2</sub> to the START bits.
- 3) Then, the DMA channel autoinitializes itself and does a block transfer.
- When the transfer counter goes to zero, wait for the CPU to write a 11<sub>2</sub> to the START field of the DMA channel control register.
- 5) Then repeat the sequence autoinitialize, transfer, and wait.
- 6) When the transfer count goes to zero, the DMA channel can be halted by forcing  $10_2$  into the START or AUX START field.

Figure 9–15. Running a DMA Channel Under Transfer Mode 11<sub>2</sub>



# 9.8 Autoinitialization

When the DMA channel is operating in autoinitialization mode, the link pointer register and auxiliary link pointer register are used to initialize the registers that control the operation of the DMA channel. These pointers are memory-address locations for blocks of data that are to be loaded into the DMA register file, as shown in Figure 9–1 and Figure 9–2, beginning on page 9-4.

How this autoinitialization is done depends upon the current mode of operation of the DMA channel and the mode to which it is being autoinitialized. In all cases, either the link pointer or auxiliary link pointer (used in DMA split channel mode) contains the address of a block of memory that contains the new DMA channel register values (registers shown in Figure 9–1 on page 9-4).

During autoinitialization, the link pointer may be **incremented** (AUTO INIT STATIC = 0) or **held constant** (AUTO INIT STATIC = 1). (This is bit 8 or 9 of the channel control register, Figure 9–3 on page 9-8.)

- When the link pointer is incremented, the autoinitialization values are stored in sequential memory locations, and the link pointer or auxiliary link pointer is incremented in order to access each of these locations.
- Holding the linking pointer constant is very useful when autoinitializing the DMA channel from a stream-oriented device such as the on-chip communication ports or external FIFOs.

The SPLIT MODE bit (bit 14 in Figure 9–3 on page 9-8) defines the mode under which the DMA channel is currently running. When autoinitializing the DMA coprocessor, *do not change* the SPLIT MODE bit. This bit should be changed *only when the DMA coprocessor has been reset and halted (see* DMA START *bit description, Table 9–5 on page 9-15)*.

Autoinitialization is a DMA operation to the DMA coprocessor's registers; i.e., it reads the value pointed to by the link pointer and writes the value to the DMA register over the peripheral bus on the next available cycle.

If the DMA channel is performing memory-to-memory transfers (SPLIT MODE = 0), the link pointer is used. The DMA channel registers are loaded in the following order:

- 1) DMA channel control register
- 2) Source address register
- 3) Source address index register
- 4) Transfer count register
- 5) Destination address register
- 6) Destination address index register
- 7) Link pointer register

The storage of new values for these registers in memory is illustrated in Figure 9–16.

Figure 9–16. Store New Values of DMA Channel Registers in Memory (SPLIT MODE = 0)



If the DMA channel is running in split mode (SPLIT MODE = 1), then the autoinitialize sequence depends upon which counter has terminated.

If the transfer-count register has gone to zero with SPLIT MODE=1, then the link-pointer register is used for autoinitialization. In this case, the DMA channel registers are loaded in the following order:

- 1) DMA channel control register
- 2) Source address register
- 3) Source address index register
- 4) Transfer count register
- 5) Link pointer register

The storage of the new values for these registers in memory is illustrated in Figure 9–17.





If the auxiliary counter has gone to zero with SPLIT MODE=1, then the auxiliary link pointer register is used for autoinitialization. In this case, the DMA channel registers are loaded in the following order:

- 1) DMA channel control register
- 2) Destination address register
- 3) Destination address index register
- Auxiliary transfer count register
- 5) Auxiliary link pointer register

The storage of the new values of these registers in memory is illustrated in Figure 9–18.

Figure 9–18. Store New Values of DMA Channel Registers in Memory (SPLIT MODE = 1 and Auxiliary Transfer Counter = 0)



Map of New Register Values in Memory

Usually, autoinitialization data will be stored in memory. In this case, synchronization for autoinitialization is not generally necessary. To disable the synchronization of data reads during autoinitialization, set AUTOINIT SYNCH (bits 10 and 11, DMA channel control register) to 0. In some cases, you may wish to transfer autoinitialization data in the same way as the synchronized data reads and writes. To synchronize autoinitialization based upon the interrupt identified with the READ SYNCH and WRITE SYNC fields (DIE register, page 3-8), set both the AUTOINIT SYNCH and AUX AUTOINIT SYNCH (bits 10–11 of DMA channel control register) to 1. In this way, autoinitialization will be synchronized only with the SYNCH MODE in effect.

The data reads for autoinitialization are arbitrated for by the DMA channels just like a typical DMA access. The only difference is that their synchronization is controlled by AUTOINIT SYNCH. A summary of the autoinitialization effect of the SYNC MODE and AUTOINIT SYNC bits is listed in Table 9–9 on page 9-37. This table pertains to autoinitialization only.

In **unified mode**, all of the writable control register bits are affected by autoinitialization. These bits are labeled in Figure 9–19.

In **split mode** during autoinitialization of the primary DMA channel, the writable, nonauxiliary bits may be modified, but auxiliary bits are protected (these bits are in Figure 9–20). In other words, only nonauxiliary bits are allowed to be modified by the CPU or DMA coprocessor. Also, if the auxiliary DMA channel is autoinitialized, the writable auxiliary bits may be modified, but nonauxiliary bits are protected. These bits are labeled in Figure 9–21.

In all autoinitialization modes, the shadowed bits (Figure 9–19) that are writable (W-designated bits in Figure 9–3) do not have an affect until autoinitialization is complete. Unshadowed bits affect the autoinitialization sequence. In other words, at autoinitialization, shadowed bit values will be entered last after all registers are loaded (as specified by the link pointer).

Regardless of whether the DMA channel is running in unified mode or split mode, writes by the CPU or another external source to the DMA channel control register affect all writable bits.

| Figure 9–19. | DMA Channel Control Register Bits That Can Be Modified by Autoinitialization Under |
|--------------|------------------------------------------------------------------------------------|
|              | Unified Mode                                                                       |



s — These shadowed bits do not take affect until autoinitialization is complete.

Figure 9–20. DMA Channel Control Register Bits That Can Be Modified by Autoinitialization of the Primary Channel Under Split Mode



s — These shadowed bits do not take affect until autoinitialization is complete.

xx — Write protected during primary channel autoinitialization.

9-35

| Figure 9–21. | DMA Channel Control Register Bits That Can Be Modified by Autoinitialization of the |
|--------------|-------------------------------------------------------------------------------------|
|              | Auxiliary Channel Under Split Mode                                                  |

| 31 | 30 | 29 | 28            | 27      | 26  | 25  | 24            | 23       | 22               | 21              | 20   | 19             | )  | 18 |
|----|----|----|---------------|---------|-----|-----|---------------|----------|------------------|-----------------|------|----------------|----|----|
| xx | xx | xx | xx            | xx      | xx  | AUX | START         | xx       | xx               | xx              | xx   | AUXT           | cc | xx |
|    | ,  |    | •             | '       |     | R/W | R/W           |          |                  |                 | ,    | S              |    |    |
|    |    |    | •             | 17      | 16  | 15  | 14            |          | 13               | 12              |      | 11             |    | 10 |
|    |    | •  |               | CO      |     | ٦Т  | SPL<br>MO     | JT<br>DE | WRITE<br>BIT REV | xx              |      | X AUTC<br>SYNC |    | xx |
|    |    |    | F             | R/W     | R/W | R/W | S             |          | S                |                 |      | S              |    |    |
|    |    |    | 9             |         | 8   |     | 7             | 6        | 5                | 4               | 3    | 2              | 1  | 0  |
|    |    | A  | UX AL<br>STAT | TO<br>C | xx  |     | SYNCH<br>MODE | xx       | AUX              | TRANSFE<br>MODE | B XX | xx             | xx | xx |
|    |    |    | S             | -       |     |     | S             |          | S                | S               |      |                |    |    |

s — These shadowed bits do not take affect until autoinitialization is complete.

xx — Write protected during primary channel autoinitialization.

Autoinitialization synchronization is a function of

- the SYNC MODE bits (DMA channel control register bits 6 and 7) that control synchronization of data transfers, and
- the AUTOINIT SYNC bits (DMA channel control register bits 10 and 11) that affect only autoinitialization synchronization.

If the SYNC MODE bits are not set to synchronize data transfers (i.e., if the preceding data transfer is not synchronized on interrupts), then the DMA channel autoinitialization sequence will not be synchronized either. If the SYNCH MODE bits are set to transfer data synchronously (i.e., if the preceding data transfer is synchronized), then the upcoming data channel autoinitialization sequence may be synchronized on either reads or writes or both (depending on whether the DMA coprocessor is in unified or split mode) as shown in Table 9–9. Note that for all combinations of the SYNCH MODE and AUTOINIT SYNC bits not shaded in the table, the DMA channel autoinitialization sequence is not synchronized on interrupts.

| These        |      | the DMA (<br>ol Register |              | Cause Autoinitialization<br>Synchronization To Occur On |                            |  |  |
|--------------|------|--------------------------|--------------|---------------------------------------------------------|----------------------------|--|--|
| SYNC         | MODE | AUTOIN                   | IT SYNC      |                                                         |                            |  |  |
| Bit M<br>7 – |      |                          | Nos:<br>- 10 | Unified Mode                                            | Split Mode                 |  |  |
| 0            | 0    | 0                        | 0            | no sync                                                 | no sync                    |  |  |
| 0            | 0    | 0                        | 1            | no sync                                                 | no sync                    |  |  |
| 0            | 0    | 1                        | 0            | no sync                                                 | no sync                    |  |  |
| 0            | 0    | 1                        | 1            | no sync                                                 | no sync                    |  |  |
| 0            | 1    | 0                        | 0            | no sync                                                 | no sync                    |  |  |
| 0            | 1    | 0                        | 1            | Read                                                    | Primary Ch                 |  |  |
| 0            | 1    | 1                        | 0            | no sync                                                 | no sync                    |  |  |
| 0            | 1    | 1                        | 1            | Read                                                    | Primary Ch                 |  |  |
| 1            | 0    | 0                        | 0            | no sync                                                 | no sync                    |  |  |
| 1            | 0    | 0                        | 1            | no sync                                                 | no sync                    |  |  |
| 1            | 0    | 1                        | 0            | Write                                                   | Auxiliary Cl               |  |  |
| •            | 0    | 1                        | 1            | Write                                                   | Auxiliary Cl               |  |  |
| 1            | 1    | 0                        | 0            | no sync                                                 | no sync                    |  |  |
| 1            | 1    | 0                        | 1            | Read                                                    | Primary Ch                 |  |  |
| 1            | 1    | 1                        | 0            | Write                                                   | Auxiliary Cl               |  |  |
| 1            | 1    | 1                        | 1            | Read<br>Write                                           | Primary Ch<br>Auxiliary Cl |  |  |

Table 9-9.

Autoinitialization Only

## 9.8.1 Fun With Link Pointers

For many applications, it is sufficient to autoinitialize the DMA channel with the same data each time. In this case, the new link-pointer value points to the start of the same block of data containing the new link pointer as illustrated in Figure 9–22. This particular example assumes a DMA channel that is not running in split mode.

If you want, you can get fancier. The new link pointer may point to a new set of register values as illustrated in Figure 9–23. This may be continued to any level you like. Have fun!

Figure 9–22. Self-Referential Link Pointer



DMA Coprocessors and Timers

## Figure 9–23. Referring to a New Link Pointer



# 9.9 DMA Coprocessor and Interrupts

All of the interrupts that the DMA coprocessor can see are first received by the CPU interrupt controller. If these interrupts are edge triggered, they are latched by the CPU in the appropriate interrupt-flag register. The **edge-triggered** interrupts are timer interrupts, DMA interrupts, and external interrupts that are configured as edge-triggered interrupts. Detailed information on interrupts is provided in Section 6.7 on page 6-23.

For **edge-triggered** interrupts, when the interrupt controller determines that the interrupt a DMA channel is waiting on has been latched into the interrupt flag, the CPU clears the interrupt flag and sends an interrupt pulse to the DMA channel. The DMA channel latches the interrupt locally until it can service the interrupt. At that time, the latched interrupt is cleared by the DMA coprocessor for two cycles.

Level-triggered interrupts that are generated by the communication ports and external interrupts that are configured as level-triggered interrupts are handled differently by the CPU interrupt controller. For level-triggered interrupts when the interrupt controller determines that the interrupt a DMA channel is waiting on has been received (recall that level-triggered interrupts are not latched by the CPU interrupt-controller), the CPU sends an interrupt pulse to the DMA channel. The DMA channel latches the interrupt locally until it can service the interrupt. At that time, the locally latched interrupt is cleared by the DMA coprocessor for two cycles.

The interrupt reset signal generated by the DMA coprocessor after a DMA interrupt is serviced has a higher priority over the interrupt set signal. Thus, the interrupt signal won't be continuously set even if the CPU is continuously sending the interrupt set signal. Hence, when the DMA-set priority scheme is used and a higher priority DMA channel is driven by continuous interrupt signals, the lower priority DMA channel can be serviced in between the higher priority DMA services.

The internal circuitry of the TMS320C40 guarantees proper operation between a communication port that generates level-triggered interrupts and the DMA channel that is synchronizing with those level-triggered interrupts. However, when you synchronize the DMA channels with external interrupts, it is better that these interrupt lines be configured as edge-triggered interrupts to ensure that only one interrupt is recognized.

Subsection 9.9.1 describes using interrupts to synchronize the DMA coprocessor. The interrupt mode for each channel is first selected in the DMA interrupt enable register, described with the CPU registers in subsection 3.1.8 on page 3-8.

# 9.9.1 Interrupts and Synchronization of DMA Channels

DMA channel transfers may be synchronized through the use of interrupts. The interrupt used is first selected by using the DMA interrupt enable register (subsection 3.1.8 on page 3-8).

Table 9–5 (page 9-15) describes the relationship between the SYNC MODE bits of the DMA channel control register and the four synchronization mechanisms performed:

- **U** No synchronization (SYNC MODE =  $0 0_2$ )
- **Source synchronization (SYNC MODE = 01\_2)**
- Destination synchronization (SYNC MODE =  $10_2$ )
- Source and destination synchronization (SYNC MODE =  $1 1_2$ )

If the DMA split mode is selected, bits 6 and 7 of the DMA channel control register (page 9-15) are used to control channel synchronization:

- bit 6 controls primary channel synchronization
- **bit 7** controls auxiliary channel synchronization

# No Synchronization (SYNC MODE = $0 0_2$ )

When SYNC MODE =  $00_2$ , no synchronization is performed. The DMA performs reads and writes whenever it has the priority to use the DMA bus. All interrupts are ignored and, therefore, are considered to be globally disabled. However, no bits in the DMA interrupt enable register are changed. Figure 9–24 shows the synchronization mechanism when SYNC MODE =  $00_2$ .

If an external interrupt is used for DMA interrupt synchronization, the external pin must be configured as a DMA interrupt pin (the DMA interrupt enable register is explained in subsection 3.1.8 on page 3-8).



Figure 9–24. No DMA Synchronization

# Source Synchronization (SYNC MODE = $0 1_2$ )

When SYNC MODE =  $0 1_2$ , the DMA coprocessor is synchronized to the source (see Figure 9–25). A read will not be performed until an interrupt is received by the DMA coprocessor (this also applies to the DMA primary channel in split mode as shown in Figure 9–25). Then, all DMA interrupts are disabled globally. However, no bits in the DMA interrupt enable register are changed.











# Destination Synchronization (SYNC MODE = $10_2$ )

When SYNC MODE = 1  $0_2$ , the DMA coprocessor is synchronized to the destination in unified mode. First, all interrupts are ignored until the read is complete. (Though the DMA interrupts are considered to be globally disabled, no bits in the DMA interrupt enable register are changed.) A write will not be performed until an interrupt is received by the DMA coprocessor. Figure 9–26 shows the synchronization mechanism when SYNC MODE = 1  $0_2$  in unified mode.

For the auxiliary channel in split mode, synchronization is similar to primary channel synchronization. The exception is that for the primary channel, the data is read from memory and written to a communication port output FIFO (shown on the right side of Figure 9–26). The auxiliary channel can read from a communication channel and write data to a memory address.





#### Source and Destination Synchronization (SYNC MODE = $11_2$ )

When SYNC MODE = 1 1<sub>2</sub>, a read is performed when a read interrupt is received, and a write is performed on the write interrupt. If a write interrupt is received before a read interrupt, the write interrupt is latched and the DMA data write won't be executed until the read is completed. If DMA split mode is selected, it reacts as two independent synchronizations for the primary and auxiliary channels. Source and destination synchronization when SYNC MODE = 1 1<sub>2</sub> is shown in Figure 9–27.

#### Figure 9–27. DMA Source and Destination Synchronization



DMA Coprocessors and Timers

# 9.10 TMS320C40 Timers

The TMS320C40 timer modules are general-purpose, 32-bit, timer/event counters, with two signaling modes and internal or external clocking (see Figure 9–28). The timer modules can be used to signal to the TMS320C40 or to the external world at specified intervals, or to count external events. **With an internal clock**, the timer can be used to signal an external A/D converter to start a conversion, or it can interrupt the TMS320C40 DMA controller to begin a data transfer. **With an external clock**, the timer can count external events and interrupt the CPU after a specified number of events. Available to each timer is an I/O pin that can be used as an input clock to the timer, an output clock signal, or a general-purpose I/O pin.





Three memory-mapped registers are used by each timer:

- Global-control register
- Period register
- **Counter register**

The **timer global-control register** determines the operating mode of the timer, monitors the timer status, and controls the function of the I/O pin of the timer. The **period register** specifies the timer's signaling frequency. The **timer counter register** contains the current value of the incrementing counter. The timer can be incremented on the rising edge or the falling edge of the input clock. The counter is zeroed whenever its value equals that in the period register. The pulse generator generates two types of external clock signals: pulse or clock. The memory map for the timer modules is shown in Figure 9–29.

Figure 9–29. Memory-Mapped Timer Locations

| Timer Global Control (See Table 9–10) |
|---------------------------------------|
| Reserved                              |
| Reserved                              |
| Reserved                              |
| Timer Counter (See subsection 9.10.2) |
| Reserved                              |
| Reserved                              |
| Reserved                              |
| Timer Period (See subsection 9.10.2)  |
| Reserved                              |

Register

| Peripheral Address |         |  |  |  |  |  |  |
|--------------------|---------|--|--|--|--|--|--|
| Timer 0            | Timer 1 |  |  |  |  |  |  |
| 808020h            | 808030h |  |  |  |  |  |  |
| 808021h            | 808031h |  |  |  |  |  |  |
| 808022h            | 808032h |  |  |  |  |  |  |
| 808023h            | 808033h |  |  |  |  |  |  |
| 808024h            | 808034h |  |  |  |  |  |  |
| 808025h            | 808035h |  |  |  |  |  |  |
| 808026h            | 808036h |  |  |  |  |  |  |
| 808027h            | 808037h |  |  |  |  |  |  |
| 808028h            | 808038h |  |  |  |  |  |  |
| 808029h            | 808039h |  |  |  |  |  |  |
| 80802Ah            | 80803Ah |  |  |  |  |  |  |
| 80802Bh            | 80803Bh |  |  |  |  |  |  |
| 80802Ch            | 80803Ch |  |  |  |  |  |  |
| 80802Dh            | 80803Dh |  |  |  |  |  |  |
| 80802Eh            | 80803Eh |  |  |  |  |  |  |
| 80802Fh            | 80803Fh |  |  |  |  |  |  |
|                    |         |  |  |  |  |  |  |

#### Peripheral Address

# 9.10.1 Timer Global-Control Register

The timer global control register is a 32-bit register that contains the global and port control bits for the timer module. Table 9–10 defines the register bits, names, and functions. Bits 3-0 are the port control bits; bits 11-6 are the timer global control bits. Figure 9–30 shows the 32-bit register. Note that at reset, all bits are set to 0 except for DATIN (set to the value read on TCLK).

| _ | 31 | 30 | 29 | 28 | 27    | 26  | 25     | 24  | 23  | 22  | 21 | 20 | 19    | 18     | 17  | 16   |
|---|----|----|----|----|-------|-----|--------|-----|-----|-----|----|----|-------|--------|-----|------|
|   | xx | xx | xx | xx | xx    | xx  | xx     | xx  | xx  | xx  | xx | xx | xx    | xx     | xx  | xx   |
|   |    |    |    |    |       |     |        |     |     |     |    |    |       |        |     |      |
|   | 15 | 14 | 13 | 12 | 11    | 10  | 9      | 8   | 7   | 6   | 5  | 4  | 3     | 2      | 1   | 0    |
| Γ | xx | xx | xx | xx | TSTAT | INV | CLKSRC | C/P | HLD | GO  | xx | xx | DATIN | DATOUT | ī/O | FUNC |
| • |    |    |    |    | R/W   | R/W | R/W    | R/W | R/W | R/W |    |    | R     | R/W    | R/W | R/W  |

*Figure 9–30. Timer Global-Control Register* 

NOTE: xx = reserved bit, read as 0. R = read, W = write.

|       |          | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits  | Name     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0     | FUNC     | FUNC controls the function of TCLK. If FUNC = 0, TCLK is configured as a general-<br>purpose digital I/O port. If FUNC = 1, TCLK is configured as a timer pin (see<br>Figure 9–33 for a description of the relationship between FUNC and CLKSRC).                                                                                                                                                                                                                                                                                                                                                                                           |
| 1     | Ī/O      | If FUNC = 0 and CLKSRC = 0, TCLK is configured as a general-purpose I/O pin. In this case, if $\overline{I}/O = 0$ , TCLK is configured as a general-purpose input pin. If $\overline{I}/O = 1$ , TCLK is configured as a general-purpose output pin.                                                                                                                                                                                                                                                                                                                                                                                       |
| 2     | DATOUT   | DATOUT drives TCLK when the TMS320C40 is in I/O port mode. DATOUT can also be used as an input to the timer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3     | DATIN    | Data input on TCLK or DATOUT. A write has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4 – 5 | Reserved | Read as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6     | GO       | The GO bit resets and starts the timer counter. When $GO = 1$ and the timer is not held, the counter is zeroed and begins incrementing on the next rising edge of the timer input clock. The GO bit is cleared on the same rising edge. $GO = 0$ has no effect on the timer. Table 9–11 further defines these bits.                                                                                                                                                                                                                                                                                                                         |
| 7     | HLD      | Counter hold signal. When this bit is zero, the counter is disabled and held in its current state. If the timer is driving TCLK, the state of TCLK is also held. The internal divide-by-two counter is also held so that the counter can continue where it left off when HLD is set to 1. The timer registers can be read and modified while the timer is being held. RESET has priority over HLD. Table 9–11 shows the effect of writing to GO and HLD.                                                                                                                                                                                    |
| 8     | C/P      | Clock/pulse mode control. When $C/\overline{P} = 1$ , clock mode is chosen, and the signaling of the status flag and external output will have a 50 percent duty cycle. When $C/\overline{P} = 0$ , the status flag and external output will be active for one H1 cycle during each timer period (see Figure 9–31).                                                                                                                                                                                                                                                                                                                         |
| 9     | CLKSRC   | Specifies the source of the timer clock. When CLKSRC = 1, an internal clock with fre-<br>quency equal to one-half the H1 frequency is used to increment the counter. The INV<br>bit has no effect on the internal clock source. When CLKSRC = 0, an external signal<br>from the TCLK pin can be used to increment the counter. The external clock is synchro-<br>nized internally, thus allowing external asynchronous clock sources that do not exceed<br>the specified maximum allowable external clock frequency. This will be less than<br>f(H1)/2. (See Figure 9–33 for a description of the relationship between FUNC and<br>CLKSRC). |
| 10    | INV      | Inverter control bit. If an external clock source is used and INV = 1, the external clock is inverted as it goes into the counter. If the output of the pulse generator is routed to TCLK and INV = 1, the output is inverted before it goes to TCLK (see Figure 9–28.). If INV = 0, no inversion is performed on the input or output of the timer. The INV bit has no effect, regardless of its value, when TCLK is used in I/O port mode.                                                                                                                                                                                                 |
| 11    | TSTAT    | This bit indicates the status of the timer. It tracks the output of the uninverted TCLK pin. This flag sets a CPU interrupt on a transition from 0 to 1. A write has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Table 9–10. | Timer Global-Control Register Bits Summary |
|-------------|--------------------------------------------|
|             |                                            |

Table 9–11 shows the result of a write using specified values of the GO and HLD bits in the timer global control register.

Table 9–11. Result of a Write of Specified Values of GO and HLD

| GO<br>(Bit 6) | HLD<br>(Bit 7) | Result                                                                                                                           |  |  |  |  |  |
|---------------|----------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0             | 0              | All timer operations are held. No reset is performed.                                                                            |  |  |  |  |  |
| 0             | 1              | Timer proceeds from state before write.                                                                                          |  |  |  |  |  |
| 1             | 0              | All timer operations are held, including zeroing of the counter. The GO bit is not cleared until the timer is taken out of hold. |  |  |  |  |  |
| 1             | 1              | Timer resets and starts.                                                                                                         |  |  |  |  |  |

# 9.10.2 Timer Period and Counter Registers

The 32-bit timer period register is used to specify the frequency of the timer signaling. The timer counter register is a 32-bit register that is reset to zero whenever it increments to the value of the period register. Both registers are set to 0 at reset. The locations of the registers are shown in Figure 9–29 on page 9-46.

Certain boundary conditions affect timer operation, such as a zero in the period register and an overflow of the counter. These conditions are listed as follows:

- □ When the period and counter registers are zero, the operation of the timer is dependent upon the  $C/\overline{P}$  mode selected. In pulse mode  $(C/\overline{P} = 0)$ , TSTAT is set and remains set. In clock mode  $(C/\overline{P} = 1)$ , the width of the cycle is 2/f(H1), and the external clocks are ignored.
- ❑ When the counter register is not 0 and the period register = 0, the counter will count, roll over to 0, and then behave as described immediately above (for both period and counter registers being zero).
- When the counter register is set to a value greater than the period register, the counter may overflow when being incremented. Once the counter reaches its maximum 32-bit value (0FFFF FFFFh), it simply clocks over to 0 and continues.

Writes from the peripheral bus override register updates from the counter and new status updates to the control register.

# 9.10.3 Timer Pulse Generation

The timer pulse generator (see Figure 9–28) can generate several different external signals. These signals may be inverted with the INV bit. The two basic modes are pulse mode and clock mode, as shown in Figure 9–31. In both modes, an internal clock source has a frequency of f(H1)/2, and an external clock source has a maximum frequency of less than f(H1)/2. Refer to timer timing in Chapter 14. In pulse mode (C/P = 0), the width of the pulse is 1/f(H1).

Figure 9–31. Timer Timing



(a) TSTAT and Timer Output (INV = 0) When  $C/\overline{P} = 0$  (Pulse Mode)



(b) TSTAT and Timer Output (INV = 0) When  $C/\overline{P} = 1$  (Clock Mode)

The rate of timer signaling is determined by the frequency of the timer input clock and the period register. The following equations are valid with either an internal or an external timer clock:

f(pulse mode) = f(timer clock) / period register
f(clock mode) = f(timer clock) / (2 x period register)

# 9.10.4 Timer Operation Modes

- □ The timer can receive its input and send its output in several different modes, depending upon the setting of CLKSRC, FUNC, and Ī/O. The four timer modes of operation are defined as follows:
- If CLKSRC = 1 and FUNC = 0, the timer input comes from the internal clock. The internal clock is not affected by the INV bit (bit 10 as shown in Figure 9–30 on page 9-47). In this mode, TCLK is connected to the I/O port control and can be used as a general-purpose I/O pin (see Figure 9–32). If Ī/O = 0, TCLK is configured as a general-purpose input pin whose state can be read in DATIN. DATOUT has no effect on TCLK or DATIN. If Ī/O = 1, TCLK is configured as a general-purpose output pin. DATOUT is placed on TCLK and can be read in DATIN.







- If CLKSRC = 1 and FUNC = 1, the timer input comes from the internal clock, and the timer output goes to TCLK. This value may be inverted by using INV, and the value output on TCLK can be read in DATIN.
- If CLKSRC = 0 and FUNC = 0, the timer is driven according to the status of the Ī/O bit. If Ī/O = 0, the timer input comes from TCLK. This value can be inverted by using INV, and the value of TCLK can be read in DATIN. If I/O = 1, TCLK is an output pin. Then, TCLK and the timer are both driven by DATOUT. All 0-to-1 transitions of DATOUT increment the counter. INV has no effect on DATOUT. The value of DATOUT can be read in DATIN.
- □ If CLKSRC = 0 and FUNC = 1, TCLK drives the timer. If INV = 0, all 0-to-1 transitions of TCLK increment the counter. If INV = 1, all 1-to-0 transitions of TCLK increment the counter. The value of TCLK can be read in DATIN.

Figure 9–33 shows the four timer modes of operation.

Figure 9–33. Timer Modes as Defined by CLKSRC and FUNC



DMA Coprocessors and Timers

# **Chapter 10**

# **Pipeline Operation**

Two characteristics of the TMS320C40 that contribute to its high performance are pipelining and concurrent I/O and CPU operation.

Five functional units control TMS320C40 operation: fetch, decode, read, execute, and DMA. Pipelining is the overlapping or parallel operations of the fetch, decode, read, and execute levels of a basic instruction.

By performing input/output operations, the DMA coprocessor reduces the need for the CPU to do so, thereby decreasing pipeline interference and enhancing the CPU's computational throughput.

Major topics discussed in this chapter are as follows:

| Sectio | n                           | Page  |  |  |  |  |  |  |  |  |
|--------|-----------------------------|-------|--|--|--|--|--|--|--|--|
| 10.1   | Pipeline Structure          |       |  |  |  |  |  |  |  |  |
| 10.2   | Pipeline Conflicts          | 10-4  |  |  |  |  |  |  |  |  |
|        | Branch Conflicts            | 10-4  |  |  |  |  |  |  |  |  |
|        | Register Conflicts          | 10-8  |  |  |  |  |  |  |  |  |
|        | Memory Conflicts            | 10-11 |  |  |  |  |  |  |  |  |
| 10.3   | Resolving Memory Conflicts  | 10-18 |  |  |  |  |  |  |  |  |
| 10.4   | Clocking of Memory Accesses | 10-20 |  |  |  |  |  |  |  |  |
|        | Program Fetches             | 10-20 |  |  |  |  |  |  |  |  |
|        | Data Loads and Stores       | 10-21 |  |  |  |  |  |  |  |  |

# **10.1 Pipeline Structure**

The five major units of the TMS320C40 pipeline structure and their functions are as follows:

| Fetch Unit (F)   | Fetches the instruction words from memory and updates the program counter (PC).                                                                                                                                     |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Decode Unit (D)  | Decodes the instruction word and performs<br>address generation. Also controls any<br>modification of the auxiliary registers and<br>the stack pointer.                                                             |
| Read Unit (R)    | If required, reads the operands from memory.                                                                                                                                                                        |
| Execute Unit (E) | If required, reads the operands from the<br>register file, performs the necessary opera-<br>tion, and writes results to the register file. If<br>required, results of previous operations are<br>written to memory. |
| <b></b>          |                                                                                                                                                                                                                     |

#### **DMA Coprocessor (DMA)** Reads and writes memory.

A basic instruction has four levels: fetch, decode, read, and execute. Figure 10–1 illustrates these four levels of the pipeline structure. The levels are indexed according to instruction and execution cycle. The perfect overlap in the pipeline, where all four units operate in parallel, occurs at cycle (*m*). Those levels about to be executed are at m + 1, and those just executed are at m-1. The TMS320C40 pipeline control allows a high-speed execution rate of one execution per cycle. It also manages pipeline conflicts so that they are transparent to the user. You do not need to take any special precautions to guarantee correct operation.

| Fiaure 10-1. | TMS320C40 Pipeline Structure |
|--------------|------------------------------|
|--------------|------------------------------|

| CYCLE | F |  | D | I | R | l | Ε | ľ               |
|-------|---|--|---|---|---|---|---|-----------------|
| m–3   | Ŵ |  | - |   | - |   | - |                 |
| m–2   | х |  | W |   |   |   | - |                 |
| m—1   | Y |  | х |   | W |   | _ |                 |
| m     | Z |  | Y |   | x |   | W | Perfect overlap |
| m+1   | - |  | Z |   | Y |   | x |                 |
| m+2   | - |  | - |   | Z |   | Y |                 |
| m+3   | _ |  | - |   | _ |   | Z |                 |

Notes: 1) W, X, Y, and Z represent instructions.

2) F, D, R, E = fetch, decode, read, and execute, respectively.

Priorities from highest to lowest have been assigned to each of the functional units as follows:

- DMA (if configured as highest priority)
- Execute
- Read
- Decode
- Fetch
- DMA (if configured as lowest priority).

When the processing of an instruction is ready to pass to the next higher 10 nineline level, but that level is not next high pipeline level, but that level is not ready to accept a new input, a pipeline conflict occurs. In this case, the lower priority unit waits until the higher priority unit completes its currently executing function.

# **10.2 Pipeline Conflicts**

The pipeline conflicts of the TMS320C40 can be grouped into the following main categories:

| Branch Conflicts   | Involve most of those instructions or operations that read and/or modify the PC.                                    |
|--------------------|---------------------------------------------------------------------------------------------------------------------|
| Register Conflicts | Involve delays that can occur when reading from<br>or writing to registers that are used for address<br>generation. |
| Memory Conflicts   | Occur when the internal units of the TMS320C40 compete for memory resources.                                        |

Each of these three types is discussed in the following sections. Examples are included. Note in these examples, when data is refetched or an operation is repeated, the symbol representing the stage of the pipeline is appended with a number. For example, if a fetch is performed again, the initial fetch is labeled F1 and the refetch is labeled F2. When an access is detained multiple cycles because of a not ready, the symbols RDY and RDY are used to indicate not ready and ready, respectively.

# 10.2.1 Branch Conflicts

#### 10.2.1.1 Standard Branches

The first class of pipeline conflicts occurs with standard (nondelayed) branches, i.e., BR, Bcond, DBcond, CALL, IDLE, RPTB, RPTS, RETIcond, RETScond, interrupts, and reset. Conflicts arise with these instructions and operations because during their execution, the pipeline is used only for the completion of the operation; other information fetched into the pipeline is discarded or refetched, or the pipeline is inactive. This is referred to as flushing the pipeline. Flushing the pipeline is necessary in these cases to guarantee that portions of succeeding instructions do not inadvertently get partially executed. TRAPcond and CALLcond are classified differently from the other types of branches and are considered later.

Example 10–1 shows the code and pipeline operation for a standard branch. Note that one dummy fetch is performed (F1), and then after the branch address is available, a new fetch (F2) is performed. This dummy fetch affects the cache.



|       | BR<br>MPYF<br>ADD<br>SUBF<br>AND | THREE | ; Unconditional branch<br>; Not executed<br>; Not executed<br>; Not executed<br>; Not executed |
|-------|----------------------------------|-------|------------------------------------------------------------------------------------------------|
|       | •                                |       |                                                                                                |
| THREE | OR<br>STI                        |       | ;Fetched after BR is fetched                                                                   |

#### **PIPELINE OPERATION**



RPTS and RPTB both flush the pipeline, allowing the RS, RE, and RC registers to be loaded at the proper time relative to the flow of the pipeline. If these registers are loaded without the use of RPTS or RPTB, no flushing of the 10 pipeline occurs. If none of the repeat modes are being used, RS, RE, and RC may be used as general-purpose 32-bit registers without any pipeline conflicts occurring. In cases such as the nesting of RPTB due to nested interrupts, it may be necessary to load and store these registers directly while using the repeat modes. Since up to four instructions can be fetched before entering the repeat mode, loads should be followed by a branch to flush the pipeline. If the RC is changing when an instruction is loading it, the direct load takes priority over the modification made by the repeat mode logic.

# 10.2.1.2 Delayed Branches

Delayed branches are implemented to guarantee the fetching of the next three instructions. The delayed branches include BRD, B*cond*D, and DB*cond*D. Example 10–2 shows the code and pipeline operation for a delayed branch.

#### Example 10–2. Delayed Branch

| THREE   | BRD<br>MPYF<br>ADD<br>SUBF<br>AND<br>MPYF | 1 | FHREE |     | ;<br>;<br>; | : E:<br>: E:<br>: No | xecut<br>xecut<br>xecut<br>ot exe | ed<br>ed<br>ec | uted |           | branch             |   |
|---------|-------------------------------------------|---|-------|-----|-------------|----------------------|-----------------------------------|----------------|------|-----------|--------------------|---|
|         |                                           |   | P     | IPI | ELINE       | O                    | PERAT                             | 01             | N    |           |                    |   |
| PC      |                                           | I | F     |     | D           | I                    | R                                 |                | Е    |           |                    |   |
| n       |                                           |   | BRD   |     | -           |                      | -                                 |                | -    |           |                    |   |
| n+1     |                                           |   | MPYF  |     | BRD         |                      | -                                 |                | _    | No exe    | cute dela          | y |
| n+2     |                                           |   | ADDF  |     | MPYF        |                      | BRD                               |                | -    |           |                    |   |
| n+3     |                                           |   | SUBF  |     | ADDF        |                      | MPYF                              |                | BRD  | <br>THREE | $E \rightarrow PC$ |   |
| THREE - |                                           |   | MPYF  |     | SUBF        |                      | ADDF                              |                | MPYF |           |                    |   |

# 10.2.1.3 Delayed Branches With Annul Option

In addition to standard and delayed branches, the 'C40 supports delayed branches with an annulling option. These instructions include BcondAT (branch conditional, annul if true) and BcondAF(branch conditional, annul if false). The status of the condition (whether the cond specifed is found true or false) controls whether or not a branch is performed (as in a delayed branch). The annulling operation cancels the effect of any operation performed in the execute phase of the three instructions following the BcondAT or BcondAF.

- □ If the condition is true, **B**condAT annuls the effect of any operation performed in the execute phase of the three instructions that follow.
- If the condition is false, **B**condAF annuls the effect of any operation performed in the execute phase of the three instructions that follow.

Example 10–3 uses both BcondAT and BcondAF.

| top:    | LDI<br>BNEGAT<br>ADDI<br>MPYF<br>NOT<br>SUBF | *AR1,R0<br>bottom<br>*++AR2,R3 | <pre>; If negative, branch and<br/>; annul the execute phase<br/>; of ADDI, MPYF, and NOT.<br/>; Otherwise, don't annul and<br/>; continue with SUBF.</pre>                                |
|---------|----------------------------------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bottom: | SUBI<br>BNNAF<br>ADDI<br>MPYF<br>NOT<br>XOR  | 1,R0<br>top<br>*++AR2,R3       | <pre>; If not negative, branch and<br/>; do not annul the execute<br/>; phase of ADDI, MPYF, and<br/>; NOT. Otherwise, annul ADDI,<br/>; MPYF, and NOT, and continue<br/>; with XOR.</pre> |

At the start of Example 10-3, if the result of the load is negative (a true condition), the BNEGAT instruction causes a branch and also an annulment of the execute phase of the three instructions that follow it. As a result, the execute phase of the ADDI instruction does not occur, and register R3 is not 10 updated by addition. However, the incrementing of AR2 and the reading of the data at the corresponding address do occur because these operatons are in the decode and read phases of the pipeline, respectively, and thus are not annullable.

In short, operations that are annullable are:

- all writes to the register file that occur in the execute phase (ADDs, LDs, etc., but do not include LDA, LDPK, etc.).
- all stores to memory.

#### **10.2.2 Register Conflicts**

Register conflicts involve the reading or writing of registers used for addressing purposes. These registers are AR0–AR7, IR0, IR1, BK, DP, and SP. These conflicts occur when the pertinent register is not ready to be used. If an instruction writes to one of these registers, the decode unit cannot use that same register until the write is complete, i.e., until instruction execution is completed.

In Example 10–4, an auxiliary register is loaded, and the same auxiliary register is used on the next instruction. Since the decode stage needs the result of the write to the auxiliary register, the decode of this second instruction is delayed two cycles. Every time the decode is delayed, a refetch of the program word is performed; i.e., the first fetch of ADDF is at F1, followed by F2 and F3 (the final fetch). Since these are actual refetches, they can cause not only conflicts with the DMA controller but also cache hits and misses. (If a different AR register was used in the MPYF instruction (than was used in the LDI instruction), *no delay would occur*.)



Example 10-4. Write to an AR Followed by an AR for Address Generation

The case for reads of these registers is similar to the case for writes. If an instruction must read registers AR0–AR7 or SP, the use of those particular registers by the decode for the following instruction is delayed until the read is complete. The registers are read at the start of the execute cycle and therefore require only a one-cycle delay of the following decode. For four registers (IR0, IR1, BK, or DP), no delay is incurred upon a read.

In Example 10–5, two auxiliary registers are added together with the result going to an extended-precision register. The next instruction uses one of the same auxiliary registers as an address register. If the MPYF instruction used an AR register other than AR0 or AR2, *no delay would occur*.

#### Example 10–5. A Read of ARs Followed by ARs for Address Generation

ADDI AR0,AR2,R1 ; AR0 + AR2 → R1 NEXT MPYF \*++AR2,R0 ; Decode delayed 1 cycle ADDF FLOAT

#### **PIPELINE OPERATION**



The DBR (decrement and branch) instruction's use of auxiliary registers for loop counters is treated the same as if the use were for addressing. Therefore, the operation shown in the two previous examples can also occur for this instruction.

# **10.2.3 Memory Conflicts**

Memory conflicts can occur when the memory bandwidth of a physical memory space is exceeded. For example, RAM blocks 0 and 1 and the ROM block can support only two accesses every cycle. The external interface can support only one access per cycle. Some conditions under which memory conflicts can be avoided are discussed in Section 10.3.

Memory pipeline conflicts consist of the following four types:

| Program Wait             | A program fetch is prevented from begin-<br>ning.                                  |
|--------------------------|------------------------------------------------------------------------------------|
| Program Fetch Incomplete | A program fetch has begun but is not yet complete.                                 |
| Execute Only             | An instruction sequence requires three CPU data accesses in a single cycle.        |
| Hold Everything          | A primary or expansion bus operation must complete before another one can proceed. |

These four types of memory conflicts are illustrated in examples and discussed in the paragraphs that follow.

### **Program Wait**

Two conditions can prevent the program fetch from beginning:

- The start of a CPU data access when
  - Two CPU data accesses are made to an internal RAM or ROM block, and a program fetch from the same block is necessary.
  - One of the external ports is starting a CPU data access, and a program fetch from the same port is necessary.
- A multicycle CPU data access or DMA data access over the external bus is needed.

Example 10–6 illustrates a program wait until a CPU data access completes. In this case, \*AR0 and \*AR1 are both pointing to data in RAM block 0, and the MPYF instruction will be fetched from RAM block 0. This results in the conflict shown. Since no more than two accesses can be made to RAM block 0 in a single cycle, the program fetch cannot begin and must wait until the CPU data accesses are complete.

Example 10–6. Program Wait Until CPU Data Access Completes

ADDF3 \*AR0,\*AR1,R0 FIX MPYF ADDF3 NEGB





Example 10–7 shows a program wait due to a multicycle data-data access or a multicycle DMA access. The ADDF, MPYF, and SUBF are fetched from some portion in memory other than the external port the DMA requires. The DMA begins a multicycle access. The program fetch corresponding to the CALL is made to the same external port the DMA is using.

Even if the DMA was configured as the lowest priority, **a multicycle access cannot be aborted**. The program fetch must therefore wait until the DMA access completes.

Example 10–7. Program Wait Due to Multicycle Access



#### **PIPELINE OPERATION**

### Program Fetch Incomplete

A program fetch incomplete occurs when a program fetch takes more than one cycle to complete due to wait states. In Example 10–8, the MPYF and ADDF are fetched from memory that supports single-cycle accesses. The SUBF is fetched from memory requiring one wait state. One example that demonstrates this conflict is a fetch across a bank boundary on the primary port.





#### **Execute Only**

The Execute Only type of memory pipeline conflict occurs when a sequence of instructions requires three CPU data accesses in a single cycle. There are two cases in which this occurs:

- An instruction performs a store and is followed by an instruction that does two memory reads.
- An instruction performs two stores and is followed by an instruction that performs at least one memory read.

The first case is shown in Example 10–9. Since this sequence requires three data memory accesses and only two are available, only the execute phase of the pipeline is allowed to proceed. The dual reads required by the LDF || LDF is delayed one cycle. Note that a refetch of the next instruction can occur.

#### Example 10–9. Single Store Followed by Two Reads

| STF | R0,*AR1 | ; R0 $\rightarrow$ *AR1                  |
|-----|---------|------------------------------------------|
| LDF | *AR2,R1 | ; *AR2 $\rightarrow$ R1 in parallel with |
| LDF | *AR3,R2 | ; *AR3 $\rightarrow$ R2                  |

#### **PIPELINE OPERATION**

| PC  | F         | D         | R         | E              |                               |
|-----|-----------|-----------|-----------|----------------|-------------------------------|
| n   | STF       | -         | -         | _              |                               |
| n+1 | ldf   ldf | STF       | -         | -              |                               |
| n+2 | W         | ldf   ldf | STF       |                | <u>Write</u> must<br>complete |
| n+3 | x         | W         | ldf   ldf | STF R0,*AR1    | before the<br>2 reads can     |
| n+4 | x         | W         | ldf   ldf | (nop)          | complete.                     |
| n+4 | Y         | x         | W         | LDF   LDF *AR2 | ,R1 and *AR3,R2               |

Example 10–10 shows a parallel store followed by a single load or read. Since the two parallel stores are required, the next CPU data memory read must wait a cycle before beginning. One program memory refetch may occur.

# Example 10–10. Parallel Store Followed by Single Read

STF R0,\*AR0 ; R0  $\rightarrow$  \*AR0 in parallel with || STF R2,\*AR1 ; R2  $\rightarrow$  \*AR1 ADDF @SUM,R1 ; R1 + @SUM  $\rightarrow$  R1 IACK ASH

#### **PIPELINE OPERATION**



#### Hold Everything

There are three types of Hold Everything memory pipeline conflicts:

- A CPU data load or store cannot be performed because an external port is busy.
- An external load takes more than one cycle.
- Conditional calls and traps.

The first type of Hold Everything conflict occurs when one of the external ports is busy because of access that has started but is not complete. In Example 10–11, the first store is a two-cycle store. The CPU writes the data to an external port. The port control then takes two cycles to complete the data-data write. The LDF is a read over the same external port. Since the store is not complete, the CPU continues to attempt LDF until the port is available.



| STF | RO,@DMA1 |
|-----|----------|
| LDF | @DMA2,RO |

#### **PIPELINE OPERATION**

| PC  | ł | F   | I | D   | I | R     | ۱ | Е     | 1                                              |
|-----|---|-----|---|-----|---|-------|---|-------|------------------------------------------------|
| n   |   | STF |   | _   |   | -     |   | -     |                                                |
| n+1 |   | LDF |   | STF |   | _     |   | -     |                                                |
| n+2 |   | W   |   | LDF |   | STF   |   | -     |                                                |
| n+2 |   | W   |   | LDF |   | (nop) |   | STF   | $\overline{\uparrow}$                          |
| n+2 |   | W   |   | LDF |   | (nop) |   | (nop) | 2-cycle external bus $\downarrow$ write access |
| n+3 |   | x   |   | W   |   | LDF   |   | (nop) |                                                |
| n+4 |   | Y   |   | x   |   | W     |   | LDF   |                                                |

The second type of Hold Everything conflict involves multicycle data reads. The read has begun and continues until completed. In Example 10–12, the LDF is performed from an external memory that requires several cycles to complete.



LDF @DMA,R0

#### **PIPELINE OPERATION**



The final type of Hold Everything conflict deals with conditional calls and traps, which are different from the other branch instructions. Whereas the other branch instructions are conditional loads, the conditional calls and traps are conditional stores, which take one more cycle than a conditional branch (see Example 10–13). The added cycle is used to push the return address after the call condition is evaluated.

Example 10–13. Conditional Calls and Traps

PIPELINE OPERATION



# **10.3 Resolving Memory Conflicts**

If program fetches and data accesses are performed in such a manner that the resources being used cannot provide the necessary bandwidth, the program fetch is delayed until the data access is complete. Certain configurations of program fetch and data accesses yield conditions under which the TMS320C40 can achieve maximum throughput.

Table 10–1 shows how many accesses can be performed from the different memory spaces when it is necessary to do a program fetch and a single data access, and still achieve maximum performance (one cycle). Four cases achieve one-cycle maximization.

| Case<br>No. | Global Bus<br>Accesses | Accesses From<br>Dual-Access<br>Internal Memory | Local Bus<br>Or Peripheral<br>Accesses |
|-------------|------------------------|-------------------------------------------------|----------------------------------------|
| 1           | 1                      | .1                                              | -                                      |
| 2           | 1                      | . –                                             | 1                                      |
| 3           | -                      | 2 from any<br>combination<br>of internal memory | -                                      |
| 4           | -                      | 1                                               | 1                                      |

 Table 10–1.
 One Program Fetch and One Data Access for Maximum Performance

Table 10–2 shows how many accesses can be performed from the different memory spaces when it is necessary to do a program fetch and two data accesses, still achieving maximum performance (one cycle). Six cases achieve this maximization.

| Case<br>No. | Global Bus<br>Accesses | Accesses From Dual-Access<br>Internal Memory                                          | Local Or<br>Peripheral Bus<br>Accesses |  |
|-------------|------------------------|---------------------------------------------------------------------------------------|----------------------------------------|--|
| 1           | 1                      | 2 from any combination of internal memory                                             | _                                      |  |
| 2†          | 1 program              | 1 Data                                                                                | 1 data                                 |  |
| 3†          | 1 data                 | 1 Data                                                                                | 1 program                              |  |
| 4           | -                      | 2 from same internal memory<br>block and1 from a different inter-<br>nal memory block | -                                      |  |
| 5           | -                      | 3 from different internal memory<br>blocks                                            | -                                      |  |
| 6           | _                      | 2 from any combination of internal<br>memory                                          | 1                                      |  |
| 7           | 1 program              | 2 data                                                                                | 1 DMA                                  |  |
| 8           | 1 DMA                  | 2 data                                                                                | 1 program                              |  |

 Table 10–2.
 One Program Fetch and Two Data Accesses for Maximum Performance

<sup>†</sup> For Cases 2 and 3, see Three-Operand Instruction Memory Reads on page 10-21.

# **10.4 Clocking of Memory Accesses**

Internal clock phases (H1 and H3) and their relationship to memory accesses are discussed in this section to show how the TMS320C40 handles multiple memory accesses. Whereas the previous section discussed the interaction between sequences of instructions, this section discusses the flow of data on an individual instruction basis.

Each major clock period of 40 ns is composed of two minor clock periods of 20 ns, labeled H3 and H1 (these times assume a 50-MHz 'C40). The active clock period for H3 and H1 is the time when that signal is high.



The precise operation of memory reads and writes can be defined according to these minor clock periods. The types of memory operations that can occur are program fetches, data loads and stores, and DMA accesses.

# **10.4.1 Program Fetches**

Internal program fetches are always performed during H3 unless a single data store must occur at the same time because of another instruction in the pipeline. In this case, the program fetch occurs during H1 and the data store during H3.

External program fetches always start at the beginning of H3 with the address being presented on the external bus. At the end of H1, they are completed with the latching of the instruction word.

# 10.4.2 Data Loads and Stores

Four types of instructions perform loads, memory reads, and stores: two-operand instructions, three-operand instructions, multiplier/ALU operation with store instructions, and parallel multiply and add instructions. See Chapter 5 for detailed information on addressing modes.

As discussed in Chapter 7, the number of bus cycles for external memory accesses differs in some cases from the number of CPU execution cycles. For external reads, the number of bus cycles and CPU execution cycles is identical. For external writes, there are always at least two bus cycles, but unless there is a port access conflict, there is only one CPU execution cycle. In the following examples, any difference in the number of bus cycles and CPU cycles is noted.

# **Two-Operand Instruction Memory Accesses**

Figure 10–2. Two-Operand Instruction Word

| 31    | 24 23     | 3 | 16 1     | 15 87    | 0 |
|-------|-----------|---|----------|----------|---|
| 0 X 0 | Operation | G | dst(src) | src(dst) |   |

Two-operand instructions include all those instructions with bits 31-29 being  $000_2$  or  $010_2$  (see Figure 10-2). In the case of a data read, bits 15-0 represent the *src* operand. Internal data reads are always performed during H1. External data reads always start at the beginning of H3 with the address being presented on the external bus, and they complete with the latching of the data word at the end of H1.

In the case of a data store, bits 15–0 represent the *dst* operand. Internal data stores are performed during H3. External data stores always start at the beginning of H3 with the address and data being presented on the external bus.

# **Three-Operand Instruction Memory Reads**

Figure 10–3. Three-Operand Instruction Word



Three-operand instructions include all instructions with bits 31-29 being  $001_2$  (see Figure 10-3). The source operands, *src1* and *src2*, come from either registers or memory. When one or more of the source operands are from memory, these instructions are always memory reads.

If only one of the source operands is from memory (either *src1* or *src2*) and is located in internal memory, the data is read during H1. If the single memory source operand is in external memory, the read starts at the beginning of H3, with the address being presented on the external bus, and completes with the latching of the data word at the end of H1.

If both source operands are to be fetched from memory, then several cases occur. If both operands are located in internal memory, the *src1* read is performed during H3 and *src2* during H1, thus completing two memory reads in a single cycle.

If *src1* is in internal memory and *src2* is in external memory, the *src2* access begins at the start of H3 and latches at the end of H1. At the same time, the *src1* access to internal memory is performed during H3. Again, two memory reads are completed in a single cycle.

If *src1* is in external memory and *src2* is in internal memory, two cycles are necessary to complete the two reads. In the first cycle, the internal *src2* access is performed. The *src1* is also performed, but not latched until the next H3.

If *src1* and *src2* are both from external memory, two cycles are required to complete the two reads. In the first cycle, the *src1* access is performed and loaded on the next H3; in the second cycle, the *src2* access is performed and loaded on that cycle's H1.

### **Operations with Parallel Stores**

*Figure 10–4. Multiply or CPU Operation With a Parallel Store* 

| 31  | ·         | 24 23 |      | 16   | 5 15 | ε | 37 | 0   |
|-----|-----------|-------|------|------|------|---|----|-----|
| 1 1 | Operation | dst1  | src1 | src3 | dst2 | 2 | sr | rc2 |

The next class of instructions includes all instructions that have a store in parallel with another instruction. Bits 31 and 30 for these instructions are equal to 1  $1_2$ .

For operations that perform a multiply or ALU operation in parallel with a store, the instruction word format is shown in Figure 10–4. If the store operation to *dst2* is external or internal, it is performed during H3. Two bus cycles are required for external stores, but only one CPU cycle is necessary to complete the write.

If the memory read operation is external, it starts at the beginning of H3 and latches at the end of H1. If the memory read operation is internal, it is performed during H1. Note that memory reads are performed by the CPU

during the read (R) phase of the pipeline, and stores are performed during the execute (E) phase.

The instruction word format for instructions that have parallel stores to memory is shown in Figure 10-5. If both destination operands, dst1 and dst2, are located in internal memory, dst1 is stored during H3 and dst2 during H1, thus completing two memory stores in a single cycle.

Figure 10–5. Two Parallel Stores

| 31         | 24 23      | 16 15     | 87      | 0   |
|------------|------------|-----------|---------|-----|
| 1 1 ST  ST | src2 0 0 ( | ) src1 ds | t1 dst2 | 1 1 |

If *dst1* is in external memory and *dst2* is in internal memory, the *dst1* store begins at the start of H3. The *dst2* store to internal memory is performed during H1. Two bus cycles are required for the external store, but only one CPU cycle is necessary to complete the write. Again, two memory stores are completed in a single cycle.

If *dst1* is in internal memory and *dst2* is in external memory, an additional bus cycle is necessary to complete the *dst2* store. Only one CPU cycle is necessary to complete the write, but the port access requires three bus cycles. In the first cycle, the internal *dst1* store is performed during H3, and dst2 is written to the port during H1. During the next cycle, the dst2 store is performed on the external bus, beginning in H3, and executes as normal through the following cycle.

If *dst1* and *dst2* are both written to external memory, a single CPU cycle is still all that is necessary to complete the stores. In this case, four bus cycles are required.

- 1) In the first cycle, both *dst1* and *dst2* are written to the port, and the external bus access for dst1 begins.
- The store for dst1 is completed on the second cycle, and the store for dst2 begins on the third external bus cycle.
- 3) Finally, the store for *dst2* is completed on the fourth external bus cycle. **10**

#### **Parallel Multiplies and Adds**

Memory addressing for parallel multiplies and adds is similar to that for three-operand instructions. The parallel multiplies and adds include all instructions with bits 31-30 equal to  $10_2$  (see Figure 10–6).

Figure 10–6. Parallel Multiplies and Adds



For these operations, *src3* and *src4* are both located in memory. If both operands are located in internal memory, *src3* is performed during H3, and *src4* is performed during H1, thus completing two memory reads in a single cycle.

If *src3* is in internal memory and *src4* is in external memory, the *src4* access begins at the start of H3 and latches at the end of H1. At the same time, the *src3* access to internal memory is performed during H3. Again, two memory reads are completed in a single cycle.

If *src3* is in external memory and *src4* is in internal memory, two cycles are necessary to complete the two reads. In the first cycle, the internal *src4* access is performed. During the H3 of the next cycle, the *src3* access is performed.

If *src3* and *src4* are both from external memory, two cycles are necessary to complete the two reads. In the first cycle, the *src3* access is performed; in the second cycle, the *src4* access is performed.

# **Chapter 11**

# Assembly Language Instructions

The TMS320C40 assembly language instruction set supports numeric-intensive, signal processing, and general-purpose applications. The instructions are organized into these major groups: load-and-store, two- or three-operand arithmetic/logical, parallel, program control, and interlocked operations instructions. The addressing modes used with the instructions are described in Chapter 5.

The TMS320C40 instruction set can also use one of 20 condition codes with any of the 10 conditional instructions, such as LDF*cond*. This chapter defines the condition codes and flags.

The assembler allows optional syntax forms to simplify the assembly language for special-case instructions. These optional forms are listed and explained.

Each of the individual instructions is described and listed in alphabetical order. An example instruction (on pages 11-15 through 11-17) demonstrates the special format used and explains its content.

This chapter discusses the following major topics:

| Section | า    |                                               | Page |
|---------|------|-----------------------------------------------|------|
| 11.1    | Inst | ruction Set                                   | 11-3 |
|         |      | Load-and-Store Instructions                   | 11-3 |
|         |      | Two-Operand Arithmetic/Logical Instructions   | 11-4 |
|         |      | Three-Operand Arithmetic/Logical Instructions | 11-6 |
|         |      | Program Control Instructions                  | 11-6 |
|         |      | Interlocked Operations Instructions           | 11-7 |
|         |      | Parallel Operations Instructions              | 11-8 |
|         |      |                                               |      |

| Section | on Page                                                                                                                                                                                      |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11.2    | Condition Codes and Flags 11-10                                                                                                                                                              |
| 11.3    | Individual Instructions 11-13                                                                                                                                                                |
|         | Symbols and Abbreviations Used in Instructions 11-13                                                                                                                                         |
|         | Optional Assembler Syntaxes                                                                                                                                                                  |
|         | <ul> <li>Individual instruction descriptions, alphabetized<br/>(includes syntax, operation, operands, encoding,<br/>description, cycles, status bits, mode bit, examples) . 11-17</li> </ul> |

Assembly Language Instructions

# 11.1 Assembly Language Instructions — Instruction Set

The TMS320C40 instruction set is exceptionally well-suited to digital signal processing and other numeric-intensive applications. All instructions are a single machine word long, and most instructions take a single cycle to execute. In addition to multiply and accumulate instructions, the TMS320C40 possesses a full complement of general-purpose instructions.

The instruction set contains 135 instructions organized into the following functional groups:

- Load-and-store
- Two-operand arithmetic/logical
- Three-operand arithmetic/logical
- Program control
- Interlocked operations
- Parallel operations

Each of these groups is discussed in the succeeding subsections.

# 11.1.1 Load-and-Store Instructions

The TMS320C40 supports 23 load-and-store instructions (see Table 11–1). These instructions can

- Load a word from memory into a register,
- Store a word from a register into memory, or
- Manipulate data on the system stack.

Two of these instructions can load data conditionally. This is useful for locating the maximum or minimum value in a data set. See Section 12.2 for detailed information on condition codes.

| Instruction     | Description                                               | Instru |
|-----------------|-----------------------------------------------------------|--------|
| LBb             | Load byte (signed)                                        | LD     |
| LBUb            | Load byte (unsigned)                                      | LH     |
| LDA             | Load address register                                     | LH     |
| LDE             | Load floating-point exponent                              | LW     |
| LDEP            | Load integer, expansion file register to primary register | LW     |
| LDF             | Load floating-point value                                 | PO     |
| LDF <i>cond</i> | Load floating-point value                                 | PU     |
| LDHI            | Load 16-bit unsigned immediate<br>into 16 MSBs            | PU     |
| LDI             | Load integer                                              | ST     |
| LDIcond         | Load integer conditionally                                | ST     |
| LDM             | Load floating-point mantissa                              | ST     |
| LDPE            | Load integer, primary register to expansion file register |        |

#### Table 11–1. Load-and-Store Instructions

| Instruction   | Description                         |
|---------------|-------------------------------------|
| LDPK          | Load DP register immediate          |
| LHW           | Load half-word signed               |
| LHUw          | Load half-word unsigned             |
| LWL <i>ct</i> | Load word left-shifted              |
| LWR <i>ct</i> | Load word right-shifted             |
| POPF          | Pop floating-point value from stack |
| PUSH          | Push integer on stack               |
| PUSHF         | Push floating-point value on stack  |
| STF           | Store floating-point value          |
| STI           | Store integer                       |
| STIK          | Store integer immediate             |

# **11.1.2 Two-Operand Instructions**

The TMS320C40 supports a complete set of 43 two-operand arithmetic and logical instructions. The two operands are the source and destination. The source operand may be a memory word, a register, or a constant. The destination operand is always a register.

These instructions provide integer, floating-point, or logical operations, and multiprecision arithmetic. Table 11–2 lists these instructions.

| Instruction       | Description                                                               |
|-------------------|---------------------------------------------------------------------------|
| ABSF              | Absolute value of a floating-<br>point number                             |
| ABSI              | Absolute value of an integer                                              |
| ADDCT             | Add integers with carry                                                   |
| ADDFT             | Add floating-point values                                                 |
| ADDIT             | Add integers                                                              |
| ANDT              | Bitwise logical-AND                                                       |
| ANDNT             | Bitwise logical-AND with<br>complement                                    |
| ASH <sup>†</sup>  | Arithmetic shift                                                          |
| CMPFT             | Compare floating-point values                                             |
| CMPIT             | Compare integers                                                          |
| FIX               | Convert floating-point value to integer                                   |
| FLOAT             | Convert integer to floating-point value                                   |
| FRIEEE            | Convert IEEE floating-point format to twos-complement floating-point for- |
| LSHT              | Logical shift                                                             |
| MB <i>ct</i>      | Merge byte, left shifted                                                  |
| MH <i>ct</i>      | Merge half-word, left shifted                                             |
| MPYFT             | Multiply floating-point values                                            |
| MPYI <sup>†</sup> | Multiply integers                                                         |
| MPYSHIT           | Multiply signed integer, 32-MSB product                                   |
| ΜΡΥUHIŤ           | Multiply unsigned integer, 32-MSB product                                 |
| NEGB              | Negate integer with borrow                                                |
| NEGF              | Negate floating-point value                                               |

| Instruction | Description                               |
|-------------|-------------------------------------------|
| NEGI        | Negate integer                            |
| NORM        | Normalize floating-point value            |
| NOT         | Bitwise logical-complement                |
| ORT         | Bitwise logical-OR                        |
| RCPF        | Reciprocal floating point                 |
| RND         | Round floating-point value                |
| ROL         | Rotate left                               |
| ROLC        | Rotate left through carry                 |
| ROR         | Rotate right                              |
| RORC        | Rotate right through carry                |
| RSQRF       | Reciprocal of square root, floating point |
| SUBBT       | Subtract integers with borrow             |
| SUBC        | Subtract integers conditionally           |
| SUBFT       | Subtract floating-point values            |
| SUBIT       | Subtract integer                          |
| SUBRB       | Subtract reverse integer with borrow      |
| SUBRF       | Subtract reverse floating-point value     |
| SUBRI       | Subtract reverse integer                  |
| TOIEEE      | Convert twos complement to IEEE format    |
| тѕтв†       | Test bit fields                           |
| XORT        | Bitwise exclusive-OR                      |

# Table 11–2.Two-Operand Instructions

† Two- and three-operand versions

## **11.1.3 Three-Operand Instructions**

Most instructions contain two or three operands. The 19 three-operand instructions allow the TMS320C40 to read two operands from memory or the CPU register file in a single cycle and store the results in a register. The following differentiates the two- and three-operand instructions:

- Two-operand instructions have a single-source operand (or shift count) and a destination operand.
- Three-operand instructions may have two source operands (or one source operand and a count operand) and a destination operand. A source operand may be a memory word, a register or a constant. The destination of a three-operand instruction is always a register.

Table 11–3 lists the instructions that have three-operand versions. Note that the 3 in the mnemonic can be omitted from three-operand instructions (see subsection 11.3.2).

| Instruction | Description                         | Instruction | Description                               |
|-------------|-------------------------------------|-------------|-------------------------------------------|
| ADDC3       | Add with carry                      | MPYF3       | Multiply floating-point values            |
| ADDF3       | Add floating-point values           | MPYI3       | Multiply integers                         |
| ADD13       | Add integers                        | MPYSH13     | Multiply signed integer, 32-MSB product   |
| AND3        | Bitwise logical-AND                 | MPYUHI3     | Multiply unsigned integer, 32-MSB product |
| ANDN3       | Bitwise logical-AND with complement | OR3         | Bitwise logical-OR                        |
| ASH3        | Arithmetic shift                    | SUBB3       | Subtract integers with borrow             |
| CMPF3       | Compare floating-point values       | SUBF3       | Subtract floating-point values            |
| CMP13       | Compare integers                    | SUB13       | Subtract integers                         |
| LSH3        | Logical shift                       | TSTB3       | Test bit fields                           |
|             | ·                                   | XOR3        | Bitwise exclusive-OR                      |

# **11.1.4 Program Control Instructions**

The program-control instruction group consists of all of those instructions (23) that affect program flow. The repeat mode allows repetition of a block of code (RPTB and RPTBD) or of a single line of code (RPTS). Both standard and delayed (single-cycle) branching are supported. Several of the program control instructions are capable of conditional operations (see Section 12.2 for detailed information on condition codes). Table 11–4 lists the program control instructions.

| and the second se |                                                    |                    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|--------------------|
| Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Description                                        | Instruction        |
| Bcond                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Branch conditionally (standard)                    | LAJcond            |
| B <i>cond</i> AF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Branch conditionally delayed and<br>annul if false | LATcond            |
| B <i>cond</i> AT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Branch conditionally delayed and<br>annul if true  | NOP                |
| BcondD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Branch conditionally (delayed)                     | RETIcond           |
| BR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Branch unconditionally (standard)                  | RETI <i>cond</i> D |
| BRD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Branch unconditionally (delayed)                   | RETScond           |
| CALL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Call subroutine                                    | RPTB               |
| CALLcond                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Call subroutine conditionally                      | RPTBD              |
| DBcond                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Decrement and branch                               | RPTS               |
| DB <i>cond</i> D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Decrement and branch                               | SWI                |
| IDLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Idle until interrupt                               | TRAP cond          |
| LAJ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Link and jump                                      | ]                  |

#### Program Control Instructions Table 11-4.

| Instruction        | Description                            |
|--------------------|----------------------------------------|
| LAJ <i>cond</i>    | Link and jump conditional              |
| LATcond            | Link and trap contitional              |
| NOP                | No operation                           |
| RETIcond           | Return from interrupt conditionally    |
| RETI <i>cond</i> D | Return from trap or interrupt, delayed |
| RETScond           | Return from subroutine conditionally   |
| RPTB               | Repeat block of instructions           |
| RPTBD              | Repeat block, delayed                  |
| RPTS               | Repeat single instruction              |
| SWI                | Software interrupt                     |
| TRAP cond          | Trap conditionally                     |

# 11.1.5 Interlocked Operations Instructions

The interlocked operations instructions support multiprocessor communication and the use of external signals to allow for powerful synchronization mechanisms. They also guarantee the integrity of the communication and result in a high-speed operation. Refer to Chapter 7 for examples of the use of interlocked instructions.

Table 11-5. Interlocked Operations Instructions

| Instruction | Description                            | Instruction | Description                             |
|-------------|----------------------------------------|-------------|-----------------------------------------|
| LDFI        | Load floating-point value, interlocked | STFI        | Store floating-point value, interlocked |
| LDII        | Load integer, interlocked              | STII        | Store integer, interlocked              |
| SIGI        | Signal, interlocked                    | <u></u>     |                                         |

# **11.1.6 Parallel Operations Instructions**

The parallel-operations instructions group makes a high degree of parallelism possible. Some of the TMS320C40 instructions can occur in pairs that will be executed in parallel. These instructions offer the following features:

- Parallel loading of registers,
- Parallel arithmetic operations, or
- Arithmetic/logical instructions used in parallel with a store instruction.

Each instruction in a pair is entered as a separate source statement. The second instruction in the pair must be preceded by two vertical bars (||). Table 11–6 lists the valid instruction pairs.

| <i>Table 11–6.</i> | Parallel Instructions |
|--------------------|-----------------------|
|--------------------|-----------------------|

| Mnemonic         | Description                                                              |  |  |  |  |
|------------------|--------------------------------------------------------------------------|--|--|--|--|
|                  | Parallel Arithmetic with Store Instructions                              |  |  |  |  |
| ABSF<br>   STF   | Absolute value of a floating-point number and store floating-point value |  |  |  |  |
| ABSI<br>   STI   | Absolute value of an integer and store integer                           |  |  |  |  |
| ADDF3<br>   STF  | Add floating-point values and store floating-point value                 |  |  |  |  |
| ADDI3<br>   STI  | Add integers and store integer                                           |  |  |  |  |
| AND3<br>   STI   | Bitwise logical-AND and store integer                                    |  |  |  |  |
| ASH3<br>   STI   | Arithmetic shift and store integer                                       |  |  |  |  |
| FIX<br>   STI    | Convert floating-point to integer and store integer                      |  |  |  |  |
| FLOAT<br>   STF  | Convert integer to floating-point value and store floating-point value   |  |  |  |  |
| FRIEEE<br>   STF | Convert IEEE floating-point format and store                             |  |  |  |  |
| LDF<br>   STF    | Load floating-point value and store floating-point value                 |  |  |  |  |
| LDI<br>   STI    | Load integer and store integer                                           |  |  |  |  |

Table concluded on next page.

# Table 11–6. Parallel Instructions (Concluded)

| Mnemonic                                        | Description                                                   |  |  |  |
|-------------------------------------------------|---------------------------------------------------------------|--|--|--|
| Parallel Arithmetic with Store Instructions     |                                                               |  |  |  |
| LSH3<br>   STI                                  | Logical shift and store integer                               |  |  |  |
| MPYF3<br>   STF                                 | Multiply floating-point values and store floating-point value |  |  |  |
| MPYI3<br>   STI                                 | Multiply integer and store integer                            |  |  |  |
| NEGF<br>   STF                                  | Negate floating-point value and store floating-point value    |  |  |  |
| NEGI<br>   STI                                  | Negate integer and store integer                              |  |  |  |
| NOT3<br>   STI                                  | Complement value and store integer                            |  |  |  |
| OR3<br>   STI                                   | Bitwise logical-OR value and store integer                    |  |  |  |
| STF<br>   STF                                   | Store floating-point values                                   |  |  |  |
| STI<br>   STI                                   | Store integers                                                |  |  |  |
| SUBF3<br>   STF                                 | Subtract floating-point value and store floating-point value  |  |  |  |
| TOIEEE<br>   STF                                | Convert to IEEE format and store                              |  |  |  |
| SUBI3<br>   STI                                 | Subtract integer and store integer                            |  |  |  |
| XOR3<br>   STI                                  | Bitwise exclusive-OR values and store integer                 |  |  |  |
|                                                 | Parallel Load Instructions                                    |  |  |  |
| LDF<br>   LDF                                   | Load floating-point                                           |  |  |  |
| LDI<br>   LDI                                   | Load integer                                                  |  |  |  |
| Parallel Multiply and Add/Subtract Instructions |                                                               |  |  |  |
| MPYF3<br>   ADDF3                               | Multiply and add floating-point                               |  |  |  |
| MPYF3<br>   SUBF3                               | Multiply and subtract floating-point                          |  |  |  |
| MPYI3<br>   ADDI3                               | Multiply and add integer                                      |  |  |  |
| MPYI3<br>   SUBI3                               | Multiply and subtract integer                                 |  |  |  |

# **11.2 Condition Codes and Flags**

The TMS320C40 provides 20 condition codes (00000 - 10100, excluding 01011) that can be used with any of the conditional instructions, such as RETS*cond* or LDF*cond*. The conditions include signed and unsigned comparisons, comparisons to zero, and comparisons based on the status of individual condition flags. Note that all conditional instructions can also accept the suffix U to indicate unconditional operation.

Seven condition flags provide information about properties of the result of arithmetic and logical instructions. The condition flags are stored in the status register (ST) and are affected by an instruction based upon the SET COND field (bit 15 of the status register).

- □ If SET COND = 0, the ST condition flags are set if the operation's target is any extended-precision register (R0–R11).
- If SET COND = 1, the ST condition flags are also set if the operaton's target is any register in the primary register file except the status register.
- □ The value of SET COND (0 or 1) does not affect the nature of the compare instructions (CMPF, CMPF3, CMPI, CMPI3, TSTB, or TSTB3).

The condition flags may be modified by most instructions when either of the preceding conditions is established and either of the following two cases occurs:

- A result is generated when the specified operation is performed to infinite precision. This is appropriate for compare-and-test instructions that do not store results in a register. It is also appropriate for arithmetic instructions that produce underflow or overflow.
- □ The output is written to the destination register as shown in Table 11–7. This is appropriate for other instructions that modify the condition flags.

| Table 11-7. | Output Value Formats |
|-------------|----------------------|
|-------------|----------------------|

| Type of Operation | Output Format                               |
|-------------------|---------------------------------------------|
| Floating-point    | 8-bit exponent, 1 sign bit, 31-bit fraction |
| Integer           | 32-bit integer                              |
| Logical           | 32-bit unsigned integer                     |

Figure 11–1 shows the condition flags in the low-order bits of the status register. Following the figure is a list of status register condition flags and descriptions on how the flags are set by most instructions. For specific details of the effect of a particular instruction on the condition flags, see the description of that instruction in subsection 11.3.3.

Status Register Figure 11–1.



- LUF Latched Underflow Condition Flag. LUF is set whenever UF (floating-point underflow flag) is set. LUF may be cleared only by a processor reset or by modifying it in the status register (ST).
- LV Latched Overflow Condition Flag. LV is set whenever V (overflow condition flag) is set. Otherwise, it is unchanged. LV may be cleared only by a processor reset or by modifying it in the status register (ST).
- UF Floating-Point Underflow Condition Flag. A floating-point underflow occurs whenever the exponent of the result is less than or equal to -128. If a floating-point underflow occurs, UF is set, and the output value is set to 0. UF is cleared if a floating-point underflow does not occur.
- Ν Negative Condition Flag. Logical operations assign N the state of the MSB of the output value. For integer and floating-point operations, N is set if the result is negative, and cleared otherwise. Zero is positive.
- Ζ Zero Condition Flag. For logical, integer, and floating-point operations, Z is set if the output is 0, and cleared otherwise.
- V **Overflow Condition Flag.** For integer operations, V is set if the result does not fit into the format specified for the destination (i.e.,  $-2^{32}$  $\leq$  result  $\leq 2^{32} - 1$ ). Otherwise, V is cleared. For floating-point operations. V is set if the exponent of the result is greater than 127; otherwise, V is cleared. Logical operations always clear V.
- С Carry Flag. When an integer addition is performed, C is set if a carry occurs out of the bit corresponding to the MSB of the output. When an integer subtraction is performed, C is set if a borrow occurs into the bit corresponding to the MSB of the output. Otherwise, for integer operations, C is cleared. The carry flag is unaffected by floating-point and logical operations. For shift instructions, this flag is set to the final value shifted out: for a zero shift count, this is set to zero.

Table 11–8 lists the condition mnemonic, code, description, and flag for each of the 19 condition codes.

Table 11–8.Condition Codes and Flags

| Condition              | Code                                  | Description                         | Flag†          |  |  |
|------------------------|---------------------------------------|-------------------------------------|----------------|--|--|
| Unconditional Compares |                                       |                                     |                |  |  |
| U                      | 00000                                 | Unconditional                       | Don't care     |  |  |
|                        |                                       | Unsigned Compares                   |                |  |  |
| LO                     | 00001                                 | Lower than                          | С              |  |  |
| LS                     | 00010                                 | Lower than or same as               | C OR Z         |  |  |
| н                      | 00011                                 | Higher than                         | ~C AND ~Z      |  |  |
| HS                     | 00100                                 | Higher than or same as              | ~ <sup>C</sup> |  |  |
| EQ                     | 00101                                 | Equal to                            | Z              |  |  |
| NE                     | 00110                                 | Not Equal to                        | ~Z             |  |  |
|                        | · · · · · · · · · · · · · · · · · · · | Signed Compares                     |                |  |  |
| L                      | 00111                                 | Less than                           | N<br>N OR Z    |  |  |
| LE                     | 01000                                 | Less than or equal to               | ~N AND ~Z      |  |  |
| GT                     | 01001                                 | Greater than                        |                |  |  |
| GE<br>EQ               | 01010                                 | Greater than or equal to            | ~N<br>Z        |  |  |
| NE                     | 00101<br>00110                        | Equal to<br>Not equal to            | ~Z             |  |  |
|                        | 00110                                 |                                     | ~ <u>/</u>     |  |  |
|                        | r                                     | Compare to Zero                     | 1_             |  |  |
| Z                      | 00101                                 | Zero                                | Z              |  |  |
| NZ                     | 00110                                 | Not zero                            | ~Z             |  |  |
| P                      | 01001                                 | Positive                            | ~N AND ~Z      |  |  |
| N<br>NN                | 00111<br>01010                        | Negative                            | N              |  |  |
|                        |                                       | Nonnegative                         | ~N             |  |  |
|                        | C                                     | ompare to Condition Flags           |                |  |  |
| NN                     | 01010                                 | Nonnegative                         | ~N             |  |  |
| N                      | 00111                                 | Negative                            | N              |  |  |
| NZ                     | 00110                                 | Nonzero                             | ~Z             |  |  |
| Z                      | 00101                                 | Zero                                | Z              |  |  |
| NV                     | 01100                                 | No overflow                         | ~v             |  |  |
| v                      | 01101                                 | Overflow                            | v              |  |  |
| NUF                    | 01110                                 | No underflow                        | ~UF            |  |  |
| UF                     | 01111                                 | Underflow                           | UF             |  |  |
| NC                     | 00100                                 | No carry                            | ~C             |  |  |
| С                      | 00001                                 | Carry                               | C              |  |  |
| NLV                    | 10000                                 | No latched overflow                 | ~LV            |  |  |
| LV                     | 10001                                 | Latched overflow                    |                |  |  |
| NLUF                   | 10010                                 | No latched floating-point underflow | ~LUF           |  |  |
| LUF                    | 10011                                 | Latched floating-point underflow    | LUF            |  |  |
| ZUF                    | 10100                                 | Zero or floating-point underflow    | ZORUF          |  |  |
| +                      | J                                     | <u>~</u> ,                          | 1-00           |  |  |

<sup>†</sup> The ~ means logical complement ("not true" condition).

# **11.3 Individual Instructions**

This section contains the individual assembly language instructions for the TMS320C40. The instructions are listed in alphabetical order. Information for each instruction includes assembler syntax, operation, operands, encoding, description, cycles, status bits, mode bit, and examples.

Definitions of the symbols and abbreviations, as well as optional syntax forms allowed by the assembler, precede the individual instruction description section. Also, an example instruction shows the special format used and explains its content.

A functional grouping of the instructions, as well as a complete instruction set summary, can be found in Section 11.1. Appendix B lists the opcodes for all the instructions. Refer to Chapter 6 for information on memory addressing. Code examples using many of the instructions are given in Chapter NO TAG, *Software Applications*.

## 11.3.1 Symbols and Abbreviations

Table 11–9 lists the symbols and abbreviations used in the individual instruction descriptions.

# Table 11–9.Instruction Symbols

| Symbol                                 | Meaning                                                                                                                                                                    |
|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| src                                    | Source operand                                                                                                                                                             |
| src1                                   | Source operand 1                                                                                                                                                           |
| src2                                   | Source operand 2                                                                                                                                                           |
| src3                                   | Source operand 3                                                                                                                                                           |
| src4                                   | Source operand 4                                                                                                                                                           |
| dst                                    | Destination operand                                                                                                                                                        |
| dst1                                   | Destination operand 1                                                                                                                                                      |
| dst2                                   | Destination operand 2                                                                                                                                                      |
| disp                                   | Displacement                                                                                                                                                               |
| cond                                   | Condition                                                                                                                                                                  |
| count                                  | Shift count                                                                                                                                                                |
| G                                      | General addressing modes                                                                                                                                                   |
| T                                      | Three-operand addressing modes                                                                                                                                             |
| P                                      | Parallel addressing modes                                                                                                                                                  |
| B                                      | Conditional-branch addressing modes                                                                                                                                        |
| ARn<br>IRn<br>RC<br>RE<br>RS<br>ST     | Auxiliary register n<br>Index register n<br>Register address n<br>Repeat count register<br>Repeat end address register<br>Repeat start address register<br>Status register |
| C                                      | Carry bit                                                                                                                                                                  |
| GIE                                    | Global interrupt enable bit                                                                                                                                                |
| N                                      | Trap vector                                                                                                                                                                |
| PC                                     | Program counter                                                                                                                                                            |
| RM                                     | Repeat mode flag                                                                                                                                                           |
| SP                                     | System stack pointer                                                                                                                                                       |
| $ x   x \rightarrow y  x(man)  x(exp)$ | Absolute value of x<br>Assign the value of x to destination y<br>Mantissa field (sign + fraction) of x<br>Exponent field of x                                              |
| op1<br>   op2                          | Operation 1 performed in parallel with operation 2                                                                                                                         |
| × AND y                                | Bitwise logical-AND of x and y                                                                                                                                             |
| × OR y                                 | Bitwise logical-OR of x and y                                                                                                                                              |
| × XOR y                                | Bitwise logical-XOR of x and y                                                                                                                                             |
| ~x                                     | Bitwise logical-complement of x                                                                                                                                            |
| x << y                                 | Shift x to the left y bits                                                                                                                                                 |
| x >> y                                 | Shift x to the right y bits                                                                                                                                                |
| *++SP                                  | Increment SP and use incremented SP as address                                                                                                                             |
| *SP                                    | Use SP as address and decrement SP                                                                                                                                         |

# **11.3.2 Optional Assembler Syntaxes**

The assembler allows a relaxed syntax form for some instructions. These optional forms simplify the assembly language so that special-case syntax can be ignored. The following is a list of these optional syntax forms.

The destination register can be omitted on unary arithmetic and logical operations when the same register is used as a source. For example.

ABSI R0,R0 can be written as ABSI RO Instructions affected: ABSI, ABSF, FIX, FLOAT, NEGB, NEGF, NEGI, NORM, NOT, RND.

All 3-operand instructions can be written without the 3. For example,

ADDI3 R0,R1,R2 can be written as ADDI R0,R1,R2 Instructions affected: ADDC3, ADDF3, ADDI3, AND3, ANDN3, ASH3, LSH3, MPYF3, MPYI3, OR3, SUBB3, SUBF3, SUBI3, XOR3, MPYSHI3, MPYUHI3.

This also applies to all the pertinent parallel instructions.

All 3-operand comparison instructions can be written without the 3. For example,

CMPI3 R0,\*AR0 can be written as CMPI R0,\*AR0

Instructions affected: CMPI3, CMPF3, TSTB3.

Indirect operands with an explicit 0 displacement are allowed. In 3-operand or parallel instructions, operands with 0 displacement are automatically converted to no-displacement mode. For example:

\*+AR0(0), R1 *is legal* LDI

Also

ADDI3 \*+AR0(0),R1,R2 is equivalent to ADDI3 \*AR0,R1,R2

Indirect operands can be written with no displacement; in which case. a displacement of one is assumed. For example,

LDI \*AR0++(1), R0 can be written LDI \*AR0++,R0

All conditional instructions accept the suffix U to indicate unconditional operation. Also, the U can be omitted from unconditional short branch instructions. For example:

BU label can be written B label

Labels can be written with or without a trailing colon. For example:

| label0: | NOP |                                       |
|---------|-----|---------------------------------------|
| label1  | NOP |                                       |
| label2: |     | (label assembles to next source line) |

Empty expressions are not allowed for the displacement in indirect mode:

LDI \*+AR0(),R0 is not legal

Immediate-mode destination operands of BR and CALL can be written with an at sign (@):

BR label can be written BR @label

The LDP pseudo-op can be used to load a register (DP by default) with the 16 MSBs of a relocatable address as follows:

LDP addr, REG Or LDP @addr, REG

The at sign (@) is optional.

If the destination REG is the DP, LDP generates an LDPK instruction. Otherwise it generates an LDIU instruction. In both cases an immediate operand with a special relocation type is used.

**D** Parallel instructions can be written in either order. For example:

| ADDI | can be written as | STI  |
|------|-------------------|------|
| STI  |                   | ADDI |
|      |                   |      |

The parallel bars indicating part 2 of a parallel instruction can be written anywhere on the line from column 0 to the mnemonic. For example:

| ADDI | can be written as | ADDI |
|------|-------------------|------|
| STI  |                   | STI  |

If the second operand of a parallel instruction is the same as the third (destination register) operand, the third operand can be omitted. This allows the writing of 3-operand parallel instructions that look like normal 2-operand instructions. For example,

| ADDI | *AR0,R2,R2 | can be written as |  | ADDI | *AR0,R2 |
|------|------------|-------------------|--|------|---------|
| MPYI | *AR1,R0,R0 |                   |  | MPYI | *AR1,R0 |

Instructions affected (applies to all parallel instructions that have a register as the second operand): ADDI, ADDF, AND, MPYI, MPYF, OR, SUBI, SUBF, XOR.

All commutative operations in parallel instructions can be written in either order. For example, the ADDI part of a parallel instruction can be written in either of two ways:

ADDI \*AR0,R1,R2 Or ADDI R1,\*AR0,R2

The instructions affected are parallel instructions containing any of the following: ADDI, ADDF, MPYI, MPYF, AND, OR, XOR.

□ Use the syntax in Table 11–10 to designate CPU registers in operands.

# **11.3.3 Individual Instruction Descriptions**

Each assembly language instruction for the TMS320C40 is described in this section in alphabetical order. The description includes the assembler syntax, operation, operands, encoding, description, cycles, status bits, mode bit, and examples.

Table 11–10. CPU Register Syntax

| Assembler<br>Syntax                                  | Register<br>Machine<br>Value (hex)           | Assigned Function Name                                                                                                                                                                                                                | Explained<br>in<br>Paragraph                                                                    | On<br>Page                                                  |
|------------------------------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| R0<br>R1<br>R2<br>R3<br>R4                           | 00<br>01<br>02<br>03<br>04                   | Extended-precision register 0<br>Extended-precision register 1<br>Extended-precision register 2<br>Extended-precision register 3<br>Extended-precision register 4                                                                     | 3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1                                              | 3-4<br>3-4<br>3-4<br>3-4<br>3-4                             |
| R5<br>R6<br>R7<br>R8<br>R9<br>R10<br>R11             | 05<br>06<br>07<br>1C<br>1D<br>1E<br>1F       | Extended-precision register 5<br>Extended-precision register 6<br>Extended-precision register 7<br>Extended-precision register 8<br>Extended-precision register 9<br>Extended-precision register 10<br>Extended-precision register 11 | 3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1<br>3.1.1                            | 3-4<br>3-4<br>3-4<br>3-4<br>3-4<br>3-4<br>3-4               |
| AR0<br>AR1<br>AR2<br>AR3<br>AR4<br>AR5<br>AR6<br>AR7 | 08<br>09<br>0A<br>0B<br>0C<br>0D<br>0E<br>0F | Auxiliary register 0<br>Auxiliary register 1<br>Auxiliary register 2<br>Auxiliary register 3<br>Auxiliary register 4<br>Auxiliary register 5<br>Auxiliary register 6<br>Auxiliary register 7                                          | 3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2<br>3.1.2 | 3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5<br>3-5 |
| DP<br>IR0<br>IR1<br>BK<br>SP                         | 10<br>11<br>12<br>13<br>14                   | Data-page pointer<br>Index register 0<br>Index register 1<br>Block-size register<br>System stack pointer                                                                                                                              | 3.1.3<br>3.1.4<br>3.1.4<br>3.1.5<br>3.1.6                                                       | 3-5<br>3-5<br>3-5<br>3-5<br>3-5                             |
| ST<br>DIE<br>IIE<br>IIF                              | 15<br>16<br>17<br>18                         | Status register<br>DMA Coprocessor interrupt enable<br>Internal-interrupt enable register<br>IIOF pins and interrupt flag register                                                                                                    | 3.1.7<br>3.1.8<br>3.1.9<br>3.1.10                                                               | 3-5<br>3-8<br>3-10<br>3-12                                  |
| RS<br>RE<br>RC                                       | 19<br>1A<br>1B                               | Repeat start address<br>Repeat end address<br>Repeat counter                                                                                                                                                                          | 3.1.11<br>3.1.11<br>3.1.11                                                                      | 3-14<br>3-14<br>3-14                                        |

Syntax INST src, dst

or

INST1 src2, dst1

|| INST2 src3, dst2

Each instruction begins with an assembler syntax expression. Labels may be placed either before the command (instruction mnemonic) on the same line or on the preceding line in the first column. The optional comment field that concludes the syntax is not included in the syntax expression. Space(s) are required between each field (label, command, operand, and comment fields).

The syntax examples illustrate the common one-line syntax and the two-line syntax used in parallel addressing. Note that the two vertical bars || that indicate a parallel addressing pair can be placed anywhere before the mnemonic on the second line. The first instruction in the pair can have a label, but the second instruction cannot have a label.

#### Operation

or

 $|src2| \rightarrow dst1$ 

 $\parallel src3 \rightarrow dst2$ 

 $|src| \rightarrow dst$ 

The instruction operation sequence describes the processing that takes place when the instruction is executed. For parallel instructions, the operation sequence is performed in parallel. Conditional effects of status register specified modes are listed for conditional instructions such as B*cond*.

Operands

*src* general addressing modes (G):

- 0 0 register (any register in CPU primary register file)
- 0 1 direct
- 10 indirect
- 11 immediate

dst register (any register in CPU primary register file)

or

```
src2 indirect (disp = 0, 1, IR0, IR1)
```

```
dst1 register (R0 — R7)
```

```
src3 register (R0 — R7)
```

dst2 indirect (disp = 0, 1, IR0, IR1)

Operands are defined according to the addressing mode and/or the type of addressing used. Note that indirect addressing uses displacements and the index registers. Refer to Chapter 5 for detailed information on addressing.

11-18



Encoding examples are shown for general addressing and parallel addressing. The instruction pair for the parallel addressing example consists of INST1 and INST2.

**Description** Instruction execution and its effect on the rest of the processor or memory contents are described. Any constraints on the operands imposed by the processor or the assembler are discussed. The description parallels and supplements the information given by the operation block.

#### Cycles

1

The digit specifies the number of cycles required to execute the instruction.

- Status Bits LUF Latched Floating-Point Underflow Condition Flag. 1 if a floating-point underflow occurs, unchanged otherwise.
  - LV Latched Overflow Condition Flag. 1 if an integer or floating-point overflow occurs, unchanged otherwise.
  - **UF** Floating-Point Underflow Condition Flag. 1 if a floating-point underflow occurs, 0 otherwise.
  - **N Negative Condition Flag.** 1 if a negative result is generated, 0 otherwise. In some instructions, this flag is the MSB of the output.
  - Z Zero Condition Flag. 1 if a zero result is generated, 0 otherwise. For logical and shift instructions, 1 if a zero output is generated, 0 otherwise.
  - V Overflow Condition Flag. 1 if an integer or floating-point overflow occurs, 0 otherwise.
  - C Carry Flag. 1 if a carry or borrow occurs, 0 otherwise. For shift instructions, this flag is set to the value of the last bit shifted out; 0 for a shift count of 0.

The seven condition flags are stored in the status register (ST). They provide information about the properties of the result or output of arithmetic or logical operations. *Mode Bit* **OVM Overflow Mode Flag.** In general, integer operations are affected by the OVM bit value (described in Table 3–2 on page 3-6).

**Example** INST @98AEh,R5

#### **Before Instruction:**

 $DP = 80h \\ R5 = 07\ 6690\ 0000h = 2.30562500e + 02 \\ Memory\ at\ 0080\ 98AEh = 5CDFh = 1.00001107e + 00 \\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0 \\ 0$ 

#### After Instruction:

DP = 80h R5 = 00 6690 0000h = 1.80126953e + 00 Memory at 80 98AEh = 5CDFh = 1.00001107e + 00 LUF LV UF N Z V C = 0 0 0 0 0 0 0

The sample code presented in the above format shows the effect of the code on system pointers (e.g., DP or SP), registers (e.g., R1 or R5), memory at specific locations, and the seven status bits. The values given for the registers include the leading zeros to show the exponent in floating-point operations. Decimal conversions are provided for all register and memory locations. The seven status bits are listed in the order in which they appear in the assembler and simulator (see Section 11.2 on page 11-10 and Table 11–8 on page 11-12 for further information on these seven status bits). Syntax ABSF src, dst

**Operation**  $|src| \rightarrow dst$ 

*Operands* src general addressing modes (G):

- 0 0 register (R0 R11)
- 01 direct
- 10 indirect
- 11 immediate

dst register (R0 – R11)

#### Encoding

| 31 24 23          | 3 16  | 15 87 | 0 |
|-------------------|-------|-------|---|
| 0 0 0 0 0 0 0 0 0 | G dst | src   |   |

**Description** The absolute value of the *src* operand is loaded into the *dst* register. The *src* and *dst* operands are assumed to be floating-point numbers.

An overflow occurs if  $src(man) = 8000\ 0000h$  and src(exp) = 7Fh. The result is dst(man) = 7FFF FFFFh and dst(exp) = 7Fh.

| Cycles   | 1                                                                                                                                                                                                                                                                                       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -        | <ul> <li>LUF Unaffected.</li> <li>LV 1 if a floating-point overflow occurs, unchanged otherwise.</li> <li>UF 0.</li> <li>N 0.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if a floating-point overflow occurs, 0 otherwise.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                         |
| Example  | ABSF R4,R7                                                                                                                                                                                                                                                                              |
|          | Before Instruction:                                                                                                                                                                                                                                                                     |
|          | R4 = 05C8000 F971h = -9.90337307e + 27<br>R7 = 07D2511 00AEh = 5.48527255e + 37<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                    |
|          | After Instruction: 11                                                                                                                                                                                                                                                                   |
|          | R4 = 05C8000 F971h = -9.90337307e + 27<br>R7 = 05C7FFF 068Fh = 9.90337307e + 27<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                    |

#### **ABSF**||**STF** Parallel ABSF and STF

| Syntax    | ABSF src2, dst1                                                                                                                  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------|
| Operation | $ src2  \rightarrow dst1$<br>$   src3 \rightarrow dst2$                                                                          |
| Operands  | src2indirect (disp = 0, 1, IR0, IR1) $dst1$ register (R0 - R7) $src3$ register (R0 - R7) $dst2$ indirect (disp = 0, 1, IR0, IR1) |

#### Encoding

68

| _ | 31 |   |   |   |   |   |   | 24 23 | _ |   |   | 16   | 15  |     |   | 8 | B 7 |    |     |   | 0 |
|---|----|---|---|---|---|---|---|-------|---|---|---|------|-----|-----|---|---|-----|----|-----|---|---|
|   | 1  | 1 | 0 | 0 | 1 | 0 | 0 | dst1  | 0 | 0 | 0 | src3 | 1 1 | dst | ? |   |     | si | rc2 | 1 | 1 |

**Description** A floating-point absolute value and a floating-point store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STF) reads from a register and the operation being performed in parallel (ABSF) writes to the same register, then STF accepts as input the contents of the register before it is modified by the ABSF.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*. If *src3* and *dst1* point to the same register, *src3* is read before the write to *dst1*.

An overflow occurs if src(man) = 8000000h and src(exp) = 7Fh. The result is dst(man) = 7FFFFFFh and dst(exp) = 7Fh.

| Cycles      | 1                                                                                             |
|-------------|-----------------------------------------------------------------------------------------------|
| Status Bits | LUF Unaffected.<br>LV 1 if a floating-point overflow occurs, unchanged otherwise.             |
|             | <b>UF</b> 0.                                                                                  |
|             | <ul> <li>N 0.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> </ul>             |
|             | <ul><li>V 1 if a floating-point overflow occurs, 0 otherwise.</li><li>C Unaffected.</li></ul> |
| Mode Bit    | <b>OVM</b> Operation is not affected by OVM bit value.                                        |

#### Example

ABSF \*++AR3(IR1),R4 STF R4,\*- AR7(1)

## **Before Instruction:**

AR3 = 80 9800h IR1 = 0AFh R4 = 733C0 0000h = 1.79750e + 02AR7 = 80 98C5h Data at 80 98AFh = 58B 4000h = -6.118750e + 01Data at 80 98C4h = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

#### **After Instruction:**

AR3 = 80 98AFh IR1 = 0AFh R4 =  $574C0\ 0000h = 6.118750e + 01$ AR7 = 80 98C5h Data at 80 98AFh =  $58B\ 4000h = -6.118750e + 01$ Data at 80 98C4h =  $733\ C000h = 1.79750e + 02$ LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax      | ABSI src, dst                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Operation   | $ src  \rightarrow dst$                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
| Operands    | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate</li> </ul>                                                                                               |  |  |  |  |  |  |  |
|             | dst register (any register in CPU primary register file)                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| Encoding    |                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
| 31          | <u>24 23 16 15 87 0</u>                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
| 0 0 0 0 0   | 0 0 0 1 G dst src                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
| Description | cription The absolute value of the <i>src</i> operand is loaded into the <i>dst</i> register. The <i>src</i> and <i>dst</i> operands are assumed to be signed integers.                                                                                                                |  |  |  |  |  |  |  |
|             | An overflow occurs if $src = 8000\ 0000$ h. If ST(OVM) = 1, the result is $dst = 7$ FFF FFFFh. If ST(OVM) = 0, the result is $dst = 8000\ 0000$ h.                                                                                                                                     |  |  |  |  |  |  |  |
| Cycles      | 1                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
| Status Bits | <ul> <li>If ST (SET COND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV 1 if an integer overflow occurs, unchanged otherwise.</li> </ul> |  |  |  |  |  |  |  |

- **UF** 0.
- N 0.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- C Unaffected.
- *Mode Bit* **OVM** Operation is affected by OVM bit value.

Example 1 ABSI R0,R0 Or ABSI R0

## **Before Instruction:**

R0 = 0FFFF FFCBh = -53

# **After Instruction:**

R0 = 035h = 53

Example 2 ABSI \*AR1,R3

## **Before Instruction:**

AR1 = 20h R3 = 0h Data at 20h = 0FFFF FFCBh = -53

# **After Instruction:**

AR1 = 20h R3 = 35h = 53 Data at 20h = 0FFFF FFCBh = - 53

| Syntax    | ABSI src2, dst1<br>   STI src3, dst2                                                                                 |
|-----------|----------------------------------------------------------------------------------------------------------------------|
| Operation | $ src2  \rightarrow dst1$<br>$   src3 \rightarrow dst2$                                                              |
| Operands  | src2indirect (disp = 0, 1, IR0, IR1)dst1register (R0 - R7)src3register (R0 - R7)dst2indirect (disp = 0, 1, IR0, IR1) |

#### Encoding

| 31            | 24 23      | 16 15  | 87     | 0   |
|---------------|------------|--------|--------|-----|
| 1 1 0 0 1 0 1 | dst1 0 0 0 | src3 d | st2 sr | rc2 |

**Description** An integer absolute value and an integer store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (ABSI) writes to the same register, then STI accepts as input the contents of the register before it is modified by the ABSI.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

An overflow occurs if  $src = 8000\ 0000$ h. If ST(OVM) = 1, the result is dst = 7FFF FFFFh. If ST(OVM) = 0, the result is  $dst = 8000\ 0000$ h.

# Cycles

Status Bits LUF Unaffected.

1

- **LV** 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.
- N 0.

**Z** 1 if a zero result is generated, 0 otherwise.

- V 1 if an integer overflow occurs, 0 otherwise.
- C Unaffected.

*Mode Bit* **OVM** Operation is affected by OVM bit value.

## Example

ABSI \*-AR5(1),R5

#### **Before Instruction:**

AR5 = 80 99E2h R5 = 0h R1 = 42h = 66 AR2 = 80 98FFh IR1 = 0Fh Data at 80 99E1h = 0FFFF FFCBh = -53Data at 80 98FFh = 2h = 2 LUF LV UF N Z V C = 0 0 0 0 0 0 0

## After Instruction:

AR5 = 80 99E2h R5 = 35h = 53 R1 = 42h = 66 AR2 = 80 98F0h IR1 = 0Fh Data at 80 99E1h = 0FFFF FFCBh = -53Data at 80 98FFh = 42h = 66 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax          | ADDC src, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Operation       | $dst + src + C \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |
| Operands        | src general addressing modes (G):<br>00 register (any register in CPU primary register file)<br>01 direct<br>10 indirect<br>11 immediate                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
|                 | dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
| Encoding        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |
| 31<br>0 0 0 0 0 | 24 23         16 15         8 7         0           0 1 0         G         dst         src                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| Description     | The sum of the <i>dst</i> and <i>src</i> operands and the C (carry) flag is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be signed integers.                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |
| Cycles          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |
| Status Bits     | <ul> <li>If ST (SET COND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV 1 if an integer overflow occurs, unchanged otherwise.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an integer overflow occurs, 0 otherwise.</li> <li>C 1 if a carry occurs, 0 otherwise.</li> </ul> |  |  |  |  |  |  |  |  |  |
| Mode Bit        | OVM Operation is affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| Example         | ADDC R1,R5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |
|                 | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|                 | R1 = 00FFFF 5C25h = - 41,947<br>R5 = 00FFFF 019Eh = - 65,122<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |
|                 | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|                 | R1 = 00FFFF 5C25h = - 41,947<br>R5 = 00FFFE 5DC4h = - 107,068<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |

Assembly Language Instructions

| Symax ADDUS SICZ, SICT, US | Syntax | ADDC3 | src2, src1, dst |
|----------------------------|--------|-------|-----------------|
|----------------------------|--------|-------|-----------------|

**Operation**  $src1 + src2 + C \rightarrow dst$ 

*Operands* src1, src2 both type 1 or type 2 three-operand addressing modes register mode (any register in CPU primary register file)

## Encoding

| Type | 1 |
|------|---|
|------|---|

| 31 24 2         | 3 16  | 15 8 | 7 0  |
|-----------------|-------|------|------|
| 0 0 1 0 0 0 0 0 | T dst | src1 | src2 |

#### Type 2

| 31 24 23        | 16    | 15 8 | 7 0  |
|-----------------|-------|------|------|
| 0 0 1 1 0 0 0 0 | T dst | src1 | src2 |

## Instruction Word Fields

|                                                          | Т  | <i>src1</i> addressing modes          | <i>src2</i> addressing modes          |
|----------------------------------------------------------|----|---------------------------------------|---------------------------------------|
| 00 register mode (any CPU register) register mode (any C |    | register mode (any CPU register)      |                                       |
| Type 1                                                   | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|                                                          | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|                                                          | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

|        | T src1 addressing modes |                                                      | src2 addressing modes                                |
|--------|-------------------------|------------------------------------------------------|------------------------------------------------------|
|        | 00                      | register mode (any CPU register)                     | 8-bit signed immediate                               |
| Type 2 | 01                      | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement)  |
| Type 2 | 10                      | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                               |
|        | 11                      | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

- **Description** The sum of the *src1* and *src2* operands and value of the C (carry) flag is loaded into the *dst* register. The *src1*, *src2*, and *dst* operands are assumed to be signed integers.
- Cycles 1

Status Bits If ST (SET COND) = 0, the condition flags are modified if the destination register is R0 - R11. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unaffected.

- LV 1 if an integer overflow occurs, unchanged otherwise.
- **U** 0.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** 1 if a carry occurs, 0 otherwise.
- *Mode Bit* **OVM** Operation is affected by OVM bit value.

| Syntax                      | ADDF src, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation                   | $dst + src \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Operands                    | src general addressing modes (G):<br>0 0 register (R0 – R11)<br>0 1 direct<br>1 0 indirect<br>1 1 immediate                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                             | <i>dst</i> register (R0 – R11)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Encoding<br>31<br>0 0 0 0 0 | 24 23 16 15 87 0<br>0 0 0 1 1 G dst src                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Description                 | The sum of the <i>dst</i> and <i>src</i> operands is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be floating-point numbers.                                                                                                                                                                                                                                                                                                                                          |  |  |
| Cycles                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| Status Bits                 | <ul> <li><i>s</i> LUF 1 if a floating-point underflow occurs, unchanged otherwise.</li> <li>LV 1 if a floating-point overflow occurs, unchanged otherwise.</li> <li>UF 1 if a floating-point underflow occurs, 0 otherwise.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an floating-point overflow occurs, 0 otherwise.</li> <li>V 1 if an floating-point overflow occurs, 0 otherwise.</li> <li>C Unaffected.</li> </ul> |  |  |
| Mode Bit                    | <b>OVM</b> Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| Example                     | ADDF *AR4++(IR1),R5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|                             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|                             | AR4 = 80 9800h<br>IR1 = 12Bh<br>R5 = 057980 0000h = $6.23750e+01$<br>Data at 80 9800h = $86B 2800h = 4.7031250e + 02$<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                             | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                             | AR4 = 80 992Bh<br>IR1 = 12Bh<br>R5 = 09052C 0000h = 5.3268750e+02<br>Data at 80 9800h = 86B 2800h = 4.7031250e + 02<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                            |  |  |

| Syntax    | ADDF3             | src2, src1, dst                                                               |
|-----------|-------------------|-------------------------------------------------------------------------------|
| Operation | src1 + src2       | $2 \rightarrow dst$                                                           |
| Operands  | src1, src2<br>dst | both type 1 or type 2 three-operand addressing modes register mode (R0 – R11) |

# Encoding

Type 1

| 31        | 24 23     | 16 15  | 87      | 0 |
|-----------|-----------|--------|---------|---|
| 0 0 1 0 0 | 0 0 0 1 T | dst sr | c1 src2 |   |

Type 2

| 31 24           | 3 | 16 15 | 8    | <u> </u> |
|-----------------|---|-------|------|----------|
| 0 0 1 1 0 0 0 0 |   | dst   | src1 | src2     |

# Instruction Word Fields

|                                                      | T                                                                   | src1 addressing modes                 | src2 addressing modes                 |
|------------------------------------------------------|---------------------------------------------------------------------|---------------------------------------|---------------------------------------|
| 00 register mode (R0 – R11) register mode (R0 – R11) |                                                                     | register mode (R0 – R11)              |                                       |
| Type 1                                               | pe 101indirect mode (disp = 0, 1, IR0, IR1)register mode (R0 - R11) |                                       | register mode (R0 – R11)              |
|                                                      | 10                                                                  | register mode (R0 – R11)              | indirect mode (disp = 0, 1, IR0, IR1) |
|                                                      | 11                                                                  | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

|        | Т  | <i>src1</i> addressing modes                         | <i>src2</i> addressing modes                         |
|--------|----|------------------------------------------------------|------------------------------------------------------|
|        |    |                                                      | indirect mode *+ARn(5-bit unsigned<br>displacement)  |
| Type 2 | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

- **Description** The sum of the *src1* and *src2* operands is loaded into the *dst* register. The *src1*, *src2*, and *dst* operands are assumed to be floating-point numbers.
- Cycles

1

Status Bits LUF 1 if a floating-point underflow occurs, unchanged otherwise.

- LV 1 if a floating-point overflow occurs, unchanged otherwise.
- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an floating-point overflow occurs, 0 otherwise.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.
- **Example** ADDF3 \*AR1(2), \*+AR1(8), R4

#### **Before Instruction:**

 $\begin{array}{l} AR1 = 2FF820h \\ R4 = 0h \\ Data at 22F F822h = 700 F000h = 1.28940e + 02 \\ Data at 22F F828h = 34C 2000h = 1.27590e + 01 \\ LUF LV UF N Z V C = 0 0 0 0 0 0 0 \end{array}$ 

#### After Instruction:

 $\begin{array}{l} \mbox{AR1} = 2F \ F820h \\ \mbox{R4} = 070DB2 \ 0000h = 1.41695313 \ e + 02 \\ \mbox{Data at } 22F \ F828h = 34C \ 2000h = 1.27590e + 01 \\ \mbox{LUF LV UF N Z V C} = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \end{array}$ 

| Syntax    | ADDF3 src2, src<br>   STF src3, dst2                        | c1, dst1                   |    |   |
|-----------|-------------------------------------------------------------|----------------------------|----|---|
| Operation | $src1 + src2 \rightarrow dst$<br>   $src3 \rightarrow dst2$ | 1                          |    |   |
| Operands  | dst1 register (R0 -<br>src3 register (R0 -                  | = 0, 1, IR0, IR1)<br>- R7) |    |   |
| Encoding  |                                                             |                            |    |   |
| 31        | 24 23                                                       | 16 15                      | 87 | 0 |

| 1 1 0 0 1 1 | 0 dst1 | src1 | src3 | dst2 | src2 |
|-------------|--------|------|------|------|------|

**Description** A floating-point addition and a floating-point store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STF) reads from a register and the operation being performed in parallel (ADDF3) writes to the same register, then STF accepts as input the contents of the register before it is modified by the ADDF3.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

## Cycles

1

Status Bits LUF 1 if a floating-point underflow occurs, unchanged otherwise.

- **LV** 1 if a floating-point overflow occurs, unchanged otherwise.
- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an floating-point overflow occurs, 0 otherwise.
- **C** Unaffected.
- *Mode Bit* OVM Operation is not affected by OVM bit value.

#### Example

ADDF3 \*+AR3(IR1),R2,R5 STF R4,\*AR2

#### **Before Instruction:**

 $\begin{array}{l} AR3 = 809800h \\ IR1 = 0A5h \\ R2 = 070C80\ 0000h = 1.4050e + 02 \\ R5 = 0h \\ R4 = 057B40\ 0000h = 6.281250e + 01 \\ AR2 = 80\ 98F3h \\ Data\ at\ 80\ 98A5h = 733\ C000h = 1.79750e + 02 \\ Data\ at\ 80\ 98F3h = 0h \\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

## **After Instruction:**

 $\begin{array}{l} AR3 = 80\ 9800h\\ IR1 = 0A5h\\ R2 = 070C80\ 0000h = 1.4050e+02\\ R5 = 082020\ 0000h = 3.20250e + 02\\ R4 = 057B40\ 0000h = 6.281250e + 01\\ AR2 = 80\ 98F3h\\ Data\ at\ 80\ 98A5h = 733\ C000h = 1.79750e + 02\\ Data\ at\ 80\ 98F3h = 57B\ 4000h = 6.28125e + 01\\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

| Syntax           | ADDI src, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Operation        | $dst + src \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| Operands <u></u> | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate</li> </ul>                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|                  | dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| Encoding         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| 00000            | 0 0 1 0 0 G dst src                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| Description      | The sum of the <i>dst</i> and <i>src</i> operands is loaded into the the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be signed integers.                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| Status Bits      | <ul> <li>If ST (SET COND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV 1 if an integer overflow occurs, unchanged otherwise.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an integer overflow occurs, 0 otherwise.</li> <li>C 1 if a carry occurs, 0 otherwise.</li> </ul> |  |  |  |  |  |  |
| Mode Bit         | OVM Operation is affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| Example          | ADDI R3,R7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|                  | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|                  | R3 = 0FFFF FFCBh = - 53<br>R7 = 35h = 53<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|                  | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                  | R3 = 0FFFF FFCBh = - 53<br>R7 = 0h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |

src2 addressing modes

Syntax ADDI3 src2, src1, dst

**Operation**  $src1 + src2 \rightarrow dst$ 

**Operands** both type 1 or type 2 three-operand addressing modes src1, src2 register mode (any register in CPU primary register file) dst

## Encoding

#### Type 1

| 31 24 23        | 16    | 15 8 | .7 <u>0</u> |
|-----------------|-------|------|-------------|
| 0 0 1 0 0 0 1 0 | T dst | src1 | src2        |

#### Type 2

| 31 24 23          |       | 16 15 | 87 0 |
|-------------------|-------|-------|------|
| 0 0 1 1 0 0 0 1 0 | T dst | src1  | src2 |

## **Instruction Word Fields**

TT

T

|        | T  | src1 addressing modes                 | <i>src2</i> addressing modes          |
|--------|----|---------------------------------------|---------------------------------------|
|        | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| Type 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
| Γ      | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|        | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

L

src1 addressing modes

|        |    | · · · · · · · · · · · · · · · · · · ·                |                                                      |
|--------|----|------------------------------------------------------|------------------------------------------------------|
|        | 00 | register mode (any CPU register)                     | 8-bit signed immediate                               |
| Type 2 | 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement)  |
| Type 2 | 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                               |
|        | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

1

**Description** The sum of the *src1* and *src2* operands is loaded into the *dst* register. The *src1*, *src2*, and *dst* operands are assumed to be signed integers.

Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unaffected.

- LV 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.
- N 1 if a negative result is generated, 0 otherwise.
- Z 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** 1 if a carry occurs, 0 otherwise.
- *Mode Bit* **OVM** Operation is affected by OVM bit value.

| Syntax    | ADDI3 src2, sro<br>   STI src3, dst2                      | c1, dst1                   |      |    |                                       |
|-----------|-----------------------------------------------------------|----------------------------|------|----|---------------------------------------|
| Operation | $src1 + src2 \rightarrow c$<br>   $src3 \rightarrow dst2$ | lst1                       |      |    |                                       |
| Operands  | dst1 register (R<br>src3 register (R                      | sp = 0, 1, IR0,<br>0 – R7) |      |    |                                       |
| Encoding  |                                                           |                            |      |    |                                       |
| 31        | 24 23                                                     | 16 15                      | 5    | 87 | · · · · · · · · · · · · · · · · · · · |
| 0 1 0 0   | 1 1 1 dst1 sr                                             | c1 src3                    | dst2 |    | src2                                  |

**Description** An integer addition and an integer store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (ADDI3) writes to the same register, then STI accepts as input the contents of the register before it is modified by the ADDI3.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

#### Cycles

#### Status Bits LUF Unaffected.

1

- LV 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.
- **N** 1 if a negative result is generated, 0 otherwise.
- Z 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** 1 if a carry occurs, 0 otherwise.

*Mode Bit* **OVM** Operation is affected by OVM bit value.

#### Example

ADDI3 \*AR0- -(IR0),R5,R0

## **Before Instruction:**

AR0 = 80 992Ch IR0 = 0Ch R5 = 0DCh = 220 R0 = 0h R3 = 35h = 53 AR7 = 80 983Bh Data at 80 992Ch = 12Ch = 300 Data at 80 983Bh = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

# **After Instruction:**

AR0 = 80 9920h IR0 = 0Ch R5 = 0DCh = 220 R0 = 208h = 520 R3 = 35h = 53 AR7 = 80 983Bh Data at 80 992Ch = 12Ch = 300 Data at 80 983Bh = 35h = 53 LUF LV UF N Z V C = 0 0 0 0 0 0 0

Ĩ

| Syntax                      | AND src, dst                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands                    | $dst \text{ AND } src \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                  |
| Operands                    | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate (not sign-extended)</li> </ul>                                                                                                                                                                            |
|                             | dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                                                                |
| Encoding<br>31<br>0 0 0 0 0 | 24 23 16 15 87 0<br>0 1 0 1 G dst src                                                                                                                                                                                                                                                                                                                                                   |
| Description                 | The bitwise logical-AND between the <i>dst</i> and <i>src</i> operands is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be unsigned integers.                                                                                                                                                                                              |
| Cycles                      | 1                                                                                                                                                                                                                                                                                                                                                                                       |
| Status Bits                 | <ul> <li>If ST (SET COND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF 0.</li> <li>N MSB of the output.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 0.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit                    | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                         |
| Example                     | AND R1,R2                                                                                                                                                                                                                                                                                                                                                                               |
|                             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                     |
|                             | R1 = 80h<br>R2 = 0AFFh<br>LUF LV UF N Z V C = 0 0 0 0 0 1                                                                                                                                                                                                                                                                                                                               |
|                             | After Instruction: 11                                                                                                                                                                                                                                                                                                                                                                   |
|                             | R1 = 80h<br>R2 = 80h<br>LUF LV UF N Z V C = 0 0 0 0 0 1                                                                                                                                                                                                                                                                                                                                 |

| ANIDO | <b></b> |              | ~ | <u> </u> |
|-------|---------|--------------|---|----------|
| AND3  | Bitwise | Logical-AND, | 3 | Operands |

| Syntax | AND3 | src2, | src1, dst |  |
|--------|------|-------|-----------|--|
|        |      |       |           |  |

Operation src1 & src2  $\rightarrow$  dst

Operands both type 1 or type 2 three-operand addressing modes src1, src2 register mode (any register in CPU primary register file) dst

# Encoding

# Type 1

| 31          | 24 23 | 16 15   | 87     | 0 |
|-------------|-------|---------|--------|---|
| 0 0 1 0 0 0 | 1 1 T | dst src | 1 src2 |   |

#### Type 2

| 31 24 23          | 16    | 15 8 | <u> </u> |
|-------------------|-------|------|----------|
| 0 0 1 1 0 0 0 1 1 | T dst | src1 | src2     |

## **Instruction Word Fields**

| Туре                                    | 1 |
|-----------------------------------------|---|
| .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | • |

|                                                                             | Т  | <i>src1</i> addressing modes          | <i>src2</i> addressing modes          |
|-----------------------------------------------------------------------------|----|---------------------------------------|---------------------------------------|
| 00 register mode (any CPU register) register mode (any CPU register)        |    | register mode (any CPU register)      |                                       |
| 1 01 indirect mode (disp = 0, 1, IR0, IR1) register mode (any CPU register) |    | register mode (any CPU register)      |                                       |
|                                                                             | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|                                                                             | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

| Type 2 | 2 |
|--------|---|
|--------|---|

| Т  | src1 addressing modes                                | src2 addressing modes                                |  |
|----|------------------------------------------------------|------------------------------------------------------|--|
| 00 | register mode (any CPU register)                     | 8-bit signed immediate                               |  |
| 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement)  |  |
| 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                               |  |
| 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |  |

- **Description** The bitwise logical-AND between the *src1* and *src2* operands is loaded into the dst register. The *src1*, *src2*, and *dst* operands are assumed to be unsigned integers.
- Cycles
- Status Bits If ST (SET COND) = 0 and the destination register is R0 R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.
  - LUF Unaffected.
  - LV Unaffected.
  - **UF** 0.

- **N** MSB of the output.
- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | AND src2, src1, c                                      | lst1                       |    |  |
|-----------|--------------------------------------------------------|----------------------------|----|--|
| Operation | src1 AND src2 $\rightarrow$    src3 $\rightarrow$ dst2 | dst1                       |    |  |
| Öperands  | dst1 register (R0 -<br>src3 register (R0 -             | = 0, 1, IR0, IR1)<br>- R7) |    |  |
| Encoding  |                                                        |                            |    |  |
| 31        | 24 23                                                  | 1615                       | 87 |  |

| 31            | 24 23     | 1615   |     | 0    |
|---------------|-----------|--------|-----|------|
|               |           |        |     |      |
| 1 1 0 1 0 0 0 | dst1 src1 | src3 d | st2 | src2 |

**Description** A bitwise logical-AND and an integer store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (AND3) writes to the same register, then STI accepts as input the contents of the register before it is modified by the AND3.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

#### Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** 0.
- **N** MSB of the output.
- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

#### Example

AND3 \*+AR1(IR0),R4,R7 || STI R3,\*AR2

# **Before Instruction:**

AR1 = 8099F1h IR0 = 8h R4 = 0A323h R7 = 0h R3 = 35h = 53 AR2 = 80 983Fh Data at 80 99F9h = 5C53h Data at 80 983Fh = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

# After Instruction:

AR1 = 80 99F1h R0 = 8h R4 = 0A323h R7 = 03h R3 = 35h = 53 AR2 = 80 983Fh Data at 80 99F9h = 5C53h Data at 80 983Fh = 35h = 53 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax          | ANDN src, dst                                                                                                                                                                                                                                                                                                                     |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Operation       | $dst AND \sim src \rightarrow dst$                                                                                                                                                                                                                                                                                                |  |  |  |
| Operands        | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate (not sign-extended)</li> </ul>                                                                                                                      |  |  |  |
|                 | dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                          |  |  |  |
| Encoding        |                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 31<br>0 0 0 0 0 | 24 23 16 15 8 7 0<br>0 0 1 1 0 G dst src                                                                                                                                                                                                                                                                                          |  |  |  |
| Description     | The bitwise logical-AND between the <i>dst</i> operand and the bitwise logical complement (~) of the <i>src</i> operand is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be unsigned integers.                                                                                       |  |  |  |
| Cycles          | 1                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| Status Bits     | If ST (SET COND) = 0 and the destination register is R0 – R11, the condition<br>flags are modified. If ST (SET COND) = 1, they are modified for all destina-<br>tion registers.<br>LUF Unaffected.<br>LV Unaffected.<br>UF 0.<br>N MSB of the output.<br>Z 1 if a zero result is generated, 0 otherwise.<br>V 0.<br>C Unaffected. |  |  |  |
| Mode Bit        | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                   |  |  |  |
| Example         | ANDN @980Ch,R2                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                 | Before Instruction:                                                                                                                                                                                                                                                                                                               |  |  |  |
|                 | DP = 80h $R2 = 0C2Fh$ Data at 80 980Ch = 0A02h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0<br>After Instruction:<br>DP = 80h $R2 = 042Dh$ Data at 80 980Ch = 0A02h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                  |  |  |  |
|                 |                                                                                                                                                                                                                                                                                                                                   |  |  |  |

**Operation** src1 AND ~ src2  $\rightarrow$  dst

*Operands* src1, src2 both type 1 or type 2 three-operand addressing modes dst register mode (any register in CPU primary register file)

#### Encoding

Type 1

| 31 2            | 24 23            | 16 15 | 87   | 0 |
|-----------------|------------------|-------|------|---|
| 0 0 1 0 0 0 1 0 | 0 0 T <i>dst</i> | src1  | src2 |   |

Type 2

| 31 24 2           | 3 16  | 15 8 | 7 0  |
|-------------------|-------|------|------|
| 0 0 1 1 0 0 1 0 0 | T dst | src1 | src2 |

Instruction Word Fields

|        | Т  | <i>src1</i> addressing modes          | <i>src2</i> addressing modes          |
|--------|----|---------------------------------------|---------------------------------------|
|        | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| Type 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|        | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|        | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

| ſ | Т  | <i>src1</i> addressing modes                         | src2 addressing modes                                |
|---|----|------------------------------------------------------|------------------------------------------------------|
| ſ | 00 | register mode (any CPU register)                     | 8-bit signed immediate                               |
| 2 | 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement)  |
|   | 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                               |
| ſ | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

Type 2

**Description** The bitwise logical-AND between the *src1* operand and the bitwise logical complement (~) of the *src2* operand is loaded into the *dst* register. The *src1*, *src2*, and *dst* operands are assumed to be unsigned integers.

Cycles

٠.

Status Bits LUF Unaffected.

1

LV Unaffected.

**UF** 0.

**N** MSB of the output.

- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Syntax ASH count, dst

**Operation** If (count  $\ge$  0):  $dst << count \rightarrow dst$ Else:

 $dst >> |count| \rightarrow dst$ 

*Operands* count general addressing modes (G):

- 0 0 register (any register in CPU primary register file)
- 0 1 direct
- 1 0 indirect
- 1 1 immediate

dst register (any register in CPU primary register file)

#### Encoding

| 31    | 24 23         | 16 15 | .87   | 0 |
|-------|---------------|-------|-------|---|
| 0 0 0 | 0 0 0 1 1 1 G | dst   | count |   |

**Description** The seven least-significant bits of the *count* operand are used to generate the twos-complement shift count of up to 32 bits.

If the *count* operand is greater than zero, the *dst* operand is left-shifted by the value of the *count* operand. Low-order bits shifted in are zero-filled, and high-order bits are shifted out through the C (carry) bit.

Arithmetic left-shift:



If the *count* operand is less than zero, the *dst* operand is right-shifted by the absolute value of the *count* operand. The high-order bits of the *dst* operand are sign-extended as it is right-shifted. Low-order bits are shifted out through the C (carry) bit.

Arithmetic right-shift:



If the *count* operand is zero, no shift is performed, and the C (carry) bit is set to 0. The *count* and *dst* operands are assumed to be signed integers.

1

## Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unaffected.

- **LV** 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.
- N MSB of the output.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** Set to the value of the last bit shifted out. 0 for a shift *count* of 0.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example 1 ASH R1,R3

#### **Before Instruction:**

R1 = 10h = 16 R3 = 0A E000h LUF LV UF N Z V C = 0 0 0 0 0 0 0

#### After Instruction:

R1 = 10h R3 = 0E0000 0000h LUF LV UF N Z V C = 0 1 0 1 0 1 0

Example 2 ASH @98C3h,R5

#### **Before Instruction:**

DP = 80hR5 = 0AEC0 0001h Dáta at 80 98C3h = 0FFE8 = -24 LUF LV UF N Z V C = 0 0 0 0 0 0 0

#### After Instruction:

DP = 80hR5 = 0FFFF FFAEhData at 80 98C3h = 0FFE8 = -24LUF LV UF N Z V C = 0 0 0 1 0 0 1

| Syntax    | ASH3 count, src, dst                                                                              |                                                                                                                |  |  |
|-----------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--|--|
| Operation | if $(count \ge 0)$<br>$src < count \rightarrow dst$<br>Else:<br>$src >   count   \rightarrow dst$ |                                                                                                                |  |  |
| Operands  | src, count<br>dst                                                                                 | both type 1 or type 2 three-operand addressing modes register mode (any register in CPU primary register file) |  |  |

# Encoding

# Type 1

| 31 24 23          | 16            | 15 8 | 7 0  |
|-------------------|---------------|------|------|
| 0 0 1 0 0 0 1 0 1 | T <i>ds</i> t | src1 | src2 |

#### Type 2

| 31    | 24 23    | 16 15   | 87     | 0 |
|-------|----------|---------|--------|---|
| 0 0 1 | 100101 T | dst src | 1 src2 | • |

# Instruction Word Fields

|        | Т  | src1 addressing modes                 | src2 addressing modes                 |
|--------|----|---------------------------------------|---------------------------------------|
|        | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| Type 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|        | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|        | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

|        | Т  | src1 addressing modes                                | src2 addressing modes                                |
|--------|----|------------------------------------------------------|------------------------------------------------------|
| Type 2 | 00 | register mode (any CPU register)                     | 8-bit signed immediate                               |
|        | 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement)  |
|        | 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                               |
|        | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

**Description** The seven least-significant bits of the *count* operand are used to generate the twos-complement shift count.

If the *count* operand is greater than zero, the *src* operand is left-shifted by the value of *count*. Low-order bits shifted in are zero-filled, and high-order bits are shifted out through the status register's C (carry) bit.

Arithmetic left-shift:



If the *count* operand is less than zero, the *src* operand is right-shifted by the absolute value of *count* (e.g. -4 = right-shift 4. The high-order bits of the *src* operand are sign-extended as they are right-shifted. Low-order bits are shifted out through the C (carry) bit.

Arithmetic right-shift:



If the *count* operand is zero, no shift is performed, and the C (carry) bit is set to 0. The *count*, *src*, and *dst* operands are assumed to be signed integers.

Cycles

Status Bits LUF Unaffected.

1

- LV 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.
- N MSB of the output.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** Set to the value of the last bit shifted out. 0 for a shift *count* of 0.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | ASH3 count,<br>   STI src3, dst2                                                                                                                             | src2, dst1 |      |      |  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------|------|--|--|
| Operation | If $(count \ge 0)$ :<br>$src2 << count \rightarrow dst1$<br>Else:<br>$src2 >>  count  \rightarrow dst1$<br>$   src3 \rightarrow dst2$                        |            |      |      |  |  |
| Operands  | count register (R0 — R7) $src2$ indirect (disp = 0, 1, IR0, IR1) $dst1$ register (R0 — R7) $src3$ register (R0 — R7) $dst2$ indirect (disp = 0, 1, IR0, IR1) |            |      |      |  |  |
| Encoding  |                                                                                                                                                              |            |      |      |  |  |
| 31        | 24 23                                                                                                                                                        | 16         | 515  | 87   |  |  |
| 1 1 0 1   | 0 0 1 <i>dst</i> 1 <i>co</i>                                                                                                                                 | Int src3   | dst2 | src2 |  |  |

**Description** The seven least-significant bits of the *count* operand register are used to generate the twos-complement shift count of up to 32 bits.

If the *count* operand is greater than zero, the *dst* operand is left-shifted by the value of the *count* operand. Low-order bits shifted in are zero-filled, and high-order bits are shifted out through the C (carry) bit.

Arithmetic left-shift:



If the *count* operand is less than zero, the *dst* operand is right-shifted by the absolute value of the *count* operand. The high-order bits of the *dst* operand are sign-extended as it is right-shifted. Low-order bits are shifted out through the C (carry) bit.

Arithmetic right-shift:



If the *count* operand is zero, no shift is performed, and the C (carry) bit is set to 0. The *count* and *dst* operands are assumed to be signed integers.

All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (ASH3) writes to the same register, then STI accepts as input the contents of the register before it is modified by the ASH3. If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

Cycles

#### Status Bits LUF Unaffected.

1

- LV 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.
- N MSB of the output.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** Set to the value of the last bit shifted out. 0 for a shift count of 0.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example ASH3 R1,\*AR6++(IR1),R0

∥STI R5,\*AR2

#### **Before Instruction:**

AR6 = 80 9900h IR1 = 8Ch R1 = 0FFE8h = -24 R0 = 0h R5 = 35h = 53 AR2 = 80 98A2h Data at 80 9900h = 0AE00 0000h Data at 80 98A2h = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0 0

#### **After Instruction:**

AR6 = 80 998Ch IR1 = 8Ch R1 = 0FFE8h = -24R0 = 0FFFF FFAEh R5 = 35h = 53 AR2 = 80 98A2h Data at 80 9900h = 0AE00 0000h Data at 80 98A2h = 35h = 53 LUF LV UF N Z V C = 0 0 0 1 0 0 0

Assembly Language Instructions

| Syntax      | Bcond src                                                                                                                                                                                                                                                                         |  |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Operation   | If <i>cond</i> is true:<br>If <i>src</i> is in register addressing mode (any register in CPU primary<br>register file),<br><i>src</i> $\rightarrow$ PC.<br>If <i>src</i> is in PC-relative mode (label or address),<br>displacement + PC + 1 $\rightarrow$ PC.<br>Else, continue. |  |  |  |  |
| Operands    | <i>src</i> conditional-branch addressing modes (B):<br>0 register<br>1 PC-relative                                                                                                                                                                                                |  |  |  |  |
| Encoding    |                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 31          | <u>24 23 16 15 8 7 0</u>                                                                                                                                                                                                                                                          |  |  |  |  |
| 0 1 1 0     | 1 0 B 0 0 0 0 <i>cond</i> register or displacement                                                                                                                                                                                                                                |  |  |  |  |
| Description | B <i>cond</i> signifies a standard branch that executes in four cycles. A branch is performed if the condition is true (since a pipeline flush also occurs on a true condition; see Section 10.2 on page 10-4). If the <i>src</i> operand is expressed                            |  |  |  |  |

condition; see Section 10.2 on page 10-4). If the *src* operand is expressed in register addressing mode, the contents of the specified register are loaded into the PC. If the *src* operand is expressed in PC-relative mode, the assembler generates a displacement: displacement = label – (PC of branch instruction + 1). This displacement is stored as a 16-bit signed integer in the 16 least significant bits of the branch instruction word. This displacement is added to the PC of the branch instruction plus 1 to generate the new PC.

The TMS320C40 provides 20 condition codes that can be used with this instruction (see Section 11.2 on page11-10 for a list of condition mnemonics, encoding, and flags).

Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

# *Mode Bit* OVM Operation is not affected by OVM bit value.

# Example BZ R0

# **Before Instruction:**

PC = 2B00h R0 = 0003 FF00h LUF LV UF N Z V C = 0 0 0 0 0 0 0

## **After Instruction:**

PC = 3FF00h R0 = 0003 FF00h LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax    | BcondAF src                                                         |
|-----------|---------------------------------------------------------------------|
| Operation | If ( <i>cond</i> is true)                                           |
|           | If ( <i>src</i> is a register)                                      |
|           | $src \rightarrow PC$                                                |
|           | If ( <i>src</i> is a displacement)                                  |
|           | src + PC of branch + 3 $\rightarrow$ PC                             |
|           | Else:                                                               |
|           | If ( <i>cond</i> is false)                                          |
|           | annul execute phase results of next three instructions and continue |
|           |                                                                     |

*Operands* src conditional-branch addressing modes

#### Encoding

| 31            | 24 23   | 16 15 | 8 7                      | 0 |
|---------------|---------|-------|--------------------------|---|
| 0 1 1 0 1 0 B | 0 1 0 1 | cond  | register or displacement |   |

#### Instruction Word Fields

| В | <i>src</i> addressing modes |
|---|-----------------------------|
| 0 | register mode               |
| 1 | PC-relative mode            |

**Description** If the condition is true, a branch and the three instructions following the branch instruction are executed. If the condition is false, it annuls the effect of the execute phase of the next three instructions and execution continues. If the *src* operand is in register mode, then the contents of the specified register are loaded into the PC. If the *src* operand is in PC-relative mode, then the sum of the PC of the branch instruction + 3 and the *src* is loaded into the PC. In PC-relative mode the *src* field is interpretted as a 16-bit signed interger.

None of the three instructions following the B*cond*AF may be an instruction that modifies the program flow. Interrupts are disabled for the duration of the B*cond*AF instruction. B*cond*AF is particular useful for controlling the exit at the bottom of a loop.

Cycles

# Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | BcondAT src                                                                                                                                                                                                                                                                                                    |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | If ( <i>cond</i> is true)<br>If ( <i>src</i> is a register)<br>$src \rightarrow PC$<br>annul execute phase results of next three instructions.<br>If ( <i>src</i> is a displacement)<br>$src + PC$ of branch +3 $\rightarrow PC$<br>annul execute phase results of next three instructions.<br>Else, continue. |
|           |                                                                                                                                                                                                                                                                                                                |

*Operands* src conditional-branch addressing modes

#### Encoding

| 31    | 24 23           | 16 15 | 87                       | 0 |
|-------|-----------------|-------|--------------------------|---|
| 0 1 1 | 0 1 0 B 0 0 1 1 | cond  | register or displacement |   |

Instruction Word Fields

| В | <i>src</i> addressing modes |
|---|-----------------------------|
| 0 | register mode               |
| 1 | PC-relative mode            |

**Description** If the condition is true, it performs a branch and annuls the effect of the execute phase of the next three instructions. If the *src* operand is expressed in register mode, then the contents of the specified register are loaded into the PC. If the *src* operand is in PC-relative mode, then the sum of the PC of the branch instruction + 3 and the *src* is loaded into the PC. In PC-relative mode, the *src* field is interpreted as a 16-bit signed interger.

None of the three instructions following the B*cond*AT may be an instruction that modifies the program flow. Interrupts are disabled for the duration of the B*cond*AT instruction.

BcondAT instruction will not annul the status signals at the external interfaces. The BcondAT is particular useful for controlling the entry at the top of the loop.  $\Sigma^{-1}$ 

| Cycles      | 1                                                      |
|-------------|--------------------------------------------------------|
| Status Bits | LUF Unaffected.                                        |
|             | LV Unaffected.                                         |
|             | UF Unaffected.                                         |
|             | N Unaffected.                                          |
|             | Z Unaffected.                                          |
|             | V Unaffected.                                          |
|             | C Unaffected.                                          |
| Mode Bit    | <b>OVM</b> Operation is not affected by OVM bit value. |

| Syntax    | BcondD src                                                                                                                                                                                                                                                                       |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | If <i>cond</i> is true:<br>If <i>src</i> is in register addressing mode (any register in CPU primary<br>register file)<br><i>src</i> $\rightarrow$ PC.<br>If <i>src</i> is in PC-relative mode (label or address),<br>displacement + PC + 3 $\rightarrow$ PC.<br>Else, continue. |
| Operands  | <i>src</i> conditional-branch addressing modes (B):<br>0 register<br>1 PC-relative                                                                                                                                                                                               |
| Encoding  |                                                                                                                                                                                                                                                                                  |
| 31        | <u>24 23 16 15 87 0</u>                                                                                                                                                                                                                                                          |
| 0 1 1 0 1 | 1 0 B 0 0 0 1 <i>cond</i> register or displacement                                                                                                                                                                                                                               |

**Description** BcondD signifies a delayed branch that allows the three instructions after the delayed branch to be fetched before the PC is modified. The effect is a single-cycle branch, and the three instructions following BcondD will not affect the cond. None of the three instructions following BcondD may be an instruction that modifies program flow.

A branch is performed if the condition is true. If the *src* operand is expressed in register addressing mode, the contents of the specified register are loaded into the PC. If the *src* operand is expressed in PC-relative mode, the assembler generates a displacement: displacement = label – (PC of branch instruction + 3). This displacement is stored as a 16-bit signed integer in the 16 least significant bits of the branch instruction. This displacement is added to the PC of the branch instruction plus 3 to generate the new PC. The TMS320C40 provides 20 condition codes that can be used with this instruction (see Section 11.2 on page 11-10 for a list of condition mnemonics, encoding, and flags).

#### Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

**Example** BNZD 36 (36 = 24h)

# **Before Instruction:**

PC = 50h LUF LV UF N Z V C = 0 0 0 0 0 0 0

# **After Instruction:**

PC = 77h LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax                      | BR src                                                                                                     |
|-----------------------------|------------------------------------------------------------------------------------------------------------|
| Operation                   | $PC + 1 + src \rightarrow PC$                                                                              |
| Operands                    | src 24-bit signed immediate displacement                                                                   |
| Encoding<br>31<br>0 1 1 0 0 | 24 23 16 15 8 7 0<br>0 0 0 0 <i>src</i> (displacement)                                                     |
| Description                 | Performs an unconditional delayed branch. The <i>src</i> operand is assumed to be a 24-bit signed integer. |
| Cycles                      | 4                                                                                                          |
| Status Bits                 | LUF Unaffected.<br>LV Unaffected.<br>UF Unaffected.                                                        |

**OVM** Operation is not affected by OVM bit value.

Ν

Ζ

V C

Mode Bit

Unaffected.

Unaffected. Unaffected.

Unaffected.

.

| Syntax                      | BRD src                                                                                                                                                                  |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                   | $PC + 3 + src \rightarrow PC$                                                                                                                                            |
| Operands                    | src 24-bit signed immediate displacement                                                                                                                                 |
| Encoding<br>31<br>0 1 1 0 ( | 24 23 16 15 8 7 0<br>1 0 0 1 <i>src</i> (displacement)                                                                                                                   |
| Description                 | Performs an unconditional delayed branch. The <i>src</i> operand is assumed to be a 24-bit signed integer. Interrupts are disabled during the BRD instruction.           |
|                             | The three instructions following the BRD instruction are fetched and executed. None of these three instructions may modify the program flow (e.g., affect the PC value). |
| Cycles                      | 1                                                                                                                                                                        |
| Status Bits                 | LUFUnaffected.LVUnaffected.UFUnaffected.NUnaffected.ZUnaffected.VUnaffected.CUnaffected.                                                                                 |
| Mode Rit                    | OVM Operation is not affected by OVM bit value                                                                                                                           |

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax | CALL | src |
|--------|------|-----|
|--------|------|-----|

**Operation** Next PC  $\rightarrow$  \*(++SP) PC + 1 + src  $\rightarrow$  PC

**Operands** src 24-bit signed immediate displacement

## Encoding

| 31            | 24 23 | 16 15    | 87         | 0 |
|---------------|-------|----------|------------|---|
| 0 1 1 0 0 0 1 | 0     | src (dis | placement) |   |

**Description** Performs a call. The next PC value is pushed onto the system stack. The *src* operand + 1 + PC address of the CALL is loaded into the PC. The *src* operand is assumed to be a 24-bit signed immediate operand (displacement).

Cycles

Status Bits LUF Unaffected.

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

| Mode Bit | <b>OVM</b> Operation is not affected by OVM bit value. |
|----------|--------------------------------------------------------|
|----------|--------------------------------------------------------|

| Syntax    | CALL cond src                                                                                                                                                                                                                                                                                             |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | If cond is true:<br>Next PC $\rightarrow$ *++SP<br>If <i>src</i> is in register addressing mode (any register in CPU primary<br>register file),<br><i>src</i> $\rightarrow$ PC.<br>If <i>src</i> is in PC-relative mode (label or address),<br>displacement + PC + 1 $\rightarrow$ PC.<br>Else, continue. |
| Operands  | <i>src</i> conditional-branch addressing modes (B):<br>0 register<br>1 PC-relative                                                                                                                                                                                                                        |
| Encoding  |                                                                                                                                                                                                                                                                                                           |
| 31        | <u>24 23 16 15 8 7 0</u>                                                                                                                                                                                                                                                                                  |
| 0 1 1 1   | 0 0 B 0 0 0 0 <i>cond</i> register or displacement                                                                                                                                                                                                                                                        |
|           |                                                                                                                                                                                                                                                                                                           |

**Description** A call is performed if the condition is true. If the condition is true, the next PC value is pushed onto the system stack. If the *src* operand is expressed in register addressing mode, the contents of the specified register are loaded into the PC. If the *src* operand is expressed in PC-relative mode, the assembler generates a displacement: displacement = label – (PC of call instruction + 1). This displacement is stored as a 16-bit signed integer in the 16 least significant bits of the call instruction word. This displacement is added to the PC of the call instruction plus 1 to generate the new PC.

The TMS320C40 provides 20 condition codes that can be used with this instruction (see Section 11.2 on page 11-10 for a list of condition mnemonics, encoding, and flags).

#### Cycles

Status Bits LUF Unaffected.

5

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- **C** Unaffected.

Mode Bit OVM Operation is not affected by OVM bit value.

Assembly Language Instructions

**Example** CALLNZ R5

# **Before Instruction:**

PC = 123h SP = 80 9835h R5 = 789h LUF LV UF N Z V C = 0 0 0 0 0 0 0

## **After Instruction:**

 $\begin{array}{l} PC = 789h \\ SP = 80\ 9836h \\ R5 = 789h \\ Data \ at \ 80\ 9836h = 124h \\ LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ \ 0 \ \ 0 \ \ 0 \ \ 0 \ \ 0 \end{array}$ 

# **CMPF** Compare Floating-Point Values

| Syntax         | CMPF src, dst                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation      | dst – src                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Operands       | src general addressing modes (G):<br>0 0 register (R0 – R11)<br>0 1 direct<br>1 0 indirect<br>1 1 immediate                                                                                                                                                                                                                                                                                                                               |  |  |
|                | dst register (R0 – R11)                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| Encoding<br>31 | 24 23 16 15 <u>8 7 0</u>                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 0 0 0 0 0      |                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| Description    | The <i>src</i> operand is subtracted from the <i>dst</i> operand. The result is not loaded into any register, thus allowing for nondestructive compares. The <i>dst</i> and <i>src</i> operands are assumed to be floating-point numbers.                                                                                                                                                                                                 |  |  |
| Cycles         | 1                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Status Bits    | <ul> <li>LUF 1 if a floating-point underflow occurs, unchanged otherwise.</li> <li>LV 1 if a floating-point overflow occurs, unchanged otherwise.</li> <li>UF 1 if a floating-point underflow occurs, 0 otherwise.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if a floating-point overflow occurs, 0 otherwise.</li> <li>C Unaffected.</li> </ul> |  |  |
| Mode Bit       | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| Example        | CMPF *+AR4,R6                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|                | AR4 = 80 98F2h<br>R6 = 070C80 0000h = $1.4050e+02$<br>Data at 80 98F3h = 070C 8000h = $1.4050e + 02$<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                               |  |  |
|                | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |

After Instruction:

 $AR4 = 80 \ 98F2h$   $R6 = 070C80 \ 0000h = 1.4050e + 02$   $Data \ at \ 80 \ 98F3h = 070C \ 8000h = 1.4050e + 02$   $LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 1 \ 0 \ 0$ 

Syntax CMPF3 src2, src1

**Operation** src1 – src2

*Operands* src1 – src2 both type 1 or type 2 three-operand addressing modes

# Encoding

Type 1

| 31            | 24 23 | 16 15       | 87     | 0   |
|---------------|-------|-------------|--------|-----|
| 0 0 1 0 0 0 1 | 10T00 | 0 0 0 0 src | 1 src2 | 1 1 |

#### Type 2

| 31          | 24 23   | 16 15     | 87        | 0 |
|-------------|---------|-----------|-----------|---|
| 0 0 1 1 0 0 | 1 0 1 T | 0 0 0 0 0 | src1 src2 |   |

## Instruction Word Fields

| Type 1 |
|--------|
|--------|

| Т  | <i>src1</i> addressing modes          | <i>src2</i> addressing modes          |
|----|---------------------------------------|---------------------------------------|
| 00 | register mode (R0 — R11)              | register mode (R0 — R11)              |
| 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (R0 — R11)              |
| 10 | register mode (R0 — R11)              | indirect mode (disp = 0, 1, IR0, IR1) |
| 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

|        | T  | <i>src1</i> addressing modes                         | <i>src2</i> addressing modes                         |
|--------|----|------------------------------------------------------|------------------------------------------------------|
|        | 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement)  |
| Type 2 | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

- **Description** The *src2* operand is subtracted from the *src1* operand. The result is not loaded into any register. This allows for nondestructive compares. The *src1* and *src2* operands are assumed to be floating-point numbers.
- Cycles

1

Status Bits LUF 1 if a floating-point underflow occurs, unchanged otherwise.

- LV 1 if a floating-point overflow occurs, unchanged otherwise.
- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- **N** 1 if a negative result is generated, 0 otherwise.
- Z 1 if a zero result is generated, 0 otherwise.
- V 1 if a floating-point overflow occurs, 0 otherwise.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Syntax CMPI src, dst

**Operation** dst – src

**Operands** src general addressing modes (G):

- 00 register (any register in CPU primary register file)
- 0 1 direct
- 10 indirect
- 11 immediate

dst register (any register in CPU primary register file)

### Encoding

| 31    | 24 23    | 16 15 | 87  | 0 |
|-------|----------|-------|-----|---|
| 0 0 0 | 001001 G | dst   | src |   |

**Description** The *src* operand is subtracted from the *dst* operand. The result is not loaded into any register, thus allowing for nondestructive compares. The *dst* and *src* operands are assumed to be signed integers.

| Cycles      | 1                                                                                                                                                                                                                                                                                                                                                 |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status Bits | <ul> <li>LUF Unaffected.</li> <li>LV 1 if an integer overflow occurs, unchanged otherwise.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an integer overflow occurs, 0 otherwise.</li> <li>C 1 if a borrow occurs, 0 otherwise.</li> </ul> |
| Mode Bit    | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                   |
| Example     | CMPI R3,R7                                                                                                                                                                                                                                                                                                                                        |
|             | Before Instruction:                                                                                                                                                                                                                                                                                                                               |
|             | R3 = 898h = 2200<br>R7 = 3E8h = 1000<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                         |
|             | After Instruction:                                                                                                                                                                                                                                                                                                                                |
|             | R3 = 898h = 2200<br>R7 = 3E8h = 1000<br>LUF LV UF N Z V C = 0 0 0 1 0 0 0                                                                                                                                                                                                                                                                         |

# CMPI3 Compare Integer, 3 Operands

# Syntax CMPI3 src2, src1

**Operation** src1 – src2

**Operands** src1 – src2 both type 1 or type 2 three-operand addressing modes

# Encoding

Type 1

| <u>31</u> 24 23   | 16 1   | 5 8  | .7 <u>0</u> |
|-------------------|--------|------|-------------|
| 0 0 1 0 0 0 1 1 1 | ТООООО | src1 | src2        |

### Type 2

| 31 24 23          | 16          | 15 8 | 7 0  |
|-------------------|-------------|------|------|
| 0 0 1 1 0 0 1 1 1 | Т 0 0 0 0 0 | src1 | src2 |

## **Instruction Word Fields**

|        | T  | src1 addressing modes                 | <i>src2</i> addressing modes          |
|--------|----|---------------------------------------|---------------------------------------|
|        | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| Type 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|        | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|        | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

|        | T src1 addressing modes |                                                      | <i>src2</i> addressing modes                         |
|--------|-------------------------|------------------------------------------------------|------------------------------------------------------|
|        | 00                      | register mode (any CPU register)                     | 8-bit signed immediate                               |
|        |                         | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement)  |
| Type 2 | 10                      | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                               |
|        | 11                      | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

**Description** The *src2* operand is subtracted from the *src1* operand. The result is not loaded into any register. This allows for nondestructive compares. The *src1* and *src2* operands are assumed to be signed integers.

Cycles

Status Bits LUF Unaffected.

1

LV 1 if an integer overflow occurs, unchanged otherwise.UF 0.

N 1 if a negative result is generated, 0 otherwise.

**Z** 1 if a zero result is generated, 0 otherwise.

V 1 if an integer overflow occurs, 0 otherwise.

**C** 1 if a borrow occurs, 0 otherwise.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | DB <i>cond</i> ARn, <i>src</i>                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | $\begin{array}{l} ARn-1 \to ARn \\ If \ \textit{cond} \ is \ true \ and \ ARn \geq 0: \\ If \ \textit{src} \ is \ in \ register \ addressing \ mode \ (any \ register \ in \ CPU \ primary \\ register \ file), \\ \textit{src} \to PC. \\ If \ \textit{src} \ is \ in \ PC\text{-relative} \ mode \ (label \ or \ address), \\ displacement + PC + 1 \to PC. \\ Else, \ continue. \end{array}$ |
| Operands  | <i>src</i> conditional-branch addressing modes (B):<br>0 register                                                                                                                                                                                                                                                                                                                               |

1 PC-relative

ARn register (any register in CPU primary register file)

#### Encoding

| 31            | 24 23 | 16 15 | 87                       | 0   |
|---------------|-------|-------|--------------------------|-----|
| 0 1 1 0 1 1 B | ARn 0 | cond  | register or displacement | 1 1 |

**Description** DB*cond* signifies a standard branch that executes in four cycles because the pipeline must be flushed if *cond* is true. The specified auxiliary register is decremented and a branch is performed if the condition is true and the specified auxiliary register is greater than or equal to zero.

> The auxiliary register is treated as a 32-bit signed integer. The most significant eight bits are unmodified by the decrement operation. The comparison of the auxiliary register uses only the 32 least significant bits of the auxiliary register. Note that the branch condition does not depend on the auxiliary register decrement.

> If the *src* operand is expressed in register addressing mode, the contents of the specified register are loaded into the PC. If the *src* operand is expressed in PC-relative addressing mode, the assembler generates a displacement: displacement = label – (PC of branch instruction + 1). This integer is stored as a 16-bit signed integer in the 16 least significant bits of the branch instruction word. This displacement is added to the PC of the branch instruction plus 1 to generate the new PC.

The TMS320C40 provides 20 condition codes that can be used with this instruction (see Section 11.2 on page 11-10 for a list of condition mnemonics, encoding, and flags).

| Cycles      | 4                                                                                                                                                                               |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status Bits | <ul> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF Unaffected.</li> <li>N Unaffected.</li> <li>Z Unaffected.</li> <li>V Unaffected.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit    | OVM Operation is not affected by OVM bit value.                                                                                                                                 |
| Example     | DBLT AR3,R2                                                                                                                                                                     |
|             | Before Instruction:                                                                                                                                                             |
|             | PC = 5Fh<br>AR3 = 12h<br>R2 = 9Fh<br>LUF LV UF N Z V C = 0 0 0 1 0 0 0<br><u>After Instruction:</u>                                                                             |

PC = 9Fh AR3 = 11h R2 = 9Fh LUF LV UF N Z V C = 0 0 0 1 0 0 0

11

| Syntax    | DB <i>cond</i> D ARn, <i>src</i>                                                                                                                                                                                                                                                                                                               |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | $\begin{array}{l} ARn - 1 \to ARn \\ If  \textit{cond} \text{ is true and } ARN \geq 0: \\ If  \textit{src} \text{ is in register addressing mode}  (any register in CPU primary register file), \\ \textit{src} \to PC \\ If  \textit{src} \text{ is in PC-relative mode} \; (label or address) \\ displacement + PC + 3 \to PC. \end{array}$ |
| Operands  | Else, continue.<br><i>src</i> conditional-branch addressing modes (B):<br>0 register<br>1 PC-relative                                                                                                                                                                                                                                          |

ARn register (any register in CPU primary register file)

| Encoding | En | co | di | ing |  |
|----------|----|----|----|-----|--|
|----------|----|----|----|-----|--|

| _31           | 24 23 | 16 15 | 87                       | 0 |
|---------------|-------|-------|--------------------------|---|
| 0 1 1 0 1 1 B | ARn 1 | cond  | register or displacement |   |

**Description** DB*cond*D signifies a delayed branch that allows the three instructions after the delayed branch to be fetched before the PC is modified. The effect is a single-cycle branch. The specified auxiliary register is decremented and a branch is performed if the condition is true and the specified auxiliary register is greater than or equal to zero. (The three instructions following the DB*cond*D must not affect the *cond*).

> The auxiliary register is treated as a 32-bit signed integer. The most significant eight bits are unmodified by the decrement operation. The comparison of the auxiliary register uses only the 32 least significant bits of the auxiliary register. Note that the branch condition does not depend on the auxiliary register decrement.

> If the *src* operand is expressed in register addressing mode, the contents of the specified register are loaded into the PC. If the *src* is expressed in PC-relative addressing, the assembler generates a displacement: displacement = label – (PC of branch instruction + 3). This displacement is added to the PC of the branch instruction plus 3 to generate the new PC. Note that bit 21 = 1 for a delayed branch.

The TMS320C40 provides 20 condition codes that can be used with this instruction (see Section 11.2 on page 11-10 for a list of condition mnemonics, encoding, and flags). Decrement and Branch Conditionally (Delayed) DBcondD

| Cycles      | 1                                                                                                                                                                               |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status Bits | <ul> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF Unaffected.</li> <li>N Unaffected.</li> <li>Z Unaffected.</li> <li>V Unaffected.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit    | OVM Operation is not affected by OVM bit value.                                                                                                                                 |
| Example     | DBZD AR5, \$+110h                                                                                                                                                               |
|             | Before Instruction:                                                                                                                                                             |
|             | PC = 0h<br>AR5 = 67h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                       |
|             | After Instruction:                                                                                                                                                              |

PC = 110h AR5 = 66h LUF LV UF N Z V C = 0 0 0 0 0 0 0

11

۰.

| Syntax    | FIX src, dst                                                                                                                                                                                                              |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | $fix(src) \rightarrow dst$                                                                                                                                                                                                |
| Operands  | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (R0 — R11)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate</li> <li>dst register (any register in CPU primary register file)</li> </ul> |

### Encoding

| 31    | 24 23   | 16 15 | 87  | 0     |
|-------|---------|-------|-----|-------|
| 0 0 0 | 001010G | dst   | src | 1 1 1 |

**Description** The floating-point operand *src* is converted to the nearest integer less than or equal to it in value, and the result is loaded into the *dst* register. The *src* operand is assumed to be a floating-point number and the *dst* operand a signed integer.

The exponent field of the result register (if it has one) is not modified.

Integer overflow occurs when the floating-point number is too large to be represented as a 32-bit twos-complement integer. In the case of integer overflow, the result will be saturated in the direction of overflow.

### Cycles

1

Status Bits If ST (SET COND) = 0 and, the condition flags are modified the destination register is R0 — R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unaffected.

LV 1 if an integer overflow occurs, unchanged otherwise.UF 0.

- **N** 1 if a negative result is generated, 0 otherwise.
- Z 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- C Unaffected.

*Mode Bit* OVM Operation is not affected by OVM bit value.

# **Example** FIX R1, R2

## **Before Instruction:**

R1 = 0A2820 0000h = 1.3454e + 3 R2 = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

## After Instruction:

 $\begin{array}{l} R1 = 0A2820\ 0000h = 13454e + 3 \\ R2 = 541h = 1345 \\ LUF\ LV\ UF\ N\ Z\ V\ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \end{array}$ 

11

## FIX||STI Parallel FIX and STI

| Syntax    | FIX src2, dst1<br>   STI src3, dst2                                                                                              |  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------|--|
| Operation | fix( <i>src2</i> ) $\rightarrow$ <i>dst1</i><br>   <i>src3</i> $\rightarrow$ <i>dst2</i>                                         |  |
| Operands  | src2indirect (disp = 0, 1, IR0, IR1) $dst1$ register (R0 - R7) $src3$ register (R0 - R7) $dst2$ indirect (disp = 0, 1, IR0, IR1) |  |

#### Encoding

| 31            | 24 23             | 16 15    | 87 | 0    |
|---------------|-------------------|----------|----|------|
| 1 1 0 1 0 1 0 | <i>dst1</i> 0 0 0 | src3 dsi | 2  | src2 |

**Description** A floating-point-to-integer conversion is performed. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register, and the operation being performed in parallel (FIX) writes to the same register, then STI accepts as input the contents of the register before it is modified by FIX.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

Integer overflow occurs when the floating-point number is too large to be represented as a 32-bit twos-complement integer. In the case of integer overflow, the result will be saturated in the direction of overflow.

### Cycles

Status Bits LUF Unaffected.

1

- LV 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

### Example

FIX \*++AR4(1),R1 || STI R0,\*AR2

### **Before Instruction:**

 $\begin{array}{l} AR4 = 80 \ 98A2h \\ R1 = 0h \\ R0 = 0DCh = 220 \\ AR2 = 80 \ 983Ch \\ Data \ at \ 80 \ 98A3h = 733 \ C000h = 1.7950e + 02 \\ Data \ at \ 80 \ 983Ch = 0h \\ LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \end{array}$ 

### **After Instruction:**

 $AR4 = 80 \ 98A3h$  R1 = 0B3h = 179 R0 = 0DCh = 220  $AR2 = 80 \ 983Ch$   $Data at \ 80 \ 98A3h = 733 \ C000h = 1.79750e + 02$   $Data at \ 80 \ 983Ch = 0DCh = 220$   $LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0$ 

| Syntax                        | FLOAT src, dst                                                                                                                                                                                                                                         |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                     | float (src) $\rightarrow$ dst                                                                                                                                                                                                                          |
| Operands                      | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate</li> </ul>                                                               |
|                               | <i>dst</i> register (R0 – R11)                                                                                                                                                                                                                         |
| Encoding<br>31<br>0 0 0 0 0 0 | 24 23 16 15 87 0<br>1 0 0 1 G dst src                                                                                                                                                                                                                  |
| Description                   | The integer operand <i>src</i> is converted to the floating-point value equal to it, and the result loaded into the <i>dst</i> register. The <i>src</i> operand is assumed to be a signed integer, and the <i>dst</i> operand a floating-point number. |
| Cycles                        | 1                                                                                                                                                                                                                                                      |
| Status Bits                   | <ul> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 0.</li> <li>C Unaffected.</li> </ul>                  |
| Mode Bit                      | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                        |
| Example                       | FLOAT *++AR2(2),R5                                                                                                                                                                                                                                     |
|                               | Before Instruction:                                                                                                                                                                                                                                    |
|                               | AR2 = 80 9800h<br>R5 = 034C 2000h = 1.27578125e + 01<br>Data at 80 9802h = 0AEh = 174<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                             |
|                               | After Instruction:                                                                                                                                                                                                                                     |
|                               | AR2 = 80 9802h<br>R5 = 072E0 0000h = 1.74e + 02<br>Data at 80 9802h = 0AEh = 174<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                  |

| Syntax    | FLOAT src2, dst1                                                                                                                 |
|-----------|----------------------------------------------------------------------------------------------------------------------------------|
| Operation | float(src2) $\rightarrow$ dst1<br>   src3 $\rightarrow$ dst2                                                                     |
| Operands  | src2indirect (disp = 0, 1, IR0, IR1) $dst1$ register (R0 - R7) $src3$ register (R0 - R7) $dst2$ register (disp = 0, 1, IR0, IR1) |

### Encoding

| 31            | 24 23             | 16 15   | 87     | 0   |
|---------------|-------------------|---------|--------|-----|
| 1 1 0 1 0 1 1 | <i>dst1</i> 0 0 0 | src3 ds | st2 si | rc2 |

**Description** An integer-to-floating-point conversion is performed. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STF) reads from a register and the operation being performed in parallel (FLOAT) writes to the same register, then STF accepts as input the contents of the register before it is modified by FLOAT.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

### Cycles

Status Bits LUF Unaffected.

- LV Unaffected.
- **UF** 0.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* OVM Operation is affected by OVM bit value.

11

### Example

FLOAT \*+AR2(IR0),R6
STF R7,\*AR1

## **Before Instruction:**

 $AR2 = 80 \ 98C5h$  IR0 = 8h R6 = 0h  $R7 = 034C20 \ 0000h = 1.27578125e + 01$   $AR1 = 80 \ 9933h$   $Data \ at \ 80 \ 98CDh = 0AEh = 174$   $Data \ at \ 80 \ 9933h = 0h$   $LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0$ 

### After Instruction:

 $AR2 = 80 \ 98C5h$  IR0 = 8h  $R6 = 072E00 \ 0000h = 1.740e + 02$   $R7 = 034C20 \ 0000h = 1.27578125e + 01$   $AR1 = 80 \ 9933h$   $Data \ at \ 80 \ 98CDh = 0AEh = 174$   $Data \ at \ 80 \ 9933h = 034C \ 2000h = 1.27578125e + 01$   $LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0$ 

Syntax FRIEEE src, dst

**Operation** convert *src* from IEEE format  $\rightarrow dst$ 

*Operands* src direct or indirect addressing modes dst extended-precision register (R0 – R11)

### Encoding

| 31    | 24 23       |   | 16  | 6 15 | 87  | 0 |
|-------|-------------|---|-----|------|-----|---|
|       |             |   |     |      |     |   |
| 0 0 0 | 1 1 1 0 0 0 | G | dst |      | SIC |   |

Instruction Word Fields

| G  | <i>src</i> addressing modes |
|----|-----------------------------|
| 01 | direct mode                 |
| 10 | indirect mode               |

**Description** The *src* operand is converted from the IEEE floating-point format to the twos-complement floating-point format.

The *src* operand comes from memory. The converted result goes into an extended precision register as a single-precision floating-point number.

Cycles

Status Bits LUF Unaffected.

1

- LV Set if overflow, otherwise unchanged.
- **UF** 0.
- **N** Sign of the result.
- **Z** 1 if result is 0, 0 otherwise.
- V 1 if overflow, 0 otherwise.
- C Unaffected
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

# FRIEEE||STF Parallel FRIEEE and STF

| Syntax    | FRIEEE src2, dst1                  STF src3, dst2                                                                                        |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | convert <i>src2</i> from IEEE format $\rightarrow dst1$<br>in parallel with<br><i>src3</i> $\rightarrow dst2$                            |
| Operands  | src2indirect mode (disp = 0, 1, IR0, IR1)dst1register mode (R0 - R7)src3register mode (R0 - R7)dst2indirect mode (disp = 0, 1, IR0, IR1) |

### Encoding

| 31            | 24 23      | 16 15    | 87     | 0 |
|---------------|------------|----------|--------|---|
| 1 1 1 1 0 0 1 | dst1 0 0 0 | src3 dst | 2 src2 |   |

**Description** The *src2* operand is converted from the IEEE floating-point format to the twos-complement format. The converted result goes into an extended-precision register *dst1* as a single-precision floating-point number.

A floating-point store is done in parallel.

If *src2* and *dst2* point to the same location, then *src2* is read before the write to *dst2*.

Cycles

Status Bits LUF Unaffected.

- LV Set if overflow, otherwise unchanged.
- **UF** 0.
- N Sign of the result.
- **Z** 1 if result is 0, 0 otherwise.
- V 1 if overflow, 0 otherwise.
- C Unaffected
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax   | IACK src                                                                                                         |  |  |  |  |
|----------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Operatio | Perform a dummy read operation with $\overline{IACK} = 0$ .<br>At end of dummy read, set $\overline{IACK}$ to 1. |  |  |  |  |
| Operand  | <i>src</i> general addressing modes (G):<br>0 1 direct<br>1 0 indirect                                           |  |  |  |  |
| Encoding | •                                                                                                                |  |  |  |  |
| 31       | <u>24 23 16 15 8 7 0</u>                                                                                         |  |  |  |  |
| 0 0 0    | 1 1 0 1 1 0 G 0 0 0 0 0 src                                                                                      |  |  |  |  |
|          | 1 1 0 1 1 0 G 0 0 0 0 0 src                                                                                      |  |  |  |  |

**Description** A dummy read operation is performed with  $\overline{IACK} = 0$ . At the end of the dummy read,  $\overline{IACK}$  is set to 1 if off-chip memory is specified. This instruction can be used to generate an external interrupt acknowledge. If the address specified is off-chip, a read operation from that address is performed. The IACK signal and the address

|             | specified is off-chip, a read operation from that address is performed. The<br>IACK signal and the address<br>can then be used to signal interrupt acknowledge to external devices. The<br>data read by the processor is unused. |   |  |  |  |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--|--|--|
| Cycles      | 1                                                                                                                                                                                                                                |   |  |  |  |  |
| Status Bits | LUFUnaffected.LVUnaffected.UFUnaffected.NUnaffected.ZUnaffected.VUnaffected.CUnaffected.                                                                                                                                         |   |  |  |  |  |
| Mode Bit    | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                  |   |  |  |  |  |
| Example     | IACK *AR5                                                                                                                                                                                                                        |   |  |  |  |  |
|             | Before Instruction:                                                                                                                                                                                                              |   |  |  |  |  |
|             | IACK = 1         PC = 300h         LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                             |   |  |  |  |  |
|             | After Instruction:                                                                                                                                                                                                               |   |  |  |  |  |
|             | IACK = 1         PC = 301h         LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                             | _ |  |  |  |  |
|             | 11-87                                                                                                                                                                                                                            |   |  |  |  |  |

| Syntax                                       | IDLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                                    | $1 \rightarrow ST(GIE)$<br>Next PC $\rightarrow$ PC<br>Idle until interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Operands                                     | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Encoding<br>31<br>0 0 0 0 0 0<br>Description | 24 23       16 15       8 7       0         0       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       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       < |
| Cycles                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Status Bits                                  | <ul> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF Unaffected.</li> <li>N Unaffected.</li> <li>Z Unaffected.</li> <li>V Unaffected.</li> <li>C Unaffected.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Mode Bit                                     | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| PC of LAJ + 4 $\rightarrow$ extended-precision register R11<br>src + 3 + PC of LAJ $\rightarrow$ PC |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------|--|--|--|--|--|
| scr 24-bit signed immediate displacement                                                            |  |  |  |  |  |
|                                                                                                     |  |  |  |  |  |
| 0                                                                                                   |  |  |  |  |  |
|                                                                                                     |  |  |  |  |  |
|                                                                                                     |  |  |  |  |  |
|                                                                                                     |  |  |  |  |  |

**Description** LAJ performs a single cycle subroutine call. The three instructions following the LAJ instruction are performed. The return address (address of the LAJ instruction + 4) is placed in extended-precision register R11. The address branched to is formed by adding the *src* operand to the PC of the LAJ instruction + 3.

None of the three instructions following the LAJ instruction should modify the program flow. Interrupts are disabled for the duration of the LAJ instruction.

Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | LAJcond src                                                                                                                                                                                                 |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | If ( <i>cond</i> is true)<br>If ( <i>src</i> is a register)<br>PC of LAJ <i>cond</i> + 4 $\rightarrow$ extended-precision register R11<br><i>src</i> $\rightarrow$ PC<br>If ( <i>src</i> is a displacement) |
|           | PC of LAJ <i>cond</i> + 4 $\rightarrow$ extended-precision register R11<br><i>src</i> + PC of the LAJ + 3 $\rightarrow$ PC<br>Else, continue.                                                               |

*Operands* src conditional-branch addressing modes

## Encoding

| 31    | 24 23    | 16 15 | 87                       | 0 |
|-------|----------|-------|--------------------------|---|
| 0 1 1 | 100B0001 | cond  | register or displacement |   |

**Instruction Word Fields** 

| В | src addressing modes |  |  |  |
|---|----------------------|--|--|--|
| 0 | register mode        |  |  |  |
| 1 | PC-relative mode     |  |  |  |

**Description** LAJ*cond* performs a conditional single-cycle subroutine call. The three instructions following the LAJ*cond* instruction are performed. The return address (address of the LAJ instruction + 4) is placed in extended-precision register R11. The address branched to is formed by either register mode or PC-relative mode.

None of the three instructions following the LAJ*cond* instruction may modify the program flow. Interrupts are disabled for the duration of the LAJ*cond* instruction.

Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

Syntax LAT cond N

Else, continue.

**Operands** N immediate mode – trap number ( $0 \le N \le 511$ )

Encoding

| 31            | 24 23 16            | 815 87          | 0 |
|---------------|---------------------|-----------------|---|
| 0 1 1 1 0 1 0 | 0 1 0 0 <i>cond</i> | 0 0 0 0 0 0 0 N |   |

**Description** Performs a delayed conditional trap. If traps are to be nested, you may need to save the status register before executing LAT*cond*. If the condition is true, ST bits GIE and CF are saved in PGIE and PCF in the status register. Then all interrupts are disabled  $(0 \rightarrow GIE)$ , and the cache is frozen  $(1 \rightarrow CF)$ . The contents of the PC of the LAT*cond* + 4 are placed in R31, and the PC is loaded with the contents of the specified trap vector (N). If the condition is not true, then continue normal operation.

The three instructions following LAT*cond* will be fetched and executed. They may not be instructions that modify the program flow or modify the status register.

Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* OVM Operation is not affected by OVM bit value.

| Syntax           | LBb src, dst                                             |              |                       |                              |   |
|------------------|----------------------------------------------------------|--------------|-----------------------|------------------------------|---|
| <b>Operation</b> | Sign-extended byte (3, 2, 1, 0) of $src \rightarrow dst$ |              |                       |                              |   |
|                  | b = byte to load                                         | (3, 2, 1, 0) |                       |                              |   |
|                  | 3 2                                                      | 1 0 =        | <b>b</b> (byte desigr | nator 3 – 0)                 |   |
| Operands         | <i>src</i> register, dire<br><i>dst</i> register mod     |              | -                     | nodes<br>mary register file) |   |
| Encoding         |                                                          |              |                       |                              |   |
| 31               | 24 23                                                    | 16           | 15                    | 87                           | 0 |
|                  |                                                          |              | 1 1 1 1               |                              |   |
| 1 0 1 1          | 0 0 0 B G                                                | dst          |                       | SIC                          |   |

Instruction Word Fields

| G  | src addressing modes |
|----|----------------------|
| 00 | register mode        |
| 01 | direct mode          |
| 10 | indirect mode        |

| В  | <i>src</i> byte |
|----|-----------------|
| 00 | byte 0 LS byte  |
| 01 | byte 1          |
| 10 | byte 2          |
| 11 | byte 3 MS byte  |

**Description** The specified byte of the *src* operand is sign-extended and right-shifted into the 8 LSBs of the *dst* register. The *src* byte is signed.

Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unaffected.

LV Unaffected.

**UF** 0.

- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

**Example** LB2 R1, R2 ; sign extended byte 2 of R1  $\rightarrow$  R2

### **Before Instruction:**

R1 = 00AB 0000hR2 = 0000 0000h

## **After Instruction:**

R1 = 00AB 0000hR2 = FFFF FFABh

| Syntax    | LBUb src, dst                                        |                                        |                       |                              |   |
|-----------|------------------------------------------------------|----------------------------------------|-----------------------|------------------------------|---|
| Operation | Byte (3, 2, 1, 0)                                    | of <i>src</i> $\rightarrow$ <i>dst</i> |                       |                              |   |
|           | b = byte to load                                     | (3, 2, 1, 0)                           |                       |                              |   |
|           | 3 2                                                  | 1 0 =                                  | <b>b</b> (byte desigr | nator 3 – 0)                 |   |
| Operands  | <i>src</i> register, dire<br><i>dst</i> register mod | •                                      | -                     | nodes<br>mary register file) |   |
| Encoding  |                                                      |                                        |                       |                              |   |
| 31        | 24 23                                                | 16                                     | 15                    | 87                           | 0 |
|           | 0 0 1 B G                                            | dst                                    |                       | src                          |   |

# Instruction Word Fields

| G  | <i>src</i> addressing modes      |
|----|----------------------------------|
| 00 | register mode (any CPU register) |
| 01 | direct mode                      |
| 10 | indirect mode                    |

| В  | <i>src</i> byte |
|----|-----------------|
| 00 | byte 0 LS byte  |
| 01 | byte 1          |
| 10 | byte 2          |
| 11 | byte 3 MS byte  |

**Description** The specified byte of the *src* operand is right-shifted without sign-extension, into the 8 LSBs of the *dst* register. The *src* byte is unsigned.

Cycles

- Status Bits If ST (SET COND) = 0 and the destination register is R0 R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.
  - LUF Unaffected.
  - LV Unaffected.
  - **UF** 0.
  - N 0.
  - **Z** 1 if a zero result is generated, 0 otherwise.
  - **V** 0.
  - C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example LB2 R1, R2

# **Before Instruction:**

| R1 = | 00AB | 0000h |
|------|------|-------|
| R2 = | 0000 | 0000h |

# After Instruction:

| R1 | = | 00AB | 0000h |
|----|---|------|-------|
| R2 | = | 0000 | 00ABh |

| Syntax    | LDA                                               |     |      |     |   |
|-----------|---------------------------------------------------|-----|------|-----|---|
| Operation | $src \rightarrow dst$                             |     |      |     |   |
| Operands  | <i>src</i> general add<br><i>dst</i> register mod |     |      |     |   |
| Encoding  |                                                   |     |      |     |   |
| 31        | 24 23                                             | 16  | 5 15 | 87  | 0 |
|           |                                                   |     |      |     |   |
| 0 0 0 1   | 1 1 1 0 1 G                                       | dst |      | SIC |   |

# Instruction Word Fields

| G  | <i>src</i> addressing modes      |
|----|----------------------------------|
| 00 | register mode (any CPU register) |
| 01 | direct mode                      |
| 10 | indirect mode                    |
| 11 | immediate mode                   |

**Description** The *src* operand is loaded into the dst register. The *dst* register may be any of the address registers: AR0 – AR7, IR0, IR1, DP, BK or SP. The load is done by the end of the read phase of the pipeline. As a result, LDA is one cycle faster than LDI for loading these registers. (All operands are treated as signed integers.)

### Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | LDE src, dst                                                                                                |
|-----------|-------------------------------------------------------------------------------------------------------------|
| Operation | $src(exp) \rightarrow dst(exp)$                                                                             |
| Operation | src general addressing modes (G):<br>0 0 register (R0 – R11)<br>0 1 direct<br>1 0 indirect<br>1 1 immediate |
|           | <i>dst</i> register (R0 – R11)                                                                              |
| Encoding  |                                                                                                             |
| _31       | <u>24 23 16 15 8 7 0</u>                                                                                    |
| 0 0 0 0   | 0 1 1 0 1 G dst src                                                                                         |

**Description** The exponent field of the *src* operand is loaded into the exponent field of the *dst* register. No modification of the *dst* register mantissa field is made unless the value of the exponent loaded is the reserved value of the exponent for zero as determined by the precision of the *src* operand. Then, the mantissa field of the *dst* register is set to zero. The *src* and *dst* operands are assumed to be floating-point numbers. Immediate values are evaluated in the short floating point format.

### Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- **C** Unaffected.

# *Mode Bit* OVM Operation is not affected by OVM bit value.

**Example** LDE R0,R5

## **Before Instruction:**

R0 = 020005 6F30h = 4.00066337e + 00 R5 = 0A056F E332h = 1.06749648e + 03 LUF LV UF N Z V C = 0 0 0 0 0 0 0

## After Instruction:

R0 = 020005 6F30h = 4.00066337e + 00 R5 = 02056F E332h = 4.16990814e + 00 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax | LDEP | src, | dst |
|--------|------|------|-----|
|--------|------|------|-----|

**Operation**  $src \rightarrow dst$ 

*Operands* src expansion register file register (IVTP or TVTP) dst register mode (any register in CPU primary register file)

#### Encoding

| <u>31</u> 24 23   | 16 | 15          | 87 | 0   |
|-------------------|----|-------------|----|-----|
| 0 1 1 1 0 1 1 0 0 |    | 0 0 0 0 0 0 |    | src |

**Description** This is a means to load a CPU register with the contents of the IVTP register (interrupt-trap table pointer) or the TVTP register. These registers are described in Section 3.2.

The *src* operand register from the expansion-register file is loaded into the *dst* register in the primary register file. The *dst* register content is assumed to be an integer.

### Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- **C** Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

| 0           |                                                                                                                                                                                                                                 |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax      | LDF src, dst                                                                                                                                                                                                                    |
| Operation   | $src \rightarrow dst$                                                                                                                                                                                                           |
| Operands    | <pre>src general addressing modes (G):     0 0 register (R0 – R11)     0 1 direct     1 0 indirect     1 1 immediate</pre>                                                                                                      |
|             | <i>dst</i> register (R0 – R11)                                                                                                                                                                                                  |
| Encoding    |                                                                                                                                                                                                                                 |
| 0 0 0 0 0   | 0 1 1 1 0 G dst src                                                                                                                                                                                                             |
| Description | The <i>src</i> operand is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be floating-point numbers.                                                                                 |
| Cycles      | 1                                                                                                                                                                                                                               |
| Status Bits | <ul> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF 0.</li> <li>N 1 if a negative result is loaded, 0 otherwise.</li> <li>Z 1 if a zero result is loaded, 0 otherwise.</li> <li>V 0.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit    | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                 |
| Example     | LDF @9800h,R2                                                                                                                                                                                                                   |
|             | Before Instruction:                                                                                                                                                                                                             |
|             | DP = 80h<br>R2 = 0h<br>Data at 80 9800h = 10C5 2A00h = 2.19254303e + 00<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                    |
|             | After Instruction:                                                                                                                                                                                                              |
|             | $DP = 80h$ $R2 = 010C52 \ A000h = 2.19254303e + 00$ Data at 80 9800h = 10C5 2A00h = 2.19254303e + 00<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0                                                               |

| Syntax | LDF <i>cond</i> | src, dst |
|--------|-----------------|----------|
|--------|-----------------|----------|

**Operation** If cond is true:

src  $\rightarrow$  dst.

Else:

dst is unchanged.

*Operands* src general addressing modes (G):

- 00 register (R0 R11)
- 01 direct
- 10 indirect
- 11 immediate

dst register (R0 – R11)

### Encoding



**Description** If the condition is true, the *src* operand is loaded into the *dst* register. Otherwise, the *dst* register is unchanged. The *dst* and *src* operands are assumed to be floating-point numbers.

The TMS320C40 provides 20 condition codes that can be used with this instruction (see Section 11.2 on page 11-10 for a list of condition mnemonics, encoding, and flags). Note that an LDFU (load floating-point unconditionally) instruction is

useful for loading R0 – R11 without affecting condition flags.

### Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- **C** Unaffected.

*Mode Bit* OVM Operation is not affected by OVM bit value.

# **Example** LDFZ R3,R5

## **Before Instruction:**

R3 = 2CFF2C D500h = 1.77055560e +13 R5 = 5F0000 003Eh = 3.96140824e + 28 LUF LV UF N Z V C = 0 0 0 1 0 0

## **After Instruction:**

R3 = 2CFF2C D500h = 1.77055560e +13 R5 = 2CFF2C D500h = 1.77055560e +13 LUF LV UF N Z V C = 0 0 0 1 0 0

| Syntax      | LDFI src, dst                                                                                                                                                                                                                                                                                                                                          |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation   | Signal interlocked operation. $src \rightarrow dst$                                                                                                                                                                                                                                                                                                    |
| Operands    | <i>src</i> general addressing modes (G):<br>0 1 direct<br>1 0 indirect                                                                                                                                                                                                                                                                                 |
|             | <i>dst</i> register (R0 – R11)                                                                                                                                                                                                                                                                                                                         |
| Encoding    |                                                                                                                                                                                                                                                                                                                                                        |
|             |                                                                                                                                                                                                                                                                                                                                                        |
| 0000        | 0 1 1 1 1 G dst src                                                                                                                                                                                                                                                                                                                                    |
| Description | The <i>src</i> operand is loaded into the <i>dst</i> register. An interlocked operation is signaled over LOCK or LLOCK. The <i>src</i> and <i>dst</i> operands are assumed to be floating-point numbers. Note that only direct and indirect modes are allowed. Refer to Section 6.5 (page 6-13) and Section 7.7 (page 7-39) for detailed descriptions. |
| Cycles      | <b>1</b>                                                                                                                                                                                                                                                                                                                                               |
| Status Bits | <ul> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 0.</li> <li>C Unaffected.</li> </ul>                                                                                                                  |
| Mode Bit    | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                        |
| Example     | LDFI *+AR2,R7                                                                                                                                                                                                                                                                                                                                          |
|             | Before Instruction:         AR2 = $8098F1h$ R7 = $0h$ Data at $80 98F2h = 584 C000h = -6.28125e + 01$ LUF LV UF N Z V C = $0$ $0$ $0$ $0$                                                                                                                                                                                                              |
|             | After Instruction:AR2 = $8098F1h$ R7 = $0584C0\ 0000h = -6.28125e + 01$ Data at $80\ 98F2h = 584\ C000h = -6.28125e + 01$ LUF LV UF N Z V C = 0 0 0 0 0 1                                                                                                                                                                                              |

| Syntax                | LDF src2, dst2                                        |                   |     |     |
|-----------------------|-------------------------------------------------------|-------------------|-----|-----|
| Operation             | $src2 \rightarrow dst2$<br>   $src1 \rightarrow dst1$ |                   |     |     |
| Operands              | dst1 register (R0 -                                   | = 0, 1, IR0, IR1) |     |     |
| <b>Encoding</b><br>31 | 24 23                                                 | 16 15             | 8 7 | . 0 |

| 31  |           | 24 23 |      | 16    | 15 8 | 0    |
|-----|-----------|-------|------|-------|------|------|
|     |           |       |      |       |      |      |
| 1 1 | 0 0 0 1 0 | dst2  | dst1 | 0 0 0 | src1 | src2 |
|     | L         |       |      |       |      |      |

**Description** Two floating-point loads are performed in parallel. If the LDFs load the same register, the assembler issues a warning. The result is that of LDF *src2*, *dst2*.

Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.
- *Mode Bit* OVM Operation is not affected by OVM bit value.

#### Example

LDF - AR1(IR0),R7

### **Before Instruction:**

AR1 = 80 985Fh IR0 = 8h R7 = 0h AR7 = 80 988Ah R3 = 0h Data at 80 9857h = 70C 8000h = 1.4050e + 02Data at 80 988Ah = 57B 4000h = 6.281250e + 01 LUF LV UF N Z V C = 0 0 0 0 0 0 0

### **After Instruction:**

AR1 = 80 9857h R0 = 8h R7 = 070C80 0000h = 1.4050e + 02AR7 = 80 988Bh R3 = 057B40 0000h = 6.281250e + 01Data at 80 9857h = 70C 8000h = 1.4050e + 02Data at 80 988Ah = 57B 4000h = 6.281250e + 01LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax    | LDF src2, dst1                                                                                                                       |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------|
|           | STF src3, dst2                                                                                                                       |
| Operation | $src2 \rightarrow dst1$                                                                                                              |
|           | $\parallel src3 \rightarrow dst2$                                                                                                    |
| Operands  | src2 indirect (disp = 0, 1, IR0, IR1)<br>dst1 register (R0 – R7)<br>src3 register (R0 – R7)<br>dst2 indirect (disp = 0, 1, IR0, IR1) |

- ----

## Encoding

| 31            | 24 23      | 16 15   | 87    | 0   |
|---------------|------------|---------|-------|-----|
| 1 1 0 1 1 0 0 | dst1 0 0 0 | src3 ds | st2 s | rc2 |

Description A floating-point load and a floating-point store are performed in parallel.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

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

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- **C** Unaffected.

# *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example

LDF\*AR2- -(1),R1 || STF R3,\*AR4++(IR1)

#### **Before Instruction:**

 $\begin{array}{l} AR2 = 80\ 98E7h \\ R1 = 0h \\ R3 = 057B40\ 0000h = 6.28125e + 01 \\ AR4 = 80\ 9900h \\ IR1 = 10h \\ Data\ at\ 80\ 98E7h = 70C\ 8000h = 1.4050e + 02 \\ Data\ at\ 80\ 9900h = 0h \\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

#### **After Instruction:**

 $AR2 = 80\ 98E6h$   $R1 = 070C80\ 0000h = 1.4050e + 02$   $R3 = 057B40\ 0000h = 6.28125e + 01$   $AR4 = 80\ 9910h$  IR1 = 10h  $Data\ at\ 80\ 98E7h = 70C\ 8000h = 1.4050e + 02$   $Data\ at\ 80\ 9900h = 57B\ 4000h = 6.28125e + 01$   $LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0$ 

| Syntax | LDHI src, dst |
|--------|---------------|
|--------|---------------|

**Operation** src  $\rightarrow$  16 MSBs of dst

*Operands* src 16-bit unsigned immediate dst register mode

#### Encoding

| 31      | 24 23         | 16 15 | 87                           | 0             |
|---------|---------------|-------|------------------------------|---------------|
| 0 0 0 1 | 1 1 1 1 1 1 1 | dst   | <i>src</i> (immediate value) | · T · T · T · |

**Operation** The 16-bit unsigned *src* immediate value is loaded into the 16 MSBs of the *dst* register. 0 is loaded into the 16 LSBs of the *dst* register. The *dst* register is assumed to be an integer.

Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example LDHI 44h, R2

### **Before Instruction:**

R2 = ABCD EF12h

#### **After Instruction:**

 $R2 = 0044\ 0000h$ 

| Syntax    | LDI src, dst                                             |
|-----------|----------------------------------------------------------|
| Operation | $src \rightarrow dst$                                    |
| Operands  | <i>src</i> general addressing modes (G):                 |
|           | 0 0 register (any register in CPU primary register file) |
|           | 0 1 direct                                               |
|           | 1.0 Induced                                              |

- 10 indirect
- 11 immediate

dst register (any register in CPU primary register file)

### Encoding

| 31    | 24 23       | 16 15 | 87  | 0 |
|-------|-------------|-------|-----|---|
| 0 0 0 | 0 1 0 0 0 G | dst   | src |   |

**Description** The *src* operand is loaded into the *dst* register. The *dst* and *src* operands are assumed to be signed integers. An alternate form of LDI, LDP, is used to load the data page pointer register (DP) or any other register with the eight MSBs of a relocatable address. See the LDP instruction in this chapter and subsection 11.3.2 (on page 11-15).

- Cycles
- Status Bits LUF Unaffected.

1

LV Unaffected.

**UF** 0.

- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

## Example LDI \*-AR1(IR0),R5

## **Before Instruction:**

 $\begin{array}{l} AR1 = 2Ch \\ IR0 = 5h \\ R5 = 3C5h = 965 \\ Data at 27h = 26h = 38 \\ LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \end{array}$ 

## **After Instruction:**

 $\begin{array}{l} AR1 = 2Ch \\ IR0 = 5h \\ R5 = 26h = 38 \\ Data at 27h = 26h = 38 \\ LUF LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \end{array}$ 

Syntax LDIcond src, dst

*Operation* If *cond* is true:

 $src \rightarrow dst$ ,

Else:

dst is unchanged.

*Operands* src general addressing modes (G):

- 00 register (any register in CPU primary register file)
- 01 direct
- 10 indirect
- 11 immediate

dst register (any register in CPU primary register file)

#### Encoding

| 31      | 24 23 | · . | 16 - | 15 | 87  | 0 |
|---------|-------|-----|------|----|-----|---|
| 0 1 0 1 | cond  | G   | dst  |    | src |   |

**Description** If the condition is true, the *src* operand is loaded into the *dst* register. Otherwise, the *dst* register is unchanged. The *dst* and *src* operands are assumed to be signed integers.

The TMS320C40 provides 20 condition codes that can be used with this instruction (see Section 11.2 on page 11-10 for a list of condition mnemonics, encoding, and flags). Note that an LDIU (load integer unconditionally) instruction is useful for loading a selected CPU register without affecting the condition flags.

Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

Mode Bit

**OVM** Operation is not affected by OVM bit value.

## **Example** LDIZ R4, R6

### **Before Instruction:**

R4 = 027Ch = 636 R6 = 0FE2h = 4,066 LUF LV UF N Z V C = 0 0 0 0 0 0 0

## **After Instruction:**

R4 = 027Ch = 636 R6 = 0FE2h = 4,066 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax      | LDII src, dst                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation   | Signal interlocked operation.<br>$src \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                 |
| Operands    | <ul> <li>src general addressing modes (G):</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>dst register (any register in CPU primary register file)</li> </ul>                                                                                                                                                                                                                                                      |
| Encoding    |                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31          | 24 23 16 15 8 7 0                                                                                                                                                                                                                                                                                                                                                                                                      |
| 00001       | 0 0 0 1 G dst src                                                                                                                                                                                                                                                                                                                                                                                                      |
| Description | The <i>src</i> operand is loaded into the <i>dst</i> register. An interlocked operation is signaled over $\overrightarrow{LOCK}$ or $\overrightarrow{LLOCK}$ . The <i>src</i> and <i>dst</i> operands are assumed to be signed integers. Note that only the direct and indirect modes are allowed. Refer to Section 7.7 on page 7-39 for a detailed description.                                                       |
| Cycles      | 1                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Status Bits | <ul> <li>If ST (SET COND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 0.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit    | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                        |
| Example     | LDII @985Fh,R3                                                                                                                                                                                                                                                                                                                                                                                                         |
|             | Before Instruction:         DP = 80 $R3 = 0h$ Data at 80 985Fh = 0DCh         LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                        |
|             | After Instruction:         DP = 80 $R3 = 0DCH$ Data at 80 985Fh = 0DCh         LUF LV UF N Z V C = 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                     |

| Syntax    | LDI src2, dst2                                                                                                                   |
|-----------|----------------------------------------------------------------------------------------------------------------------------------|
|           | LDI src1, dst1                                                                                                                   |
| Operation | $src2 \rightarrow dst2$                                                                                                          |
|           | $  $ src1 $\rightarrow$ dst1                                                                                                     |
| Operands  | src1indirect (disp = 0, 1, IR0, IR1) $dst1$ register (R0 - R7) $src2$ indirect (disp = 0, 1, IR0, IR1) $dst2$ register (R0 - R7) |

## Encoding

| 31            | 24 23     | 16 15 | 87      | 0  |
|---------------|-----------|-------|---------|----|
| 1 1 0 0 0 1 1 | dst2 dst1 | 0 0 0 | src1 sr | c2 |

Description Two integer loads are performed in parallel. A warning is issued by the assembler if the LDIs load the same register. The result is that of LDI src2, dst2.

- Cycles
- Status Bits LUF Unaffected.

1

- Unaffected. LV
- UF Unaffected. Unaffected.
- N Unaffected.
- Ζ V
- Unaffected.
- С Unaffected.

Mode Bit **OVM** Operation is not affected by OVM bit value.

#### Example

LDI \*-AR1(1),R7 || LDI \*AR7++(IR0),R1

#### **Before Instruction:**

 $AR1 = 80 \ 9826h$  R7 = 0h  $AR7 = 80 \ 98C8h$  IR0 = 10h R1 = 0h  $Data \ at \ 80 \ 9825h = 0FAh = 250$   $Data \ at \ 80 \ 98C8h = 2EEh = 750$   $LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0$ 

### After Instruction:

 $AR1 = 80 \ 9826h$  R7 = 0FAh = 250  $AR7 = 80 \ 98D8h$  IR0 = 10h R1 = 02EEh = 750  $Data \ at \ 80 \ 9825h = 0FAh = 250$   $Data \ at \ 80 \ 98C8h = 2EEh = 750$   $LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0$ 

| Syntax    | LDI src2, dst1                                                                                                                   |
|-----------|----------------------------------------------------------------------------------------------------------------------------------|
|           | STI src3, dst2                                                                                                                   |
| Operation | $src2 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                                                            |
| Operands  | src2indirect (disp = 0, 1, IR0, IR1) $dst1$ register (R0 - R7) $src3$ register (R0 - R7) $dst2$ indirect (disp = 0, 1, IR0, IR1) |

### Encoding

| 31 | 24 23      | 16 15   | 87     | 0  |
|----|------------|---------|--------|----|
|    | dst1 0 0 0 | src3 ds | t2 sro | c2 |

**Description** An integer load and an integer store are performed in parallel. If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

## Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

#### Example

LDI \*-AR1(1),R2 || STI R7,\*AR5++(IR0)

### **Before Instruction:**

AR1 = 80 98E7h R2 = 0h R7 = 35h = 53 AR5 = 80 982Ch IR0 = 8h Data at 80 98E6h = 0DCh = 220 Data at 80 982Ch = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

### After Instruction:

 $AR1 = 80 \ 98E7h$  R2 = 0DCh = 220 R7 = 35h = 53  $AR5 = 80 \ 9834h$  IR0 = 8h  $Data \ at \ 80 \ 98E6h = 0DCh = 220$   $Data \ at \ 80 \ 982Ch = 35h = 53$   $LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0$ 

Syntax LDM src, dst Operation src (man)  $\rightarrow$  dst (man) Operands src general addressing modes (G): 00 register (R0 – R11) 01 direct 10 indirect 11 immediate dst register (R0 – R11) Encoding 24 23 16 15 31 87 n 0 0 0 0 0 1 G dst 0 1 0 src

**Description** The mantissa field of the *src* operand is loaded into the mantissa field of the *dst* register. The *dst* exponent field is not modified. The *src* and *dst* operands are assumed to be floating-point numbers. If immediate addressing mode is used, bits 15–12 of the instruction word are forced to 0 by the assembler. If the source is in the memory, the 32-bit data are loaded into the mantisa field.

#### Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* OVM Operation is not affected by OVM bit value.

Example LDM 156.75,R2

 $(156.75 = 07 \ 1CC0 \ 0000h)$ 

### **Before Instruction:**

R2=0h LUF LV UF N Z V C=0 0 0 0 0 0 0

#### After Instruction:

R2 = 00 1CC0 0000h = 1.22460938e + 00 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax                      | LDP src[,DP]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                   | $src \rightarrow$ Data page pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Operands                    | <i>src</i> is the <b>16 MSBs</b> of the <b>absolute 32-bi</b> t source address ( <i>src</i> ).                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                             | dst is optional (data page pointer understood if ",DP" left out of operand)                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Encoding<br>31<br>0 0 0 0 1 | 24 23     16 15     8 7     0       0 0 0 0     1 1     1 0 0 0 0     src                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Description                 | This pseudo-op is an alternate form of the LDI instruction, except that LDP <i>is always</i> in the immediate addressing mode (bits $22 - 21 = 11_2$ ). The 16 MSBs of the <i>src</i> absolute 32-bit value (note that an <i>src</i> less than 32 bits will be zero filled to make the 32 bits) are loaded into the 16 LSBs of the data page pointer. (For example, an <i>src</i> of <i>any</i> 16-bit value will result in 16 zeroes placed in the DP (the 16 extended zeroes used to fill the <i>MSBs of the src</i> value). |
|                             | The 16 LSBs of the pointer are used in direct addressing as a pointer to the page of data being addressed. There is a total of 256 pages, each page 64K words long. Bits $31 - 16$ of the pointer are reserved and should be kept to zero.                                                                                                                                                                                                                                                                                     |
| Cycles                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Status Bits                 | LUFUnaffected.LVUnaffected.UFUnaffected.ZUnaffected.VUnaffected.CUnaffected.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Mode Bit                    | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Example                     | LDP @809900h, DP<br>or<br>LDP @809900h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                             | DP = 6465h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                             | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Syntax                | LDPE src, <i>dst</i>                                                                                                                                                                      |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation             | $src \rightarrow dst$                                                                                                                                                                     |
| Operands              | <i>src</i> register mode (any register in CPU primary register file)<br><i>dst</i> expansion register file register (IVTP or TVTP)                                                        |
| <b>Encoding</b><br>31 | 24 23 16 15 8 7 0                                                                                                                                                                         |
| 0 1 1 1 0             | ) 1 1 0 1 0 0 dst 0 0 0 0 0 0 0 0 0 0 src                                                                                                                                                 |
| Description           | This is a means to load the IVTP register (interrupt-vector table pointer) or TVTP register (trap-vector table pointer). These registers are described in Section 3.2 on page 3-15.       |
|                       | The <i>scr</i> operand register from the primary-register file is loaded into the <i>dst</i> register in the expansion register file. The <i>dst</i> operand is assumed to be an integer. |
| Cycles                | 1                                                                                                                                                                                         |
| Status Bits           | LUFUnaffected.LVUnaffected.UFUnaffected.NUnaffected.ZUnaffected.VUnaffected.CUnaffected.                                                                                                  |
| Mode Bit              | OVM Operation is not affected by OVM bit value.                                                                                                                                           |
| Example               | IDPE AR TWTP · set tran-vector pointer                                                                                                                                                    |

**Example** LDPE AR, TVTP ; set trap-vector pointer

| Syntax | LDPK src |
|--------|----------|
|--------|----------|

**Operation**  $STC \rightarrow DP$ 

Operands src 16-bit unsigned immediate

#### Encoding

| 31 | 24 23         | 16 15   | 87  | 0 |
|----|---------------|---------|-----|---|
| 1  | 1 1 1 1 0 1 1 | 1 0 0 0 | src |   |

**Description** The 16-bit unsigned immediate value is loaded into the DP register. This operation is completed by the end of the decode phase of the LDPK instruction; thus, the value loaded is ready for the next instruction for immediate addressing.

#### Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | LHw src, dst                                                                                                                      |  |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation | Sign-extended half-word (0, 1) of $src \rightarrow dst$                                                                           |  |  |
|           | w = half-word to load (0, 1)                                                                                                      |  |  |
|           | 1 0 = w designator                                                                                                                |  |  |
| Operands  | <i>src</i> register, direct, or indirect addressing modes<br><i>dst</i> register mode (any register in CPU primary register file) |  |  |
| Encoding  |                                                                                                                                   |  |  |
| 31        | <u>24 23 16 15 8 7 0</u>                                                                                                          |  |  |
| 1011      | 1 0 1 0 H G dst src                                                                                                               |  |  |

Instruction Word Fields

| G  | src addressing modes                  |  |
|----|---------------------------------------|--|
| 00 | register mode (Rn, $0 \le n \le 31$ ) |  |
| 01 | direct mode                           |  |
| 10 | indirect mode                         |  |

| Н | <i>src</i> half-word       |  |
|---|----------------------------|--|
| 0 | half-word 0 (LS half-word) |  |
| 1 | half-word 1 (MS half-word) |  |

**Description** The specified half-word of the *src* operand is sign-extended and rightshifted into the 16 LSBs of the *dst* register. The *src* half-word is signed.

Cycles

- Status Bits If ST (SET COND) = 0 and the destination register is R0 R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.
  - LUF Unaffected.
  - LV Unaffected.
  - **UF** 0.
  - **N** 1 if a negative result is generated, 0 otherwise.
  - **Z** 1 if a zero result is generated, 0 otherwise.
  - **V** 0.
  - C Unaffected.
- *Mode Bit* OVM Operation is not affected by OVM bit value.

Example LHO R1, R2

#### **Before Instruction:**

R1 = ABCD EF12h R2 = 1234 5678h

### **After Instruction:**

R1 = ABCD EF12hR2 = FFFF FF12h

| Syntax    | LHUw src. dst                                                                                                                     |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------|
| Operation | Unsigned half-word (0, 1) of $src \rightarrow dst$                                                                                |
|           | w = half-word to load (0, 1)                                                                                                      |
|           | 1 0 = w designator                                                                                                                |
| Operands  | <i>src</i> register, direct, or indirect addressing modes<br><i>dst</i> register mode (any register in CPU primary register file) |
| Encoding  |                                                                                                                                   |
| 31        | <u>24 23 16 15 8 7 0</u>                                                                                                          |
|           | 1 0 1 1 H G dst src                                                                                                               |

### Instruction Word Fields

| G  | <i>src</i> addressing modes      |  |
|----|----------------------------------|--|
| 00 | register mode (any CPU register) |  |
| 01 | direct mode                      |  |
| 10 | indirect mode                    |  |

| Н | <i>src</i> half-word       |  |
|---|----------------------------|--|
| 0 | half-word 0 (LS half-word) |  |
| 1 | half-word 1 (MS half-word) |  |

**Description** The specified half-word of the *src* operand is unsigned and right-shifted into the 16 LSBs of the *dst* register. The *src* half-word is unsigned.

Cycles

- Status Bits If ST (SET COND) = 0 and the destination register is R0 R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.
  - LUF Unaffected.
  - LV Unaffected.
  - **UF** 0.
  - N 0.
  - **Z** 1 if a zero result is generated, 0 otherwise.
  - **V** 0.
  - **C** Unaffected.
- *Mode Bit* OVM Operation is not affected by OVM bit value.

Example LHU0 R1, R2

#### **Before Instruction:**

R1 = ABCD EF12hR2 = 1234 5678h

#### After Instruction:

R1 = ABCD EF12hR2 = 0000 EF12h

Syntax LSH count, dst

**Operation** If  $count \ge 0$ :  $dst << count \rightarrow dst$ Else:  $dst >> |count| \rightarrow dst$ 

*Operands* dst general addressing modes (G):

- 00 register (any CPU register)
- 01 direct
- 10 indirect
- 1 1 immediate

dst register (any register in CPU primary register file)

#### Encoding

| 31    | 24 23         | 16 15 | 87    | 0 |
|-------|---------------|-------|-------|---|
| 0 0 0 | 0 1 0 0 1 1 G | dst   | count |   |

**Description** The seven least significant bits of the *count* operand are used to generate the twos-complement shift count. If the *count* operand is greater than zero, the *dst* operand is left-shifted by the value of the *count* operand. Low-order bits shifted in are zero-filled, and high-order bits are shifted out through the C (carry) bit.

Logical left-shift:

 $C \leftarrow dst \leftarrow 0$ 

If the *count* operand is less than zero, the *dst* is right-shifted by the absolute value of the *count* operand. The high-order bits of the *dst* operand are zero-filled as they are shifted to the right. Low-order bits are shifted out through the C (carry) bit.

Logical right-shift:

 $0 \rightarrow dst \rightarrow C$ 

If the *count* operand is 0, no shift is performed, and the C (carry) bit is set to 0. The *count* operand is assumed to be a signed integer, and the *dst* operand is assumed to be an unsigned integer.

1

### Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unaffected.

LV Unaffected.

**UF** 0.

N MSB of the output.

- **Z** 1 if a zero output is generated, 0 otherwise.
- **V** 0.
- **C** Set to the value of the last bit shifted out. 0 for a shift *count* of 0.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example LSH R4,R7

### **Before Instruction:**

R4 = 018h = 24 R7 = 02ACh LUF LV UF N Z V C = 0 0 0 0 0 0 0

#### After Instruction:

R4 = 018h = 24 R7 = 0AC00 0000h LUF LV UF N Z V C = 0 0 0 1 0 1 0

Example LSH \*-AR5(IR1),R5

#### **Before Instruction:**

AR5 = 80 9908h IR0 = 4h R5 = 00 12C0 0000h Data at 80 9904h = 0FFF FFFF4h = -12LUF LV UF N Z V C = 0 0 0 0 0 0 0

#### After Instruction:

AR5 = 80 9908h IR0 = 4h R5 = 00 0001 2C00h Data at 80 9904h = 0FFF FFFF4h = -12LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax    | LSH3 coun         | t, src, dst                                                                                                    |
|-----------|-------------------|----------------------------------------------------------------------------------------------------------------|
| Operation | Else:             | b:<br>$punt \rightarrow dst$<br>$punt   \rightarrow dst$                                                       |
| Operands  | src, count<br>dst | both type 1 or type 2 three-operand addressing modes register mode (any register in CPU primary register file) |

## Encoding

## Type 1

| 31 24 23          | 16    | 15 8 | 7 0 |
|-------------------|-------|------|-----|
| 0 0 1 0 0 1 0 0 0 | T dst | src  | cnt |

## Type 2

| 31 24 23          | 3 16 | 15 8 | 7. 0 |
|-------------------|------|------|------|
| 0 0 1 1 0 1 0 0 0 |      | src  | cnt  |

## Instruction Word Fields

|        | Т  | <i>src1</i> addressing modes          | src2 addressing modes                 |
|--------|----|---------------------------------------|---------------------------------------|
|        | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| Type 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|        | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|        | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

|        | Т  | src1 addressing modes                                | <i>src2</i> addressing modes                        |  |
|--------|----|------------------------------------------------------|-----------------------------------------------------|--|
| Type 2 | 00 | register mode (any CPU register)                     | 8-bit signed immediate                              |  |
|        | 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement) |  |
|        | 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                              |  |
|        | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned displacement)   |  |

**Description** The seven least significant bits of the *count* operand are used to generate the twos-complement shift *count*.

If the *count* operand is greater than zero, the *dst* operand is left shifted by the value of the *count* operand. Low-order bits shifted in are zero-filled, and high-order bits are shifted out through the C (carry) bit.

Logical left-shift:



If the *count* operand is less than zero, the *src* operand is right shifted by the absolute value of the *count* operand. The high-order bits of the *dst* operand are zero-filled as shifted to the right. Low-order bits are shifted out through the C (carry) bit.

Logical right-shift:



If the *count* operand is 0, no shift is performed and the C (carry) bit is set to 0. The *count* operand is assumed to be a signed integer. The *src* and *dst* operands are assumed to be unsigned integers.

If *count* is greater than 32, the LSB ends up in the carry (C) bit. If *count* is less than –32, 0 ends up in the carry bit. This also applies to LSH.

#### Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unaffected.

LV Unaffected.

**UF** 0.

1

- **N** MSB of the output.
- Z 1 if a zero output is generated, 0 otherwise.

**V** 0.

**C** Set to the value of the last bit shifted out. 0 for a shift *count* of 0. Unaffected if *dst* is not R0 – R7.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | LSH3 count, src2, dst1                                                                                                                                      |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | If $count \ge 0$ :<br>$src2 << count \rightarrow dst1$<br>Else:<br>$src2 >>  count  \rightarrow dst1$<br>$   src3 \rightarrow dst2$                         |
| Operands  | countregister (R0 - R7) $src1$ indirect (disp = 0, 1, IR0, IR1) $dst1$ register (R0 - R7) $src2$ register (R0 - R7) $dst2$ indirect (disp = 0, 1, IR0, IR1) |

#### Encodina

| 31  | . – |       | 24 23 |       | 16   | 15  | 8 | 37  | 0 |
|-----|-----|-------|-------|-------|------|-----|---|-----|---|
| 1 1 | 0 1 | 1 1 0 | dst1  | count | src3 | dst | 2 | src | 2 |

Description The seven least significant bits of the count operand are used to generate the twos-complement shift count.

> If the *count* operand is greater than zero, the *dst* operand is left shifted by the value of the count operand. Low-order bits shifted in are zero-filled, and high-order bits are shifted out through the C (carry) bit.

Logical left-shift:

 $C \leftarrow dst2 \leftarrow 0$ 

If the *count* operand is less than zero, the *dst* operand is right shifted by the absolute value of the *count* operand. The high-order bits of the *dst* operand. are zero-filled as shifted to the right. Low-order bits are shifted out through the C (carry bit).

Logical right-shift:

 $0 \rightarrow dst2 \rightarrow C$ 

If the *count* operand is 0, no shift is performed and the carry bit is set to 0.

The *count* operand is assumed to be a 7-bit signed integer, and the *src2* and dst1 operands are assumed to be unsigned integers. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (LSH3) writes to the same register, then STI accepts as input the contents of the register before it is modified by the LSH3.

If src2 and dst2 point to the same location, src2 is read before the write to dst2.



| Cycles      | 1                                                                                                                                                                                                                                                                        |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status Bits | <ul> <li>LUF Unaffected.</li> <li>LV Unaffected</li> <li>UF 0.</li> <li>N MSB of the output.</li> <li>Z 1 if a zero output is generated, 0 otherwise.</li> <li>V 0.</li> <li>C Set to the value of the last bit shifted out. 0 for a shift <i>count</i> of 0.</li> </ul> |
| Mode Bit    | <b>OVM</b> Operation is affected by OVM bit value.                                                                                                                                                                                                                       |
| Example     | LSH3 R2,*++AR3(1),R0<br>   STI R4,*-AR5                                                                                                                                                                                                                                  |
|             | Before Instruction:                                                                                                                                                                                                                                                      |
|             | R2 = 18h = 24 $AR3 = 8098C2h$ $R0 = 0h$ $R4 = 0DCh = 220$ $AR5 = 80 98A3h$ $Data at 80 98C3h = 0ACh$ $Data at 80 98A2h = 0h$ $LUF LV UF N Z V C = 0 0 0 0 0 0 0$                                                                                                         |
|             | After Instruction: $R2 = 18h = 24$ $AR3 = 8098C3h$ $R0 = 0AC00\ 0000h$ $R4 = 0DCh = 220$ $AR5 = 80\ 98A3h$ Data at 80\ 98C3h = 0ACh         Data at 80\ 98A2h = 0DCh = 220         LUF LV UF N Z V C = 0 0 0 1 0 1 0                                                     |
|             |                                                                                                                                                                                                                                                                          |

#### Example

LSH3R7,\*AR2- -(1),R2 || STI R0,\*+AR0(1)

### **Before Instruction:**

R7 = 0FFFFF FF4h = -12 AR2 = 80 9863h R2 = 0h R0 = 12Ch = 300 AR0 = 80 98B7h Data at 80 9863h = 2C00 0000h Data at 80 98B8h = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

### After Instruction:

R7 = 0FFFFF FF4h = -12 AR2 = 80 9862h R2 = 2C000h R0 = 12Ch = 300 AR0 = 80 98B7h Data at 80 9863h = 2C00 0000h Data at 80 98B8h = 12Ch = 300 LUF LV UF N Z V C = 0 0 0 0 0 0 0

11

| Syntax    | LWLct src, dst                                                                                                                                                                                                                      |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Operation | src << {0, 1, 2, or 3} bytes and merged with $dst \rightarrow dst$                                                                                                                                                                  |  |  |  |
| Operands  | <ul> <li>ct the count of bytes {0, 1, 2, or 3} to shift left (ct x 8 = shift in bits)</li> <li>src register, direct, or indirect addressing modes</li> <li>dst register mode (any register in CPU primary register file)</li> </ul> |  |  |  |
| Encoding  |                                                                                                                                                                                                                                     |  |  |  |
| 31        | 24 23 16 15 8 7 <u>0</u>                                                                                                                                                                                                            |  |  |  |
|           |                                                                                                                                                                                                                                     |  |  |  |

src

#### Instruction Word Fields

в

G

1011010

| G  | <i>src</i> addressing modes      |
|----|----------------------------------|
| 00 | register mode (any CPU register) |
| 01 | direct mode                      |
| 10 | indirect mode                    |

dst

| В  | <i>src</i> byte          |  |  |
|----|--------------------------|--|--|
| 00 | no shift                 |  |  |
| 01 | shift left 1 byte space  |  |  |
| 10 | shift left 2 byte spaces |  |  |
| 11 | shift left 3 byte spaces |  |  |

**Description** The *src* operand is left shifted the specified number of bytes and merged with the bytes of the *dst* register that are below the left-shifted LSB of the *src* register.

Cycles

- Status Bits If ST (SET COND) = 0 and the destination register is R0 R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.
  - LUF Unaffected.
  - LV Unaffected.
  - **UF** 0.
  - N MSB of the output.
  - Z 1 if a zero result is generated, 0 otherwise.
  - **V** 0.
  - C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example LWL2 R1, R2

### **Before Instruction:**

R1 = ABCD EF12hR2 = 1234 5678h

#### **After Instruction:**

- R1 = ABCD EF12h (remains unchanged) EF12 0000h (left shifted interim value)
- R2 = EF125678h (contents merged)

| Syntax    | LWRct src, dst                                                                                                                                                                                                                       |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | src >> {0, 1, 2, or 3} bytes and merged with $dst \rightarrow dst$                                                                                                                                                                   |
| Operands  | <ul> <li>ct the count of bytes {0, 1, 2, or 3} to shift right (ct x 8 = shift in bits)</li> <li>src register, direct, or indirect addressing modes</li> <li>dst register mode (any register in CPU primary register file)</li> </ul> |
| Encoding  |                                                                                                                                                                                                                                      |

#### Encoding

| 31      | 24 23 | 16 15 | 87  | 0     |
|---------|-------|-------|-----|-------|
| 1011011 | BG    | dst   | src | 1 1 1 |

#### **Instruction Word Fields**

| G  | <i>src</i> addressing modes      |  |  |
|----|----------------------------------|--|--|
| 00 | register mode (any CPU register) |  |  |
| 01 | direct mode                      |  |  |
| 10 | indirect mode                    |  |  |

| В  | <i>src</i> byte           |
|----|---------------------------|
| 00 | no shift                  |
| 01 | shift right 1 byte space  |
| 10 | shift right 2 byte spaces |
| 11 | shift right 3 byte spaces |

**Description** The *src* operand is right shifted the specified number of bytes and merged with the bytes of the *dst* register that are above the right-shifted MSB of the *src* register. Sign is not extended.

Cycles



Status Bits If ST (SET COND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unaffected.

- LV Unaffected.
- **UF** 0.
- **N** MSB of the output.
- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

**Example** LWR1 AR1, R2

### **Before Instruction:**

AR1 = ABCD EF12hR2 = 1234 5678h

### After Instruction:

- AR1 = ABCD EF12h (remains unchanged) 00AB CDEFh (right-shifted interim value)
- R2 = 12AB CDEFh (contents merged)

## MBct Merge Byte, Left-Shifted

| Syntax    | MBct src, dst                                                                                                                                                                                                                    |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | 8 LSBs of <i>src</i> << {0, 1, 2, or 3} bytes and merged with $dst \rightarrow dst$                                                                                                                                              |
| Operands  | <ul> <li>ct the count of bytes {0, 1, 2, 3} to shift left (ct x 8 = shift in bits)</li> <li>src register, direct, or indirect addressing modes</li> <li>dst register mode (any register in CPU primary register file)</li> </ul> |
| Encodina  |                                                                                                                                                                                                                                  |

#### Encoaing

| 31      | 24 23 | 16 15 | 87  | 0 |
|---------|-------|-------|-----|---|
| 1011100 | B G   | dst   | src |   |

#### **Instruction Word Fields**

| G  | <i>src</i> addressing modes      |  |  |
|----|----------------------------------|--|--|
| 00 | register mode (any CPU register) |  |  |
| 01 | direct mode                      |  |  |
| 10 | indirect mode                    |  |  |

| В  | <i>src</i> byte          |  |
|----|--------------------------|--|
| 00 | no shift                 |  |
| 01 | shift left 1 byte space  |  |
| 10 | shift left 2 byte spaces |  |
| 11 | shift left 3 byte spaces |  |

Description The 8 LSBs of the src operand are left shifted (0, 1, 2, or 3) bytes and merged with the dst register.

Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unaffected.

- LV Unaffected.
- **UF** 0.
- **N** MSB of the output.
- Z 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.
- **Example** MB2 AR1, AR2

### **Before Instruction:**

AR1 = ABCD EF12hAR2 = 1234 5678h

### **After Instruction:**

- AR1 = ABCD EF12h (remains unchanged) 00AB CDEFh (left-shifted interim value)
- AR2 = 12125678h (contents merged)

| Syntax    | MHct src, dst                                                                                                                                                                                    |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | 16 LSBs of src << {0, 1} half-words merged with $dst \rightarrow dst$                                                                                                                            |
| Operands  | <ul> <li>ct the count of half-word (16-bit) shifts</li> <li>src register, direct, or indirect addressing modes</li> <li>dst register mode (any register in CPU primary register file)</li> </ul> |

## Encoding

| 31     | 24 23   | 16 15 | 87  | 0 |
|--------|---------|-------|-----|---|
| 101111 | 0 0 H G | dst   | src |   |

#### Instruction Word Fields

| G  | <i>src</i> addressing modes      |  |
|----|----------------------------------|--|
| 00 | register mode (any CPU register) |  |
| 01 | direct mode                      |  |
| 10 | indirect mode                    |  |

| Η  | <i>src</i> byte                  |  |  |
|----|----------------------------------|--|--|
| 00 | no shift                         |  |  |
| 01 | shift left 1 half-word (16 bits) |  |  |

**Description** The 16 LSBs of the *src* operand are left shifted (0, 1) half-words and merged with the *dst* register.

Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unaffected.

LV Unaffected.

**UF** 0.

- **N** MSB of the output.
- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.

*Mode Bit* OVM Operation is not affected by OVM bit value.

**Example** MH1 AR1, AR2

### **Before Instruction:**

AR1 = ABCD EF12hAR2 = 1234 5678h

#### After Instruction:

AR1 = ABCD EF12h (remains unchanged) EF12 0000h (left-shifted interim value)

AR2 = EF125678h (contents merged)

| Syntax                                                                                                                                                                                                                                                                                                                                                                                                                                                   | MPYF src, dst                                                                                                                                                                                                                                              |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                | $dst \times src \rightarrow dst$                                                                                                                                                                                                                           |  |  |  |
| Operands                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (R0 - R11)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate</li> </ul>                                                                                                    |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <i>dst</i> register (R0 – R11)                                                                                                                                                                                                                             |  |  |  |
| <b>Encoding</b><br>31                                                                                                                                                                                                                                                                                                                                                                                                                                    | 24 23 16 15 8 7 0                                                                                                                                                                                                                                          |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            |  |  |  |
| 0 0 1 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1 0 1 0 0 G dst src                                                                                                                                                                                                                                        |  |  |  |
| Description                                                                                                                                                                                                                                                                                                                                                                                                                                              | The product of the <i>dst</i> and <i>src</i> operands is loaded into the <i>dst</i> register. The <i>src</i> operand is assumed to be a single-precision floating-point number, and the <i>dst</i> operand is an extended-precision floating-point number. |  |  |  |
| Cycles                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1                                                                                                                                                                                                                                                          |  |  |  |
| <ul> <li>Status Bits LUF 1 if a floating-point underflow occurs, unchanged otherwise.</li> <li>LV 1 if a floating-point overflow occurs, unchanged otherwise.</li> <li>UF 1 if a floating-point underflow occurs, 0 otherwise.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if a floating-point is overflow occurs, 0 otherwise.</li> <li>C Unaffected.</li> </ul> |                                                                                                                                                                                                                                                            |  |  |  |
| Mode Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>OVM</b> Operation is not affected by OVM bit value.                                                                                                                                                                                                     |  |  |  |
| Example                                                                                                                                                                                                                                                                                                                                                                                                                                                  | MPYF R0,R2                                                                                                                                                                                                                                                 |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Before Instruction:                                                                                                                                                                                                                                        |  |  |  |
| R0 = 07 0C80 0000h = 1.4050e + 02<br>R2 = 03 4C20 0000h = 1.27578125e + 01<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                          | After Instruction:                                                                                                                                                                                                                                         |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R0 = 07 0C80 0000h = 1.4050e + 02<br>R2 = 0A 600F 2000h = 1.79247266e + 03<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                            |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            |  |  |  |

| Syntax MPYF3 src2, src1, | , dst |
|--------------------------|-------|
|--------------------------|-------|

**Operation** src1 x src2  $\rightarrow$  dst

*Operands* src1, src2 both type 1 or type 2 three-operand addressing modes dst register mode (R0 – R11)

### Encoding

Type 1

| 31 24 23          | 16    | 15 8 | 7 0  |
|-------------------|-------|------|------|
| 0 0 1 0 0 1 0 0 1 | T dst | src1 | src2 |

#### Type 2

| 31 2            | 4 23 16 | 15 8 | 7 0  |
|-----------------|---------|------|------|
| 0 0 1 1 0 1 0 0 | 1 T dst | src1 | src2 |

Instruction Word Fields

|        | Т  | <i>src1</i> addressing modes          | src2 addressing modes                 |
|--------|----|---------------------------------------|---------------------------------------|
|        | 00 | register mode (R0 — R11)              | register mode (R0 — R11)              |
| Type 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|        | 10 | register mode (R0 — R11)              | indirect mode (disp = 0, 1, IR0, IR1) |
|        | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

|   | Т  | <i>src1</i> addressing modes                         | <i>src2</i> addressing modes                      |
|---|----|------------------------------------------------------|---------------------------------------------------|
|   | 01 | register mode (R0 — R11)                             | indirect mode *+ARn(5-bit unsigned displacement)  |
| 2 | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned displacement) |

Type 2

**Description** The product of *src1*, and *src2*, is loaded into the *dst* register. The values at *src1*, *src2*, and *dst* are extended-precision floating-point numbers.

# Cycles 1

Status Bits LUF 1 if a floating-point underflow occurs, unchanged otherwise.

- LV 1 if a floating-point overflow occurs, unchanged otherwise.
- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- N 1 if a negative result is generated, 0 otherwise.
- Z 1 if a zero result is generated, 0 otherwise.
- V 1 if a floating-point is overflow occurs, 0 otherwise.
- C Unaffected.
- *Mode Bit* OVM Operation is not affected by OVM bit value.

| Syntax    | MPYF3 srcA, srcB, dst1<br>   ADDF3 srcC, srcD, dst2 |                                                    |                                                                                                                                                      |
|-----------|-----------------------------------------------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation |                                                     | $srcB \rightarrow dst1$<br>$srcD \rightarrow dst2$ |                                                                                                                                                      |
| Operands  | -                                                   |                                                    |                                                                                                                                                      |
|           | srcA<br>srcB<br>srcC<br>srcD                        |                                                    | nust be indirect (disp = 0, 1, IR0, IR1), and<br>nust be register (R0 – R7)                                                                          |
|           | dst1                                                | register ( <i>c</i><br>0 = R0<br>1 = R1            | (1):                                                                                                                                                 |
|           | dst2                                                | register ( <i>c</i><br>0 = R2<br>1 = R3            | 12):                                                                                                                                                 |
|           | src1<br>src2<br>src3<br>src4                        | register<br>register<br>indirect<br>indirect       | (R0 – R7)<br>(R0 – R7)<br>(disp = 0, 1, IR0, IR1)<br>(disp = 0, 1, IR0, IR1)                                                                         |
|           | P                                                   | parallel ac                                        | ddressing modes ( $0 \le P \le 3$ )                                                                                                                  |
|           | Operation (P Field)                                 |                                                    |                                                                                                                                                      |
|           |                                                     | 00<br>01<br>10<br>11                               | $src3 \times src4$ , $src1 + src2$<br>$src3 \times src1$ , $src4 + src2$<br>$src1 \times src2$ , $src3 + src4$<br>$src3 \times src1$ , $src2 + src4$ |
| Encoding  | 24 23                                               | 3                                                  | 16 15 8 7                                                                                                                                            |

**Description** A floating-point multiplication and a floating-point addition are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (MPYF3) reads from a register and the operation being performed in parallel (ADDF3) writes to the same register, then MPYF3 accepts as input the contents of the register before it is modified by the ADDF3.

src3

src2

src1

P d1 d2

1 0 0 0 0 0

0

src4

Any combination of addressing modes may be coded for the four possible source operands as long as two are coded as indirect and two are register. The assignment of the source operands srcA - srcD to the src1 - src4 fields varies, depending on the combination of addressing modes used; the P field is encoded accordingly. The assembler may, when not significant, change the order of operands in commutative operations in order to simplify processing.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

### Cycles

Status Bits

*Bits* LUF 1 if a floating-point underflow occurs, unchanged otherwise.

LV 1 if a floating-point overflow occurs, unchanged otherwise.

- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- N 0.

1

- **Z** 0.
- V 1 if a floating-point overflow occurs, 0 otherwise.
- C Unaffected.

#### Mode Bit

**OVM** Operation is not affected by OVM bit value.

### Example

11

MP¥ER5++(1),\*- -Addf3 r5,r7,r3

AR1(IR0),R0

## **Before Instruction:**

 $\begin{array}{l} AR5 = 80 \; 98C5h \\ AR1 = 80 \; 98A8h \\ IR0 = 4h \\ R0 = 0h \\ R5 = 07 \; 33C0 \; 0000h = 1.79750e + 02 \\ R7 = 07 \; 0C80 \; 0000h = 1.4050e + 02 \\ R3 = 0h \\ Data \; at \; 80 \; 98C5h = 34C \; 0000h = 1.2750e + 01 \\ Data \; at \; 80 \; 98A4h = 111 \; 0000h = 2.2500e + 00 \\ LUF \; LV \; UF \; N \; Z \; V \; C = 0 \; 0 \; 0 \; 0 \; 0 \; 0 \; 0 \end{array}$ 

## **After Instruction:**

 $\begin{array}{l} AR5 = 80\ 98C6h\\ AR1 = 80\ 98A4h\\ IR0 = 4h\\ R0 = 04\ 6718\ 0000h = 2.88867188e + 01\\ R5 = 07\ 33C0\ 0000h = 1.79750e + 02\\ R7 = 07\ 0C80\ 0000h = 1.4050e + 02\\ R3 = 08\ 2020\ 0000h = 3.20250e + 02\\ Data\ at\ 80\ 98C5h = 34C\ 0000h = 1.2750e + 01\\ Data\ at\ 80\ 98A4h = 111\ 0000h = 2.2500e + 00\\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

# **MPYF3**||**STF** Parallel MPYF3 and STF

| Synta | ax        |             | IPYF3 s<br>TF src3            | rc2, src1<br>, dst2                                           | l, dst                 |    |              |             |
|-------|-----------|-------------|-------------------------------|---------------------------------------------------------------|------------------------|----|--------------|-------------|
| Oper  | ation     |             | c1 × src.<br>c3 → ds          | 2 → dst1<br>t2                                                | 1                      |    |              |             |
| Oper  | ands      | dst1        | indirec<br>registe<br>registe | r (R0 – I<br>t (disp =<br>r (R0 – I<br>r (R0 – I<br>t (disp = | 0, 1, IR<br>77)<br>77) |    |              |             |
| Enco  | ding      |             |                               |                                                               |                        |    |              |             |
| 31    | - <u></u> | <del></del> | 24 23                         | <del></del>                                                   | 16                     | 15 | <del> </del> | <del></del> |
|       |           |             | • •                           |                                                               | •••                    |    | •••          | • •         |

src1

**Description** A floating-point multiplication and a floating-point store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (MPYF3) writes to a register and the operation being performed in parallel (STF) reads from the same register, then the STF accepts as input the contents of the register before it is modified by the MPYF3.

src3

If *src2* and *dst2* point to the same location, then *src2* is read before the write to *dst2*.

dst2

## Cycles

1

1 1 0 1 1 1 1

Status Bits LUF 1 if a floating-point underflow occurs, 0 unchanged otherwise.

- LV 1 if a floating-point overflow occurs, unchanged otherwise.
- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- **N** 1 if a negative result is generated, 0 otherwise.
- Z 1 if a zero result is generated, 0 otherwise.
- V 1 if a floating-point overflow occurs, 0 otherwise.
- C Unaffected.

dst1

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

1

src2

### Example

MPYF3 \*-AR2(1),R7,R0 || STFR3,\*AR0--(IR0)

## **Before Instruction:**

 $\begin{array}{l} AR2 = 80\ 982Bh \\ R7 = 05\ 7B40\ 0000h = 6.281250e + 01 \\ R0 = 0h \\ R3 = 08\ 6B28\ 0000h = 4.7031250e + 02 \\ AR0 = 80\ 9860h \\ IR0 = 8h \\ Data\ at\ 80\ 982Ah = 70C8000h = 1.4050e + 02 \\ Data\ at\ 80\ 9860h = 0h \\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

# After Instruction:

AR2 = 80 982Bh R7 = 05 7B40 0000h = 6.281250e + 01 R0 = 0D 09E4 A000h = 8.82515625e + 03 R3 = 08 6B28 0000h = 4.7031250e + 02 AR0 = 80 9858h IR0 = 8h Data at 80 982Ah = 70C 8000h = 1.4050e + 02 Data at 80 9860h = 86B28 0000h = 4.7031250e + 02 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax    |                              | 3 srcA, srcE<br>3 srcC, srcE                     |                                                                              |                   |
|-----------|------------------------------|--------------------------------------------------|------------------------------------------------------------------------------|-------------------|
| Operands  | -                            |                                                  |                                                                              |                   |
|           | srcA<br>srcB<br>srcC<br>srcD |                                                  | nust be indirect (disp = 0, 1, IR0, IR1), and nust be register (R0 $-$ R7)   |                   |
| Operation |                              | $srcB \rightarrow dst$<br>$srcC \rightarrow dst$ |                                                                              |                   |
|           | dst1                         | register ( <i>d</i><br>0 = R0<br>1 = R1          | 11):                                                                         |                   |
|           | dst2                         | register ( <i>d</i><br>0 = R2<br>1 = R3          | <i>12</i> ):                                                                 |                   |
|           | src1<br>src2<br>src3<br>src4 | register<br>register<br>indirect<br>indirect     | (R0 – R7)<br>(R0 – R7)<br>(disp = 0, 1, IR0, IR1)<br>(disp = 0, 1, IR0, IR1) |                   |
|           | Р                            | parallel ad                                      | ddressing modes ( $0 \le P \le 3$ )                                          |                   |
|           |                              | Opera                                            | ation (P Field)                                                              |                   |
|           |                              | 00                                               | src3 × src4, src1 – src2                                                     |                   |
|           |                              | 01                                               | src3 × src1, src4 – src2                                                     |                   |
|           |                              | 10                                               | src1 × src2, src3 – src4                                                     |                   |
|           |                              | 11                                               | src3 × src1, src2 – src4                                                     |                   |
| Encoding  |                              |                                                  |                                                                              |                   |
|           | 24 2                         | 3                                                | 16 15 8 7                                                                    |                   |
| 1 0 0 0   | 0 1 P d                      | 1 d2 <i>src1</i>                                 | src2 src3 src4                                                               | 1 <b>Г Т</b><br>4 |

**Description** A floating-point multiplication and a floating-point subtraction are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (MPYF3) reads from a register, and the operation being performed in parallel (SUBF3) writes to the same register, then MPYF3 accepts as input the contents of the register before it is modified by the SUBF3.

11

Assembly Language Instructions

Any combination of addressing modes may be coded for the four possible source operands as long as two are coded as indirect and two are register. The assignment of the source operands srcA - srcD to the src1 - src4 fields varies, depending on the combination of addressing modes used; the P field is encoded accordingly. The assembler may, when not significant, change the order of operands in commutative operations in order to simplify processing.

### Cycles

Status Bits LUF 1 if a floating-point underflow occurs, unchanged otherwise.

LV 1 if a floating-point overflow occurs, unchanged otherwise.

- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- N 0.

1

- **Z** 0.
- V 1 if a floating-point overflow occurs, 0 otherwise.
- C Unaffected.

# *Mode Bit* **OVM** Operation is not affected by OVM bit value.

## **MPYF3**||**SUBF3** Parallel MPYF3 and SUBF3

#### Example

|    | $MPIFS RS, ^{++}AR/(IRI), RU$ |
|----|-------------------------------|
|    | SUBF3R7,*AR3(1),R2            |
| or |                               |

MOVES DE + INDS/TD1) DO

MPYF3 \*++AR7(IR1), R5,R0
I SUBF3R7,\*AR3- -(1),R2

## **Before Instruction:**

 $\begin{array}{l} R5 = 03\ 4\text{C00}\ 0000h = 1.2750e + 01\\ AR7 = 80\ 9904h\\ IR1 = 8h\\ R0 = 0h\\ R7 = 07\ 33\text{C0}\ 0000h = 1.79750e + 02\\ AR3 = 80\ 98B2h\\ R2 = 0h\\ Data\ at\ 80\ 990\text{Ch} = 111\ 0000h = 2.250e + 00\\ Data\ at\ 80\ 98B2h = 70\text{C}\ 8000h = 1.4050e + 02\\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

## After Instruction:

 $\begin{array}{l} R5 = 03\ 4C00\ 0000h = 1.2750e + 01\\ AR7 = 80\ 990Ch\\ IR1 = 8h\\ R0 = 04\ 6718\ 0000h = 2.88867188e + 01\\ R7 = 07\ 33C0\ 0000h = 1.79750e + 02\\ AR3 = 80\ 98B1h\\ R2 = 05\ E300\ 0000h = -\ 3.9250e + 01\\ Data\ at\ 80\ 990Ch = 111\ 0000h = 2.250e + 00\\ Data\ at\ 80\ 98B2h = 70C\ 8000h = 1.4050e + 02\\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

| Syntax | MPYI | src, | dst |  |
|--------|------|------|-----|--|
|--------|------|------|-----|--|

**Operation**  $dst \times src \rightarrow dst$ 

*Operands* src general addressing modes (G):

0 0 register (any CPU register)

- 01 direct
- 10 indirect
- 11 immediate

dst register (any register in CPU primary register file)

### Encoding

| 31    | 24 23         | 16 15 | 87  | 0 |
|-------|---------------|-------|-----|---|
| 0 0 0 | 0 1 0 1 0 1 G | dst   | src |   |

**Description** The product of the *dst* and *src* operands is loaded into the *dst* register. The *src* and *dst* operands, when read, are assumed to be 32-bit signed integers. The result is assumed to be a 64-bit signed integer. The output to the *dst* register is the 32 least-significant bits of the result.

Integer overflow occurs when any of the most significant 32 bits of the 64-bit result differs from the most significant bit of the 32-bit output value.

Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unchanged.

- LV 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.

1

- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** Unaffected.
- *Mode Bit* **OVM** Operation is affected by OVM bit value.

**Example** MPYI R1,R5

## **Before Instruction:**

R1 = 00 0033 C251h = 3,392,081 R5 = 00 0078 B600h = 7,910,912 LUF LV UF N Z V C = 0 0 0 0 0 0 0

## After Instruction:

R1 = 00 0033 C251h = 3,392,081 R5 = 00 E21D 9600h =- 501,377,536 LUF LV UF N Z V C = 0 1 0 1 0 1 0

# MPYI3 Multiply Integer, 3 Operands

**Operation**  $src1 \times src2 \rightarrow dst$ 

*Operands* src1, src2 both type 1 or type 2 three-operand addressing modes dst register mode (any register in CPU primary register file)

### Encoding

Type 1

| 31            | 24 23 10         | 6 15 8 | .7 <u>0</u> |
|---------------|------------------|--------|-------------|
| 0 0 1 0 0 1 0 | 1 0 T <i>dst</i> | src1   | src2        |

### Type 2

| 31          | 24 23   | 16 15  | 87      | 0 |
|-------------|---------|--------|---------|---|
| 0 0 1 1 0 1 | 0 1 0 T | dst sr | c1 src2 |   |

### Instruction Word Fields

| Туре | 1 |
|------|---|

|   | Т  | <i>src1</i> addressing modes          | <i>src2</i> addressing modes          |
|---|----|---------------------------------------|---------------------------------------|
|   | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|   | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|   | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

| Type | 2 |
|------|---|
| .,   | _ |

| Т  | src1 addressing modes                                | <i>src2</i> addressing modes                      |
|----|------------------------------------------------------|---------------------------------------------------|
| 00 | register mode (any CPU register)                     | 8-bit signed immediate                            |
| 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned displacement)  |
| 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                            |
| 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned displacement) |

**Description** The product of the numbers at *src1* and *src2* is loaded into the *dst* register. The multiplied numbers are assumed to be 32-bit signed integers. The result is assumed to be a signed 64-bit integer. The output to the *dst* register is the 32 least significant bits of the result.

Cycles

1

11-152

11

Assembly Language Instructions

- Status Bits If ST (SET COND) = 0 and the destination register is R0 R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.
  - LUF Unchanged.
  - LV 1 if an integer overflow occurs, unchanged otherwise.
  - **UF** 0.
  - **N** 1 if a negative result is generated, 0 otherwise.
  - **Z** 1 if a zero result is generated, 0 otherwise.
  - V 1 if an integer overflow occurs, 0 otherwise.
  - C Unaffected.
- *Mode Bit* **OVM** Operation is affected by OVM bit value.
- *Note* Integer overflow occurs when any of the most significant 32 bits of the 64-bit result differs from the most significant bit of the 32-bit output value.

# MPYI3||ADDI3 Parallel MPYI3 and ADDI3

| Syntax         | MPYI3 srcA, srcB, dst1       |                                              |                                                                                  |                  |
|----------------|------------------------------|----------------------------------------------|----------------------------------------------------------------------------------|------------------|
| -              | ADDI3 srcC, srcD, dst2       |                                              |                                                                                  |                  |
| Operation      |                              | $srcA \times srcB \rightarrow dst1$          |                                                                                  |                  |
|                | <i>srcD</i> +                | $srcC \rightarrow ds$                        | 12                                                                               |                  |
| Operands       | -                            |                                              |                                                                                  |                  |
|                | srcA<br>srcB<br>srcC<br>srcD |                                              | nust be indirect (disp = 0, 1<br>nust be register (R0 – R7)                      | , IR0, IR1), and |
|                | dst1                         | register (a<br>0 = R0<br>1 = R1              | (1):                                                                             |                  |
|                | dst2                         | register (a<br>0 = R2<br>1 = R3              | <i>12</i> ):                                                                     |                  |
|                | src1<br>src2<br>src3<br>src4 | register<br>register<br>indirect<br>indirect | (R0 – R7)<br>(R0 – R7)<br>(disp = 0, 1, IR0, IR1)<br>(disp = 0, 1, IR0, IR1)     |                  |
|                | Р                            | parallel ac                                  | dressing modes ( $0 \le P \le 3$ )                                               | )                |
|                |                              | Opera                                        | ation (P Field)                                                                  |                  |
|                |                              | 00<br>01<br>10                               | src3 × src4, src1 + src2<br>src3 × src1, src4 + src2<br>src1 × src2, src3 + src4 |                  |
|                |                              | 11                                           | $src3 \times src1$ , $src2 + src4$                                               |                  |
| Encoding<br>31 | 24.23                        | 3                                            | 16 15                                                                            | 87               |

| 31    | 24 23      | 3 16         | 15 8 | 7 0  |
|-------|------------|--------------|------|------|
| 1 0 0 | 0 1 0 P d1 | d2 src1 src2 | src3 | src4 |

**Description** An integer multiplication and an integer addition are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (MPYI3) reads from a register and the operation being performed in parallel (ADDI3) writes to the same register, then MPYI3 accepts as input the contents of the register before it is modified by the ADDI3.

Any combination of addressing modes may be coded for the four possible source operands as long as two are coded as indirect and two are register. The assignment of the source operands srcA - srcD to the src1 - src4 fields varies, depending on the combination of addressing modes used; the P field is encoded accordingly. The assembler may, when not significant, change the order of operands in commutative operations in order to simplify processing.

## Cycles

Status Bits LUF Unchanged.

1

- LV 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.

**N** 0.

**Z** 0.

- V 1 if an integer overflow occurs, 0 otherwise.
- **C** Unaffected.

*Mode Bit* **OVM** Operation is affected by OVM bit value.

Example

MPYI3 R7,R4,R0 ADDI3\*-AR3,\*AR5- -(1),R3

## **Before Instruction:**

 $\begin{array}{l} {\rm R7}=14{\rm h}=20\\ {\rm R4}=64{\rm h}=100\\ {\rm R0}=0{\rm h}\\ {\rm AR3}=80\ 981{\rm Fh}\\ {\rm AR5}=80\ 996{\rm Eh}\\ {\rm R3}=0{\rm h}\\ {\rm Data\ at\ 80\ 981{\rm Eh}}=0{\rm FFFF\ FFCBh}=-53\\ {\rm Data\ at\ 80\ 996{\rm Eh}}=35{\rm h}=53\\ {\rm LUF\ LV\ UF\ N\ Z\ V\ C}=0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

# After Instruction:

 $\begin{array}{l} {\rm R7}=14{\rm h}=20\\ {\rm R4}=64{\rm h}=100\\ {\rm R0}=07{\rm D0h}=2000\\ {\rm AR3}=80\ 981{\rm Fh}\\ {\rm AR5}=80\ 996{\rm Dh}\\ {\rm R3}=0{\rm h}\\ {\rm Data\ at\ 80\ 981{\rm Eh}}=0{\rm FFFF\ FFCBh}=-53\\ {\rm Data\ at\ 80\ 996{\rm Eh}}=35{\rm h}=53\\ {\rm LUF\ LV\ UF\ N\ Z\ V\ C}=0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

### **MPYI3**||**STI** Parallel MPYI3 and STI3

| Syntax                | MPYI3 src2, src<br>   STI src3, dst2                                                       | 1, dst1                    |    |  |
|-----------------------|--------------------------------------------------------------------------------------------|----------------------------|----|--|
| Operation             | $src1 \times src2 \rightarrow ds$<br>   $src3 \rightarrow dst2$                            | lst1                       |    |  |
| Operands              | src1register (R0 -src2indirect (dispdst1register (R0 -src3register (R0 -dst2indirect (disp | = 0, 1, IR0, IR1)<br>- R7) |    |  |
| <b>Encoding</b><br>31 | 24 23                                                                                      | 16 15                      | 87 |  |

| 31  |           | 24 23 |      | 16    | 15   | 8 | 7       | 0 |
|-----|-----------|-------|------|-------|------|---|---------|---|
|     |           |       |      | 1 1   |      |   | 1 1 1 1 |   |
| 1 1 | 1 0 0 0 0 | dst1  | src1 | src3  | dst2 |   | src     | 2 |
|     |           |       |      | · · · |      |   |         |   |

**Description** An integer multiplication and an integer store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (MPYI3) writes to the same register, then STI accepts as input the contents of the register before it is modified by the MPYI3.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

Integer overflow occurs when any of the most significant 16 bits of the 48-bit result differs from the most significant bit of the 32-bit output value.

| Cycles      | 1                                                                                                                                                                                                                               |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status Bits | LUF Unchanged.<br>LV 1 if an integer overflow occurs, unchanged otherwise.                                                                                                                                                      |
|             | <ul> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an integer overflow occurs, 0 otherwise.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit    | <b>OVM</b> Operation is affected by OVM bit value.                                                                                                                                                                              |

### Example

MPYI3 \*++AR0(1),R5,R7 || STI R2,\*-AR3(1)

# **Before Instruction:**

AR0 = 80 995Ah R5 = 32h = 50 R7 = 0h R2 = 0DCh = 220 AR3 = 80 982Fh Data at 80 995Bh = 0C8h = 200 Data at 80 982Eh = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

# After Instruction:

AR0 = 80 995Bh R5 = 32h = 50 R7 = 2710h = 10000 R2 = 0DCh = 220 AR3 = 80 982Fh Data at 80 995Bh = 0C8h = 200 Data at 80 982Eh = 0DCh = 220 LUF LV UF N Z V C = 0 0 0 0 0 0 0

### MPYI3||SUBI3 Parallel MPYI3 and SUBI3

| Syntax    | MPYI3 srcA, srcB, dst1<br>   SUBI3 srcC, srcD, dst2 |                                                                                            |                                                                                                                                                      |  |
|-----------|-----------------------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation |                                                     | $srcB \rightarrow dst1$<br>$srcC \rightarrow dst2$                                         |                                                                                                                                                      |  |
| Operands  |                                                     |                                                                                            |                                                                                                                                                      |  |
| -         | srcA<br>srcB<br>srcC<br>srcD                        | Any two must be indirect (disp = 0, 1, IR0, IR1), and any two must be register (R0 $-$ R7) |                                                                                                                                                      |  |
|           | dst1                                                | register ( <i>d1</i><br>0 = R0<br>1 = R1                                                   | ():                                                                                                                                                  |  |
|           | dst2                                                | register ( <i>d2</i><br>0 = R2<br>1 = R3                                                   | 2):                                                                                                                                                  |  |
|           | src1<br>src2<br>src3<br>src4                        | register<br>register<br>indirect<br>indirect                                               | (R0 – R7)<br>(R0 – R7)<br>(disp = 0, 1, IR0, IR1)<br>(disp = 0, 1, IR0, IR1)                                                                         |  |
|           | Р                                                   | parallel add                                                                               | dressing modes ( $0 \le P \le 3$ )                                                                                                                   |  |
|           |                                                     | Operation (P Field)                                                                        |                                                                                                                                                      |  |
|           |                                                     | 00<br>01<br>10<br>11                                                                       | $src3 \times src4$ , $src1 - src2$<br>$src3 \times src1$ , $src4 - src2$<br>$src1 \times src2$ , $src3 - src4$<br>$src3 \times src1$ , $src2 - src4$ |  |
| Encoding  |                                                     |                                                                                            |                                                                                                                                                      |  |
| 31        | 24 23                                               | 3                                                                                          | 16 15 8 7                                                                                                                                            |  |
|           |                                                     |                                                                                            |                                                                                                                                                      |  |

 31
 24 23
 16 15
 8 7
 0

 1 0
 0 0 1 1
 P
 d1 d2
 src1
 src2
 src3
 src4

**Description** An integer multiplication and an integer subtraction are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (MPYI3) reads from a register and the operation being performed in parallel (SUBI3) writes to the same register, then MPYI3 accepts as input the contents of the register before it is modified by the SUBI3. Any combination of addressing modes may be coded for the four possible source operands as long as two are coded as indirect and two are register. The assignment of the source operands srcA - srcD to the src1 - src4 fields varies, depending on the combination of addressing modes used; the P field is encoded accordingly. The assembler may, when not significant, change the order of operands in commutative operations in order to simplify processing.

Integer overflow occurs when any of the most significant 16 bits of the 48-bit result differs from the most significant bit of the 32-bit output value.

Cycles

Status Bits LUF Unchanged.

1

LV 1 if an integer overflow occurs, unchanged otherwise.

**UF** 1 if an integer underflow occurs, 0 otherwise.

N 0.

**Z** 0.

V 1 if an integer overflow occurs, 0 otherwise.

**C** Unaffected.

*Mode Bit* **OVM** Operation is affected by OVM bit value.

#### Example

|      | MPYI3 R2,*++AR0(1),R0 |
|------|-----------------------|
| li – | SUBI3AR5 (IR1),R4,R2  |
| or   |                       |
|      | MPYI3 *++AR0(1),R2,R0 |
| I    | SUBI3AR5 (IR1),R4,R2  |

### **Before Instruction:**

R2 = 32h = 50  $AR0 = 80 \ 98E3h$  R0 = 0h  $AR5 = 80 \ 99FCh$  IR1 = 0Ch R4 = 07D0h = 2000  $Data \ at \ 80 \ 98E4h = 62h = 98$   $Data \ at \ 80 \ 99FCh = 4B0h = 1200$   $LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0$ 

## **After Instruction:**

R2 = 320h = 800 AR0 = 80 98E4h R0 = 01324h = 4900 AR5 = 80 99F0h IR1 = 0Ch R4 = 07D0h = 2000 Data at 80 98E4h = 62h = 98 Data at 80 99FCh = 4B0h = 1200 LUF LV UF N Z V C = 0 0 0 0 0 0 0

**Operation**  $dst \times src \rightarrow dst$ 

*Operands src* general addressing modes dst register mode (any register in CPU primary register file)

### Encoding

| 31 24 23          | 16    | 15 87 | 0 |
|-------------------|-------|-------|---|
| 0 0 0 1 1 1 0 1 1 | G dst | src   |   |

## Instruction Word Fields

| G  | <i>src</i> addressing modes      |  |  |  |
|----|----------------------------------|--|--|--|
| 00 | register mode (any CPU register) |  |  |  |
| 01 | direct mode                      |  |  |  |
| 10 | indirect mode                    |  |  |  |
| 11 | immediate mode                   |  |  |  |

**Description** The 32 MSBs of the product of the numbers at *dst* and *src* are loaded into the *dst* register. These numbers, when read, are assumed to be signed 32-bit integers. The result is assumed to be a signed 64-bit integer. The output to the *dst* register is the 32 most significant bits of the result.

### Cycles

- Status Bits If ST (SET COND) = 0 and the destination register is R0 R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.
  - LUF Unchanged.
  - LV Unchanged.

**UF** 0.

1

- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if all 64 bits of the product are 0, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax | MPYSHI3 | src2, src1, dst |
|--------|---------|-----------------|
|        |         |                 |

**Operation**  $src1 \times src2 \rightarrow dst$ 

**Operands** type 1 or type 2 three-operand addressing modes src1 type 1 or type 2 three-operand addressing modes src2 register mode (any register in CPU primary register file) dst

## Encoding

Type 1

| 31 24 2           | 3     | 16 15 | 87 0 |
|-------------------|-------|-------|------|
| 0 0 1 0 1 0 0 0 1 | T dst | src1  | src2 |

Type 2

| 31 24 23          | 16    | 15 8 | 7 0  |
|-------------------|-------|------|------|
| 0 0 1 1 1 0 0 0 1 | T dst | src1 | src2 |

Instruction Word Fields

|        | Т  | <i>src1</i> addressing modes          | <i>src2</i> addressing modes          |
|--------|----|---------------------------------------|---------------------------------------|
|        | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| Type 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|        | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|        | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

|                                                                                                                                                                                                                                               | Т                                                   | src1 addressing modes                                | <i>src2</i> addressing modes                         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|------------------------------------------------------|------------------------------------------------------|
| Type 2       00       register mode (any CPU register)         01       register mode (any CPU register)         10       indirect mode *+ARn(5-bit unsigned displacement)         11       indirect mode *+ARn1(5-bit unsigned displacement) | 00                                                  | register mode (any CPU register)                     | 8-bit signed immediate                               |
|                                                                                                                                                                                                                                               | 01                                                  | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement)  |
|                                                                                                                                                                                                                                               | indirect mode *+ARn(5-bit unsigned<br>displacement) | 8-bit signed immediate                               |                                                      |
|                                                                                                                                                                                                                                               | 11                                                  | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

11

Description The product of the numbers at the src1 and src2 operands is loaded into the dst register. The numbers at the src1 and src2 operands are assumed to be 32-bit signed integers. The result is assumed to be a signed 64-bit integer. The output to the dst register is the 32 most significant bits of the result.

### Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unchanged.

LV 1 if an integer overflow occurs, unchanged otherwise.

**UF** 0.

1

- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | MPYUHI src, d                 | st                                       |                            |       |
|-----------|-------------------------------|------------------------------------------|----------------------------|-------|
| Operation | $dst  x  src \rightarrow dst$ |                                          |                            |       |
| Operands  |                               | ddressing modes<br>node (any register in | CPU primary register file) |       |
| Encoding  |                               |                                          |                            |       |
| 31        | 24 23                         | 16 15                                    | 87                         | 0     |
|           |                               |                                          |                            | 1 1 1 |
| 0 0 0 1   | 1 1 1 0 0 G                   | dst                                      | SIC                        | 1     |

Instruction Word Fields

| G  | <i>src</i> addressing modes      |  |
|----|----------------------------------|--|
| 00 | register mode (any CPU register) |  |
| 01 | direct mode                      |  |
| 10 | indirect mode                    |  |
| 11 | immediate mode                   |  |

**Description** The 32 MSBs of the product of the numbers at *dst* and *src* operands are loaded into the *dst* register. These numbers, when read, are assumed to be unsigned 32-bit integers. The result is assumed to be an unsigned 64-bit integer. The output to the *dst* register is the 32 most significant bits of the result.

Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unchanged.

LV Unchanged.

**UF** 0.

1

N 0.

- **Z** 1 if all 64 bits of the product are 0, 0 otherwise.
- **V** 0.
- C Unaffected.

*Mode Bit* OVM Operation is not affected by OVM bit value.

| Syntax MPYUHI3 | src2, | src1, | dst |
|----------------|-------|-------|-----|
|----------------|-------|-------|-----|

| Operation | src1 × | $src2 \rightarrow$ | dst |
|-----------|--------|--------------------|-----|
|-----------|--------|--------------------|-----|

*Operands* src1, src2 both type 1 or type 2 three-operand addressing modes dst register mode (any register in CPU primary register file)

# Encoding

### Type 1

| 31 24 2         | 3 1   | 6 15 8 | <u> </u> |
|-----------------|-------|--------|----------|
| 0 0 1 0 1 0 0 1 | T dst | src1   | src2     |

#### Type 2

| 31 24 23          | 16    | 15 8 | 7 0  |
|-------------------|-------|------|------|
| 0 0 1 1 1 0 0 1 0 | T dst | src1 | src2 |

### **Instruction Word Fields**

|        | Т  | src1 addressing modes                 | src2 addressing modes                 |
|--------|----|---------------------------------------|---------------------------------------|
| -      | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| Type 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|        | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|        | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

|        | Т  | src1 addressing modes                                | src2 addressing modes                                |
|--------|----|------------------------------------------------------|------------------------------------------------------|
| Type 2 | 00 | register mode (any CPU register)                     | 8-bit signed immediate                               |
|        | 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned displacement)     |
|        | 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                               |
|        | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

**Description** The product of the numbers at the *src1* and *src2* operands is loaded into the *dst* register. The numbers at the *src1* and *src2* operands are assumed to be 32-bit signed integers. The result is assumed to be an unsigned 64-bit integer. The output to the *dst* register is the 32 most significant bits of the result.

Cycles

Status Bits If ST (SET COND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SET COND) = 1, they are modified for all destination registers.

LUF Unchanged.

LV Unchanged.

**UF** 0.

N 0.

- **Z** 1 if all 64 bits of the product are 0, 0 otherwise.
- **V** 0.
- C Unaffected.

*Mode Bit* OVM Operation is not affected by OVM bit value.

| Syntax                      | NEGB src, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                   | $0 - src - C \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Operands                    | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate</li> </ul>                                                                                                                                                                                                                                                                                                                                         |
|                             | dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Encoding<br>31<br>0 0 0 0 1 | 24 23 16 15 87 0<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Description                 | The difference of the 0, <i>src</i> , and C operands, calculated as shown, is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> are assumed to be signed integers.                                                                                                                                                                                                                                                                                                                                              |
| Cycles                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Status Bits                 | <ul> <li>If ST (SETCOND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV 1 if an integer overflow occurs, unchanged otherwise.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an integer overflow occurs, 0 otherwise.</li> <li>C 1 if a borrow occurs, 0 otherwise.</li> </ul> |
| Mode Bit                    | OVM Operation is affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Example                     | NEGB R5,R7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                             | R5 = 0FFFF FFCBh = - 53<br>R7 = 0h<br>LUF LV UF N Z V C = 0 0 0 0 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                             | After Instruction: 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                             | R5 = 0FFFF FFCBh = - 53<br>R7 = 34h = 52<br>LUF LV UF N Z V C = 0 0 0 0 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Syntax                      | NEGF src, dst                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation                   | $0 - src \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| Operands                    | <pre>src general addressing modes (G): 0 0 register (R0 - R11) 0 1 direct 1 0 indirect 1 1 immediate</pre>                                                                                                                                                                                                                                                                                                                                |  |
|                             | <i>dst</i> register (R0 – R11)                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Encoding<br>31<br>0 0 0 0 1 | 24 23 16 15 87 0<br>0 1 1 1 G dst src                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| Description                 | The difference of the 0 and <i>src</i> operands is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be floating-point numbers.                                                                                                                                                                                                                                                                  |  |
| Cycles                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| Status Bits                 | <ul> <li>LUF 1 if a floating-point underflow occurs, unchanged otherwise.</li> <li>LV 1 if a floating-point overflow occurs, unchanged otherwise.</li> <li>UF 1 if a floating-point underflow occurs, 0 otherwise.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if a floating-point overflow occurs, 0 otherwise.</li> <li>C Unaffected.</li> </ul> |  |
| Mode Bit<br>Example         | <b>OVM</b> Operation is not affected by OVM bit value.<br>NEGF *++AR3(2), R1                                                                                                                                                                                                                                                                                                                                                              |  |
|                             | Before Instruction:         AR3 = 80 9800h         R1 = 05 7B40 0025h = $6.28125006e + 01$ Data at 80 9802h = 70C 8000h = $1.4050e + 02$ LUF LV UF N Z V C = 0 0 0 0 0 0 0 0         After Instruction:         AR3 = 80 9802h         R1 = 07 F380 0000h = $-1.4050e + 02$ Data at 80 9802h         R1 = 07 F380 0000h = $-1.4050e + 02$ LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                               |  |
|                             |                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |

| Syntax    | NEGF src2, dst1                                                                                                      |
|-----------|----------------------------------------------------------------------------------------------------------------------|
|           | STF src3, dst2                                                                                                       |
| Operation | $0 - src2 \rightarrow dst1$                                                                                          |
|           | $\parallel src3 \rightarrow dst2$                                                                                    |
| Operands  | src2indirect (disp = 0, 1, IR0, IR1)dst1register (R0 - R7)src3register (R0 - R7)dst2indirect (disp = 0, 1, IR0, IR1) |

## Encoding

| 31          | 24 23      | 16 15   | 87    | 0    |
|-------------|------------|---------|-------|------|
| 1 1 1 0 0 1 | dst1 0 0 0 | src3 ds | 11111 | src2 |

**Description** A floating-point negation and a floating-point store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STF) reads from a register and the operation being performed in parallel (NEGF) writes to the same register, then STF accepts as input the contents of the register before it is modified by the NEGF.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

## Cycles

1

Status Bits LUF 1 if a floating-point underflow occurs, 0 unchanged otherwise.

- **LV** 1 if a floating-point overflow occurs, unchanged otherwise.
- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if a floating-point overflow occurs, 0 otherwise.
- C Unaffected.

# *Mode Bit* **OVM** Operation is not affected by OVM bit value.

```
Example
```

NEGF\*AR4- -(1),R7 || STF R2,\*++AR5(1)

### **Before Instruction:**

 $\begin{array}{l} AR4 = 80\ 98E1h \\ R7 = 0h \\ R2 = 07\ 33C0\ 0000h = 1.79750e + 02 \\ AR5 = 80\ 9803h \\ Data\ at\ 80\ 98E1h = 57\ B40\ 0000h = 6.281250e + 01 \\ Data\ at\ 80\ 9804h = 0h \\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

## After Instruction:

 $\begin{array}{l} \mathsf{AR4} = 80\ 98\mathsf{E0h} \\ \mathsf{R7} = 05\ 84\mathsf{C0}\ 0000h = -\ 6.281250e +\ 01 \\ \mathsf{R2} = 07\ 33\mathsf{C0}\ 0000h = 1.79750e +\ 02 \\ \mathsf{AR5} = 80\ 9804h \\ \mathsf{Data}\ at\ 80\ 98\mathsf{E1h} = 57\mathsf{B}\ 4000h = 6.281250e +\ 01 \\ \mathsf{Data}\ at\ 80\ 9804h = 733\ \mathsf{C000h} = 1.79750e +\ 02 \\ \mathsf{LUF}\ \mathsf{LV}\ \mathsf{UF}\ \mathsf{N}\ \mathsf{Z}\ \mathsf{V}\ \mathsf{C} = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \end{array}$ 

| Syntax                      | NEGI src, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                   | $0 - src \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Operands                    | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate</li> </ul>                                                                                                                                                                                                                                                                                                                                         |
|                             | dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Encoding<br>31<br>0 0 0 0 1 | 24 23 16 15 87 0<br>1 0 0 0 G dst src                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Description                 | The difference of the 0 and <i>src</i> operands is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be signed integers.                                                                                                                                                                                                                                                                                                                                                                |
| Cycles                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Status Bits                 | <ul> <li>If ST (SETCOND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV 1 if an integer overflow occurs, unchanged otherwise.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an integer overflow occurs, 0 otherwise.</li> <li>C 1 if a borrow occurs, 0 otherwise.</li> </ul> |
| Mode Bit                    | OVM Operation is affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Example                     | NEGI 174, R5 $(174 = 0AEh)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                             | R5 = 0DCh = 220<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                             | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                             | R5 = 0FFFFF52 = -174<br>LUF LV UF N Z V C = 0 0 0 1 0 0 1 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## **NEGI||STI** Parallel NEGI and STI

| Syntax    | NEGI src2, dst1                                                                                                                  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------|
| Operation | $0 - src2 \rightarrow dst1$    src3 $\rightarrow$ dst2                                                                           |
| Operands  | src2indirect (disp = 0, 1, IR0, IR1) $dst1$ register (R0 - R7) $src3$ register (R0 - R7) $dst2$ indirect (disp = 0, 1, IR0, IR1) |

### Encoding

| 31            | 24 23      | 16 15     | 87     | 0            |
|---------------|------------|-----------|--------|--------------|
| 1 1 1 0 0 1 0 | dst1 0 0 0 | src3 dst2 | ? src2 | <b>· · ·</b> |

**Description** An integer negation and an integer store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (NEGI) writes to the same register, then STI accepts as input the contents of the register before it is modified by the NEGI.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

Cycles

Status Bits LUF Unaffected.

1

LV 1 if an integer overflow occurs, unchanged otherwise.

- **UF** 0.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** 1 if a borrow occurs, 0 otherwise.

*Mode Bit* **OVM** Operation is affected by OVM bit value.

### Example

NEGI \*-AR3,R2 || STI R2,\*AR1++

# **Before Instruction:**

AR3 = 80 982Fh R2 = 19h = 25 AR1 = 80 98A5h Data at 80 982Eh = 0DCh = 220 Data at 80 98A5h = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

### After Instruction:

AR3 = 80 982Fh R2 = 0FFFF FF24h = -220AR1 = 80 98A6h Data at 80 982Eh = 0DCh = 220 Data at 80 98A5h = 19h = 25 LUF LV UF N Z V C = 0 0 0 1 0 0 1

| Syntax      | NOP src                                                                                                                                                                                                       |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operation   | No ALU or multiplier operations.<br>ARn is modified if <i>src</i> is specified in indirect mode.                                                                                                              |  |  |
| Operands    | src general addressing modes (G): $0 \ 0$ $1 \ 0$ indirect (modify ARn, $0 \le n \le 7$ )                                                                                                                     |  |  |
| Encoding    |                                                                                                                                                                                                               |  |  |
|             | $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                          |  |  |
| 0 0 0 0 1   | 1 0 0 1 G 0 0 0 0 0 src                                                                                                                                                                                       |  |  |
| Description | If the <i>src</i> operand is specified in the indirect mode, the specified addressing operation is performed and a dummy memory read occurs. If the <i>src</i> operand is omitted, no operation is performed. |  |  |
| Cycles      | 1                                                                                                                                                                                                             |  |  |
| Status Bits | <ul> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF Unaffected.</li> <li>N Unaffected.</li> <li>Z Unaffected.</li> <li>V Unaffected.</li> <li>C Unaffected.</li> </ul>                               |  |  |
| Mode Bit    | OVM Operation is not affected by OVM bit value.                                                                                                                                                               |  |  |
| Example     | NOP                                                                                                                                                                                                           |  |  |
|             | Before Instruction:                                                                                                                                                                                           |  |  |
|             | PC = 3Ah                                                                                                                                                                                                      |  |  |
|             | After Instruction:                                                                                                                                                                                            |  |  |
|             | PC = 3Bh                                                                                                                                                                                                      |  |  |
| Example     | NOP *AR3(1)                                                                                                                                                                                                   |  |  |
|             | Before Instruction:                                                                                                                                                                                           |  |  |
|             | PC = 5h<br>AR3 = 80 9900h                                                                                                                                                                                     |  |  |
| I           | After Instruction:                                                                                                                                                                                            |  |  |
|             | PC = 6h<br>AR3 = 80 98FFh                                                                                                                                                                                     |  |  |

| Syntax    | NORM src, dst                                                                                           |      |
|-----------|---------------------------------------------------------------------------------------------------------|------|
| Operation | norm ( <i>src</i> ) → <i>dst</i>                                                                        |      |
| Operands  | src general addressing modes (G):<br>00 register (R0 – R11)<br>01 direct<br>10 indirect<br>11 immediate |      |
| Encoding  |                                                                                                         |      |
| 31        | 24 23 16 15                                                                                             | 87 0 |
| 0 0 0 0   | 1 1 0 1 0 G <i>dst</i>                                                                                  | src  |

**Description** The *src* operand is assumed to be an unnormalized floating-point number; i.e., the implied bit is set equal to the sign bit. The *dst* is set equal to the normalized *src* operand with the implied bit removed. The *dst* operand exponent is set to the *src* operand exponent minus the size of the left shift necessary to normalize the *src*. The *dst* operand is assumed to be a normalized floating-point number.

For values of src:

- If src (exp) = -128 and src (man) = 0, then dst = 0, Z = 1, and UF = 0.
- □ If src (exp) = -128 and src (man)  $\neq 0$ , then dst = 0, Z = 0, and UF = 1.
- □ For all other cases of the *src*, if a floating-point underflow occurs, then *dst* (man) is forced to 0 and *dst* (exp) = -128. If *src* (man) = 0, then *dst* (man) = 0 and *dst* (exp) = -128. Refer to Section 4.7 on page 4-24.

# Cycles

Status Bits LUF 1 if a floating-point underflow occurs, unchanged otherwise.

- LV Unaffected.
- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- N 1 if a negative result is generated, 0 otherwise.
- Z 1 if a zero result is generated, 0 otherwise.
- **V** 0.

1

- **C** Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

**Example** NORM R1, R2

# **Before Instruction:**

R1 = 04 0000 3AF5h R2 = 07 0C80 0000h LUF LV UF N Z V C = 0 0 0 0 0 0 0

# **After Instruction:**

R1 = 04 0000 3AF5h R2 = F2 6BD4 0000h = 1.12451613e - 04 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax          | NOT src, dst                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation       | $\sim$ src $\rightarrow$ dst                                                                                                                                                                                                                                                                                                                                                          |
| Operands        | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate</li> </ul>                                                                                                                                                                                              |
| Encoding        | dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                                                              |
| 31<br>0 0 0 0 1 | 24 23 16 15 87 0<br>1 0 1 1 G dst src                                                                                                                                                                                                                                                                                                                                                 |
| Description     | The bitwise logical complement of the <i>src</i> operand is loaded into the <i>dst</i> reg-<br>ister. The complement is formed by a logical NOT of each bit of the <i>src</i> oper-<br>and. The <i>dst</i> and <i>src</i> operands are assumed to be unsigned integers.                                                                                                               |
| Cycles          | 1                                                                                                                                                                                                                                                                                                                                                                                     |
| Status Bits     | <ul> <li>If ST (SETCOND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF 0.</li> <li>N MSB of the output.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 0.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit        | <b>OVM</b> Operation is affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                    |
| Example         | NOT 0982Ch, R4<br>Before Instruction:<br>DP = 80h<br>R4 = 0h<br>Data at 80 982Ch = 5E2Fh<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0 0<br>After Instruction:<br>DP = 80h<br>R4 = 0FFFF A1D0h<br>Data at 80 982Ch = 5E2Fh<br>LUF LV UF N Z V C = 0 0 0 1 0 0 0                                                                                                                                |

| Syntax    | NOT <i>src2</i> , <i>dst1</i><br>   STI <i>src3</i> , <i>dst2</i>                                                                |
|-----------|----------------------------------------------------------------------------------------------------------------------------------|
| Operation | $\sim$ src2 $\rightarrow$ dst1<br>   src3 $\rightarrow$ dst2                                                                     |
| Operands  | src2indirect (disp = 0, 1, IR0, IR1) $dst1$ register (R0 - R7) $src3$ register (R0 - R7) $dst2$ indirect (disp = 0, 1, IR0, IR1) |

## Encoding

| 31            | 24 23             | 16 15   | 87      | 0 |
|---------------|-------------------|---------|---------|---|
| 1 1 1 0 0 1 1 | <i>dst1</i> 0 0 0 | src3 ds | t2 src2 |   |

**Description** A bitwise logical NOT and an integer store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (NOT) writes to the same register, then STI accepts as input the contents of the register before it is modified by the NOT.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

#### Cycles

Status Bits LUF Unaffected.

- LV Unaffected.
- **UF** 0.
- N MSB of the output.
- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

## Example

NOT \*+AR2,R3 || STI R7,\*- -AR4 (IR1)

# **Before Instruction:**

AR2 = 80 99CBh R3 = 0h R7 = 0DCh = 220 AR4 = 80 9850h IR1 = 10h Data at 80 99CCh = 0C2Fh Data at 80 9840h = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

# **After Instruction:**

AR2 = 80 99CBh R3 = 0FFFF F3D0h R7 = 0DCh = 220 AR4 = 80 9840h IR1 = 10h Data at 80 99CCh = 0C2Fh Data at 80 9840h = 0DCh = 220 LUF LV UF N Z V C = 0 0 0 1 0 0 0

|    | Syntax                | OR src, dst                                                                                                                                                                                                                                                                                                                     |
|----|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | Operation             | $dst \text{ OR } src \rightarrow dst$                                                                                                                                                                                                                                                                                           |
|    | Operands              | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate (not sign-extended)</li> </ul>                                                                                                                    |
|    |                       | dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                        |
|    | <b>Encoding</b><br>31 | 24 23 16 15 8 7 0                                                                                                                                                                                                                                                                                                               |
|    |                       |                                                                                                                                                                                                                                                                                                                                 |
|    |                       | The bitwise logical OR between the <i>src</i> and <i>dst</i> opreands is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be unsigned integers.                                                                                                                                       |
|    | Cycles<br>Status Bits | 1                                                                                                                                                                                                                                                                                                                               |
|    |                       | If ST (SETCOND) = 0 and the destination register is R0 – R11, the condition<br>flags are modified. If ST (SETCOND) = 1, they are modified for all destina-<br>tion registers.<br>LUF Unaffected.<br>LV Unaffected.<br>UF 0.<br>N MSB of the output.<br>Z 1 if a zero result is generated, 0 otherwise.<br>V 0.<br>C Unaffected. |
|    | Mode Bit              | <b>OVM</b> Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                          |
|    | Example               | OR *++AR1(IR1),R2                                                                                                                                                                                                                                                                                                               |
|    |                       | Before Instruction:         AR1 = 80 9800h         IR1 = 4h         R2 = 01256 0000h         Data at 80 9804h = 2BCDh         LUF LV UF N Z V C = 0 0 0 0 0 0 0 0                                                                                                                                                               |
| 11 |                       | After Instruction:         AR1 = $80\ 9804h$ IR1 = $4h$ R2 = $01256\ 2BCDh$ Data at $80\ 9804h = 2BCDh$ LUF LV UF N Z V C = $0\ 0\ 0\ 0\ 0\ 0\ 0$                                                                                                                                                                               |

Assembly Language Instructions

| Syntax | OR3 ( | src2, | src1, | dst |
|--------|-------|-------|-------|-----|
|--------|-------|-------|-------|-----|

**Operation**  $src1 \mid src2 \rightarrow dst$  (| = OR)

*Operands* src1, src2 both type 1 or type 2 three-operand addressing modes register mode (any register in CPU primary register file)

# Encoding

Type 1

| 31 24 23          | 3 16  | 15 8 | 7 0  |
|-------------------|-------|------|------|
| 0 0 1 0 0 1 0 1 1 | T dst | src1 | src2 |

## Type 2

| 31 24 23          | 16    | 15 8 | 7 0  |
|-------------------|-------|------|------|
| 0 0 1 1 0 1 0 1 1 | T dst | src1 | src2 |

# Instruction Word Fields

|     | Т  | <i>src1</i> addressing modes          | <i>src2</i> addressing modes          |
|-----|----|---------------------------------------|---------------------------------------|
|     | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| e 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|     | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|     | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

Type 1

|        | Т  | src1 addressing modes                                | <i>src2</i> addressing modes                         |
|--------|----|------------------------------------------------------|------------------------------------------------------|
|        | 00 | register mode (any CPU register)                     | 8-bit signed immediate                               |
| Type 2 | 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement)  |
| Type 2 | 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                               |
|        | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

**Description** The bitwise logical OR between the numbers at the *src1* and *src2* operands is loaded into the *dst* register. The numbers at the *src1*, *src2*, and *dst* operands are assumed to be unsigned integers.

#### Cycles

**Status Bits** If ST (SETCOND) = 0, the condition flags are modified if the destination register is R0 — R11. If ST (SETCOND) = 1, they are modified for all destination registers.

LUF Unaffected.

- LV Unaffected.
- **UF** 0.

- **N** MSB of the output.
- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | OR3 src2, src1,<br>   STI src3, dst2                                                                                                               | , dst1                              |    |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|----|
| Operation | src1 OR src2 – $\parallel src3 \rightarrow dst2$                                                                                                   | → dst1                              |    |
| Operands  | <i>src1</i> register (R0 –<br><i>src2</i> indirect (disp<br><i>dst1</i> register (R0 –<br><i>src3</i> register (R0 –<br><i>dst2</i> indirect (disp | = 0, 1, IR0, IR1)<br>- R7)<br>- R7) |    |
| Encoding  |                                                                                                                                                    |                                     |    |
| 31        | 24 23                                                                                                                                              | 16 15                               | 87 |

| 31  |           | 24 23     | CI 01 | 0/   | <u> </u> |
|-----|-----------|-----------|-------|------|----------|
|     |           |           |       |      |          |
| 1 1 | 1 0 1 0 0 | dst1 src1 | src3  | dst2 | src2     |

A bitwise logical OR and an integer store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (OR3) writes to the same register, then STI accepts as input the contents of the register before it is modified by the OR3.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

# Cycles

Status Bits LUF Unaffected.

1

LV Unaffected.

**UF** 0.

- **N** MSB of the output.
- **Z** 1 if a zero result is generated, 0 otherwise.
- **V** 0.
- C Unaffected.

# *Mode Bit* **OVM** Operation is not affected by OVM bit value.

11

Δ

#### Example

OR3 \*++AR2,R5,R2 || STIR6,\*AR1- -

## **Before Instruction:**

 $\begin{array}{l} AR2 = 80 \ 9830h \\ R5 = 80 \ 0000h \\ R2 = 0h \\ R6 = 0DCh = 220 \\ AR1 = 80 \ 9883h \\ Data \ at \ 80 \ 9831h = 9800h \\ Data \ at \ 80 \ 9883h = 0h \\ LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \end{array}$ 

## After Instruction:

AR2 = 80 9831hR5 = 80 0000h R2 = 80 9800h R6 = 0DCh = 220 AR1 = 80 9882h Data at 80 9831h = 9800h Data at 80 9883h = 0DCh = 220 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax      | POP dst                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •           |                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Operation   | $*SP \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                |
| Operands    | dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                                                                                             |
| Encoding    | 24 23 16 15 8 7 0                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0 0 0 0 1   |                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Description | The top of the current system stack is popped and loaded into the <i>dst</i> regis-<br>ter. The top of the stack is assumed to be a signed integer. The POP is per-<br>formed with a post decrement of the stack pointer.                                                                                                                                                                                            |
| Cycles      | 1                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Status Bits | <ul> <li>If ST (SETCOND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV Unaffected.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 0.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit    | <b>OVM</b> Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                               |
| Example     | POP R3                                                                                                                                                                                                                                                                                                                                                                                                               |
|             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                  |
|             | $SP = 80\ 9856h$<br>R3 = 012DAh = 4,826<br>Data at 80 9856h = 0FFFF 0DA4h = - 62,044<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                            |
|             | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                   |
|             | $SP = 80\ 9855h$<br>R3 = 0FFFF 0DA4h = -62,044<br>Data at 80 9856h = 0FFFF 0DA4h = -62,044<br>LUF LV UF N Z V C = 0 0 0 1 0 0 0 1                                                                                                                                                                                                                                                                                    |

POPF POP Floating-Point Value

| Syntax      | POPF dst                                                                                                                                                                                                                              |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation   | *SP $\rightarrow$ dst1                                                                                                                                                                                                                |
| Operands    | dst register (R0 – R11)                                                                                                                                                                                                               |
| Encoding    |                                                                                                                                                                                                                                       |
| 31          |                                                                                                                                                                                                                                       |
| 00001       | 1 1 0 1 0 1 dst 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                 |
| Description | The top of the current system stack is popped and loaded into the <i>dst</i> regis-<br>ter. The top of the stack is assumed to be a floating-point number. The POP<br>is performed with a post decrement of the stack pointer.        |
| Cycles      | 1                                                                                                                                                                                                                                     |
| Status Bits | <ul> <li>LUF Unaffected.</li> <li>UF 0.</li> <li>LV Unaffected.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 0.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit    | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                       |
| Example     | POPF R4                                                                                                                                                                                                                               |
|             | Before Instruction:                                                                                                                                                                                                                   |
|             | $SP = 80\ 984Ah$<br>R4 = 02 5D2E 0123h = 6.91186578e + 00<br>Data at 80 984Ah = 5F2C 1302h = 5.32544007e + 28<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0 0                                                                                  |
|             | After Instruction:                                                                                                                                                                                                                    |
|             | $SP = 80\ 9849h$<br>R4 = 5F 2C13 0200h = 5.32544007e + 28<br>Data at 80 984Ah = 5F2C 1302h = 5.32544007e + 28<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                    |

**Operation**  $src \rightarrow *++SP$ 

**Operands** src register (any register in CPU primary register file)

## Encoding

| 31 | 24 23           | 16 15 | 87                  | 0 |
|----|-----------------|-------|---------------------|---|
|    | 0 1 1 1 1 0 0 1 |       | 0 0 0 0 0 0 0 0 0 0 |   |

**Description** The contents of the *src* register are pushed on the current system stack. The *src* is assumed to be a signed integer. The PUSH is performed with a preincrement of the stack pointer.

#### Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- **C** Unaffected.

# *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example PUSH R6

# **Before Instruction:**

 $SP = 80 \ 98AEh$ R6 = 815Bh = 33,115 Data at 80 98AFh = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

## After Instruction:

SP = 80 98AFh R6 = 815Bh = 33,115Data at 80 98AFh = 815Bh = 33,115 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax                | PUSHF src                                                                                                                                                                                                        |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation             | $src \rightarrow *++SP$                                                                                                                                                                                          |
| Operands              | <i>src</i> register (R0 – R11)                                                                                                                                                                                   |
| <b>Encoding</b><br>31 | 24 23 16 15 8 7 0                                                                                                                                                                                                |
| 0 0 0 0 1             |                                                                                                                                                                                                                  |
| Description           | The contents of the <i>src</i> register are pushed onto the current system stack.<br>The <i>src</i> is assumed to be a floating-point number. The PUSH is performed<br>with a preincrement of the stack pointer. |
| Cycles                | 1                                                                                                                                                                                                                |
| Status Bits           | LUFUnaffected.LVUnaffected.UFUnaffected.NUnaffected.ZUnaffected.VUnaffected.CUnaffected.                                                                                                                         |
| Mode Bit              | OVM Operation is not affected by OVM bit value.                                                                                                                                                                  |
| Example               | PUSHF R2                                                                                                                                                                                                         |
|                       | Before Instruction:                                                                                                                                                                                              |
|                       | $SP = 80\ 9801h$<br>$R2 = 02\ 5C12\ 8081h = 6.87725854e + 00$<br>Data at 80\ 9802h = 0h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                     |
|                       | After Instruction:                                                                                                                                                                                               |
|                       | $SP = 80\ 9802h$<br>$R2 = 02\ 5C1\ 28081h = 6.87725854e + 00$<br>Data at 80\ 9802h = 025C\ 1280h = 6.87725830e + 00<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                         |
|                       |                                                                                                                                                                                                                  |

Syntax RCPF src, dst

**Operation** 16-bit reciprocal of  $src \rightarrow dst$ 

*Operands* src extended-precision register, direct and indirect addressing modes dst R0 - R11

## Encoding

| 31        | 24 23     | 16 15 | 87  | 0              |
|-----------|-----------|-------|-----|----------------|
| 0 0 0 1 1 | 1 0 1 0 G | dst   | src | - <b>I</b> I I |

Instruction Word Fields

| G  | <i>src</i> addressing modes               |
|----|-------------------------------------------|
| 00 | extended-precision register<br>(R0 – R11) |
| 01 | direct mode                               |
| 10 | indirect mode                             |

**Description** The 16-bit approximation of the reciprocal of the *src* operand is loaded into the *dst* register. The *dst* and *src* operands are assumed to be floating-point numbers.

Cycles

1

Status Bits LUF 1 if a floating-point underflow occurs, unchanged otherwise.

LV 1 if a floating-point overflow occurs, unchanged otherwise.

**UF** 1 if a floating-point underflow occurs, 0 otherwise.

- **N** 1 if a negative result is generated, 0 otherwise.
- Z 1 is a zero result, 0 otherwise.
- V 1 if a floating-point overflow occurs, 0 otherwise.
- C Unaffected.

*Mode Bit* OVM Operation is not affected by OVM bit value.

| RETIcond                    | Return From Interrupt or Trap Conditionally                                                                                                                                                                                              |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax                      | RETIcond                                                                                                                                                                                                                                 |
| Operation                   | If ( <i>cond</i> is true)<br>$^{*}(SP) \rightarrow PC$<br>$ST(PGIE) \rightarrow ST(GIE)$<br>$ST(PCF) \rightarrow ST(CF)$<br>Else, continue                                                                                               |
| Operands                    | None                                                                                                                                                                                                                                     |
| Encoding<br>31<br>0 1 1 1 1 | 24 23 16 15 87 0<br>0 0 0 0 0 <i>cond</i> 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                |
| Description                 | If the condition is true, then the top of the stack is popped to the PC, PGIE is copied to GIE, and PCF is copied to CF. If the condition is not true, then continue normal operation (see Section 11.2 on page 11-10 for a list of con- |

dition mnemonics, encoding, and flags).

| Cycles      | 4   |             |
|-------------|-----|-------------|
| Status Bits | LUF | Unaffected. |
|             | LV  | Unaffected. |
|             | UF  | Unaffected. |
|             | Ν   | Unaffected. |
|             | Ζ   | Unaffected. |
|             | V   | Unaffected. |
|             | Ċ   | Unaffected. |

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax    | RETIcondD                                                                                                                               |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Operation | If ( <i>cond</i> is true)<br>$*(SP) \rightarrow PC$<br>$ST(PGIE) \rightarrow ST(GIE)$<br>$ST(PCF) \rightarrow ST(CF)$<br>Else, continue |
| Operands  | None                                                                                                                                    |
| Encoding  |                                                                                                                                         |
| 31        | 24 23 16 15 8 7 0                                                                                                                       |
|           |                                                                                                                                         |
| 0 1 1 1   | 1 0 0 0 0 1 <i>cond</i> 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                 |
| <b>.</b>  |                                                                                                                                         |

Description Performs a delayed return from an interrupt or trap.

Since this is a delayed return, the three instructions following the RETI*cond*D are fetched and executed. These three instructions may neither modify the program flow nor load the status register (see Section 11.2 on page 11-10 for a list of condition mnemonics, encoding, and flags).

Interrupts are disabled for the duration of the RETI*cond*D.

Cycles

| Status Bits | LUF<br>LV<br>UF<br>N<br>Z<br>V<br>C | Unaffected.<br>Unaffected.<br>Unaffected.<br>Unaffected.<br>Unaffected.<br>Unaffected. |
|-------------|-------------------------------------|----------------------------------------------------------------------------------------|
|             | •                                   | Unaffected.                                                                            |

1

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax                      | RETScond                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                   | If <i>cond</i> is true:<br>*SP $ \rightarrow$ PC.<br>Else, continue.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Operands                    | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Encoding<br>31<br>0 1 1 1 1 | 24 23     16 15     87     0       0     0     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     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 |
| Description                 | A conditional return is performed. If the condition is true, the top of the stack is popped to the PC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                             | The TMS320C40 provides 20 condition codes that can be used with this in-<br>struction (see Section 11.2 on page 11-10 for a list of condition mnemonics,<br>encoding, and flags).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Cycles                      | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Status Bits                 | LUFUnaffected.LVUnaffected.UFUnaffected.NUnaffected.ZUnaffected.VUnaffected.CUnaffected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Mode Bit                    | <b>OVM</b> Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Example                     | RETSGE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                             | PC = 123h<br>SP = 80 983Ch<br>Data at 80 983Ch = 456h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                             | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                             | PC = 456h<br>SP = 80 983Bh<br>Data at 80 983Ch = 456h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

.

| Syntax                      | RND src, dst                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation                   | $rnd(src) \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                                |
| Operands                    | <pre>src general addressing modes (G): 0 0 register (R0 - R11) 0 1 direct 1 0 indirect 1 1 immediate</pre>                                                                                                                                                                                                                                                                                                                                |
|                             | <i>dst</i> register (R0 – R11)                                                                                                                                                                                                                                                                                                                                                                                                            |
| Encoding<br>31<br>0 0 0 1 0 | 24 23 16 15 87 0<br>0 0 1 0 G dst src                                                                                                                                                                                                                                                                                                                                                                                                     |
| Description                 | The result of rounding the <i>src</i> operand is loaded into the <i>dst</i> register. The <i>src</i> operand is rounded to the nearest single-precision floating-point value. If the <i>src</i> operand is exactly halfway between two single-precision values, it is rounded to the most positive of those values.                                                                                                                       |
| Cycles                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Status Bits                 | <ul> <li>LUF 1 if a floating-point underflow occurs, unchanged otherwise.</li> <li>LV 1 if a floating-point overflow occurs, unchanged otherwise.</li> <li>UF 1 if a floating-point underflow occurs, 0 otherwise.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if a floating-point overflow occurs, 0 otherwise.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit                    | OVM Operation is affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                               |
| Example                     | RND R5,R2                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                             | R5 = 07 33C1 6EEFh = 1.79755599e + 02<br>R2 = 0h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                     |
|                             | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                             | R5 = 07 33C1 6EEFh = 1.79755599e + 02<br>R2 = 07 33C1 6F00h = 1.79755600e + 02<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                     |

# ROL Rotate Left

Syntax ROL dst

**Operation** dst left-rotated 1 bit  $\rightarrow$  dst

**Operands** dst register (any register in CPU primary register file)

#### Encoding

| 31 | 24 23    | 16 15              | 87                | 0 |
|----|----------|--------------------|-------------------|---|
|    | 10001111 | <i>dst</i> 0 0 0 0 | 0 0 0 0 0 0 0 0 0 |   |

**Description** The contents of the *dst* operand are left-rotated one bit and loaded into the *dst* register. This is a circular rotate with the MSB transferred into the LSB.

**Rotate left:** 



#### Cycles

Status Bits If ST (SETCOND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.

LUF Unaffected.

LV Unaffected.

**UF** 0.

1

**N** MSB of the output.

**Z** 1 if a zero output is generated, 0 otherwise.

**V** 0.

C Set to the value of the bit rotated out of the high-order bit. Unaffected if dst is not R0 – R7.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

**Example** ROL R3

## **Before Instruction:**

R3 = 8002 5CD4h

 $LUF \ LV \ UF \ N \ Z \ V \ C = 0 \quad 0 \quad 0 \quad 0 \quad 0 \quad 0 \quad 0$ 

# After Instruction:

R3 = 0004 B9A9h LUF LV UF N Z V C = 0 0 0 0 0 1 Syntax ROLC dst

**Operation** dst left-rotated 1 bit through carry bit  $\rightarrow$  dst

**Operands** dst register (any register in CPU primary register file)

## Encoding

| 31 | 24 23    | 16 15           | 87                | 0 |
|----|----------|-----------------|-------------------|---|
|    | 10010011 | <i>dst</i> 0000 | 0 0 0 0 0 0 0 0 0 | 1 |

**Description** The contents of the *dst* operand are left-rotated one bit through the carry bit and loaded into the *dst* register. The MSB is rotated to the carry bit, at the same time the carry bit is transferred to the LSB.

Rotate left through carry bit:



# Cycles

Status Bits If ST (SETCOND) = 0 and the destination register is R0 — R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.

LUF Unaffected.

LV Unaffected.

**UF** 0.

- **N** MSB of the output.
- **Z** 1 if a zero output is generated, 0 otherwise.
- **V** 0.
- C Set to the value of the bit rotated out of the high-order bit. If dst is not R0 R7, then C is shifted into the dst but not changed.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

**Example** ROLC R3

## **Before Instruction:**

R3 = 0000 0420h LUF LV UF N Z V C = 0 0 0 0 0 1

# After Instruction:

R3 = 00000 0841h LUF LV UF N Z V C = 0 0 0 0 0 0 0

**Example** ROLC R3

# **Before Instruction:**

R3 = 8000 4281h LUF LV UF N Z V C = 0 0 0 0 0 0 0

## **After Instruction:**

R3 = 0000 8502h LUF LV UF N Z V C = 0 0 0 0 0 1

Syntax ROR dst

**Operation** dst right-rotated 1 bit through carry bit  $\rightarrow$  dst

*Operands* dst register (any register in CPU primary register file)

# Encoding

| 31          | 24 23 | 16 15 8 7             | 0 |
|-------------|-------|-----------------------|---|
| 0 0 0 1 0 0 |       | 0 0 0 0 0 0 0 0 0 0 0 |   |

**Description** The contents of the *dst* operand are right-rotated one bit and loaded into the *dst* register. The LSB is rotated into the carry bit and also transferred into the MSB.

Rotate right:



## Cycles

Status Bits If ST (SETCOND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.

LUF Unaffected.

LV Unaffected.

**UF** 0.

1

- N MSB of the output.
- **Z** 1 if a zero output is generated, 0 otherwise.
- **V** 0.
- C Set to the value of the bit rotated out of the high-order bit. Unaffected if *dst* is not R0 R7.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example ROR R7

# **Before Instruction:**

R7 = 00000421h LUF LV UF N Z V C = 0 0 0 0 0 0 0

# After Instruction:

R7 = 80000210h LUF LV UF N Z V C = 0 0 0 1 0 0 1

# **RORC** Rotate Right Through Carry

Syntax RORC dst

**Operation** dst right-rotated 1 bit through carry bit  $\rightarrow$  dst

*Operands* dst register (any register in CPU primary register file)

#### Encoding

| 3 | 1 |   |   |   |   |   | - | 24 | 42 | 3 |   |   | ÷., |   | 16 | 3 15 | i |   |   |   |   |   | 8 | 37 |   |     |   |   |   | - | 0   |
|---|---|---|---|---|---|---|---|----|----|---|---|---|-----|---|----|------|---|---|---|---|---|---|---|----|---|-----|---|---|---|---|-----|
| C | ) | 0 | 0 | 1 | 0 | 0 | 1 | 1  | C  | 1 | 1 | E |     | d | 1  |      | • | • | • | • | • | • | • |    | • | · . | 1 | • | • | • | · . |

**Description** The contents of the *dst* operand are right-rotated one bit through the status register's carry bit. This could be viewed as a 33-bit shift. The carry bit value is rotated into the MSB of the *dst*; at the same time, the *dst* LSB is rotated into the carry bit.

Rotate right through carry bit:



## Cycles

Status Bits If ST (SETCOND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.

LUF Unaffected.

- LV Unaffected.
- **UF** 0.

1

- **N** MSB of the output.
- **Z** 1 if a zero output is generated, 0 otherwise.
- V 0.
- C Set to the value of the bit rotated out of the high-order bit. If dst is not R0 R7, then C is shifted in but not changed.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example RORC R4

# **Before Instruction:**

R4 = 8000 0081h LUF LV UF N Z V C = 0 0 0 1 0 0 0

## After Instruction:

R4 = 4000 0040h LUF LV UF N Z V C = 0 0 0 0 0 1

Assembly Language Instructions

Syntax RPTB src

**Operation**  $src + PC + 1 \rightarrow RE$ 1  $\rightarrow$  ST (RM) Next PC  $\rightarrow$  RS

*Operands* src 24-bit signed immediate displacement or register mode

# Encoding

For 24-bit signed immediate or register mode:

| 31  | 24          | 23 | 16 15              | 87 | 0 |
|-----|-------------|----|--------------------|----|---|
| 0 1 | 1 0 0 1 0 0 |    | <i>src</i> (displa |    |   |

For register mode:

| 31 | 24 23 | 16 15           | 87 | 0   |
|----|-------|-----------------|----|-----|
|    |       | 0 0 0 0 0 0 0 0 |    | src |

**Description** RPTB allows a block of instructions to be repeated a number of times without any penalty for looping.

It activates the block repeat mode of updating the PC. The *src* operand may be a 32-bit register value or a 24-bit signed immediate value (displacement). The resulting *src* address is the end address of the block to be repeated. This address is loaded into the repeat end address (RE) register. A 1 is written into the repeat mode bit of status register (ST(RM)) to indicate that the PC is to be updated in the repeat mode. The address of the next instruction is loaded into the repeat start address (RS) register.

Cycles

Status BitsLUFUnaffected.LVUnaffected.UFUnaffected.ZUnaffected.ZUnaffected.VUnaffected.CUnaffected.

4

*Mode Bit* OVM Operation is not affected by OVM bit value.

- men

| RPIBD SIC                                                                           |
|-------------------------------------------------------------------------------------|
| if <i>src</i> is an immediate value (displacement)<br>$src + PC + 3 \rightarrow RE$ |
| Else:                                                                               |
| $src \rightarrow RE$                                                                |
| $1 \rightarrow ST(RM)$                                                              |
| PC of RPTBD + 4 $\rightarrow$ RS                                                    |
|                                                                                     |

Operands src 24-bit signed immediate displacement or register mode

## Encoding

C. mtore

For 24-bit signed immediate or register mode:

|                                           | 0 | 87                        | 23 16 15 | 24 | 31 |
|-------------------------------------------|---|---------------------------|----------|----|----|
| 0 1 1 0 0 1 0 1 <i>src</i> (displacement) |   | <i>src</i> (displacement) |          |    |    |

For register mode:

| 31 24 23 | 3 16 15               | 87 | 0   |
|----------|-----------------------|----|-----|
|          | 0 0 0 0 0 0 0 0 0 0 0 |    | src |

**Description** RPTBD allows a block of instructions to be repeated a number of times without any penalty for looping and with single-cycle execution of the RPTBD instruction.

It activates the block repeat mode of updating the PC. The *src* operand may be a 32-bit register value or a 24-bit signed immediate value (displacement). The resulting *src* address is loaded into the repeat end address (RE) register (block end address). A 1 is written to the status-register repeat mode bit (ST(RM)), indicating the PC is to be updated in the repeat mode. The address of the next instruction +3 is loaded into the repeat start address (RS) register.

RPTBD does not flush the pipeline. The three instructions following RPTBD are executed and may not be an instruction that modifies the program flow. These three instructions are not part of the block that is repeated.

| Cycles      | 1   |                                             |
|-------------|-----|---------------------------------------------|
| Status Bits | LUF | Unaffected.                                 |
|             | LV  | Unaffected.                                 |
|             | UF  | Unaffected.                                 |
|             | Ν   | Unaffected.                                 |
|             | Ζ   | Unaffected.                                 |
|             | V   | Unaffected.                                 |
|             | С   | Unaffected.                                 |
| Mode Bit    | OVM | Operation is not affected by OVM bit value. |

| Syntax        | <b>RPTS</b> src |
|---------------|-----------------|
| <b>U</b> yman |                 |

| Operation | $src \rightarrow RC$     |
|-----------|--------------------------|
|           | $1 \rightarrow ST (RM)$  |
|           | 1 → S                    |
|           | Next PC $\rightarrow$ RS |
|           |                          |

Next PC  $\rightarrow$  RE

*Operands* src general addressing modes (G):

- 00 register
- 0 1 direct
- 10 indirect
- 11 immediate

# Encoding

| 31    | 24 23         | 16 15     | 87  | 0 |
|-------|---------------|-----------|-----|---|
| 0 0 0 | 1 0 0 1 1 1 G | 1 1 0 1 1 | src |   |

**Description** The RPTS instruction allows a single instruction to be repeated a number of times without any penalty for looping. Fetches can also be made from the instruction register (IR), thus avoiding repeated memory access.

The *src* operand is loaded into the repeat counter (RC). A 1 is written into the repeat mode bit of the status register ST (RM). A 1 is also written into the repeat single bit (S). This indicates that the program fetches are to be performed only from the instruction register. The next PC is loaded into the repeat end address (RE) register and the repeat start address (RS) register.

For the immediate mode, the *src* operand is assumed to be an unsigned integer and is not sign-extended.

| Cycles      | 4   |             |
|-------------|-----|-------------|
| Status Bits | LUF | Unaffected. |
|             | LV  | Unaffected. |
|             | UF  | Unaffected. |
|             | Ν   | Unaffected. |
|             | Z   | Unaffected. |
|             | V   | Unaffected. |
|             | С   | Unaffected. |

*Mode Bit* OVM Operation is not affected by OVM bit value.

2

Example RPTS AR5

# **Before Instruction:**

| PC = 123h<br>ST = 0h<br>RS = 0h     |   |   |   |   |   |   |
|-------------------------------------|---|---|---|---|---|---|
| RE = 0h $RC = 0h$                   |   |   |   |   |   |   |
| AR5 = 0FFh<br>LUF LV UF N Z V C = 0 | 0 | 0 | 0 | 0 | 0 | 0 |

# After Instruction:

| PC = 124h  |   |   |   |       |   |   |   |   |   |   |  |
|------------|---|---|---|-------|---|---|---|---|---|---|--|
| ST = 100h  |   |   |   |       |   |   |   |   |   |   |  |
| RS = 124h  |   |   |   |       |   |   |   |   |   |   |  |
| RE = 124h  |   |   |   |       |   |   |   |   |   |   |  |
| RC = 0FFh  |   |   |   |       |   |   |   |   |   |   |  |
| AR5 = 0FFh |   |   |   |       |   |   |   |   |   |   |  |
| LUF LV UF  | Ν | Ζ | V | C = 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

Syntax RSQRF src, dst

**Operation** 16-bit reciprocal of the square root of  $src \rightarrow dst$ 

*Operands src* extended-precision register, direct and indirect addressing modes *dst* extended-precision register

## Encoding

| 31 24 2           | 3     | 16 15 | 87  | 0 |
|-------------------|-------|-------|-----|---|
| 0 0 0 1 1 1 0 0 1 | G dsi | t     | src |   |

Instruction Word Fields

| G  | <i>src</i> addressing modes               |
|----|-------------------------------------------|
| 00 | extended-precision register<br>(R0 – R11) |
| 01 | direct mode                               |
| 10 | indirect mode                             |

**Description** The 16-bit approximation of the reciprocal of the square root of the number at the *src* operand is loaded into the *dst* register. The number at the *src* operand is assumed to be positive. The operation for negative inputs is undefined.

The value at the *dst* and *src* operands are assumed to be floating-point numbers.

# Cycles

Status Bits LUF Unchanged.

1

- LV 1 if input is zero unchanged otherwise.
- **UF** 0.
- N 0.
- **Z** 0
- V 1 if input is zero, 0 otherwise.
- **C** Unaffected.
- *Mode Bit* OVM Operation is not affected by OVM bit value.

| Syntax    | SIGI src, dst                                                   |
|-----------|-----------------------------------------------------------------|
| Operation | $\overline{LOCK}$ (or $\overline{LLOCK}$ ) pin brought low.     |
|           | $\frac{src \rightarrow dst}{LOCK}$ (or LLOCK) pin brought high. |
| Operands  | src direct and indirect addressing mod                          |

*Operands* src direct and indirect addressing modes (assumed to be signed integer) dst register mode (assumed to be signed integer)

## Encoding

| 31        | 24 23     | 16 15 | 87  | 0 |
|-----------|-----------|-------|-----|---|
| 0 0 0 1 0 | 1 1 0 0 G | dst   | src |   |

## **Instruction Word Fields**

| G  | src addressing modes |
|----|----------------------|
| 01 | direct mode          |
| 10 | indirect mode        |

**Description** An interlocking operation is signaled using the appropriate bus-lock signal (LOCK or LLOCK) if and only if an external memory access is performed. The *src* and *dst* operands are assumed to be signed integers. After the read is performed, the bus-lock signal is deasserted. If an internal memory access is performed, SIGI will perform the read but will not assert a bus-lock signal.

The numbers at the *src* and *dst* operands are treated as signed integers.

## Cycles

- Status Bits If ST (SETCOND) = 0 and the destination register is R0 R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.
  - LUF Unaffected.
  - LV Unaffected.
  - **UF** 0.

- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 0.
- C Unaffected.

Syntax STF src, dst Operation  $src \rightarrow dst$ **Operands** src register (R0 – R11) dst general addressing modes (G): direct 01 10 indirect Encoding 31 24 23 16 15 87 0 0 0 0 101000 G dst src

Description The src register is loaded into the dst memory location. The src and dst operands are assumed to be floating-point numbers.

| Cycles      | 1                                                                                                                                         |  |  |  |  |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Status Bits | LUFUnaffected.LVUnaffected.UFUnaffected.NUnaffected.ZUnaffected.VUnaffected.CUnaffected.                                                  |  |  |  |  |  |
| Mode Bit    | <b>OVM</b> Operation is not affected by OVM bit value.                                                                                    |  |  |  |  |  |
| Example     | STF R2,098A1h                                                                                                                             |  |  |  |  |  |
|             | Before Instruction:                                                                                                                       |  |  |  |  |  |
|             | DP = 80h<br>R2 = 052 C501 900h = 4.30782204e + 01<br>Data at 80 98A1h = 0h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                           |  |  |  |  |  |
|             | After Instruction:                                                                                                                        |  |  |  |  |  |
|             | DP = 80h<br>R2 = 05 2C50 1900h = 4.30782204e + 01<br>Data at 80 98A1h = 52C 5019h = 4.30782204e + 01<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0 |  |  |  |  |  |

| Syntax         | STFI src, dst                                                                                                                                                                                                                                                                             |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation      | $src \rightarrow dst$<br>Signal end of interlocked operation.                                                                                                                                                                                                                             |
| Operands       | <i>src</i> register (R0 – R11)                                                                                                                                                                                                                                                            |
|                | <i>dst</i> general addressing modes (G):<br>0 1 direct                                                                                                                                                                                                                                    |
| <b>-</b>       | 10 indirect                                                                                                                                                                                                                                                                               |
| Encoding<br>31 | 24 23 16 15 8 7 0                                                                                                                                                                                                                                                                         |
| 0 0 0 1 0      | 1 0 0 1 G src dst                                                                                                                                                                                                                                                                         |
| Description    | The <i>src</i> register is loaded into the <i>dst</i> memory location. An interlocked oper-<br>ation is signaled over LOCK or LLOCK. The <i>src</i> and <i>dst</i> operands are as-<br>sumed to be floating-point numbers. Refer to Section 7.7 on page 7-39 for<br>detailed information. |
| Cycles         | 1                                                                                                                                                                                                                                                                                         |
| Status Bits    | LUFUnaffected.LVUnaffected.UFUnaffected.VUnaffected.ZUnaffected.VUnaffected.CUnaffected.                                                                                                                                                                                                  |
| Mode Bit       | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                           |
| Example        | STFI R3,*-AR4                                                                                                                                                                                                                                                                             |
|                | Before Instruction:                                                                                                                                                                                                                                                                       |
|                | R3 = 07 33C0 0000h = 1.79750e + 02<br>AR4 = 80 993Ch<br>Data at 80 993Bh = 0h<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                        |
|                | After Instruction:                                                                                                                                                                                                                                                                        |
|                | $\begin{array}{l} \text{R3} = 07\ 33\text{C0}\ 0000\text{h} = 1.79750\text{e} + 02\\ \text{AR4} = 80\ 993\text{Ch}\\ \text{Data at 80}\ 993\text{Bh} = 733\ \text{C000h} = 1.79750\text{e} + 02\\ \text{LUF LV UF N Z V C} = 0  0  0  0  0  0  0 \end{array}$                             |
| 11-206         | Assembly Language Instructions                                                                                                                                                                                                                                                            |

11

Assembly Language Instructions

| Syntax    | STF src2, dst2                                                                                                                                     |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | $src2 \rightarrow dst2$<br>   $src1 \rightarrow dst1$                                                                                              |
| Operands  | src1register (Rn1, $0 \le n1 \le 7$ )dst1indirect (disp = 0, 1, IR0, IR1)src2register (Rn2, $0 \le n2 \le 7$ )dst2indirect (disp = 0, 1, IR0, IR1) |

# Encoding

| 31          | 24 23      | 16 15   | 87      | 0 |
|-------------|------------|---------|---------|---|
| 1 1 0 0 0 0 | src2 0 0 0 | src1 ds | st1 dst | 2 |

**Description** Two STF instructions are executed in parallel. Both *src1* and *src2* are assumed to be floating-point numbers.

| Cycles      | 1                                   |                                                                                        |
|-------------|-------------------------------------|----------------------------------------------------------------------------------------|
| Status Bits | LUF<br>LV<br>UF<br>N<br>Z<br>V<br>C | Unaffected.<br>Unaffected.<br>Unaffected.<br>Unaffected.<br>Unaffected.<br>Unaffected. |

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

## Example

1

STFR4,\*AR3- -STF R3,\*++AR5

## **Before Instruction:**

 $\begin{array}{l} R4 = 07\ 0C80\ 0000h = 1.4050e + 02\\ AR3 = 80\ 9835h\\ R3 = 07\ 33C0\ 0000h = 1.79750e + 02\\ AR5 = 80\ 99D2h\\ Data\ at\ 80\ 9835h = 0h\\ Data\ at\ 80\ 99D3h = 0h\\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

## **After Instruction:**

 $\begin{array}{l} \mathsf{R4} = 07\ 0\mathsf{C80}\ 0000h = 1.4050e + 02\\ \mathsf{AR3} = 80\ 9834h\\ \mathsf{R3} = 07\ 33\mathsf{C0}\ 0000h = 1.79750e + 02\\ \mathsf{AR5} = 80\ 99\mathsf{D3h}\\ \mathsf{Data}\ at\ 80\ 9835h = 070\mathsf{C}\ 8000h = 1.4050e + 02\\ \mathsf{Data}\ at\ 80\ 99\mathsf{D3h} = 0733\ \mathsf{C000h} = 1.79750e + 02\\ \mathsf{LUF}\ \mathsf{LV}\ \mathsf{UF}\ \mathsf{N}\ \mathsf{Z}\ \mathsf{V}\ \mathsf{C} = 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0 \end{array}$ 

SyntaxSTI src, dstOperationsrc  $\rightarrow$  dstOperandssrc register (any register in CPU primary register file)dst general addressing modes (G):0 1direct1 0indirect

| 31 24 23          | 16    | 15 87 | 0   |  |  |
|-------------------|-------|-------|-----|--|--|
| 0 0 0 1 0 1 0 1 0 | G src | dst   | 1 1 |  |  |

**Description** The *src* register is loaded into the *dst* memory location. The *src* and *dst* operands are assumed to be signed integers.

- Cycles
- Status Bits LUF Unaffected.

1

- LV Unaffected.
- UF Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example STI R4,0982Bh

# **Before Instruction:**

DP = 80h R4 = 42BD7h = 273,367 Data at 80 982Bh = 0E5FCh = 58,876 LUF LV UF N Z V C = 0 0 0 0 0 0 0

# **After Instruction:**

DP = 80h R4 = 42 BD7h = 273,367 Data at 80 982Bh = 42BD7h = 273,367 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax    | STII src, dst                                                          |
|-----------|------------------------------------------------------------------------|
| Operation | $src \rightarrow dst$<br>Signal end of interlocked operation.          |
| Operands  | src register (any register in CPU primary register file)               |
|           | <i>dst</i> general addressing modes (G):<br>0 1 direct<br>1 0 indirect |
| Encoding  |                                                                        |
| 31        | 24 23 16 15 8 7                                                        |
| 0 0 0 1   | 0 1 0 1 1 G src dst                                                    |
|           |                                                                        |

**Description** The *src* register is loaded into the *dst* memory location. An interlocked operation is signaled over LOCK or LLOCK. The *src* and *dst* operands are assumed to be signed integers. Refer to Section 7.7 on page 7-39 for detailed information.

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

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- **Z** Unaffected.
- V Unaffected.
- **C** Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example STII R1,098AEh

# **Before Instruction:**

DP = 80h R1 = 78Dh Data at 80 98AEh = 25Ch

# After Instruction:

DP = 80h R1 = 78Dh Data at 80 98AEh = 7BDh

Assembly Language Instructions

| Syntax    | STI src2, dst2<br>   STI src1, dst1                                                                                              |  |  |  |  |  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Operation | $src2 \rightarrow dst2$<br>   $src1 \rightarrow dst1$                                                                            |  |  |  |  |  |
| Operands  | src1register (R0 - R7) $dst1$ indirect (disp = 0, 1, IR0, IR1) $src2$ register (R0 - R7) $dst2$ indirect (disp = 0, 1, IR0, IR1) |  |  |  |  |  |

# Encoding

| 31 |   |   |   |   |    | 24 23 |   |   |   | 1    | 6 15 |      |   |   | ε | 37 |    |   |      |   |    | 0 |
|----|---|---|---|---|----|-------|---|---|---|------|------|------|---|---|---|----|----|---|------|---|----|---|
| 1  | 1 | 0 | 0 | 0 | 01 | src2  | 0 | 0 | 0 | src1 |      | dst1 | 1 | 1 | Τ |    | -1 | T | dst. | 2 | -1 |   |

**Description** Two integer stores are performed in parallel. If both stores are executed to the same address, the value written is that of STI *src2, dst2*.

- Cycles 1
- Status Bits LUF Unaffected.
  - LV Unaffected.
  - UF Unaffected.
  - N Unaffected.
  - Z Unaffected.
  - V Unaffected.
  - C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

#### Example

STI R0,\*++AR2(IR0)
|| STI R5,\*AR0

## **Before Instruction:**

R0 = 0DCh = 220 AR2 = 80 9830h IR0 = 8h R5 = 35h = 53 AR0 = 80 98D3h Data at 80 9838h = 0h Data at 80 98D3h = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

## **After Instruction:**

R0 = 0DCh = 220 AR2 = 80 9838h IR0 = 8h R5 = 35h = 53 AR0 = 80 98D3h Data at 80 9838h = 0DCh = 220 Data at 80 98D3h = 35h = 53 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax    | STIK src, dst                                                       |
|-----------|---------------------------------------------------------------------|
| Operation | $src \rightarrow dst$                                               |
| Operands  | <i>src</i> 5-bit signed integer <i>dst</i> direct and indirect mode |

# Encoding

| 31 | 24 23    | 16 15 | 87  | 0 |
|----|----------|-------|-----|---|
|    | 101010 G | dst   | src |   |

## Instruction Word Fields

| G  | dst addressing modes |
|----|----------------------|
| 00 | direct mode          |
| 11 | indirect mode        |

**Description** The 5-bit signed integer *src* value is loaded into the *dst* memory location. The *src* and dst operands are assumed to be signed integers.

Cycles 1

|    | Unaffected.<br>Unaffected. |
|----|----------------------------|
|    |                            |
| UF | Unaffected.                |
| Ν  | Unaffected.                |
| Z  | Unaffected.                |
| V  | Unaffected.                |
| С  | Unaffected.                |
|    | LV<br>UF<br>N<br>Z<br>V    |

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax<br>Operation<br>Operands | SUBB src, dst<br>dst - src - C → dst<br>src general addressing modes (G):<br>00 register (any register in CPU primary register file)<br>01 direct<br>10 indirect<br>11 immediate<br>dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                     |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding<br>31                  | 24 23 16 15 8 7 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Description                     | The difference of the <i>dst</i> , <i>src</i> , and C operands, as calculated above, is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be signed integers.                                                                                                                                                                                                                                                                                                                           |
| Cycles                          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Status Bits                     | <ul> <li>If ST (SETCOND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV 1 if an integer overflow occurs, unchanged otherwise.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an integer overflow occurs, 0 otherwise.</li> <li>C 1 if a borrow occurs, 0 otherwise.</li> </ul> |
| Mode Bit                        | <b>OVM</b> Operation is affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Example                         | SUBB *AR5++(4),R5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                 | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                 | AR5 = 80 9800h<br>R5 = 0FAh = 250<br>Data at 80 9800h = 0C7h = 199<br>LUF LV UF N Z V C = 0 0 0 0 0 1                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                 | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                 | $\begin{array}{l} AR5 = 80 \ 9804h \\ R5 = 032h = 50 \\ Data \ at \ 80 \ 9800h = 0C7h = 199 \\ LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \end{array}$                                                                                                                                                                                                                                                                                                                                                            |

| Syntax | SUBB3 | src2, | src1, dst | t |
|--------|-------|-------|-----------|---|
|--------|-------|-------|-----------|---|

**Operation**  $src1 - src2 - C \rightarrow dst$ 

*Operands* src1, src2 both type 1 or type 2 three-operand addressing modes register mode (any register in CPU primary register file)

## Encoding

.

## Type 1

| 31        | 24 23     | 16 15 | 87        | 0 |
|-----------|-----------|-------|-----------|---|
| 0 0 1 0 0 | 1 1 0 0 T | dst   | src1 src. | 2 |

#### Type 2

| 31 24 23          | 16    | 15 8 | 7 0  |
|-------------------|-------|------|------|
| 0 0 1 1 0 1 1 0 0 | T dst | src1 | src2 |

## Instruction Word Fields

|        | Т  | src1 addressing modes                 | <i>src2</i> addressing modes          |
|--------|----|---------------------------------------|---------------------------------------|
|        | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| Type 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|        | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|        | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

Type 2

| Т  | <i>src1</i> addressing modes                         | src2 addressing modes                               |
|----|------------------------------------------------------|-----------------------------------------------------|
| 00 | register mode (any CPU register)                     | 8-bit signed immediate                              |
| 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement) |
| 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                              |
| 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned displacement)   |

- **Description** The difference of the *src1* and *src2* operands and the C (carry) flag is loaded into the *dst* register. The *src1*, *src2*, and *dst* operands are assumed to be signed integers.
- Cycles

Status Bits If ST (SETCOND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.

LUF Unaffected.

- LV 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.

1

- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** 1 if a borrow is generated, 0 otherwise.

*Mode Bit* **OVM** Operation is affected by OVM bit value.

Syntax SUBC src, dst

**Operation** If  $(dst - src \ge 0)$ : (dst - src << 1) OR  $1 \rightarrow dst$ Else:  $dst << 1 \rightarrow dst$ 

*Operands* src general addressing modes (G):

- 0 0 register (any register in CPU primary register file)
- 01 direct
- 10 indirect
- 11 immediate

dst register (any register in CPU primary register file)

#### Encoding

| 31    | 24 23         | 16 15 | 87  | 0 |
|-------|---------------|-------|-----|---|
| 0 0 0 | 1 0 1 1 1 0 G | dst   | src |   |

**Description** The *src* operand is subtracted from the *dst* operand. The *dst* operand is loaded with a value that depends upon the result of the subtraction. If (*dst* – *src*) is greater than or equal to zero, then (*dst* – *src*) is left-shifted one bit, the least-significant bit is set to 1, and the result is loaded into the *dst* register. If (*dst* – *src*) is less than zero, *dst* is left-shifted one bit and loaded into the *dst* register. The *dst* and *src* operands are assumed to be unsigned integers.

SUBC may be used to perform a single step of a multi-bit integer division. See subsection 12.3.4 for a detailed description.

#### Cycles

Status Bits LUF Unaffected.

1

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

FF

Example SUBC @98C5h,R1

#### **Before Instruction:**

DP = 80hR1 = 04F6h = 1270 Data at 80 98C5h = 492h = 1170 LUF LV UF N Z V C = 0 0 0 0 0 0 0

#### **After Instruction:**

DP = 80hR1 = 0C9h = 201 Data at 80 98C5h = 492h = 1170 LUF LV UF N Z V C = 0 0 0 0 0 0 0

**Example** SUBC 3000, R0 (3000 = 0BB8h)

## **Before Instruction:**

R0 = 07D0h = 2000 LUF LV UF N Z V C = 0 0 0 0 0 0 0

After Instruction:

R0 = 0FA0h = 4000 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax      | SUBF src, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Operation   | $dst - src \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| Operands    | <pre>src general addressing modes (G): 0 0 register (R0 - R11) 0 1 direct 1 0 indirect 1 1 immediate</pre>                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|             | <i>dst</i> register (R0 – R11)                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| Encoding    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| 0 0 0 1 0   | 1 1 1 1 G dst src                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| Description | The result of <i>the dst</i> operand minus the <i>src</i> operand is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be floating-point numbers.                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| Cycles      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| Status Bits | <ul> <li>LUF 1 if a floating-point underflow occurs, unchanged otherwise.</li> <li>LV 1 if an floating-point overflow occurs, unchanged otherwise.</li> <li>UF 1 if a floating-point underflow occurs, 0 otherwise.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an floating-point overflow occurs, 0 otherwise.</li> <li>V 1 if an floating-point overflow occurs, 0 otherwise.</li> <li>C Unaffected.</li> </ul> |  |  |  |  |
| Mode Bit    | <b>OVM</b> Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| Example     | SUBF *AR0(IR0),R5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|             | AR0 = 80 9888h $IR0 = 80h$ $R5 = 07 33C0 0000h = 1.79750000e + 02$ $Data at 80 9888h = 70C 8000h = 1.4050e + 02$ $LUF LV UF N Z V C = 0 0 0 0 0 0 0$                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|             | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|             | AR0 = 80 9808h $IR0 = 80h$ $R5 = 05 1D00 0000h = 3.9250e + 01$ $Data at 80 9888h = 70C 8000h = 1.4050e + 02$ $LUF LV UF N Z V C = 0 0 0 0 0 0 0$                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |

| Syntax | SUBF3 src2, src1, dst |  |
|--------|-----------------------|--|
|--------|-----------------------|--|

**Operation**  $src1 - src2 \rightarrow dst$ 

Operands src1, src2 both type 1 or type 2 three-operand addressing modes register mode (R0 – R11) dst

#### Encoding

Type 1

| 31 24 2           | 3 16  | 15 8 | 0    |
|-------------------|-------|------|------|
| 0 0 1 0 0 1 1 0 1 | T dst | src1 | src2 |

#### Type 2

| 31 24 23          | 3 | 16  | 6 15 | 8    | 37   | 0 |
|-------------------|---|-----|------|------|------|---|
| 0 0 1 1 0 1 1 0 1 | Т | dst |      | src1 | src2 |   |

#### **Instruction Word Fields**

| Type                                    | 1 |
|-----------------------------------------|---|
| .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |   |

| T  | src1 addressing modes                 | <i>src2</i> addressing modes          |  |  |  |  |  |  |  |
|----|---------------------------------------|---------------------------------------|--|--|--|--|--|--|--|
| 00 | register mode (R0 — R11)              | register mode (R0 — R11)              |  |  |  |  |  |  |  |
| 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (R0 R11)                |  |  |  |  |  |  |  |
| 10 | register mode (R0 — R11)              | indirect mode (disp = 0, 1, IR0, IR1) |  |  |  |  |  |  |  |
| 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |  |  |  |  |  |  |  |

Туре

|   | T  | <i>src1</i> addressing modes                         | <i>src2</i> addressing modes                         |
|---|----|------------------------------------------------------|------------------------------------------------------|
| • | 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned<br>displacement)  |
| 2 | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |

- **Description** The difference of the *src1* and *src2* operands is loaded into the *dst* register. The *src1*, *src2*, and *dst* operands are assumed to be floating-point numbers.
- Cycles

1

Status Bits LUF 1 if a floating-point underflow occurs, unchanged otherwise.

- LV 1 if an floating-point overflow occurs, unchanged otherwise.
- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an floating-point overflow occurs, 0 otherwise.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

#### SUBF3||STF Parallel SUBF3 and STF

| Syntax    | SUBF3 src1, src2, dst1<br>   STF src3, dst2                                                                                                        |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation | $src2 - src1 \rightarrow dst1$<br>   $src3 \rightarrow dst2$                                                                                       |
| Operands  | src1register (R0 - R7)src2indirect (disp = 0, 1, IR0, IR1) $dst1$ register (R0 - R7)src3register (R0 - R7) $dst2$ indirect (disp = 0, 1, IR0, IR1) |
| Encoding  |                                                                                                                                                    |

| 31            | 24 23     | 16 15     | 87   | 0 |
|---------------|-----------|-----------|------|---|
| 1 1 1 0 1 0 1 | dst1 src1 | src3 dst2 | src2 |   |

**Description** A floating-point subtraction and a floating-point store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STF) reads from a register and the operation being performed in parallel (SUBF3) writes to the same register, then STF accepts as input the contents of the register before it is modified by the SUBF3.

If *src3* and *dst1* point to the same location, *src3* is read before the write to *dst1*.

#### Cycles

1

Status Bits LUF 1 if a floating-point underflow occurs, unchanged otherwise.

- LV 1 if an floating-point overflow occurs, unchanged otherwise.
- **UF** 1 if a floating-point underflow occurs, 0 otherwise.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an floating-point overflow occurs, 0 otherwise.
- **C** Unaffected.

## *Mode Bit* **OVM** Operation is not affected by OVM bit value.

#### Example

SUBF3 R1,\*-AR4(IR1),R0 || STF R7,\*+AR5(IR0)

#### **Before Instruction:**

 $\begin{array}{l} R1 = 05\ 7B40\ 0000h = 6.28125e + 01\\ AR4 = 80\ 98B8h\\ IR1 = 8h\\ R0 = 0h\\ R7 = 07\ 33C0\ 0000h = 1.79750e + 02\\ AR5 = 80\ 9850h\\ IR0 = 10h\\ Data\ at\ 80\ 98B0h = 70C\ 8000h = 1.4050e + 02\\ Data\ at\ 80\ 98B0h = 0h\\ LUF\ LV\ UF\ N\ Z\ V\ C = 0\ 0\ 0\ 0\ 0\ 0\ 0\end{array}$ 

#### After Instruction:

R1 = 05 7B40 0000h = 6.28125e + 01AR4 = 8098B8hIR1 = 8hR0 = 06 1B60 0000h = 7.768750e + 01R7 = 07 33C0 0000h = 1.79750e + 02AR5 = 80 9850hIR0 = 10hData at 80 98B0h = 70C 8000h = <math>1.4050e + 02Data at 80 98B0h = 733 C000h = 1.79750e + 02LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax                      | SUBI src, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Operation                   | $dst - src \rightarrow dst$<br>src general addressing modes (G):<br>0 0 register (any register in CPU primary register file)<br>0 1 direct<br>1 0 indirect<br>1 1 immediate                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Operands                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                             | dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Encoding<br>31<br>0 0 0 1 1 | 24 23 16 15 87 0<br>0 0 0 0 G dst src                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Description                 | The difference of the <i>dst</i> operand minus the <i>src</i> operand is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be signed integers.                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Cycles                      | <b>1</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Status Bits                 | If ST (SETCOND) = 0 and the destination register is R0 – R11, the condition<br>flags are modified. If ST (SETCOND) = 1, they are modified for all destina-<br>tion registers.<br>LUF Unaffected.<br>LV 1 if an integer overflow occurs, unchanged otherwise.<br>UF 0.<br>N 1 if a negative result is generated, 0 otherwise.<br>Z 1 if a zero result is generated, 0 otherwise.<br>V 1 if an integer overflow occurs, 0 otherwise.<br>C 1 if a borrow occurs, 0 otherwise |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Mode Bit                    | OVM Operation is affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Example                     | SUBI 220,R7                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                             | R7 = 226h = 550<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                             | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                             | R7 = 14Ah = 330<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |  |  |  |  |

erc2 addressing modes

Syntax SUBI3 src2, src1, dst

**Operation**  $src1 - src2 \rightarrow dst$ 

*Operands* src1, src2 both type 1 or type 2 three-operand addressing modes register mode (any register in CPU primary register file)

## Encoding

## Type 1

| <u>31 2</u>     | 4 23 16 | 15 8 | 7 0  |
|-----------------|---------|------|------|
| 0 0 1 0 0 1 1 1 | 0 T dst | src1 | src2 |

#### Type 2

| 31 24 23          |      | 16 15 | 8    | 8 7  |  |  |  |  |  |  |  |  |  |
|-------------------|------|-------|------|------|--|--|--|--|--|--|--|--|--|
| 0 0 1 1 0 1 1 1 0 | T ds |       | src1 | src2 |  |  |  |  |  |  |  |  |  |

#### Instruction Word Fields

T

|  | T  | <i>src1</i> addressing modes          | <i>src2</i> addressing modes          |  |  |  |  |  |  |  |
|--|----|---------------------------------------|---------------------------------------|--|--|--|--|--|--|--|
|  | 00 | register mode (any CPU register)      | register mode (any CPU register)      |  |  |  |  |  |  |  |
|  | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |  |  |  |  |  |  |  |
|  | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |  |  |  |  |  |  |  |
|  | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |  |  |  |  |  |  |  |

erc1 addressing modes

## Type 2

|    | sici addressing modes                                | SICZ addressing modes                                |  |  |  |  |  |  |
|----|------------------------------------------------------|------------------------------------------------------|--|--|--|--|--|--|
| 00 | register mode (any CPU register)                     | 8-bit signed immediate                               |  |  |  |  |  |  |
| 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned displacement)     |  |  |  |  |  |  |
| 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                               |  |  |  |  |  |  |
| 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned<br>displacement) |  |  |  |  |  |  |

- **Description** The result of the *src1* operand minus the *src2* operand is loaded into the *dst* register. The *src1*, *src2*, and *dst* operands are assumed to be signed integers.
- Cycles 1

Status Bits If ST (SETCOND) = 0 and the destination register is R0 - R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.

LUF Unaffected.

- **LV** 1 if an integer overflow occurs, unchanged otherwise.
- **UF** 0.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** 1 if a borrow is generated, 0 otherwise.
- *Mode Bit* **OVM** Operation is affected by OVM bit value.

| Syntax    | SUBI3 src1, src<br>   STI src3, dst2                                                 | 2, dst1                      |    |  |
|-----------|--------------------------------------------------------------------------------------|------------------------------|----|--|
| Operation | $src2 - src1 \rightarrow d$<br>   $src3 \rightarrow dst2$                            | st1                          |    |  |
| Operands  | src1register (R0src2indirect (dispdst1register (R0src3register (R0dst2indirect (disp | 9 = 0, 1, IR0, IR1)<br>– R7) |    |  |
| Encoding  |                                                                                      |                              |    |  |
| 31        | 24 23                                                                                | 16 15                        | 87 |  |

| <u>31</u> | 24 23 |    |   |   |   |   |   |  |    | 16 15 |  |          |   |  |   |           |  |  |  | 87 |   |   |      |  |   |   |  |  |  | 0    |   |   |  |  |  |   |   |
|-----------|-------|----|---|---|---|---|---|--|----|-------|--|----------|---|--|---|-----------|--|--|--|----|---|---|------|--|---|---|--|--|--|------|---|---|--|--|--|---|---|
|           |       |    | Т |   |   | Г | 1 |  | Τ. |       |  | -        | 1 |  | T | T         |  |  |  | Т  | Т | 1 |      |  | Т | Т |  |  |  | T    | Т | Т |  |  |  | 1 | 1 |
| 1         | ١     | ין |   | 0 | 1 | 1 | 0 |  | d  | st1   |  | src1 src |   |  |   | src3 dst2 |  |  |  |    |   |   | dst2 |  |   |   |  |  |  | src2 |   |   |  |  |  |   |   |

**Description** An integer subtraction and an integer store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (SUBI3) writes to the same register, then STI accepts as input the contents of the register before it is modified by the SUBI3.

If *src3* and *dst1* point to the same location, *src3* is read before the write to *dst1*.

#### Cycles

## Status Bits LUF Unaffected.

1

LV 1 if an integer overflow occurs, unchanged otherwise.

- **UF** 0.
- **N** 1 if a negative result is generated, 0 otherwise.
- **Z** 1 if a zero result is generated, 0 otherwise.
- V 1 if an integer overflow occurs, 0 otherwise.
- **C** 1 if a borrow occurs, 0 otherwise.

*Mode Bit* **OVM** Operation is affected by OVM bit value.

Example

SUBI3 R7,\*+AR2(IR0),R1 || STI R3,\*++AR7

#### **Before Instruction:**

 $\begin{array}{l} R7 = 14h = 20 \\ AR2 = 80 \ 982Fh \\ IR0 = 10h \\ R1 = 0h \\ R3 = 35h = 53 \\ AR7 = 80 \ 983Bh \\ Data \ at \ 80 \ 983Fh = 0DCh = 220 \\ Data \ at \ 80 \ 983Ch = 0h \\ LUF \ LV \ UF \ N \ Z \ V \ C = 0 \ 0 \ 0 \ 0 \ 0 \ 0 \ 0 \end{array}$ 

#### **After Instruction:**

R7 = 14h = 20 AR2 = 80 982Fh IR0 = 10h R1 = 0C8h = 200 R3 = 35h = 53 AR7 = 80 983Ch Data at 80 983Fh = 0DCh = 220 Data at 80 983Ch = 35h = 53 LUF LV UF N Z V C = 0 0 0 0 0 0 0 0

Assembly Language Instructions

| <b>-</b> .            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax                | SUBRB src, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| Operation             | $src - dst - C \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Operands              | <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate</li> </ul> dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                |  |
| Encoding              | ust register (any register in or o primary register me)                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| <b>Encoding</b><br>31 | 24 23 16 15 8 7 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| 0 0 0 1 1             | 0 0 0 1 G dst src                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Description           | The difference of the <i>src, dst</i> , and C operands, as calculated above, is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be signed integers.                                                                                                                                                                                                                                                                                                                                   |  |
| Cycles                | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Status Bits           | <ul> <li>If ST (SETCOND) = 0 and the destination register is R0 – R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV 1 if an integer overflow occurs, unchanged otherwise.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an integer overflow occurs, 0 otherwise.</li> <li>C 1 if a borrow occurs, 0 otherwise.</li> </ul> |  |
| Mode Bit              | OVM Operation is affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Example               | SUBRB R4,R6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                       | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|                       | R4 = 03CBh = 971<br>R6 = 0258h = 600<br>LUF LV UF N Z V C = 0 0 0 0 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|                       | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |

R4 = 03CBh = 971 R6 = 0172h = 370 LUF LV UF N Z V C = 0 0 0 0 0 0 0

| Syntax      | SUBRF src, dst                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation   | $src - dst \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                               |
| Operands    | <pre>src general addressing modes (G): 0 0 register (R0 - R11) 0 1 direct 1 0 indirect 1 1 immediate</pre>                                                                                                                                                                                                                                                                                                                                |
|             | <i>dst</i> register (R0 – R11)                                                                                                                                                                                                                                                                                                                                                                                                            |
| Encoding    |                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31          | 24 23 16 15 87 0                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 00011       | 0 0 1 0 G dst src                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Description | The result of the <i>src</i> operand minus the <i>dst</i> operand is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be floating-point numbers.                                                                                                                                                                                                                                                |
| Cycles      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Status Bits | <ul> <li>LUF 1 if a floating-point underflow occurs, unchanged otherwise.</li> <li>LV 1 if a floating-point overflow occurs, unchanged otherwise.</li> <li>UF 1 if a floating-point underflow occurs, 0 otherwise.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if a floating-point overflow occurs, 0 otherwise.</li> <li>C Unaffected.</li> </ul> |
| Mode Bit    | OVM Operation is not affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                           |
| Example     | SUBRF @9905h,R5                                                                                                                                                                                                                                                                                                                                                                                                                           |
|             | Before Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                       |
|             | DP = 80h<br>R5 = 05 7B40 0000h = 6.281250e + 01<br>Data at 80 9905h = 733 C000h = 1.79750e + 02<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                      |
|             | After Instruction:                                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | DP = 80h<br>R5 = 06 69E0 0000h = 1.16937500e + 02<br>Data at 80 9905h = 733 C000h = 1.79750e + 02<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                    |

| SUBRI src, dst                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $src - dst \rightarrow dst$                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <ul> <li>src general addressing modes (G):</li> <li>0 0 register (any register in CPU primary register file)</li> <li>0 1 direct</li> <li>1 0 indirect</li> <li>1 1 immediate</li> </ul>                                                                                                                                                                                                                                                             |
| dst register (any register in CPU primary register file)                                                                                                                                                                                                                                                                                                                                                                                             |
| 24 23 16 15 8 7 0                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0 0 1 1   G   dst   src                                                                                                                                                                                                                                                                                                                                                                                                                              |
| The result of the <i>src</i> operand minus the <i>dst</i> operand is loaded into the <i>dst</i> register. The <i>dst</i> and <i>src</i> operands are assumed to be signed integers.                                                                                                                                                                                                                                                                  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <ul> <li>flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.</li> <li>LUF Unaffected.</li> <li>LV 1 if an integer overflow occurs, unchanged otherwise.</li> <li>UF 0.</li> <li>N 1 if a negative result is generated, 0 otherwise.</li> <li>Z 1 if a zero result is generated, 0 otherwise.</li> <li>V 1 if an integer overflow occurs, 0 otherwise.</li> <li>C 1 if a borrow occurs, 0 otherwise.</li> </ul> |
| OVM Operation is affected by OVM bit value.                                                                                                                                                                                                                                                                                                                                                                                                          |
| SUBRI *AR5++ (IR0), R3<br><b>Before Instruction:</b><br>AR5 = 80 9900h<br>IR0 = 8h<br>R3 = 0DCh = 220<br>Data at 80 9900h = 226h = 550<br>LUF LV UF N Z V C = 0 0 0 0 0 0 0<br>After Instruction:<br>AR5 = 80 9908h<br>IR0 = 8h<br>I1                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Syntax      | SWI                                                                        |
|-------------|----------------------------------------------------------------------------|
| Operation   | Performs an emulation interrupt                                            |
| Operands    | None                                                                       |
| Encoding    |                                                                            |
| 31          | <u>24 23 16 15 8 7 0</u>                                                   |
| 0 1 1 0     | 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                    |
| Description | The SWI instruction performs an emulator interrupt. This is a reserved in- |

**Description** The SWI instruction performs an emulator interrupt. This is a reserved instruction and should not be used in normal programming.

Cycles

Status Bits LUF Unaffected.

4

- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

Mode Bit OVM Operation is not affected by OVM bit value.

Syntax TOIEEE src, dst

**Operation** convert *src* to IEEE format  $\rightarrow dst$ 

*Operands* src extended-precision register (R0 – R11), direct and indirect addressing modes

dst extended-precision register

#### Encoding

| 31 24 23          | 16    | 15 87 | 0 |
|-------------------|-------|-------|---|
| 0 0 0 1 1 0 1 1 1 | G dst | src   |   |

#### Instruction Word Fields

| G  | <i>src</i> addressing modes                               |
|----|-----------------------------------------------------------|
| 00 | register mode (extended-preci-<br>sion register R0 – R11) |
| 01 | direct mode                                               |
| 10 | indirect mode                                             |

**Description** The *src* operand is converted from a twos-complement floating-point format to the IEEE floating-point format.

The *src* operand is assumed to be a single-precision floating-point number. The converted result goes into the 32 MSBs of the *dst* register. STF can be used to store the result to memory.

#### Cycles

Status Bits LUF Unaffected.

1

LV 1 if an overflow occurs, unchanged otherwise.

- **UF** 0.
- **N** 1 if a negative result is generated, 0 otherwise.

Z 1 if a zero result is generated, 0 otherwise.

V 1 if an overflow occurs, 0 otherwise.

- **C** Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

#### **TOIEEE**||**STF** Parallel TOIEEE and STF

| Syntax    | TOIEEE src2, dst1<br>   STF src3, dst2                                                                                                                                 |  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation | convert <i>src2</i> to IEEE format $\rightarrow dst1$<br>in parallel with<br><i>src3</i> $\rightarrow dst2$                                                            |  |
| Operands  | src2indirect mode (disp = 0, 1, IRO, IR1)dst1register mode (Rn1, $0 \le n1 \le 7$ )src3register mode (Rn1, $0 \le n1 \le 7$ )dst2indirect mode (disp = 0, 1, IRO, IR1) |  |
| Encodina  |                                                                                                                                                                        |  |

#### counny

| 31            | 24 23      | 16 15    | 87     | 0 |
|---------------|------------|----------|--------|---|
| 1 1 1 1 0 0 0 | dst1 0 0 0 | src3 dsi | 2 src2 |   |

Description The src2 operand is converted from a twos-complement floating-point format to the IEEE floating-point format.

> The src2 operand is assumed to be a single-precision floating-point number. The converted result goes into the 32 MSBs of the dst1 register. In parallel a floating-point store is done.

> If src2 and dst2 point to the same location, then src2 is read before the write to dst2.

Cycles

Status Bits LUF Unaffected.

1

- LV 1 if an overflow occurs, unchanged otherwise.
- UF 0.
- Ν 1 if a negative result is generated, 0 otherwise.
- Ζ 1 if a zero result is generated, 0 otherwise.
- 1 if an overflow occurs, 0 otherwise. V
- С Unaffected.

Mode Bit **OVM** Operation is not affected by OVM bit value.

#### Syntax TRAPcond N

OperationIf (cond is true)<br/> $ST(GIE) \rightarrow ST(PGIE)$ <br/> $ST(CF) \rightarrow ST(PCF)$ <br/> $0 \rightarrow ST(GIE)$ <br/> $1 \rightarrow ST(CF)$ <br/>next PC  $\rightarrow *(++SP)$ <br/>trap vector N  $\rightarrow$  PC<br/>Else, continue.

**Operands** N immediate mode  $(0 \le N \le 511)$ 

#### Encoding

| 31            | 24 23   | 16 15               | 87        | 0 |
|---------------|---------|---------------------|-----------|---|
| 0 1 1 1 0 1 0 | 0 0 0 0 | <i>cond</i> 0 0 0 0 | 0 0 0 0 N |   |

**Description** If traps are to be nested, you may need to save the status register before executing TRAP*cond*. If the condition is true, then GIE and CF are saved in PGIE and PCF in the status register, all interrups are disabled  $(0 \rightarrow GIE)$ , and the cache is frozen  $(1 \rightarrow CF)$ . Then, the contents of the PC are pushed onto the system stack, and the PC is loaded with the contents of the specified trap vector (N). If the condition is not true, then continue normal operation.

#### Cycles

5

Status Bits GIE Set to 0 if TRAP executes.

- LUF Unaffected.
- LV Unaffected.
- **UF** Unaffected.
- N Unaffected.
- Z Unaffected.
- V Unaffected.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

| Syntax TSTB src, ds | t |
|---------------------|---|
|---------------------|---|

**Operation** dst AND src

*Operands* src general addressing modes (G):

0 0 register (any register in CPU primary register file)

- 01 direct
- 10 indirect
- 11 immediate

dst register (any register in CPU primary register file)

#### Encoding

Cvcles

| 31      | 24 23  | 16 15 | 87  | 0 |
|---------|--------|-------|-----|---|
| 0 0 0 1 | 10100G | dst   | src |   |

**Description** The bitwise logical AND of the *dst* and *src* operands is formed, but the result is not loaded in any register. This allows for nondestructive compares. The *dst* and *src* operands are assumed to be unsigned integers.

|             | •                                                                 |
|-------------|-------------------------------------------------------------------|
| Status Bits | These condition flags are modified for all destination registers. |
|             | LUE Unaffected                                                    |

- LV Unaffected.
- **UF** 0.

1

- **N** MSB of the output.
- **Z** 1 if a zero output is generated, 0 otherwise.
- **V** 0.
- C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example TSTB \*-AR4(1),R5

## **Before Instruction:**

AR4 = 80 99C5h R5 = 898h = 2200 Data at 80 99C4h = 767h = 1895 LUF LV UF N Z V C = 0 0 0 0 0 0 0

#### After Instruction:

AR4 =  $80\ 99C5h$ R5 = 898h = 2200Data at  $80\ 99C4h$  = 767h = 1895LUF LV UF N Z V C =  $0\ 0\ 0\ 1\ 0\ 0$  Syntax TSTB3 src2, src1

**Operation** src1 & src2

*Operands* src1, src2 both type 1 or type 2 three-operand addressing modes

## Encoding

Type 1

| 31 24           | 23 16       | i 15 | <u> </u> |
|-----------------|-------------|------|----------|
| 0 0 1 0 0 1 1 1 | 1 T 0 0 0 0 | src1 | src2     |

## Type 2

| 31            | 24 23       | 16 15            | 87                | 0   |
|---------------|-------------|------------------|-------------------|-----|
| 0 0 1 1 0 1 1 | 1 1 T 0 0 C | ) 0 0 <i>src</i> | 1 I I I I<br>1 SI | rc2 |

#### Instruction Word Fields

| Type | 1 |
|------|---|
| .,   |   |

|   | Т  | <i>src1</i> addressing modes          | <i>src2</i> addressing modes          |
|---|----|---------------------------------------|---------------------------------------|
|   | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|   | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|   | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

| Type | 2 |
|------|---|

| Т  | src1 addressing modes                                | src2 addressing modes                             |
|----|------------------------------------------------------|---------------------------------------------------|
| 00 | register mode (any CPU register)                     | 8-bit signed immediate                            |
| 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned displacement)  |
| 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                            |
| 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned displacement) |

**Description** The bitwise logical AND between the *src1* and *src2* operands is formed but is not loaded into any register. This allows for nondestructive compares. The *src1* and *src2* operands are assumed to be signed integers.

Cycles

Status Bits LUF Unaffected.

1

LV Unaffected.

**UF** 0.

N MSB of the output.

Z 1 if a zero output is generated, 0 otherwise.

**V** 0.

C Unaffected.

*Mode Bit* **OVM** Operation is not affected by OVM bit value.

Syntax XOR src, dst

**Operation** dst XOR  $src \rightarrow dst$ 

*Operands* src general addressing modes (G):

- 00 register (any register in CPU primary register file)
- 0 1 direct
- 10 indirect
- 11 immediate

dst register (any register in CPU primary register file)

#### Encoding

| 31    | 24 23         | 16 15 | 87  | 0 |
|-------|---------------|-------|-----|---|
| 0 0 0 | 1 1 0 1 0 1 G | dst   | src |   |

**Description** The bitwise exclusive OR of the *src* and *dst* operands is loaded into the *dst* register. The *dst* and *src* operands are assumed to be unsigned integers.

#### Cycles

- Status Bits If ST (SETCOND) = 0 and the destination register is R0 R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.
  - LUF Unaffected.
  - LV Unaffected.
  - **UF** 0.

1

- **N** MSB of the output.
- **Z** 1 if a zero output is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* OVM Operation is not affected by OVM bit value.

Example XOR R1, R2

## **Before Instruction:**

R1 = 0F FA32h R2 = 0F F5C1h LUF LV UF N Z V C = 0 0 0 0 0 0 0

## After Instruction:

R1 = 0F F412h R2 = 00 0FF3h LUF LV UF N Z V C = 0 0 0 0 0 0 0

## **XOR3** Bitwise Exclusive OR, 3 Operands

| Syntax    | XOR3 src2,        | src1, dst                                                                                                      |
|-----------|-------------------|----------------------------------------------------------------------------------------------------------------|
| Operation | src1 XOR s        | $rc2 \rightarrow dst$                                                                                          |
| Operands  | src1, src2<br>dst | both type 1 or type 2 three-operand addressing modes register mode (any register in CPU primary register file) |

## Encoding

| Туре | 1 |
|------|---|
|------|---|

| 31 24 23        | 3 | 16  | 15   | 87   | 0 |
|-----------------|---|-----|------|------|---|
| 0 0 1 0 0 0 0 0 | T | dst | src1 | src2 |   |

#### Type 2

| 31      | 24 23       | 16 15 | 87       | 0 |
|---------|-------------|-------|----------|---|
| 0 0 1 1 | 1 0 0 0 0 T | dst s | rc1 src2 |   |

## Instruction Word Fields

| Туре | 1 |
|------|---|

|     | Т  | <i>src1</i> addressing modes          | <i>src2</i> addressing modes          |
|-----|----|---------------------------------------|---------------------------------------|
|     | 00 | register mode (any CPU register)      | register mode (any CPU register)      |
| e 1 | 01 | indirect mode (disp = 0, 1, IR0, IR1) | register mode (any CPU register)      |
|     | 10 | register mode (any CPU register)      | indirect mode (disp = 0, 1, IR0, IR1) |
|     | 11 | indirect mode (disp = 0, 1, IR0, IR1) | indirect mode (disp = 0, 1, IR0, IR1) |

|      | Т  | <i>src1</i> addressing modes                         | <i>src2</i> addressing modes                      |  |
|------|----|------------------------------------------------------|---------------------------------------------------|--|
| be 2 | 00 | register mode (any CPU register)                     | 8-bit signed immediate                            |  |
|      | 01 | register mode (any CPU register)                     | indirect mode *+ARn(5-bit unsigned displacement)  |  |
|      | 10 | indirect mode *+ARn(5-bit unsigned<br>displacement)  | 8-bit signed immediate                            |  |
|      | 11 | indirect mode *+ARn1(5-bit unsigned<br>displacement) | indirect mode *+ARn2(5-bit unsigned displacement) |  |

Type 2

- **Description** The bitwise exclusive OR between the *src1* and *src2* operands is loaded into the *dst* register. The *src1*, *src2*, and *dst* operands are assumed to be signed integers.
- Cycles
- Status Bits If ST (SETCOND) = 0 and the destination register is R0 R11, the condition flags are modified. If ST (SETCOND) = 1, they are modified for all destination registers.
  - LUF Unaffected.
  - LV Unaffected.
  - **UF** 0.

- **N** MSB of the output.
- **Z** 1 if a zero output is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

#### **XOR3**||**STI** Parallel XOR3 and STI

| Syntax    | XOR3 src2, s                                       | •                          |       |      |
|-----------|----------------------------------------------------|----------------------------|-------|------|
| Operation | src1 XOR src<br>$\parallel src3 \rightarrow dst2$  | $2 \rightarrow dst1$       |       |      |
| Operands  | <i>dst1</i> register (F<br><i>src3</i> register (F | isp = 0, 1, IR<br>{0 – R7) | · · · |      |
| Encoding  |                                                    |                            |       |      |
| <u>31</u> | 24 23                                              | 16                         | 3 15  | 87   |
| 1 1 1 0   | 1 1 1 <i>dst</i>                                   | src1 src3                  | dst2  | src2 |

**Description** A bitwise exclusive-XOR and an integer store are performed in parallel. All registers are read at the beginning and loaded at the end of the execute cycle. This means that if one of the parallel operations (STI) reads from a register and the operation being performed in parallel (XOR3) writes to the same register, then STI accepts as input the contents of the register before it is modified by the XOR3.

If *src2* and *dst2* point to the same location, *src2* is read before the write to *dst2*.

#### Cycles

| Status Bits | LUF | Unaffected. |
|-------------|-----|-------------|
|-------------|-----|-------------|

1

LV Unaffected.

**UF** 0.

- **N** MSB of the output.
- **Z** 1 if a zero output is generated, 0 otherwise.
- **V** 0.
- C Unaffected.
- *Mode Bit* **OVM** Operation is not affected by OVM bit value.

Example XOR3 \*AR1++,R3,R3

|| STI R6,\*-AR2(IR0)

## **Before Instruction:**

AR1 = 80 987Eh R3 = 85h R6 = 0DCh = 220 AR2 = 80 98B4h IR0 = 8h Data at 80 987Eh = 85h Data at 80 98ACh = 0h LUF LV UF N Z V C = 0 0 0 0 0 0 0

## **After Instruction:**

AR1 = 80 987Fh R3 = 0h R6 = 0DCh = 220 AR2 = 80 98B4h IR0 = 8h Data at 80 987Eh = 85h Data at 80 98ACh = 0DCh = 220 LUF LV UF N Z V C = 0 0 0 0 0 0 0 0



## Chapter 12

# **Software Applications**

This chapter explains how to use the instruction set, the architecture, and the interface of the 'C40. It presents coding examples for frequently used applications and discusses more involved examples and applications. It also defines the principles involved in the application and gives the corresponding assembly-language code for instructional purposes and for immediate use. Whenever the detailed explanation of the underlying theory is too extensive to be included in this manual, appropriate references are given for further information.

Major topics discussed in this chapter are listed below:

| Section |                                              | Page  |
|---------|----------------------------------------------|-------|
| 12.1    | Processor Initialization                     | 12-3  |
|         | Reset Process                                | 12-3  |
|         | ■ Initialization                             | 12-3  |
| 12.2    | Program Control                              | 12-9  |
|         | ■ Regular and Zero-Overhead Subroutine Calls | 12-9  |
|         | Software Stack                               | 12-13 |
|         | ■ Interrupt Service Routines                 | 12-14 |
|         | Delayed Branches                             | 12-22 |
|         | ■ Repeat Modes                               | 12-23 |
|         | Computed GOTOs                               | 12-27 |
| 12.3    | Logical and Arithmetic Operations            | 12-28 |
|         | Bit Manipulation                             | 12-28 |
|         | Block Moves                                  | 12-29 |
|         | Byte and Half Word Manipulation              | 12-30 |
|         | Bit Reversed Addressing                      | 12-31 |

| Section |     |                                          | Page   |
|---------|-----|------------------------------------------|--------|
|         |     | Division                                 | 12-33  |
|         |     | Square Root                              | 12-38  |
|         |     | Extended-Precision Arithmetic            | 12-41  |
|         |     | IEEE <==> C40 Floating-Point Conversions | 12-42  |
| 12.4    | Ap  | plication-Oriented Operations            | 12-46  |
|         |     | Companding (A-law/µ-law)                 | 12-46  |
|         |     | FIR/IIR Filters (fixed and adaptive)     | 12-51  |
|         |     | Matrix Math                              | 12-61  |
|         |     | FFT                                      | 12-63  |
|         |     | Lattice Filters                          | 12-88  |
| 12.5    | Pro | ogramming Tips                           | 12-94  |
|         |     | C-Callable Routines                      | 12-94  |
|         |     | Hints for Assembly Coding                | 12-95  |
| 12.6    | Pe  | ripherals                                | 12-97  |
|         |     | Timer                                    | 12-97  |
|         |     | Communication Port                       | 12-98  |
|         |     | Direct Memory Access                     | 12-101 |

## **12.1 Processor Initialization**

## 12.1.1 Reset Process

Before you execute a DSP algorithm, it is necessary to initialize the processor. Generally, initialization takes place any time the processor is reset.

When reset is activated by applying a low level to the RESET input for several cycles, the 'C40 terminates execution and puts the RESET vector in the program counter. The RESET vector of 'C40 may be mapped to one of four different locations, controlled by the value of the RESETLOC(1,0) pins at RESET (shown in Table 12–1). The RESET vector normally contains the address of the system initialization routine. The hardware reset also initializes various registers and status bits (reset conditions are further defined in Section 6.6 on page 6-18).

| Table 12–1. | Relationship of RESETLOC(1,0) Pins to RESET Vector Location |
|-------------|-------------------------------------------------------------|
|             |                                                             |

| RESETLOC(1,0) | RESET Vector Address |
|---------------|----------------------|
| 0 0           | 0000 0000h           |
| 0 1           | 7FFF FFFFh           |
| 10            | 8000 0000h           |
| 11            | FFFF FFFFh           |

After reset, initialize the processor further by executing instructions that set up operational modes, memory pointers, interrupts, and the remaining functions needed to meet system requirements.

## 12.1.2 Initialization

To configure the processor at reset, the following internal functions should be initialized:

- CPU expansion register file
- Memory-mapped registers
- □ Interrupt structure

Example 12-1 shows coding for initializing the 'C40 to the following machine state, in addition to the initialization performed during the hardware reset (for conditions after hardware reset, see Section 6.6 on page 6-18):

All interrupts are enabled.

The program cache is enabled.

The overflow mode is disabled.

The data memory page pointer is set to zero.

The stack pointer is set to internal RAM address 002FFF00H

The internal memory is filled with zeros.

Note that all constants larger than 16 bits should be placed in memory and accessed through direct or indirect addressing.

Example 12–1. Processor Initialization Example

| TITLE                                                                                                                                                                  | PROCESSOR INITIALIZATION EXAMPLE'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa<br>.globa | <pre>1 TIME0, TIME1, TINT0, TINT1<br/>1 NMI, INT0, INT1, INT2, INT3<br/>1 NON_MASK, ISR0, ISR1, ISR2, ISR3<br/>1 ICFULL0, ICRDY0, OCRDY0, OCEMPTY0<br/>1 ICFSR0, ICRSR0, OCRSR0, OCESR0<br/>1 ICFULL1, ICRDY1, OCRDY1, OCEMPTY1<br/>1 ICFSR1, ICRSR1, OCRSR1, OCESR1<br/>1 ICFULL2, ICRDY2, OCRDY2, OCEMPTY2<br/>1 ICFSR2, ICRSR2, OCRSR2, OCESR2<br/>1 ICFULL3, ICRDY3, OCRDY3, OCEMPTY3<br/>1 ICFSR3, ICRSR3, OCRSR3, OCESR3<br/>1 ICFULL4, ICRDY4, OCRDY4, OCEMPTY4<br/>1 ICFSR4, ICRSR4, OCRSR4, OCESR4<br/>1 ICFULL5, ICRDY5, OCRDY5, OCEMPTY5<br/>1 ICFSR5, ICRSR5, OCRSR5, OCESR5</pre> |
| .globa<br>.globa<br>.globa                                                                                                                                             | 1 DMA0, DMA1, DMA2, DMA3, DMA4, DMA5<br>1 TRAP0, TRAP1, TRAP2, TRAP3, TRAP4, TRAP5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Software Applications

12

\* \* \*

Example 12–1. Processor Initialization Example (Continued)

\* \* PROCESSOR INITIALIZATION FOR THE TMS320C40. \* RESET AND INTERRUPT VECTOR SPECIFICATION. THIS ARRANGEMENT \* \* ASSUMES THAT DURING LINKING, THE FOLLOWING TEXT SEGMENT \* WILL BE PLACED TO START AT MEMORY LOCATION AS: \* \* SEGMENT NAME | MEMORY LOCATION \* reset\_adr | SAME AS RESETLOC(1,0) SETUP int\_vect | 00000200h trap\_vect | 00000400h \* \* \* \* .data | 00000500h \* | 00000600h .text \* \* NOTE THAT THE INTERRUPT AND TRAP VECTORS TABLE CAN BE \* RELOCATED TO A 512-WORD BOUNDARY BY CHANGING THE VALUES \* OF THE IVTP AND TVTP. .sect "reset adr" ; Named section for RESET vector RESET ; RS-load address INIT to PC .word INIT \* ; Named section for interrupt .sect "int vect" ; structures \* .space 1 ; Reserved space .word NON\_MASK ; Non Maskable Interrupt NMI-loads NMI ; address NMI to PC ; Timer 0 interrupt processing TINTO .word TIME0 \* ; INTO- loads address INTO to PC ; INTI- loads address INT1 to PC ; INT2- loads address INT2 to PC ; INT3- loads address INT3 to PC ; Reserved space .word ISR0 .word ISR1 INTO INT1 TNT2 .word ISR2 INT3 .word ISR3 ; Reserved space .space 6 ICFULL0.wordICFSR0; Comm. port 0 input full processingICRDY0.wordICRSR0; Comm. port 0 input ready processingOCRDY0.wordOCRSR0; Comm. port 0 output ready processingOCEMPTY0.wordOCESR0; Comm. port 0 output ready processing ICFULL1 .word ICFSR1 ICRDY1 .word ICRSR1 OCRDY1 .word OCRSR1 ; Comm. port 1 input full processing ; Comm. port 1 input ready processing ; Comm. port 1 output ready processing ; Comm. port 1 output empty processing OCEMPTY1 .word OCESR1 ; Comm. port 2 input full processing ICFULL2 .word ICFSR2 ; Comm. port 2 input ready processing ; Comm. port 2 output ready processing ICRDY2 .word ICRSR2 OCRDY2 .word OCRSR2 OCEMPTY2 .word OCESR2 ; Comm. port 2 output empty processing ICFULL3.wordICFSR3; Comm. port 3 input full processingICRDY3.wordICRSR3; Comm. port 3 input ready processingOCRDY3.wordOCRSR3; Comm. port 3 output ready processingOCEMPTY3.wordOCESR3; Comm. port 3 output ready processing

## Processor Initialization

| Exampl | e 12–1 | Process | sor Initia | lization | Example | e (Continued) | 1 |
|--------|--------|---------|------------|----------|---------|---------------|---|
|--------|--------|---------|------------|----------|---------|---------------|---|

| ICFULL4                                                                                                                                                                                               |                                                                                                                                                                                                      | ICFSR4                                                                                                                        | ;                                                         | Comm. port 4 input full processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ICRDY4                                                                                                                                                                                                |                                                                                                                                                                                                      | ICRSR4                                                                                                                        | ;                                                         | Comm. port 4 input ready processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| OCRDY4                                                                                                                                                                                                |                                                                                                                                                                                                      | OCRSR4                                                                                                                        | ;                                                         | Comm. port 4 output ready processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| OCEMPTY4<br>*                                                                                                                                                                                         | .word                                                                                                                                                                                                | OCESR4                                                                                                                        | ;                                                         | Comm. port 4 output empty processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ICFULL5                                                                                                                                                                                               |                                                                                                                                                                                                      | ICFSR5                                                                                                                        | ;                                                         | Comm. port 5 input full processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ICRDY5                                                                                                                                                                                                |                                                                                                                                                                                                      | ICRSR5                                                                                                                        | ;                                                         | Comm. port 5 input ready processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| OCRDY5                                                                                                                                                                                                | .word                                                                                                                                                                                                | OCRSR5                                                                                                                        | ;                                                         | Comm. port 5 output ready processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| OCEMPTY5<br>*                                                                                                                                                                                         | .word                                                                                                                                                                                                | OCESR5                                                                                                                        | ;                                                         | Comm. port 5 output empty processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DINT0                                                                                                                                                                                                 | .word                                                                                                                                                                                                | DMA0                                                                                                                          | ;                                                         | DMA Channel 0 interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DINT1                                                                                                                                                                                                 | .word                                                                                                                                                                                                | DMA1                                                                                                                          | ;                                                         | DMA Channel 1 interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DINT2                                                                                                                                                                                                 | .word                                                                                                                                                                                                | DMA2                                                                                                                          | ;                                                         | DMA Channel 2 interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DINT3                                                                                                                                                                                                 | .word                                                                                                                                                                                                | DMA3                                                                                                                          | ;                                                         | DMA Channel 3 interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DINT4                                                                                                                                                                                                 | .word                                                                                                                                                                                                | DMA4                                                                                                                          | ;                                                         | DMA Channel 4 interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DINT5                                                                                                                                                                                                 | .word                                                                                                                                                                                                | DMA5                                                                                                                          | ;                                                         | DMA Channel 5 interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| TINT1                                                                                                                                                                                                 | .word                                                                                                                                                                                                | TIME1                                                                                                                         | ;                                                         | Timer 1 interrupt processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                       | .space                                                                                                                                                                                               |                                                                                                                               | ;                                                         | Reserved space                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| *                                                                                                                                                                                                     |                                                                                                                                                                                                      |                                                                                                                               | •                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                       | .sect                                                                                                                                                                                                | "trap_vect"                                                                                                                   | ;                                                         | Named section for trap structures                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| TRAP0                                                                                                                                                                                                 | .word                                                                                                                                                                                                |                                                                                                                               | ;                                                         | Trap 0 vector processing begins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TRAP1                                                                                                                                                                                                 | .word                                                                                                                                                                                                | TRP1                                                                                                                          | ;                                                         | Trap 1 vector processing begins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TRAP2                                                                                                                                                                                                 | .word                                                                                                                                                                                                | TRP2                                                                                                                          | ;                                                         | Trap 2 vector processing begins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TRAP3                                                                                                                                                                                                 | .word                                                                                                                                                                                                |                                                                                                                               | ;                                                         | Trap 3 vector processing begins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TRAP4                                                                                                                                                                                                 | .word                                                                                                                                                                                                |                                                                                                                               | ;                                                         | Trap 4 vector processing begins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TRAP5                                                                                                                                                                                                 | .word                                                                                                                                                                                                |                                                                                                                               | ;                                                         | Trap 5 vector processing begins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                       | .space                                                                                                                                                                                               |                                                                                                                               |                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                       |                                                                                                                                                                                                      |                                                                                                                               |                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| *                                                                                                                                                                                                     | .space                                                                                                                                                                                               | 500                                                                                                                           | ;                                                         | Leave space for the other 506 traps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| *                                                                                                                                                                                                     |                                                                                                                                                                                                      |                                                                                                                               |                                                           | TANTS THAT CANNOT BE REPRESENTED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                       | IN THI                                                                                                                                                                                               | S SECTION, C                                                                                                                  | ONS                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| *                                                                                                                                                                                                     | IN THI                                                                                                                                                                                               | S SECTION, C                                                                                                                  | ONS                                                       | TANTS THAT CANNOT BE REPRESENTED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| *                                                                                                                                                                                                     | IN THI<br>IN THE<br>.data                                                                                                                                                                            | S SECTION, C                                                                                                                  | ONS                                                       | TANTS THAT CANNOT BE REPRESENTED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| *                                                                                                                                                                                                     | IN THI<br>IN THE<br>.data<br>.word                                                                                                                                                                   | S SECTION, CO<br>SHORT FORMA                                                                                                  | ONS<br>F F                                                | TANTS THAT CANNOT BE REPRESENTED RE INITIALIZED.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| *<br>*<br>MASK                                                                                                                                                                                        | IN THI<br>IN THE<br>.data<br>.word<br>.word                                                                                                                                                          | S SECTION, CO<br>SHORT FORMA<br>OFFFFFFFH                                                                                     | ONS<br>T F                                                | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| *<br>MASK<br>BLK0<br>BLK1                                                                                                                                                                             | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word                                                                                                                                                 | S SECTION, CO<br>SHORT FORMA<br>OFFFFFFFFH<br>02FF800H<br>02FFC00H                                                            | ONS<br>T #<br>;                                           | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| *<br>MASK<br>BLK0<br>BLK1<br>CTRL                                                                                                                                                                     | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word                                                                                                                                        | S SECTION, CO<br>SHORT FORMA<br>OFFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H                                                | ONS<br>F #<br>;<br>;                                      | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| *<br>MASK<br>BLK0<br>BLK1                                                                                                                                                                             | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word                                                                                                                                        | S SECTION, CO<br>SHORT FORMA<br>OFFFFFFFFH<br>02FF800H<br>02FFC00H                                                            | ONS<br>F <i>F</i><br>;<br>;                               | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT                                                                                                                                                      | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word                                                                                                                               | S SECTION, CO<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>000000H                                      | ONS<br>F F<br>;<br>;<br>;                                 | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT                                                                                                                                                      | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word                                                                                                                               | S SECTION, CO<br>SHORT FORMA<br>OFFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H                                                | ONS<br>F #<br>;<br>;<br>;<br>;                            | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT                                                                                                                                                      | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word                                                                                                                               | S SECTION, CO<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>000000H                                      | ONS<br>F F<br>;<br>;<br>;                                 | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| *<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL                                                                                                                                    | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                                                                                                                      | S SECTION, Co<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H                         | ONS<br>F <i>F</i><br>;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL                                                                                                                    | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                                                                                                             | S SECTION, Co<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H             | ONS<br>F <i>F</i><br>;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)                                                                                                                                                                                                                                                                                                                                                                                                               |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA2CTL                                                                                                         | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                                                                                                    | S SECTION, Co<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000   | ONS<br>F 7<br>;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;         | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)                                                                                                                                                                                                                                                                                                                                                                     |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA1CTL<br>DMA2CTL<br>DMA3CTL                                                                                   | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                                                                                           | S SECTION, Co<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000   | ONS<br>F F<br>;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;          | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)<br>Initialization for DMA 3 control (208)                                                                                                                                                                                                                                                                                                                           |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA1CTL<br>DMA3CTL<br>DMA3CTL<br>DMA4CTL                                                                        | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                                                                                  | S SECTION, Co<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000   | ONS<br>I I<br>;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;          | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)<br>Initialization for DMA 3 control (208)<br>Initialization for DMA 4 control (224)                                                                                                                                                                                                                                                                                 |
| *<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA1CTL<br>DMA3CTL<br>DMA3CTL<br>DMA4CTL<br>DMA5CTL                                                                  | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                                                                         | S SECTION, Co<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000   |                                                           | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)<br>Initialization for DMA 3 control (208)<br>Initialization for DMA 4 control (224)<br>Initialization for DMA 5 control (240)                                                                                                                                                                                                                                       |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA1CTL<br>DMA3CTL<br>DMA4CTL<br>DMA5CTL<br>CP0CTL                                                              | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                                                       | S SECTION, Co<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000   |                                                           | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)<br>Initialization for DMA 3 control (208)<br>Initialization for DMA 4 control (224)<br>Initialization for DMA 5 control (240)<br>Init of comm. port 0 control (64)                                                                                                                                                                                                  |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA1CTL<br>DMA3CTL<br>DMA3CTL<br>DMA4CTL<br>DMA5CTL<br>CP0CTL<br>CP1CTL                                         | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                                                       | S SECTION, Co<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000   |                                                           | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)<br>Initialization for DMA 3 control (208)<br>Initialization for DMA 4 control (224)<br>Initialization for DMA 5 control (240)<br>Init of comm. port 0 control (64)<br>Init of comm. port 1 control (80)                                                                                                                                                             |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA1CTL<br>DMA3CTL<br>DMA3CTL<br>DMA5CTL<br>CP0CTL<br>CP0CTL<br>CP1CTL<br>CP2CTL                                | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                                     | S SECTION, Co<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000   |                                                           | STANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)<br>Initialization for DMA 3 control (208)<br>Initialization for DMA 4 control (224)<br>Initialization for DMA 5 control (240)<br>Init of comm. port 0 control (64)<br>Init of comm. port 1 control (80)<br>Init of comm. port 2 control (96)                                                                                                                       |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA1CTL<br>DMA3CTL<br>DMA4CTL<br>DMA4CTL<br>CP0CTL<br>CP1CTL<br>CP2CTL<br>CP3CTL                                | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                                     | S SECTION, Co<br>SHORT FORMA<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000   |                                                           | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)<br>Initialization for DMA 3 control (208)<br>Initialization for DMA 4 control (224)<br>Initialization for DMA 5 control (240)<br>Init of comm. port 0 control (64)<br>Init of comm. port 1 control (80)<br>Init of comm. port 3 control (112)                                                                                                                       |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA1CTL<br>DMA2CTL<br>DMA3CTL<br>DMA4CTL<br>DMA5CTL<br>CP0CTL<br>CP1CTL<br>CP2CTL<br>CP2CTL<br>CP3CTL<br>CP4CTL | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                            | S SECTION, Co<br>SHORT FORMA'<br>OFFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000 |                                                           | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)<br>Initialization for DMA 3 control (208)<br>Initialization for DMA 4 control (224)<br>Initialization for DMA 5 control (240)<br>Init of comm. port 1 control (80)<br>Init of comm. port 2 control (96)<br>Init of comm. port 3 control (128)                                                                                                                       |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA1CTL<br>DMA3CTL<br>DMA4CTL<br>DMA4CTL<br>CP0CTL<br>CP1CTL<br>CP2CTL<br>CP2CTL<br>CP3CTL<br>CP3CTL<br>CP5CTL  | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word                   | S SECTION, Co<br>SHORT FORMA'<br>OFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000  |                                                           | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)<br>Initialization for DMA 3 control (208)<br>Initialization for DMA 4 control (224)<br>Initialization for DMA 5 control (240)<br>Init of comm. port 1 control (80)<br>Init of comm. port 2 control (96)<br>Init of comm. port 3 control (128)<br>Init of comm. port 4 control (124)                                                                                 |
| *<br>*<br>MASK<br>BLK0<br>BLK1<br>CTRL<br>GLOINT<br>LOCALINT<br>DMA0CTL<br>DMA1CTL<br>DMA1CTL<br>DMA2CTL<br>DMA3CTL<br>DMA4CTL<br>DMA5CTL<br>CP0CTL<br>CP1CTL<br>CP2CTL<br>CP2CTL<br>CP3CTL<br>CP4CTL | IN THI<br>IN THE<br>.data<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word | S SECTION, Co<br>SHORT FORMA'<br>OFFFFFFFFH<br>02FF800H<br>02FFC00H<br>0100000H<br>0000000H<br>0000000H<br>0000000H<br>000000 |                                                           | TANTS THAT CANNOT BE REPRESENTED<br>RE INITIALIZED.<br>Beginning address of RAM block 0<br>Beginning address of RAM block 1<br>Pointer for peripheral-bus memory map<br>Init of global memory interface<br>control (0)<br>Init of local memory interface<br>control (4)<br>Initialization for DMA 0 control (160)<br>Initialization for DMA 1 control (176)<br>Initialization for DMA 2 control (192)<br>Initialization for DMA 3 control (208)<br>Initialization for DMA 4 control (224)<br>Initialization for DMA 5 control (240)<br>Init of comm. port 0 control (64)<br>Init of comm. port 1 control (80)<br>Init of comm. port 3 control (112)<br>Init of comm. port 4 control (128)<br>Init of comm. port 5 control (144)<br>Initialization of timer 0 control (32) |

12

Software Applications

Example 12–1. Processor Initialization Example (Continued)

; Initialization of analysis module (16) ANACTL .word 0000000H STCK ; Beginningof stack .word 02FFF00H \* .text \* \* THE ADDRESS AT RESET VECTOR DIRECTS EXECUTION TO BEGIN HERE FOR RESET PROCESSING THAT INITIALIZES THE PROCESSOR. WHEN \* \* RESET IS APPLIED, THE FOLLOWING REGISTERS ARE INITIALIZED \* TO ZERO: \* \* ST-- CPU STATUS REGISTER \* DIE -- DMA INTERRUPT ENABLE REGISTER \* -- INTERNAL INTERRUPT ENABLE REGISTER IIE \* ITF -- IIOF PINS AND INTERRUPT FLAG REGISTER \* \* -- INTERRUPT-VECTOR TABLE POINTER IVTP \* TVTP -- TRAP-VECTOR TABLE POINTER \* \* THE STATUS REGISTER HAS THE FOLLOWING ARRANGEMENT: \* BITS: 31-17 16 15 14 13 12 11 10 \* FUNCTION: RESRV ANALYSIS SET PGIE GIE CC CE CF COND IDLE 5 2 \* 9 8 7 6 4 3 0 BITS: 1 \* LUF LV UF 37 С FUNCTION: PCF RM OVM NZ \* INIT LDPX MASK ; Point the DP register to page 0 1800H,ST ; Clear and enable cache, and LDI : disable OVM \* \* SET UP IVTP AND TVTP TO 200H AND 400H \* LDI 0200H, AR0 ; Set Primary Register AR0 to 200H LDPE AR0, IVTP ; Set Expansion Register IVTP to 200H ; Set Primary Register AR0 to 400H ADDI 0200H, AR0 AR0, TVTP ; Set Expansion Register TVTP to 400H LDPE ; Enable all interrupts LDI @MASK, IE \* INTERNAL DATA MEMORY INITIALIZATION TO FLOATING POINT ZERO \* \* LDI @BLK0,AR0 ; ARO points to block 0 LDI @BLK1,AR1 ; AR1 points to block 1 LDF 0.0,R0 ; Zero register RO RPTS 1023 ; Repeat 1024 times ... ; Zero out location in RAM block 0 and STF R0,\*AR0++(1) ; Zero out location in RAM block 1. STF R0, \*AR1++(1)\* \* THE PROCESSOR IS INITIALIZED. THE REMAINING APPLICATION-\* DEPENDENT PART OF THE SYSTEM (BOTH ON- AND OFF-CHIP SHOULD \* NOW BE INITIALIZED. \* \* FIRST, INITIALIZE THE CONTROL REGISTERS. IN THIS EXAMPLE, \* EVERYTHING IS INITIALIZED TO ZERO SINCE THE ACTUAL INITIALIZATION IS APPLICATION DEPENDENT. \* \*

| Example 12–1. | Processor | Initialization | Example | (Conclude | ed) |
|---------------|-----------|----------------|---------|-----------|-----|
|---------------|-----------|----------------|---------|-----------|-----|

| LDI        | @CTRL, ARO                 | ; LOAD in ARO the pointer to control   |
|------------|----------------------------|----------------------------------------|
|            | 0.0T.O.T.VIII . D.O.       | ; registers                            |
| LDI        | @GLOINT,RO                 | . Tuit alabel memory interface control |
| STI        | RO,*ARO                    | ; Init global memory interface control |
| LDI        | @LOCALINT,RO               | This least memory interface control    |
| STI        | R0,*+AR0(4)                | ; Init local memory interface control  |
| LDI        | @DMAOCTL,RO                | This DVA C control                     |
| STI        | R0,*+AR0(160)              | ; Init DMA 0 control                   |
| LDI        | @DMA1CTL,R0                | This DVA 1 control                     |
| STI        | R0,*+AR0(176)              | ; Init DMA 1 control                   |
| LDI        | @DMA2CTL,R0                | Trit DWD 0 control                     |
| STI        | R0,*+AR0(192)              | ; Init DMA 2 control                   |
| LDI        | @DMA3CTL,R0                |                                        |
| STI        | R0,*+AR0(208)              | ; Init DMA 3 control                   |
| LDI        | @DMA4CTL,R0                | ; Init DMA 4 control                   |
| STI        | R0,*+AR0(224)              | ; INIT DMA 4 CONTROL                   |
| LDI        | @DMA5CTL,R0                | . Trit DWD 5 control                   |
| STI        | R0,*+AR0(240)              | ; Init DMA 5 control                   |
| LDI        | @CPOCTL,R0                 | · Thit communication next ( control    |
| STI        | R0,*+AR0(64)               | ; Init communication port 0 control    |
| LDI<br>STI | @CP1CTL,R0<br>R0,*+AR0(80) | ; Init communication port 0 control    |
| LDI        | @CP2CTL,R0                 | , init communication port o control    |
| STI        | R0, *+AR0 (96)             | ; Init communication port 0 control    |
| LDI        | @CP3CTL,R0                 | , This communication poir o control    |
| STI        | R0, *+AR0 (112)            | ; Init communication port 0 control    |
| LDI        | @CP4CTL,R0                 | , mit communication poit o contion     |
| STI        | R0,*+AR0(128)              | ; Init communication port 0 control    |
| LDI        | @CP5CTL,R0                 | , This communication pois o control    |
| STI        | R0, *+AR0(144)             | ; Init communication port 0 control    |
| LDI        | @TIMOCTL,RO                | , inte communication port o control    |
| STI        | R0,*+AR0(32)               | ; Init timer 0 control                 |
| LDI        | @TIM1CTL,R0                | , init timer o concret                 |
| STI        | R0,*+AR0(48)               | ; Init timer 1 control                 |
| LDI        | @ANACTL,R0                 | ,                                      |
| STI        | R0,*+AR0(16)               | ; Init analysis module control         |
| LDÍ        | @STCK, SP                  | ; Initialize the stack pointer         |
| OR         | 2000H, ST                  | ; Global interrupt enable              |
|            |                            | ,                                      |
| BR         | BEGIN                      | ; Branch to the beginning of           |
|            |                            | ; application.                         |
| .end       |                            |                                        |
|            |                            |                                        |

12

\*

\*

# 12.2 Program Control

TMS320C40 instructions provide program control and facilitates highspeed processing. These instructions directly handle:

- Regular and zero-overhead subroutine calls
- Software stack
- Interrupts
- Delayed branches
- Single- and multiple-instruction loops without any overhead

### 12.2.1 Subroutines

The 'C40 provides two ways to invoke the subroutine calls: regular and zerooverhead. The **regular** and **zero-overhead** subroutine calls use software stack (SP) and extended-precision register R11 respectively to save the return address. The following subsections use example programs to explain how this works.

# 12.2.1.1 Regular Subroutine Calls

The 'C40 has a 32-bit program counter (PC) and a practically unlimited software stack. The CALL and CALL*cond* subroutine calls cause the stack pointer to increment and store the contents of the next value of the PC counter on the stack. At the end of the subroutine, RETS*cond* performs a conditional return.

Example 12–2 illustrates the use of a subroutine to determine the dot product between two vectors. Given two vectors of length N, represented by the arrays a[0], a[1], ..., a[N–1] and b[0], b[1],..., b[N–1], the dot product is computed from the expression

 $d = a[0] b[0] + a[1] b[1] + \dots + a[N-1] b[N-1]$ 

Processing proceeds in the main routine to the point where the dot product is to be computed. It is assumed that the arguments of the subroutine have been appropriately initialized. At this point, a CALL is made to the subroutine, transferring control to that section of the program memory for execution, then returning to the calling routine via the RETS instruction when execution has completed. Note that for this particular example, it would suffice to save the register R2. However, a larger number of registers are saved for demonstration purposes. The saved registers are stored on the system stack, which should be large enough to accommodate the maximum anticipated storage requirements. Other methods of saving registers could be used equally well.

Example 12–2. Regular Subroutine Call (Dot Product)

```
*
*
         TITLE REGULAR SUBROUTINE CALL (DOT PRODUCT)
*
*
*
         MAIN ROUTINE THAT CALLS THE SUBROUTINE 'DOT' TO COMPUTE THE
*
         DOT PRODUCT OF TWO VECTORS.
         ٠
                   @blk0,AR0 ; AR0 points to vector a
@blk1,AR1 ; AR1 points to vector b
         LDI
         LDI
         LDI
                               ; RC contains the number of elements
                   N, RC
CALL
         DOT
*SUBROUTINE DOT
*
*EQUATION:
             d = a(0) * b(0) + a(1) * b(1) + ... + a(N-1) * b(N-1)
*THE DOT PRODUCT OF a AND b IS PLACED IN REGISTER R0. N MUST
*BE GREATER THAN OR EQUAL TO 2.
*
*
         ARGUMENT ASSIGNMENTS:
*
           ARGUMENT | FUNCTION
*
                       ______
           ------
                                       _ _ _ _ _ _ _
*
            AR0
                    | ADDRESS OF a(0)
*
            AR1
                    | ADDRESS OF b(0)
*
            RC
                     | LENGTH OF VECTORS (N)
*
*
         REGISTERS USED AS INPUT: ARO, AR1, RC
*
         REGISTER MODIFIED: RO
*
         REGISTER CONTAINING RESULT: RO
*
*
*
         .global
                   DOT
*
DOT
         PUSH
                   ST
                               ; Save status register
                                ; Use the stack to save R2's
                   R2
         PUSH
         PUSHF
                   R2
                                ; bottom 32 and top 32 bits
                                ; Save AR0
                   AR0
         PUSH
         PUSH
                   AR1
                                ; Save AR1
                                ; Save RC
         PUSH
                   RC
         PUSH
                   RS
         PUSH
                   RE
*
                                 ; Initialize RO:
         MPYF3
                   *AR0,*AR1,R0;
                                    a(0) * b(0) -> R0
                   R2.R2,R2 ;
11
         SUBF
                                    Initialize R2.
         SUBI
                    2,RC
                                    Set RC = N-2
                                 ;
```

12

ł

| *      | DOT PRODUCT (1 <= i < N)                               |                                                |          |                                                         |  |
|--------|--------------------------------------------------------|------------------------------------------------|----------|---------------------------------------------------------|--|
| *      | RPTS                                                   | RC                                             |          | ; Setup the repeat single.                              |  |
| <br>*  | MPYF3<br>ADDF3                                         | *++AR0(1),*++A<br>R0,R2,R2                     | R1(1),R0 | ; a(i) * b(i) -> R0<br>; a(i-1)*b(i-1) + R2 -> R2       |  |
| *      | ADDF3                                                  | R0,R2,R0                                       |          | ; a(N-1)*b(N-1) + R2 -> R0                              |  |
| *      | RETURN                                                 | SEQUENCE                                       |          |                                                         |  |
| *      | POP<br>POP<br>POP<br>POP<br>POPF<br>POP<br>POP<br>RETS | RE<br>RS<br>RC<br>AR1<br>AR0<br>R2<br>R2<br>ST |          | AR1<br>AR0<br>top 32 bits of R2<br>bottom 32 bits of R2 |  |
| *<br>* | end                                                    |                                                |          |                                                         |  |
|        | .end                                                   |                                                |          |                                                         |  |

#### 12.2.1.2 Zero-Overhead Subroutine Calls

Two 'C40 instructions, link and jump (LAJ) and link and jump conditional (LAJ*cond*), allow zero-overhead subroutine calls to be implemented on the 'C40. Unlike the CALL and CALL*cond* which put the value of PC+1 into the software stack, the LAJ and LAJ*cond* put the value of PC+4 into the extended-precision register R11. Three instructions following LAJ or LAJ*cond* will be executed before going to the subroutine. The restriction of these three instructions is the same as that of the three instructions following a delayed branch. At the end of the subroutine, a delayed branch conditional, B*cond*D, using the register addressing mode with R11 as source, can be used to perform a zero-overhead subroutine return.

For comparison, the same dot product example with zero-overhead subroutine call is given in the following example program. Example 12–3. Zero-Overhead Subroutine Call (Dot Product)

\* \* TITLE ZERO-OVERHEAD SUBROUTINE CALL (DOT PRODUCT) \* \* \* MAIN ROUTINE THAT CALLS THE SUBROUTINE 'DOT' TO COMPUTE THE \* DOT PRODUCT OF TWO VECTORS. LAJ DOT @blk0,AR0 ; AR0 points to vector a
@blk1,AR1 ; AR1 points to vector b LDI LDI LDI N,RC ; RC contains the number of elements \* \*SUBROUTINE DOT \* \*EQUATION: d = a(0) \* b(0) + a(1) \* b(1) + ... + a(N-1) \* b(N-1)\* \* THE DOT PRODUCT OF a AND b IS PLACED IN REGISTER RO. N MUST \* BE GREATER THAN OR EQUAL TO 2. \* \* **ARGUMENT ASSIGNMENTS:** \* ARGUMENT | FUNCTION \* AR0 \* | ADDRESS OF a(0) \* AR1 | ADDRESS OF b(0) \* RC | LENGTH OF VECTORS (N) \* \* REGISTERS USED AS INPUT: ARO, AR1, RC \* REGISTER MODIFIED: RO \* REGISTER CONTAINING RESULT: RO \* \* \* .global DOT \* DOT STPUSH ; Save status register ; Use the stack to save R2's PUSH R2 ; bottom 32 and top 32 bits PUSHF R2 ; Save ARO PUSH AR0 AR1 PUSH ; Save AR1 PUSH RC ; Save RC PUSH RS PUSH RE ; Initialize R0: \* ; a(0) \* b(0) -> R0 MPYF3 \*AR0,\*AR1,R0 R2.R2,R2 ; Initialize R2. SUBF SUBI 2,RC ; Set RC = N-2

12-12

12

Software Applications

| *      | DOT PRODU                       | CT (1 <= i < N)                         |   |                                                                            |
|--------|---------------------------------|-----------------------------------------|---|----------------------------------------------------------------------------|
|        | RPTS<br>MPYF3<br>ADDF3          | RC<br>*++AR0(1),*++AR1(1),R<br>R0,R2,R2 | 0 | Setup the repeat single<br>; a(i) * b(i) -> R0<br>a(i-1)*b(i-1) + R2 -> R2 |
| *      | ADDF3                           | R0,R2,R0                                | ; | a(N-1)*b(N-1) + R2 -> R0                                                   |
| *<br>* | RETURN SE                       | QUENCE                                  |   |                                                                            |
|        | POP<br>POP<br>POP<br>POP<br>POP | RE<br>RS<br>RC<br>AR1<br>AR0            | ; | Restore RC<br>Restore AR1<br>Restore AR0                                   |
|        | BUD                             | R11                                     | ; | Return                                                                     |
| *      | POPF<br>POP<br>POP              | R2<br>R2<br>ST                          | ; | Restore top 32 bits of R2<br>Restore bottom 32 bits of R2<br>Restore ST    |
| *      | end                             |                                         |   |                                                                            |
|        | .end                            |                                         |   |                                                                            |

### 12.2.2 Software Stack

Location of the 'C40 software stack is determined by the contents of the stack pointer register (SP). The stack pointer increments from low to high values, and provisions should be made to accommodate the anticipated storage requirements. The stack can be used not only during the subroutine CALL and RETS, but also inside the subroutine as a place of temporary storage of the registers as shown in Example 12–2. SP always points to the **last value pushed onto the stack**.

The CALL and CALL*cond* instructions push the value of the program counter onto the stack, as do the interrupt routines. Then, RETS*cond* and RETI*cond* pop the stack and place the value in the program counter. The integer value of any register can be pushed onto and popped off the stack by using the PUSH and POP instructions.

Two additional instructions, PUSHF and POPF, are for floating-point numbers. These instructions can be used to pop and push floating-point numbers to registers R0 — R11. This feature is very useful for saving the extended precision registers (see Example 12–2 and Example 12–3). You can use PUSH and PUSHF on the same register to save the lower 32 and upper 32 bits. PUSH saves the lower 32 bits; PUSHF, the upper 32 bits. To recover this extended-precision number, execute a POPF followed by POP. It is important to do the integer and floating-point PUSH and POP in the above order. POPF forces the last eight bits of the extended-precision registers to zero.

The stack pointer (SP) can be read as well as written to. Multiple stacks for different program segments may be easily created. SP is not initialized by the hardware during reset; therefore, it is important to remember to initialize its value so that SP points to a predetermined memory location. This avoids the problem of SP attempting to write into ROM or write over other useful data.

## **12.2.3 Interrupt Service Routines**

There are two types of interrupts on the 'C40: maskable and nonmaskable. The maskable interrupts include internal and external interrupts. All the interrupts are vectored and prioritized. The vector table for the various interrupts is located in relation to the interrupt-vector table pointer (IVTP, shown in Section 3.2 on page 3-15). The nonmaskable interrupt (NMI) has the highest priority over other interrupts. Unlike other interrupts, the NMI cannot be masked by its own mask or by the GIE bit in the ST. It is temporarily masked during delayed branches and multicycle CPU operation.

When an interrupt occurs, the corresponding flag is set in the interrupt flag register (IIF --- explained in subsection 3.1.10, page 3-12). For nonmaskable interrupt, if the corresponding NMI flag is set, NMI begins the interrupt processing, as long as the CPU is not executing delayed branches or multicycle operation. For maskable interrupts, in order to respond to the interrupt when the corresponding interrupt flag is set, the GIE bit in the ST must be set to enable maskable interrupts globally, and the corresponding bit in the interrupt enable register (IIE — described in subsection 3.1.9, page 3-10) or IIF register (for external interrupts) must be set also. Since pins IIOF(3 - 0) can be either general-purpose I/O or external interrupt pins, you must configure (using IIF register) those pins as interrupt pins to enable an external interrupt. Also, if the IIOF(3 - 0) pins are configured as interrupt pins, they can be configured (also at IIF register) as either edge-triggered or level-triggered interrupts. You can also write to the IIF register, making it possible to force an interrupt by software or to clear interrupts without processing them.

The interrupt flag register can be read, and action can be taken, depending on whether the interrupt has occurred. This is true even when the maskable interrupt is disabled. This can be useful when an interrupt-driven interface is not implemented. Example 12–4 shows the case in which a subroutine is called when external interrupt 1 has not occurred. Example 12-4. Use of Interrupts for Software Polling

TITLE INTERRUPT POLLING . . . TSTB 40H,IIF ; Test if interrupt 1 has occurred CALLZ SUBROUTINE ; If not, call subroutine . .

When interrupt processing begins, the program counter is pushed on the stack, and the interrupt vector is loaded in the program counter. Interrupts are then disabled by setting GIE=0, and the program continues from the address loaded in the program counter. Since all maskable interrupts are disabled, interrupt processing may proceed without further interruption unless the interrupt service routine re-enables interrupts, or the NMI occurs.

Except for very simple interrupt service routines, it is important to assure that the processor context is saved during execution of this routine. The context must be saved before you execute the routine itself, and it must be restored after the routine is finished. The procedure is called context switching. Context switching is also useful for subroutine calls, especially when extensive use is made of the auxiliary and the extended-precision registers. Code examples of context switching and an interrupt service routine are provided in this section.

### 12.2.3.1 Context Switching

Context switching is commonly required when processing a subroutine call or interrupt. It may be quite extensive or simple, depending on system requirements. For the 'C40, the program counter is automatically pushed onto the stack. Important information in other 'C40 registers, such as the status, auxiliary, or extended-precision registers must be saved by special commands. The status register should be saved first and restored last in order to preserve the processor status without any further change caused by other context-switching instructions. Example 12–4 and Example 12–5 show saving and restoring of the 'C40 state. In both examples, the stack is used for saving the registers, and it expands towards higher addresses. If you don't want to use the stack pointed at by the SP, you can create a separate stack by using an auxiliary register as the stack pointer. Registers saved in these examples:

- Status register (ST) should be saved first and restored last
- Extended-precision registers R0 through R11
- Auxiliary registers AR0 through AR7
- Data-page pointer (DP)
- □ Index registers (IR0 and IR1)
- Block-size register (BK)
- □ Interrupt-related registers IIE, IIF, and DIE
- □ Repeat-related registers RS, RE, and RC

# Example 12–5. Context-Save for the TMS320C40

| *      | TITLE CONTEXT-SAV               | VE FOR THE TN                           | MS320C40                                       |          |
|--------|---------------------------------|-----------------------------------------|------------------------------------------------|----------|
| *<br>* | .global SAVE                    |                                         |                                                |          |
| *      | CONTEXT SAVE ON S               | SUBROUTINE CA                           | ALL OR INTERRUPT.                              |          |
| SAVE:  | PUSH ST                         | ;                                       | Save status register                           |          |
| * *    | SAVE THE EXTENDED               | PRECISION H                             | REGISTERS                                      |          |
|        | PUSH RO<br>PUSHF RO             |                                         | Save the lower 32 bit<br>and the upper 32 bits |          |
|        | PUSH R1                         | ;                                       | Save the lower 32 bit                          | s of R1  |
|        | PUSHF R1<br>PUSH R2<br>PUSHF R2 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | Save the lower 32 bit                          | s of R2  |
|        | PUSH R3<br>PUSHF R3             | ;                                       | Save the lower 32 bit                          | s of R3  |
|        | PUSH R4<br>PUSHF R4             | ;                                       | Save the lower 32 bit                          | s of R4  |
|        | PUSH R5<br>PUSHF R5             | ;                                       | Save the lower 32 bit                          | s of R5  |
|        | PUSH R6<br>PUSHF R6             | ;                                       | Save the lower 32 bit                          | s of R6  |
|        | PUSH R7                         | ;                                       | Save the lower 32 bit                          | s of R7  |
|        | PUSHF R7<br>PUSH R8             | ;;                                      |                                                | s of R8  |
|        | PUSHF R8<br>PUSH R9             | ;<br>;                                  | and the upper 32 bits<br>Save the lower 32 bit | s of R9  |
|        | PUSHF R9<br>PUSH R10            | ;                                       | and the upper 32 bits<br>Save the lower 32 bit |          |
|        | PUSHF R10                       | ;                                       | and the upper 32 bits                          |          |
|        | PUSH R11<br>PUSHF R11           | ;;                                      | Save the lower 32 bit<br>and the upper 32 bits |          |
| *      | SAVE THE AUXILIAN               | RY REGISTERS                            |                                                |          |
| *      | _                               |                                         |                                                |          |
|        | PUSH ARO<br>PUSH AR1            |                                         | Save ARO<br>Save AR1                           |          |
|        | PUSH AR2                        | ;                                       | Save AR2                                       |          |
|        | PUSH AR3                        |                                         | Save AR3                                       |          |
|        | PUSH AR4                        |                                         | Save AR4                                       |          |
|        | PUSH AR5<br>PUSH AR6            | ;                                       | Save AR5<br>Save AR6                           |          |
|        | PUSH AR6<br>PUSH AR7            |                                         | Save ARD<br>Save AR7                           |          |
| *      |                                 | •                                       | buve may                                       |          |
| *<br>* | SAVE THE REST REC               | GISTERS FROM                            | THE REGISTER FILE                              |          |
|        | PUSH DP                         |                                         | Save data page pointe                          |          |
|        | PUSH IRO                        | ;                                       | Save index register I                          | RO       |
|        | PUSH IR1                        |                                         | Save index register I                          |          |
|        | PUSH BK                         |                                         | Save block-size regis                          |          |
|        | PUSH IIE<br>PUSH IIF            | ;                                       | Save interrupt enable<br>Save interrupt flag r | register |
|        | roon IIf                        | i                                       | Save incertupt itag i                          | CATOCOL  |

#### Program Control — Interrupt Service Routines

| Fiogram  | Sontrol — Interrupt Ser  | vice houlines                                 |
|----------|--------------------------|-----------------------------------------------|
|          |                          |                                               |
|          | PUSH DIE                 | ; Save DMA interrupt enable register          |
|          | PUSH RS                  | ; Save repeat start address                   |
|          | PUSH RE                  | ; Save repeat end address                     |
|          |                          |                                               |
|          | PUSH RC                  | ; Save repeat counter                         |
|          |                          |                                               |
|          | SAVE IS COMPLETE         |                                               |
|          |                          |                                               |
|          |                          |                                               |
| xample 1 | 2–6. Context-Restore for | the TMS320C40                                 |
|          |                          |                                               |
|          |                          | ESTORE FOR THE TMS320C40                      |
|          | TITLE CONTEXT-R          | ESTORE FOR THE IMS520040                      |
|          |                          |                                               |
|          | .global REST             | R                                             |
|          |                          |                                               |
|          | CONTEXT RESTORE          | AT THE END OF A SUBROUTINE CALL OR INTERRUPT. |
| ESTR:    | • •                      |                                               |
|          |                          |                                               |
|          | RESTORE THE REST         | T REGISTERS FROM THE REGISTER FILE            |
|          |                          |                                               |
|          | POPRC                    | ; Restore repeat counter                      |
|          | POPRE                    |                                               |
|          |                          | ; Restore repeat end address                  |
|          | POPRS                    | ; Restore repeat start address                |
|          | POPDIE                   | ; Restore DMA interrupt enable register       |
|          | POPIIF                   | ; Restore interrupt flag register             |
|          | POPIIE                   | ; Restore interrupt enable register           |
|          | POP BK                   | ; Restore block-size register                 |
|          | POP IR1                  | ; Restore index register IR1                  |
|          | POP IRO                  | ; Restore index register IRO                  |
|          |                          |                                               |
|          | POPDP                    | ; Restore data page pointer                   |
|          |                          |                                               |
|          | RESTORE THE AUX          | ILIARY REGISTERS                              |
|          |                          |                                               |
|          | POP AR7                  | ; Restore AR7                                 |
|          | POP AR6                  | ; Restore AR6                                 |
|          | POPAR5                   |                                               |
|          |                          | ; Restore AR5                                 |
|          | POPAR4                   | ; Restore AR4                                 |
|          | POP AR3                  | ; Restore AR3                                 |
|          | POP AR2                  | ; Restore AR2                                 |
|          | POP AR1                  | ; Restore AR1                                 |
|          | POP ARO                  | ; Restore ARO                                 |
|          |                          |                                               |
|          |                          | ENDED PRECISION REGISTERS                     |
|          | NEGIORE INE EXIL         | CINED LECTOION REGIOIERO                      |
|          |                          | · Destans the unread 20 bits and              |
|          | POPF R11                 |                                               |
|          | POP R11                  | ; the lower 32 bits of R11                    |
|          | POPF R10                 | ; Restore the upper 32 bits and               |
|          | POP P10                  |                                               |

Software Applications

; the lower 32 bits of R10

; the lower 32 bits of R9

; the lower 32 bits of R8

; the lower 32 bits of R7

; the lower 32 bits of R6

; Restore the upper 32 bits and

12

12-18

POP

POPF

POP

POPF

POP

POPF

POPF

POP

POP

R10

R9

R9

R8

R8

R7

R7

R6

R6

POPF R5 ; Restore the upper 32 bits and POP R5 ; the lower 32 bits of R5 POPF R4 ; Restore the upper 32 bits and POP R4 ; the lower 32 bits of R4 R3 POPF ; Restore the upper 32 bits and POP R3 ; the lower 32 bits of R3 R2 POPF ; Restore the upper 32 bits and R2 POP ; the lower 32 bits of R2 POPF R1 ; Restore the upper 32 bits and POP R1 ; the lower 32 bits of R1 POPF R0 ; Restore the upper 32 bits and ; the lower 32 bits of R0 POP R0 POP ST ; Restore status register

\*

RESTORE IS COMPLETE

\*

12.2.3.2 Interrupt-Vector Table

The interrupt-vector table (IVT, shown in Figure 3–8 on page 3-16) of the 'C40 is relocatable. The location of the IVT is relative to the interrupt-vector table pointer (IVTP). The IVTP is a 32-bit expansion register that points to the base address of the IVT. Since the IVT is required to lie on a 512-word boundary, the 9 LSBs of the IVTP should always be zero. The two instructions, LDEP and LDPE, read from and write to the expansion registers, IVTP and trap-vector table pointer (TVTP). Example 12–6 shows how to change the value of the IVTP (it is similar to changing the value of the TVTP). With this relocatable feature, an interrupt signal can be used for different services. In Example 12–7, the IVTP is reset in the external INT0 interrupt service routines EINT0A and EINT0B. After the value of the IVTP is changed, CPU will go to a different interrupt service routine when the same interrupt signal occurs again.

Example 12–7. Use of One Interrupt Signal for Two Different Services

| *                   | TITLE USE                                                                   | OF ONE INTERRUP                                                                                                                                         | T SI                                         | GNAL F                                                         | OR TWO                                                       | DIFFERE                                                             | NT SI                                           | ERVIC                                      | ES          |
|---------------------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------|--------------------------------------------|-------------|
| * * * * * * * * * * | MEMORY LO<br>HAS NOT BI<br>INTERRUPT<br>SIGNAL CO<br>IF THE NE<br>WILL BE E | XAMPLE, THE ADDR<br>CATION 03H AND<br>EEN CHANGED AFTE<br>IIOFO IS ENABLE<br>MES IN, THE EINT<br>XT IIOFO INTERRU<br>XECUTED, AND SO<br>TURN TO BE EXEC | 1003<br>R DE<br>D. W<br>OA F<br>JPT S<br>ON. | H RESPE<br>VICE RE<br>HEN THE<br>OUTINE<br>GIGNAL O<br>THE EIN | ECTIVE:<br>ESET AN<br>E FIRS'<br>WILL N<br>DCCURS<br>NTOA AN | LY. ASSU<br>ND THE E<br>T IIOFO<br>BE EXECU<br>, THE EI<br>ND EINTO | MING<br>XTERN<br>INTEF<br>TED.<br>NTOB<br>B ROU | THE<br>IAL<br>RUPT<br>AND<br>ROUT<br>JTINE | THEN<br>INE |
| *                   | External                                                                    | IIOF0 interrupt                                                                                                                                         | serv                                         | vice ro                                                        | utine                                                        | A                                                                   |                                                 |                                            |             |
| *<br>EINTOA:        | .global<br>LDI<br>LDPE                                                      | EINTOA<br>1000H,R0<br>R0,IVTP                                                                                                                           | ;                                            | Change                                                         | IVTP                                                         | to point                                                            | to I                                            | 1000н                                      |             |
| *                   | RETI                                                                        |                                                                                                                                                         | ;                                            | Return                                                         | and e                                                        | nable in                                                            | terr                                            | upts                                       |             |
| *<br>*              | External                                                                    | IIOF0 interrupt                                                                                                                                         | serv                                         | vice ro                                                        | utine                                                        | A                                                                   |                                                 |                                            |             |
| *<br>EINTOB:        | .global                                                                     | EINTOB                                                                                                                                                  |                                              |                                                                |                                                              |                                                                     |                                                 |                                            |             |
| *                   | LDI<br>LDPE                                                                 | 0,R0<br>R0,IVTP                                                                                                                                         | ;                                            | Change                                                         | IVTP                                                         | to point                                                            | to (                                            | D                                          |             |
| <b>T</b>            | RETI                                                                        |                                                                                                                                                         | ;                                            | Return                                                         | and e                                                        | nable in                                                            | terr                                            | upts                                       |             |

### 12.2.3.3 Interrupt Priority

Interrupts on the 'C40 are automatically prioritized. This allows interrupts that occur simultaneously to be serviced in a predefined order. Infrequent, but lengthy, interrupt service routines may need to be interrupted by more frequently occurring interrupts. Since the GIE bit in ST is reset when the interrupt vector is taken, this nesting interrupt will occur only if it is the NMI interrupt or if the interrupt is re-enabled in the interrupt service routine.

In Example 12–8, the interrupt service routine for INT2 temporarily modifies the interrupt enable register (IIE) and interrupt flag register (IIF) to permit interrupt processing when an interrupt to INT0 or NMI (but no other interrupt) occurs. When the routine has finished processing, the IIE register is restored to its original state. Notice that the RETI*cond* instruction not only pops the next program counter address from the stack, but also restores GIE and CF bits from the PGIE and PCF bits. This re-enables all interrupts that were enabled before the INT2 interrupt was serviced.

| Example | 1 <b>2–8</b> . | Interrup | t Service | Routine |
|---------|----------------|----------|-----------|---------|
|---------|----------------|----------|-----------|---------|

| *<br>*<br>* | TITLE INT.<br>.global                                                | ERRUPT SERVIC<br>ISR2                                               | E         | ROUTINE                                                                                                                                                                                                              |
|-------------|----------------------------------------------------------------------|---------------------------------------------------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| *           | ENABLE<br>MASK                                                       | .set<br>.set                                                        | 20<br>91: | 000h                                                                                                                                                                                                                 |
| *<br>*      | INTERRUPT                                                            | PROCESSING F                                                        | FOR       | EXTERNAL INTERRUPT INT2-                                                                                                                                                                                             |
| ISR2:       | PUSH<br>PUSH<br>PUSH<br>PUSH<br>PUSH<br>PUSHF<br>PUSHF<br>LDI<br>LDI | ST<br>DP<br>IIE<br>IIF<br>RO<br>RO<br>R1<br>R1<br>O,IIE<br>MASK, RO | ;;;;;;;   | Save status register<br>Save data page pointer<br>Save interrupt enable register<br>Save lower 32 bits and<br>upper 32 bits of R0<br>Save lower 32 bits and<br>upper 32 bits of R1<br>Unmask all internal interrupts |
| *           | MH0<br>OR                                                            | RO, IIF<br>ENABLE,ST                                                | -         | Enable INT2<br>Enable all interrupts                                                                                                                                                                                 |
| *           | MAIN PROC                                                            | ESSING SECTIC                                                       | N         | FOR ISR2                                                                                                                                                                                                             |
|             | XOR<br>POPF<br>POP<br>POPF<br>POP<br>POP                             | ENABLE, ST<br>R1<br>R1<br>R0<br>IIF                                 | ;;;;      |                                                                                                                                                                                                                      |
| *           | POP<br>POP<br>POP                                                    | IIE<br>DP<br>ST                                                     | ;;;       | Restore interrupt enable register<br>Restore data page register<br>Restore status register                                                                                                                           |
|             | RETI                                                                 |                                                                     | ;         | Return and enable interrupts                                                                                                                                                                                         |

# **12.2.4 Delayed Branches**

The 'C40 uses delayed branches to create single-cycle branching. The delayed branches operate like regular branches but do not flush the pipeline. Instead, the three instructions following a delayed branch are also executed. Similarly, besides delayed branches, 'C40 also uses link and jump (LAJ), link and trap (LAT), delayed repeat block (RPTBD), and delayed return from interrupt or trap conditionally (RETI*cond* D) instructions to avoid the pipeline flush (as discussed in Section 6.3 on page 6-9) in the *Program Flow Control* chapter (Chapter 6), the only limitations are that **none** of the three instructions following a delayed branch can be a:

- Branch (standard or delayed)
- Branch and annul conditionally
- Call to a subroutine
- Link and jump instruction
- Link and trap instruction
- **G** Return from a subroutine
- Return from an interrupt or trap (standard or delayed)
- Repeat instruction (standard or delayed)
- TRAP instruction
- IDLE instruction

Conditional delayed branches use the conditions that exist at the end of the instruction immediately preceding the delayed branch. Sometimes, a branch is necessary in the flow of a program, but fewer than three instructions can be placed after a delayed branch. For faster execution, it is still advantageous to use a delayed branch. This is shown in Example 12–9, with a NOP taking the place of the third unused instruction. The tradeoff is more instruction words for less execution time.



| *    | TITLE DE                           | LAYED BRANCH E                         | EXE   | CUTION                                                                                                                                                                               |
|------|------------------------------------|----------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | •                                  |                                        |       |                                                                                                                                                                                      |
|      | •                                  |                                        |       |                                                                                                                                                                                      |
| *    | LDF<br>BGED<br>LDFN<br>SUBF<br>NOP | *+AR1(5),R2<br>SKIP<br>R2,R1<br>3.0,R1 | ;;;;; | Load contents of memory to R2<br>If loaded number >=0, branch (delayed)<br>If loaded number <0, load it to R1<br>Subtract 3 from R1<br>Dummy operation to complete delayed<br>branch |
|      | MPYF<br>•<br>•                     | 1.5,R1                                 | ;     | Continue here if loaded number <0                                                                                                                                                    |
| SKIP | LDF                                | R1,R3                                  | ;     | Continue here if loaded number >=0                                                                                                                                                   |

### 12.2.5 Repeat Modes

The 'C40 supports looping without any overhead. For that purpose, there are three instructions: RPTB and RPTBD repeat a block of code, and RPTS repeats a single instruction. The three control registers

- RS (Repeat Start address),
- RE (Repeat End address), and
- RC (Repeat Counter)

contain the parameters that specify loop execution (refer to Section 6.1 on page 6-2 for a description of RPTB, RPTBD, and RPTS). Registers RS and RE are automatically set from the code, while RC must be set by the user, as shown in Example 12–10.

Example 12–10. Use of Block Repeat to Find a Maximum or a Minimum

```
*
*
         TITLE USE OF BLOCK REPEAT TO FIND A MAXIMUM OR A MINIMUM
*
*
         THIS ROUTINE FINDS THE MAXIMUM OR THE MINIMUM OF N=147 NUMBERS
         .
         LDI
                    146,RC
                                 ; Initialize repeat counter to 147-1
         LDI
                    @ADDR, ARO
                                 ; ARO points to the beginning
                    ; of the array
*AR0++(1),R0; Initialize MAX or MIN to the
         LDF
                                 ; first value
                                ; If it is a negative array, find the
         BLT
                   LOOP2
                                 ; minimum
```

| *           |              |                      |                                  |    |
|-------------|--------------|----------------------|----------------------------------|----|
| LOOP1       | RPTB<br>CMPF | MAX<br>*AR0,R0 ;     | Compare number to the maximum    |    |
| MAX         | LDFLT<br>B   | *ARO,RO ;<br>NEXT    | If greater, this is a new maximu | ım |
| LOOP2       | RPTB<br>CMPF | MIN<br>*ARO++(1),RO; | Compare number to the minimum    |    |
| MIN<br>NEXT | LDFLT<br>•   | *-ARO(1),RO ;        | If smaller, this is a new minimu | ım |
|             | •            |                      |                                  |    |
|             | •            |                      |                                  |    |

#### 12.2.5.1 Block Repeat

The 'C40 supports both standard and delayed repeat block instructions (RPTB and RPTBD). RPTB and RPTBD are the same except that the three instructions following RPTBD *are not* included in the loop (but *are* included in the RPTB loop). For RPTBD, the loop starts at the fourth instruction following RPTBD. The restriction of these three following instructions is the same as that of the three instructions following a delayed branch. Since RPTBD is a single-cycle instruction, it is very useful in making the nesting loop program more efficient. Example 12–10 shows the use of the block repeat to find the maximum or the minimum value of 147 numbers. The elements of the array are either all positive or all negative numbers. Since the loop cannot be predetermined, the RPTBD instruction is not suitable here.

#### 12.2.5.2 Specifies Restrictions in the Block-Repeat Construct

Because the program counter is modified at the end of the loop according to the contents of registers RS, RE, and RC, no operation should attempt to modify the repeat counter or the program counter at the end of the loop to a different value.

In principle, it is possible to nest repeat blocks. However, there is only one set of control registers: RS, RE, and RC. It is, therefore, necessary to save these registers before entering an inside loop and to restore these registers after completing the inside loop. It takes four cycles overhead to save and restore these registers. Hence, sometimes, it may be more economical to implement a nested loop by the more traditional method of using a register as a counter, and then using a delayed branch rather than by using the nested repeat block approach.

Program Control — Repeat Modes

Example 12–11 shows an application of the delayed block repeat construct. In this example, an array of 64 elements is flipped over by exchanging the elements that are equidistant from the end of the array. In other words, if the original array is

a(1), a(2),..., a(31), a(32),..., a(64);

the final array after the rearrangement will be

a(64), a(63),..., a(32), a(31),..., a(1).

Because the exchange operation is done on two elements at the same time, it requires 32 operations. The repeat counter (RC) is initialized to 31. In general, if RC contains the number N, the loop will be executed N+1 times. The loop is defined by the fourth instruction following the RPTBD instruction and the EXCH label.

Example 12–11. Loop Using Delayed Block Repeat

| *           | TITLE LO                                | OOP USING DELAY                | ED BLOCK REPEAT                                                  |
|-------------|-----------------------------------------|--------------------------------|------------------------------------------------------------------|
| *<br>*<br>* |                                         |                                | NGES THE VALUES OF ARRAY ELEMENTS THAT<br>E MIDDLE OF THE ARRAY. |
|             | •                                       |                                |                                                                  |
|             | LDI                                     | @ADDR,AR0 ;                    | ARO points to the beginning of the array                         |
| *           | RPTBD                                   | EXCH ;                         | Repeat RC+1 times between START and EXCH                         |
|             | LDI<br>ADDI<br>LDI                      | AR0,AR1<br>63,AR1 ;<br>31,RC ; | AR1 points to the end of the array<br>Initialize repeat counter  |
| *           | >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> |                                | Loop starts here                                                 |
| START<br>   | LDI                                     | *AR0,R0 ;<br>*AR1,R1 ;         | Load one memory element in RO,<br>and the other in R1            |
| EXCH<br>    | STI<br>STI                              | R1,*AR0++(1);<br>R0,*AR1(1)    | Then, exchange their locations                                   |
|             | •                                       |                                |                                                                  |

### 12.2.5.3 Single-Instruction Repeat

The single-instruction repeat uses control registers RS, RE, and RC in the same way as does the block repeat. The advantage over the block repeat is that the instruction is fetched only once, and then the buses are available for moving operands. One difference to note is that the single-instruction repeat construct is not interruptible, while block repeat is interruptible.

Example 12–12 shows an application of the repeat-single construct. In this example, the sum of the products of two arrays is computed. The arrays are not necessarily different. If the arrays are a(i) and b(i), and if each is of length N=512, register R0 will contain, after computation, this quantity:

a(1) b(1) + a(2) b(2) + ... + a(N) b(N).

The value of the repeat counter (RC) is specified to be 511 in the instruction.

Example 12–12. Loop Using Single Repeat

| *  | TITLE LOC | P USING SINGLE REPEAT  |                            |
|----|-----------|------------------------|----------------------------|
|    | •         |                        |                            |
|    | LDI       | @ADDR1,AR0             | ; ARO points to array a(i) |
| *  | LDI       | @ADDR2,AR1             | ; AR1 points to array b(i) |
| *  | LDF       | 0.0,R0                 | ; Initialize R0            |
| *  |           |                        |                            |
| *  | MPYF3     | *AR0++(1),*AR1++(1),R1 | ; Compute first product    |
| *  | RPTS      | 511                    | ; Repeat 512 times         |
| ^  | MPYF3     | *AR0++(1),*AR1++(1),R1 | ; Compute next product and |
| 11 | ADDF 3    | R1,R0,R0               | ; accumulate the           |
| *  |           |                        | ; previous one             |
|    | ADDF      | R1,R0                  | ; One final addition       |
|    | •         |                        |                            |

# 12.2.6 Computed GOTOs to Select Subroutines at Runtime

Occasionally, it is convenient to select during runtime, and not during assembly, the subroutine to be executed. The 'C40's computed GOTO supports this selection. The computed GOTO is implemented by using the CALL*cond* instruction in the register addressing mode. This instruction uses the contents of the register as the address of the call. Example 12–13 shows the case of a task controller.

#### Example 12–13. Computed GOTO

| *        | TITLE COM     | PUTED GOTO       |                                        |
|----------|---------------|------------------|----------------------------------------|
| *        |               |                  |                                        |
| *        | TASK CONTR    | OLLER            |                                        |
| *        |               |                  |                                        |
| *        |               |                  | 5 THE ORDER OF TASK EXECUTION (6 TASKS |
| *        |               |                  | ASKO THROUGH TASK5 ARE THE NAMES OF    |
| *        |               |                  | THEY ARE EXECUTED IN ORDER, TASKO,     |
| *        | TASK1,        | . TASK5. WHEN A  | AN INTERRUPT OCCURS, THE INTERRUPT     |
| *        | SERVICE RO    | UTINE IS EXECUTE | D, AND THE PROCESSOR CONTINUES         |
| *        |               |                  | WING THE IDLE INSTRUCTION. THIS        |
| *        | ROUTINE SE    | LECTS THE TASK A | APPROPRIATE FOR THE CURRENT CYCLE,     |
| *        | CALLS THE     | TASK AS A SUBROU | JTINE, AND BRANCHES BACK TO THE IDLE   |
| . *      | TO WAIT FO    | R THE NEXT SAMPI | E INTERRUPT WHEN THE SCHEDULED TASK    |
| *        | HAS COMPLE    | TED EXECUTION. F | RO HOLDS THE OFFSET FROM THE BASE      |
| *        | ADDRESS OF    | THE TASK TO BE   | EXECUTED. BIT 15 (SET COND BIT) OF     |
| *        | STATUS REG    | ISTER (ST) SHOUL | LD BE SET TO 1.                        |
| *        |               | • • •            |                                        |
| *        |               |                  |                                        |
|          | LDI           | 5,IR0            | ; Initialize IRO                       |
|          | LDI           | @ADDR, AR1       | ; AR1 holds the base address           |
|          |               | •                | ; of the table                         |
| WAIT     | IDLE          |                  | ; Wait for the next interrupt          |
|          | ADDI          | *+AR1(IR0),R1    | ; Add the base address to the table    |
| *        |               |                  | ; entry number                         |
|          | SUBI          | 1,IR0            | ; Decrement IRO                        |
|          | LDILT         | 5,IR0            | ; If IRO<0, reinitialize it to 5       |
|          | CALLU         | R1               | ; Execute appropriate task             |
|          | BRWAIT        |                  | ,                                      |
| *        |               |                  |                                        |
| TSKSEQ   | .word         | TASK5            | ; Address of TASK5                     |
| <b>-</b> | .word         | TASK4            | ; Address of TASK4                     |
|          | .word         | TASK3            | ; Address of TASK3                     |
|          | .word         | TASK2            | ; Address of TASK2                     |
|          | .word         | TASK1            | ; Address of TASK1                     |
|          | .word         | TASKO            | : Address of TASKO                     |
| ADDR     | .word         | TSKSEO           | , Multob of INDRO                      |
| ADDI     | • <b>WOLU</b> | TORODA           |                                        |

# **12.3 Logical and Arithmetic Operations**

The 'C40 instruction set supports both integer and floating-point arithmetic and logical operations. The basic functions of such instructions can be combined to form more complex operations. This section examines examples of these operations:

- **D** Bit manipulation
- Block moves
- Byte and half-word manipulation
- Bit-reversed addressing
- □ Integer and floating-point division
- Square root
- **Extended-precision** arithmetic
- Floating-point format conversion between IEEE and 'C40 formats

# 12.3.1 Bit Manipulation

Instructions for logical operations, such as AND, OR, NOT, ANDN, and XOR, can be used together with the shift instructions for bit manipulation. A special instruction, TSTB, tests bits. TSTB does the same operation as AND, but the result of the TSTB is used only to set the condition flags and is not written anywhere. Example 12–14 and Example 12–15 demonstrate the use of the several instructions for bit manipulation and testing.

Example 12–14. Use of TSTB for Software-Controlled Interrupt

```
*
         TITLE
               USE OF TSTB FOR SOFTWARE-CONTROLLED INTERRUPT
*
*
         IN THIS EXAMPLE, ALL INTERRUPTS HAVE BEEN DISABLED BY
*
         RESETTING THE GIE BIT OF THE STATUS REGISTER. WHEN AN
*
         INTERRUPT ARRIVES, IT IS STORED IN THE IF REGISTER. THE
*
         PRESENT EXAMPLE ACTIVATES THE INTERRUPT SERVICE ROUTINE INTR
*
         WHEN IT DETECTS THAT INT2- HAS OCCURRED.
         TSTB
                    4,IIF
                               ; Check if bit 2 of IF is set,
                    INTR
         CALLNZ
                               ; and, if so, call subroutine INTR
```

```
Example 12–15. Copy a Bit from One Location to Another
```

```
*
        TITLE COPY A BIT FROM ONE LOCATION TO ANOTHER
*
*
        BIT I OF R1 NEEDS TO BE COPIED TO BIT J OF R2.
*
        ARO POINTS TO A LOCATION HOLDING I, AND IT IS ASSUMED THAT THE
*
        NEXT MEMORY LOCATION HOLDS THE VALUE J.
*
        LDI
                   1,R0
                                ; Shift 1 to align it with bit I
        LSH
                   *AR0,R0
        TSTB
                  R1,R0
                                 ; Test the I-th bit of R1
                   CONT
        BZD
                                ; If bit = 0, branch delayed
        LDI
                  1.R0
                                ; Align 1 with J-th location
        LSH
                  *+ARO(1),RO
                                 ; If bit = 0, reset J-th bit of R2
        ANDN
                   R0,R2
                   R0,R2
                                 ; If bit = 1, set J-th bit of R2
        OR
        CONT
```

### 12.3.2 Block Moves

Because the 'C40 directly addresses a large amount of memory, blocks of data or program code can be stored off-chip in slow memories and then loaded on-chip for faster execution. Data can also be moved from on-chip to off-chip for storage or for multiprocessor data transfers.

Such data transfers can be accomplished efficiently in parallel with CPU operations using the DMA. The DMA operation is explained in detail in Chapter 9. An alternative to DMA is to perform data transfers under program control by using load and store instructions in a repeat mode. Example 12–16 shows the transfer of a block of 512 floating-point numbers from external memory to block 1 of the on-chip RAM.

| Example 12–16. | Block Move Ur | nder Program Control |
|----------------|---------------|----------------------|
|----------------|---------------|----------------------|

```
TITLE BLOCK MOVE UNDER PROGRAM CONTROL
         .word 01000H
extern
block1
         .word 02FFC00H
        LDI
                               ; Source address
              @extern,AR0
        LDI
              @block1,AR1
                               ; Destination address
        LDF
              *AR0++,R0
                               ; Load the first number
        RPTS 510
                               ; Repeat following instruction
                               ; 511 times
        LDF
              *AR0++,R0
                              ; Load the next number, and...
11
         STF
              R0,*AR1++
                              ; store the previous one
         STF
              R0,*AR1
                               ; Store the last number
```

#### 12.3.3 Byte and Half-Word Manipulation

A new set of instructions for byte and half-word accessibility, such as LB(3,2,1,0), LBU(3,2,1,0), LH(1,0), LHU(1,0), LWL(0,1,2,3), LWR(0,1,2,3), MB(3,2,1,0), and MH(1,0), are available on the 'C40. In application such as image processing, it is often important to be able to manipulate packed data. For example, the pixels in color images are often represented by four 8-bit unsigned quantities — red, green, blue and alpha — which are packed into a single 32-bit word. The byte and half-word instruction will make it very easy to manipulate this packed data.

Example 12–17 shows the case of packing data from a half-word FIFO to 32-bit data memory, and Example 12–18 shows the case of unpacking a 32-bit data array into a four-byte-wide data array (assuming the 32-bit data array contains four 8-bit unsigned numbers).

Example 12–17. Use of Packing Data From Half-Word FIFO to 32-Bit Data Memory

| * | TITLE USE OF PACKING DATA FROM HALF-WORD FIFO              |
|---|------------------------------------------------------------|
| * | TO 32-BIT DATA MEMORY                                      |
| * |                                                            |
| * | IN THIS EXAMPLE, EVERY TWO INPUT 16 BITS DATA              |
| * | HAS BEEN PACKED INTO ONE 32-BIT DATA MEMORY. THE LOOP SIZE |
| * | USED HERE IS ARRAY SIZE, NOT THE INPUT DATA LENGTH.        |
|   | · · · · · · · · · · · · · · · · · · ·                      |

|      | RPTBD   | PACK           |                           |
|------|---------|----------------|---------------------------|
|      | LDI     | @fifo adr, AR1 | ; Load fifo address       |
|      | LDI     | @array, AR2    | ; Load data array address |
|      | LDI     | size-1,RC      | ; Load array size         |
| *    | >>>>>>> | >>>>>>>        | ; Loop starts here        |
|      | LWLO    | *AR1,R9        | ; Pack 16 LSBs            |
|      | LWL1    | *AR1,R9        | ; Pack 16 MSBs            |
| PACK | STI     | R9,*AR2++(1)   | ; Store the data          |
|      | •       |                |                           |
|      | •       |                |                           |
|      | •       |                |                           |
|      |         |                |                           |

#### Example 12–18. Use of Unpacking 32-Bit Data Into Four-Byte-Wide Data Array

| *<br>*<br>* |                                         | SE OF UNPACKING 32<br>DATA ARRAY | -В | IT DATA INTO FOUR BYTE-WIDE                                          |
|-------------|-----------------------------------------|----------------------------------|----|----------------------------------------------------------------------|
| *<br>*      | THIS EXAN<br>UNSIGNED                   |                                  | TH | E 32-BIT DATA CONTAINS FOUR 8-BIT                                    |
|             | •                                       | DAIA.                            |    |                                                                      |
|             | •                                       |                                  |    |                                                                      |
|             | LDI                                     | <pre>@input_adr,AR0</pre>        |    | Load RPTBD UNPACKinput address                                       |
|             | LDI<br>LDI                              | @array1,AR1<br>@array2,AR2       | •  | Load output data array 1 address<br>Load output data array 2 address |
|             | RPTBD                                   | UNPACK                           |    |                                                                      |
|             | LDI                                     | @array3,AR3                      |    | Load output data array 3 address                                     |
|             | LDI                                     | @array4,AR4                      |    | Load output data array 4 address                                     |
|             | LDI                                     | size-1,RC                        |    | Load array size                                                      |
| *           | >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> |                                  | •  | Loop starts here                                                     |
|             | LBUO<br>STI                             | *AR0,R8<br>R8,*AR1++(1)          | ;  | Unpack first byte                                                    |
|             | LBU1                                    | *AR0,R8                          | •  | Unpack second byte                                                   |
|             | STI                                     | R8,*AR2++(1)                     | '  | onpuen becond byce                                                   |
|             | LBU2                                    | *AR0, R8                         | ;  | Unpack third byte                                                    |
|             | STI,                                    | R8,*AR3++(1)                     |    |                                                                      |
|             | LBU3                                    | *AR0++(1),R8                     | ;  | Unpack fourth byte                                                   |
| UNPACK      | STI                                     | R8,*AR4++(1)                     |    | —                                                                    |
|             |                                         |                                  |    |                                                                      |

# 12.3.4 Bit-Reversed Addressing

The 'C40 can implement fast Fourier transforms (FFT) with bit-reversed addressing. If the data to be transformed is in the correct order, the final result of the FFT is scrambled in bit-reversed order. To recover the frequency-domain data in the correct order, certain memory locations must be swapped. The bit-reversed addressing mode makes swapping unnecessary. The next time data needs to be accessed, the access is done in a bit-reversed manner rather than sequentially. In 'C40, this bit-reversed addressing can be implemented through both the CPU and DMA.

In CPU bit-reversed addressing, IR0 holds a value equal to one-half the size of the FFT, if real and imaginary data are stored in separate arrays. During 12 accessing, the auxiliary register is indexed by IR0, but with reverse carry propagation. Example 12–19 illustrates a 512-point complex FFT being moved from the place of computation (pointed at by AR0) to a location pointed at by AR1. In this example, real and imaginary parts XR(i) and XI(i) of the data are not stored in separate arrays, but they are interleaved with XR(0), XI(0), XR(1), XI(1), ..., XR(N1), XI(N1). Because of this arrangement, the length of the array is 2N instead of N, and IR0 is set to 512 instead of 256.

| Example 12–19. B | it-Reversed Addressing |
|------------------|------------------------|
|------------------|------------------------|

| ^           |              |                   |     |                                                     |
|-------------|--------------|-------------------|-----|-----------------------------------------------------|
| *           | TITLE BIT-F  | REVERSED ADDRESSI | NG  |                                                     |
| *<br>*<br>* | COMPUTATION  | N, POINTED AT BY  | AR  | OF THE 512-POINT FFT<br>0, TO A LOCATION POINTED AT |
| *           | BY AR1. REA  | AL AND IMAGINARY  | PO: | INTS ARE ALTERNATING.                               |
|             | •            |                   |     |                                                     |
|             | •            |                   |     |                                                     |
|             | •            |                   |     |                                                     |
|             | LDI<br>RPTBD | 512, IRO<br>LOOP  |     |                                                     |
|             | LDI<br>LDI   | 2,IR1<br>511,RC   |     | Repeat 511+1 times                                  |
| *           | LDF          | *+AR0(1),R1       | ;   | Load first imaginary point                          |
|             | LDF          | *AR0++(IR0)B,R0   |     | Load real value (and point                          |
| <br>*       | STF          | R1,*+AR1(1)       |     | to next location) and store the imaginary value     |
| LOOP        | LDF          | *+AR0(1),R1       |     | Load next imaginary point<br>and store              |
|             | STF          | R0,*AR1++(IR1)    | •   | previous real value                                 |
|             |              |                   |     |                                                     |

In DMA bit-reversed addressing, there are two bits in the DMA control register to enable bit-reversed addressing on DMA reads and DMA write. The source address index register and destination address index register are used to define the size of the bit-reversed addressing. Their function is similar to the CPU index register IR0. For more detail information about DMA operation, refer to Chapter 9.

# 12.3.5 Integer and Floating-Point Division

'C40 has a single-cycle instruction, RCPF, to generate an estimate of the reciprocal of a floating-point number. This estimate has the correct exponent, and the mantissa is accurate to the eighth binary place (the error of the mantissa is  $< 2^{-8}$ ). Often, this is a satisfactory estimate of the reciprocal of a floating-point number. In other cases, this estimate may be used as a seed for an algorithm that computes the reciprocal to even greater accuracy. The Newton-Raphson algorithm described later is one such case.

For integer division, although the special instruction is not provided, the instruction set has the capacity to perform an efficient division routine. Besides, the rough estimate can be achieved through FLOAT, RCPF, and FIX instructions.

### 12.3.5.1 Integer Division

Division is implemented on the 'C40 by repeated subtractions using SUBC, a special conditional subtract instruction. Consider the case of a 32-bit positive dividend with i significant bits (and 32–i sign bits), and a 32-bit positive divisor with j significant bits (and 32–j sign bits). The repetition of the SUBC command i-j+1 times produces a 32-bit result where the lower i-j+1 bits are the quotient, and the upper 31-i+j bits are the remainder of the division.

SUBC implements binary division in the same manner as long division. The divisor (assumed to be smaller than the dividend) is shifted left i-j times to be aligned with the dividend. Then, using SUBC, the shifted divisor is subtracted from the dividend. For each subtract that does not produce a negative answer, the dividend is replaced by the difference. It is then shifted to the left, and a one is put in the LSB. If the difference is negative, the dividend is simply shifted left by one. This operation is repeated i-j+1 times.

As an example, consider the division of 33 by 5 using both long division and the SUBC method. In this case, i=6, j=3, and the SUBC operation is repeated 6-3+1=4 times.



When the SUBC command is used, both the dividend and the divisor must be positive. Example 12–20 shows a realization of the integer division in which the sign of the quotient is properly handled. The last instruction before returning modifies the condition flag in case subsequent operations depend on the sign of the result.

Example 12–20. Integer Division

\*

| *      |                         |                    |      |                                     |       |
|--------|-------------------------|--------------------|------|-------------------------------------|-------|
| *      | TITLE INTE              | GER DIVISION       |      |                                     |       |
| *      |                         |                    |      |                                     |       |
| *      | SUBROUTINE              | DIVI               |      |                                     |       |
| *      |                         |                    |      |                                     |       |
| *      |                         | GNED INTEGER DIV   | מדע  | END IN BO                           |       |
| *      |                         | GNED INTEGER DIV   |      |                                     |       |
| *      |                         |                    |      |                                     |       |
| *      | OUTPUT: R0/             | 'R1 into R0.       |      |                                     |       |
| *      |                         |                    |      |                                     |       |
| *      | REGISTERS U             | JSED: R0-R3, IR0,  | , I  | R1                                  |       |
| *      |                         |                    | 1170 | OD WITHU DIVIDEND                   |       |
| *      | OPERATION:              | 2. REPEAT SUBC     | VIS  | OR WITH DIVIDEND                    |       |
| *      |                         | 3. QUOTIENT IS     | TN   | LSB& OF PESULT                      |       |
| *      |                         | S. QUOITENI IS     | TIN  | 1555 OF RESULT                      |       |
| *      | CYCLES: 31-             | -62 (DEPENDS ON A  | AMO  | UNT OF NORMALIZATION)               |       |
| *      |                         | •                  |      |                                     |       |
|        | .globl DI               | IVI                |      |                                     |       |
|        |                         | set R2             |      |                                     |       |
|        |                         | set R3             |      |                                     |       |
|        |                         | et IRO             |      |                                     |       |
|        | COUNT .s                | et IR1             |      |                                     |       |
| *      | DIVI - SIGN             | NED DIVISION       |      |                                     |       |
| DIVI:  |                         |                    |      |                                     |       |
| *      |                         |                    |      |                                     |       |
| * DETE | RMINE SIGN (            | OF RESULT. GET A   | BSC  | LUTE VALUE OF OPERANDS.             |       |
| *      |                         |                    |      |                                     |       |
|        | XOR                     | R0,R1,SIGN         | ;    | Get the sign                        |       |
|        | ABSI                    | RO                 |      | -                                   |       |
|        | ABSI                    | R1                 |      |                                     |       |
|        | CMPI                    | R0,R1              | ;    | Divisor > dividend ?                |       |
|        | BGTD                    | ZERO               | ;    | If so, return 0                     |       |
| *      |                         |                    |      |                                     |       |
| *      |                         |                    |      | RENCE IN EXPONENTS AS SHIFT         | COUNT |
| *      | FOR DIVISOR             | R, AND AS REPEAT   | CO   | UNT FOR 'SUBC'.                     |       |
| *      | <b>T</b> T 0 3 <b>T</b> |                    |      |                                     |       |
|        | FLOAT                   | RO, TEMPF          |      | Normalize dividend                  |       |
|        | PUSHF<br>POP            | TEMPF<br>COUNT     |      | USH as float                        |       |
|        | LSH                     | -24, COUNT         |      | POP as int<br>Get dividend exponent |       |
|        |                         |                    |      |                                     |       |
|        | FLOAT<br>PUSHF          | R1, TEMPF<br>TEMPF |      | Normalize divisor<br>PUSH as float  |       |
|        | POP                     | TEMPF<br>TEMP      |      | POSH as float<br>POP as int         |       |
|        | LSH                     |                    |      | Get divisor exponent                |       |
|        | SUBI                    | TEMP COUNT         | 1    | Get difference in exponents         |       |
|        | LSH                     |                    |      | Align divisor with dividend         |       |
|        | 11-11                   | 000M1/I/T          | ,    | WITHIN GIVISOL WICH GIVIGING        |       |

| *   | DO COUNT+1     | SUBTRACT & SHIFTS.                                           |  |
|-----|----------------|--------------------------------------------------------------|--|
| *   |                |                                                              |  |
|     | RPTS           | COUNT                                                        |  |
| *   | SUBC           | R1,R0                                                        |  |
| *   | MASK OFF T     | HE LOWER COUNT+1 BITS OF RO                                  |  |
| *   |                |                                                              |  |
|     | SUBRI          | 31,COUNT ; Shift count is (32 - (COUNT+1))                   |  |
|     | LSH            | COUNT,R0 ; Shift left                                        |  |
|     | NEGI<br>LSH    | COUNT<br>COUNT,R0 ; Shift right to get result                |  |
| *   | LSR            | COOMI, KO , SHITE HIGHE CO GET LESULE                        |  |
| *   | CHECK SIGN AND | NEGATE RESULT IF NECESSARY.                                  |  |
| *   |                |                                                              |  |
|     | NEGI           | R0,R1 ; Negate result                                        |  |
|     | ASH<br>LDINZ   | -31,SIGN ; Check sign<br>R1,R0 ; If set, use negative result |  |
|     | CMPI           | 0,R0 ; Set status from result RETS                           |  |
| *   |                |                                                              |  |
| *   | RETURN ZERO.   |                                                              |  |
| *   | <u>~</u>       |                                                              |  |
| ZER | LDI            | 0, R0                                                        |  |
|     | RETS           |                                                              |  |
|     | .end           |                                                              |  |

If the dividend is less than the divisor and you want fractional division, you can perform a division after you determine the desired accuracy of the quotient in bits. If the desired accuracy is k bits, start by shifting the dividend left by k positions. Then apply the algorithm described above, where i should now be replaced by i + k. It is assumed that i + k is less than 32.

#### 12.3.5.2 Computation of Floating-Point Inverse and Division

This section presents a method of implementing a single-cycle RCPF instruction (reciprocal of a floating-point number) with an algorithm to extend the precision of the mantissa of the reciprocal of a floating-point number generated by RCPF instruction. The floating-point division can be obtained by multiplying the dividend and the reciprocal of the divisor.

The input to RCPF is assumed to be  $v - v(man) \ge 2^{v(exp)}$ . The output is  $x = x(man) \ge 2^{x(exp)}$ . The value v(man) (or x(man)) is composed of three fields: the sign bit v(sign), an implied nonsign bit, and the fraction field v(frac).

The algorithm for RCPF uses these four rules:

1) If v > 0, then x(exp) = -v(exp) - 1 and x(man) = 2/v(man). For the special case where the ten MSBs of v(man) = 01.00000000b, then  $x(man) = 2 - 2^{-8} = 01.11111111b$ . In both cases, the 23 LSBs of x(frac) = 0.

- 2) If v < 0, then x(exp) = -v(exp) 1 and x(man) = 2/v(man). For the special case of the ten MSBs of v(man) = 10.00000000, then  $x(man) = -1 - 2^{-8} = 10.11111111$ . In both cases, the 23 LSBs of x(frac) = 0.
- 4) If v(exp) = 127, then x(exp) = -128 and x(man) = 0. The zero flag (Z) is set to 1.

The RCPF instruction gives an estimate of the reciprocal of a number. The Newton-Raphson algorithm may be used to further extend the precision of the mantissa. The algorithm is

x[n+1] = x[n](2.0-vx[n])

v is the number for which the reciprocal is desired. x[0] is the seed for the algorithm and is given by RCPF. At every iteration of the algorithm, the number of bits of accuracy in the mantissa doubles. Using RCPF, accuracy starts at eight bits. With one iteration, accuracy increases to 16 bits, and with the second iteration, accuracy increases to 32 bits in the mantissa. Example 12–21 shows the program to implement this algorithm on the 'C40.

Example 12–21. Inverse of a Floating-Point Number With 32-Bit Mantissa Accuracy

| ~ |                                                                           |  |  |  |  |  |  |  |
|---|---------------------------------------------------------------------------|--|--|--|--|--|--|--|
| * | TITLE INVERSE OF A FLOATING-POINT NUMBER<br>WITH 32-BIT MANTISSA ACCURACY |  |  |  |  |  |  |  |
| * |                                                                           |  |  |  |  |  |  |  |
| * | SUBROUTINE INVF                                                           |  |  |  |  |  |  |  |
| * |                                                                           |  |  |  |  |  |  |  |
| * | THE FLOATING-POINT NUMBER $v$ is stored in R0. After the                  |  |  |  |  |  |  |  |
| * | COMPUTATION IS COMPLETED, 1/v IS STORED IN R1.                            |  |  |  |  |  |  |  |
| * |                                                                           |  |  |  |  |  |  |  |
| * | TYPICAL CALLING SEQUENCE:                                                 |  |  |  |  |  |  |  |
| * | LAJU INVF                                                                 |  |  |  |  |  |  |  |
| * | LDF v, RO                                                                 |  |  |  |  |  |  |  |
| * | NOP < can be other non-pipeline-break                                     |  |  |  |  |  |  |  |
| * | NOP < instructions                                                        |  |  |  |  |  |  |  |
| * |                                                                           |  |  |  |  |  |  |  |
| * | ARGUMENT ASSIGNMENTS:                                                     |  |  |  |  |  |  |  |
| * |                                                                           |  |  |  |  |  |  |  |
| * | ARGUMENT   FUNCTION                                                       |  |  |  |  |  |  |  |
| * |                                                                           |  |  |  |  |  |  |  |
| * | R0   v = NUMBER TO FIND THE RECIPROCAL OF                                 |  |  |  |  |  |  |  |
| * | (UPON THE CALL)                                                           |  |  |  |  |  |  |  |
| * | R1   1/v (UPON THE RETURN)                                                |  |  |  |  |  |  |  |
|   |                                                                           |  |  |  |  |  |  |  |

12-37

.

| *          |          |                                       |      |        |         |       |           |    |      |      |   |
|------------|----------|---------------------------------------|------|--------|---------|-------|-----------|----|------|------|---|
| *          | REGISTER | USED AS INP                           | UT:  |        |         | R0    |           |    |      |      |   |
| *          | REGISTER | S MODIFIED:                           |      |        |         | R1,   | R2        |    |      |      |   |
| *          | REGISTER | CONTAINING 1                          | RESU | JLT:   |         | R1    |           |    |      |      |   |
| *          | REGISTER | USED FOR SUI                          | BROI | JTINE  | CALL:   | R11   |           |    |      |      |   |
| *          |          |                                       |      |        |         |       |           |    |      |      |   |
| *          | CYCLES:  | 8 WORDS: 8                            |      |        |         |       |           |    |      |      |   |
| *          |          |                                       |      |        |         |       |           |    |      |      |   |
| *          |          |                                       |      |        |         |       |           |    |      |      |   |
|            | .global  | INVF                                  |      |        |         |       |           |    |      |      |   |
| *          |          | · · · · · · · · · · · · · · · · · · · |      |        |         |       | •         | -  |      |      |   |
| INVF:<br>* | RCPF     | R0,R1                                 | ;    | Get    | x[0] =  | the   | estimate  | of | 1/v, | R0 = | v |
|            | MPYF3    | R1,R0,R2                              |      |        |         |       |           |    |      |      |   |
|            | SUBRF    | 2.0,R2                                |      |        |         |       |           |    |      |      |   |
|            | MPYF     | R2,R1                                 | •    |        |         |       | teration  |    |      |      |   |
|            |          |                                       | ;    | (16    | bits ad | ccura | acy)      |    |      |      |   |
| *          |          |                                       |      |        |         |       |           |    |      |      |   |
|            | BUD      | R11                                   | ;    | Dela   | yed ret | turn  | to calle  | r  |      |      |   |
| *          |          |                                       |      |        |         |       |           |    |      |      |   |
|            | MPYF3    | R1,R0,R2                              |      |        |         |       |           |    |      |      |   |
|            | SUBRF    | 2.0,R2                                |      |        |         |       |           |    |      |      |   |
|            | MPYF     | R2,R1                                 |      |        |         |       | iteration |    |      |      |   |
| *          |          |                                       | ;    | (32)   | bits ad | Joura | acy)      |    |      |      |   |
| *          |          | D1 _ 1/ 1                             | 20+1 |        |         | ~     |           |    |      |      |   |
| *          |          | R1 = 1/v, H                           | .ect | 111 00 | carre   | Ŧ     |           |    |      |      |   |
| ••         | end      |                                       |      |        |         |       |           |    |      |      |   |
|            |          |                                       |      |        |         |       |           |    |      |      |   |

.end

### 12.3.6 Square Root

In many applications, normalization of data values is necessary. Often, the normalizing factor is the square root of another quantity. For example, given a vector, the unit vector in the same direction as the original vector can be found by normalizing the original vector by the length of the vector. This involves a division by a square root. The 'C40 provides a single-cycle instruction, RSQRF, to generate an estimate of the reciprocal of the square root of a positive floating-point number. This estimate has the correct exponent, and the mantissa is accurate to the eighth binary place (the error of the mantissa is <  $2^{-8}$ ). Like the algorithm for RCPF, the algorithm for RSQRF uses these three rules:

 If v(exp) is even, then x(exp) = -(v(exp)/2) - 1 and x(man) = 2/sqrt(v(man)). For the special case where the ten MSBs of y(man) = 01.00000000b, then x(man) = 2 - 2 - 8 = 01.1111111b. In both cases, the 23 LSBs of x(frac) = 0.

- 2) If v(exp) is odd, then x(exp) = -((v(exp) 1)/2) 1 and x(man) = sqrt(2/v(man)). The 23 LSBs of x(frac) = 0.
- 3) If v = 0 (v(exp) = -128), then x(exp) = 127 and In other words, if v = 0, then x becomes the largest positive number representable in the extended-precision floating-point format. The overflow flag (V) is set to 1.

Once the RSQRF instruction gives the estimate of the reciprocal of the square root, you can use the Newton-Raphson algorithm to further extend the precision of the mantissa. The algorithm is

x[n+1] = x[n](1.5-(v/2)x[n]x[n])

v is the number for which the reciprocal is desired. x[0] is the seed for the algorithm and is given by RSQRF. At every iteration of the algorithm, the number of bits of accuracy in the mantissa doubles. Using RSQRF, accuracy starts at eight bits. With one iteration, accuracy increases to 16 bits, and with the second iteration, accuracy increases to 32 bits in the mantissa. Example 12–22 shows the program to implement this algorithm on the 'C40.

Example 12–22. Reciprocal of the Square Root of a Positive Floating-Point

| * |                                                        |  |  |  |  |  |  |
|---|--------------------------------------------------------|--|--|--|--|--|--|
| * | TITLE RECIPROCAL OF THE SQUARE ROOT OF A POSITIVE      |  |  |  |  |  |  |
| * | FLOATING-POINT                                         |  |  |  |  |  |  |
| * |                                                        |  |  |  |  |  |  |
| * | SUBROUTINE RCPSORF                                     |  |  |  |  |  |  |
| * |                                                        |  |  |  |  |  |  |
| * | THE FLOATING-POINT NUMBER V IS STORED IN RO. AFTER THE |  |  |  |  |  |  |
| * | COMPUTATION IS COMPLETED, 1/SQRT(v) IS STORED IN R1.   |  |  |  |  |  |  |
| * | COMPUTATION IS COMPLETED, I/SURI(V) IS STORED IN RI.   |  |  |  |  |  |  |
| * | TYPICAL CALLING SEQUENCE:                              |  |  |  |  |  |  |
| * |                                                        |  |  |  |  |  |  |
| * | LDFv, RO                                               |  |  |  |  |  |  |
| * | LAJU RCPSQRF                                           |  |  |  |  |  |  |
| * |                                                        |  |  |  |  |  |  |
|   | ARGUMENT ASSIGNMENTS:                                  |  |  |  |  |  |  |
| * |                                                        |  |  |  |  |  |  |
| * | ARGUMENT   FUNCTION                                    |  |  |  |  |  |  |
| * |                                                        |  |  |  |  |  |  |
| * | R0   v = NUMBER TO FIND THE RECIPROCAL OF              |  |  |  |  |  |  |
|   | (UPON THE CALL)                                        |  |  |  |  |  |  |
| * | R1   1/sqrt(v) (UPON THE RETURN)                       |  |  |  |  |  |  |
| * |                                                        |  |  |  |  |  |  |
| * | REGISTER USED AS INPUT: R0                             |  |  |  |  |  |  |
| * | REGISTERS MODIFIED: R1, R2                             |  |  |  |  |  |  |
| * | REGISTER CONTAINING RESULT: R1                         |  |  |  |  |  |  |
| * | REGISTER USED FOR SUBROUTINE CALL: R11                 |  |  |  |  |  |  |
| * |                                                        |  |  |  |  |  |  |

#### Logical and Arithmetic Operations

| *        | CYCLES: 11             | WORDS: 11                   | - |                                                   |
|----------|------------------------|-----------------------------|---|---------------------------------------------------|
| *        | .global                | RCPSQRF                     |   |                                                   |
| RCPSQRF: | RSQRF                  | R0,R1                       |   | Get $x[0]$ = the estimate of $1/sqrt(v)$ , R0 = v |
| *        | MPYF                   | 0.5,R0                      |   | R0 = v/2                                          |
|          | MPYF3<br>MPYF<br>SUBRF | R1,R1,R2<br>R0,R2<br>1.5,R2 | ; | First iteration                                   |
| *        | MPYF                   | R2,R1                       | • | End of first iteration<br>(16 bits accuracy)      |
| *        | MPYF3                  | R1,R1,R2                    | ; | Second iteration                                  |
| *        | BRD                    | R11                         | ; | Delayed return to caller                          |
|          | MPYF<br>SUBRF<br>MPYF  | R0,R2<br>1.5,R2<br>R2,R1    |   | End of second iteration<br>(32 bits accuracy)     |
| *        | R1 = 1/SQR             | I(v), Return                | t | co caller                                         |

.end

\*

Of course, the square root is found by a simple multiplication: sqrt(v) = vx[n]where x[n] is the estimate of 1/sqrt(v) as determined by the Newton-Raphson algorithm or some other algorithms.

# 12.3.7 Extended-Precision Arithmetic

The TMS320C40 offers 32 bits of precision for integer arithmetic, and 24 bits of precision in the mantissa for floating-point arithmetic. For higher precision in floating-point operations, the twelve extended-precision registers R0 to R11 contain eight more bits of accuracy. Since no comparable extension is available for fixed-point arithmetic, this section discusses how fixed-point double precision can be achieved by using the capabilities of the processor. The technique consists of performing the arithmetic by parts and is similar to the way in which longhand arithmetic is done.

In the instruction set, operations ADDC (add with carry) and SUBB (subtract with borrow) use the status carry bit for extended-precision arithmetic. The carry bit is affected by the arithmetic operations of the ALU and by the rotate and shift instructions. It can also be manipulated directly by setting the status register to certain values. For proper operation, the overflow mode bit should be reset (OVM = 0) so that the accumulator results will not be loaded with the saturation values. Example 12–23 and Example 12–24 show 64-bit addition and 64-bit subtraction. The first operand is stored in the registers R0 (low word) and R1 (high word). The second operand is stored in R2 and R3, respectively. The result is stored in R0 and R1.



\* \* TITLE 64-BIT ADDITION \* \* TWO 64-BIT NUMBERS ARE ADDED TO EACH OTHER PRODUCING \* \* A 64-BIT RESULT. THE NUMBERS X (R1,R0) AND Y (R3,R2) \* \* ADDED, RESULTING IN W (R1,R0). \* \* R1 R0 \* + R3 R2 \* \* R1 R0 \* R2,R0 ADDI ADDC R3,R1

#### Example 12–24. 64-Bit Subtraction

|     | When two 00 bit mumbers are multiplied a 04 bit product results |
|-----|-----------------------------------------------------------------|
|     | SUBI R2,R0<br>SUBB R3,R1                                        |
| *   |                                                                 |
| *   | R1 R0                                                           |
|     |                                                                 |
| *   | – R3 R2                                                         |
| *   |                                                                 |
| *   | R1 R0                                                           |
| *   |                                                                 |
| *   | Y (R3,R2) ARE SUBTRACTED, RESULTING IN W (R1,R0).               |
| *   | PRODUCING A 64-BIT RESULT. THE NUMBERS X (R1,R0) AND            |
| *   | TWO 64-BIT NUMBERS ARE SUBTRACTED FROM EACH OTHER               |
| *   |                                                                 |
| *   | TITLE 64-BIT SUBTRACTION                                        |
| *   |                                                                 |
| ملد |                                                                 |

When two 32-bit numbers are multiplied, a 64-bit product results. To do this, 'C40 provides a 32 x 32-bit multiplier and two special instructions, MPYSHI (multiply signed integer and produce 32 MSBs) and MPYUHI (multiply unsigned integer and produce 32 MSBs). Example 12-25 shows the implementation of a 32-bit by 32-bit multiplication.

Example 12–25. 32-Bit by 32-Bit Multiplication

\* \* TITLE 32 × 32-BIT MULTIPLICATION \* \* TWO 32-BIT NUMBERS ARE MULTIPLIED, PRODUCING A 64-BIT RESULT. \* THE TWO NUMBERS X (RO) AND Y (R1) ARE MULTIPLIED, RESULTING \* IN W (R3,R2). \* \* R0 \* × R1 \* \* R3 R2 \* R0,R1,R2 MPYI3 MPYSHI3 R0,R1,R3

## 12.3.8 Floating-Point Format Conversion: IEEE to/from TMS320C40

In fixed-point arithmetic, the binary point that separates the integer from the fractional part of the number is fixed at a certain location. For example, if a 32-bit number has the binary point after the most significant bit (which is also the sign bit), only fractional numbers (numbers with absolute values less than 1), can be represented. In other words, there is a number with 31 fractional bits called a Q31. All operations assume that the binary point is fixed at this location. The fixed-point system, although simple to implement in

hardware, imposes limitations in the dynamic range of the represented number. This causes scaling problems in many applications. You can avoid this difficulty by using floating-point numbers.

A floating-point number consists of a mantissa m multiplied by base b raised to an exponent *e*:

m \* be

In current hardware implementations, the mantissa is typically a normalized number with an absolute value between 1 and 2, and the base is b = 2. Although the mantissa is represented as a fixed-point number, the actual value of the overall number floats the binary point because of the multiplication by  $b^e$ . The exponent *e* is an integer whose value determines the position of the binary point in the number. IEEE has established a standard format for the representation of floating-point numbers.

To achieve higher efficiency in the hardware implementation, the 'C40 uses a floating-point format that differs from the IEEE standard. However, 'C40 has two single-cycle instructions, TOIEEE and FRIEEE, for the format conversion. These two instructions can also be used with the STF instruction, which allows the data format to be converted within memory to memory transfer. This subsection describes briefly the two formats and presents an example program to convert between them.

## TMS320C40 floating-point format:

| 8 bits | 1 | 23 bits |
|--------|---|---------|
| е      | s | f       |

In a 32-bit word representing a floating-point number, the first 8 bits correspond to the exponent expressed in twos-complement format. One bit is for sign, and 23 bits are for the mantissa. The mantissa is expressed in twoscomplement form with the binary point after the most significant nonsign bit. Since this bit is the complement of the sign bit s, it is suppressed. In other words, the mantissa actually has 24 bits. One special case occurs when e = -128. In this case, the number is interpreted as zero, independently of the values of s and f (which are by default set to zero). To summarize, the values of the represented numbers in the 'C40 floating-point format are as follows:

 $2^{e^*}$  (01.f) if s = 0 $2^{e^*}$  (10.f) if s = 10 if e = -128

#### IEEE floating-point format:

| 1 | 8 bits | 23 bits |
|---|--------|---------|
| s | e      | f       |

The IEEE floating-point format uses sign-magnitude notation for the mantissa, and offset by 127 for the exponent. In a 32-bit word representing a floating-point number, the first bit is the sign bit. The next 8 bits correspond to the exponent, expressed in an offset-by-127 format (the actual exponent is e-127). The following 23 bits represent the absolute value of the mantissa with the most significant 1 implied. The binary point is after this most significant 1. In other words, the mantissa actually has 24 bits. There are several special cases, summarized below.

These are values of the represented numbers in the IEEE floating-point format:

| (- | -1) | s | * | 2 | <b>e</b> | 127 | <b>'</b> * | (0 | 1 | .f) | ) |  |
|----|-----|---|---|---|----------|-----|------------|----|---|-----|---|--|
|    |     |   |   |   |          |     |            |    |   |     |   |  |

Special cases:

| (–1) <sup><i>s</i> * 2<sup>–126</sup> * (0.f)<br/>(–1)<sup><i>s</i> * infinity</sup></sup> | if $e = 0$ and $f = 0$ (zero)<br>if $e = 0$ and $f <> 0$ (denormalized)<br>if $e = 255$ and $f = 0$ (infinity) |
|--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| NaN (not a number)                                                                         | if <i>e</i> = 255 and f <> 0                                                                                   |

if 0 < e < 255

Based on these definitions of the formats, 'C40 has developed the hardware to do the conversion. It assumes that the source data for the IEEE format is in memory only and that for the 'C40 floating-point format, the source data is in either memory or an extended-precision register. The destination for both conversions must be in an extended-precision register. In the case of block memory transfer, the no penalty data format conversion can be achieved by parallel instruction with STF. Example 12–26 and Example 12–27 show the data format conversion within the data transformation between communication port and internal RAM.

| -           |                          |                                                    |                                                                                                                                                              |         |
|-------------|--------------------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| *<br>*<br>* | TITLE IE<br>TRANSFEF     |                                                    | ) CONVERSION WITHIN BLOCK MEMORY                                                                                                                             |         |
| * * * * * * | ARE FULI<br>COMMUNIC     | OF IEEE FORMA<br>CATION PORT 0 T<br>RE CONVERTED F | TE INPUT FIFO OF COMMUNICATION PORT 0<br>DATA. EIGHT DATA ARE TRANSFERRED FRO<br>INTERNAL RAM BLOCK 0 AND THE DATA<br>ROM IEEE FORMAT TO TMS320C40 FLOATING- | · · · · |
| 'n          | •                        |                                                    |                                                                                                                                                              |         |
|             | •                        |                                                    |                                                                                                                                                              |         |
|             | LDI                      | @CP0_IN, AR0                                       | ; Load comm. port 0 input Fifo<br>; address                                                                                                                  |         |
|             | LDI<br>FRIEEE            | @RAMO,AR1<br>*ARO,RO                               | ; Load internal RAM block 0 address<br>; Convert first data                                                                                                  |         |
|             | RPTS<br>FRIEEE<br>   STF | 6<br>*AR0,R0<br>R0,*AR1++(1)                       | ; Convert next data<br>; Store previous data                                                                                                                 |         |
|             | STF<br>•                 | R0,*AR1++(1)                                       | ; Store last data                                                                                                                                            |         |
|             |                          |                                                    |                                                                                                                                                              |         |

Example 12–26. IEEE to TMS320C40 Conversion Within Block Memory Transfer

Example 12–27. TMS320C40 to IEEE Conversion Within Block Memory Transfer

•

\* TITLE TMS320C40 TO IEEE CONVERSION WITHIN BLOCK MEMORY \* TRANSFER \* \* PROGRAM ASSUMES THAT THE OUTPUT FIFO OF COMMUNICATION PORT 0 \* IS EMPTY. EIGHT DATA ARE TRANSFERRED FROM INTERNAL RAM BLOCK 0 \* TO COMMUNICATION PORT 0 AND THE DATA FORMAT ARE CONVERTED FROM \* TMS320C40 FLOATING-POINT FORMAT TO IEEE FORMAT. \* • @CP0\_OUT,AR0 ; Load comm. port 0 output Fifo address @RAM0,AR1 ; Load internal RAM block 0 address LDI LDI \*AR1++(1),R0 ; Convert first data TOIEEE RPTS 6 TDIEEE \*AR1++(1),R0 ; Convert next data R0,\*AR0 ; Store previous data 11 STF STFR0, \*ARO ; Store last data

# **12.4 Application-Oriented Operations**

Certain features of the 'C40 architecture and instruction set facilitate the solution of numerically intensive problems. This section presents examples of applications that use these features, such as companding, filtering, matrix arithmetic, and fast Fourier transforms (FFT).

## 12.4.1 Companding

In the area of telecommunications, one of the primary concerns is to conserve the channel bandwidth and, at the same time, to preserve high speech quality. This is achieved by quantizing the speech samples logarithmically. It has been demonstrated that an 8-bit logarithmic quantizer produces speech quality equivalent to a 13-bit uniform quantizer. The logarithmic quantization is achieved by companding (COMpress/exPANDing). Two international standards have been established for companding: the µ-law (used in the United States and Japan), and the A-law (used in Europe). Detailed descriptions of  $\mu$ -law and A-law companding are presented in an application report on companding routines included in the book Digital Signal Processing Applications with the TMS320 Family (literature number SPRA012A).

During transmission, logarithmically compressed data in sign-magnitude form are transmitted along the communications channel. If any processing is necessary, these data should be expanded to a 14-bit (for  $\mu$ -law) or 13-bit (for A-law) linear format. This operation occurs when data is received at the digital signal processor. After processing, and in order to continue transmission, the result is compressed back to 8-bit format and transmitted through the channel.

Example 12–28 and Example 12–29 show  $\mu$ -law compression and expansion (i.e., linear to  $\mu$ -law and  $\mu$ -law to linear conversion), while Example 12–30 and Example 12–31 show A-law compression and expansion. For expansion, using a look-up table is an alternative approach. It trades memory space for speed of execution. Since the compressed data is 8 bits long, a table with 256 entries can be constructed to contain the expanded data. If the compressed data is stored in the register AR0, the following two instructions will put the expanded data in register R0:

ADDI @TABL,ARO ; @TABL = BASE ADDRESS OF TABLE LDI \*ARO,RO ; PUT EXPANDED NUMBER IN RO

The same look-up table approach could be used for compression, but the required table length would then be 16,384 words for  $\mu$ -law or 8,192 words for A-law. If this memory size is not acceptable, the subroutines presented in Example 12–28 or Example 12–30 should be used.

Example 12–28. µ-Law Compression \* \* TITLE  $\mu$ -LAW COMPRESSION \* \* SUBROUTINE MUCMPR \* \* TYPICAL CALLING SEQUENCE: \* MUCMPR LAJU \* LDI v, R0 \* NOP <---can be other non-pipeline-break \* NOP <---instructions \* \* **ARGUMENT ASSIGNMENTS:** \* \* ARGUMENT | FUNCTION \* \* v = NUMBER TO BE CONVERTEDR0 \* \* REGISTERS USED AS INPUT: RO \* REGISTERS MODIFIED: R0, R1 \* REGISTER CONTAINING RESULT: RO \* \* \* CYCLES: 15 WORDS: 15 \* \* .global MUCMPR \* MUCMPR LSH3 -6,R0,R1 ; Save sign of number ABSI R0,R0 ; If R0>0x1FDE, CMPI 1FDEH,RO ; saturate the result LDIGT 1FDEH,RO ADDI 33,R0 Add bias ; FLOAT Normalize: (seg+5) OWXYZx...x R0 ; MPYF 0.03125,R0 ; Adjust segment number by 2\*\*(-5) LSH 1,R0 ; (seg)WXYZx...x PUSHF R0 POP R0 Treat number as integer ; ; Right-justify LSH -20,R0 BUD R11 Delayed return ; AND 080H,R1 ; Set sign bit ADDI R1,R0 ; R0 = compressed number NOT R0 ; Reverse all bits for transmission

| Example 1   | <i>12–29</i> . μ <i>-La</i> | w Expansion       |       |                                             |
|-------------|-----------------------------|-------------------|-------|---------------------------------------------|
| *           |                             |                   |       |                                             |
| *TITLE<br>* | 'μ-law exi                  | PANSION'          |       |                                             |
| *           | SUBROUT                     | INE MUXPND        |       |                                             |
| *           | TYPICAL                     | CALLING SEQUE     | NCE : |                                             |
| *           | LAJU                        | MUXPND            |       |                                             |
| *           | LDI                         | v, R0             |       |                                             |
| *           | NOP                         |                   |       | er non-pipeline-break                       |
| *           | NOP                         | < instru          | ctic  | ons                                         |
| ~<br>*<br>* | ARGUMEN                     | F ASSIGNMENTS:    |       |                                             |
| *           | ARGUN                       | MENT   FUNCTION   | I<br> |                                             |
| *<br>*      | RO                          | v = NUME          | ER 1  | IO BE CONVERTED                             |
| *           | REGISTE                     | RS USED AS INP    | UT:   | RO                                          |
| *           | REGISTE                     | RS MODIFIED: R    | 0, F  | R1, R2                                      |
| *           | REGISTE                     | R CONTAINING      | RESU  | JLT: RO                                     |
| *           |                             |                   |       |                                             |
| *<br>*      | CYCLES:                     | 14 (WORST CAS     | E)    | WORDS: 14                                   |
| *<br>*      |                             |                   |       |                                             |
| ^           | alohal                      | MUVDND            |       |                                             |
| *           | .grobar                     | MUXPND            |       |                                             |
| MUXPND      | NOT                         | R0,R0             | •     | Complement bits                             |
|             | AND3                        | OFH,R0,R1         |       | Isolate quantization bin                    |
|             | LSH                         | 1,R1              | ,     |                                             |
|             | ADDI                        | 33,R1             | ;     | Add bias to introduce 1xxxx1                |
|             | LSH3                        | -4,R0             | ;     |                                             |
|             | TSTB                        | 08H,R0            | ;     | Test sign                                   |
|             | BZD                         | R11               | ;     | if positive, delayed return                 |
|             | AND                         | 7,R0              |       | Shift and mut month in DO                   |
|             | LSH3<br>SUBI                | R0,R1,R0<br>33,R0 | ;     | Shift and put result in R0<br>Subtract bias |
|             | BUD                         | R11               |       | Delayed return                              |
|             | NEGI                        | RO                | ;     |                                             |
|             | NOP                         |                   | '     | negate if a negative number                 |
|             | NOP                         |                   |       |                                             |

Example 12–30. A-Law Compression

| * * * * * * * * * * * *         | SUBROUTI<br>TYPICAL<br>LAJACMPR<br>LDIV, RO<br>NOP<<br>NOP<<br>ARGUMENT<br>ARGUM | CALLING SEQUEN<br>can be other<br>instructions<br>ASSIGNMENTS:<br>ENT   FUNCTIO | NCE :<br>nor                            | n-pipeline-break                                                                                 |
|---------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------|
| *<br>*<br>*<br>*<br>*<br>*<br>* | RO<br>REGISTER<br>REGISTER                                                       | V = NUM<br>S USED AS INPO<br>S MODIFIED: RO<br>CONTAINING RO                    | IBER<br>UT:<br>D, F                     | RO<br>RO                                                                                         |
| *<br>*<br>*<br>ACMPR            | CYCLES:1<br>.global<br>LSH3                                                      |                                                                                 |                                         | Save sign of number                                                                              |
|                                 | ABSI<br>CMPI<br>BLED<br>CMPI<br>LDIGT<br>LSH                                     | R0,R0<br>1FH,R0<br>END<br>OFFFH,R0<br>OFFFH,R0<br>-1,R0                         | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | If R0<0x20,<br>Do linear coding<br>If R0>0xFFF,<br>saturate the result                           |
|                                 | FLOAT<br>MPYF<br>LSH<br>PUSH<br>POP<br>LSH                                       | R0<br>0.125,R0<br>1,R0<br>FR0<br>R0<br>-20,R0                                   | ;                                       | Adjust segment number by 2**(-3)<br>(seg)WXYZxx<br>Treat number as integer                       |
| END                             | BUD<br>AND<br>ADDI<br>XOR                                                        | R11<br>080H,R1<br>R1,R0<br>0D5H,R0                                              | ;;;;                                    | Delayed return<br>Set sign bit<br>R0 = compressed number<br>Invert even bits for<br>transmission |

| *     |           |               |           |                                       |  |  |  |  |  |
|-------|-----------|---------------|-----------|---------------------------------------|--|--|--|--|--|
| *     | TITLE A-  | LAW EXPANSIO  | N         |                                       |  |  |  |  |  |
| *     |           |               |           |                                       |  |  |  |  |  |
| *     | SUBROUTI  | NE AXPND      |           |                                       |  |  |  |  |  |
| *     |           |               |           |                                       |  |  |  |  |  |
| *     | TYPICAL   | CALLING SEQUE | ENCE:     |                                       |  |  |  |  |  |
| *     | LAJU      | AXPND         |           |                                       |  |  |  |  |  |
| *     | LDI       | <b>v</b> , R0 |           |                                       |  |  |  |  |  |
| *     | NOP       |               | can       | be other non-pipeline-break           |  |  |  |  |  |
| *     | NOP       | <             |           | ructions                              |  |  |  |  |  |
| *     |           |               |           |                                       |  |  |  |  |  |
| *     | ARGUMENT  | ASSIGNMENTS   | •         |                                       |  |  |  |  |  |
| *     |           |               | •         |                                       |  |  |  |  |  |
| *     | ARGUM     | ENTI FUNCTIO  | N         |                                       |  |  |  |  |  |
| *     |           |               |           |                                       |  |  |  |  |  |
| *     | RO        | v = NIIM      | BER       | TO BE CONVERTED                       |  |  |  |  |  |
| *     | 100       | 1 4 - 1011    |           | TO BE CONVERTED                       |  |  |  |  |  |
| *     | DECTOTED  | S USED AS INF | • יחידו כ | P۵                                    |  |  |  |  |  |
| *     |           | S MODIFIED: H |           |                                       |  |  |  |  |  |
| *     |           | CONTAINING H  | •         | •                                     |  |  |  |  |  |
| *     | REGISIER  | CONTAINING I  | VE201     | 1. KU                                 |  |  |  |  |  |
| *     | avat Da . |               |           | WORDS 10                              |  |  |  |  |  |
| *     | CICLES:   | 19 (WORST CAS | 5E)       | WORDS: 16                             |  |  |  |  |  |
|       |           |               |           |                                       |  |  |  |  |  |
| *     |           |               |           |                                       |  |  |  |  |  |
|       | .global   | AXPND         |           |                                       |  |  |  |  |  |
| *     |           |               |           |                                       |  |  |  |  |  |
| AXPND | XOR       | 0D5H,R0,R2    | ;         | Invert even bits                      |  |  |  |  |  |
|       | ASH3      | - 4 02 00     | -         | Stone for bit sign                    |  |  |  |  |  |
|       |           | -4,R2,R0      |           | Store for bit sign                    |  |  |  |  |  |
|       | AND       | 7,R0          | ;         | Isolate segment code                  |  |  |  |  |  |
|       | BZD       | SKIP1         |           | we have a second construction between |  |  |  |  |  |
|       | AND3      | 0FH,R2,R1     | ;         | Isolate quantization bin              |  |  |  |  |  |
|       | LSH       | 1,R1          |           |                                       |  |  |  |  |  |
|       | ADDI      | 1,R1          | •         | Create 0xxxx1                         |  |  |  |  |  |
|       | ADDI      | 32,R1         | ;         | Or 1xxxx1                             |  |  |  |  |  |
|       | SUBI      | 1,R0          |           |                                       |  |  |  |  |  |
| SKIP1 | LSH3      | R0,R1,R0      |           | Shift and put result in R0            |  |  |  |  |  |
|       | TSTB      | 80H,R2        | ;         | Test sign bit                         |  |  |  |  |  |
|       | BZAT      | R11           | ;         | If positive, delayed return and       |  |  |  |  |  |
|       |           |               | ;         | annul next three instructions         |  |  |  |  |  |
|       | NEGI      | R0            | ;         | Negate if a negative number           |  |  |  |  |  |
|       | NOP       |               | •         |                                       |  |  |  |  |  |
|       | NOP       |               |           |                                       |  |  |  |  |  |
|       | BU        | R11           | ;         | Return                                |  |  |  |  |  |
|       |           |               | ,         |                                       |  |  |  |  |  |

# 12.4.2 FIR, IIR, and Adaptive Filters

Digital filters are a common requirement for digital signal processing systems. There are two types of digital filters: finite impulse response (FIR) and infinite impulse response (IIR). Each of these types can have either fixed or adaptable coefficients. In this section, the fixed-coefficient filters are presented first, and then the adaptive filters are discussed.

## 12.4.2.1 FIR Filters

If the FIR filter has an impulse response h[0], h[1],..., h[N-1], and x[n] represents the input of the filter at time n, the output y[n] at time n is given by this equation:

$$y[n] = h[0] x[n] + h[1] x[n-1] + ... + h[N-1] x[n-(N-1)]$$

Two features of the 'C40 that facilitate the implementation of the FIR filters are parallel multiply/add operations and circular addressing. The first one permits the performance of a multiplication and an addition in a single machine cycle, while the second one makes a finite buffer of length N sufficient for the data x.

Figure 12–1 shows the arrangement of the memory locations in order to implement circular addressing, while Example 12–32 presents the 'C40 assembly code for an FIR filter.

Figure 12–1. Data Memory Organization for an FIR Filter



In order to set up circular addressing, initialize the block-size register BK to block length N. Also, the locations for signal x should start from a memory location whose address is a multiple of the smallest power of 2 that is greater than N. For instance, if N = 24, the first address for x should be a multiple of 32 (the lower 5 bits of the beginning address should be zero). To understand this requirement, look at Section 5.3 on page 5-25, *Circular Addressing*.

In Example 12–32, the pointer to the input sequence x is incremented and assumed to be moving from an older input to a newer input. At the end of the subroutine, AR1 will point to the position for the next input sample.

### Example 12–32. FIR Filter

| * |                                                  |
|---|--------------------------------------------------|
| * | TITLE FIR FILTER                                 |
| * |                                                  |
| * |                                                  |
| * | SUBROUTINE FIR                                   |
| * |                                                  |
| * | EQUATION: $y(n) = h(0) * x(n) + h(1) * x(n-1) +$ |
| * | + $h(N-1) * x(n-(N-1))$                          |
| * |                                                  |
| * | TYPICAL CALLING SEQUENCE:                        |
| * |                                                  |
| * | LOAD ARO                                         |
| * | LAJU FIR                                         |
| * | LOAD AR1                                         |
| * | LOAD RC                                          |
| * | LOAD BK                                          |
| * |                                                  |
| * |                                                  |
| * | ARGUMENT ASSIGNMENTS:                            |
| * |                                                  |
| * | ARGUMENT   FUNCTION                              |
| * |                                                  |
| * | AR0   ADDRESS OF h(N-1)                          |
| * | AR1   ADDRESS OF $x(N-1)$                        |
| * | RC   LENGTH OF FILTER $-2$ (N-2)                 |
| * | BK   LENGTH OF FILTER (N)                        |
| * |                                                  |
| * | REGISTERS USED AS INPUT: ARO, AR1, RC, BK        |
| * | REGISTERS MODIFIED: R0, R2, AR0, AR1, RC         |
| * | REGISTER CONTAINING RESULT: R0                   |
| * |                                                  |

```
*
*
         CYCLES: 7 + N
                               WORDS: 9
*
*
         .global
FIR
                   FIR
*
         RPTBD
                   CONV
                                             ; Setup the repeat cycle.
*
                                             ; Initialize RO:
                   *AR0++(1),*AR1++(1)%,R0; h(N-1) *x(n-(N-1)) ->R0
         MPYF3
         LDF
                   0.0,R2
                                           ; Initialize R2.
         NOP
*
*
         FILTER
                   (1 \le i \le N)
CONV
                   *ARO++(1),*AR1++(1)%,RO; h(N-1-i)*x(n-(N-1-i))->RO
         MPYF3
         ADDF3
                   R0,R2,R2
                                            ; Multiply and add operation
11
*
         BUD
                   R11
                                             ; Delayed return
         ADDF
                   R0,R2,R0
                                             ; Add last product
         NOP
         NOP
*
         end
*
          .end
```

### 12.4.2.2 IIR Filters

The transfer function of the IIR filters has both poles and zeros. Its output depends on both the input and the past output. As a rule, the filters need less computation than an FIR with similar frequency response, but the filters have the drawback of being sensitive to coefficient quantization. Most often, the IIR filters are implemented as a cascade of second-order sections, called biquads. Example 12–33 and Example 12–34 show the implementation for one biquad and for any number of biquads, respectively.

y[n] = a1 y[n-1] + a2 y[n-2] + b0 x[n] + b1 x[n-1] + b2 x[n-2]

However, the following two equations are more convenient and have smaller storage requirements:

d[n] = a2 d[n-2] + a1 d[n-1] + x[n] y[n] = b2 d[n-2] + b1 d[n-1] + b0 d[n]

Figure 12–2 shows the memory organization for this two-equation approach, an implementation of a single biquad on the 'C40.

#### Figure 12–2. Data Memory Organization for a Single Biquad



As in the case of FIR filters, the address for the start of the values d must be a multiple of 4; i.e., the last two bits of the beginning address must be zero. The block-size register BK must be initialized to 3.

### Example 12–33. IIR Filter (One Biguad)

| *<br>*      | TITLE IIR filter                                                                                     |
|-------------|------------------------------------------------------------------------------------------------------|
| *<br>*      | SUBROUTINE IIR1                                                                                      |
| *           | IIR1 == IIR FILTER (ONE BIQUAD)                                                                      |
| *<br>*<br>* | EQUATIONS: $d(n) = a2 * d(n-2) + a1 * d(n-1) + x(n)$<br>y(n) = b2 * d(n-2) + b1 * d(n-1) + b0 * d(n) |
| *           | OR $y(n) = a1*y(n-1) + a2*y(n-2) + b0*x(n) + b1*x(n-1) + b2*x(n-2)$                                  |
| *           |                                                                                                      |
| *<br>*      | TYPICAL CALLING SEQUENCE:                                                                            |
| *<br>*<br>* | load R2<br>LAJU IIR1<br>load AR0                                                                     |
| *<br>*<br>* | load AR1<br>load BK                                                                                  |
|             |                                                                                                      |

12-54

| *    |                       |                           |                                               |  |  |  |
|------|-----------------------|---------------------------|-----------------------------------------------|--|--|--|
| *    | ARGUMENT ASSIGNMENTS: |                           |                                               |  |  |  |
| *    | ARGUMENT   FUNCTION   |                           |                                               |  |  |  |
| *    |                       | +                         | *****                                         |  |  |  |
| *    | R2                    | INPUT SAMPLE X(N)         |                                               |  |  |  |
| *    | ARO                   |                           |                                               |  |  |  |
| *    | AR1                   |                           | VALUES $(D(N-2))$                             |  |  |  |
| *    | BK                    | BK = 3                    |                                               |  |  |  |
| *    | DECTONED              | S USED AS INPUT: R2, AR0, | אס וסג                                        |  |  |  |
| *    |                       |                           | R2, AR0, AR1                                  |  |  |  |
| *    |                       | CONTAINING RESULT: R0     | NZ, ANO, ANI                                  |  |  |  |
| *    | 10010101              |                           |                                               |  |  |  |
| *    | CYCLES:               | 8WORDS: 8                 |                                               |  |  |  |
| *    |                       |                           |                                               |  |  |  |
| *    |                       |                           |                                               |  |  |  |
|      | .global               | IIR1                      |                                               |  |  |  |
| *    | _                     |                           |                                               |  |  |  |
| IIR1 | MPYF3                 | *AR0, *AR1, R0            | ; $a2 * d(n-2) \rightarrow R0$                |  |  |  |
| *    | MPYF3                 | *++ARO(1),*AR1(1)%,R1     | ; b2 * d(n-2) -> R1                           |  |  |  |
| ^    | MPYF3                 | *++AR0(1),*AR1,R0         | 1 + d(-1)                                     |  |  |  |
|      | ADDF3                 | R0, R2, R2                | ; a1 * d(n-1) -> R0<br>; a2*d(n-2)+x(n) -> R2 |  |  |  |
| *    | ADDE 5                | R0, R2, R2                | ; $a_2 a_3 (n_2) + x(n_1) - x k_2$            |  |  |  |
|      | MPYF3                 | *++ARO(1),*AR1(1)%,RO     | ; b1 * d(n-1) -> R0                           |  |  |  |
| 11   | ADDF3                 | R0, R2, R2                | ; $a1*d(n-1)+a2*d(n-2)$                       |  |  |  |
| •••  |                       |                           | ; +x(n) -> R2                                 |  |  |  |
| *    |                       |                           |                                               |  |  |  |
|      | BUD                   | R11                       | ; Delayed return                              |  |  |  |
| *    |                       |                           |                                               |  |  |  |
|      | MPYF3                 | *++ARO(1),R2,R2           | ; b0 * d(n) $->$ R2                           |  |  |  |
| 11   | STF                   | R2,*AR1++(1)%             | ; Store d(n) and point to                     |  |  |  |
|      |                       |                           | ; d(n-1)                                      |  |  |  |
| *    |                       |                           |                                               |  |  |  |
|      | ADDF                  | R0, R2                    | ; $b1*d(n-1)+b0*d(n) \rightarrow R2$          |  |  |  |
|      | ADDF                  | R1,R2,R0                  | ; b2*d(n-2)+b1*d(n-1)<br>; +b0*d(n) -> R0     |  |  |  |
| *    |                       |                           | $; + DU^{\alpha}(n) \rightarrow KU$           |  |  |  |
| *    | end                   |                           |                                               |  |  |  |
| *    | Circ                  |                           |                                               |  |  |  |
|      | .end                  |                           |                                               |  |  |  |
|      |                       |                           |                                               |  |  |  |

بد

In the more general case, the IIR filter contains N>1 biquads. The equations for its implementation are given by the following pseudo-C language code:

$$\begin{split} y[0,n] &= x[n] \\ for (i=0; i < N; i++) \\ d[i,n] &= a2[i] d[i,n-2] + a1[i] d[i,n-1] + y[i-1,n] \\ y[i,n] &= b2[i] d[i-2] + b1[i] d[i,n-1] + b0[i] d[i,n] \\ y[n] &= y[N-1,n] \end{split}$$

}

Figure 12–3 shows the corresponding memory organization, while Example 12–34 shows the 'C40 assembly-language code.





The block size register BK should be initialized to 3, and the beginning of each set of d values (i.e., d[i,n], i = 0...N-1) should be at an address that is a multiple of 4 (the last two bits zero), as stated in the case of a single biquad.

Example 12–34. IIR Filters (N > 1 Biguads)

```
*
*
         TITLE IIR FILTERS (N > BIQUADS)
*
*
         SUBROUTINE IIR2
*
*
         EQUATIONS: y(0, n) = x(n)
*
*
         FOR (i = 0; i < N; i++)
*
*
         d(i,n) = a2(i) * d(i,n-2) + a1(i) * d(i,n-1) * y(i-1,n)
         y(i,n) = b2(i) * d(i,n-2) + b1(i) * d(i,n-1) * b0(i) * d(i,n)
*
*
*
         y(n) = y(N-1, n)
*
*
         TYPICAL CALLING SEQUENCE:
*
*
         load
                   R2
         load
                   AR0
*
         load
                   AR1
         load
                   IR0
```

Software Applications

| *<br>*<br>*     | LAJU<br>load<br>load                       | IIR2<br>IR1<br>BK                                                                     |                                                                                                                 |
|-----------------|--------------------------------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| *<br>*          |                                            | RC                                                                                    |                                                                                                                 |
| *<br>*<br>*     | ARGUMENT<br>ARGUMEN                        | ASSIGNMENT:<br>T   FUNCTION                                                           |                                                                                                                 |
| * * * * * * * * | R2<br>ARO<br>AR1<br>BK<br>IR0<br>IR1<br>RC | BK = 3   IR0 = 4   IR1 = 4*N-4                                                        | VALUES $(d(0,n-2))$                                                                                             |
| *<br>*<br>*     | REGISTER                                   | S USED AS INPUT; R2, AR0, A<br>S MODIFIED; R0, R1, R2, AR0<br>S CONTAINING RESULT: R0 |                                                                                                                 |
| *<br>*<br>*     | CYCLES:                                    | 4 + 6N WORDS: 15                                                                      |                                                                                                                 |
| *               | .global                                    | IIR2                                                                                  |                                                                                                                 |
| IIR2            | MPYF3<br>MPYF3                             |                                                                                       | ; a2(0) * d(0,n-2) -> R0<br>; b2(0) * d(0,n-2) -> R1                                                            |
| *               | RPTBD                                      | LOOP                                                                                  | ; Set loop for 1 <= i < n                                                                                       |
| <br>*           | MPYF3<br>ADDF                              | *++ARO(1),*AR1,R0<br>R0,R2,R2                                                         | ; a1(0) * D(0,n-1) -> R0<br>; First sum term<br>; of d(0,n).                                                    |
| 11              | MPYF3<br>ADDF3                             | R0, R2, R2                                                                            | <pre>; Second sum term ; of d(0,n).</pre>                                                                       |
| <br>*           | MPYF3<br>STF                               | *++ARO(1),R2,R2<br>R2,*AR1-(1)%                                                       | <pre>; b0(0) * d(0,n) -&gt; R2 ; Store d(0,n) ; Point to ; d(0,n-2)</pre>                                       |
| *               | LOOP STA                                   | RTS HERE                                                                              |                                                                                                                 |
| <br>*<br>*      | MPYF3<br>ADDF3                             | *++AR0(1),*++AR1(IR0),R0<br>R0,R2,R2                                                  | <pre>; a2(i) * d(i,n-2) -&gt; R0 ; First sum term ; of y(i-1,n). ; Pipeline hit on previous ; instruction</pre> |
| II -            | MPYF3<br>ADDF3                             | *++AR0(1),*AR1-(1)%,R1<br>R1,R2,R2                                                    | ; b2(i) * D(i,n-2) -> R1<br>; Second sum term<br>; of y(i-1,n).                                                 |
|                 | MPYF3                                      | *++AR0(1),*AR1,R0                                                                     | ; al(i) * d(i,n-1) -> R0                                                                                        |

| *           | ADDF3          | R0,R2,R2                           | ;<br>;      | First sum term<br>of d(i,n).                              |
|-------------|----------------|------------------------------------|-------------|-----------------------------------------------------------|
| <br>*       | MPYF3<br>ADDF3 | *++AR0(1),*AR1-(1)%,R0<br>R0,R2,R2 | ;;;;;       | bl(i) * d(i,n-1) -> R0<br>Secondsumterm<br>of d(i,n).     |
| LOOP<br>    | MPYF3<br>STF   | *++ARO(1),R2,R2<br>R2, *AR1-(1)%   | ;;;;        | b0(i) * d(i,n) -> R2<br>Store d(i,n)<br>point to d(i,n-2) |
| *<br>*<br>* | FINAL SU       | MMATION                            |             |                                                           |
| *           | BRD            | R11                                | į           | Delayed return                                            |
| ~           | ADDF           | R0, R2                             | ;           | First sum term ofy(n-1,n)                                 |
|             | ADDF3          | R1,R2,R0                           | ;           | Second sum term of y(n-1,n                                |
|             | LDI<br>LDI     | *AR1(IR1),R1<br>*AR1(1)%,R2        | ,<br>;<br>; | Return to first biquad<br>Point to d(0,n-1)               |
| *<br>*<br>* | end            |                                    |             |                                                           |

.end

#### 12.4.2.3 Adaptive Filters (LMS Algorithm)

In some applications in digital signal processing, a filter must be adapted over time to keep track of changing conditions. The book *Theory and Design of Adaptive Filters* by Treichler, Johnson, and Larimore (Wiley-Interscience, 1987) presents the theory of adaptive filters. Although in theory, both FIR and IIR structures can be used as adaptive filters, the stability problems and the local optimum points that the IIR filters exhibit make them less attractive for such an application. Hence, until further research makes IIR filters a better choice, only the FIR filters are used in adaptive algorithms of practical applications.

In an adaptive FIR filter, the filtering equation takes this form:

y[n] = h[n,0] x[n] + h[n,1]x[n-1] + ... + h[n,N-1]x[n-(N-1)]

The filter coefficients are time-dependent. In a least-mean-squares (LMS) algorithm, the coefficients are updated by an equation in this form:

$$h[n+1,i] = h[n,1] + b \times [n-i], i = 0, 1, ..., N-1$$

*b* is a constant for the computation. The updating of the filter coefficients can be interleaved with the computation of the filter output so that it takes 3 cycles per filter tap to do both. The updated coefficients are written over the old filter coefficients. Example 12–35 shows the implementation of an adaptive FIR filter on the 'C40. The memory organization and the positioning of the data in memory should follow the same rules as the above FIR filter with fixed coefficients.

Example 12–35. Adaptive FIR Filter (LMS Algorithm) \* TITLE ADAPTIVE FIR FILTER (LMS ALGORITHM) \* \* SUBROUTINE LMS \* \* LMS == LMS ADAPTIVE FILTER \* \* EOUATIONS:  $y(n) = h(n, 0) * x(n) + h(n, 1) * x(n-1) + \dots$ \* \* FOR \* + tmuerr \* x(n-i)\* \*

+ h(n, N-1) \* x(n-(N-1))(i = 0; i < N; i++) h(n+1,i) = h(n,i)TYPICAL CALLING SEQUENCE: \* \* load R4 \* load AR0 \* LAJU LMS \* load AR1 \* load RC \* load BK \* \* \* **ARGUMENT ASSIGNMENTS:** \* ARGUMENT | FUNCTION \* ------R4 \* SCALE FACTOR (2 \* mu \* err) \* AR0 | ADDRESS OF h(n, N-1) \* AR1 | ADDRESS OF x(n-(N-1))\* LENGTH OF FILTER -2 (N-2) RC 1 \* BK | LENGTH OF FILTER (N) \* \* REGISTERS USED AS INPUT: R4, AR0, AR1, RC, BK \* REGISTERS MODIFIED: R0, R1, R2, AR0, AR1, RC \* REGISTER CONTAINING RESULT: RO \* \* PROGRAM SIZE: 12 words \*

\* EXECUTION CYCLES: 6 + 3N

| *              | SETUP (i                           | = 0)                                               |        |                                                                                                   |
|----------------|------------------------------------|----------------------------------------------------|--------|---------------------------------------------------------------------------------------------------|
| LMS<br>*       | .global<br>RPTBD<br>MPYF3<br>SUBF3 | LMS<br>LOOP<br>*AR0,*AR1,R0<br>R2, R2, R2          | ; '    | Setup the delayed repeat block.<br>Initialize R0:<br>h(n,N-1) * x(n-(N-1)) -> R0<br>Initialize R2 |
| *              | MPYF3<br>ADDF3                     | *AR1++(1)%,R4,R1<br>*AR0++(1),R1,R1                | 7<br>7 | Initialize R1:<br>x(n-(N-1)) * tmuerr -> R1<br>h(n,N-1) + x(n-(N-1)) *<br>tmuerr -> R1            |
| * *            | FILTER AN<br>MPYF3<br>ADDF3        | ID UPDATE (1 <= I <<br>*AR0(1),*AR1,R0<br>R0,R2,R2 | ;<br>; | Filter:<br>$h(n, N-1-i) * x(n-(N-1-i)) \rightarrow R0$<br>Multiply and add operation.             |
| *<br>*<br>     | MPYF3<br>STF                       | *AR1++(1)%,R4,R1<br>R1,*AR0++(1)                   | ;      | UPDATE:<br>x(n,N-(N-1-i)) * tmuerr -> R1<br>R1 -> h(n+1,N-1-(i-1))                                |
| *<br>LOOP<br>* | ADDF3                              | *AR0++(1),R1,R1                                    |        | h(n,N-1-i) + x(n-(N-1-i))<br>*tmuerr -> R1                                                        |
| *              | BUD                                | R11                                                | į      | Delayed return                                                                                    |
|                | ADDF3<br>STF                       | R0,R2,R0<br>R1,*-AR0(1)                            | ;      | Add last product.<br>h(n,0) + x(n* tmuerr -><br>h(n+1 ,0)                                         |
| *              | NOP                                |                                                    | •      |                                                                                                   |
| *              | end                                |                                                    |        |                                                                                                   |
|                | .end                               |                                                    |        |                                                                                                   |
|                |                                    |                                                    |        |                                                                                                   |

# 12.4.3 Matrix-Vector Multiplication

In matrix-vector multiplication, a K  $\times$  N matrix of elements m(i,j), having K rows and N columns, is multiplied by an N  $\times$  1 vector to produce a K  $\times$  1 result. The multiplier vector has elements v(j), and the product vector has elements p(i). Each one of the product-vector elements is computed by the following expression:

$$p(i) = m(i,0) v(0) + m(i,1) v(1) + ... + m(i,N-1) v(N-1)$$
  $i = 0,1,...,K-1$ 

This is essentially a dot product, and the matrix-vector multiplication contains, as a special case, the dot product presented in Example 12–2 on page 12-10 and Example 12–3 on page 12-12. In pseudo-C format, the computation of the matrix multiplication is expressed by

Figure 12–4 shows the data memory organization for matrix-vector multiplication, and Example 12–36 shows the 'C40 assembly code to implement it. Note that in Example 12–36, K (number of rows) should be greater than 0, and N (number of columns) should be greater than 1.

## Figure 12–4. Data Memory Organization for Matrix-Vector Multiplication



#### Example 12–36. Matrix Times a Vector Multiplication

\* \* TITLE MATRIX TIMES A VECTOR MULTIPLICATION \* \* SUBROUTINE MAT \* \* MAT == MATRIX TIMES A VECTOR OPERATION \* \* TYPICAL CALLING SEQUENCE: \* \* load AR0 \* load AR1 \* load AR2 \* load AR3 \* load R1 \* MAT CALL \* \* ARGUMENT ASSIGNMENTS: \* \* ARGUMENT | FUNCTION \* \* AR0 | ADDRESS OF M(0,0)\* AR1 | ADDRESS OF V(0) \* AR2 | ADDRESS OF P(0) \* | NUMBER OF ROWS - 1 (K-1) AR3 \* R1 NUMBER OF COLUMNS -2 (N-2) \* \* REGISTERS USED AS INPUT: ARO, AR1, AR2, AR3, R1 \* REGISTERS MODIFIED: R0, R2, AR0, AR1, AR2, AR3, IR0, RC \* \* \* PROGRAM SIZE: 11 \* \* EXECUTION CYCLES: 5 + 7K + KN = 5 + ((N-1) + 8) \* K\* \* .global MAT \* \* SETUP \* MAT ADDI3 R1,2,IRO ; IRO = N \* \* FOR (i = 0; i < K; i++) LOOP OVER THE ROWS. \* RPTBD ROWS ; Setup mulitply a row by a Dot ; column. LDI R1,RC ; Set loop counter LDF 0.0,R2 ; Initialize R2 \*AR0++(1),\*AR1++(1),R0 ; m(i,0) \* v(0) -> R0 MPYF3

\*

```
*
         FOR (j = 1; j < N; j++) DO DOT PRODUCT OVER COLUMNS
*
DOT
         MPYF3
                     *AR0++(1),*AR1++(1),R0 ;
                                                 m(i,j) * v(j) -> R0
                                                 m(i,j-1) *v(j-1) +
          ADDF3
                    R0, R2, R2
;
                                                 R2 -> R2.
                                              ;
*
         DBD
                    AR3, ROWS
                                              ;
                                                 counts the number of rows
                                              ;
                                                 left.
*
*
         ADDF
                    R0, R2
                                                 last accumulate.
                                              ;
         STF
                    R2, *AR2++(1)
                                              ; result \rightarrow p(i)
         NOP
                    *--AR1(IR0)
                                                 set AR1 to point to v(0).
                                              ;
          !!! DELAYED BRANCH HAPPENS HERE !!!
*
*
*
         · RETURN SEQUENCE
*
         RETS
                                                return
                                              ;
*
*
          end
*
          .end
```

### **12.4.4 Fast Fourier Transforms (FFT)**

Fourier transforms are an important tool often used in digital signal processing systems. The purpose of the transform is to convert information from the time domain to the frequency domain. The inverse Fourier transform converts information back to the time domain from the frequency domain. Implementation of Fourier transforms that are computationally efficient are known as fast Fourier transforms (FFTs). The theory of FFTs can be found in books such as *DFT/FFT and Convolution Algorithms* by C.S. Burrus and T.W. Parks (John Wiley, 1985), and in the book *Digital Signal Processing Applications with the TMS320 Family*.

Certain 'C40 features that increase efficient implementation of numerically intensive algorithms are particularly well-suited for FFTs. The high speed of the device (40-ns cycle time) makes the implementation of realtime algorithms easier, while the floating-point capability eliminates the problems associated with dynamic range. The powerful indexing scheme in indirect addressing facilitates the access of FFT butterfly legs that have different spans. The repeat block implemented by the RPTB or RPTBD instruction reduces the looping overhead in algorithms heavily dependent on loops (such as the FFTs). This construct gives the efficiency of in-line coding but has the form of a loop. Since the output of the FFT is in scrambled (bit-reversed) order when the input is in regular order, it must be restored to the proper order. This rearrangement does not require extra cycles. The device has a special form of indirect addressing (bit-reversed addressing mode) that can be used when the FFT output is needed. The 'C40 can implement this mode on either the CPU or DMA. This mode permits accessing the FFT output in the proper order. If the DMA transfer with bit-reversed addressing mode is used, there is no overhead for data input and output.

There are several types of FFTs:

- Radix-2 and radix-4 algorithms depending on the size of the FFT butterfly
- Decimation in time or frequency (DIT or DIF)
- Complex or real FFTs
- FFTs of different lengths, etc.

The examples in this section of FFT implementation are based on programs contained in the application report, *"An Implementation of FFT, DCT, and Other Transforms on the TMS320C30"*, by Panos Papamichalis in the *Digital Signal Processing Applications with the TMS320 Family*, volume III.

Example 12–37 and Example 12–38 show the implementation of a complex radix-2, DIF FFT on the 'C40. Example 12–37 contains the generic code of the FFT that can be used with any length number. However, for the complete implementation of an FFT, a table of twiddle factors (sines/cosines) is needed, and this table depends on the size of the transform. To retain the generic form of Example 12–37, the table with the twiddle factors (containing 1-1/4 complete cycles of a sine) is presented separately in Example 12–38 for the case of a 64-point FFT. A full cycle of a sine should have a number of points equal to the FFT size. In Example 12–38, the FFT length N and M, which is equal to the logarithm of N to base equal to the radix, are defined. M is the number of stages of the FFT. For a 64-point FFT, M = 6 when using a radix-2 algorithm, or M = 3 when using a radix-4 algorithm. If the table with the twiddle factors and the FFT code are kept in separate files, they should be connected at link time.

Example 12–37. Complex, Radix-2, DIF FFT

\* \* TITLE COMPLEX, RADIX-2, DIF FFT \* \* GENERIC PROGRAM FOR A LOOPED-CODE RADIX-2 FFT COMPUTATION \* IN 320C40 \* \* THE PROGRAM IS DERIVED FROM THE BURRUS AND PARKS \* BOOK, "DFT/FFT AND CONVOLUTION ALGORITHMS", PAGE 111. \* THE (COMPLEX) DATA RESIDE IN INTERNAL MEMORY. \* THE COMPUTATION IS DONE IN-PLACE, BUT THE \* RESULT IS MOVED TO ANOTHER MEMORY SECTION TO \* DEMONSTRATE THE BIT-REVERSED ADDRESSING. \* \* THE TWIDDLE FACTORS ARE SUPPLIED IN A TABLE PUT IN A \* .DATA SECTION. THIS DATA IS INCLUDED IN A SEPARATE \* FILE TO PRESERVE THE GENERIC NATURE OF THE PROGRAM. \* FOR THE SAME PURPOSE, THE SIZE OF THE FFT N AND \* LOG2(N) ARE DEFINED IN A .GLOBL DIRECTIVE AND \* SPECIFIED DURING LINKING. \* \* .globl FFT ; Entry point for execution .globl Ν ; FFT size .globl ; LOG2(N) М .globl ; Address of sine table SINE INP "IN",1024 ; Memory with input data .usect ; Memory with output data .BSS OUTP,1024 .text \* INITIALIZE FFTSIZ .word Ν LOGFFT .word Μ SINTAB .word SINE INPUT .word INP OUTPUT .word OUTP FFT: LDP FFTSIZ ; Command to load data page pointer ; R7=N2 LDI @FFTSIZ,R7 LSH3 -2,R7,IR1 ; IR1=N/4, pointer for SIN/COS table LDI @LOGFFT,R9 ; R9 holds the remain stage number LSH3 1,R7,IR0 ; IR0=2\*N1 (because of real/imag) LDI 1,R8 ; Initialize repeat counter of first ; 100p LDI 1,AR5 ; Initialize IE index (AR5=IE) @INPUT,R10 ; R10 points to X(I) LDI

| *      | OUTER LOC | )P                 |   |                                         |
|--------|-----------|--------------------|---|-----------------------------------------|
| LOOP:  | RPTBD     | BLK1               | ; | Setup for first loop                    |
|        | LDI       | R10,AR0            | ; | ARO points to X(I)                      |
|        | ADDI      | R7,AR0,AR2         | ; | AR2 points to X(L)                      |
|        | SUBI3     | 1,R8,RC            | ; | RC shouldbeonelessthan                  |
|        |           |                    |   | desired #                               |
| *      | FIRST LOC | )P                 |   |                                         |
|        | ADDF      | *AR0,*AR2,R0       | ; | R0 = X(I) + X(L)                        |
|        | SUBF      |                    |   | R1 = X(I) - X(L)                        |
|        | ADDF      | *AR2,*AR0,R2       |   | R2 = Y(I) + Y(L)                        |
|        | SUBF      | *AR2, *AR0, R3     |   | R3 = Y(I) - Y(L)                        |
|        | STF       | R2,*AR0            |   | Y(I) = R2 and                           |
| 11     | STF       | R3, *AR2           | 1 | Y(L) = R3                               |
| BLK1   | STF       | R0,*AR0++(IR0)     |   | X(I) = R0 and                           |
|        | STF       | R1,*AR2++(IR0)     |   | X(L) = R1 and $AR0, 2 = AR0, 2 + 2*n$   |
| *      |           | IS THE LAST STAGE, |   |                                         |
|        | SUBI      | 1,R9               | T | OU ARE DONE                             |
|        | BZD       | END                |   |                                         |
| *      | MAIN INNE |                    |   |                                         |
|        | LDI       | 2, AR1             |   | Init loop counter for inner loop        |
|        | LDI       | @SINTAB, AR4       |   | Initialize IA index (AR4=IA)            |
|        | ADDI      | AR5, AR4           |   | IA=IA+IE; AR4 points to cosine          |
|        | ADDI      | R10, AR1, ARO      |   |                                         |
|        | ADDI      |                    |   | (X(I),Y(I)) pointer                     |
| INLOP: | RPTBD     | 2,AR1<br>BLK2      |   | Increase inner loop counter             |
| INLOP: |           |                    |   | Setup for second loop                   |
|        | ADDI      | R7,AR0,AR2         |   | (X(L),Y(L)) pointer                     |
|        | SUBI      | 1,R8,RC            | - | RC should be one less than              |
|        | TDD       | +304 56            |   | desired #                               |
| *      | LDF       | *AR4,R6            | ; | R6=SIN                                  |
| *      | SECOND LC |                    |   |                                         |
|        | SUBF      | *AR2,*AR0,R2       | ; | R2=X(I)-X(L)                            |
| *      | SUBF      | *+AR2,*+AR0,R1     |   |                                         |
| *      |           |                    |   | R1 = Y(I) - Y(L)                        |
|        | MPYF      | R2,R6,R0           | - | R0 = R2 * SIN and                       |
| 11     | ADDF      | *+AR2,*+AR0,R3     |   | R3 = Y(I) + Y(L)                        |
|        | MPYF      |                    |   | $R3 = R1 * COS and \dots$               |
|        | STF       | R3,*+AR0           |   | Y(I) = Y(I) + Y(L)                      |
|        | SUBF      | R0,R3,R4           |   | R4 = R1*COS - R2*SIN                    |
|        | MPYF      | R1,R6,R0           | ; | $R0 = R1 \times SIN$ and                |
| 1.1    | ADDF      | *AR2,*AR0,R3       | ; | R3 = X(I) + X(L)                        |
|        | MPYF      | R2,*+AR4(IR1),R3   | ; | $R3 = R2 * COS and \dots$               |
| 11     | STF       | R3,*AR0++(IR0)     |   |                                         |
| *      |           |                    |   |                                         |
| *      |           |                    | ; | X(I) = X(I) + X(L) and $AR0=AR0 + 2*N1$ |
|        | ADDF      | R0,R3,R5           |   | R5 = R2*COS + R1*SIN                    |
| BLK2   | STF       | R5,*AR2++(IR0)     | ; | X(L) = R2*COS + R1*SIN, incr AR2        |
|        |           |                    | ; | and                                     |
| 11     | STF       | R4,*+AR2           | ; | $Y(L) = R1 \times COS - R2 \times SIN$  |
|        |           |                    |   |                                         |

|                                   | CMPI<br>BNEAF<br>ADDI                                                                             | R7,AR1<br>INLOP<br>AR5,AR4                                                                                                                                                                    | ; Loop back to the inner loop<br>; IA = IA + IE; ARgointtscosine                                    |
|-----------------------------------|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
|                                   | ADDI<br>ADDI                                                                                      | R10,AR1,AR0<br>2,AR1                                                                                                                                                                          | ; (X(I),Y(I)) pointer<br>; Increase inner loop counter                                              |
|                                   | LSH                                                                                               | 1,R8                                                                                                                                                                                          | ; Increment loop counter for ; next time                                                            |
|                                   | BRD<br>LSH<br>LDI<br>LSH                                                                          | LOOP<br>1,AR5<br>R7,IR0<br>-1,R7                                                                                                                                                              | <pre>; Next time<br/>; Next FFT stage (delayed)<br/>; IE = 2*IE<br/>; N1 = N2<br/>; N2 = N2/2</pre> |
| *<br>END:<br>*<br>  <br>BITRV<br> | STORE RES<br>LDI<br>SUBI3<br>LDI<br>RPTBD<br>LDI<br>LDI<br>LDF<br>BIT<br>LDF<br>STF<br>LDF<br>STF | ULT OUT USING BIT<br>@FFTSIZ,IR0<br>2,IR0,RC<br>2,IR1<br>BITRV<br>@INPUT,AR0<br>@OUTPUT,AR1<br>*+AR0(1),R0<br>REVERSE LOOP<br>*AR0++(IR0)B,R1<br>R0,*+AR1(1)<br>*+AR0(1),R0<br>R1,*AR1++(IR1) | T-REVERSED ADDRESSING<br>; IRO = size of FFT = N<br>; RC = N - 2                                    |
| <br>SELF                          | LDF<br>STF<br>STF<br>BR<br>.end                                                                   | *ARO++(IRO)B,R1<br>RO,*+AR1(1)<br>R1,*AR1++(IR1)<br>SELF                                                                                                                                      | ; Branch to itself at the end                                                                       |

| Example 12  | –38. Table with Twiddle Factors for a 64-Point FFT                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| *<br>*<br>* | TITLE TABLE WITH TWIDDLE FACTORS FOR A 64-POINT FFT                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| *<br>*<br>* | FILE TO BE LINKED WITH THE SOURCE CODE FOR A 64-POINT, RADIX-2 FFT.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|             | .globl SINE<br>.globl N<br>.globl M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| N<br>M      | .set 64<br>.set 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| SINE        | .data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|             | .float0.000000.float0.098017.float0.195090.float0.290285.float0.382683.float0.471397.float0.555570.float0.634393.float0.707107.float0.73010.float0.831470.float0.923880.float0.923880.float0.923880.float0.980785.float0.995185                                                                                                                                                                                                                                                                                    |
| COSINE      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|             | .float 1.000000<br>.float 0.995185<br>.float 0.980785<br>.float 0.923880<br>.float 0.923880<br>.float 0.881921<br>.float 0.831470<br>.float 0.773010<br>.float 0.773010<br>.float 0.707107<br>.float 0.634393<br>.float 0.555570<br>.float 0.471397<br>.float 0.382683<br>.float 0.290285<br>.float 0.098017<br>.float 0.098017<br>.float 0.098017<br>.float -0.098017<br>.float -0.195090<br>.float -0.290285<br>.float -0.290285<br>.float -0.382683<br>.float -0.382683<br>.float -0.382683<br>.float -0.471397 |

| <pre>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float<br/>.float</pre> | $\begin{array}{c} -0.555570\\ -0.634393\\ -0.707107\\ -0.773010\\ -0.831470\\ -0.881921\\ -0.923880\\ -0.956940\\ -0.980785\\ -0.995185\\ -1.000000\\ -0.995185\\ -1.000000\\ -0.995185\\ -0.995185\\ -0.980785\\ -0.980785\\ -0.980785\\ -0.980785\\ -0.980785\\ -0.995185\\ -0.980785\\ -0.995185\\ -0.980785\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.995185\\ -0.9$ |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .float<br>.float<br>.float<br>.float<br>.float<br>.float<br>.float<br>.float<br>.float<br>.float<br>.float<br>.float<br>.float<br>.float<br>.float                                                                                                                                                                                    | 0.000000<br>0.098017<br>0.195090<br>0.290285<br>0.382683<br>0.471397<br>0.555570<br>0.634393<br>0.707107<br>0.773010<br>0.831470<br>0.881921<br>0.923880<br>0.956940<br>0.980785<br>0.995185                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

The radix-2 algorithm has tutorial value because it is relatively easy to understand how the FFT algorithm functions. However, radix-4 implementations can increase the speed of the execution by reducing the overall arithmetic required. Example 12–39 shows the generic implementation of a complex, DIF FFT in radix-4. A companion table, like the one in Example 12–38, should have a value of M equal to the log N, where the base of the logarithm is four.

Example 12–39. Complex, Radix-4, DIF FFT \* \* TITLE COMPLEX, RADIX-4, DIF FFT \* \* GENERIC PROGRAM TO DO A LOOPED-CODE RADIX-4 FFT COMPUTATION IN \* THE TMS320C40. \* \* THE PROGRAM IS DERIVED FROM THE BURRUS AND PARKS BOOK, \* DFT/FFT AND CONVOLUTION ALGORITHMS, P. 117. THE \* (COMPLEX) DATA RESIDE IN INTERNAL MEMORY, AND THE \* COMPUTATION IS DONE IN-PLACE. \* \* THE TWIDDLE FACTORS ARE SUPPLIED IN A TABLE PUT IN A \* .DATA SECTION. THIS DATA IS INCLUDED IN A SEPARATE FILE TO \* PRESERVE THE GENERIC NATURE OF THE PROGRAM. FOR THE SAME \* PURPOSE, THE SIZE OF THE FFT N AND LOG4 (N) ARE DEFINED IN A \* .GLOBL DIRECTIVE AND SPECIFIED DURING LINKING. \* \* IN ORDER TO HAVE THE FINAL RESULT IN BIT-REVERSED ORDER, THE \* TWO MIDDLE BRANCHES OF THE RADIX-4 BUTTERFLY ARE INTERCHANGED \* DURING STORAGE. NOTE THIS DIFFERENCE WHEN COMPARING WITH THE \* PROGRAM IN P. 117 OF THE BURRUS AND PARKS BOOK. \* \* .globl FFT ; Entry point for execution .globl Ν ; FFT size .globl ; LOG4(N) М .globl SINE ; Address of sine table ; Memory with input data "IN",1024 INP .usect OUTP,1024 ; Memory with output data .bss .text INITIALIZE \* FFTSIZ ; FFT size .word Ν LOGFFT .word М ; LOG4 (FFTSIZ) SINTAB SINE .word ; Sine/cosine table base INPUT .word INP ; Area with input data to process OUTPUT OUTP ; Area with output data to process .word FFT: LDP FFT ; Command to load data page pointer LDI @FFTSIZ,BK ; IR0=2\*N1 (because of real/imag) LSH3 1, BK, IRO LSH3 -2, BK, IR1 ; IR1=N/4, pointer for SIN/COS table ; Initialize IE index LDI 1,AR7 ; Initialize repeat counter of first LDI 1,R8 ; loop ADDI 2, IR1, R9 ; R9 = JT = R0/2 + 2LSH. -1,BK ; R7 = N2

| *      | OUTER LOC  | P                 |                                                     |
|--------|------------|-------------------|-----------------------------------------------------|
| LOOP:  | LDI        | @INPUT, ARO       | ; ARO points to X(I)                                |
|        | ADDI       | BK,ARO,AR1        | ; AR1 points to X(I1)                               |
|        | ADDI       | BK,AR1,AR2        | ; AR2 points to X(I2)                               |
|        | RPTBD      | BLK1              | ; Setup loop BLK1                                   |
|        | ADDI       | BK,AR2,AR3        | ; AR3 points to X(I3)                               |
|        | SUBI3      | 1,R8,RC           | ; RC should be one less                             |
|        |            |                   | ; than desired #                                    |
|        | LDF        | *+AR1,R0          | ; $R0 = Y(I1)$                                      |
|        |            |                   |                                                     |
| *      | FIRST LOC  | P: BLK1           |                                                     |
|        | ADDF       | R0,*+AR3,R3       | ; $R3 = Y(I1) + Y(I3)$                              |
|        | ADDF       | *+AR0, *+AR2, R1  | ; $R1 = Y(I) + Y(I2)$                               |
|        | ADDF       | R3, R1, R6        | ; $R6 = R1 + R3$                                    |
|        | SUBF       | *+AR2, *+AR0, R4  | ; $R4 = Y(I) - Y(I2)$                               |
|        | LDF        | *AR2, R5          | ; $R5 = X(I2)$                                      |
| 11     | STF        | R6,*+AR0          | ; $Y(I) = RI + R3$                                  |
|        | SUBF       | R3, R1            | ; $R1 = R1 - R3$                                    |
|        | ADDF       | *AR3,*AR1,R3      | ; $R3 = X(I1) + X(I3)$                              |
|        | ADDF       | R5,*AR0,R1        | ; $R1 = X(I) + X(I2)$                               |
| 11     | STF        | R1,*+AR1          | ; $Y(I1) = R1 - R3$                                 |
| • •    | ADDF       | R3, R1, R6        | ; $R6 = R1 + R3$                                    |
|        | SUBF       | R5,*AR0,R4        | ; $R4 = X(I) - X(I2)$                               |
| 11     | STF        | R6,*AR0++(IR0)    | ; $X(I) = RI + R3$                                  |
|        | SUBF       | R3, R1            | ; $R1 = R1 - R3$                                    |
|        | SUBF       | *AR3, *AR1, R6    | ; $R6 = X(I1) - X(I3)$                              |
|        | SUBF       | R0, *+AR3, R3     | ; -R3 = Y(I1) - Y(I3)                               |
| 11     | STF        | R1,*AR1++(IR0)    | ; $X(I1) = R1-R3$                                   |
|        | SUBF       | R6, R4, R5        | ; $R5 = R4 - R6$                                    |
|        | ADDF       | R6,R4             | $R^{2} = R^{2} + R^{2}$                             |
|        | STF        | R5, *+AR2         | ; $Y(12) = R4 - R6$                                 |
| 11     | STF        | R2,*+AR3          | (12) = R4 + R6                                      |
| 11     | SUBF       | R3, R2, R5        | ; $R5 = R2 - R3$                                    |
|        | ADDF       | R3, R2            | ; $R2 = R2 + R3$                                    |
|        | STF        | R2,*AR3++(IR0)    | $X = R^2 + R^3$ ; $X = R^2 + R^3$ ; $X = R^2 + R^3$ |
| BLK1   | STF        | R5, *AR2++(IR0)   | X(13) = R2 - R3                                     |
|        | LDF        | *+AR1,R0          | ; $R0 = Y(I1)$                                      |
| 11     | гог        | "+ARI, RO         | ; RO = I(II)                                        |
| *      | IF THIS I  | S THE LAST STAGE, | YOU ARE DONE                                        |
|        | CMPI       | IR1,R8            |                                                     |
| BZD    | END        | •                 | •                                                   |
|        |            |                   |                                                     |
| * MAIN | INNER LOOP |                   |                                                     |
|        | LDI        | 1,R10             | ; Init IA1 index                                    |
|        | LDI        | 2,R11             | ; Init loop counter for inner loop                  |
|        | LDI        | R11, AR0          |                                                     |
|        | ADDI       | @INPUT, ARO       | ; (X(I),Y(I)) pointer                               |
|        | ADDI       | 2,R11             | ; Increment inner loop counter                      |
|        |            | _,                | , roop oouncor                                      |

i

| INLOP: | ADDI<br>ADDI<br>CMPI | R10,AR7<br>BK,AR0,AR1<br>R9,R11 |   | (X(I1),Y(I1)) pointer<br>If LPCNT = JT, go to |
|--------|----------------------|---------------------------------|---|-----------------------------------------------|
|        | BZD                  | SPCL                            | ; | special butterfly                             |
|        | ADDI                 | BK, AR1, AR2                    | ; | (X(I2),Y(I2)) pointer                         |
|        | ADDI                 | BK, AR2, AR3                    | ; | (X(I3),Y(I3)) pointer                         |
|        | SUBI3                | 1,R8,RC                         |   | RC should be one less than                    |
|        |                      |                                 | ; | desired #                                     |
|        | LDI                  | R10, AR4                        |   |                                               |
|        | ADDI                 | @SINTAB, AR4                    | ; | Create cosine index AR4                       |
|        | ADDI                 | AR4, R10, AR5                   |   |                                               |
|        | SUBI                 | 1,AR5                           | ; |                                               |
|        | RPTBD                | BLK2                            | ; | Setup loop BLK2                               |
|        | ADDI                 | 10,AR5,AR6                      |   | · · · · · · · · · · · · · · · · · · ·         |
|        | SUBI                 | 1,AR6                           | ; |                                               |
|        | LDF                  | *+AR2,R7                        | ; | R7 = Y(I2)                                    |
| *      | SECOND LC            | OP: BLK2                        |   |                                               |
|        | ADDF                 | R7,*+AR0,R3                     | ; | R3 = Y(I) + Y(I2)                             |
|        | ADDF                 | *+AR3, *+AR1, R5                |   | R5 = Y(I1) + Y(I3)                            |
|        | ADDF                 | R5, R3, R6                      |   | R6 = R3 + R5                                  |
|        | SUBF                 | R7,*+AR0,R4                     |   | R4 = Y(I) - Y(I2)                             |
|        | SUBF                 | R5, R3                          |   | R3 = R3 - R5                                  |
|        | ADDF                 | *AR2, *AR0, R1                  |   | R1 = X(I) + X(I2)                             |
|        | ADDF                 | *AR3, *AR1, R5                  |   | R5 = X(I1) + X(I3)                            |
|        | MPYF                 | R3,*+AR5(IR1),R6                |   | R6 = R3*C02                                   |
|        | STF                  |                                 |   | Y(I) = R3 + R5                                |
|        | ADDF                 | R5, R1, R0                      |   | R0 = R1 + R5                                  |
|        | SUBF                 | *AR2, *AR0, R2                  |   | R2 = X(I) - X(I2)                             |
|        | SUBF                 | R5,R1                           |   | R1 = R1 - R5                                  |
|        | MPYF                 | R1,*AR5,R0                      | - | R0 = R1 * SI2                                 |
| 11     | STF                  | R0,*AR0++(IR0)                  |   | X(I) = RI + R5                                |
|        | SUBF                 | R0, R6                          |   | R6 = R3*C02 - R1*SI2                          |
|        | SUBF                 | *+AR3, *+AR1, R5                |   | R5 = Y(I1) - Y(I3)                            |
|        | MPYF                 | R1, *+AR5(IR1), R0              |   | R0 = R1 * C02                                 |
|        | STF                  | R6, *+AR1                       |   | Y(I1) = R3*C02 - R1*SI2                       |
| ••     | MPYF                 | R3,*AR5,R6                      |   | R6 = R3*SI2                                   |
|        | ADDF                 | RO,R6                           |   | R6 = R1*CO2 + R3*SI2                          |
|        | ADDF                 | R5, R2, R1                      |   | R1 = R2 + R5                                  |
|        | SUBF                 | R5, R2                          |   | R2 = R2 - R5                                  |
|        | SUBF                 | *AR3, *AR1, R5                  |   | R5 = X(I1) - X(I3)                            |
|        | SUBF                 | R5, R4, R3                      |   | R3 = R4 - R5                                  |
|        | ADDF                 | R5,R4                           |   | R4 = R4 + R5                                  |
|        | MPYF                 | R3, *+AR4 (IR1), R6             |   | R6 = R3*C01                                   |
| 11     | STF                  | R6, *AR1++ (IR0)                |   | X(I1) = R1*CO2 + R3*SI2                       |
| ••     | MPYF                 | R1,*AR4,R0                      |   | R0 = R1*SI1                                   |
|        | SUBF                 | R0, R6                          |   | R6 = R3*C01 - R1*SI1                          |
|        | MPYF                 | R1,*+AR4(IR1),R6                |   | R6 = R1*C01                                   |
| 11     | STF                  | R6,*+AR2                        |   | Y(I2) = R3*C01 - R1*SI1                       |
|        | MPYF                 | R3, *AR4, R0                    |   | R0 = R3*SI1                                   |
|        | ADDF                 | R0,R6                           |   | R6 = R1*C01 + R3*SI1                          |
|        | MPYF                 | R4, *+AR6(IR1), R6              | , |                                               |
|        |                      |                                 | / |                                               |

| 11       | STF         | R6,*AR2++(IR0)         | ; X(I2) = R1*CO1 + R3*SI1                                    |
|----------|-------------|------------------------|--------------------------------------------------------------|
|          | MPYF        | R2,*AR6,R0             | ; $RO = R2 * SI3$                                            |
|          | SUBF        | R0, R6                 | ; R6 = R4*CO3 - R2*SI3                                       |
|          | MPYF        | R2, *+AR6(IR1), R6     | ; $R6 = R2*C03$                                              |
| 11       | STF         | R6, *+AR3              | ; $Y(I3) = R4*C03 - R2*SI3$                                  |
| ••       | MPYF        | R4, *AR6, R0           | ; $RO = R4 * SI3$                                            |
|          | ADDF        | R0, R6                 | ; $R6 = R2*C03 + R4*SI3$                                     |
| BLK2     | STF         | R6, *AR3++ (IR0)       | ; $x(i3) = R2*CO3 + R4*SI3$                                  |
|          |             | *+AR2,R7               |                                                              |
| 11       | LDF         |                        | ; Load next Y(I2)                                            |
|          | CMPI        | R11,BK                 |                                                              |
|          | BPD         | INLOP                  | ; LOOP BACK TO THE INNER LOOP                                |
|          | LDI         | R11, ARO               |                                                              |
|          | ADDI        | @INPUT, ARO            | ; (X(I),Y(I)) pointer                                        |
|          | ADDI        | 2,R11                  | ; Increment inner loop counter                               |
|          | BRD         | CONT                   |                                                              |
|          | LSH         | 2,R8                   | ; Increment repeat counter for                               |
|          |             | ,<br>,                 | ; next time                                                  |
|          | LSH         | 2,AR7                  | ; IE = $4 \times IE$                                         |
|          | LDI         | BK, IRO                | ; $N1 = N2$                                                  |
|          |             |                        | ,                                                            |
|          |             |                        |                                                              |
| *        | SPECIAL     | BUTTERFLY FOR W=J      |                                                              |
| SPCL     | RPTBD       | BLK3                   | ; Setup loop BLK3                                            |
|          | LSH         | -1, IR1, AR4           | ; Point to SIN(45)                                           |
|          | ADDI        | @SINTAB, AR4           |                                                              |
|          | ADDI        | COINTRD, ANA           | ; Create cosine index AR4 = CO21                             |
|          |             |                        |                                                              |
|          | LDF         | *AR2,R7                | ; $R7 = X(I2)$                                               |
| *CPCT TO | DOP: BLK3   | ANZ, N                 | $, \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \$                    |
| "SECT D  |             | D7 +3D0 D1             | D1 - Y(T) + Y(T)                                             |
|          | ADDF        | R7,*AR0,R1             | ; $R1 = X(I) + X(I2)$                                        |
|          | ADDF        | *+AR2, *+AR0, R3       | ; $R3 = Y(I) + Y(I2)$                                        |
|          | SUBF        | *+AR2,*+AR0,R4         | ; $R4 = Y(I) - Y(I2)$                                        |
|          | ADDF        | *AR3,*AR1,R5           | ; $R5 = X(I1) + X(I3)$                                       |
|          | SUBF        | R1,R5,R6               | ; $R6 = R5 - R1$                                             |
|          | ADDF        | R5, R1                 | ; $R1 = R1 + R5$                                             |
|          | ADDF        | *+AR3, *+AR1, R5       | ; R5 = Y(I1) + Y(I3)                                         |
|          | SUBF        | R5,R3,R0               | R0 = R3 - R5                                                 |
|          | ADDF        | R5, R3                 | ; $R3 = R3 + R5$                                             |
|          | SUBF        |                        |                                                              |
|          |             | R7,*AR0,R2             | ; $R2 = X(I) - X(I2)$                                        |
|          | STF         | R3, *+AR0              | ; $Y(I) = R3 + R5$                                           |
|          | LDF         | *AR3, R7               | ; $R7 = X(I3)$                                               |
| 11       | STF         | R1,*AR0++(IR0)         | ; $X(I) = R1 + R5$                                           |
|          | SUBF        | R7,*AR1,R1             | ; $R1 = X(I1) - X(I3)$                                       |
| 11       | STF         | R6,*+AR1               | ; $Y(I1) = R5 - R1$                                          |
|          | SUBF        | *+AR3,*+AR1,R3         | ; $R3 = Y(I1) - Y(I3)$                                       |
|          | ADDF        | R3, R2, R5             | ; $R5 = R2 + R3$                                             |
|          | SUBF        | R2,R3,R2               | ; R2 = -R2 + R3                                              |
|          | SUBF        | R1,R4,R3               | ; $R3 = R4 - R1$                                             |
|          | ADDF        | R1, R4                 | ; $R4 = R4 + R1$                                             |
|          | SUBF        | R5, R3, R1             | ; $R1 = R3 - R5$                                             |
|          |             |                        |                                                              |
|          | MPYF        | R1,*AR4,R1             | ; $R1 = R1*C021$                                             |
|          | STF         | R0,*AR1++(IR0)         | ; $X(I1) = R3 - R5$                                          |
|          | ADD         | R5,R3                  | ; $R3 = R3 + R5$                                             |
|          |             |                        |                                                              |
|          | MPYF        | R3,*AR4,R3             | ; $R3 = R3*C021$                                             |
| 11       | MPYF<br>STF | R3,*AR4,R3<br>R1,*+AR2 | ; $R3 = R3 \times CO21$<br>; $Y(I2) = (R3 - R5) \times CO21$ |
| 11       |             | • •                    |                                                              |
| 11       | STF         | R1,*+AR2               | ; $Y(I2) = (R3 - R5) * CO21$                                 |

|       | MPYF     | R1,*AR4,R1      | ; | R1 = R1 * CO21               |
|-------|----------|-----------------|---|------------------------------|
| []    | STF      | R3,*AR2++(IR0)  | ; | X(I2) = (R3 + R5) * CO21     |
|       | ADDF     | R4, R2          | ; | R2 = R2 + R4                 |
|       | MPYF3    | R2,*AR4,R2      | ; | R2 = R2 * CO21               |
| 11    | STF      | R1,*+AR3        | ; | Y(I3) = -(R4 - R2) * CO21    |
| BLK3  | LDF      | *AR2,R          | ; |                              |
| 11    | STF      | R2,*AR3++(IR0)  | ; | X(I3) = (R4 + R2) * CO21     |
|       | CMPI     | R11, BK         |   |                              |
|       | BPD      | INLOP           | ; | Loop back to the inner loop  |
|       | LDI      | R11,AR0         |   |                              |
|       | ADDI     | @INPUT,ARO      | ; | (X(I),Y(I)) pointer          |
|       | ADDI     | 2,R11           | ; | Increment inner loop counter |
| LSH   | 2,R8     |                 | ; | -                            |
|       |          |                 | • | time                         |
|       | LSH      | 2, AR           | ; | $IE = 4 \times IE$           |
|       | LDI      | BK, IRO         | ; |                              |
| CONT  | BRD      | LOOP            | ; | Next FFT stage (delayed)     |
|       | LSH      | -2,BK           | ; | N2 = N2/4                    |
|       | LSH3     | -1,BK,R9        |   |                              |
|       | ADDI     | 2,R9            | - | JT = N2/2 + 2                |
| *     |          |                 |   | EVERSED ADDRESSING           |
| END:  | LDI      | @FFTSIZ,IRO     | - | IRO = size of FFT = N        |
|       | SUBI3    | 2,IR0,RC        | ; | RC = N - 2                   |
|       | LDI      | 2, IR1          |   |                              |
|       | RPTBD    | BITRV           |   |                              |
|       | LDI      | @INPUT, ARO     |   |                              |
|       | LDI      | @OUTPUT, AR1    |   |                              |
|       | LDF      | *+ARO(1),RO     |   |                              |
| *     | BIT REVE |                 |   |                              |
|       | LDF      | *AR0++(IR0)B,R1 |   |                              |
|       | STF      | R0,*+AR1(1)     |   |                              |
| BITRV | LDF      | *+ARO(1),RO     |   |                              |
|       | STF      | R1,*AR1++(IR1)  |   |                              |
|       | LDF      | *AR0++(IR0)B,R1 |   |                              |
| 11    | STF      | R0,*+AR1(1)     |   |                              |
|       | STF      | R1,*AR1++(IR1)  |   |                              |
| SELF  | BR       | SELF            | ; | Branch to itself at the end. |
|       | .end     |                 |   |                              |
|       |          |                 |   |                              |

Most often, the data to be transformed is a sequence of real numbers. In this case, the FFT demonstrates certain symmetries that permit the reduction of the computational load even further. Example 12–40 shows the generic implementation of a real-valued, radix-2 FFT. For such an FFT, the total storage required for a length-N transform is only N locations; in a complex FFT, 2N are necessary. Recovery of the rest of the points is based on the symmetry conditions.

# Example 12–40. Real, Radix-2 FFT

| *<br>*                                           | TITLE REAL, RADIX-2 FFT                                                                                                                                                                                                                                                                                                             |                                      |        |                                                                                                      |  |  |  |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------|------------------------------------------------------------------------------------------------------|--|--|--|
| *                                                |                                                                                                                                                                                                                                                                                                                                     |                                      |        |                                                                                                      |  |  |  |
| *<br>*<br>*                                      | GENERIC PROGRAM TO DO A RADIX-2 REAL FFT COMPUTATION<br>IN 320C40.                                                                                                                                                                                                                                                                  |                                      |        |                                                                                                      |  |  |  |
| *<br>*<br>*                                      | THE PROGRAM IS DERIVED FROM THE PAPER BY SORENSEN ET AL.,<br>JUNE 1987 ISSUE OF THE TRANSACTIONS ON ASSP.<br>THE REAL DATA RESIDE IN INTERNAL MEMORY. THE COMPUTATION<br>DONE IN-PLACE. THE BIT-REVERSAL IS DONE AT THE BEGINNING<br>THE PROGRAM.                                                                                   |                                      |        |                                                                                                      |  |  |  |
| *<br>*<br>*                                      |                                                                                                                                                                                                                                                                                                                                     |                                      |        |                                                                                                      |  |  |  |
| * * * * * *                                      | THE TWIDDLE FACTORS ARE SUPPLIED IN A TABLE PUT IN A .DATA SECTION. THIS DATA IS INCLUDED IN A SEPARATE FILE TO PRESERVE THE GENERIC NATURE OF THE PROGRAM. FOR THE SAME PURPOSE, THE SIZE OF THE FFT N AND LOG2 (N) ARE DEFINED IN A .GLOBL DIRECTIVE AND SPECIFIED DURING LINKING. THE LENGTH OF THE TABLE IS $N/4 + N/4 = N/2$ . |                                      |        |                                                                                                      |  |  |  |
|                                                  | .globl<br>.globl<br>.globl<br>.globl<br>.bss<br>.text                                                                                                                                                                                                                                                                               | N<br>M<br>SINE                       | ;;;    | Entry point for execution<br>FFT size<br>LOG2(N)<br>Address of sine table<br>Memory with input data  |  |  |  |
| *<br>FFTSIZ<br>LOGFFT<br>SINTAB<br>INPUT<br>FFT: | INITIALIZ<br>.word<br>.word<br>.word<br>.word<br>LDP                                                                                                                                                                                                                                                                                | E<br>N<br>M<br>SINE<br>INP<br>FFTSIZ | ;      | Command to load data page printer                                                                    |  |  |  |
| *                                                | DO THE BIT-REVERSING AT THE<br>LDI @FFTSIZ,R8<br>SUBI 1,R8,RC<br>LDI @SINTAB,R9                                                                                                                                                                                                                                                     |                                      | ;<br>; | BEGINNING<br>R8 = N<br>RC should be one less<br>than desired #                                       |  |  |  |
|                                                  | LDI<br>RPTBD<br>LSH3<br>LDI<br>LDI                                                                                                                                                                                                                                                                                                  | -1,R8,IR0                            | ;<br>; | Setup for BITRV loop<br>IR1 = half the size of FFT = N/2<br>AR0 points to X(I)<br>AR1 points to X(I) |  |  |  |

| *     | DIGIT REV | ERSE COUNTER        |                                |  |  |  |  |
|-------|-----------|---------------------|--------------------------------|--|--|--|--|
|       | CMPI      | AR1,AR0             | ; Exchange locations only      |  |  |  |  |
|       | LDF       | *AR0++(1),R1        | ; if ARO <ar1< td=""></ar1<>   |  |  |  |  |
| 11    | LDF       | *AR1++(IR0)B,R0     |                                |  |  |  |  |
| ••    | LDFLT     | *AR0,R0             |                                |  |  |  |  |
|       | LDFLT     | *AR1, R1            |                                |  |  |  |  |
| BITRV | STF       | RO,*AR1             |                                |  |  |  |  |
| 11    | STF       | R1,*ARO             |                                |  |  |  |  |
|       | 011       | ,                   |                                |  |  |  |  |
|       |           |                     |                                |  |  |  |  |
| *     |           | O BUTTERFLIES       |                                |  |  |  |  |
|       | LDI       | @INPUT, ARO         | ; ARO points to X(I)           |  |  |  |  |
|       | RPTBD     | BLK1                | ; Setup for BLK1 loop          |  |  |  |  |
|       | SUBI3     | 1, IRO, RC          | ; $RC = (N/2) - 1$             |  |  |  |  |
|       | LDF       | *+AR0(1),R2         | ; $R2 = X(I + 1)$              |  |  |  |  |
|       | LDI       | 2,IR0               | ; $IRO = 2 = N2$               |  |  |  |  |
| *     | BLK1 LOOP |                     |                                |  |  |  |  |
|       | ADDF      | R2,*AR0,R0          | ; $RO = X(I) + X(I + 1)$       |  |  |  |  |
|       | SUBF      | R2,*AR0,R1          | ; $R1 = X(I) - X(I + 1)$       |  |  |  |  |
| 11    | STF       | R0,*AR0++(1)        | ; $X(I) = X(I) + X(I + 1)$     |  |  |  |  |
| BLK1  | LDF       | *+AR0(IR0),R2       | ; Load next X(I)               |  |  |  |  |
| 11    | STF       | R1,*AR0++(1)        | ; $X(I + 1) = X(I) - X(I + 1)$ |  |  |  |  |
| *     | FIRST DAS | S OF THE DO-20 LOOP | (STAGE $K = 2$ IN DO-10 LOOP)  |  |  |  |  |
|       | LDI       | @INPUT, ARO         | ; ARO points to X(I)           |  |  |  |  |
|       | RPTBD     | BLK2                | ; Setup for BLK2 loop          |  |  |  |  |
|       | LSH3      |                     |                                |  |  |  |  |
|       |           | -2,R8,RC            | ; Repeat N/4 times             |  |  |  |  |
|       | SUBI      | 1,RC                | ; RC should be one less        |  |  |  |  |
|       | TDE       | *                   | ; than desired #               |  |  |  |  |
|       | LDF       | *+AR0(IR0),R2       | ; $R2 = X(I + 2)$              |  |  |  |  |
| *     | BLK2 LOOP |                     |                                |  |  |  |  |
|       | ADDF      | R2,*AR0++(IR0),R0   | ; $R0 = X(I) + X(I + 2)$       |  |  |  |  |
|       | SUBF      | R2,*-AR0(IR0),R1    | ; $R1 = X(I) - X(I + 2)$       |  |  |  |  |
| 11    | STF       | R0, *-AR0(IR0)      | ; $X(I) = X(I) + X(I + 2)$     |  |  |  |  |
| ••    | NEGF      | *+AR0, R0           | ; $RO = -X(I + 3)$             |  |  |  |  |
| 11    | STF       | R1, *AR0++(IR0)     | ; $X(I + 2) = X(I) - X(I + 2)$ |  |  |  |  |
| BLK2  | LDF       | *+AR0(IR0),R2       | ; Load next $X(I + 2)$         |  |  |  |  |
|       | STF       | R0, *-AR0           | ; $X(I + 3) = -X(I + 3)$       |  |  |  |  |
|       | SIL       | NO, ANO             | (1 + 3) = X(1 + 3)             |  |  |  |  |
| *     | MAIN LOOP | (FFT STAGES)        |                                |  |  |  |  |
|       | LSH3      | -3,R8,IR0           | ; IRO = $E/2$ index for E      |  |  |  |  |
|       | LDI       | 3,R11               | ; R11 holds the current        |  |  |  |  |
|       |           |                     | ; stage number                 |  |  |  |  |
|       | LDI       | 2,R4                | ; $R4 = N4$                    |  |  |  |  |
|       | LDI       | 4,R3                | ; $R3 = N2$                    |  |  |  |  |
| LOOP  | LDI       | @INPUT, AR5         | ; AR5 points to X(I)           |  |  |  |  |
|       | LSH3      | 2,R4,R10            | ; Set loop counter             |  |  |  |  |
|       | ADDI3     | IRO, R9, ARO        | ; AR0 points to SIN/COS        |  |  |  |  |
|       |           |                     | ; table                        |  |  |  |  |
|       |           |                     | ,                              |  |  |  |  |

| *      | TNNER LOC | P (DO-20 LOOP IN THE | PR | JGRAM)                           |
|--------|-----------|----------------------|----|----------------------------------|
| INLOP  | LDI       | R4, IR1              |    | IR1 = N4  or  N2/2               |
| TIMEOT | ADDI3     | 1, AR5, AR1          | -  | AR1 points to $X(I1) = X(I + J)$ |
|        | _         |                      |    | AR3 points to                    |
|        | ADDI3     | R3,AR1,AR3           |    |                                  |
|        |           | 0 300 300            |    | X(I3) = X(I + J + N2)            |
|        | SUBI3     | 2,AR3,AR2            |    | AR2 points to                    |
|        |           |                      |    | X(I2) = X(I - J + N2)            |
|        | ADDI      | R3,AR2,AR4           |    | AR4 points to                    |
|        |           |                      |    | X(I4) = X(I - J + N1)            |
|        | LDF       | *AR5++(IR1),R0       |    | RO = X(I)                        |
|        | ADDF      | *+AR5(IR1),R0,R1     | ;  | R1 = X(I) + X(I + N2)            |
|        | SUBF      | R0,*++AR5(IR1),R0    | ;  | RO = -X(I) + X(I + N2)           |
| 11     | STF       | R1,*-AR5(IR1)        | ;  | X(I) = X(I) + X(I + N2)          |
|        | NEGF      | RO                   |    | R0 = X(I) - X(I + N2)            |
|        | NEGF      | *++AR5(IR1),R1       |    | R1 = -X(I + N4 + N2)             |
| 11     | STF       | R0,*AR5              |    | X(I + N2) = X(I) - X(I + N2)     |
|        | STF       | R1, *AR5             | ,  | X(I + N4 + N2) = -X(I + N4 + N2) |
| *      | INNERMOST |                      | '  |                                  |
|        | RPTBD     | BLK3                 |    | Setup for BLK3 loop              |
|        |           |                      |    |                                  |
|        | LSH3      | -2,R8,               |    | IR1=separation between           |
|        |           | 0.54.55              |    | SIN/COS tbls                     |
|        | SUBI      | 2,R4,RC              |    | Repeat N4 - 1 times              |
|        | LDF       | *AR3,R5              | ;  | R5 = X(I3)                       |
| *      | BLK3 LOOF |                      |    |                                  |
|        | MPYF      | R5,*+AR0(IR1),R0     | ;  | R0 = X(I3) * COS                 |
|        | MPYF      | *AR4,*AR0,R1         | ;  | R1 = X(I4) * SIN                 |
|        | MPYF      | *AR4, *+AR0(IR1), R1 | ;  | R1 = X(I4) * COS                 |
| 11     | ADDF      | R0,R1,R2             |    | R2 = X(I3) * COS + X(I4) * SIN   |
|        | MPYF      | R5,*AR0++(IR0),R0    |    | R0 = X(I3) * SIN                 |
|        | SUBF      | R0, R1, R0           |    | R0 = -X(I3) * SIN + X(I4) * COS  |
|        | SUBF      | *AR2, R0, R1         |    | R1 = -X(I2) + R0                 |
|        | ADDF      | *AR2, R0, R1         | •  | R1 = X(I2) + R0                  |
| 1.1    |           |                      |    |                                  |
| 11     | STF       | R1,*AR3++            |    | X(I3) = -X(I2) + R0              |
|        | ADDF      | *AR1,R2,R1           |    | R1 = X(I1) + R2                  |
| 11     | STF       | R1,*AR4              |    | X(I4) = X(I2) + R0               |
|        | SUBF      | R2,*AR1,R1           |    | R1 = X(I1) - R2                  |
|        | STF       | R1,*AR1++            |    | X(I1) = X(I1) + R2               |
| BLK3   | LDF       | *AR3,R5              | ;  | Load next X(I3)                  |
| 11     | STF       | R1,*AR2              | ;  | X(I2) = X(I1) - R2               |
|        | CMPI      | @FFTSIZ,R10          |    |                                  |
|        | BLTAF     | INLOP                | ;  | Loop back inner to theloop       |
|        | ADDI      | R4,AR5               | ;  | AR5 = I + N1                     |
|        | ADDI      | R10,R10              | •  |                                  |
|        | ADDI3     | IRO, R9, ARO         | :  | AR0 points to                    |
|        |           |                      |    | SIN/COS table                    |
|        | ADDI      | 1,R11                | '  | SIN/COD CADIC                    |
|        | CMPI      |                      |    |                                  |
|        |           | @LOGFFT,R11          |    |                                  |
|        | BLEAF     | LOOP                 |    | $\mathbf{E} = \mathbf{E}/2$      |
|        | LSH       | -1,IR0               |    | E = E/2                          |
|        | LSH       | 1,R4                 |    | $N4 = 2 \times N4$               |
|        | LSH       | 1,R3                 |    | $N2 = 2 \times N2$               |
| END    | BR        | END                  | ;  | Branch to itself at the end.     |
|        | .end      |                      |    |                                  |
|        |           |                      |    |                                  |

Example 12–37, Example 12–39, and Example 12–40 provide an easy understanding of the FFT algorithm functions. However, they are not optimized for fast speed execution of FFT. Example 12–41 shows a faster version of a radix-2 DIT FFT algorithm. This program uses a different twiddle factors table than the previous examples. The twiddle factors are stored in bit reversed order and with a table length of N/2 (N = FFT length). For instance, if the FFT length is 32, the twiddle factors table should be:

| Address              |                                                                                                     | <b>Coefficient</b>                                                   |                                          |
|----------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------|
| 0<br>1<br>2<br>3     | $\begin{array}{lll} R\{WN(0)\} &= \\ -l\{WN(0)\} &= \\ R\{WN(4)\} &= \\ -l\{WN(4)\} &= \end{array}$ | COS(2*PI*0/32)<br>SIN(2*PI*0/32)<br>COS(2*PI*4/32)<br>SIN(2*PI*4/32) | = 1<br>= 0<br>= 0.707<br>= 0.707         |
| •                    |                                                                                                     | •                                                                    |                                          |
| •                    |                                                                                                     | -                                                                    |                                          |
| •                    |                                                                                                     | -                                                                    |                                          |
| 12<br>13<br>14<br>15 | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                | COS(2*PI*3/32)<br>SIN(2*PI*3/32)<br>COS(2*PI*7/32)<br>SIN(2*PI*7/32) | = 0.831<br>= 0.556<br>= 0.195<br>= 0.981 |

Example 12–41. Faster Version Complex, Radix-2 DIT FFT

\* TITLE FASTER VERSION COMPLEX, RADIX-2 DIT FFT \* \* GENERIC PROGRAM FOR A FAST LOOPED-CODE RADIX-2 DIT FFT \* COMPUTATION IN TMS320C40 \* \* THE PROGRAM IS DERIVED FROM THE PAPER BY RAIMUND MEYER AND \* AND KARL SCHWARZ, VOLUME 3, PROCEEDINGS OF ICASSP 90. \* THE (COMPLEX) DATA RESIDE IN INTERNAL MEMORY. THE COMPUTATION \* IS DONE IN-PLACE, BUT THE RESULT IS MOVED TO ANOTHER MEMORY \* SECTION TO DEMONSTRATE THE BIT-REVERSED ADDRESSING. \* \* FOR THIS PROGRAM THE MINIMUM FFT LENGTH IS 32 POINTS BECAUSE \* OF THE SEPARATE STAGES. FIRST TWO PASSES ARE REALIZED AS A \* FOUR BUTTERFLY LOOP SINCE THE MULTIPLIES ARE TRIVIAL. THE \* MULTIPLIER IS ONLY USED FOR A LOAD IN PARALLEL WITH AN ADDF \* OR SUBF. \* \* THE TWIDDLE FACTORS ARE SUPPLIED IN A TABLE PUT IN A .DATA \* SECTION. THIS DATA IS INCLUDED IN A SEPARATE FILE TO PRESERVE \* THE GENERIC NATURE OF THE PROGRAM. FOR THE SAME PURPOSE, THE × SIZE OF THE FFT N AND LOG2 (N) ARE DEFINED IN A .GLOBL \* DIRECTIVE AND SPECIFIED DURING LINKING. THE LENGTH OF THE TABLE IS N/2.

\*

| .global<br>.global<br>.global<br>.global<br>.global<br>.global<br>.global<br>.BSS                                 | fft<br>n<br>nhalb<br>nviert<br>nachtel<br>m<br>sine<br>inp,2048                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ; ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <pre>input vector length = 2n (depends of n)n)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BSS                                                                                                               | outp,2048                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | output vector length = 2n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| .text<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word | n<br>nviert-2<br>nviert-3<br>nachtel-2<br>nhalb<br>nhalb-3<br>m<br>sine<br>sine-1<br>sine+2<br>inp<br>inp+2<br>outp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | (depends of n)n)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ar1 : BR<br>ar2 : CR<br>ar3 : DR<br>ar4 : AR'<br>ar5 : BR'<br>ar6 : DR'                                           | + BI<br>+ CI + CR' + CI'<br>+ DI<br>+ AI'<br>+ BI'<br>+ DI'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| ldp<br>ldi<br>ldi<br>addi<br>addi<br>addi<br>ldi<br>ldi<br>ldi<br>ldi<br>ldi<br>lsh                               | <pre>fftsiz @fg2,ir0 @sintab,ar7 @input,ar0 ir0,ar0,ar1 ir0,ar1,ar2 ir0,ar2,ar3 ar0,ar4 ar1,ar5 ar3,ar6 2,ir1 -1,ir0 2,ir0,rc</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ar7 points to twiddle factor 1<br>ar0 points to AR<br>ar1 points to BR<br>ar2 points to CR<br>ar3 points to DR<br>ar4 points to AR'<br>ar5 points to BR'<br>ar6 points to DR'<br>address offset                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                   | .global<br>.global<br>.global<br>.global<br>.global<br>.global<br>.global<br>.global<br>.BSS<br>.text<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.word<br>.wo | .global n<br>.global nhalb<br>.global nviert<br>.global nachtel<br>.global sine<br>.BSS inp,2048<br>.BSS outp,2048<br>.text<br>.word n<br>.word nviert-2<br>.word nviert-3<br>.word nachtel-2<br>.word nhalb<br>.word sine<br>.word sine-1<br>.word sine+2<br>.word inp+2<br>.word inp+2<br>.word outp<br>ar0 : AR + AI<br>ar1 : BR + BI<br>ar2 : CR + CI + CR' + CI'<br>ar3 : DR + DI<br>ar4 : AR' + AI'<br>ar5 : BR' + BI'<br>ar6 : DR' + DI'<br>ar7 : first twiddle factor<br>ldp fftsiz<br>ldi @fg2,ir0<br>ldi @sintab,ar7<br>ldi @finput,ar0<br>addi ir0,ar1,ar2<br>addi ir0,ar4<br>ldi ar1,ar5<br>ldi ar3,ar6<br>ldi 2,ir1<br>lsh -1,ir0 | .global n<br>.global nhalb<br>.global nviert<br>.global nachtel<br>.global sine<br>.BSS inp,2048 ;<br>.BSS outp,2048 ;<br>.text<br>.word n<br>.word nviert-2<br>.word nviert-3<br>.word nachtel-2<br>.word nhalb<br>.word nhalb<br>.word sine<br>.word sine-1<br>.word sine+2<br>.word inp<br>.word inp+2<br>.word outp<br>ar0 : AR + AI<br>ar1 : BR + BI<br>ar2 : CR + CI + CR' + CI'<br>ar3 : DR + DI<br>ar4 : AR' + AI'<br>ar5 : BR' + BI'<br>ar6 : DR' + DI'<br>ar7 : first twiddle factor =<br>ldp fftsiz ;<br>ldi @fg2,ir0 ;<br>ldi @fg2,ir0 ;<br>ldi @fg2,ir1 ;<br>addi ir0,ar2,ar3 ;<br>ldi ar1,ar5 ;<br>ldi ar3,ar6 ;<br>ldi 2,ir1 ;<br>lsh -1,ir0 ; |

\*----- BUTTERFLY-----FIRST 2 STAGES AS RADIX-4 BUTTERFLY------FIRST 2 \* fill pipeline addf \*ar2,\*ar0,r4 ; r4 = AR + CRsubf \*ar2,\*ar0++,r5 ; r5 = AR - CRaddf \*ar1,\*ar3,r6 ; r6 = DR + BRsubf \*ar1++,\*ar3++,r7 ; r7 = DR - BR addf ; AR' = r0 = r4 + r6r6,r4,r0 mpyf \*ar3++,\*ar7,r1 ; r1 = DI , BR' = r3 = r4 - r611 subf r6, r4, r3 addf r1,\*ar1,r0 ; r0 = BI + DI , AR' = r011 stf r0,\*ar4++ r1,\*ar1++,r1 subf ; r1 = BI - DI , BR' = r311 stf r3,\*ar5++ addf r1, r5, r2 ; CR' = r2 = r5 + r1\*+ar2,\*ar7,r1 mpy ; r1 = CI , DR' = r3 = r5 - r1r1,r5,r3 subf rptbd blk1 ; Setup for radix-4 butterfly loop ; r2 = AI + CI , CR' = r2r1,\*ar0,r2 add 11 r2,\*ar2++(ir1) stf r1,\*ar0++,r6 ; r6 = AI - CI , DR' = r3subf stf r3,\*ar6++ addf r0,r2,r4 ; AI' = r4 = r2 + r0\* radix-4 butterfly loop \*ar2--,\*ar7,r0 ; r0 = CR , (BI' = r2 = r2 - r0)mpyf 11 subf r0, r2, r2 ; r1 = BR , (CI' = r3 = r6 + r7)mpyf \*ar1++,\*ar7,r1 11 addf r7,r6,r3 addf r0,\*ar0,r4 ; r4 = AR + CR, (AI' = r4)11 stf r4,\*ar4++ ; r5 = AR - CR, (BI' = r2)subf r0,\*ar0++,r5 11 stf r2,\*ar5++ ; (DI' = r7 = r6 - r7)subf r7,r6,r7 addf r1,\*ar3,r6 ; r6 = DR + BR , (DI' = r7)11 stf r7,\*ar6++ subf r1,\*ar3++,r7 ; r7 = DR - BR , (CI' = r3)11 stf r3,\*ar2++ ; AR' = r0 = r4 + r6addf r6,r4,r0 ; r1 = DI , BR' = r3 = r4 - r6mpyf \*ar3++,\*ar7,r1 subf r6, r4, r3 ; r0 = BI + DI , AR' = r0addf r1,\*ar1,r0 11 stf r0,\*ar4++ r1,\*ar1++,r1 ; r1 = BI - DI , BR' = r3subf stf r3,\*ar5++ ; CR' = r2 = r5 + r1addf r1, r5, r2 ; r1 = CI , DR' = r3 = r5 - r1mpyf \*+ar2,\*ar7,r1 11 subf r1, r5, r3 addf r1,\*ar0,r2 ; r2 = AI + CI , CR' = r211 stf r2, \*ar2++(ir1)subf r1,\*ar0++,r6 ; r6 = AI - CI , DR' = r3stf 11 r3,\*ar6++ blk1 addf r0,r2,r4 ; AI' = r4 = r2 + r0

12-80

12

Software Applications

| * clear                                | pipeline                                                            |                                                                                                                            |                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|----------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                                        | subf<br>addf<br>st<br>stf<br>subf<br>stf<br>stf                     | r0,r2,r2<br>r7,r6,r3<br>r4,*ar4<br>r2,*ar5<br>r7,r6,r7<br>r7,*ar6<br>r3,*ar2                                               | <pre>; BI' = r2 = r2 - r0<br/>; CI' = r3 = r6 + r7<br/>; AI' = r4 , BI' = r2<br/>; DI' = r7 = r6 - r7<br/>; DI' = r7 , CI' = r3</pre>                                                                                                                                                                                    |  |  |  |  |  |
| ************************************** |                                                                     |                                                                                                                            |                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| * * * * * * * *                        | ldi<br>subi<br>ldi                                                  | @fg2,ir1<br>1,ir0,ar5<br>1,ar6                                                                                             | **********                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| stufe                                  | ldi<br>ldi<br>ldi<br>addi<br>ldi<br>lsh<br>lsh<br>lsh<br>lsh        | <pre>@sintab, ar7 0, ar4 @input, ar0 ar0, ar2 ir0, ar0, ar3 ar3, ar1 1, ar6 -2, ar5 1, ar5 -1, ir0 -1, ir1</pre>           | <pre>; pointer to twiddle factor<br/>; group counter<br/>; upper real butterfly input<br/>; upper real butterfly output<br/>; lower real butterfly output<br/>; lower real butterfly input<br/>; double group count<br/>; half butterfly count<br/>; clear LSB<br/>; half step from upper to<br/>; lower real part</pre> |  |  |  |  |  |
|                                        | addi<br>ldf                                                         | 1,ir1<br>*ar1++,r6                                                                                                         | ; step from old imaginary to new<br>; real value<br>; dummy load, only for address                                                                                                                                                                                                                                       |  |  |  |  |  |
|                                        | ld ar7,r7                                                           | ·                                                                                                                          | ; update                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| gruppe                                 | 14 41 / 17                                                          | , 17 = 005                                                                                                                 |                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| * fill p                               | ipeline                                                             |                                                                                                                            |                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| *<br>*<br>*<br>*                       | ar0 = upp<br>ar1 = low<br>ar2 = upp<br>ar3 = low                    | per real butterfly<br>wer real butterfly<br>ber real butterfly<br>wer real butterfly<br>nary part has to                   | v input<br>v output<br>v output                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| .н<br>н<br>н                           | ldf<br>mpyf<br>addf<br>mpyf<br>addf<br>rptbd<br>spyf<br>subf<br>add | <pre>*++ar7,r6 *ar1,r6,r1 *++ar4,r0,r3 *ar1,r7,r0 *ar1++,*ar7,r0 r0,r1,r3 bfly1 *ar1++,r7,r1 r3,*ar0,r2 *ar0++,r3,r5</pre> | <pre>; r6 = SIN<br/>; r1 = BI * SIN<br/>; dummy addf for counter update<br/>; r0 = BR * COS<br/>; r3 = TR = r0 + r1 , r0 = BR * SIN<br/>; Setup for loop bfly1<br/>; r1 = BI * COS , r2 = AR - TR<br/>; r5 = AR + TR , BR' = r2</pre>                                                                                    |  |  |  |  |  |
|                                        | stf<br>ldi                                                          | r2,*ar3++<br>ar5,rc                                                                                                        | 12                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |

| * FIRS | T BUTTERI     | FLY-TYPE:          |   |                              |
|--------|---------------|--------------------|---|------------------------------|
| *      | TR = BR       | * COS + BI * SIN   |   |                              |
| *      | TI = BR       | * SIN - BI * COS   |   |                              |
| *      | AR' = AB      | R + TR             |   |                              |
| *      | AI' = AI      | [ - TI             |   |                              |
| *      | BR' = AF      | R – TR             |   |                              |
| *      | BI' = AI      | [ + TI             |   |                              |
| *      | loop bfl      | Ly1                |   |                              |
|        | mpy           | *+ar1,r6,r5        | ; | r5 = BI * SIN, (AR' = r5)    |
|        | stf           | r5,*ar2++          |   |                              |
|        | subf          | r1, r0, r2         | ; | (r2 = TI = r0 - r1)          |
|        | mpyf          | *ar1,r7,r0         |   | r0 = BR * COS,               |
|        |               | · · ·              | ; |                              |
| 11     | addf          | r2,*ar0,r3         |   |                              |
|        | subf          | r2,*ar0++,r4       | ; | (r4 = AI - TI, BI' = r3)     |
| 11     | stf           | r3,*ar3++          |   |                              |
|        | addf          | r0, r5, r3         | ; | r3 = TR = r0 + r5            |
|        | mpyf          | *ar1++,r6,r0       |   | r0 = BR * SIN,               |
|        |               |                    | ; | • • • • •                    |
| 11     | subf          | r3,*ar0,r2         | - |                              |
|        | mpyf          | *ar1++,r7,r1       | ; | r1 = BI * COS, $(AI' = r4)$  |
| 11     | stf           | r4,*ar2++          |   |                              |
| bfly1  | addf          | *ar0++,r3,r5       | ; | r5 = AR + TR, $BR' = r2$     |
| 11     | stf           | r2,*ar3++          |   | •                            |
|        | over to       | next group         |   |                              |
|        | subf          | r1,r0,r2           | ; | r2 = TI = r0 - r1            |
|        | addf          | r2,*ar0,r3         | - | r3 = AI + TI, $AR' = r5$     |
| 11     | stf           | r5,*ar2++          |   | ,                            |
| • •    | subf          | r2,*ar0++(ir1),r4  | ; | r4 = AI - TI , BI' = r3      |
| 11     | stf           | r3,*ar3++(ir1)     |   |                              |
| • •    | nop           | *ar1++(ir1)        | : | address update               |
|        | mpyf          | *ar1,r7,r1         |   | r1 = BI * COS , AI' = r4     |
| 11     | stf           | r4,*ar2++(ir1)     | • |                              |
|        | mpyf          | *ar1, r6, r0       | : | r0 = BR * SIN                |
|        | mpyf          | *ar1++,*ar7++,r0   | - | r3 = TR = r1 - r0, $r0 = BF$ |
| * COS  |               | all, , all, , , 10 |   |                              |
| 11     | subf          | r0,r1,r3           |   |                              |
|        | rptbd         | bfly2              |   | Setup for loop bfly2         |
|        | mpyf          | *ar1++,r6,r1       |   | r1 = BI * SIN,               |
|        |               |                    |   | $r^2 = AR - TR$              |
| 11     | subf          | r3,*ar0,r2         | , |                              |
|        | addf          | *ar0++,r3,r5       | • | r5 = AR + TR, $BR' = r2$     |
| 11     | stf           | r2,*ar3++          |   |                              |
|        | ldi           | ar5,rc             |   |                              |
|        | and the state | ~~~/ ~~            |   |                              |

```
*
   SECOND BUTTERFLY-TYPE:
*
*
        TR = BI * COS - BR * SIN
*
        TI = BI * SIN + BR * COS
*
        AR' = AR + TR
*
        AI' = AI - TI
*
        BR' = AR - TR
*
        BI' = AI + TI
*
       loop bfly2
        mpyf
                 *+ar1,r7,r5
                                   ; r5 = BI * COS , (AR' = r5)
        stf
11
                 r5,*ar2++
        addf
                 r1,r0,r2
                                    ; (r2 = TI = r0 + r1)
        mpyf
                 *ar1,r6,r0
                                    ; r0 = BR * SIN ,
                                      (r3 = AI + TI)
11
        addf
                 r2,*ar0,r3
                 r2,*ar0++,r4
                                    ; (r4 = AI - TI, BI' = r3)
        sub
11
        stf
                 r3,*ar3++
        subf
                                    ; TR = r3 = r5 - r0
                 r0, r5, r3
        mpyf
                 *ar1++,r7,r0
                                    ; r0 = BR * COS , r2 = AR - TR
11
        subf
                 r3,*ar0,r2
                                    ; r1 = BI * SIN, (AI' = r4)
        mpyf
                 *ar1++,r6,r1
stf
                 r4,*ar2++
bfly2
                                    ; r5 = AR + TR , BR' = r2
        addf
                 *ar0++,r3,r5
        stf
                 r2,*ar3++
11
* clear pipeline
        addf
                 r1,r0,r2
                                    ; r^2 = TI = r^0 + r^1
                                    ; r3 = AI + TI
        addf
                 r2,*ar0,r3
                 r5,*ar2++
                                    ; AR' = r5
stf
                 ar6,ar4
        cmpi
                                    ; do following 3 instructions
        bned
                 gruppe
        subf
                 r2,*ar0++(ir1),r4
                                    ; r4 = AI - TI , BI' = r3
11
        stf
                 r3,*ar3++(ir1)
        ldf
                 *++ar7,r7
                                    ; r7 = COS
                                    ; AI' = r4
11
        stf
                 r4,*ar2++(ir1)
        nop
                 *ar1++(ir1)
                                    ; branch here
* end of this butterfly group
        cmpi
                 4, ir0
                                    ; jump out after ld(n)-3 stage
        bnzaf
                 stufe
        ldi
                 @sintab,ar7
                                    ; pointer to twiddle factor
        ldi
                                    ; group counter
                 0,ar4
        ldi
                 @input,ar0
                                    ; upper real butterfly input
*-----SECOND LAST STAGE-----*
ldi
                 @input,ar0
                                    ; upper input
        ldi
                 ar0, ar2
                                    ; upper output
        addi
                 ir0,ar0,ar1
                                    ; lower input
                                    ; lower output
        ldi
                 ar1,ar3
                                   ; pointer to twiddle factor
        ldi
                 @sintp2,ar7
        ldi
                 5,ir0
                                    ; distance between two groups
        ldi
                 @fg8m2,rc
```

| * loop bf2end<br>ld *ar7++,r7 ; $r7 = COS$ , $((AI' = r4))$<br>ll stf r4,*ar2++<br>ldf *ar7++,r6 ; r6 = SIN, $(BR' = r2)$<br>ll stf r2,*ar3++<br>mpyf *tarl,r6,r5 ; r5 = BI * SIN, $(AR' = r3)$<br>ll stf r3,*ar2++<br>addf r1,r0,r2 ; $(r2 = TI = r0 + r1)$<br>mpyf *ar1,r7,r0 ; $r0 = BR * COS$ ,<br>; $(r3 = AI + TI)$<br>ll stf r3,*ar3++ (ir0)<br>addf r0,r5,r3 ; r3 = TR = r0 + r5<br>mpyf *ar1++,r6,r0 ; r0 = BR * SIN, r2 = AR - TI<br>ll sub r3,*ar0,r2<br>mpyf *ar1++,r7,r1 ; r1 = BI * COS , (AI' = r4)<br>ll stf r4,*ar2++ (ir0)<br>addf *ar0++,r3,r5 ; r5 = BI * SIN , (AR' = r5)<br>ll stf r5,*ar2++<br>subf r1,r0,r2 ; $(r2 = TI = r0 - r1)$<br>mpyf *ar1,r7,r0 ; r1 = BI * COS , (AI' = r4)<br>ll stf r2,*ar3++<br>mpyf *ar1,r7,r0 ; r0 = BR * COS ,<br>(r3 = AI + TI)<br>ll stf r5,*ar2++<br>subf r1,r0,r2 ; $(r2 = TI = r0 - r1)$<br>mpyf *ar1,r7,r0 ; r0 = BR * COS ,<br>(r3 = AI + TI)<br>ll stf r3,*ar3++<br>addf r0,r5,r3 ; r3 = TR = r0 + r5<br>mpyf *ar1,r7,r0 ; r0 = BR * COS ,<br>(r3 = AI + TI)<br>ll stf r3,*ar3++<br>addf r0,r5,r3 ; r3 = TR = r0 + r5<br>mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T<br>mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T<br>mpyf *ar1++,r6,r0 ; r1 = BI * COS , (AI' = r4)<br>ll stf r3,*ar3++<br>addf r0,r5,r3 ; r3 = TR = r0 + r5<br>mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T<br>mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T<br>mpyf *ar1++,r6,r0 ; r1 = BI * COS , (AI' = r4)<br>ll stf r4,*ar2++<br>addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2<br>ll stf r2,*ar3++<br>mpyf *ar1++,r5,r5 ; r5 = BI * COS , (AI' = r4)<br>ll stf r4,*ar2++<br>mpyf *ar1++,r5,r5 ; r5 = BI * COS , (AR' = r3)                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| addf $r1, r0, r2$ ; $(r2 = TI = r0 + r1)$<br>mpyf *ar1, r7, r0 ; $r0 = BR * COS$ ,<br>; $(r3 = AI + TI)$<br>11 addf $r2, *ar0, r3$<br>sub $r2, *ar0++(ir0), r4$ ; $(r4 = AI - TI , BI' = r3)$<br>11 stf $r3, *ar3++(ir0)$<br>addf $r0, r5, r3$ ; $r3 = TR = r0 + r5$<br>mpyf *ar1++, r6, r0 ; $r0 = BR * SIN , r2 = AR - TI$<br>11 subf $r3, *ar0, r2$<br>mpyf *ar1++, r7, r1 ; $r1 = BI * COS , (AI' = r4)$<br>11 stf $r4, *ar2++(ir0)$<br>addf *ar0++, r3, r5 ; $r5 = AR + TR , BR' = r2$<br>11 stf $r2, *ar3++$<br>mpyf *tar1, r6, r5 ; $r5 = BI * SIN , (AR' = r5)$<br>11 stf $r2, *ar0+7$<br>11 addf $r2, *ar0, r3$<br>subf $r1, r0, r2$ ; $(r2 = TI = r0 - r1)$<br>mpyf *ar1, r7, r0 ; $r0 = BR * COS$ ,<br>11 addf $r2, *ar0+7$ ; $r3 = TR = r0 + r5$<br>mpyf *ar1++, r6, r0 ; $r3 = TR = r0 + r5$<br>mpyf *ar1++, r6, r0 ; $r0 = BR * SIN , r2 = AR - T$<br>11 stf $r3, *ar3++$<br>addf $r0, r5, r3$ ; $r3 = TR = r0 + r5$<br>mpyf *ar1++, r6, r0 ; $r0 = BR * SIN , r2 = AR - T$<br>11 stf $r3, *ar3++$<br>addf $r4, *ar2++$<br>addf $r2, *ar3++$<br>r3 = AR + TR , BR' = r2<br>11 stf $r4, *ar2++$<br>addf $*ar0++, r3, r3$ ; $r3 = AR + TR , BR' = r2$<br>11 stf $r4, *ar2++$<br>addf $*ar0++, r3, r3$ ; $r5 = BI * COS , (AI' = r4)$<br>12 stf $r2, *ar3++$<br>mpyf *ar1++(ir0), r7, r1 ; $r1 = BI * COS , (AI' = r4)$<br>13 stf $r2, *ar3++$<br>addf $*ar0++, r3, r3$ ; $r3 = AR + TR , BR' = r2$<br>14 stf $r4, *ar2++$<br>addf $*ar0++, r3, r3$ ; $r5 = BI * COS , (AR' = r3)$                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <pre>(r3 = AI + TI) (r3 = AI + TI) (r4 = AI - TI , BI' = r3) (r3 = AI + r5 (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r4 = AI - TI , BI' = r4) (r3 = AI + TI , BI' = r4) (r3 = AI + TI , BI' = r4) (r3 = AI + TI , BI' = r4) (r3 = AI + TI , BI' = r4) (r3 = AI + TI , BI' = r4) (r4 = AI - TI , BI' = r5) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r3) (r3 = AI + TI , BI' = r4) (r3 = AI + r5 , r3 = TR = r0 + r5 (r3 = AI + TI , BI' = r4) (r3 = AI + r6, r0 ; r0 = BR * SIN , r2 = AR - T (r3 = AI + TI , BI' = r4) (r3 = AI + (ir0), r7, r1 ; r1 = BI * COS , (AI' = r4) (r3 = AI + r3, r3 ; r3 = AR + TR , BR' = r2 (r3 = AI + TR , BR' = r2 (r3 = AI + TR , BR' = r2 (r3 = AI + TR , BR' = r2 (r3 = AI + TR , BR' = r2 (r3 = AI + TR , BR' = r2 (r3 = AI + TR , BR' = r2 (r4 = AI - TI , BI' = r3) (r3 = AI + TI , AI + r4) (r3 = AI + r5 , r3 = r6 + r5 (r3 = AI + r6, r0 ; r3 = AR + TR , BR' = r2 (r3 = AI + TR , BR' = r2 (r4 = AI - TI , BI' = r4) (r3 = AI + r6, r0 ; r1 = BI * COS , (AI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r3) (r4 = AI - TI , BI' = r3) (r4 = AI - TI , BI' = r3) (r4 = AI - TI , BI' = r3) (r4 = AI - TI , BI' = r3) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI - TI , BI' = r4) (r4 = AI</pre> |
| <pre>sub r2,*ar0++(ir0),r4 ; (r4 = AI - TI , BI' = r3)<br/>addf r3,*ar3++(ir0)<br/>addf r0,r5,r3 ; r3 = TR = r0 + r5<br/>mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T<br/>mpyf *ar1++,r7,r1 ; r1 = BI * COS , (AI' = r4)<br/>addf *ar0++,r3,r5 ; r5 = AR + TR , BR' = r2<br/>istf r2,*ar3++<br/>mpyf *ar1,r6,r5 ; r5 = BI * SIN , (AR' = r5)<br/>istf r5,*ar2++<br/>subf r1,r0,r2 ; (r2 = TI = r0 - r1)<br/>mpyf *ar1,r7,r0 ; r0 = BR * COS ,<br/>; (r3 = AI + TI)<br/>istf r2,*ar0,r3 ; r3 = TR = r0 + r5<br/>mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T<br/>istf r3,*ar3++<br/>addf r0,r5,r3 ; r3 = TR = r0 + r5<br/>mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T<br/>istf r3,*ar3++<br/>addf r0,r5,r3 ; r3 = TR = r0 + r5<br/>mpyf *ar1++(ir0),r7,r1 ; r1 = BI * COS , (AI' = r4)<br/>istf r4,*ar2++<br/>addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2<br/>istf r2,*ar3++<br/>mpyf *ar1++(ir0),r7,r1 ; r1 = BI * COS , (AI' = r4)<br/>istf r4,*ar2++<br/>addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2<br/>istf r2,*ar3++<br/>mpyf *ar1+, 7,r5 ; r5 = BI * COS , (AR' = r3)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| addf $r0, r5, r3$ ; $r3 = TR = r0 + r5$<br>mpyf *arl++, r6, r0 ; $r0 = BR * SIN$ , $r2 = AR - TF$<br>is subf $r3, *ar0, r2$<br>mpyf *arl++, r7, r1 ; $r1 = BI * COS$ , $(AI' = r4)$<br>is stf $r4, *ar2++(ir0)$<br>addf *ar0++, r3, r5 ; $r5 = AR + TR$ , $BR' = r2$<br>is stf $r2, *ar3++$<br>mpyf *+ar1, r6, r5 ; $r5 = BI * SIN$ , $(AR' = r5)$<br>is stf $r5, *ar2++$<br>subf $r1, r0, r2$ ; $(r2 = TI = r0 - r1)$<br>mpyf *ar1, r7, r0 ; $r0 = BR * COS$ ,<br>; $(r3 = AI + TI)$<br>is stf $r3, *ar3++$<br>addf $r0, r5, r3$ ; $r3 = TR = r0 + r5$<br>mpyf *ar1++, r6, r0 ; $r0 = BR * SIN$ , $r2 = AR - T$<br>is subf $r3, *ar0, r2$<br>mpyf *ar1++, r6, r0 ; $r1 = BI * COS$ , $(AI' = r4)$<br>is stf $r3, *ar3++$<br>addf $r4, *ar2++$<br>addf $r4, *ar2++$<br>addf $r4, *ar2++$<br>addf $r2, *ar3++$<br>mpyf *ar1++, r7, r5 ; $r5 = BI * COS$ , $(AI' = r3)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| addf $r0, r5, r3$ ; $r3 = TR = r0 + r5$<br>mpyf *arl++, r6, r0 ; $r0 = BR * SIN$ , $r2 = AR - TF$<br>is subf $r3, *ar0, r2$<br>mpyf *arl++, r7, r1 ; $r1 = BI * COS$ , $(AI' = r4)$<br>is stf $r4, *ar2++(ir0)$<br>addf *ar0++, r3, r5 ; $r5 = AR + TR$ , $BR' = r2$<br>is stf $r2, *ar3++$<br>mpyf *+ar1, r6, r5 ; $r5 = BI * SIN$ , $(AR' = r5)$<br>is stf $r5, *ar2++$<br>subf $r1, r0, r2$ ; $(r2 = TI = r0 - r1)$<br>mpyf *ar1, r7, r0 ; $r0 = BR * COS$ ,<br>; $(r3 = AI + TI)$<br>is stf $r3, *ar3++$<br>addf $r0, r5, r3$ ; $r3 = TR = r0 + r5$<br>mpyf *ar1++, r6, r0 ; $r0 = BR * SIN$ , $r2 = AR - T$<br>is subf $r3, *ar0, r2$<br>mpyf *ar1++, r6, r0 ; $r1 = BI * COS$ , $(AI' = r4)$<br>is stf $r3, *ar3++$<br>addf $r4, *ar2++$<br>addf $r4, *ar2++$<br>addf $r4, *ar2++$<br>addf $r2, *ar3++$<br>mpyf *ar1++, r7, r5 ; $r5 = BI * COS$ , $(AI' = r3)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| addf *ar0++,r3,r5 ; r5 = AR + TR , BR' = r2<br>i stf r2,*ar3++<br>mpyf *+ar1,r6,r5 ; r5 = BI * SIN , (AR' = r5)<br>stf r5,*ar2++<br>subf r1,r0,r2 ; (r2 = TI = r0 - r1)<br>mpyf *ar1,r7,r0 ; r0 = BR * COS ,<br>; (r3 = AI + TI)<br>i addf r2,*ar0,r3<br>subf r2,*ar0++,r4 ; (r4 = AI - TI , BI' = r3)<br>i stf r3,*ar3++<br>addf r0,r5,r3 ; r3 = TR = r0 + r5<br>mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T<br>i subf r3,*ar0,r2<br>mpyf *ar1++(ir0),r7,r1 ; r1 = BI * COS , (AI' = r4)<br>i stf r4,*ar2++<br>addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2<br>i stf r2,*ar3++<br>mpyf *ar1,r7,r5 ; r5 = BI * COS , (AR' = r3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <pre>; (r3 = AI + TI) ; (r3 = AI + TI) ; (r3 = AI + TI) ; (r4 = AI - TI , BI' = r3) ; r3 = TR = r0 + r5 ; r0 = BR * SIN , r2 = AR - T; ; r1 = BI * COS , (AI' = r4) ; r1 = BI * COS , (AI' = r4) ; r2 = AR - T; ; r3 = AR + TR , BR' = r2 ; r3 = AR + TR , BR' = r2 ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) </pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <pre>; (r3 = AI + TI) ; (r3 = AI + TI) ; (r3 = AI + TI) ; (r4 = AI - TI , BI' = r3) ; r3 = TR = r0 + r5 ; r0 = BR * SIN , r2 = AR - T; ; r1 = BI * COS , (AI' = r4) ; r1 = BI * COS , (AI' = r4) ; r2 = AR - T; ; r3 = AR + TR , BR' = r2 ; r3 = AR + TR , BR' = r2 ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) ; r5 = BI * COS , (AR' = r3) </pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <pre>11 addf r2,*ar0,r3<br/>subf r2,*ar0++,r4 ; (r4 = AI - TI , BI' = r3)<br/>11 stf r3,*ar3++<br/>addf r0,r5,r3 ; r3 = TR = r0 + r5<br/>mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T<br/>11 subf r3,*ar0,r2<br/>mpyf *ar1++(ir0),r7,r1 ; r1 = BI * COS , (AI' = r4)<br/>11 stf r4,*ar2++<br/>addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2<br/>11 stf r2,*ar3++<br/>mpyf *+ar1,r7,r5 ; r5 = BI * COS , (AR' = r3)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <pre>subf r2,*ar0++,r4 ; (r4 = AI - TI , BI' = r3) il stf r3,*ar3++ addf r0,r5,r3 ; r3 = TR = r0 + r5 mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T il subf r3,*ar0,r2 mpyf *ar1++(ir0),r7,r1 ; r1 = BI * COS , (AI' = r4) il stf r4,*ar2++ addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2 il stf r2,*ar3++ mpyf *+ar1,r7,r5 ; r5 = BI * COS , (AR' = r3)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <pre>   stf r3,*ar3++     addf r0,r5,r3 ; r3 = TR = r0 + r5     mpyf *ar1++,r6,r0 ; r0 = BR * SIN , r2 = AR - T    subf r3,*ar0,r2     mpyf *ar1++(ir0),r7,r1 ; r1 = BI * COS , (AI' = r4)    stf r4,*ar2++     addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2    stf r2,*ar3++     mpyf *+ar1,r7,r5 ; r5 = BI * COS , (AR' = r3)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| addf       r0,r5,r3       ; r3 = TR = r0 + r5         mpyf       *ar1++,r6,r0       ; r0 = BR * SIN , r2 = AR - T         ii       subf       r3,*ar0,r2         mpyf       *ar1++(ir0),r7,r1       ; r1 = BI * COS , (AI' = r4)         ii       stf       r4,*ar2++         addf       *ar0++,r3,r3       ; r3 = AR + TR , BR' = r2         iii       stf       r2,*ar3++         mpyf       *+ar1,r7,r5       ; r5 = BI * COS , (AR' = r3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <pre>mpyf *arl++,r6,r0 ; r0 = BR * SIN , r2 = AR - T subf r3,*ar0,r2 mpyf *arl++(ir0),r7,r1 ; r1 = BI * COS , (AI' = r4) stf r4,*ar2++ addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2 stf r2,*ar3++ mpyf *+ar1,r7,r5 ; r5 = BI * COS , (AR' = r3)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <pre>   subf r3,*ar0,r2<br/>mpyf *ar1++(ir0),r7,r1 ; r1 = BI * COS , (AI' = r4)<br/>   stf r4,*ar2++<br/>addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2<br/>   stf r2,*ar3++<br/>mpyf *+ar1,r7,r5 ; r5 = BI * COS , (AR' = r3)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <pre>mpyf *arl++(ir0),r7,r1 ; r1 = BI * COS , (AI' = r4) ll stf r4,*ar2++ addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2 ll stf r2,*ar3++ mpyf *+ar1,r7,r5 ; r5 = BI * COS , (AR' = r3)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <pre>   stf r4,*ar2++<br/>addf *ar0++,r3,r3 ; r3 = AR + TR , BR' = r2<br/>   stf r2,*ar3++<br/>mpyf *+ar1,r7,r5 ; r5 = BI * COS , (AR' = r3)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| addf       *ar0++,r3,r3       ; r3 = AR + TR , BR' = r2                  stf       r2,*ar3++         mpyf       *+ar1,r7,r5       ; r5 = BI * COS , (AR' = r3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <pre>   stf r2,*ar3++ mpyf *+ar1,r7,r5 ; r5 = BI * COS , (AR' = r3)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <pre>   stf r2,*ar3++ mpyf *+ar1,r7,r5 ; r5 = BI * COS , (AR' = r3)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| mpyf $*+ar1, r7, r5$ ; $r5 = BI * COS$ , $(AR' = r3)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| stf r3,*ar2++                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| subf $r1, r0, r2$ ; $(r2 = TI = r0 - r1)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| mpyf $*ar1, r6, r0$ ; $r0 = BR * SIN$ ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| (r3 = AI + TI)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| addf r2,*ar0,r3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| sub $r_2, *ar_0++(ir_0), r_4$ ; $(r_4 = AI - TI, BI' = r_3)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| stf r3,*ar3++(ir0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| subf $r0, r5, r3$ ; $r3 = TR = r5 - r0$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| mpyf $*ar1++, r7, r0$ ; $r0 = BR * COS$ , $r2 = AR - T$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| subf r3,*ar0,r2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| mpyf *arl++,r6,r1 ; r1 = BI * SIN , (AI' = r4)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| stf r4,*ar2++(ir0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| addf $*ar0++, r3, r5$ ; $r5 = AR + TR$ , $BR' = r2$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| stf r2,*ar3++                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

Software Applications

- 10

|                                  | mpyf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | *+ar1,r7,r5                                                                                                   | ; r                                     | 5 = BI * COS, (AR' = r5)                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11                               | stf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r5,*ar2++                                                                                                     |                                         |                                                                                                                                                                                                                                                                                                                                                                                         |
|                                  | addf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | r1, r0, r2                                                                                                    | ; z                                     | (r2 = TI = r0 + r1)                                                                                                                                                                                                                                                                                                                                                                     |
|                                  | mpyf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                               |                                         | 0 = BR * SIN ,                                                                                                                                                                                                                                                                                                                                                                          |
|                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | • • • • • • •                                                                                                 |                                         | 3 = AI + TI                                                                                                                                                                                                                                                                                                                                                                             |
| 11                               | addf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | r2,*ar0,r3                                                                                                    |                                         | ,                                                                                                                                                                                                                                                                                                                                                                                       |
|                                  | subf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | r2,*ar0++,r4                                                                                                  | : (                                     | r4 = AI - TI ,                                                                                                                                                                                                                                                                                                                                                                          |
|                                  | 0 4.0 -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                               |                                         | (L) = BI' = r3)                                                                                                                                                                                                                                                                                                                                                                         |
| 11                               | stf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r3,*ar3++                                                                                                     | · 1                                     | (=, == ==)                                                                                                                                                                                                                                                                                                                                                                              |
|                                  | subf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | r0, r5, r3                                                                                                    | ; r                                     | 3 = TR = r5 - r0                                                                                                                                                                                                                                                                                                                                                                        |
|                                  | mpyf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | *ar1++,r7,r0                                                                                                  |                                         | 0 = BR * COS ,                                                                                                                                                                                                                                                                                                                                                                          |
|                                  | mpyr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | a11,1,1,1,10                                                                                                  |                                         | 2 = AR - TR                                                                                                                                                                                                                                                                                                                                                                             |
| 11                               | subf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | r3,*ar0,r2                                                                                                    | , -                                     |                                                                                                                                                                                                                                                                                                                                                                                         |
| bf2end                           | mpyf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | *arl++(ir0),r6,r1                                                                                             |                                         | 1 = BI * SIN,                                                                                                                                                                                                                                                                                                                                                                           |
| Drzena                           | шруг                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | "all" (110),10,11                                                                                             |                                         | 3 = AR + TR                                                                                                                                                                                                                                                                                                                                                                             |
|                                  | - d d f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | *~~0++ ~~2 ~~2                                                                                                | ; 1                                     | 3 - AK + IK                                                                                                                                                                                                                                                                                                                                                                             |
| 11                               | addf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | *ar0++,r3,r3                                                                                                  |                                         |                                                                                                                                                                                                                                                                                                                                                                                         |
| *                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                               |                                         |                                                                                                                                                                                                                                                                                                                                                                                         |
| ^ clear                          | pipeline                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                               |                                         |                                                                                                                                                                                                                                                                                                                                                                                         |
|                                  | stf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r2,*ar3++                                                                                                     | ;                                       | BR' = r2 , $AI' = r4$                                                                                                                                                                                                                                                                                                                                                                   |
|                                  | stf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r4,*ar2++                                                                                                     |                                         |                                                                                                                                                                                                                                                                                                                                                                                         |
|                                  | add                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r1,r0,r2                                                                                                      |                                         | r2 = TI = r0 + r1                                                                                                                                                                                                                                                                                                                                                                       |
|                                  | add                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r2,*ar0,r3                                                                                                    | ;                                       | r3 = AI + TI, $AR' = r3$                                                                                                                                                                                                                                                                                                                                                                |
| 11                               | stf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r3,*ar2++                                                                                                     |                                         |                                                                                                                                                                                                                                                                                                                                                                                         |
|                                  | subf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | r2,*ar0,r4                                                                                                    | ;                                       | r4 = AI - TI, $BI' = r3$                                                                                                                                                                                                                                                                                                                                                                |
| 11                               | stf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r3,*ar3                                                                                                       |                                         |                                                                                                                                                                                                                                                                                                                                                                                         |
|                                  | stf                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | r4,*ar2                                                                                                       | ;                                       | AI' = r4                                                                                                                                                                                                                                                                                                                                                                                |
|                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                               |                                         |                                                                                                                                                                                                                                                                                                                                                                                         |
| ******                           | *********                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | *****                                                                                                         | ****                                    | ******                                                                                                                                                                                                                                                                                                                                                                                  |
| *                                | тлс                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                               |                                         |                                                                                                                                                                                                                                                                                                                                                                                         |
|                                  | TAS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ST STAGE                                                                                                      |                                         | *                                                                                                                                                                                                                                                                                                                                                                                       |
|                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                               | ****                                    | *<br>*********                                                                                                                                                                                                                                                                                                                                                                          |
|                                  | *****                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | *****                                                                                                         |                                         |                                                                                                                                                                                                                                                                                                                                                                                         |
|                                  | **********<br>ldi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | **************************************                                                                        | ;                                       | upper input                                                                                                                                                                                                                                                                                                                                                                             |
|                                  | ***********<br>ldi<br>ldi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | **************************************                                                                        | ;;                                      | upper input<br>upper output                                                                                                                                                                                                                                                                                                                                                             |
|                                  | ***********<br>ldi<br>ldi<br>ldi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <pre>************************************</pre>                                                               | ;;;                                     | upper input<br>upper output<br>lower input                                                                                                                                                                                                                                                                                                                                              |
|                                  | **************************************                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <pre>************************************</pre>                                                               | ;;;;                                    | upper input<br>upper output<br>lower input<br>lower output                                                                                                                                                                                                                                                                                                                              |
|                                  | ***********<br>ldi<br>ldi<br>ldi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <pre>************************************</pre>                                                               | ;;;;;;                                  | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle                                                                                                                                                                                                                                                                                                        |
|                                  | ***********<br>ldi<br>ldi<br>ldi<br>ldi<br>ldi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <pre>************************************</pre>                                                               | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors                                                                                                                                                                                                                                                                                             |
|                                  | ***********<br>ldi<br>ldi<br>ldi<br>ldi<br>ldi<br>ldi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <pre>@input,ar0 ar0,ar2 @inputp2,ar1 ar1,ar3 @sintp2,ar7 3,ir0</pre>                                          | ;;;;;;                                  | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors                                                                                                                                                                                                                                                                                             |
|                                  | ***********<br>ldi<br>ldi<br>ldi<br>ldi<br>ldi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <pre>************************************</pre>                                                               | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors                                                                                                                                                                                                                                                                                             |
| *****                            | ***********<br>ldi<br>ldi<br>ldi<br>ldi<br>ldi<br>ldi<br>ldi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <pre>@input,ar0 ar0,ar2 @inputp2,ar1 ar1,ar3 @sintp2,ar7 3,ir0</pre>                                          | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors                                                                                                                                                                                                                                                                                             |
| *******<br>* fill p              | **********<br>ldi<br>ldi<br>ldi<br>ldi<br>ldi<br>ldi<br>pipeline                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <pre>%************************************</pre>                                                              | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors                                                                                                                                                                                                                                                                                             |
| *******<br>* fill p              | <pre>********** ldi ldi ldi ldi ldi ldi ldi compeline cterfly: w'</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <pre>%************************************</pre>                                                              | ;;;;;;;;                                | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors<br>group offset                                                                                                                                                                                                                                                                             |
| *******<br>* fill p              | <pre>********** ldi ldi ldi ldi ldi ldi ldi cipeline cterfly: w' addf</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <pre>%************************************</pre>                                                              | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors<br>group offset<br>AR' = r6 = AR + BR                                                                                                                                                                                                                                                       |
| *******<br>* fill p              | <pre>********** ldi ldi ldi ldi ldi ldi ldi cipeline cterfly: w' addf subf</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <pre>%************************************</pre>                                                              | ;;;;;;;;                                | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors<br>group offset<br>AR' = r6 = AR + BR<br>BR' = r7 = AR - BR                                                                                                                                                                                                                                 |
| *******<br>* fill p              | <pre>********** ldi ldi ldi ldi ldi ldi ldi cipeline cterfly: w' addf subf addf</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <pre>%************************************</pre>                                                              | ;;;;;;;                                 | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors<br>group offset<br>AR' = r6 = AR + BR                                                                                                                                                                                                                                                       |
| *******<br>* fill p              | <pre>********** ldi ldi ldi ldi ldi ldi ldi cipeline cterfly: w' addf subf</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <pre>%************************************</pre>                                                              | ;;;;;;;                                 | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors<br>group offset<br>AR' = r6 = AR + BR<br>BR' = r7 = AR - BR<br>AI' = r4 = AI + BI                                                                                                                                                                                                           |
| *******<br>* fill r<br>* 1. but  | <pre>the state of the state of</pre> | <pre>@input, ar0<br/>ar0, ar2<br/>@inputp2, ar1<br/>ar1, ar3<br/>@sintp2, ar7<br/>3, ir0<br/>@fg4m2, rc</pre> | ;;;;;;;                                 | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors<br>group offset<br>AR' = r6 = AR + BR<br>BR' = r7 = AR - BR                                                                                                                                                                                                                                 |
| *******<br>* fill r<br>* 1. but  | <pre>********** ldi ldi ldi ldi ldi ldi ldi suppline cterfly: w' addf subf addf subf subf</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <pre>@input, ar0<br/>ar0, ar2<br/>@inputp2, ar1<br/>ar1, ar3<br/>@sintp2, ar7<br/>3, ir0<br/>@fg4m2, rc</pre> | ;;;;;;;                                 | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors<br>group offset<br>AR' = r6 = AR + BR<br>BR' = r7 = AR - BR<br>AI' = r4 = AI + BI<br>BI' = r5 = AI - BI                                                                                                                                                                                     |
| *******<br>* fill r<br>* 1. but  | <pre>********** ldi ldi ldi ldi ldi ldi ldi subf addf subf subf subf subf</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <pre>@input, ar0<br/>ar0, ar2<br/>@inputp2, ar1<br/>ar1, ar3<br/>@sintp2, ar7<br/>3, ir0<br/>@fg4m2, rc</pre> | ;;;;;;;                                 | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors<br>group offset<br>AR' = r6 = AR + BR<br>BR' = r7 = AR - BR<br>AI' = r4 = AI + BI<br>BI' = r5 = AI - BI<br>AR' = r3 = AR + BI                                                                                                                                                               |
| * fill r<br>* 1. but<br>* 2. but | <pre>********** ldi ldi ldi ldi ldi ldi ldi subf addf subf subf subf terfly: w' addf ldf</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <pre>@input, ar0<br/>ar0, ar2<br/>@inputp2, ar1<br/>ar1, ar3<br/>@sintp2, ar7<br/>3, ir0<br/>@fg4m2, rc</pre> | ;;;;;;;                                 | <pre>upper input<br/>upper output<br/>lower input<br/>lower output<br/>pointer to twiddle<br/>factors<br/>group offset<br/>AR' = r6 = AR + BR<br/>BR' = r7 = AR - BR<br/>AI' = r4 = AI + BI<br/>BI' = r5 = AI - BI<br/>AR' = r3 = AR + BI<br/>r1 = 0 (for inner loop)</pre>                                                                                                             |
| *******<br>* fill r<br>* 1. but  | <pre>********** ldi ldi ldi ldi ldi ldi ldi subf addf subf subf subf terfly: w' addf ldf ldf</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <pre>@input, ar0<br/>ar0, ar2<br/>@inputp2, ar1<br/>ar1, ar3<br/>@sintp2, ar7<br/>3, ir0<br/>@fg4m2, rc</pre> | ;;;;;;;                                 | <pre>upper input<br/>upper output<br/>lower input<br/>lower output<br/>pointer to twiddle<br/>factors<br/>group offset<br/>AR' = r6 = AR + BR<br/>BR' = r7 = AR - BR<br/>AI' = r4 = AI + BI<br/>BI' = r5 = AI - BI<br/>AR' = r3 = AR + BI<br/>r1 = 0 (for inner loop)<br/>r0 = BR (for inner loop)</pre>                                                                                |
| * fill r<br>* 1. but<br>* 2. but | <pre>********** ldi ldi ldi ldi ldi ldi ldi subf addf subf subf subf terfly: w' addf ldf ldf ldf ldf rptbd</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <pre>@input, ar0<br/>ar0, ar2<br/>@inputp2, ar1<br/>ar1, ar3<br/>@sintp2, ar7<br/>3, ir0<br/>@fg4m2, rc</pre> | ;;;;;;;                                 | <pre>upper input<br/>upper output<br/>lower input<br/>lower output<br/>pointer to twiddle<br/>factors<br/>group offset<br/>AR' = r6 = AR + BR<br/>BR' = r7 = AR - BR<br/>AI' = r4 = AI + BI<br/>BI' = r5 = AI - BI<br/>AR' = r3 = AR + BI<br/>r1 = 0 (for inner loop)<br/>r0 = BR (for inner loop)<br/>Setup for loop bflend</pre>                                                      |
| * fill r<br>* 1. but<br>* 2. but | <pre>********** ldi ldi ldi ldi ldi ldi ldi cterfly: w' addf subf subf subf cterfly: w' addf ldf ldf ldf subf</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <pre>@input, ar0<br/>ar0, ar2<br/>@inputp2, ar1<br/>ar1, ar3<br/>@sintp2, ar7<br/>3, ir0<br/>@fg4m2, rc</pre> | ;;;;;;;                                 | upper input<br>upper output<br>lower input<br>lower output<br>pointer to twiddle<br>factors<br>group offset<br>AR' = r6 = AR + BR<br>BR' = r7 = AR - BR<br>AI' = r4 = AI + BI<br>BI' = r5 = AI - BI<br>AR' = r3 = AR + BI<br>r1 = 0 (for inner loop)<br>r0 = BR (for inner loop)<br>Setup for loop bflend<br>BR' = r2 = AR - BI                                                         |
| * fill r<br>* 1. but<br>* 2. but | <pre>********** ldi ldi ldi ldi ldi ldi ldi cterfly: w' addf addf subf subf subf subf subf subf subf sub</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <pre>@input, ar0<br/>ar0, ar2<br/>@inputp2, ar1<br/>ar1, ar3<br/>@sintp2, ar7<br/>3, ir0<br/>@fg4m2, rc</pre> | ;;;;;;;                                 | <pre>upper input<br/>upper output<br/>lower input<br/>lower output<br/>pointer to twiddle<br/>factors<br/>group offset<br/>AR' = r6 = AR + BR<br/>BR' = r7 = AR - BR<br/>AI' = r4 = AI + BI<br/>BI' = r5 = AI - BI<br/>AR' = r3 = AR + BI<br/>r1 = 0 (for inner loop)<br/>r0 = BR (for inner loop)<br/>Setup for loop bflend<br/>BR' = r2 = AR - BI<br/>(AR' = r6)</pre>                |
| * fill r<br>* 1. but<br>* 2. but | <pre>********** ldi ldi ldi ldi ldi ldi ldi ldi subf addf subf addf ldf ldf ldf ldf subf subf stf stf</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <pre>@input, ar0<br/>ar0, ar2<br/>@inputp2, ar1<br/>ar1, ar3<br/>@sintp2, ar7<br/>3, ir0<br/>@fg4m2, rc</pre> | ;;;;;;;                                 | <pre>upper input<br/>upper output<br/>lower input<br/>lower output<br/>pointer to twiddle<br/>factors<br/>group offset<br/>AR' = r6 = AR + BR<br/>BR' = r7 = AR - BR<br/>AI' = r4 = AI + BI<br/>BI' = r5 = AI - BI<br/>AR' = r3 = AR + BI<br/>r1 = 0 (for inner loop)<br/>r0 = BR (for inner loop)<br/>Setup for loop bflend<br/>BR' = r2 = AR - BI<br/>(AR' = r6)<br/>(BR' = r7)</pre> |
| * fill r<br>* 1. but<br>* 2. but | <pre>********** ldi ldi ldi ldi ldi ldi ldi cterfly: w' addf addf subf subf subf subf subf subf subf sub</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <pre>@input, ar0<br/>ar0, ar2<br/>@inputp2, ar1<br/>ar1, ar3<br/>@sintp2, ar7<br/>3, ir0<br/>@fg4m2, rc</pre> | ;;;;;;;                                 | <pre>upper input<br/>upper output<br/>lower input<br/>lower output<br/>pointer to twiddle<br/>factors<br/>group offset<br/>AR' = r6 = AR + BR<br/>BR' = r7 = AR - BR<br/>AI' = r4 = AI + BI<br/>BI' = r5 = AI - BI<br/>AR' = r3 = AR + BI<br/>r1 = 0 (for inner loop)<br/>r0 = BR (for inner loop)<br/>Setup for loop bflend<br/>BR' = r2 = AR - BI<br/>(AR' = r6)</pre>                |

12-85

| Example 12–41. Fa | aster Version Complex, I | Radix-2 DIT FFT | (Continued) |
|-------------------|--------------------------|-----------------|-------------|
|-------------------|--------------------------|-----------------|-------------|

|    | * 3. to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | M. butterf          | 1                   |     |                                                                                                                                                                                                                                    |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | loop bfle           | -y.                 |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ldf                 | *ar7++,r7           |     | r7 = COS , ((AI' = r4))                                                                                                                                                                                                            |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | stf                 | r4,*ar2++(ir0)      | '   | 17 = 000 7 ((M1 = 14))                                                                                                                                                                                                             |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ldf                 | *ar7++, r6          |     | r6 = SIN , (BR' = r2)                                                                                                                                                                                                              |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |                     | ,   | 10 = 51N, (BK = 12)                                                                                                                                                                                                                |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | stf                 | r2,*ar3++           |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | mpyf                | *+ar1,r6,r5         |     | r5 = BI * SIN,                                                                                                                                                                                                                     |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |                     | ;   | (AR' = r3)                                                                                                                                                                                                                         |
|    | II.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | stf                 | r3,*ar2++           |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | addf                | r1,r0,r2            |     | (r2 = TI = r0 + r1)                                                                                                                                                                                                                |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | mpyf                | *ar1,r7,r0          |     | r0 = BR * COS,                                                                                                                                                                                                                     |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |                     | ;   | (r3 = AI + TI)                                                                                                                                                                                                                     |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | addf                | r2,*ar0,r3          |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | subf                | r2,*ar0++(ir0),r4   | -   | (r4 = AI - TI)                                                                                                                                                                                                                     |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |                     | ;   | BI' = r3)                                                                                                                                                                                                                          |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |                     |     |                                                                                                                                                                                                                                    |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | stf                 | r3,*ar3++(ir0)      |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | addf                | r0, r5, r3          | ;   | r3 = TR = r0 + r5                                                                                                                                                                                                                  |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | mpyf                | *ar1++,r6,r0        |     | r0 = BR * SIN,                                                                                                                                                                                                                     |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     | //                  |     | r2 = AR - TR                                                                                                                                                                                                                       |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | subf                | r3,*ar0,r2          |     |                                                                                                                                                                                                                                    |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | mpyf                | *arl++(ir0),r7,r1   |     | r1 = BI *, COS                                                                                                                                                                                                                     |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | шруг                | a1111 (110),17,11   |     | (AI' = r4)                                                                                                                                                                                                                         |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | a+ <b>f</b>         | r4,*ar2++(ir0)      | '   | (AI - I4)                                                                                                                                                                                                                          |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | stf                 |                     |     | $m^2 = 3D + TD - DD = m^2$                                                                                                                                                                                                         |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | addf                | *ar0++,r3,r3        | ;   | r3 = AR + IR, BR' = r2                                                                                                                                                                                                             |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | r2,*ar3++           |                     |     | 5 DT # 202                                                                                                                                                                                                                         |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | mpyf                | *+ar1,r7,r5         |     | r5 = BI * COS,                                                                                                                                                                                                                     |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |                     | ;   | (AR' = r3)                                                                                                                                                                                                                         |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | stf                 | r3,*ar2++           |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | subf                | r1,r0,r2            | ;   | (r2 = TI = r0 - r1)                                                                                                                                                                                                                |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | mpyf                | *ar1,r6,r0          | ;   | r0 = BR * SIN,                                                                                                                                                                                                                     |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |                     | ;   | (r3 = AI + TI)                                                                                                                                                                                                                     |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | addf                | r2,*ar0,r3          |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | subf                | r2,*ar0++(ir0),r4   | ;   | (r4 = AI - TI)                                                                                                                                                                                                                     |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |                     | ;   | BI' = r3                                                                                                                                                                                                                           |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | stf                 | r3,*ar3++(ir0)      |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | subf                | r0, r5, r3          | ;   | r3 = TR = r0 - r5                                                                                                                                                                                                                  |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | mpyf                | *ar1++,r7,r0        |     | r0 = BR * COS                                                                                                                                                                                                                      |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1 1                 | • • • • •           |     | r2 = AR - IR                                                                                                                                                                                                                       |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | subf                | r3,*ar0,r2          |     |                                                                                                                                                                                                                                    |
|    | bflend                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | mpyf                | *ar1++(ir0),r6,r1   |     | r1 = BI * SIN,                                                                                                                                                                                                                     |
|    | <i>D</i> 0u                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | mpy -               | 411. (110) / 10/ 11 |     | r3 = AR + TR                                                                                                                                                                                                                       |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | addf                | *ar0++,r3,r3        | '   |                                                                                                                                                                                                                                    |
|    | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | auur                | alo++,15,15         |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |                     |     |                                                                                                                                                                                                                                    |
|    | <b>1</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | · · · · · · · · · · |                     |     |                                                                                                                                                                                                                                    |
|    | * clear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | pipeline            |                     |     |                                                                                                                                                                                                                                    |
|    | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | stf                 | r2,*ar3++           | ; ; | BR' = r2, (AI' = r4)                                                                                                                                                                                                               |
|    | 11 S.A.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | stf                 | r4,*ar2++(ir0)      |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | addf                | r1,r0,r2            |     | r2 = TI = r0 + r1                                                                                                                                                                                                                  |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | addf                | r2,*ar0,r3          | ;   | r3 = AI + TI, $AR' = r3$                                                                                                                                                                                                           |
|    | TI Sherre                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | stf                 | r3,*ar2++           |     |                                                                                                                                                                                                                                    |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | subf                | r2,*ar0,r4          | ;   | r4 = AI - TI, $BI' = r3$                                                                                                                                                                                                           |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | stf                 | r3,*ar3             | •   |                                                                                                                                                                                                                                    |
| 10 | ••                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | stf                 | r4,*ar2             | :   | AI' = r4                                                                                                                                                                                                                           |
| 12 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |                     |     | n an an an Arran an A<br>Arran an Arran an Arr |
|    | <ul> <li>A second sec<br/>second second sec</li></ul> |                     |                     |     |                                                                                                                                                                                                                                    |

12-86

Software Applications

| Example 12-41. | Faster Version Complex  | , Radix-2 DIT FFT | (Concluded) |
|----------------|-------------------------|-------------------|-------------|
|                | rasiei veisiun uunipiex | , naux-2 DII FFI  | (Concluded) |

|               |                                                              | OF FFT*<br>******************************                                                                                                               |
|---------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| *             | BIT                                                          | **************************************                                                                                                                  |
|               | ldi<br>ldi<br>ldi<br>ldi<br>subi                             | <pre>@fftsiz,ir0 2,ir1 @input,ar0 @output,ar1 @fftsiz,rc 2,rc</pre>                                                                                     |
| <br>bitrv<br> | ldf<br>rptb<br>ldf<br>stf<br>ldf<br>stf<br>ldf<br>stf<br>stf | <pre>*+ar0(1),r0<br/>bitrv<br/>*ar0++(ir0)b,r1<br/>r0,*+ar1(1)<br/>*+ar0(1),r0<br/>r1,*ar1++(ir1)<br/>*ar0++(ir0)b,r1<br/>r0,*+ar1(1)<br/>r1,*ar1</pre> |
| end:          | nop<br>nop<br>nop<br>nop                                     |                                                                                                                                                         |
| self          | br self<br>.end                                              |                                                                                                                                                         |

The 'C40 quickly executes FFT lengths up to 1024 points (complex) or 2048 (real), covering most applications, because it can do so almost entirely in on-chip memory. Table 12–2 summarizes the execution time required for FFT lengths between 64 and 1024 points for the four algorithms in Example 12–37, Example 12–39, Example 12–40, and Example 12–41.

|                        | FFT Timing (in milliseconds)          |                                       |                                       |                                    |  |  |
|------------------------|---------------------------------------|---------------------------------------|---------------------------------------|------------------------------------|--|--|
| Number<br>of<br>Points | Complex<br>Radix-2<br>(Example 12–37) | Complex<br>Radix-2<br>(Example 12–41) | Complex<br>Radix-4<br>(Example 12–39) | Real<br>Radix-2<br>(Example 12–40) |  |  |
| 64                     | 0.09112                               | 0.0606                                | 0.0694                                | 0.04                               |  |  |
| 128                    | 0.2066                                | 0.13316                               | -                                     | 0.09156                            |  |  |
| 256                    | 0.46288                               | 0.3058                                | 0.36756                               | 0.20712                            |  |  |
| 512                    | 1.02636                               | 0.69208                               | -                                     | 0.45988                            |  |  |
| 1024                   | 2.25544                               | 1.54516                               | 1.82924                               | 1.01984                            |  |  |

| Table 12-2. 1 | TMS320C40 FF | T Timing | Benchmarks |
|---------------|--------------|----------|------------|
|---------------|--------------|----------|------------|

#### **12.4.5 Lattice Filters**

The lattice form is an alternative way of implementing digital filters; it has found applications in speech processing, spectral estimation, and other areas. In this discussion, the notation and terminology from speech processing applications are used.

If H(z) is the transfer function of a digital filter that has only poles, A(z) = 1/H(z) will be a filter having only zeros, and it will be called the inverse filter. The inverse lattice filter is shown in Figure 12–5. These equations describe the filter in mathematical terms:

f(i,n) = f(i-1,n) + k(i) b(i-1,n-1)b(i,n) = b(i-1,n-1) + k(i) f(i-1,n)

Initial conditions:

f(0,n) = b(0,n) = x(n)

Final conditions:

y(n) = f(p,n).

In the above equation, f(i,n) is the forward error, b(i,n) is the backward error, k(i) is the i-h reflection coefficient, x(n) is the input, and y(n) is the output signal. The order of the filter (i.e., the number of stages) is p. In the linear predictive coding (LPC) method of speech processing, the inverse lattice filter is used during analysis, and the (forward) lattice filter is used during speech synthesis.

Figure 12–5. Structure of the Inverse Lattice Filter



Figure 12–6 shows the data memory organization of the inverse lattice filter on the 'C40.





| Example 12 | 2–42. Inverse     | a Lattice Filter                      |                                                    |  |  |  |  |
|------------|-------------------|---------------------------------------|----------------------------------------------------|--|--|--|--|
| *          | TITLE INV         | VERSE LATTICE FILT                    | ER                                                 |  |  |  |  |
| *          |                   |                                       |                                                    |  |  |  |  |
| *          | SUBROUTINE LATINV |                                       |                                                    |  |  |  |  |
| *          | LATINV ==         | = LATTICE FILTER (                    | LPC INVERSE FILTER - ANALYSIS)                     |  |  |  |  |
| *          |                   |                                       |                                                    |  |  |  |  |
| *          | TIPICAL C         | CALLING SEQUENCE:                     |                                                    |  |  |  |  |
| *          | load              | R2                                    |                                                    |  |  |  |  |
|            | LAJU              | LATINV                                |                                                    |  |  |  |  |
| *          | load              | ARO                                   |                                                    |  |  |  |  |
| *          | load<br>load      | AR1<br>RC                             |                                                    |  |  |  |  |
| *          | IUau              | RC .                                  |                                                    |  |  |  |  |
| *          |                   |                                       |                                                    |  |  |  |  |
| *          | ARGUMENT          | ASSIGNMENTS:                          |                                                    |  |  |  |  |
| *          | ARGUMEN           | NT  FUNCTION                          |                                                    |  |  |  |  |
| *          | <br>R2            | f(0, n) = v(n)                        |                                                    |  |  |  |  |
| *          |                   |                                       |                                                    |  |  |  |  |
| *          | ARO<br>AR1        | ADDRESS OF BA                         | ACKWARD PROPAGATION VALUES (b(0,n-1))              |  |  |  |  |
| *          | RC                | RC = p - 2                            |                                                    |  |  |  |  |
| *          |                   |                                       |                                                    |  |  |  |  |
| *          |                   | S USED AS INPUT: F                    | , R2, R3, RS, RE, RC, AR0, AR1                     |  |  |  |  |
| *          |                   | CONTAINING RESULT                     |                                                    |  |  |  |  |
| *          |                   | · · · · · · · · · · · · · · · · · · · |                                                    |  |  |  |  |
|            | PROGRAM S         | SIZE: 11 WORDS                        |                                                    |  |  |  |  |
| *          | EVECTITIO         | N CYCLES: 5 + 3p                      |                                                    |  |  |  |  |
| *          | EVECOLIO          | 1  CICLES:  5 + 5p                    |                                                    |  |  |  |  |
| *          | •                 |                                       |                                                    |  |  |  |  |
| *          | .global 1         | LATINV                                |                                                    |  |  |  |  |
| *          | i = 1             |                                       |                                                    |  |  |  |  |
| *          |                   |                                       |                                                    |  |  |  |  |
| LATINV     | RPTBD             | LOOP                                  | ; Setup the delayed repeat                         |  |  |  |  |
|            | MPYF3             | *AR0,*AR1,R0                          | ; block loop<br>; $k(1) * b(0,n-1) \rightarrow R0$ |  |  |  |  |
|            |                   |                                       | ; Assume $f(0,n) \rightarrow R2$ .                 |  |  |  |  |
|            | LDF               | R2,R3                                 | ; Put $b(0,n) = f(0,n) \rightarrow R3$ .           |  |  |  |  |
| *          | MPYF3             | ^AKU++(1),K2,R1                       | ; k(1) * f(0,n) -> R1                              |  |  |  |  |
|            |                   |                                       |                                                    |  |  |  |  |

| *        | 2 <= i <=      | p (Repeat block l             | 00 | p start here)                                                                               |
|----------|----------------|-------------------------------|----|---------------------------------------------------------------------------------------------|
| <br>*    | MPYF3<br>ADDF3 | *AR0,*++AR1(1),R0<br>R2,R0,R2 | ;  | $k(i) * b(i-1,n-1) \rightarrow R0$<br>f(i-1-1,n) + k(i-1) *b(i-1-1,n-1)<br>= f(i-1,n) -> R2 |
| <br>*    | ADDF3<br>STF   | *-AR1(1),R1,R3<br>R3,*-AR1(1) | ;  | b(i-l-1,n-1) + k(i-1)*f(i-l-1,n)<br>= b(i-1,n) -> R3<br>b(i-l-1,n) -> b(i-l-1,n-1)          |
| L00<br>* | MPYF3          | *AR0++(1),R2,R1               | ;  | k(i) * f(i-1,n) -> R1                                                                       |
| *        | I = P + 1      | (CLEANUP)                     |    |                                                                                             |
| *        | BUD<br>ADDF3   | R11<br>R2,R0,R2               | ;  | Delayed return<br>f(p-1,n) + k(p) * b(p-1,n-1)<br>= $f(p,n) -> R2$                          |
| ^        | ADDF3          | *AR1,R1,R3                    |    | b(p-1,n-1) + k(p)*f(p-1,n)<br>= b(p,n) -> R3                                                |
| <br>*    | STF<br>NOP     | R3,*AR1                       |    | $b(p-1,n) \rightarrow b(p-1,n-1)$                                                           |
| *        | end            |                               |    |                                                                                             |
|          | .end           |                               |    |                                                                                             |

The structure of the forward lattice filter, shown in Figure 12–7, is similar to that of the inverse filter (also shown in the figure). These corresponding equations describe the lattice filter:

 $\begin{aligned} f(i-1,n) &= f(i,n) - k(i) \ b(i-1,n-1) \\ b(i,n) &= b(i-1,n-1) + k(i) \ f(i-1,n) \end{aligned}$ 

Initial conditions:

f(p,n) = x(n), b(i,n-1) = 0 for i = 1, ..., p

Final conditions:

y(n) = f(0,n).

The data memory organization is identical to that of the inverse filter, as shown in Figure 12–6. Example 12–43 shows the implementation of the lattice filter on the 'C40.

Figure 12–7. Structure of the (Forward) Lattice Filter



| Examp | le 12 | ?43. | Lattice | Filter |
|-------|-------|------|---------|--------|
|-------|-------|------|---------|--------|

| * | TITLE LATTICE FILTER                                     |
|---|----------------------------------------------------------|
| * | SUBROUTINE LATICE                                        |
|   | LAJU LATICE<br>LOAD ARO<br>LOAD AR1<br>LOA RC            |
| * |                                                          |
| * |                                                          |
| * | ARGUMENT ASSIGNMENTS:                                    |
| * | ARGUMENT   FUNCTION                                      |
| * | +                                                        |
| * | R2   $F(P,N) = E(N) = EXCITATION$                        |
| * | ARO   ADDRESS OF FILTER COEFFICIENTS (K(P))              |
| * | AR1   ADDRESS OF BACKWARD PROPAGATION                    |
| * | VALUES (B(P-1,N-1))                                      |
| * | RC   RC = P - 2                                          |
| * |                                                          |
| * | REGISTERS USED AS INPUT: R2, AR0, AR1, RC                |
| * | REGISTERS MODIFIED: R0, R1, R2, R3, RS, RE, RC, AR0, AR1 |
| * | REGISTER CONTAINING RESULT: R2 (f(0,n))                  |
| * |                                                          |
| * | PROGRAM SIZE: 13 WORDS                                   |
| * |                                                          |

Concluded on next page

Example 12–43. Lattice Filter (Concluded)

```
*
          EXECUTION CYCLES: 3 + 5P
*
          .global
                     LATICE
*
*
LATICE
          RPTBD
                     LOOP
                                                ; Setup the delayed repeat
                                                ; block loop
                     *AR0, *AR1, R0
          MPYF3
                                                ; K(P) * B(P-1, N-1) \rightarrow R0
          SUBF3
                     R0,R2,R2
                                                 ; Assume F(P,N) \rightarrow R2
          NOP
                                                 ; F(P,N)-K(P) * B(P-1,N-1)
                                                 ; = F(P-1,N) \rightarrow R2
*
*
          2 <= I <= P (Repeat block loop start here)
*
          MPYF3
                     *AR0,R2,R1
                                                 ; K(I) * F(I-1,N) -> R1
          MPYF3
                     * - -ARO(1), *-AR1(1), RO ; K(I-1) *
                                                 ; B(I-1-1,N-1) -> R0
          ADDF3
                     *AR1 - -(1), R1, R3
                                                 ; B(I-1, N-1) + K(I) * F(I-1, N)
*
                                                 ; = B(I,N) \rightarrow R3
                     R3,*+AR1(2)
                                                 ; B(I,N) \rightarrow B(I,N-1)
          STF
LOOP
          SUBF3
                     R0,R2,R2
                                                 ; F(I-1,N)-K(I-1)
                                                 ; *B(I-1-1,N-1)
*
                                                 ; = F(I-1-1,N) \rightarrow R2
*
*
          I = 1 (CLEANUP)
*
          BUD
                     R11
                                                ; Delayed return
          MPYF
                     *AR0,R2,R1
                                                ; K(1) * F(0,N) -> R1
                                                ; B(0, N-1) + K(1) * F(0, N)
          ADDF3
                     *AR1,R1,R3
*
                                                ; = B(1,N) \rightarrow R3
          STF
                     R3,*+AR1(1)
                                                ; B(1,N) \rightarrow B(1,N-1)
          STF
                     R2,*AR1
                                                 ; F(0,N) \rightarrow B(0,N-1)
11
*
*
          end
*
           end
```

# 12.5 Programming Tips

Programming style is highly personal and reflects each individual's preferences and experiences. The purpose of this section is not to impose any particular style. Instead, it emphasizes some of the features of the 'C40 that can help in producing faster and/or shorter programs. The tips cover both C compiler and assembly language programming.

#### 12.5.1 C-Callable Routines

The 'C40 was designed with a large register file, software stack, and large memory space in order to implement a high-level language (HLL) compiler easily. The first such implementation supplied is a C compiler. Use of the C compiler increases the transportability of applications that have been tested on large, general-purpose computers and decreases their porting time.

To use the compiler efficiently, complete the following steps:

- 1) Write the application in the high-level language.
- 2) Debug the program.
- 3) Estimate if it runs in realtime.
- 4) If it doesn't, identify places where most of the execution time is spent.
- 5) Optimize these areas by writing assembly language routines that implement the functions.
- 6) Call the routines from the C program as C functions.

When writing a C program, you can increase the execution speed by maximizing the use of register variables. For more information, refer to the *TMS320 Floating-Point DSP Optimizing C Compiler User's Guide* (literature number SPRU034, due for release 3Q, 1991).

Certain conventions must be observed in writing a C-callable routine. These conventions are outlined in the *Runtime Environment* chapter of the *TMS320 Floating-Point DSP Optimizing C Compiler User's Guide*. Certain registers are saved by the calling function, and others need to be saved by the called function. The C compiler manual helps achieve a clean interface. The end result is the readability and natural flow of a high-level language combined with the efficiency and special-feature use of assembly language.

## 12.5.2 Hints for Optimizing Assembly Code

Each program has particular requirements. Not all possible optimizations will make sense in every case. The suggestions presented in this section can be used as a checklist of available software tools.

- Use delayed branches. Delayed branches execute in a single cycle; regular branches execute in four. The three instructions that follow the delayed branch are executed whether the branch is taken or not. If fewer than three instructions are used, use the delayed branch and append NOPs. Machine cycles (time) are still being saved.
- Use delayed subroutine call and return. Regular subroutine CALL and RETS execute in four cycles. The delayed subroutine call can be achieved by using link and jump (LAJ) and delayed branches with R11 register mode (BUD R11) instructions. Both LAJ and BUD instructions execute in a single cycle. The rule for using LAJ instruction is the same as for delayed branches.
- Apply the repeat single/block construct. In this way, loops are achieved with no overhead. Nesting such constructs will not normally increase efficiency, so try to use the feature on the most often performed loop. The RPTBD is a single-cycle instruction, and the RPTS and RPTB are four-cycle instructions. The usage of RPTBD is similar to that of the delayed branches. Note that RPTS is not interruptible, and the executed instruction is not refetched for execution. This frees the buses for operands.
- Use parallel instructions. It is possible to have a multiply in parallel with an add (or subtract) and to have stores in parallel with any multiply or ALU operation. This increases the number of operations executed in a single cycle. For maximum efficiency, observe the addressing modes used in parallel instructions and arrange the data appropriately. You can have loads in parallel with any multiply or add (or subtract). Since the result of a multiply by one or an add of zero is the same as a load, parallel instructions with a data load can be implemented by substituting the load instruction with a multiply or an add instruction with one extra register containing a one or zero.

- Maximize the use of registers. The registers are an efficient way to access scratch-pad memory. Extensive use of the register file facilitates the use of parallel instructions and helps avoid pipeline conflicts when you use register addressing (register addressing is described in subsection 5.1.1 on page 5-3).
- Use the cache. Use cache especially in conjunction with slow external memory. The cache is transparent to the user, so make sure that it is enabled.
- Use internal memory instead of external memory. The internal memory (2K×32 bits RAM and 4K×32 bits ROM) is considerably faster to access. In a single cycle, two operands can be brought from internal memory. You can maximize performance if you use the DMA in parallel with the CPU to transfer data to internal memory before you operate on them.
- Avoid pipeline conflicts. If there is no problem with program speed, ignore this suggestion. For time-critical operations, make sure that cycles are not missed because of conflicts. To identify conflicts, run the trace function on the development tools (simulator, emulators) with the program tracing option enabled. The tracing immediately identifies the pipeline conflicts. Consult the appropriate section of this user's guide for an explanation of the reason for the conflict. You can then take steps to correct the problem.

The above checklist is not exhaustive, and it does not address some features outlined in more detail in the different sections of this manual. To learn how to exploit the full power of the 'C40, carefully study its architecture, hardware configuration, and instruction set described in this user's guide.

## **12.6 Peripherals**

TMS320C40 peripheral modules include one analysis module, two timers, six direct memory access (DMA) controllers, and six high speed bi-directional communication ports. They are designed to improve system performance and decrease system cost without reducing the computational throughput of the CPU. These peripheral modules are controlled through memory-mapped registers located on the dedicated peripheral bus. The examples that show how to program the timer, communication port, and DMA operations are presented in the following subsections.

#### 12.6.1 Timers

There are two general-purpose, 32-bit timers on the 'C40 device. Both timers are identical to and independent from each other (detailed information on the timers is in Section 9.10 on page 9-45). The timers are controlled by three registers: timer global control register, timer counter register, and timer period register. Pins TCLK0 and TCLK1 of 'C40 are dedicated for timers. These pins can be configured as either general-purpose data I/O or timer.

If bit 0 and bit 9 of the timer global control register are set to 0, the TCLKx pin is configured as a general-purpose data I/O pin. Timer counter and period registers have no effect on this configuration. Bit 1 of the timer global control register is used to configure TCLKx as an input or output pin. If TCLKx is configured as an output pin (bit 1 = 1), the data value in bit 2 of the timer global control register is shown on TCLKx. If TCLKx is configured as an input pin (bit 1 = 0), the signal on TCLKx is shown in bit 3 of the timer global control register.

If bit 0 of the timer global control register is set to 1, pin TCLKx is configured as a timer pin. The frequency of the timer signaling is specified by the timer period register. However, this assumes that the timer counter register equals 0 (writing 1 to bit 6 of the timer global control register will reset the counter register, too). If the timer counter register has a nonzero value in it, the first period will be different than the others. When the counter register is set to a value greater than the period register, the counter will count, roll over to 0, and continue counting to period register. Therefore, it is important to have correct values in the timer period and counter register starts the timer (writing a 1 to bit 7 of the timer global control register starts the timer). The frequency of the timer signaling is determined by the frequency of the timer input clock and the period register. The following equations are valid with either an internal or an external timer clock:

f(pulse mode) = f(timer clock) / period register

f(clock mode) = f(timer clock) / (2 x period register)

When the period and counter register are zero, the operation of the timer is dependent upon the  $C/\overline{P}$  mode selected. In pulse mode ( $C/\overline{P} = 0$ ), TSTAT is set and remains set. In the other words, the frequency is equal to infinite. In clock mode ( $C/\overline{P} = 1$ ), the width of the cycle is 2/f(H1), and the external clock is ignored. Therefore, the maximum frequency of timer clock generated by internal clock is f(H1)/2. Example 12–44 shows how to set up the 'C40 timer to generate the maximum frequency clock through the TCLKx pin.

Example 12–44. Maximum Frequency Timer Clock Setup

| *                                | TITLE MAX                | IMUM FREQUENC                                   | Y TIMER CLOCK SETUP                                                                       |         |
|----------------------------------|--------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------|---------|
| *<br>*<br>*                      | FREQUENCY                | TIMER CLOCK                                     | TO SET UP TIMER TO GENERATE<br>USING INTERNAL CLOCK. WHERE<br>ON IS LOCATED FROM 808020H. | MAXIMUM |
| TIM0_CTL<br>TIM0_CNT<br>TIM0_PRD | REG                      | .usect                                          | "TIMER_REGISTER",4<br>"TIMER_REGISTER",4<br>"TIMER_REGISTER",8                            |         |
|                                  | LDI<br>STI<br>LDI<br>STI | 0,R0<br>R0,@TIM0_PRD<br>3C1H,R0<br>R0,@TIM0_CTL |                                                                                           |         |

#### **12.6.2 Communication Ports**

In order to provide direct processor-to-processor communication, 'C40 has six parallel bidirection communication ports (see Chapter 8). Since these ports have port arbitration units to handle the ownership of the communication port data bus between the processors, the programmer needs to concentrate only on the internal operation of the communication ports. For software, these communication ports can be treated as 32-bit on-chip data I/O FIFO buffers. Processor read/write data from/to communication is simple:

```
LDI @comm_port0_input,R0 ; Read data from comm. port 0
Or
```

```
STI R0,@comm_port0_output ; Write data to comm. port 1
```

If the CPU or DMA reads from or writes to the communication port I/O FIFO and the I/O FIFO is either empty (on a read) or full (on a write), the read/write execution will be extended until the data is available in the input FIFO for a read, or the space is available in the output FIFO for a write. Sometimes, this can be used to synchronize the devices. However, this will slow down the processing speed and even hang up the processor. Avoid such situations.

Each 'C40 communication port provides four flags to indicate the status of the port:

**ICRDY** (input channel ready)

- = 0, the input channel is empty and not ready to be read.
- = 1, the input channel contains data and is ready to read.
- **ICFULL** (input channel full)
  - = 0, the input channel is not full.
  - = 1, the input channel is full.

**OCRDY** (output channel ready)

- = 0, the output channel is full and not ready to be written.
- = 1, the output channel is not full and ready to be written.

**OCEMPTY** (output channel empty)

- = 0, the output channel is not empty.
- = 1, the output channel is empty.

These flags can be used to synchronize the CPU/DMA access to the communication port. Example 12–45 shows reading data from the communication port eight data at a time using the CPU ICFULL interrupt. Example 12–46 shows writing data to a communication port one datum at a time using the polling method. The example shows DMA reads/writes of data from/to the communication port (DMA is discussed in the next subsection, subsection 12.6.3).

| Example 12–45. | Read Data from C | Communication Port | t With CPU ICFL | ILL Interrupt |
|----------------|------------------|--------------------|-----------------|---------------|
|----------------|------------------|--------------------|-----------------|---------------|

| *<br>*<br>*<br>* | ICFULL IN                                           |                                                  |        |                                                                                    |
|------------------|-----------------------------------------------------|--------------------------------------------------|--------|------------------------------------------------------------------------------------|
| ~<br>*<br>*      | CPU INTER                                           |                                                  | ΕI     | D INTERRUPT VECTOR IS SET IN THE<br>EIGHT DATA ARE READ IN<br>4 PORT 0 INPUT FIFO. |
|                  | •                                                   |                                                  |        |                                                                                    |
|                  | LDA                                                 | <pre>@COMM_PORT0_CTL,AR2</pre>                   |        | Load comm port 0<br>control reg address                                            |
|                  | LDA                                                 | @COMM_PORT0_INPUT,AR(                            | ;<br>; | Load comm port 0<br>input FIFO address                                             |
|                  | LDA<br>AND3                                         | @INTERNAL_RAM,AR1<br>OF7H,*AR2,R9                | ;<br>; | Load internal RAM address<br>Unhalt comm port 0<br>input channel                   |
|                  | STI<br>OR<br>OR                                     |                                                  |        | Enable ICRDY 0 interrupt<br>Enable CPU global interrupt                            |
|                  | •                                                   |                                                  |        |                                                                                    |
| ICFULLO          | PUSH<br>PUSH<br>PUSH<br>PUSH<br>RPTBD<br>LDI<br>LDI | ST<br>RS<br>RE<br>RC<br>READ<br>6,RC<br>*AR0,R10 | ;      | Setup for loop READ<br>Set repeat counter<br>Read data from comm port 0<br>input   |
|                  | NOP                                                 |                                                  |        |                                                                                    |
| READ             | LDI                                                 | *AR0,R10                                         |        | Read data from comm port 0<br>input                                                |
| 11               | STI                                                 | R10,*AR1++(1)                                    | ;      | Store data into internal RAM                                                       |
|                  | STI<br>POP<br>POP<br>POP<br>RETI                    | R10,*AR1++(1)<br>RC<br>RE<br>RS<br>ST            | ;      | Store data into internal RAM                                                       |

Example 12–46. Write Data to Communication Port With Polling Method

| *          |        |                         |     |                                         |
|------------|--------|-------------------------|-----|-----------------------------------------|
| *          | TITLE  | WRITE DATA TO COMMUNICA | AT: | ION PORT WITH POLLING METHOD            |
| *          |        |                         |     |                                         |
| *          | THE BI | T 8 OF COMMUNICATION PO | DR' | F 0 CONTROL REGISTER WILL BE            |
| *          | SET ON | LY WHEN THE OUTPUT FIFO | ) : | IS FULL. THIS EXAMPLE CHECKS            |
| *          |        | IT TO MAKE SURE THERE   |     |                                         |
| *          | OUTPUT |                         |     |                                         |
| *          | 001101 |                         |     |                                         |
|            |        |                         |     |                                         |
|            | •      |                         |     |                                         |
|            | •      |                         |     |                                         |
|            |        | 0.0000/ DODWO (MT 100   |     | - 1                                     |
|            | LDA    | @COMM_PORT0_CTL,AR2     | ;   | Load comm port 0 control reg<br>address |
|            | LDA    | @COMM_PORT0_OUTPUT, ARC | ;   | Load comm port 0 output<br>FIFO address |
|            | LDA    | @INTERNAL RAM, AR1      | ;   | Load internal RAM address               |
|            | AND3   | 0EFH, *AR2, R9          | -   | Unhalt comm port 0 output channel       |
|            | STI    | R9,*AR2                 |     |                                         |
|            | LDI    | 0100H,R9                | :   | Load mask for bit 8                     |
| WAIT:      | TSTB   | •                       | •   | Check if output FIFO is full            |
|            | BZD    | WAIT                    |     | If yes, check again                     |
| WDTTE COMM |        |                         | '.  | Read data from internal RAM             |
| WRITE_COMM |        | *AR1++(1), R10          | •   |                                         |
|            | STI    | R10,*ARO                | ;   | Store data into comm port<br>0 output   |

#### 12.6.3 Direct Memory Access

The 'C40 direct memory access (DMA) coprocessor supports six DMA channels (detailed information on DMA is in Chapter 9). These channels perform transfers to and from anywhere in the processor memory map. The DMA coprocessor is a self-programming device that allows data transfers to occur without any intervention from the CPU. It also provides a special split-mode to support 12 DMA channels for communication port memory transfer. This section contains examples of DMA programs from a very simple single-block memory-to-memory transfer to a sophisticated memory transfer with autoinitialization.

Example 12–47 shows one way for setting up DMA channel 2 to initialize an array to zero. This DMA transfer is set up to have higher priority over a CPU operation and to generate an interrupt flag, DMA INT2, after the transfer is completed. The DMA control register is set to 03040007H (refer to DMA control register bit functions in Table 9–1 on page 9-8 for further information on this setup).

Example 12–47. Array initialization With DMA

| *       |           |                                                                |   |                                    |  |  |  |  |
|---------|-----------|----------------------------------------------------------------|---|------------------------------------|--|--|--|--|
| *       | TITLE ARR | AY INITIALIZATION                                              | W | ITH DMA                            |  |  |  |  |
| *       |           |                                                                |   |                                    |  |  |  |  |
| *       | THIS EXAM | IPLE INITIALIZES A                                             | 1 | 28 ELEMENTS ARRAY TO ZERO. THE DMA |  |  |  |  |
| *       | TRANSFER  | TRANSFER IS SET UP TO HAVE HIGHER PRIORITY OVER CPU OPERATION. |   |                                    |  |  |  |  |
| *       | THE DMA I | NT2 INTERRUPT FLA                                              | G | IS SET TO 1 AFTER THE TRANSFER IS  |  |  |  |  |
| *       | COMPLETED | ).                                                             |   |                                    |  |  |  |  |
| *       |           |                                                                |   |                                    |  |  |  |  |
|         | .data     |                                                                |   |                                    |  |  |  |  |
| DMA2    | .word     | 001000СОН                                                      | ; | DMA channel 2 map address          |  |  |  |  |
| CONTROL | .word     | 00С40007н                                                      | ; | DMA register initialization data   |  |  |  |  |
| SOURCE  | .word     | ZERO                                                           |   | 2                                  |  |  |  |  |
| SRC IDX | .word     | 0                                                              |   |                                    |  |  |  |  |
| COUNT   | .word     | 128                                                            |   |                                    |  |  |  |  |
| DESTIN  | .word     | ARRAY                                                          |   |                                    |  |  |  |  |
| DES IDX | .word     | 1                                                              |   |                                    |  |  |  |  |
| ZERÖ    | .word     | 0.0                                                            | ; | Array initialization value 0.0     |  |  |  |  |
|         | .bss      | ARRAY,128                                                      |   | -                                  |  |  |  |  |
|         | .text     |                                                                |   |                                    |  |  |  |  |
| START   | LDP       | @DMA2                                                          | ; | Load data page pointer             |  |  |  |  |
|         | LDA       | @DMA2,ARO                                                      | ; | Point to DMA channel 2 registers   |  |  |  |  |
|         | LDI       | @SOURCE,RO                                                     | ; | Initialize DMA source register     |  |  |  |  |
|         | STI       | R0,*+AR0(1)                                                    |   |                                    |  |  |  |  |
|         | LDI       | @SRC IDX,R0                                                    | ; | Initialize DMA source index        |  |  |  |  |
|         |           | _                                                              | ; | register                           |  |  |  |  |
|         | STI       | RO,*+ARO(2)                                                    |   |                                    |  |  |  |  |
|         | LDI       | QCOUNT, RO                                                     | ; | Initialize DMA count register      |  |  |  |  |
|         | STI       | RO,*+ARO(3)                                                    |   |                                    |  |  |  |  |
|         | LDI       | @DESTIN,RO                                                     | ; | Initialize DMA destination         |  |  |  |  |
|         |           |                                                                | ; | register                           |  |  |  |  |
|         | STI       | R0,*+AR0(4)                                                    |   |                                    |  |  |  |  |
|         | LDI       | @DES_IDX,RO                                                    |   | Initialize DMA destination         |  |  |  |  |
|         |           |                                                                | ; | index register                     |  |  |  |  |
|         | STI       | R0,*+AR0(5)                                                    |   |                                    |  |  |  |  |
|         | LDI       | @CONTROL,RO                                                    | ; | Start DMA channel 2 transfer       |  |  |  |  |
|         | STI       | RO,*ARO                                                        |   |                                    |  |  |  |  |
|         | .end      |                                                                |   |                                    |  |  |  |  |

The DMA transfer can be synchronized with external interrupts, communication port ICRDY/OCRDY signals, and timer interrupts. In order to enable this feature, the SYNCH MODE field, bits 6–7, of the DMA control register must be configured to a proper value (Table 9–1 on page 9-8), and the corresponding bits of the DMA interrupt enable (DIE) register must be set. Example 12–48 sets up DMA channel 4 read synchronization with the communication port ICRDY signal. The DMA is set up to continuously transfer data from the communication port input register until the START field, bits 22–23 of the DMA control register, is changed by the CPU.

Example 12–48. DMA Transfer With Communication Port ICRDY Synchronization

| * * * * * * * * * * *                         | COMMUNICA<br>SIGNAL RE<br>SET TO 00                                                                                            | SYNCHRONIZATIO<br>PLE SETS UP DMA<br>TION PORT INPUT<br>AD SYNCHRONIZAT<br>. THEREFORE THE                                                                                                                 | N<br>C<br>R<br>IO<br>T                  | H COMMUNICATION PORT ICRDY<br>HANNEL 4 TO TRANSFER DATA FROM<br>EGISTER TO INTERNAL RAM WITH ICRDY<br>N. THE TRANSFER MODE OF THE DMA IS<br>RANSFER WON'T STOP UNTIL THE START<br>GISTER IS CHANGED.                                                                                                               |
|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| *                                             | BIIS OF I                                                                                                                      | HE DHA CONTROL                                                                                                                                                                                             | RE                                      | GISTER IS CHANGED.                                                                                                                                                                                                                                                                                                 |
| DMA4<br>CONTROL<br>SOURCE<br>SRC_IDX<br>COUNT | .word                                                                                                                          | 001000E0H<br>00C00040H<br>00100081H<br>0<br>0                                                                                                                                                              | ;                                       | DMA channel 4 map address<br>DMA register initialization data<br>Transfer counter is set to                                                                                                                                                                                                                        |
| *                                             | ·word                                                                                                                          | U                                                                                                                                                                                                          | •                                       | largest value                                                                                                                                                                                                                                                                                                      |
| DESTIN<br>DES_IDX                             | .word<br>.word                                                                                                                 | 002FF800H<br>1                                                                                                                                                                                             | •                                       | largebt varae                                                                                                                                                                                                                                                                                                      |
| START                                         | .text<br>LDP<br>LDA<br>LDI<br>STI<br>LDI<br>STI<br>LDI<br>STI<br>LDI<br>STI<br>LDI<br>STI<br>LDI<br>STI<br>LDI<br>LDHI<br>.end | @DMA4<br>@DMA4,AR0<br>@SOURCE,R0<br>R0,*+AR0(1)<br>@SRC_IDX,R0<br>R0,*+AR0(2)<br>@COUNT,R0<br>R0,*+AR0(3)<br>@DESTIN,R0<br>R0,*+AR0(4)<br>@DES_IDX,R0<br>R0,*+AR0(5)<br>@CONTROL,R0<br>R0,*AR0<br>010H,DIE | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | Load data page pointer<br>Point to DAM channel 4 registers<br>Initialize DMA source register<br>Initialize DMA count register<br>Initialize DMA count register<br>Initialize DMA destination register<br>Initialize DMA destination index<br>register<br>Start DMA channel 4 transfer<br>Enable ICRDY 4 read sync. |

If external interrupt signals are used for DMA transfer synchronization, then pins IIOF0-3 must be configured as interrupt pins also.

The 'C40 DMA split mode is another way besides memory map address to transfer data from/to the communication port. When the split-mode bit of the DMA control register is set, the DMA is separated into primary and auxiliary channels. The primary channel transfers data from memory to the communication port output register, and the auxiliary channel transfers data from the communication port to memory. The communication port number is selected in bits 15 - 17 of the DMA control register.

Example 12–49 shows how to set up DMA channel 1 into split mode. The DMA primary channel transfers data from internal RAM to communication port 3 using external interrupt INT2 synchronization and bit-reversed addressing. The DMA auxiliary channel transfers data from communication port 3 to internal RAM using external interrupt INT3 synchronization and linear addressing.

Example 12–49. DMA Split-Mode Transfer With External Interrupt Synchronization

| *               |           |                                    |     |                                         |
|-----------------|-----------|------------------------------------|-----|-----------------------------------------|
| *               |           | 1A SPLIT-MODE TR<br>INCHRONIZATION | RAN | SFER WITH EXTERNAL INTERRUPT            |
| *               |           |                                    |     |                                         |
| *               | THIS EXAM | IPLE SETS UP DMA                   | C   | HANNEL 1 TO SPLIT-MODE. THE PRIMARY     |
| *               |           |                                    |     | M INTERNAL RAM TO COMM PORT 3 OUTPUT    |
| *               | REGISTER  | WITH EXTERNAL I                    | NT  | ERRUPT INT2 SYNCHRONIZATION AND BIT-    |
| *               | REVERSED  | ADDRESSING. THE                    | A   | UXILIARY CHANNEL TRANSFERS DATA FROM    |
| *               |           |                                    | -   | REGISTER TO INTERNAL RAM WITH           |
| *               | EXTERNAL  | INTERRUPT INT3                     | SY  | NCHRONIZATION AND LINEAR ADDRESSING.    |
| *               | •         |                                    |     |                                         |
| DM7 1           | .data     | 001000001                          |     | DVD shaws 1 1 may address               |
| DMA1<br>CONTROL | .word     | 001000B0H<br>03CDD0D4H             |     | DMA channel 1 map address               |
| SOURCE          | .word     | 002FFC00H                          | ;   | DMA register initialization data        |
| SRC IDX         | .word     | 08H                                |     | The same value as IR0 for bit-reversed  |
| COUNT           | .word     | 8                                  | '   | The bane variae as the for bit feverbea |
| DESTIN          | .word     | 002FF800H                          |     |                                         |
| DES IDX         | .word     | 1                                  |     |                                         |
| AUX CNT         | .word     | 8                                  |     |                                         |
|                 | .text     |                                    |     |                                         |
| STAR            | LDP       | 0DMA1                              |     | Load data page pointer                  |
| DIAN            | LDA       | @DMA1,AR0                          |     | Point to DAM channel 1 registers        |
|                 | LDI       | @SOURCE,RO                         | ;   | Initialize DMA primary source register  |
|                 | STI       | R0,*+AR0(1)                        | '   |                                         |
|                 | LDI       | @SRC IDX,R0                        | ;   | nitialize DMA primary source index reg  |
|                 | STI       | R0,*+AR0(2)                        |     |                                         |
|                 | LDI       | @COUNT, RO                         | ;   | Initialize DMA primary count register   |
|                 | STI       | R0,*+AR0(3)                        |     |                                         |
|                 | LDI       | @DESTIN,RO                         | ;   | Initialize DMA aux destination          |
|                 |           |                                    | ;   | register                                |

| STI<br>LDI        | R0,*+AR0(4)<br>@DES_IDX,R0            | ; Initialize DMA aux destination<br>; index register |
|-------------------|---------------------------------------|------------------------------------------------------|
| STI               | R0,*+AR0(5)                           |                                                      |
| LDI               | @AUC_CNT,R0                           | ; Initialize DMA auxiliary count<br>; register       |
| STI<br>LDI<br>STI | R0,*+AR0(7)<br>@CONTROL,R0<br>R0,*AR0 | ; Start DMA channel 1 transfer                       |
| LDI               | 01100H,IIF                            | ; Configure INT2 and INT3 as<br>; interrupt pins     |
| LDI<br>.end       | OAOH, DIE                             | ; Enable INT2 read and INT3 write sync.              |

An advantage of the 'C40 DMA is the autoinitialization feature. This allows you to set up the DMA transfer in advance and makes the DMA operation 100 percent independent from the CPU. When the DMA is operating in autoinitialization mode, the link pointer and auxiliary link pointer are used to initialize the registers that control the DMA operation. The link pointer may be incremented (AUTOINIT STATIC = 0 — shown in Table 9–1 on page 9-8) during autoinitialization or held constant (AUTOINIT STATIC = 1) during autoinitialization. This option allows autoinitialization values to be stored in sequential memory locations or in stream-oriented devices such as the on-chip communication ports or external FIFOs. When DMA SYNC MODE is enabled, The DMA autoinitialization operation can be configured to synchronize with the same signal too. Example 12–50 sets up DMA channel 0 to wait for the communication port to input the initialization value. After DMA autoinitialization is complete, the DMA channel starts transferring data from the communication port input register to internal RAM.

| * TITLE DMA AUTOINITIALIZATION WITH COMMUNICATION PO         | APT TOPAY                                                                                                                     |  |  |  |
|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| * IIILE DMA AUTOINITIALIZATION WITH COMMONICATION PC         | JRI ICRDI                                                                                                                     |  |  |  |
| * THIS EXAMPLE SETS UP DMA CHANNEL 0 TO WAIT FOR COM         | THIS EXAMPLE SETS UP DMA CHANNEL 0 TO WAIT FOR COMMUNICATION                                                                  |  |  |  |
| * PORT TO INPUT THE INITIALIZATION VALUE. THE DMA AU         | PORT TO INPUT THE INITIALIZATION VALUE. THE DMA AUTOINITIAL-                                                                  |  |  |  |
|                                                              | IZATION AND TRANSFER ARE BOTH DRIVEN BY ICRDY 0 FLAG. AFTER                                                                   |  |  |  |
|                                                              | DMA AUTOINIT IS COMPLETED, THE DMA CHANNEL STARTS TRANSFERRING                                                                |  |  |  |
|                                                              | DATA FROM COMM PORT INPUT REGISTER TO INTERNAL RAM WITH ICRDY<br>0 READ SYNCHRONIZATION. THE VALUES IN COMM PORT 0 INPUT FIFO |  |  |  |
| * SHOULD BE:                                                 | INPOI FIFO                                                                                                                    |  |  |  |
| *                                                            |                                                                                                                               |  |  |  |
| * SEQUENCE   VALUE                                           |                                                                                                                               |  |  |  |
| * 1   00C40047H (STOP AFTER TRANSFER COMPL                   |                                                                                                                               |  |  |  |
| *   OR 00C4054BH (REPEAT AFTER TRANSFER COMPL                |                                                                                                                               |  |  |  |
| * 2   00100041H                                              |                                                                                                                               |  |  |  |
| * З ЮН                                                       |                                                                                                                               |  |  |  |
| * 4   20H<br>* 5   002FF800H                                 |                                                                                                                               |  |  |  |
| * 4   20H<br>* 5   002FF800H<br>* 6   1H                     |                                                                                                                               |  |  |  |
| * 7 I 00100041H                                              |                                                                                                                               |  |  |  |
| *                                                            |                                                                                                                               |  |  |  |
| .data                                                        |                                                                                                                               |  |  |  |
| DMA0 .word 001000A0H ; DMA channel 0 map add                 |                                                                                                                               |  |  |  |
| DMA INIT .word 0004054BH ; DMA initialization co             |                                                                                                                               |  |  |  |
| LINK .word 00100041H ; Comm port input regis                 |                                                                                                                               |  |  |  |
| DMA_START .word 00C4054BH ; DMA start control word .text     | ca                                                                                                                            |  |  |  |
| START LDP @DMA0 ; Load data page pointe                      | er                                                                                                                            |  |  |  |
| LDA @DMA0,AR0 ; Point to DMA channel                         |                                                                                                                               |  |  |  |
| LDI @DMA_INIT,R0 ; Initialize DMA contro                     |                                                                                                                               |  |  |  |
| STI RO, *ARO                                                 |                                                                                                                               |  |  |  |
| LDI @LINK,R0 ; Initialize DMA link p                         | pointer                                                                                                                       |  |  |  |
| STI R0,*+AR0(6)<br>LDI @DMA START,R0 ; Start DMA channel 0 t | ranefer                                                                                                                       |  |  |  |
| STI RO, *ARO                                                 | LAUDICI                                                                                                                       |  |  |  |
| LDI 01H, DIE ; Enable ICRDY 0 read s                         | sync.                                                                                                                         |  |  |  |
| .end                                                         | -                                                                                                                             |  |  |  |

Example 12–50. DMA Autoinitialization With Communication Port ICRDY

The DMA autoinitialization and transfer will continue executing if the DMA autoinitialization is still enabled. Therefore, a DMA setup like the one in Example 12–50 can make it possible for the DMA operation to be controlled by an external device through the communication port. With the autoinitialization feature, the 'C40 DMA can support a variety of DMA operations without slowing down CPU computation. A good example is a DMA transfer triggered by one interrupt signal. Usually, this is achieved by starting a DMA activity with a CPU interrupt service routine, but this utilizes CPU time. However, with the autoinitialization feature, 'C40 DMA can achieve this kind of setup without CPU interruption, as shown in Example 12–51. One method is to set up a single interrupt-driven dummy DMA transfer with autoinitialization. When the interrupt signal is set, the DMA will complete the dummy DMA transfer and start the autoinitialization for the desired DMA transfer.

Example 12–51. Single-Interrupt-Driven DMA Transfer

| *        |           |                   |       |                                   |
|----------|-----------|-------------------|-------|-----------------------------------|
| *        | TITLE SIN | NGLE INTERRUPT-DF | RIVĒJ | N DMA TRANSFER                    |
| *        |           |                   |       |                                   |
| *        |           |                   |       | DMA TRANSFER FROM INTERNAL RAM    |
| *        |           |                   |       | RNAL INT 0 SYNCHRONIZATION AND    |
| *        |           |                   |       | FERRING 64 DATA FROM LOCAL MEMORY |
| *        |           |                   |       | ECOND TRANSFER IS COMPLETED, THE  |
| *        | DMA IS RE | E-INITIALIZED TO  | FIRS  | ST DMA RANSFER SETUP.             |
| *        |           |                   |       |                                   |
|          | .data     |                   |       |                                   |
| DMA5     | .word     | 001000F0H         | ;     |                                   |
| DMA_INIT | .word     | 000004вн          | ;     | DMA initialization control word   |
| LINK     | .word     | DMA1              | ;     | 1st DMA link list address         |
| DMA_STAR | T .word   | 00C0004BH         | ;     | DMA start control word            |
| DMA1     | .word     | 00С0004ВН         | ;     | 1st dummy DMA transfer link list  |
|          | .word     | 002FF800H         |       |                                   |
|          | .word     | 0000000н          |       |                                   |
|          | .word     | 0000001н          |       |                                   |
|          | .word     | 002FF800H         |       |                                   |
|          | .word     | 0000000н          |       |                                   |
|          | .word     | DMA2              |       |                                   |
| DMA2     | .word     | 00С4000ВН         | ;     | The desired DMA transfer link     |
|          | .word     | 00400000H         | ;     | list                              |
|          | .word     | 00000001H         |       |                                   |
|          | .word     | 0000040н          |       |                                   |
|          | .word     | 002FF800H         |       |                                   |
|          | .word     | 0000001н          |       |                                   |
|          | .word     | DMA1              |       |                                   |
|          | .text     |                   |       |                                   |
| START    | LDP       | @DMA5             | ;     | Load data page pointer            |
|          | LDA       | @DMA5,ARO         | ;     | Point to DMA channel 5 registers  |
|          | LDI       | @DMA_INIT,RO      | ;     | Initialize DMA control register   |
|          | STI       | R0,*ĀR0           |       |                                   |
|          | LDI       | @LINK,RO          | ;     | Initialize DMA link pointer       |
|          | STI       | R0,*+AR0(6)       |       | -                                 |
|          | LDI       | @DMA_START,R0     | ;     | Start DMA channel 5 transfer      |
|          | STI       | R0,*ĀR0           |       |                                   |
|          | LDI       | 01H,IIF           | ;     | Configure INTO as interrupt pins  |
|          | LDHI      | 0800H,DIE         | ;     | Enable INT 0 read sync. for       |
|          |           |                   | ;     | DMA channel 5                     |
|          | and       |                   |       |                                   |

.end



# **Chapter 13**

# **Hardware Applications**

The TMS320C40's advanced interface design can be used to implement a wide variety of system configurations. Its two external buses and DMA capability provide a flexible parallel 32-bit interface to byte- or word-wide devices; the communication ports provide a glueless interface to other 'C40s; and the interrupt interface, communication ports, and general-purpose digital I/O provide communication with a multitude of peripherals.

This chapter describes how to use the 'C40's interfaces to connect to various external devices. Specific discussions include implementation of parallel interface to devices with and without wait states, parallel processing through the communication ports and port control logic, and system control function circuit design.

Major topics discussed in this chapter are as follows:

| Sectio | n   |                                                    | Page  |
|--------|-----|----------------------------------------------------|-------|
| 13.1   | Sys | stem Configuration Options Overview                | 13-3  |
|        |     | Categories of Interfaces on the TMS320C40          | 13-3  |
| 13.2   | Bo  | ot Loader Description and External ROM Interfacing | 13-5  |
|        |     | TMS320C40 Boot Loader Description                  | 13-5  |
|        |     | Examples of External Memory Loads                  | 13-8  |
|        |     | Communication Port Loading                         | 13-8  |
|        |     | External ROM Interfacing to the TMS320C40          | 13-9  |
|        |     | External Memory Loading                            | 13-14 |
|        |     | TMS320C40 Boot Loader Source Program               | 13-14 |
| 13.3   | Glo | bal and Local Bus Interface                        | 13-20 |
|        |     | Zero Wait-State Interface to RAMs                  | 13-20 |
| 13.4   | Rea | ady Generation                                     | 13-27 |
|        |     | ORing of the Ready Signals (SWW = 10)              | 13-28 |

|      |     | ANDing of the Ready Signals (SWW = 11) 13-28                 |
|------|-----|--------------------------------------------------------------|
| Ì    |     | External Ready Generation 13-29                              |
|      |     | Ready Control Logic 13-30                                    |
|      |     | Example Circuit 13-31                                        |
|      |     | Page Switching Techniques 13-32                              |
| 13.5 | Par | allel Processing Interfaces 13-37                            |
|      |     | Message Broadcasting From a TMS320C40 to Many<br>TMS320C40's |
|      |     | Shared Global Memory Interface With Fair Arbitration . 13-38 |
|      |     | Shared Bus Interface Overview 13-43                          |
| 13.6 | Bus | Arbitration 13-48                                            |
|      |     | Arbitration Implementation 13-48                             |
|      |     | Global Bus Arbitration and Transfer Timing 13-70             |
|      |     | Arbitration Protocol Limitations                             |
| 13.7 | Res | et Signal Generation Control Functions                       |

# 13.1 System Configuration Options Overview

The 'C40 interfaces connect to a wide variety of device types. Each of these interfaces is tailored to a particular family of devices.

# 13.1.1 Categories of Interfaces on the TMS320C40

The interface types on the 'C40 fall into several different categories, depending on the devices to which they are intended to be connected. Each interface comprises one or more signal lines, which transfer information and control its operation. Shown in Figure 13–1 are the signal line groupings for each of these interfaces.



Figure 13–1. External Interfaces to the TMS320C40



Each interface is independent of the others, and different operations may be performed simultaneously on each interface. These pins are defined in more detail in Table 14–2 on page 14-5. The global and local buses implement the primary memory-mapped interfaces to the device. These interfaces allow external devices such as DMA controllers and other microprocessors to share resources with one or more 'C40's through a common bus.

The devices that can be interfaced to the 'C40 include memory, DMA devices, and numerous parallel and serial peripherals and I/O devices. In addition, 'C40's can interface directly with each other, without external logic, through their communication ports or their external flag pins IIOF(0–3). Figure 13–2 illustrates a typical configuration of a 'C40 system with different types of external devices and the interfaces to which they are connected.

*Figure 13–2. Possible System Configurations* 



The above block diagram in Figure 13–2 constitutes a more or less fully expanded system. In an actual design, any subset or superset of the illustrated configuration may be used.

# **13.2 Boot Loader Description and External ROM Interfacing**

## 13.2.1 TMS320C40 Boot Loader Description/Operation

The boot loader provided in the on-chip ROM of the 'C40 can load and execute source programs that are received from a host processor, inexpensive ROM, or other standard memory devices. The 'C40 boot loader functions primarily as either a *memory boot loader* or a *communication port boot loader*.

- □ The memory boot loader supports user-definable byte, half-word, and full-word data formats, which allow the flexibility to load a source program from memories having widths of a byte, 16 bits, and 32 bits. The source programs to be loaded reside in one of six predefined memory locations: 0x0030 0000, 0x4000 0000, 0x6000 0000, 0x8000 0000, 0xA000 0000, and 0xC000 0000 as listed in Table 13–1.
- □ The **communication port boot loader** waits for the first data input from one of the six communication port channels and uses that channel to perform the boot load. Format of the incoming data stream is similar to that for a memory data stream except that the source memory width is excluded (format is described in Table 13–2, page 13-7).

Table 13–1 lists the pin values on IIOF(3–1), that select from which location the source program will be loaded.

| External Pin |       | Pin   |                                             |
|--------------|-------|-------|---------------------------------------------|
| II0F3        | ll0F2 | ll0F1 | Source Program Location                     |
| 1            | 1     | 0     | Load source program from address 0030 0000h |
| 1            | 0     | 1     | Load source program from address 4000 0000h |
| 1            | 0     | 0     | Load source program from address 6000 0000h |
| 0            | 1     | 1     | Load source program from address 8000 0000h |
| 0            | 1     | 0     | Load source program from address A000 0000h |
| 0            | 0     | 1     | Load source program from address C000 0000h |
| 0            | 0     | 0     | Reserved                                    |
| 1            | 1     | 1     | Load source program from communication port |

Table 13–1. Boot Loader Mode Selection Using Pins IIOF(3–1)

#### 13.2.2 Boot Load Sequence

A general sequence of events in boot loading a source program is as follows:

- Select the boot loader mode by resetting the processor while driving the on-chip ROM enable pin (ROMEN) high. The status of external pins IIOF(3-1) indicates where to find the source program to be loaded (memory or communication port). These options are listed in Table 13-1. (Pins IIOF(3-1) are read as the IIOF flags in the CPU IIF register (described in Table 3-6 on page 3-13).)
- The boot loader takes the following steps to determine the source program's location:
  - a) If an IIF(3—1) value of 110<sub>2</sub> to 001<sub>2</sub> (6 to 1) is found, the source program is loaded from the corresponding memory address shown in the top six lines of Table 13–1.
  - b) If an IIF(3—1) value of  $000_2(0)$  is found, the boot program is exited.
  - c) If none of the combinations 000<sub>2</sub> 110<sub>2</sub> are found, the boot loader program assumes loading will be via a communication port, and it starts checking communication port input channels (in the order port 0 through port 5). If no input is found from a communication port, the program returns to checking the status of the IIOF(3–1) pins again.
- 3) When the source program's data stream is found, the program is loaded at the address found in the fifth word of the data stream (format shown in Table 13–2) using the bus width specified in the first word (8, 16, or 32 bits wide). The first five words of the source program specify its loading and execution criteria. Remaining words are the source program(s) and vector table pointers as shown in Table 13–2:
- An IACK instruction is exectued. The IACK indicates the completion of the boot load sequence.
- 5) The source program is then executed (entry point is the first word of the *first* loaded program).

The data stream with its source program(s) should be in the format shown in Table 13–2. The contents of words 4 through n vary for the different source programs loaded throughout the entire data stream. The first three words and the last three words are nonvariables that affect each of the source-program blocks. The eight least significant bits of the first word specify

| Word        | Contents                                                                                                                                                                                                                                                                                                                                    |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | Memory width where source program resides (8, 16, or 32 bits wide)                                                                                                                                                                                                                                                                          |
| 2           | Value to set in the global memory interface control register (shown in Figure 7–2, page 7-7, and Table 7–3).                                                                                                                                                                                                                                |
| 3           | Value to set in the local memory interface control register (shown in Figure 7–2, page 7-7, and Table 7–3).                                                                                                                                                                                                                                 |
|             | Block size in words of the first program to be loaded (after this number of words are leaded, the next word should be all zeroes; if not, another block is assumed to follow).                                                                                                                                                              |
| 5           | Address to where the source program is loaded.                                                                                                                                                                                                                                                                                              |
| <b>6</b>    | First word of source program.                                                                                                                                                                                                                                                                                                               |
|             | Last word of source program (the program organized as words 4 through 7 -                                                                                                                                                                                                                                                                   |
| <i>n</i> +1 | Word of all zeroes. (Note that if several source-program blocks were sent, word $n$ above would be the last word of the <i>last</i> source-program block. Each source-program block would have the format shown in words 4 through $n$ ( <b>shaded above</b> ). Then this word of all zeroes follows the <i>last</i> source program block). |
| <i>n</i> +2 | IVTP value (interrupt vector table pointer, see Section 3.2 on page 3-15).                                                                                                                                                                                                                                                                  |
| <i>n</i> +3 | TVTP value (trap vector table pointer, see Section 3.2 on page 3-15).                                                                                                                                                                                                                                                                       |
| <i>n</i> +4 | Memory location for IACK instruction (see IACK instruction in Chapter 11).                                                                                                                                                                                                                                                                  |

Table 13–2. Structure of Source Program Data Stream

the memory width. If byte or half-word wide is selected, the loading sequence is from LSBs to MSBs.

Each source program in a multiple block program transfer can be loaded to different specified destinations. Each program block specifies its own block size and destination address at the beginning of the block. End the entire block program loader function by appending an all-zero word (0x0000 0000h) to the *last* block (only).

The second and third last words of the source memory define the interrupt vector table pointer (IVTP) and the trap vector table pointer (TVTP). The last word of the source memory defines the memory location for the IACK instruction. Since the IACK instruction brings down the IACK signal as data is read, the memory location specified in the IACK instruction has to be in external memory that is available in the system in order to bring the IACK signal low. Then the processor begins execution of the first code block.

It is assumed that at least one block of source code will be loaded when the loader is invoked. Initial loader invocation with a block size of 0x0000000 produces unpredictable results.

#### **13.2.3 Examples of External Memory Loads**

Example 13–1, Example 13–2, and Example 13–3 respectively show memory images for memory configured as byte wide, 16-bit wide, and 32-bit wide. These examples assume that:

- □ The status of the IIOF(3–1) pins is 110<sub>2</sub> after reset is deasserted (memory load from 0x030 0000h see Table 13–1 on page 13-5).
- □ The source program resides at memory location 0x030 0000h and defines the following:
  - Memory width for boot loader: 8, 16, or 32 bits
  - Global bus memory that requires one software wait state, external RDY (SWW = 11), page size = 64K for both STRB0 and STRB1, and active address range = 1G for both STRB0 and STRB1.
  - Local memory bus that requires two software wait states (SWW = 01), page size = 32K, and active address range = 1G for both STRB0 and STRB1.
  - First block program with 294 words in length and destination address at 0x002F F840h.
  - Second block program with 64 words in length and destination address at 0x002F F800h.
  - IVTP and TVTP, which are overlapped and point to the beginning of the on-chip RAM.
  - Memory location of 0x30 0000h for IACK instruction.

### **13.2.4 Communication Port Loading**

A value of all ones on IIOF(3-1) signals that the source program is being transmitted via a communication port. Bringing all three of the IIOF(3-1) pins high also allows the pins to be used as interrupt lines without any external decode logic. With pins IIOF(3-1) all high at reset, the 'C40 determines which channel contains the program by polling the input level of each port. The input data sequence of the communication boot loader is the same as that of the memory boot loader except for the source memory width definition (because the memory width is fixed on the communication port boot loader).

# 13.2.5 External ROM Interfacing to the TMS320C40

When the 'C40's ROMEN input pin is high and RESETLOC(1,0)= $00_2$  during reset, the memory boot loader can load programs stored in off-chip ROM to any valid external or internal memory in the 'C40's memory map.



Regardless of what width ROM is used (byte-wide, 16-, or 32-bit wide), the 8 LSBs of the first word read of the data stream specify the memory width. As shown in the three data stream examples starting with Example 13–1 on page 13-10, the first byte for each memory width is:

08h

- 8-bit memories:
- 16-bit memories: 0010h
- □ 32-bit memories: 00000020h

If 8- or 16-bit ROMs are used, the loading sequence is from LSBs to MSBs. The boot loader reads the contents of 16-bit wide memories (least significant half word first) and packs each pair of 16-bit half words to make a 32-bit word before loading each word to memory. Accordingly, the boot loader reads the contents of byte-wide memories (least significant byte first) and packs each group of four bytes into a 32-bit word before loading each word to memory. Since the boot loader does byte packing before loading, no external hardware is needed to pack the loaded bytes into a 32-bit word. For 32-bit wide ROMs, no byte packing is necessary, because the ROM data width matches that of the 'C40.

For 16-bit ROMs, the data read is expected to be in bit positions zero through fifteen. Thus, the half-word ROM's data lines should be interfaced to 'C40 data lines (L)D15–0. For byte-wide ROMs, the data read is expected to be in bit positions zero through seven. Hence, the byte-wide ROM's data lines should be interfaced to 'C40 data lines (L) D7–0. Even though the 'C40 does not require that unused data lines be pulled up to  $V_{CC}$ , it is recommended that each unused data line be pulled up through separate 22-kilohm resistors to 5 volts for minimum power dissipation.

| Example | 13–1. | Byte-Wide | Configured Memory |  |
|---------|-------|-----------|-------------------|--|
|---------|-------|-----------|-------------------|--|

| Word                        | Address    | Value | Comments                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | 0300000h   | 08h   | Memory width = 8 bits                                                                                                                                                                                                                                                                                                                              |
| 1                           | 0300001h   | 00h   |                                                                                                                                                                                                                                                                                                                                                    |
|                             | 0300002h   | 00h   |                                                                                                                                                                                                                                                                                                                                                    |
|                             | 0300003h   | 00h   |                                                                                                                                                                                                                                                                                                                                                    |
|                             | 0300004h   | F0h   | Global memory bus control word = 1D7BC9F0h                                                                                                                                                                                                                                                                                                         |
| 2                           | 0300005h   | C9h   | (Described in Figure 7–2 on page 7-7.)                                                                                                                                                                                                                                                                                                             |
|                             | 0300006h   | 7Bh   |                                                                                                                                                                                                                                                                                                                                                    |
|                             | 0300007h   | 1Dh   |                                                                                                                                                                                                                                                                                                                                                    |
|                             | 0300008h   | 50h   | Local memory bus control word = 1D739250h                                                                                                                                                                                                                                                                                                          |
| 3                           | 0300009h   | 92h   | (Described in Figure 7–2 on page 7-7.)                                                                                                                                                                                                                                                                                                             |
|                             | 030000Ah   | 73h   |                                                                                                                                                                                                                                                                                                                                                    |
|                             | 030000Bh   | 1Dh   |                                                                                                                                                                                                                                                                                                                                                    |
|                             | 030000Ch   | 26h   | tst source program block size = 126h                                                                                                                                                                                                                                                                                                               |
|                             | 030000Dh   | 01h   | a da                                                                                                                                                                                                                                                                                                           |
|                             | 030000Eh   | 00h   | and a start of the second start<br>A start of the second start of t                                                                                                                |
| MIL "MIL "ILL "HE "HE       | ► 030000Fh | 00h   | and a second second<br>And a second second<br>And a second |
|                             |            | 40h   | 1st source program block starting addr = 2FF840h                                                                                                                                                                                                                                                                                                   |
| 5                           | 0300011h   | F8h   | a ser an                                                                                                                                                                                                                                                                                                       |
|                             | 0300012h   | 2Fh   | an a                                                                                                                                                                                                                                                                                                           |
|                             | 0300013h   | 00h   | a a da a                                                                                                                                                                                                                                                                                                             |
| he alte alte alte alte alte | 1 0800014h |       | 1st source program block starts here (first word)                                                                                                                                                                                                                                                                                                  |
|                             |            |       | an a                                                                                                                                                                                                                                                                                                           |
|                             |            |       | and a second second<br>And a second second<br>And a second |
| 299                         |            |       | a a a a a a a a a a a a a a a a a a a                                                                                                                                                                                                                                                                                                              |
|                             | 03004ABh   |       | tst source program block ends here (last word)                                                                                                                                                                                                                                                                                                     |
|                             | U3004ABn   |       | 1st source program block ends here (last word)                                                                                                                                                                                                                                                                                                     |

Note: Shaded area identifies source program block.

Example concluded on next page

| Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Comments                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| AND ADDRESS AND ADDRESS ADDRES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 03004ACh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 40h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 2nd source program block size = 40                |
| 300                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 03004ADh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
| PROPERTY OF THE SECOND STREET, STRE                                                                                                                                                                                                                                            | 03004AEh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
| CHARTER CONTRACTOR CON | 03004AFh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03004B0h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 2nd source program block starting addr = 2FF800h  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03004B1h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | F8h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
| AND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 03004B2h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03004B3h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03004B4h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | And a start and a start and a start a star                                                                                                                                                                                                                                             | 2nd source program block starts here (first word) |
| 302<br>through                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | and a second and a second and a second and a second a se                                                                                                                                                                                                                                            | and a second sec |                                                   |
| 365                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | and a state of the | Construction and the second se |                                                   |
| and a second second second second second                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | and a state of the | California and a second and a second                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                   |
| AND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 03005B3h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Construction of the second sec | 2nd source program block ends here (last word)    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005B4h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Value 0 to terminate the program block load       |
| 366                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 03005B5h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005B6h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005B7h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005B8h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | IVTP = 002FF800h                                  |
| 367                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 03005B9h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | F8h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005BAh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005BBh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005BCh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | TVTP = 002FF800h                                  |
| 368                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 03005BDh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | F8h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005BEh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005BFh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005C0h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Memory location for IACK instruction = 30 0000h   |
| 369                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 03005C1h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005C2h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 30h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03005C3h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | (This is the final word in the data stream.)      |

Example 13–1. Byte-Wide Configured Memory (Concluded)

Note: Shaded area identifies source program block.

| Example 13-2. | 16–Bits-Wide | Configured Memory |
|---------------|--------------|-------------------|
|---------------|--------------|-------------------|

| Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Comments                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0300000h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0010h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Memory width = 16 bits                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0300001h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0000h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0300002h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | C9F0h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Global memory bus control word = 1D7BC9F0h      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 030003h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1D7Bh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |
| 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0300004h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 9250h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Local memory bus control word = 1D739250h       |
| n. n. n. n. n.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0300005h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1D73h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |
| 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0300006h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0126h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | tst.program block size = 126h                   |
| ······································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0300007h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0000h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |
| 5. S.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0300008h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | F840h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1st program block starting addr = 2FF840h       |
| ······································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0300009h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 002Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |
| 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 030000Ah                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | an a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1st program block starts here (first word)      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                 |
| 6<br>through                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | New Constraints and the second s                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                 |
| 299                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1999,999,999,999,999,999,999,999,999,99                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                 |
| <sup>1</sup> 1 <sup>111111111111111111111111111111111</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0300255h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1st program block ends here (last word)         |
| 300                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0300256h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0040h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2nd program block size = 40h                    |
| and the second s | 0300257h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | .0000h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                 |
| 301                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0300258h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | F800h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2nd program block starting affr = 2FF800h       |
| AND DE ALE A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0300259h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 002Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |
| INTERNAL AND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 030025Ah                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | and a second                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2nd program block starts here (first word)      |
| 302<br>through                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | and a second a secon | A CARACTER AND A CARACTER                                                                                                                                                                                                                                             |                                                 |
| 365                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | and and a second a second a second a second a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | A STATE STATE STATE AND A STAT |                                                 |
| Constant of the second s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | an and a second and a second a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | A REAL PROPERTY AND A REAL |                                                 |
| NAR AND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 03002D9h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | and a second                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2nd program block ends here (last word)         |
| 366                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 03002DAh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0000h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Value 0 to terminate the program block road     |
| States and a state and a stat                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 03002DBh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0000h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |
| 367                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 03002DCh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | F800h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | IVTP = 002FF800h                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03002DDh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 002Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |
| 368                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 03002DEh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | F800h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TVTP = 002FF800h                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03002DFh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 002Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                 |
| 369                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 03002E0h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0000h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Memory location for IACK instruction = 30 0000h |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 03002E1h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0030h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | (This is the final word in the data stream.)    |

Note: Shaded areas identify source program blocks.

| Word                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Word Address Value |                                       | Comments                                          |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|---------------------------------------|---------------------------------------------------|--|
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0300000h           | 00000020h                             | Memory width = 32 bits                            |  |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0300001h           | 1D7BC9F0h                             | Global memory bus control word = 01D7BC9F0h       |  |
| The second states of the secon | 030002h            | 1D739250h                             | Local memory bus control word = 01D739250h        |  |
| Anterna Anterna Anterna Anterna<br>Anterna Anterna                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0300003h           | 00000126h                             | 1st program block size = 126h                     |  |
| ······································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0300004h           | 002FF840h                             | 1st program block starting addr = 2FF840h         |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                    |                                       | 1st program block starts here (first word)        |  |
| 1949 1949 1949 1949 1949 1949 1949 1949                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                    |                                       | tst program block ends here (last word)           |  |
| 300                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 030012Bh           | 00000040h                             | 2nd program block size = 40h                      |  |
| 301                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 030012Ch           | 002FF800h                             | 2nd program block starting addr = 2FF800h         |  |
| 302<br>through<br>365                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 030012Dh           |                                       | 2nd program block starts here (first word)        |  |
| and and an and an and an and an and and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 030016Ch           | · · · · · · · · · · · · · · · · · · · | 2nd program block ends here (last word)           |  |
| 366                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 030016Dh           | 0000000h                              | Value 0 to terminate the program block load       |  |
| 367                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 030016Eh           | 002FF800h                             | IVTP = 002FF800h                                  |  |
| 368                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 030016Fh           | 002FF800h                             | TVTP = 002FF800h                                  |  |
| 369                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0300170h           | 00300000h                             | Address location for IACK instruction = 00300000h |  |

Note: Shaded areas identify source program blocks.

# 13.2.6 IIOF(3-1) Pin Loading

13

The load options are based upon the status of IIOF(3-1) as general-purpose input pins. Therefore, in order to select the correct boot loader mode, pins IIOF(3-1) must be kept at a constant valid status value for a certain time period (values listed in Table 13-1 on page 13-5). See the 'C40 boot loader program for detailed information — Figure 13-4 starting on page 13-14.

After the boot load is complete, the IACK signal is brought down for one cycle. Figure 13–3 shows an example circuit that generates the IIOF(3–1) signals for boot load selection and also allows incoming external interrupts during normal mode of operation. In this example, after reset, the IIOF pins stay low until the IACK signal is received.

Figure 13–3. Circuit for Generation of a Low IIOF signal for Boot Loader Selection



#### 13.2.7 TMS320C40 Boot Loader Source Program

*Figure 13–4.* Boot Loader Source Program

\* C40BOOT - TMS320C40 BOOT LOADER PROGRAM \* (C) COPYRIGHT TEXAS INSTRUMENTS INC., 1990 \* \*NOTE: 1. AFTER DEVICE RESET, THE PROGRAM IS CHECKING THE INPUT STATUS OF IIOF1-3 PINS AND COMMUNI-\* \* CATION PORT INPUT FLAGS TO CONFIGURE ITSELF \* WHEN ON CHIP ROM IS ENABLED (ROMEN=1). THE IIOFO \* PIN IS ASSUMED TO BE PULLED HIGH. \* \* 2. THE FUNCTION SELECTION OF IIOF1-3 IS LISTED AS: \* IIOF3 IIOF2 IIOF1 FUNCTION \* 1 1 0 Memory boot loader from 00300000H 1 0 1 Memory boot loader from 4000000H 1 0 Memory boot loader from 6000000H 0

| ire 13-4. | BOOL | Loader Source | e Progran      | i (Conun                           | ueu)                              |  |  |  |  |  |
|-----------|------|---------------|----------------|------------------------------------|-----------------------------------|--|--|--|--|--|
|           | *    | 0             | 1              | 1                                  | Memory boot loader from 80000000H |  |  |  |  |  |
|           | *    | 0             | 1              | 0                                  | Memory boot loader from A0000000H |  |  |  |  |  |
|           | *    | 0             | 0              | 1                                  | Memory boot loader from C0000000H |  |  |  |  |  |
|           | *    | 0             | 0              | 0                                  | Reserved                          |  |  |  |  |  |
|           | *    | 1             | 1              | 1                                  | Communication Port boot loader    |  |  |  |  |  |
|           | *    |               | I              | 1                                  | l                                 |  |  |  |  |  |
|           | *    | THE PRO       | GRAM AS        | SSUMES                             | THE COMMUNICATION PORT BOOT       |  |  |  |  |  |
|           | *    | LOADER        | IS THE         | DEFAUL                             | T FUNCTION. IF NO OTHER           |  |  |  |  |  |
|           | *    | FUNCTIO       | N IS SE        | ELECTED                            | , THE PROGRAM STARTS CHECKING     |  |  |  |  |  |
|           | *    |               |                |                                    | RT INPUT CHANNELS. IF THERE IS    |  |  |  |  |  |
|           | *    | NO INPU       | T FROM         | A COMM                             | UNICATION PORT, THE PROGRAM       |  |  |  |  |  |
|           | *    | RECHECK       | S THE 1        | LIOF (3-                           | 1) STATUS AGAIN.                  |  |  |  |  |  |
|           | *    |               |                |                                    |                                   |  |  |  |  |  |
|           | *    |               |                |                                    | OADS WORD, HALF-WORD, OR BYTE     |  |  |  |  |  |
|           | *    |               |                |                                    | ERENT SPECIFIED LOCATIONS. THE 8  |  |  |  |  |  |
|           | *    |               |                |                                    | MORY SPECIFIES THE MEMORY WIDTH.  |  |  |  |  |  |
|           | *    |               |                |                                    | BYTE WIDE PROGRAM IS SELECTED,    |  |  |  |  |  |
|           | *    |               |                |                                    | FIRST AND THEN THE MSBs. THE NEXT |  |  |  |  |  |
|           | *    |               |                |                                    | CONTROL WORD FOR THE GLOBAL AND   |  |  |  |  |  |
|           | *    |               |                |                                    | CE CONTROL REGISTERS. NEXT COME   |  |  |  |  |  |
|           | *    |               |                |                                    | THE FIRST TWO WORDS OF EACH       |  |  |  |  |  |
|           | *    |               |                |                                    | N THE BLOCK SIZE AND DESTINATION  |  |  |  |  |  |
|           | *    |               |                |                                    | OGRAM IS TO BE LOADED. WHEN THE   |  |  |  |  |  |
|           | *    |               |                |                                    | EAD, THE PROGRAM BLOCK LOADING    |  |  |  |  |  |
|           | *    |               |                |                                    | XT TWO WORDS ARE THE              |  |  |  |  |  |
|           | *    |               |                | S FOR THE IVTP AND TVTP REGISTERS. |                                   |  |  |  |  |  |
|           | *    |               |                |                                    | G IS COMPLETED, THE IACK SIG-     |  |  |  |  |  |
|           | *    |               |                |                                    | ACCORDING TO THE LAST WORD OF THE |  |  |  |  |  |
|           | *    |               |                |                                    | HE PROGRAM COUNTER WILL           |  |  |  |  |  |
|           | *    |               |                |                                    | NG ADDRESS OF THE FIRST           |  |  |  |  |  |
|           | *    | PROGRAM       | PROGRAM BLOCK. |                                    |                                   |  |  |  |  |  |
|           | *    |               |                |                                    |                                   |  |  |  |  |  |
|           | *    |               |                |                                    | SETUP FOR COMMUNICATION PORT      |  |  |  |  |  |
|           | *    |               | •              |                                    | ESSOR WILL WAIT FOR THE FIRST     |  |  |  |  |  |
|           | *    |               |                |                                    | COMMUNICATION CHANNEL AND USE     |  |  |  |  |  |
|           | *    |               |                |                                    | ORM THE DOWNLOAD. THE BEGIN-      |  |  |  |  |  |
|           | *    |               |                |                                    | D CONTAIN THE GLOBAL AND LOCAL    |  |  |  |  |  |
|           | *    |               |                |                                    | IMILAR TO THE MEMORY LOADER,      |  |  |  |  |  |
|           | *    |               |                |                                    | D INTO DIFFERENT MEMORY           |  |  |  |  |  |
|           | *    |               |                |                                    | RD OF EACH PROGRAM BLOCK CON-     |  |  |  |  |  |
|           | *    |               |                |                                    | MEMORY ADDRESS TO BE LOADED       |  |  |  |  |  |
|           | *    | INTO. W       | HEN TH         | E ZERO                             | BLOCK SIZE IS READ, THE PRO-      |  |  |  |  |  |
|           | *    |               |                |                                    | S TERMINATED. IN OTHER WORDS,     |  |  |  |  |  |
|           | *    |               |                |                                    | E THE PROGRAM BLOCK LOADING, A    |  |  |  |  |  |
|           | *    |               |                |                                    | AT THE END OF PROGRAM BLOCK.      |  |  |  |  |  |
|           | *    |               |                |                                    | RDS ARE THE INITIAL VALUES FOR    |  |  |  |  |  |
|           | *    |               |                |                                    | GISTERS. AFTER THE BOOT LOAD-     |  |  |  |  |  |
|           | *    |               |                |                                    | E IACK SIGNAL WILL BE SENT OUT    |  |  |  |  |  |
|           | *    |               |                |                                    | T WORD OF THE SOURCE MEMORY,      |  |  |  |  |  |
|           | *    |               |                |                                    | TER WILL BRANCH TO THE START-     |  |  |  |  |  |
|           | *    | ING ADD       | RESS OF        | THE F                              | IRST PROGRAM BLOCK.               |  |  |  |  |  |
|           |      |               |                |                                    |                                   |  |  |  |  |  |

| Figure 13-4. | Boot Loa | der Source | Program | (Continued) |
|--------------|----------|------------|---------|-------------|
|              |          |            |         | 00          |

# Figure 13–4. Boot Loader Source Program (Continued)

| *****        | .page        | ****                     | **  | *****                                                          |  |  |  |  |
|--------------|--------------|--------------------------|-----|----------------------------------------------------------------|--|--|--|--|
| *            |              |                          |     |                                                                |  |  |  |  |
| ************ |              |                          |     |                                                                |  |  |  |  |
|              | .sect        | "vectors"                |     |                                                                |  |  |  |  |
| RESET        | .word        | START                    | ;   | On hardware RESET go to START                                  |  |  |  |  |
| *****        | *****        | ****                     | **  | *****                                                          |  |  |  |  |
| *            |              |                          |     | R BOOT LOADER *                                                |  |  |  |  |
| *****        |              |                          |     | ****                                                           |  |  |  |  |
|              | .text        |                          |     |                                                                |  |  |  |  |
| START:       |              | 04440H,IIF               | ;   | Test IIOF0 pin conditiom                                       |  |  |  |  |
|              | BEQ          | LIFETEST                 | ;   | If low, execute life test                                      |  |  |  |  |
|              | LDHI         | 0010H,AR0                | ;   | Load peripheral mem. map start<br>addr 100000H                 |  |  |  |  |
|              | LDHI         | 002FH, SP                | ;   | Initialize stack pointer SP to                                 |  |  |  |  |
|              | OR           | OFFFOH, SP               | ;   | internal RAM address 2FFFFOH                                   |  |  |  |  |
|              | LDI          | 0,R0                     |     | Set start address flag off                                     |  |  |  |  |
|              | LDI          | COM_LOAD,R10             | ;   | Comm. port load subroutine                                     |  |  |  |  |
|              |              |                          |     | address -> R10                                                 |  |  |  |  |
|              |              |                          |     |                                                                |  |  |  |  |
| *            |              |                          | _   |                                                                |  |  |  |  |
| * C          | HECK TH      | HE IIOF1-3 FOR           | . Т | HE BOOT LOADER                                                 |  |  |  |  |
| CHECK:       | LDHT         | 0030H,AR1                |     | Load memory address = 00300000H                                |  |  |  |  |
| 0111011.     | CMPI         | 04404H,IIF               | ;   | Test function 110 condition                                    |  |  |  |  |
|              | BEQ          | MEMORY                   | ;   | If true, execute memory boot                                   |  |  |  |  |
| *            |              |                          |     | loader                                                         |  |  |  |  |
|              | LDHI         | 04000H,AR1               | ;   | Load memory address = 40000000H                                |  |  |  |  |
|              | CMPI         | 04044H,IIF               |     | Test function 101 condition                                    |  |  |  |  |
| *            | BEQ          | MEMORY                   | ;   | If true, execute memory boot<br>loader                         |  |  |  |  |
|              | LDHI         | 06000H,AR1               | ;   | Load memory address = 60000000H                                |  |  |  |  |
|              | CMPI         | 04004H,IIF               | ;   |                                                                |  |  |  |  |
|              | BEQ          | MEMORY                   | ;   | If true, execute memory boot                                   |  |  |  |  |
| *            | T D I T      | 000000 351               |     | loader                                                         |  |  |  |  |
|              | LDHI<br>CMPI | 08000H,AR1<br>00444H,IIF |     | Load memory address = 80000000H<br>Test function 011 condition |  |  |  |  |
|              | BEO          | MEMORY                   | ;;  | If true, execute memory boot                                   |  |  |  |  |
| *            |              |                          | '   | loader                                                         |  |  |  |  |
|              | LDHI         | 0A000H,AR1               | ;   | Load memory address = A0000000H                                |  |  |  |  |
|              | CMPI         | 00404H,IIF               | ;   | Test function 010 condition                                    |  |  |  |  |
|              | BEQ          | MEMORY                   | ;   | If true, execute memory boot                                   |  |  |  |  |
| *            | TDUT         | 00000 301                |     | loader                                                         |  |  |  |  |
|              | LDHI<br>CMPI | 0C000H,AR1<br>00044H,IIF |     | Load memory address = C0000000H<br>Test function 001 condition |  |  |  |  |
|              | BEQ          | MEMORY                   | ;   | If true, execute memory boot                                   |  |  |  |  |
| *            |              |                          | 1   | loader                                                         |  |  |  |  |
|              | CMPI         | 00004H,IIF               |     | Test function 000 condition                                    |  |  |  |  |
|              | BEQ          | RESERVED                 | ;   | If true, branch to reserve                                     |  |  |  |  |

Figure 13–4. Boot Loader Source Program (Continued)

COMMUNICATION PORT BOOT LOADER \* CHECK COMMUNICATION PORT INPUT CHANNEL ADDI 040H, AR0, AR3 ; Point to comm. port 0 \* control register addr LDI 5, AR1 ; Set loop counter for CHECK CH loop \* CHECK\_CH: LSH3 -9,\*AR3,R1 ; Check comm port input BNZ LOAD1 ; If input exist, start comm \* port loader ADDI 010H, AR3 ; Point to next comm. port channel addr DBU AR1, CHECK CH ; Check next comm. port channel input CHECK ; Recheck the input flags в MEMORY BOOT LOADER \* \* TEST MEMORY WORD WIDTH \* MEMORY: LDI \*AR1++(1),R1 ; Load the memory word width
LDI W\_WIDE,R10 ; Full-word size subroutine \* address -> R10 ; Test bit5 of mem. width word LSH 26,R1 BN LOADO ; If '1' start PGM loading (32 bits width) \* NOP \*AR1++(1) ; Jump last half word from mem. word ; Half-word size subroutine LDI H WIDE, R10 address -> R10 LSH 1,R1 BN LOADO ; Test bit4 of mem. width word ; If '1' start PGM loading (16 bits width) \* LDI B WIDE, R10 ; Byte size subroutine address -> R10 \* ADDI 2,AR1 ; Jump last 2 bytes from mem. word \* \* START PROGRAM LOADING 4 LOADO: CALLU R10 ; Load new word according to mem. width STI AR2,\*AR0 ; Set global bus control register CALLU R10 ; Load new word according to mem. width STI AR2, \*+AR0(4) ; Set local bus control register

| ure 13–4. | Boot Load                                                                                         | der Source     | Program (Continued)  |             |                                                                                 |  |  |
|-----------|---------------------------------------------------------------------------------------------------|----------------|----------------------|-------------|---------------------------------------------------------------------------------|--|--|
|           | LOAD2:                                                                                            | CALLU          | R10                  | ;           | Load new word according to mem. width                                           |  |  |
|           | *                                                                                                 | SUBI3          | 1,AR2,RC             | ;           | Set block size for<br>repeat loop                                               |  |  |
|           | *                                                                                                 | CMPI<br>BEQ    | -1,RC<br>IVTP_LOAD   | ;           | If 0 block size start PGM                                                       |  |  |
|           |                                                                                                   | CALLU          | R10                  | ;           | Load new word according to mem. width                                           |  |  |
|           | *                                                                                                 | LDI<br>LDI     | AR2,AR0<br>R0,R0     | ;           | ; Set destination address<br>Test start address loaded<br>flag                  |  |  |
|           | *                                                                                                 | LDIZ           | AR2,R9               | ;           | Load start address if flag<br>off                                               |  |  |
|           | *                                                                                                 | LDI            | -1,R0                | ;           | Set start & dest. address flag on                                               |  |  |
|           |                                                                                                   | SUBI           | 1,R10                |             | Sub address with loop                                                           |  |  |
|           | *                                                                                                 | CALLU          | R10<br>1,R0          |             | Load block words according<br>to mem. width<br>Set dest. address flag off       |  |  |
|           | *                                                                                                 | ADDI<br>B      | 1,R10<br>LOAD2       | ;           | Sub address without loop<br>Jump to load a new block<br>when loop completed     |  |  |
|           | *<br>* TI                                                                                         | ΝΤͲΤΑΤ.Τ       | ZE IVTP AND TVTE     | ਜ ਸ         |                                                                                 |  |  |
|           | *                                                                                                 |                | LU R10               |             | Load new word according to                                                      |  |  |
|           | * -<br>TVTP_L                                                                                     | LDP<br>OAD:CAL | E AR2,IVTP<br>LU R10 | ;           | nem. width<br>Load the IVTP pointer<br>Load new word according to<br>mem. width |  |  |
|           | *                                                                                                 |                | LU R10               | ;           | Load the TVTP pointer<br>Load new word according to<br>mem. width               |  |  |
|           |                                                                                                   | IAC<br>BU      | K *AR2<br>R9         |             | Send out IACK signal out                                                        |  |  |
|           | BU         R9         ; Branch to start of program           ************************************ |                |                      |             |                                                                                 |  |  |
|           | LOOP B                                                                                            |                |                      |             | PGM load loop                                                                   |  |  |
|           | B_WIDE                                                                                            |                | 0 *AR1++(1),AF       |             | Load byte 0 (LSB)                                                               |  |  |
|           |                                                                                                   | LWI<br>NOP     |                      | χ2 <b>;</b> | Join byte 1 with byte 0                                                         |  |  |
|           |                                                                                                   | LWI<br>NOP     | · · · ·              |             | Join byte 2 with byte 0 & 1                                                     |  |  |
|           | *                                                                                                 | LWI            |                      |             | Join byte 3 with byte 0, 1,<br>& 2                                              |  |  |
|           |                                                                                                   | LDI<br>BNN     | B_END                |             | Test load address flag                                                          |  |  |
|           | LOAD_B                                                                                            |                |                      |             | Store new word to dest.<br>address                                              |  |  |
|           | B_END:                                                                                            | REI            | SU                   | ;           | Return from subroutine                                                          |  |  |

Figu 10 ı٦

Hardware Applications

#### Figure 13–4. Boot Loader Source Program (Concluded)

\* HALF-WORD WIDE MEMORY BOOT LOADER SUBROUTINE LOOP H: LOAD H ; PGM load loop RPTB H WIDE: LWLO \*AR1++(1), AR2; Load LSB half-word NOP LWL2 \*AR1++(1), AR2; Join MSB half-word with \* LSB half-word LDI R0,R0 ; Test load address flag BNN H END LOAD H STI AR2,\*AR0++(1); Store new word to dest. address H END RETSU ; Return from subroutine \* FULL-WORD WIDE MEMORY BOOT LOADER SUBROUTINE LOAD W ; PGM load loop LOOP W RPTB \*AR1++(1), AR2; Read a new 32 bits word W WIDE LDI LDI R0,R0 ; Test load address flag BNN W END STI  $A\overline{R}2$ , \*AR0++(1); Store new word to dest. LOAD W address W END RETSU ; Return from subroutine \* COMMUNICATION PORT BOOT LOADER SUBROUTINE LOOP C LOAD C RPTB ; PGM load loop -9,\*AR3,R1 ; Check comm port input COM\_LOAD ; Wait for comm port input COM LOAD LSH3 ΒZ LDI \*+AR3(1),AR2 ; Read a new 32 bits word ; Test load address flag LDI R0,R0 C END BNN  $A\overline{R}2$ , \*AR0++(1): Store new word to dest. LOAD C STI address C END ; Return from subroutine RETSU **RESERVED:** 

.end

an An An An An An An

# 13.3 Global and Local Bus Interface

The 'C40 uses the global and local buses to access the majority of its memory-mapped locations. Since these two memory interfaces are identical in every way, except for their positions in the memory map, each example in this memory interface section focuses on only one of the two interfaces. However, all of the examples are applicable to either the local or global bus. Additionally, each of the buses features two identical, mutually exclusive sets of control signals:

| Global<br>Bus | Local<br>Bus |
|---------------|--------------|
| STRB0         | LSTRB0       |
| STRB1         | LSTRB1       |
| CE0           | LCE0         |
| CE1           | LCE1         |
| RDY0          | LRDY0        |
| RDY1          | LRDY1        |

Also,  $\overline{AE}$  and  $\overline{DE}$  put the global bus in high impedance, and  $\overline{LAE}$  and  $\overline{LDE}$  put the local bus in high impedance.

Although both the global and the local buses can interface to a wide variety of devices, the devices most commonly interfaced are memories. Therefore, memory interface examples are used in this section.

#### 13.3.1 Zero Wait-State Interface to RAMs

For a full-speed, zero wait-state interface to any device, a 50-MHz 'C40 (40-ns instruction cycle time) requires a read access time of 21-ns from address stable to data valid. For most memories, the access time from chip enable is the same as access time from address; thus, it is possible to use 20-ns memories at full speed with a 50-MHz 'C40. However, to properly use 20-ns memories, there can be no long delays between the processor and the memories. Avoiding these delays is not always possible in practice, because of interconnection delays and the fact that gating is sometimes required for chip enable generation. In addition, if a memory device with an output enable is chosen, output enable must become active soon enough to ensure that the memory can meet the data valid timing requirements of the 'C40. For memories with 20-ns access times, the output enable active to data valid timing parameter is typically less than 10 ns.

Currently available RAMs without output enable (OE) control lines include the 1-bit wide organized RAMs and most of the 4-bit wide RAMs. Those with OE controls include the byte-wide and a few of the 4-bit wide RAMs. Many of the fastest RAMs do not provide OE control; they use chip-enable (CE) controlled write cycles to ensure that data outputs do not turn on for write operations. In CE-controlled write cycles, the write control line ( $\overline{WE}$ ) goes low before CE goes low, and internal logic holds the outputs disabled until the cycle is completed. Using CE-controlled write cycles is an efficient way to interface fast RAMs without OE controls to the 'C40 at full speed.

#### 13.3.1.1 RAM Interface - Using One Local Strobe

Figure 13–5 shows the 'C40's local bus interfaced to the Integrated Device Technology™ IDT71258 20-ns 64K x 4-bit CMOS static RAMs with zero wait states using chip enable-controlled write cycles. These RAMs are arranged to implement 64K, 32-bit words located at addresses 00000h thru 0FFFFh (internal ROM is assumed to be disabled), which are the first 64K words in external memory. If these 64K words of SRAM are the only memory controlled by LSTRB0, the LSTRB ACTIVE field of the local memory interface control register (LMICR) should be set to its minimum value 011112, allowing LSTRB0 to be active only for the first 64K words of the 'C40's memory space. (The memory interface control register and its various fields are shown in Figure 7–2 on page 7-7). In addition, because this memory is the only memory interfaced to LSTRB0, LSTRB0 requires only one page. The PAGESIZE field of the LMICR should be set to 011112. Also note that in Figure 13-5, the LRDY0 input is tied low, selecting zero wait states for all LSTRB0 accesses on the local bus. With all of the zero-wait-state memory controlled by LSTRB0, LSTRB1 can be used to control accesses to slower read-only memory devices or other types of memory.





In this circuit implementation, no external logic is necessary to interface the 'C40 to the memory device. This glueless interface is possible because changes in LR/W are always framed by LSTRB. For typical memory devices, it is necessary to hold the device inactive ( $\overline{CS}$  inactive) during changes in WE; this avoids undesired memory accesses while the address changes. The 'C40 ensures this by having LSTRB always frame changes in LR/W. (See Section 7.5 on page 7-17 for more information.)

#### 13.3.1.2 Consecutive Reads Followed by a Write Interface Timing

Figure 13–6 shows the timing of consecutive reads followed by a write. For consecutive reads, LSTRB0 stays active (low), and LR/ $\overline{W}$  stays high as long as read cycles continue. The critical timing that must be met for back-to-back reads is the address-valid to data-valid time. The 'C40 requires zero-wait-state memories to have an address-valid to data-valid time of less than 21-ns. This can be explained in more detail as:

one H1 cycle time - [(H1 low to address-valid time) + (data setup time before H1 low)]

For most memory devices, this time is the same as the memory access time, which is  $t_1 = 20$  ns. Thus, memories with access times of 25 ns or more cannot meet this timing.

Memory device timing is not as critical for zero-wait-state as for nonzerowait-state write cycles, because of the two H1 cycle writes of the 'C40. The extra cycle gives LSTRB0 enough time to frame LR/W, preventing memories that go into high impedance slowly at the end of a read cycle from driving the bus during the subsequent write cycle. For the memory device used in this design (Figure 13–6), the data lines are guaranteed to be three stated ( $t_2 = 10$  ns) after  $\overline{CS}$  goes inactive, which gives more than 23 ns of margin before the 'C40 starts driving the bus with write data. Also, the extra cycle with LSTRB0 inactive prevents writes to random locations in memory while the address is changing between consecutive writes.

For the write cycles shown in Figure 13–6 and Figure 13–7, the RAM requires 15 ns of write data setup before  $\overline{CS}$  goes high, and this design provides at least 24 ns (t<sub>3</sub>). A data hold time of 0 ns (t<sub>4</sub>) is required by the RAM, and this design provides greater than 13 ns. Finally, the RAM's setup and hold times for address (with respect to  $\overline{CS}$  high) of 20 and 0 ns, respectively, are also met with a clear margin.





Figure 13–7. Consecutive Writes Followed by a Read



#### 13.3.1.3 Consecutive Writes Followed by a Read Interface Timing

Figure 13–7 shows the timing of consecutive writes followed by a read. Notice that between consecutive writes, LR/W stays low, but STRB0 goes inactive to frame the write cycles. Although 'C40 zero-wait-state writes take two H1 cycles, internally (from the perspective of the CPU and DMA) writes appear to take one cycle if no accesses to that interface is already in progress.

In the read cycle following the writes in Figure 13–7, the 'C40 requires zero-wait-state memories to have a LSTRB active to data-valid time of less than 21 ns (one H1 cycle time minus (H1 low to LSTRB active time plus data setup time before H1 low)). For most memory devices, this time is the same as the memory access time, which is  $t_1 = 20$  ns in this design. Thus, a margin of only 1 ns exists, leaving little time for STRB gating if desired.

#### 13.3.1.4 RAM Interface Using Both Local Strobes

Figure 13–8 shows the 'C40's local bus interfaced to IDT71258 RAMS — 20-ns 64K x 4-bit CMOS static RAMs with zero wait states using  $\overline{CS}$  controlled write cycles. These RAMs are arranged to allow 128K 32-bit words of local memory, which is implemented as two 64K x 32-bit banks. One bank is controlled by each of the two sets of control signals on the local bus. To map these memory devices properly in the 'C40's memory space, you must use the local memory interface control register (LMICR) to define which part of the local bus's memory space is mapped to each of the two strobes. In this implementation with internal ROM disabled, LSTRB0 is mapped to the first 64K words of the local space - addresses 0h through 0FFFFh, and LSTRB1 is mapped to the rest of the local space — addresses 10000h through 7FFF FFFFh. For this memory configuration, the LSTRB ACTIVE field of the local memory interface control register (LMICR) should be set to 011112. Also, each LSTRB requires only one page. The PAGESIZE field of the LMICR should be set to 01111<sub>2</sub>. Also, note that in Figure 13–8, the LRDY inputs are tied low, selecting zero wait states for all accesses on the local bus.

Hence, through the use of the 'C40's four strobes (two each on the local and global buses), four different banks of memory can be decoded. In addition, the address decoding can be changed under program control by changing the LSTRB active field (bits 24–28) of the LMICR or the global memory interface control register (GMICR). If more than four banks of memory must be decoded or if the chosen memory device cannot meet the read cycle timing requirements for the 'C40 at zero wait states, page switching (discussed in subsection 13.4.6 on page 13-32) should be used to add an extra cycle to read accesses outside the current bank boundary.



Figure 13–8. TMS320C40 Interface to Zero-Wait-State SRAMs, Two Strobes

# 13.4 Wait States and Ready Generation

The use of wait states can greatly increase system flexibility and reduce hardware requirements over systems without wait-state capability. The 'C40 has the capability of generating wait states on either the global bus or the local bus, and both buses have independent sets of ready control logic. The buses' wait-state configuration is determined by the SWW and WTCNT fields of the local and global bus interface control registers (see Section 7.4, page 7-15, for a detailed description of the wait-state options).

This section discusses ready generation from the perspective of the *global bus* interface; however, wait-state operation on the *local bus* is the same as on the global bus, so this discussion pertains equally well to both (local and global). Also, the local and global buses each have two sets of control signals — R/W0, STRB0, RDY0, and R/W1, STRB1, RDY1 — with each set of control signals having its own ready signal, providing for more flexibility in support of external devices with different speeds. Since both strobes' ready signals share the same electrical characteristics, the following discussion focuses on one of the global bus's set of control signals.

Wait states are generated on the basis of:

- □ the internal wait-state generator,
- □ the external ready inputs (RDY0 or RDY1), or
- □ the logical AND or OR of the two (discussed in Section 7.4, page 7-15).

When enabled, internally generated wait states affect all external cycles, regardless of the address accessed. If different numbers of wait states are required for various external devices, the external RDY input may be used to customize wait-state generation to specific system requirements.

If either the logical OR or electrical AND (since the signals are true low) of the external and wait-count ready signals is selected, the earlier of the two signals will generate a ready condition and allow the cycle to be completed. It is not required that both signals be present.

# Note: STRBx SWW Field Values

The STRBx SWW fields of the memory-interface control register are shown in Figure 7–2 (page 7-7) and explained in Table 7–7 (page 7-16).

# **13.4.1** ORing of the Ready Signals (STRBx SWW = 10)

The OR of the two ready signals can be used to implement wait states for devices that require a greater number of wait states than are implemented with internal logic (up to seven). This feature is useful, for example, if a system contains some fast and some slow devices. In this case:

- Fast devices can generate ready externally with a minimum of logic. When fast devices are accessed, the external hardware responds promptly with ready, which terminates the cycle.
- Slow devices can use the internal wait counter for larger numbers of wait states. When slow devices are accessed, the external hardware does not respond, and the cycle is appropriately terminated after the internal wait count.

The OR of the two ready signals may also be used if conditions occur that require termination of bus cycles before the number of wait states implemented with external logic. In this case, a shorter wait count is specified internally than the number of wait states implemented with the external ready logic, and the bus cycle is terminated after the wait count. This feature may also be used as a safeguard against inadvertent accesses to nonexistent memory that would never respond with ready and would therefore lock up the 'C40.

If the OR of the two ready signals is used, however, and the internal waitstate count is less than the number of wait states implemented externally, the external ready generation logic must have the ability to reset its sequencing to allow a new cycle to begin immediately following the end of the internal wait count. This requires that, under these conditions:

- consecutive cycles must be from independently decoded areas of memory (or from different pages in memory), and
- the external ready generation logic must be capable of restarting its sequence as soon as a new cycle begins.

Otherwise, the external ready generation logic may lose synchronization with bus cycles and therefore generate improperly timed wait states.

## 13.4.2 ANDing of the Ready Signals (STRBx SWW = 11)

If the logical AND (electrical OR) of the wait count and external ready signals is selected, the later of the two signals will control the internal ready signal, but both signals must occur. Accordingly, external ready control must be implemented for each wait-state device, and the wait count ready signal must be enabled.

This feature is useful if there are devices in a system that are equipped to provide a ready signal but cannot respond quickly enough to meet the

'C40's timing requirements. In particular, if these devices normally indicate a ready condition and, when accessed, respond with a wait until they become ready, the logical AND of the two ready signals can be used to save hardware in the system. In this case, the internal wait counter can provide wait states initially, and then the external ready can provide wait states after the external device has had time to send a not-ready indication. The internal wait counter then remains ready until the external device also becomes ready, which terminates the cycle.

Additionally, the AND of the two ready signals may be used for extending the number of wait states for devices that already have external ready logic implemented but require additional wait states under certain unique circumstances.

#### **13.4.3 External Ready Generation**

In the implementation of external ready generation hardware, the particular technique employed depends heavily on the specific characteristics of the system. The optimum approach to ready generation varies, depending on the relative number of wait-state and nonwait-state devices in the system and on the maximum number of wait states required for any one device. The approaches discussed here are intended to be general enough for most applications and are easily modifiable to comprehend many different system configurations.

In general, ready generation involves the following three functions:

- 1) Segmentation of the address space in some fashion to distinguish fast and slow devices.
- 2) Generation of properly timed ready indications.
- 3) Logical ORing of all the separate ready timing signals together to connect to the physical ready input.

Segmentation of the address space is required to obtain a unique indication of each particular area within the address space that requires wait states. This segmentation is commonly implemented in a system in the form of chip-select generation. Chip-select signals may be used to initiate wait states in many cases; however, occasionally, chip-select decoding considerations may provide signals that will not allow ready input timing requirements to be met. In this case, *coarse* address space segmentation may be made on the basis of a small number of address lines, where simpler gating allows signals to be generated more quickly. In either case, the signal indicating that a particular area of memory is being addressed is normally used to initiate the ready or wait-state signal.

Once the region of address space being accessed has been established, a timing circuit of some sort is normally used to provide a ready indication to the processor at the appropriate point in the cycle to satisfy each device's unique requirements.

Finally, since indications of ready status from multiple devices are typically present, the signals are logically ORed by using a single gate to drive the RDY input.

#### 13.4.4 Ready Control Logic

One of two basic approaches may be taken in the implementation of ready control logic, depending upon the state of the ready input between accesses. If RDY is low between accesses, the processor is always ready unless a wait state is required; if RDY is high between accesses, the processor will always enter a wait state unless a ready indication is generated.

If RDY is low between accesses, control of devices that are zero-waitstate at full speed is straightforward; no action is necessary, because ready is always active unless otherwise required. Devices requiring wait states, however, must drive ready high fast enough to meet the input timing requirements. Then, after an appropriate delay, a ready indication must be generated. This can be quite difficult in many circumstances because wait-state devices are inherently slow and often require complex select decoding.

If RDY **is high between accesses**, zero-wait-state devices, which tend to be inherently fast, can usually respond immediately with a ready indication. Wait-state devices may simply delay their select signals appropriately to generate a ready. Typically, this approach results in the most efficient implementation of ready control logic. Figure 13–9 shows a circuit of this type, which can be used to generate 0, 1, or 2 wait states for multiple devices in a system.



Figure 13–9. Logic for Generation of 0, 1, or 2 Wait States for Multiple Devices

#### **13.4.5 Example Circuit**

Figure 13–9 shows how a single, 7-ns 16R4 programmable logic device (PLD) can be used to generate 0, 1, and 2 wait states for multiple devices that are interfaced to a TMS320C40. In this example, distinct address bits are used to select the different wait-state devices. Here, each of the three address lines input to the 16R4 corresponds to a different speed device. For a single 16R4 implementation, up to ten different address bits can be used to select different speed devices.

The single output, 4Q, of the PLD is connected directly to the RDY0 input of the TMS320C40 to signal the completion of a bus access when external wait-state generation is desired (see Section 7.4 on page 7-15 for more information on TMS320C40 wait-state options). Since, RDY0 is sampled on the falling of H1, the H3 output clock is used as the PLD clock input.

Figure 13–10 shows the state machine and equation for programming the 16R4 PLD ready logic. The PLD language shown in this figure is ABEL. STRB0 is an input into the PLD that indicates that a valid TMS320C40 bus cycle is occurring. RESET can also be used to bring the state machine back to the idle state.

Notice that the  $\overline{\text{RDY0}}$  output of the PLD is not registered. An asynchronous  $\overline{\text{RDY0}}$  signal is necessary to generate a ready signal for zero-wait-state devices. When a zero-wait-state device is selected (ahi1 high in Figure 13–10 and  $\overline{\text{STRB0}}$  is low, the PLD asserts  $\overline{\text{RDY0}}$  low within 7 ns. Hence,  $\overline{\text{RDY0}}$ 

goes active fast enough to satisfy the 20-ns setup time of  $\overline{\text{RDY}}$ 0 low before H1 low.

For generation of  $\overline{\text{RDY0}}$  for one and two wait states, the device select address bits and  $\overline{\text{STRB0}}$  are delayed one and two cycles, respectively, by the PLD before a  $\overline{\text{RDY0}}$  is brought active low. The one H3-cycle delay required for one-wait-state device ready generation corresponds to state wait\_one in Figure 13–10 and the two H3-cycle delay required for two-wait-state devices corresponds to state wait\_twoa and wait\_twob.

This 16R4 PLD-based design can be used to implement different numbers of wait states for multiple devices. More devices can be selected with TMS320C40 address lines, and a higher number of wait states can be produced with a PLD logic. Furthermore, this approach can be used in conjunction with the TMS320C40's internal wait-state generator.

#### 13.4.6 Page Switching Techniques

The 'C40's programmable page switching feature can greatly ease system design when large amounts of memory or slow external peripheral devices are required. This feature can provide a time period for disabling all device selects that would not normally be present otherwise (refer to subsection 7.3.2 on page 7-13 for further information regarding page switching). During this interval, slow devices are allowed time to turn off before other devices have the opportunity to drive the data bus, thus avoiding bus contention.

When page switching is enabled, any time a portion of the high-order address lines changes, as defined by the contents of the STRB0 and STRB1 PAGESIZE fields (in the global and local memory interface control registers), the corresponding STRB and PAGE go high for one full H1 cycle. Provided that STRB is included in chip-select decodes, this causes all devices selected by that STRB to be disabled during this period. The next page of devices is not enabled until STRB and PAGE go low again.

If the high-order address lines remain constant during a read cycle, the memory access is the same as that of a memory access without page switching. In addition, page switching is not required during writes, because these cycles exhibit an inherent one-half H1 cycle setup of address information before STRB goes low. Thus, when you use page switching for read/write devices, a minimum of half of one H1 cycle of address setup is provided for all accesses outside a page boundary. Therefore, large amounts of memory can be implemented without wait states or extra hardware required for isolation between pages. Also, note that access time for cycles during page switching is the same as that of cycles without page switching, and, accordingly, full-speed accesses may still be accomplished within each page.

The circuit shown in Figure 13–10 illustrates the use of page switching with the Cypress Semiconductor<sup>™</sup> CY7B185 15-ns 8K x 8 BICMOS static RAM. This circuit implements 32K 32-bit words of memory with full-speed zero wait-state accesses within each page.

| Figure 13–10. State Machine and Equation for the 16R4 I | 1 PLC | 16R4 | for the | uation f | and Ec | Machine | State | 13–10. | Fiaure |
|---------------------------------------------------------|-------|------|---------|----------|--------|---------|-------|--------|--------|
|---------------------------------------------------------|-------|------|---------|----------|--------|---------|-------|--------|--------|

```
0001
            module
        Т
                          ready_generation
0002
             title'
                          ready generation logic for 0, 1 and 2
        1
                          wait state devices interfaced to
0003
                          TMS320C40'
        1
0004
        Т
0005
                 c40u5
                          device 'P16R4';
0006
0007
                 "inputs
0008
                 h3
                         Pin 1;
0009
0010
0011
                 "The following are TMS320C40 address bits used to
0012
                 "select the different speed devices. More can be used if
0013
                 "necessary. In this example, a zero wait state, a one wait
                 "state, and a two wait state device are decoded with these
0014
                 "three address bits
0015
                              Pin 2; "when high selects zero wait state device
Pin 3; "when high selects one wait state device
Pin 4; "when high selects two wait state device
Pin 5; "indicates valid TMS320C40 bus cycle
0016
                 ahil
0017
                 ahi2
0018
                 ahi3
0019
                 strb0
                              Pin 6; "reset signal from TMS320C40
0020
                 reset
0021
0022
                 "output
0023
                 rdy0
                              Pin 12; "ready signal to TMS320C40
0024
0025
                 one wait
                              Pin 14; "internal flip-flop signal for 1 wait state
0026
                                        "device ready signal generation
0027
                 two waita
                              Pin 15; "internal flip-flop signal for first of the
two
0028
                 "wait states for 2 wait state devices
0029
                  two waitb Pin 16; "internal flip-flop signal for second
0030
                                        "of the two wait states for 2 wait
0031
                                           state devices
0032
0033
                 "name substitutions for test vectors
0034
                 C, H, L, X = .C., 1, 0, .X.;
0035
0036
0037
                 "state bits
0038
                 outstate = [one wait, two waita, two waitb];
0039
```

Figure 13–10. State Machine and Equation for the 16R4 PLD (Concluded)

| 0040<br>0041<br>0042<br>0043<br>0044<br>0045 | <pre>idle = ^b111;<br/>wait_one = ^b011;<br/>wait_twoa = ^b101;<br/>wait_twob = ^b110;</pre>      |
|----------------------------------------------|---------------------------------------------------------------------------------------------------|
| 0046                                         | <br> state_diagram outstate                                                                       |
| 0047<br>0048                                 | <br> state idle:                                                                                  |
| 0049<br>0050                                 | if (reset_& ahi2 & !strb0_) then wait_one                                                         |
| 0051                                         | <pre>l else if (reset_ &amp; ahi3 &amp; !strb0_) then wait_twoa l else idle;</pre>                |
| 0052<br>0053                                 |                                                                                                   |
| 0054                                         | state wait_one:                                                                                   |
| 0055<br>0056                                 | GOTO idle;                                                                                        |
| 0057                                         | state wait_twoa:                                                                                  |
| 0058<br>0059                                 | <pre>if (reset_) then wait_twob else idle;</pre>                                                  |
| 0060                                         |                                                                                                   |
| 0061<br>0062                                 | state wait_twob:<br>                                                                              |
| 0063                                         |                                                                                                   |
| 0064<br>0065                                 | <pre>lequations  </pre>                                                                           |
|                                              | ! !two_waitb) ;                                                                                   |
| 0066<br>0067                                 | l @page                                                                                           |
| 0068                                         | "Test 1st level global arbitration logic                                                          |
|                                              | <pre>ltest_vectors  ([h3,ahi1,ahi2,ahi3,strb0 , reset ] -&gt; [outstate, rdy0 ])</pre>            |
| 0071                                         | <pre>/[c, X, X, X, X, X, L ] -&gt; [idle, H ];</pre>                                              |
|                                              | <pre>[[c, L, H, L, L, H] -&gt; [wait_one, L];</pre>                                               |
|                                              | <pre> [c, X, X, X, X, L] -&gt; [idle, H];<br/> [c, L, L, H, L, H] -&gt; [wait_twoa, H];</pre>     |
| 0075                                         | <pre>[[c, X, X, X, X, L] -&gt; [idle, H];</pre>                                                   |
|                                              | <pre>[[c, L, L, H, L, H] -&gt; [wait_twoa, H];</pre>                                              |
|                                              | <pre> [c, L, L, H, L, H ] -&gt; [wait_twob, L ];<br/> [c, X, X, X, X, L ] -&gt; [idle, H ];</pre> |
|                                              | [L, H, L, L, L, H ] -> [idle, L ];                                                                |
|                                              | [ C, H, L, L, L, H ] -> [idle, L ];<br> [ L, L, L, L, L, H ] -> [idle, H ];                       |
|                                              | $ [c, L, H, L, L, H] \rightarrow [wait one, L];$                                                  |
|                                              | <pre>[[c, X, X, X, X, H] -&gt; [idle, H];</pre>                                                   |
|                                              | [ c, L, L, H, L, H ] -> [wait_twoa, H ];<br> [ c, L, L, H, L, H ] -> [wait_twob, L ];             |
| 0086                                         | <pre>/(c, L, L, L, L, H ] -&gt; [idle, L ];</pre>                                                 |
|                                              | $ [c, X, X, X, H, H] \rightarrow [idle, H];$                                                      |
|                                              | <pre> [c, X, X, X, H, H] -&gt; [idle, H];<br/> end ready_generation</pre>                         |
|                                              |                                                                                                   |



Figure 13–11. Page Switching for the Cypress Semiconductor™ CY7C185

A 5-ns, '16L8 PLD decodes lines A15 – A13. These lines along with  $\overline{STRB0}$  select each of the four pages in this circuit. With the PAGESIZE field of  $\overline{STRB0}$  of the global memory interface control register set to 0Ch, the pages are selected on even 8K-word boundaries, starting at location zero in external memory space.

This circuit cannot be implemented without page switching, because data output's turn-on and turn-off delays cause bus conflicts, and full-speed accesses do not allow enough time for chip-select decoding for the four pages. Here, the propagation delay of the 16L8 is involved only during page switches, where there is sufficient time between cycles to allow new chip-selects to be decoded.

The timing of this circuit for read operations using page switching is shown in Figure 13–12. When a page switch occurs, the page address on address lines A30 – A13 is updated during the extra H1 cycle while STRB0 is high. Then, after chip-select decodes have stabilized and the previously selected page has disabled its outputs, STRB goes low for the next read cycle. Further accesses occur at full speed with the normal bus timings, as long as another page switch is not necessary. Write cycles do not require page switching, because of the inherent address setup provided in their timings.

This timing is summarized in Table 13–3.

13-35





Table 13–3. Page Switching Interface Timing

| Time<br>Interval | Event                            | Time Period |
|------------------|----------------------------------|-------------|
| t <sub>1</sub>   | H1 falling to address/STRB valid | 7 ns        |
| t <sub>2</sub>   | STRB to select delay             | 5 ns        |
| t <sub>3</sub>   | Memory disable from select       | 8 ns        |
| t <sub>4</sub>   | H1 falling to STRB               | 7 ns        |
| t <sub>5</sub>   | STRB to select delay             | 5 ns        |
| t <sub>6</sub>   | Memory output enable delay       | 3 ns        |

# **13.5 Parallel Processing Interfaces**

The 'C40 communication ports and support for shared memory are the keys to parallel processing design flexibility. Almost any number of processors can be linked together in a wide variety of configurations. In this section, Figure 13–14 (in three parts) illustrates 'C40 parallel processing configurations that are used to fulfill many signal processing system needs.

# 13.5.1 Message Broadcasting From One TMS320C40 to Many TMS320C40's

Message broadcasting from one 'C40 to many 'C40s requires a simple interface. The block diagram of one is shown in Figure 13-13. To simplify the interface, no token transferring is done. In this design, one 'C40 is the dedicated transmitter, and three 'C40s are dedicated receivers. No reset circuitry is needed because of the transmitter is communication port 0 and the receivers are communication ports 3, 4, and 5. At reset, 'C40 communication ports 0, 1, and 2 are output ports, and communication ports 3, 4, and 5, are input ports. Due to this fixed communications configuration, no token transfer is needed, allowing the CREQ and CACK pins of all processors to be individually pulled up to 5 volts through 22-k $\Omega$  resistors. Also, the STRB pins of the communicating processors can be tied together along with the data lines CD7-0. However, if more than 5 receivers must be driven by a single transmitter at the 'C40s rated speed, the STRB and CD7-0 lines need to be buffered. Since the 'C40 communication ports protocol is asynchronous, if the speed of broadcast is not critical, buffers are not needed as long as the number of receivers is less than 30. The CRDY signal input by the transmitter communication port is generated by ORing the RDY outputs of all of the receiver communication ports. The transmitter should not receive a RDY signal until the receiver has received all data.

In addition, to ensure that the dedicated receiver 'C40s do not try to arbitrate for the communication port bus, you should halt the output ports of the receiver 'C40s by setting bit four of their communication port control registers to one.





#### 13.5.2 Shared Global Memory Interface With Fair Bus Arbitration

One of the most common multiprocessing system configurations is memory shared by each processor in a system. Shared memory is typically implemented by tying the processors' data and address lines together. However, the shared memory interface must guarantee that no more than one processor is driving the shared bus at any one time; it must also allow all processors sharing the bus to have a chance to access shared resources.

The 'C40 supports shared memory multiprocessing with its identical global and local port interfaces. Both interfaces have four status output signals, (L)STAT3–0, which identify what type of access is attempting to begin on

the bus. These signals identify whether the 'C40 port is idle, a DMA read is occurring, a STRB1 write is occuring, a LOCKed access to memory is pending, etc. (as listed in Table 7–2, page 7-5). These signals can be interpreted to issue single access or locked access bus requests to a shared bus arbiter.

To support shared address control and data lines, the 'C40 provides the (L)CE, (L)AE, and (L)DE input signals. When disabled (made high), these signals three-state the control signals, address lines, and data lines, respectively, of the port. These bus enable lines are asynchronous inputs to the 'C40, which can quickly turn off bus drivers when another processor is accessing a shared resource. However, these signals asynchronously turn off the 'C40's local and global buses, without memory accesses being suspended. To ensure that data written is seen externally and data read is valid, the external (L)RDY should be be used for wait-state generation in shared memory designs. An (L)RDY signal should not be sent to the 'C40 until the processor has regained access to the bus  $(\overline{CE}, \overline{AE}, \overline{DE} \text{ enabled})$  and has had enough time to complete its access. Hence with bus enable and status signals, the flexible bus interfaces of the 'C40 allow high-speed shared bus configurations to be implemented.

'C40

'C40

13





PIPELINED LINEAR ARRAY

For convolution and correlation and other pipelined operations in graphics and modem applications.



TREE STRUCTURES Supports broadcasting and data searches for speech and image recognition applications.



'C40





Figure 13–14. TMS320C40 Parallel DSP System Architectures (Continued)

4-D HYPERCUBE A more general-purpose structure.

Figure concluded on next page

13-41





Memory interfaces support shared global memory and private local memory.



Architectures utilizing shared memory and communication ports are possible.



13-42

In this section, a 'C40 shared memory example is shown. Four 'C40s share SRAM with their global buses tied together. A bus arbitrator implemented as a programmable logic device provides a fair scheme for processor access to the shared bus. The design shown here uses high speed parts but employs a fully asynchronous handshake protocol, which is still general, allowing varying speed 'C40s and processors other than 'C40s to be added to this bus configuration.

### 13.5.3 Shared Bus Interface Overview

Figure 13–15 and Figure 13–16 are *examples* of shared memory configurations. In these figures:

- Four 'C40s (each as shown in Figure 13–15) have their global buses tied together,
- **\Box** Each shares 128K  $\times$  32 of one-wait-state SRAM,
- □ 64K of the memory is controlled by R/W0; STRB0 and the other 64K are controlled by R/W1 and STRB1.

The memory devices are organized as  $64K \times 4$ , 35-ns SRAMs. Due to the 'C40's bus enable signals —  $\overline{AE}$ ,  $\overline{DE}$  and  $\overline{CE}$  — all four 'C40s' data, address, and control lines can be tied together for a shared memory configuration. However, since 128K words of shared memory are being implemented on the global bus (shown in Figure 13–15 and Figure 13–16), the common address lines are buffered to provide adequate drive to the 16 required memory devices. Also, the memories' chip-enable lines are pulled up to 5 volts through 22-k $\Omega$  resistors to ensure that the memory devices are disabled when no 'C40 is accessing them.

The required shared global bus interface logic consists of two levels of bus arbitration logic implemented as programmable logic devices (PLD). Each of the 'C40s has an identical first level of logic that interfaces to the shared second level arbiter. The first level of logic for each of the four 'C40s consists of one 7-ns 16R6 PLD and one 7-ns 16R4 PLD (center of Figure 13–15). Each first level 16R6 PLD receives status and control signals from the corresponding 'C40, determines what kind of global bus transfer the associated 'C40 requires, and issues a global bus request signal to the global bus controller (GBC, bottom of Figure 13–16), which, with the bus-grant time-out counter, implements the second level of arbitration logic. The GBC is implemented with a 7-ns 16R8 PLD, and the timeout counter is implemented with a 7-ns 16R4 PLD. In addition to the two GBC PLDs, a 16L8 PLD is used to issue write enable signals to the shared memory.

Since typical high-speed PLDs do not have many registered I/O pins or multiple clock sources, each first-level 16R6 PLD uses a 16R4 PLD to synchronize some of the input and output signals, and the 16R8 GBC PLD uses external flip-flops to synchronize input signals. If a 'C40 requires uninterrupted, multicycle global bus transfers, the first-level PLD keeps its bus-request signal active until the uninterruptable cycles are complete. The bus controller performs arbitration between the 'C40s requesting the shared global bus. If a 'C40 is given access to the bus, the bus controller sends its first-level PLDs a bus grant signal. The first-level PLD then sends a bus enable signal to the 'C40, which brings its bus control, address, and data signals out of high impedance. The first-level PLD also sends a BUSRDYQ signal to the 'C40 to end each read or write cycle.



Figure 13–15. TMS320C40 Shared Memory Interface

- **Notes:** 1) This figure represents one of four 'C40s and its interface (the 3 other 'C40s in the system have the same configuration).
  - 2) The shared memory (shared by the four 'C40s) and global bus controller are shown in Figure 13–16 on the next page.
  - 3) The fixed/rotating priority is a programmable option at the global bus controller (GBC).



Figure 13–16. TMS320C40 Shared Memory and Bus Controller Interface



13-45

For full-speed operation, the 'C40s run from separate, 50-MHz crystal-oscillator clock sources. For synchronization of shared bus control signals, the H3 output clock of each 'C40 serves as the 16R4 PLD synchronizer clock for first-level input and output signals. Also, the H1 output clock of each 'C40 serves as the state machine clock for each of the first-level, 16R6 PLDs. In addition, for high-speed bus controller synchronization, a 50-MHz crystal oscillator is used as the input clock for the 16R8 GBC PLD, the 16R4 timeout generator PLD, and the GBC input signal synchronizers. (Note: for fastest bus arbitration, the 'C40s sharing the bus can be synchronized by having common RESET and CLKIN inputs. If the 'C40s are synchronized in this way, the 50-MHz input to the second-level, global control PLDs can be the common CLKIN.) The AS174 D flip-flops are used as GBC input signal synchronizers.

Due to these arbitration synchronizer delays and the 35-ns SRAMs, access to the shared memory requires wait states. After an arbitration win, the first shared memory access requires three H1 cycles, and arbitration requires at least two H1 cycles from BUS REQUEST active to BUS ENABLE active. Figure 13–17 is a timing diagram of the arbitration contest. A bus master's first access after an arbitration win takes at least three H1 cycles; however, subsequent read or write accesses require only two H1 cycles. The three-cycles required for the first access provide enough time for the old bus master to stop driving the bus after an arbitration loss and enough time for new bus master control signals to go active and inactive to complete 35-ns memory accesses. Also, three-cycle memory accesses allow enough time for signal buffering (buffer delays are less than 15 ns with commercially available parts) between the processor bus and memory.

The subsection that follows covers the global bus configuration for use with this shared memory configuration.

#### 13.5.3.1 Global Memory Interface Control Register (GMICR) Configuration

For use in this shared memory configuration, the global bus should be configured as such at the GMICR:

SWW = 00 (RDYint = RDYext) STRB ACTIVE =  $01111_2$ PAGESIZE =  $01111_2$ STRB SWITCH = 0

In addition, IIOF1 should be configured as a general-purpose output pin. IIOF1 high signals that a high-priority DMA request is active.





## **13.6 Bus Arbitration**

#### **13.6.1** Arbitration Implementation

Arbitration on the bus is implemented with two levels of logic. The first level consists of four identically programmed 7-ns, 16R6 PLDs, and four identically programmed 16R4 PLDs, with one16R4 and 16R6 associated with each 'C40. The signals needed for arbitration from the 'C40 are STAT(3-0), STRB0, STRB1, LOCK, and IIOF1 (PAGE can be used in designs where page switching is necessary). IIOF1 should be configured as an output pin and should be used to indicate that a high-priority DMA transfer is active. Applications software should set IIOF1 low before priority DMA cycles are started. Figure 13-18 illustrates graphically the state machine for each of the first-level 16R6 PLDs. Each first-level PLD sends an active low BUS-REQ signal to the global bus controller, the second level of arbitration logic. The global bus controller sends a BUSGRANT signal to the requesting 'C40's first level logic when it has been granted control of the global bus. If an interlocked or high-priority DMA bus request has been granted, the firstlevel logic will keep its BUSREQ asserted low as long as interlocked or priority DMA cycles are required. The bus controller will see BUSREQ remain active and will give the current 'C40 bus master access to the bus until the interlocked or priority DMA operations are complete.

After a high-priority DMA bus cycle is complete, the 'C40 applications software should clear (set IIOF1 to logic level 1). Accordingly, interlocked access to memory should always end in a SIGI, STII, or STFI operation to bring  $\overrightarrow{LOCK}$  inactive. If priority accesses are completed by making IIOF1 or  $\overrightarrow{LOCK}$  inactive, the first-level PLD will always have an opportunity to bring its  $\overrightarrow{BUSREQ}$  inactive, preventing shared bus deadlock.

When the 'C40 associated with a first-level PLD is not the global bus master (i.e., cannot access the global bus), the first-level PLD sends a logic level one BUSREADY signal to that 'C40, extending any pending bus cycle until after the 'C40 becomes bus master and has completed an access. In addition, each first-level of logic sends both a BUSENABLE and CTLENABLE signal to the corresponding C40. The BUSENABLE signal is connected to the DE and AE pins and CTLENABLE is connected to the CE pin of the corresponding 'C40. These two signals cause the following to be in high-impedance when another 'C40 in the system is accessing the shared bus: bus chip enable and the address and data lines.



Figure 13–18. Shared Bus Interface PLD State Machine

- Notes: 1) In this state diagram, the output signals are all shown as active high for diagram clarity.
  2) A " ! " in front of a signal indicates that it is not active (deasserted).
  - 3) & = logical AND of signals; # = logical OR of signals.

For proper system reset operation, a RESET signal clears bus requests to the global bus controller and sends a logic level one BUSRDY and BUSENABLE signal to each 'C40 to extend upcoming bus cycles and three-state the bus until that 'C40 has been granted access to the bus.

Figure 13–19 shows equations for programming the 16R6 PLD used for the first-level logic. The PLD language shown in this figure is ABEL. ABEL's PLD language is used to describe the state machine illustrated in Figure 13–18.

#### Note: Active-Low Indicators

In listings (e.g., Figure 13–19), an underscore following a signal name (e.g., busreq\_) indicates the signal is active low. (in regular text, such signals are overbarred (e.g., BUSREQ).

The three PLD outputs — <code>busreq\_</code>, <code>busenable\_</code>, and <code>busrdy\_</code> — are used for three of the output state bits. The <code>park\_state</code> and <code>start\_state</code> bits (used to indicate the park state and start state) are the fourth and fifth output state bits. Also included in the ABEL description are test vectors for the state machine.

The PLDs described in Figure 13–19 and Figure 13–20 work together to interface to the GBC. Figure 13–20 (page 13-60) shows equations for programming the 16R4 PLD used for synchornizing the first-level input and output signals.

| Figure 1 | '3–19. PLD Ed | quations for Pl | rogramming the | e 16R4 PLD (First-Level Logic)                    |
|----------|---------------|-----------------|----------------|---------------------------------------------------|
| 0001     | module        | C40 loca        | l glob bus     | interf                                            |
| 0002     | title'        |                 |                | -                                                 |
| 0003     | DWG NAME      | Local co        | ntrol (of      | shared bus arbitration                            |
|          | 1             | (logic)         |                |                                                   |
| 0004     | 1             |                 |                |                                                   |
| 0005     | DWG #         |                 |                |                                                   |
| 0006     | 1             |                 |                |                                                   |
| 0007     | COMPANY       | TEXAS IN        | STRUMENTS      | INCROPORATED'                                     |
| 0008     | 1             |                 |                |                                                   |
| 0009     | c40u2         | device          | 'P1            | 6R6';                                             |
| 0010     | 1             |                 |                |                                                   |
| 0011     | "input        | s for glo       | bal interf     | face logic                                        |
| 0012     | h1            |                 | Pin 1;         | "clock input                                      |
| 0013     | priDMA        | <i>¥</i>        | Pin 2;         | "flag req output used to signal priority DMA      |
| 0014     | stat3         |                 | Pin 3;         | "stat3=0 STRB0 access, stat3=1<br>STRB1 access    |
| 0015     | stat2         |                 | Pin 4;         |                                                   |
| 0016     | stat1         |                 | Pin 5;         |                                                   |
| 0017     | stat0         |                 | Pin 6;         |                                                   |
| 0018     | strb0_        |                 | Pin 7;         |                                                   |
| 0019     | strb1_        |                 | Pin 8;         | "rdy signal from the external expansion connector |
| 0020     | l bg          |                 | Pin 9;         | "busgrant (from bus arbiter)                      |
| 0021     | lock          |                 | Pin 12;        |                                                   |
| 0022     | reset         | _               | Pin 19;        |                                                   |
| 0023     | 1             | -               |                |                                                   |
| 0024     | "outpu        | uts for gl      | lobal inter    | face logic                                        |
| 0025     | start_        | _state          | Pin 18;        | "low if the output state is the strt cycle state  |
| 0026     | busred        | 1               | Pin 17;        | <b>—</b> ~                                        |
| 0027     | busena        | able_           | Pin 16;        |                                                   |
| 0028     | busrdy        |                 | Pin 15;        |                                                   |
| 0029     | park_s        | state           | Pin 14;        | "low if the output state is the park state        |
| 0030     | 1             |                 |                |                                                   |
| 0031     | gwe_          |                 | Pin 13;        | "write enable signal for shared                   |
|          |               |                 |                | memory                                            |
| 0032     | 1             |                 |                |                                                   |
| 0033     | "defir        | ne machine      | e state bit    | S                                                 |
| 0034     | "[star        | ct,park,bu      | sreq_, buse    | enable_,busrdy_];                                 |
| 0035     | 1             |                 |                |                                                   |
| 0036     | idle          | =               | ^b11111;       | <b>``31</b>                                       |
| 0037     | req_cy        | /cle =          | ^b11011;       | "27                                               |
| 0038     | strt o        |                 | ^b01001;       | °09                                               |
| 0039     | do cyc        | -               | ^b11001;       | <b>`</b> 25                                       |
|          |               |                 | ,              |                                                   |

Figure 13–19. PLD Equations for Programming the 16R4 PLD (First-Level Logic)

```
Figure 13–19. PLD Equations for Programming the 16R4 PLD (First-Level Logic) (Continued)
|040 |
          fin cycle =
                        ^b11000;
                                  ~24
                                  ``17
0041
     park
                    =
                        ^b10001;
0042 |
0043 |
          "convert to positive logic to make the test vectors easier to
          understand
0044 |
0045 |
          lock
                    ==
                        !lock ;
0046 |
          bq
                    =
                        !bg ;
0047 |
          priDMA
                        !priDMA ;
                    =
0048
          idle_stat =
                        (stat2 & stat1 & stat0); "the bus is idle
                        when all are hi
0049
     1
0050 |
          "outstate
0051 I
          ost
                    ==
                        [start state, park state, busreq ,
                        busenable ,busrdy ];
0052 |
           •
0053 |
          c, H, L, X = .C., 1, 0, .X.;
0054 |@page
0055
     0056
    |state diagramost
0057
     0058 |state idle:
                 (!reset_ # idle_stat)
0059 |
          case
                                               :idle;
0060 |
                 ( reset & !idle stat )
                                                :req cycle;
0061 |
             endcase;
0062 |
0063 |
0064 |state req_cycle:
0065 I
          case
                 (!reset # idle stat)
                                                :idle;
0066 |
                 ( reset_ & bg_ & !idle_stat ) :req_cycle;
0067 |
                 ( reset & !bg & !idle stat ):strt cycl;
0068 |
             endcase;
0069 |
0070 |
0071 |
0072 |state strt_cycl:
0073 |
                                                :idle;
          case
                 (!reset )
0074
                 (reset)
                                                :do_cycle;
0075 |
             endcase;
0076 |
0077 |
0078 |state do cycle:
0079
          case
                 (!reset )
                                                :idle;
0080
                 ( reset )
                                                :fin cycle;
```

Hardware Applications

1<u>3</u>

```
Figure 13–19. PLD Equations for Programming the 16R4 PLD (First-Level Logic) (Continued)
0081
             endcase;
     - 1
0082
     1
0083
     1
0084 |
0085 |state fin cycle:
0086 |
          case
0087 |
                 (!reset )
                               :idle;
0088 |
                 ( reset )
                               :park;
0089 1
             endcase;
0090 |
0091 I
0092 |
0093 |state park:
0094 |
          case
                 (!reset # (bg & lock & priDMA )) :idle;
0095
     ( reset & idle stat & (!bg # !lock # !priDMA ))
                 :park;
0096
     1
                 ( reset & !idle stat & ((!stat3 & strb0 ) #
                 (stat3 & strb1_))
     1
                 (!bg # !lock # !priDMA ))
0097 1
                                                :do cycle;
0098
                 ( reset & ((!stat3 & !strb0 ) # (stat3 & !strb1 ))
     1
0099 |
                 & (!bg # !lock # !priDMA )) :fin cycle;
0100 |
0101 |
             endcase;
0102 |
0103 |
0104 |
0105 |equations
0106
          !gwe := reset & stat2 & !idle stat & ((!bus
     1
          req & !bg ) # !busenable );
0107 |@page
0108 |
0109 |"Test 1st level global arbitration logic
0110 |test vectors
0111
     ([h1,stat3,stat2,stat1,stat0,lock ,priDMA,strb0 ,bg,strb1 ,
          reset ]->[ost,qwe ])
0112 |[
          c, X, H, H, H, X, X, X, X, H, L] -> [ idle,H];
0113 |[
         c, X, H, L, H, H, L, X, L, H, H] -> [req cycle,H];
          c, X, H, H, H, X, X, X, X, H, L] \rightarrow [idle,H];
0114 | [
0115
     0116 |[
          c, X, X, X, L, X, X, X, L, H, H] -> [req_cycle,H];
0117 [[
          с, Х, Н
                    H, X, L, X, X, X, H, H] \rightarrow [strt_cycl,L];
0118 |[
          c, X, H, H, H, X, X,
                                 Х, Х, Н,
                                            L] -> [ idle,H];
0119 |"vector 7
0120 | [ c, X, X, X, L, X, X, X, L, H, H] -> [req_cycle,H];
```

#### **Bus Arbitration**

| Figure | 13–19 | ). Pl | D Ec | quatio | ons fo | or Pro | ogran | nming | the | 16R4 | PLD | ) (Firs | st-Lev | vel Logic) (Continued)    |
|--------|-------|-------|------|--------|--------|--------|-------|-------|-----|------|-----|---------|--------|---------------------------|
| 0121   | 1.    | c,    | х,   | н,     | x,     | L,     | x,    | x,    | х,  | н,   | н,  | Н]      | ->     | [strt_cycl,L];            |
| 0122   | 1.    | c,    | x,   | н,     | x,     | L,     | x,    | х,    | x,  | н,   | н,  | H]      | ->     | [do_cycle,L];             |
| 0123   | 1[    | c,    | х,   | н,     | Н,     | H,     | х,    | х,    | x,  | х,   | Н,  | L]      | ->     | [ idle,H];                |
| 0124   | 1     |       |      |        |        |        |       |       |     |      |     |         |        |                           |
| 0125   | [     | с,    | x,   | н,     | L,     | Н,     | н,    | L,    | x,  | L,   | н,  | H]      | ->     | <pre>[req_cycle,H];</pre> |
| 0126   | ] [   | c,    | х,   | н,     | x,     | L,     | x,    | х,    | x,  | н,   | н,  | H]      | ->     | [strt_cycl,L];            |
| 0127   | ] [   | c,    | x,   | н,     | x,     | L,     | х,    | x,    | x,  | н,   | н,  | H]      | ->     | <pre>[do_cycle,L];</pre>  |
| 0128   | ] [   | c,    | x,   | н,     | x,     | L,     | x,    | x,    | н,  | н,   | H,  | Н]      | ->     | [fin_cycle,L];            |
| 0129   | [     | c,    | x,   | н,     | н,     | н,     | x,    | x,    | x,  | х,   | н,  | L]      | ->     | [ idle,H];                |
| 0130   | "v    | ecto  | or 1 | 6      |        |        |       |       |     |      |     |         |        |                           |
| 0131   | 11    | c,    | x,   | x,     | x,     | L,     | x,    | x,    | x,  | L,   | н,  | Н]      | ->     | <pre>[req_cycle,H];</pre> |
| 0132   | 1[    | c,    | х,   | н,     | x,     | L,     | x,    | x,    | x,  | н,   | н,  | Н]      | ->     | [strt_cycl,L];            |
| 0133   | ] [   | c,    | x,   | н,     | x,     | L,     | x,    | x,    | x,  | н,   | н,  | Н]      | ->     | <pre>[do_cycle,L];</pre>  |
| 0134   | ] [   | c,    | x,   | н,     | x,     | L,     | x,    | x,    | н,  | н,   | н,  | Н]      | ->     | [fin cycle,L];            |
| 0135   | ] [   | c,    | L,   | н,     | x,     | L,     | x,    | x,    | н,  | н,   | н,  | Н]      | ->     | [park,L];                 |
| 0136   | ] [   | c,    | x,   | н,     | н,     | н,     | x,    | x,    | x,  | x,   | H,  | L]      | ->     | <pre>[ idle,H];</pre>     |
| 0137   | 1     |       |      |        |        |        |       |       |     |      |     |         |        |                           |
| 0138   | 1     |       |      |        |        |        |       |       |     |      |     |         |        |                           |
| 0139   | 1     |       |      |        |        |        |       |       |     |      |     |         |        |                           |
| 0140   | [     | c,    | x,   | x,     | x,     | L,     | x,    | x,    | x,  | L,   | н,  | H]      | ->     | <pre>[req_cycle,H];</pre> |
| 0141   | ] [   | c,    | x,   | н,     | x,     | L,     | x,    | x,    | x,  | н,   | н,  | Н]      | ->     | [strt_cycl,L];            |
| 0142   | ] [   | c,    | x,   | н,     | x,     | L,     | x,    | x,    | x,  | н,   | н,  | Н]      | ->     | [do cycle,L];             |
| 0143   | ] [   | c,    | x,   | н,     | x,     | L,     | x,    | x,    | н,  | н,   | н,  | H]      | ->     | [fin cycle,L];            |
| 0144   | ] [   | с,    | L,   | н,     | x,     | L,     | x,    | x,    | н,  | н,   | н,  | Н]      | ->     | [park,L];                 |
| 0145   | 1     |       |      |        |        |        |       |       |     | -    |     | -       |        |                           |
| 0146   | "v    | ecto  | or O | 9      |        |        |       |       |     |      |     |         |        |                           |
| 0147   | ] [   | c,    | x,   | н,     | x,     | x,     | н,    | L,    | x,  | L,   | н,  | Н]      | ->     | [ idle,L];                |
| 0148   | [     | с,    | x,   | н,     | н,     | н,     | x,    | x,    | x,  | х,   | н,  | н]      |        | [ idle,H];                |
| 0149   | ] [   | c,    | x,   | L,     | н,     | L,     | н,    | L,    | x,  | L,   | н,  | H]      | ->     | <pre>[req cycle,H];</pre> |
| 0150   | ] [   | c,    | ,    | x,     | L,     | н,     | L,    | x,    | x,  | н,   | L,  | H]      | ->     | <pre>[req cycle,H];</pre> |
| 0151   | ] [   | c,    | x,   | L,     | н,     | L,     | x,    | x,    | н,  | н,   | н,  | Н]      | ->     | [strt cycl,H];            |
| 0152   | ] [   | c,    | x,   | L,     | н,     | L,     | x,    | x,    | н,  | L,   | н,  | Н]      | ->     | <pre>[do cycle,H];</pre>  |
| 0153   | ] [   | с,    | x,   | L,     | н,     | L,     | н,    | L,    | н,  | L,   | н,  | н]      | ->     | [fin cycle,H];            |
| 0154   | ] [   | с,    | L,   | L,     | н,     | L,     | н,    | L,    |     | L,   | н,  | H]      | ->     | [park,H];                 |
| 0155   | 1 [   | с,    | х,   |        |        |        |       |       |     |      | •   |         |        | [idle,H];                 |
| 0156   | 1     |       | •    | •      | -      | •      |       | •     | ·   | •    | •   | -       |        | . ,                       |
| 0157   | ″v    | ecto  | or 1 | 8      |        |        |       |       |     |      |     |         |        |                           |
| 0158   | 1     |       |      |        | н,     | н,     | L,    | x,    | н,  | L,   | н,  | H]      | ->     | [idle,H];                 |
| 0159   | 1[    |       | н,   |        |        |        |       |       |     |      |     |         |        | [req cycle];              |
| 0160   | 1[    |       | н,   |        | x,     |        |       |       |     | L,   |     |         |        | <pre>[req_cycle,H];</pre> |
| 0161   | Ì     |       | н,   | •      |        |        |       |       |     | н,   |     |         |        | [strt cycl,H];            |
| 0162   | 1     |       |      |        |        |        |       |       |     |      |     |         |        | <pre>[do cycle,H];</pre>  |
|        |       |       |      |        |        |        |       |       |     |      |     |         |        | [fin cycle,H];            |
|        |       | •     | - •  |        |        |        |       |       |     |      |     |         |        |                           |

13

Hardware Applications

| Figure 13–19. PLD Equations for Programming the 16R4 PLD (First-Level Logic) (Continued) |      |      |                 |          |          |     |     |            |          |    |    |                                       |
|------------------------------------------------------------------------------------------|------|------|-----------------|----------|----------|-----|-----|------------|----------|----|----|---------------------------------------|
| 0164  [                                                                                  | c, 1 | н, І | , x,            | н,       | н,       | L,  | н,  | x,         | L,       | H] | -> | <pre>[park,H];</pre>                  |
| 0165  [                                                                                  | L, 1 | н, І | , x,            | н,       | н,       | L,  | н,  | x,         | H,       | H] | -> | <pre>[park,H];</pre>                  |
| 0166  [                                                                                  | c, 1 | н, і | , x,            | н,       | н,       | н,  | н,  | L,         | L,       | H] | -> | <pre>[fin_cycle,H];</pre>             |
| 0167  [                                                                                  | c, 1 | н, і | , x,            | H,       | н,       | н,  | н,  | x,         | L,       | H] | -> | <pre>[park,H];</pre>                  |
| 0168  [                                                                                  | ь, з | х, і | , X,            | н,       | н,       | н,  | н,  | x,         | н,       | H] | -> | <pre>[park,H];</pre>                  |
| 0169  [                                                                                  | c, 3 | L, I | Ь, L,           | н,       | L,       | x,  | н,  | н,         | н,       | H] | -> | <pre>[do_cycle,H];</pre>              |
| 0170  [                                                                                  | c, 3 | L, I | L, L,           | H,       | н,       | L,  | н,  | L,         | н,       | H] | -> | [fin_cycle,H];                        |
| 0171  [                                                                                  | c, 3 | L, I | Ь, L,           | н,       | н,       | L,  | н,  | x,         | L,       | H] | -> | [park,H];                             |
| 0172  [                                                                                  | c, 1 | н, н | н, н,           | н,       | н,       | н,  | н,  | x,         | н,       | H] | -> | <pre>[park,H];</pre>                  |
| 0173  [                                                                                  | c, 1 | н, н | н, н,           | н,       | н,       | н,  | н,  | x,         | н,       | H] | -> | <pre>[park,H];</pre>                  |
| 0174  [                                                                                  | c, 3 | x, > | к, х,           | x,       | н,       | L,  | н,  | L,         | н,       | H] | -> | [idle,H];                             |
| 0175  "ve                                                                                | ctor | 37   |                 |          |          |     |     |            |          |    |    |                                       |
| 0176  [                                                                                  | c, 3 | х, н | н, н,           | н,       | L,       | x,  | н,  | L,         | н,       | H] | -> | [idle,H];                             |
| 0177  [                                                                                  | c, 3 | х, і | Ь, L,           | L,       | L,       | x,  | н,  | L,         | н,       | H] | -> | [req_cycle,H];                        |
| 0178  [                                                                                  | c, 3 | х, і | L, L,           | L,       | L,       | x,  | н,  | L,         | н,       | Н] | -> | [req_cycle,H];                        |
| 0179  [                                                                                  | c, 3 | х, і | Ь, Ь,           | L,       | x,       | x,  | н,  | н,         | н,       | н] | -> | [strt cycl,H];                        |
| 0180  [                                                                                  | c, 3 | х, і | Ь, L,           | L,       | L,       | x,  | н,  | н,         | н,       | н] | -> | [do_cycle,H];                         |
| 0181  [                                                                                  | c, 3 | х, і | Ь, L,           | L,       | н,       | L,  | Н,  | L,         | н,       | H] | -> | [fin cycle,H];                        |
| 0182  [                                                                                  | с, 1 | н, І | L, L,           | L,       | н,       | L,  | Н,  | x,         | н,       | H] | -> | [park,H];                             |
| 0183  [                                                                                  | L, 1 | н, І | , L,            | L,       | н,       | L,  | н,  | х,         | н,       | H] | -> | [park,H];                             |
| 0184  [                                                                                  | c, 1 | н, І | ., L,           | L,       | L,       | н,  | н,  | L,         | L,       | нj | -> | [fin_cycle,H];                        |
| 0185  [                                                                                  | с,   | н, І | , L,            | L,       | L,       | н,  | н,  | x,         | L,       | H] | -> | [park,H];                             |
| 0186  [                                                                                  | L, 3 | Х, І | , L,            | L,       | L,       | н,  | н,  | х,         | н,       | н] | -> | [park,H];                             |
| 0187  [                                                                                  | c, 1 | •    | Ι, L,           | L,       | L,       | н,  | н,  | н,         | н,       | н] | -> | [do cycle,H];                         |
| 0188  [                                                                                  |      | •    | ., L,           | L,       | L,       | н,  | н,  | L,         | L,       | н] | -> | [fin cycle,H];                        |
| 0189  [                                                                                  | -    | •    | с, L,           | _,<br>L, | н,       | L,  | н,  | -,<br>х,   | _,<br>L, | H] | -> | <pre>[park,H];</pre>                  |
| 0190  [                                                                                  | •    | •    | -, _,<br>Ц, Ц,  | L,       | н,       | L,  | н,  | х,         | н,       | H] | -> | [par,H];                              |
| 0191  [                                                                                  | •    | •    | н, н,           | н,       | L,       | н,  | н,  | х,         | н,       | H] | -> | [park,H];                             |
| 0192  [                                                                                  | •    | •    | н, н,           | н,       | _,<br>L, | н,  | н,  | х,         | н,       | H] | -> | <pre>[park,H];</pre>                  |
| 0193  [                                                                                  | •    | •    | с, х,           | х,       | н,       | L,  | L,  | н,         | н,       | H] | -> | [fin_cycle,H];                        |
| 0194  [                                                                                  |      | •    | с, х,           | х,       | Н,       | L,  | н,  | х,         | н,       | H] | -> | <pre>[park,H];</pre>                  |
| 0195  [                                                                                  |      | •    | ζ, Χ,           | х,       | Н,       | L,  | н,  | L,         | н,       | H] | -> | [idle,H];                             |
|                                                                                          | ctor | •    | -,,             | ,        | ,        | _,  | ,   | -,         | ,        | ,  |    | [_0_0/]/                              |
| 0197 [[                                                                                  |      | х, н | н, н,           | н,       | L.       | x,  | н,  | L.         | н,       | Н] | -> | [idle,H];                             |
| 0198  [                                                                                  | •    | •    | ц, х,           |          |          |     |     |            |          |    |    | <pre>[req_cycle,H];</pre>             |
|                                                                                          |      |      |                 |          |          |     |     |            |          |    |    | [strt_cycl,H];                        |
| 0200 [[                                                                                  |      |      |                 | н,       |          |     |     |            |          |    |    | <pre>[do_cycle,H];</pre>              |
| 0201  [                                                                                  | c, 1 |      |                 | н,       |          |     |     |            |          |    | -> |                                       |
|                                                                                          | c, 1 |      |                 | н,       |          |     |     |            |          |    | -> |                                       |
| 0202  [                                                                                  | L, 1 |      |                 | н,<br>н, |          |     |     | х,         |          |    | -> | [park,H];                             |
| 0203  [                                                                                  | c, 1 |      |                 | н,       |          |     | н,  |            | ц,       |    | -> |                                       |
| 0204 [                                                                                   |      |      |                 | н,       |          |     | н,  | х,         |          | H] | -> | <pre>[IIII_cycle,II]; [park,H];</pre> |
| 0205 [[                                                                                  | L, 1 |      |                 |          |          |     |     |            |          |    |    | [park,H];                             |
|                                                                                          | ц, 1 | , 1  | -, <sub>^</sub> | 11,      | 11,      | 11, | 11, | <u>~</u> / | 11,      |    | -  | [Park, II];                           |

# Bus Arbitration

| Figure | 13–19 | ). Pl        | D Ec | quatic | ons fo | or Pro | ogran | nming | the | 16R4 | PLD  | ) (Firs | st-Lev | el Logic) (Concluded)     |
|--------|-------|--------------|------|--------|--------|--------|-------|-------|-----|------|------|---------|--------|---------------------------|
| 0207   | 1[    | с,           | H,   | н,     | L,     | н,     | L,    | x,    | н,  | Н,   | н,   | Н]      | ->     | [do_cycle,L];             |
| 0208   | ] [   | с,           | н,   | н,     | L,     | H,     | н,    | L,    | н,  | L,   | н,   | H]      | ->     | <pre>[fin_cycle,L];</pre> |
| 0209   | [     | с,           | H,   | н,     | L,     | Н,     | н,    | L,    | н,  | x,   | н,   | H]      | ->     | <pre>[park,L];</pre>      |
| 0210   | ] [   | с,           | x,   | L,     | L,     | L,     | L,    | н,    | н,  | Н,   | н,   | H]      | ->     | <pre>[do_cycle,H];</pre>  |
| 0211   | 1     | с,           | H,   | L,     | L,     | L,     | L,    | н,    | н,  | L,   | L,   | H]      | ->     | <pre>[fin_cycle,H];</pre> |
| 0212   | [     | с,           | н,   | L,     | L,     | L,     | н,    | L,    | н,  | Х,   | L,   | H]      | ->     | <pre>[park,H];</pre>      |
| 0213   | 1[    | L,           | н,   | L,     | L,     | L,     | н,    | L,    | н,  | x,   | н,   | H]      | ->     | <pre>[park,H];</pre>      |
| 0214   | T     | c,           | x,   | L,     | x,     | x,     | н,    | L,    | L,  | Н,   | н,   | Н]      | ->     | <pre>[fin_cycle,H];</pre> |
| 0215   | [     | c,           | L,   | L,     | x,     | х,     | н,    | L,    | н,  | х,   | н,   | Н]      | ->     | <pre>[park,H];</pre>      |
| 0216   | ΙE    | c,           | н,   | н,     | н,     | н,     | x,    | x,    | н,  | Н,   | н,   | H]      | ->     | <pre>[park,H];</pre>      |
| 0217   | [     | с,           | н,   | н,     | н,     | н,     | н,    | н,    | н,  | н,   | н,   | H]      | ->     | <pre>[park,H];</pre>      |
| 0218   | 1[    | c,           | x,   | x,     | x,     | х,     | н,    | L,    | н,  | L,   | Н,   | H]      | ->     | [idle,H];                 |
| 0219   | l@pa  | age          |      |        |        |        |       |       |     |      |      |         |        |                           |
| 0220   | [     | c,           | x,   | H,     | x,     | L,     | X,    | Х,    | х,  | L,   | Н,   | H]      | ->     | <pre>[req_cycle,H];</pre> |
| 0221   | 1[    | c,           | X,   | H,     | X,     | L,     | X,    | X,    | х,  | H,   | н,   | H]      | ->     | [strt_cycl,L];            |
| 0222   | [     | c,           | x,   | Н,     | x,     | L,     | x,    | x,    | х,  | Н,   | Н,   | H]      | ->     | [do_cycle,L];             |
| 0223   | 1[    | c,           | x,   | Н,     | х,     | L,     | x,    | x,    | н,  | Н,   | н,   | H]      | ->     | <pre>[fin_cycle,L];</pre> |
| 0224   | [     | с,           | L,   | н,     | x,     | L,     | x,    | х,    | н,  | Н,   | н,   | H]      | ->     | <pre>[park,L];</pre>      |
| 0225   | 1[    | с,           | х,   | H,     | x,     | x,     | H,    | L,    | x,  | L,   | н,   | H]      | ->     | [ idle,L];                |
| 0226   | [     | c,           | •    |        |        |        |       |       |     |      |      |         |        | <pre>[req_cycle,H];</pre> |
| 0227   |       | [h1,<br>set] |      |        |        |        |       | l,st  | at0 | ,100 | ck_, | pri     | DMA,   | strb0_,bg,strb1,          |
| 0228   | I     |              |      |        |        |        |       |       |     |      |      |         |        |                           |
| 0229   | I     |              |      |        |        |        |       |       |     |      |      |         |        |                           |
| 0230   | en    | d            | c4   | 0_10   | cal    | _gl    | ob_k  | ous_  | int | erf  |      |         |        |                           |
| 0231   | I     |              |      |        |        |        |       |       |     |      |      |         |        |                           |
| 0232   | 1     |              |      |        |        |        |       |       |     |      |      |         |        |                           |
| 0233   | 1     |              |      |        |        |        |       |       |     |      |      |         |        |                           |
| 0234   | 1     |              |      |        |        |        |       |       |     |      |      |         |        |                           |
| 0235   | ļ     |              |      |        |        |        |       |       |     |      |      |         |        |                           |

The six PLD states are idle, request\_cycle, start\_cycle, do\_cycle, finish\_cycle, and park.

- 1) After reset, the first-level PLD's state machine starts in the idle state and transcends to the request\_cycle state when a global bus transfer is required.
- 2) The transition to request\_cycle occurs when any of the 'C40 status lines (STAT2–0) are low (when the status lines are all high, the bus is idle). In this state, the BUSREQ signal becomes active and is sent to the GBC PLD.
- 3) When the PLD receives a BUSGRANT signal, the state machine transitions to the start cycle state. For the start\_cycle, do\_cycle, finish\_cycle and park states, BUSREQUEST and BUSENABLE are active.
- 4) From the start\_cycle state, the state machine transitions to the do\_cycle state during the next H1 cycle.
- 5) From the do\_cycle state, the state machine transitions to the finish\_cycle state in the next H1 cycle. In this state, the BUSRDY signal is active. BUSRDY indicates to the 'C40 that the memory access has been completed and that another access can be started.
- 6) From the finish\_cycle state, the state machine transitions to the park state during the next H1 cycle. BUSRDY goes inactive in anticipation of another bus cycle starting.

Bus parking is implemented for this bus arbitration protocol to allow the current bus master to retain control of the bus and continue making accesses to global memory as long as consecutive interlocked or priority DMA cycles are required or if no other processor is requesting use of the bus. Bus parking reduces memory access latency when only one 'C40 desires access to the global bus during any duration.

Notice that when the state machine leaves the park state, allowing the current bus master to perform another shared memory access, the state machine can transition to either the finish\_cycle or do\_cycle states, depending on the level of STRB0 or STRB1. The STRB signal remaining low between accesses indicates back-to-back read cycles, which require only two H1 cycles to complete for 35-ns memories. Hence, the state machine transitions from the park state directly to finish\_cycle. If the STRB signal goes high one H1 cycle and then back low between accesses, the state machine transitions from the park state to do\_cycle, allowing the one cycle for the STRB high and two for the subsequent access.

The global bus controller (second-level logic) is implemented as a 16R8 PLD. This PLD takes as inputs the outputs of each of the four first-level PLDs. Hence, the GBC has four BUSREQUEST signals as inputs — one

from each of the four, first-level logic PLDs associated with each of the 'C40s. The GBC asserts four outputs, the BUSGRANT signals associated with each 'C40's first-level arbitration logic.

Figure 13–21 illustrates graphically the state machine for the global bus controller. The GBC asserts low the BUSGRANT signal associated with the 'C40 that wins an arbitration contest. This BUSGRANT signal remains active until another processor desires access to the shared bus and a time-out signal has been received. The new contestant is not granted access to the shared bus until after the current bus master deasserts (brings high) its BUSREQ signal, indicating it has finished its priority accesses or single nonpriority memory access. The system RESET signal should also be an input to the GBC PLD. The system RESET signal should clear (deassert high) all BUSGRANT signals to any of the 'C40s and return the GBC state machine to an idle state.

The time-out signal is also a necessary input for the GBC because of the high speed of bus arbitration. Before taking a BUSGRANT signal away, the GBC must guarantee that a bus arbitration winner has had a chance to see the BUSGRANT and start using the bus. The timeout signal is generated by a counter implemented with a 16R4 PLD. The counter starts counting when a processor first receives a BUSGRANT signal. It counts four cycles and then issues a time-out signal to the GBC indicating that the GBC can take away the current master's BUSGRANT if necessary. Hence, the time-out counter provides at least four cycles for a 'C40's first level of logic to see a BUSGRANT and start using the bus before the GBC can take the BUSGRANT away. Figure 13–23 contains the ABEL PLD equations for the time-out counter.

The type of arbitration implemented in this GBC example is a **rotating** priority scheme. This rotating priority scheme provides fair arbitration among the four 'C40s sharing the global bus. In a rotating priority scheme, the last bus master becomes the lowest (last serviced) priority processor. The processors sequentially rotate throughout the priority list with the least recently serviced processor having the highest priority in subsequent arbitration contests. The priority rotates every time the bus request of the current bus master goes inactive and another processor desires access to shared memory. At system reset, the priorities are 1, 2, 3, or 4, with 1 being the highest or first serviced priority.

Figure 13–22 shows PLD equations for programming the 16R8 PLD used to implement the rotating priority global bus controller. ABEL's PLD language is used to describe the state machine shown in Figure 13–21.

#### Note: Active-Low Indicators

In listings (e.g., Figure 13–22), an underscore following a signal name (e.g., busreq\_) indicates that the signal is active low. (in regular text, such signals are overbarred (e.g., BUSREQ).

The PLD's four outputs are the four busgrant lines, with each line giving a different 'C40 access to the shared bus. These four bits are also used as half of the output state bits. The other four state bits are used to indicate the ready state corresponding to each busgrant state. At reset, the GBC state machine goes to the idle state. All busgrant signals are inactive. In the idle state, br signals can be received from any of the four first-level PLDs. After arbitration, the state machine makes a transition to one of the grx states (where x = 1, 2, 3, or 4). The corresponding busgrantx output signal goes active. The GBC stays in that state until a busrequest and a time-out signal is received from another processors' first-level PLD. Once another busrequest is received, the state machine transcends to the corresponding bryx state. In this state, the busgrantx signal goes inactive. However, the GBC state machine stays in this state until the corresponding bus request (brx ) input goes inactive high, indicating that the current bus master has relinguished control of the shared bus. When brx goes inactive, the state machine changes to the highest priority processor's gry state (where y = 1, 2, 3, or 4) that had its br signal active.

```
Figure 13–20. PLD Equations for Programming the 16R4 PLD
0001 |module
                c40 global bus interface
0002 |title'
0003 |
0004 |DWG
0005 |DWG #
0006 |
0007 |COMPANY
                TEXAS INSTRUMENTS INCROPORATED'
0008 |
0009 |c40ul device 'P16R4';
0010 I
0011 |
          "inputs
0012 |
          h3
                           Pin 1;
0013 |
                           Pin 7;
          bg
0014 |
          busrdy
                           Pin 8;
                                     "busrdy from global interface PAL
0015
    busenable
                           Pin 9;
                                     "busenable from global interface
                                     PAL
0016 |
0017 |
          "outputs
0018 |
                                     "enable signal for control lines
         ctrl enable
                           Pin 18;
0019 |
                           Pin 17;
                                     "rdy signal for shared SRAM
         rdy
0020 |
          sync ae
                           Pin 15;
                                     "synchronized busenable signal
0021 |
          bg sync
                           Pin 14;
0022 |
0023 |
0024 | "name substitutions
0025 |
             CE
                              ctrl_enable_;
                           =
0026 |
             bry
                           =
                              rdy_;
0027 |
0028 |"substitutions for test vectors
0029 |
             C, H, L, X,
                         =
                              .C.1,0,.X.;
0030 |
0031 |equations
0032 |
             sync ae :
                          =
                              busenable ;
0033 |
             !ctrl_enable_= !sync_ae_ & !busenable_;
0034 |
             rdy_:
                              busrdy ;
                           =
0035 |
             bg sync :
                          =
                              bg ;
0036 |
0037 |@page
0038 |
0039 |
0040 |
0041
     0042 |"Test 1st level global arbitration logic
0043 |test_vectors
```

Hardware Applications

| Figure | 13–20. | PL  | D Eq | uatio | ns fo      | r Prog | gram | nming | the  | 16R4 PLD (Concluded)  |
|--------|--------|-----|------|-------|------------|--------|------|-------|------|-----------------------|
| 0044   | ([h    | 3,b | user | nabl  | .e_,       | busi   | dy_  | _, bg | _]-: | >[CE_,bry_,bg_sync_]) |
| 0045   | 1[     | с,  | н,   | H,    | H]         | ->     | [    | н,    | н,   | H];                   |
| 0046   | ] [    | с,  | L,   | H,    | H]         | ->     | [    | L,    | н,   | H];                   |
| 0047   | ] [    | c,  | L,   | H,    | L]         | ->     | [    | L,    | н,   | L];                   |
| 0048   | ] [    | L,  | L,   | L,    | H]         | ->     | [    | L,    | н,   | L];                   |
| 0049   | 1[     | c,  | L,   | L,    | H]         | ->     | ],   | L,    | L,   | н];                   |
| 0050   | 1[     | c,  | н,   | H,    | H]         | ->     | [    | н,    | н,   | H];                   |
| 0051   | ] [    | c,  | н,   | H,    | H]         | ->     | [    | н,    | н,   | H];                   |
| 0052   | 1[     | c,  | н,   | н,    | Н]         | ->     | [    | Н,    | н,   | H];                   |
| 0053   | [      | c,  | н,   | H,    | H]         | ->     | ]    | н,    | н,   | H];                   |
| 0054   | [      | L,  | L,   | Н,    | L]         | ->     | [    | н,    | н,   | H];                   |
| 0055   | ] [    | c,  | L,   | н,    | H•]        | ->     | [    | L,    | н,   | H];                   |
| 0056   | 1[     | c,  | L,   | H,    | Н]         | ->     | [    | L,    | н,   | H];                   |
| 0057   | ] [    | c,  | L,   | L,    | H]         | ->     | [    | L,    | L,   | H];                   |
| 0058   | ] [    | c,  | L,   | н,    | r]         | ->     | [    | L,    | н,   | L];                   |
| 0059   | 1[     | c,  | L,   | L,    | L]         | ->     | [    | L,    | L,   | L];                   |
| 0060   | 1[     | L,  | н,   | н,    | H]         | ->     | [    | н,    | L,   | L];                   |
| 0061   | ] [    | ç,  | н,   | н,    | H]         | ->     | [    | н,    | н,   | H];                   |
| 0062   | [      | c,  | н,   | н,    | Н]         | ->     | [    | H,    | н,   | H];                   |
| 0063   | ] [    | c,  | н,   | Н,    | L]         | ->     | [    | н,    | н,   | L];                   |
| 0064   | @pa    | ge  |      |       |            |        |      |       |      |                       |
| 0065   | ] [    | c,  | н,   | н,    | L]         | ->     | [    | н,    | н,   | L];                   |
| 0066   | ] [    | c,  | н,   | н,    | L]         | ->     | [    | н,    | н,   | L];                   |
| 0067   | [      | c,  | н,   | н,    | L]         | ->     | [    | н,    | н,   | L];                   |
| 0068   | ] [    | c,  | н,   | н,    | <b>L</b> ] | ->     | [    | Н,    | н,   | L];                   |
| 0069   | ] [    | c,  | L,   | н,    | H]         | ->     | [    | L,    | н,   | H];                   |
| 0070   | ] [    | c,  | L,   | н,    | Н]         | ->     | Į    | L,    | н,   | H];                   |
| 0071   | ] [    | L,  | L,   | L,    | н]         | ->     | [    | L,    | Ħ,   | H];                   |
| 0072   | ] [    | c,  | L,   | L,    | Н]         | ->     | [    | L,    | L,   | H];                   |
| 0073   | [      | c,  | н,   | н,    | Н]         | ->     | [    | н,    | н,   | н];                   |
| 0074   | ] [    | c,  | н,   | н,    | H]         | ->     | [    | н,    | н,   | H];                   |
| 0075   | [      | c,  | н,   | н,    | H]         | ->     | [    | н,    | н,   | H];                   |
| 0076   | [      | c,  | н,   | Н,    | Н]         | ->     | [    | Н,    | н,   | H];                   |
| 0077   | ] [    | L,  | L,   | н,    | Н]         | ->     | [    | н,    | н,   | H];                   |
| 0078   | [      | c,  | L,   | н,    | Н]         | ->     | [    | L,    | н,   | н];                   |
| 0079   | [      | c,  | L,   | H,    | H]         | ->     | [    | L,    | н,   | H];                   |
| 0080   | ] [    | c,  | L,   |       | H]         | ->     | [    | L,    | L,   | H];                   |
| 0081   | I I    | c,  | L,   | H,    | H]         | ->     | [    | L,    | Н,   | H];                   |
| 0082   | ] [    | c,  | L,   | L,    | H]         | ->     | [    | L,    | Ŀ,   | H];                   |
| 0083   | I      |     |      |       |            |        |      |       |      |                       |
| 0084   | end    |     | c40  | _gl   | oba        | l_bu   | s_i  | nte   | rfac | ce                    |





Hardware Applications

| Figure 13–22. | PLD Equations for Programming the 16R8 PLD |
|---------------|--------------------------------------------|
|---------------|--------------------------------------------|

| 0002                                                                         | module_global_bus_cntrl<br> title'                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |
|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| 0004<br>0005<br>0006<br>0007                                                 | DWG NAME Shared bus interface<br>DWG #                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |  |  |
|                                                                              | COMPANY TEXAS INSTRUMENTS INCORPORATED'                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |
| 0008<br>0009<br>0010                                                         | xub5 device 'P16R8';                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |
| 0011<br>0012<br>0013<br>0014<br>0015<br>0016<br>0017                         | h50 Pin 1; "50 MHz clock<br>br1_ Pin 2; "bus request 1<br>br2_ Pin 3; "bus request 2<br>br3_ Pin 4; "bus request 3<br>br4_ Pin 5; "bus request 4<br>reset_ Pin 6; "reset<br>fix_rot Pin 7; "fix/rot_ not used here but can be added                                                           |  |  |  |  |  |  |  |  |  |  |  |
| 0018<br>0019<br>0020<br>0021                                                 | oe Pin 11;<br>  timeout_ Pin 8<br>  vss Pin 10;                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |
| 0022<br>0023<br>0024<br>0025<br>0026<br>0027<br>0028<br>0029<br>0030<br>0031 | bg1Pin 19;       "grant 1         bg2Pin 18;       "grant 2         bg3Pin 17;       "grant 3         bg4Pin 16;       "grant 4         s3Pin 15;       "state 3         s2Pin 14;       "state 2         s1Pin 13;       "state 1         s0Pin 12;       "state 0         vcc       Pin 20; |  |  |  |  |  |  |  |  |  |  |  |
| 0032<br>0033<br>0034<br>0035<br>0036                                         | <pre>c,H,L,X = .C.,1,0,.X.; ' 'define state machine bits bus_state = [s3,s2,s1,s0,bg4_,bg3_,bg2_,bg1_]</pre>                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |
| 0037<br>0038<br>0039<br>0040<br>0041<br>0042<br>0043                         | <pre>"states<br/>bry1 = ^b01111111; "ready 1<br/>bry2 = ^b10111111; "ready 2<br/>bry3 = ^b11011111; "ready 3<br/>bry4 = ^b11101111; "ready 4<br/>idle = ^b11111111; "idle state</pre>                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |
| 0044<br>0045                                                                 | gr1 = ^b1111110; "grant 1<br>gr2 = ^b1111101; "grant 2<br>gr3 = ^b1111011; "grant 3<br>gr4 = ^b11110111; "grant 4                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |
| 0049<br>0050<br>0051<br>0052<br>0053<br>0054                                 | <pre>"convert inputs to positive logic<br/>br1 = !br1_;<br/>br2 = !br2_;<br/>br3 = !br3_;<br/>br4 = !br4_;<br/>reset = !reset_;<br/>@page</pre>                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |

Figure 13–22. PLD Equations for Programming the 16R8 PLD (Continued)

| 0056 |                                                                                                         |
|------|---------------------------------------------------------------------------------------------------------|
|      | state_diagrambus_state                                                                                  |
| 0058 | state idle:                                                                                             |
| 0059 |                                                                                                         |
| 0060 | else if ( !reset & !br1 & !br2 & br3 & br4)then gr4                                                     |
| 0061 | else if ( !reset & !br1 & !br2 & br3 ) then gr3                                                         |
| 0062 | else if ( !reset & !brl & br2 ) then gr2                                                                |
| 0063 | else if ( !reset & brl ) then grl                                                                       |
| 0064 | else idle;                                                                                              |
| 0065 |                                                                                                         |
| 0066 | state bry4:                                                                                             |
| 0067 | if (reset) then idle                                                                                    |
| 0068 | else if (!reset & br4 ) then bry4                                                                       |
| 0069 |                                                                                                         |
| 0070 |                                                                                                         |
| 0071 | else if ( !reset & !br1 & br2 & !br4) then gr2                                                          |
| 0072 | else if ( !reset & br1 & !br4) then gr1;                                                                |
| 0073 |                                                                                                         |
| 0074 |                                                                                                         |
| 0075 |                                                                                                         |
| 0076 | else if (!reset & br3 ) then bry3                                                                       |
| 0077 | else if (!reset & !br4 & !br1 & br2 & !br3) then idle                                                   |
| 0078 |                                                                                                         |
| 0079 |                                                                                                         |
| 0080 | else if (!reset & br4 & !br3) then gr4;                                                                 |
| 0081 |                                                                                                         |
| 0082 | state bry2:                                                                                             |
| 0083 |                                                                                                         |
| 0084 | else if (!reset & br2 ) then bry2                                                                       |
| 0085 | else if ( !reset & !br3 & !br4 & !br1 & !br2) then idle                                                 |
|      | else if ( !reset & !br3 & !br4 & br1 & !br2) then gr1                                                   |
| 0087 | else if ( !reset & !br3 & br4 & br2) then gr4                                                           |
| 0088 | else if ( !reset & br3 & lbr2) then gr3;                                                                |
| 0089 | l eise II ( :leset a bis a :biz) then gis;                                                              |
| 0090 | state bry1:                                                                                             |
| 0090 | if (reset) then idle                                                                                    |
| 0091 | if (!reset & brl ) then bryl                                                                            |
| 0092 | else if ( !reset & !br2 & !br3 & !br4 & !br1) then idle                                                 |
|      |                                                                                                         |
| 0094 | else if ( !reset & !br2 & !br3 & br4 & !br1) then gr4<br>else if ( !reset & !br2 & br3 & !br1) then gr3 |
|      |                                                                                                         |
| 0096 | else if ( !reset & br2 & !br1) then gr2;                                                                |
| 0097 |                                                                                                         |
| 0098 |                                                                                                         |
| 0099 |                                                                                                         |
| 0100 | else if ( reset ) then idle                                                                             |
| 0101 |                                                                                                         |
| 0102 |                                                                                                         |
| 0103 | state gr3:                                                                                              |
| 0104 | if ( !reset & (timeout # !br4 & !br1 & !br2)) then gr3                                                  |
| 0105 | else if (reset ) then idle                                                                              |
| 0106 |                                                                                                         |
| 0107 |                                                                                                         |
| 0108 | state gr2:                                                                                              |
|      |                                                                                                         |

```
Figure 13–22. PLD Equations for Programming the 16R8 PLD (Continued)
0109
                  if (!reset &) (timeout # !br3 & !br4 & !br1 )) then gr2
0110
                  else if ( reset ) then idle
0111
0112
0113
               state
                          gr1:
0114
                  if ( !reset & (timeout # !br2 & !br3 & !br4 ) then gr1
0115
                  else if ( reset ) then idle
0116
0117
      |@page
0115
      |test vectors
0116
      1
0117
      |"rotating priority vectors
0118 |([h50,br1,br2,br3,br4,timeout_,reset_] -> [bus_state])
0119
     |"check for go to IDLE
0120
      1
           C, X, X, X, X, X, L
                                     ]
                                         -> [idle];
0121
                  L, L, H,
      1[
              L,
                             х,
                                 Н
           c,
                                     ]
                                         ->
                                            [qr4];
0122
      ] [
           c, X,
                  X, X, X,
                             Х,
                                 L
                                     ]
                                         -> [idle];
0123
      1[
              L,
                  L,
                      Н,
                          X,
                             X,
                                 Н
                                     ]
           c,
                                         ->
                                            [gr3];
0124
      1[
           c, X,
                  X,
                      Х,
                          х,
                             х.
                                 L
                                     ]
                                         -> [idle];
0125
      1[
           c, L,
                  н, х,
                         X,
                             X,
                                     1
                                 Н
                                         -> [gr2];
0126
      11
              X,
                  X,
                     X,
                                 L
           c,
                         х,
                             Χ,
                                     1
                                         -> [idle];
0127
           с, Н,
                  х, х,
      11
                         Х,
                             Х,
                                 Н
                                     1
                                         -> [gr1];
0128
      1[
           c, X,
                  х, х,
                         x,
                             X,
                                     ]
                                 \mathbf{L}
                                         -> [idle];
0129
      11
           C. L.
                  L, L,
                         H,
                             X,
                                 Η
                                     1
                                         -> [gr4];
0130
      11
           с, Н,
                  L, L,
                          H,
                                 Н
                                     ]
                             L,
                                         -> [bry4];
0131
      1 [
           c, X,
                  х, х,
                          Х,
                             Х,
                                 L
                                     1
                                         -> [idle];
0132
     11
           C, L,
                  L,
                     H,
                          Х,
                             X,
                                 Н
                                     1
                                         -> [gr3];
0133
      11
           c, L,
                  H,
                     H,
                          L,
                                 н
                                     1
                             L,
                                         -> [bry3];
0134
           c, X,
      1[
                  Х,
                      X,
                         X,
                             X,
                                 \mathbf{L}_{\ell}
                                     1
                                         -> [idle];
0135
     11
           c, L,
                  н, х,
                          Х,
                             X,
                                 Н
                                     1
                                         -> [gr2];
0136
           c, L,
      1[
                  H,
                     H,
                          Н,
                             L,
                                 н
                                     1
                                         -> [bry2];
0137
      11
           c, X,
                  X,
                     X,
                          Х,
                             x,
                                     ]
                                 L
                                         -> [idle];
0138
      11
                  х, х,
           с, Н,
                          Х,
                             X,
                                 Н
                                     1
                                         -> [gr1];
0139
      1[
           с, Н,
                  Н, Н, Н,
                             L,
                                 н
                                     ]
                                         -> [bry1];
0140
      1[
           c, X, X, X, X, X,
                                 L
                                     ]
                                         -> [idle];
0141
      0142
      1
0143
      ] [
           C, X, X, X, L, X,
                                 Н
                                     ]
                                         -> [idle];
0144
      1[
           c,
              L,
                  L,
                      H,
                          х,
                             X,
                                 Н
                                     ]
                                         -> [qr3];
0145
      1
           с, Х,
                  X, L,
                          х,
                             Χ,
                                 Н
                                     ]
                                         -> [idle];
0146
      11
              L,
                  Н,
                      X,
                                 Н
           c,
                          Х,
                             X,
                                     1
                                         -> [qr2];
0147
      11
           c, X,
                  L,
                      X,
                          Х,
                             Х,
                                     1
                                 Н
                                         -> [idle];
0148
      1[
                  X, X,
           с, Н,
                          x,
                             X,
                                 н
                                     ]
                                         -> [gr1];
0149
      1
           c,
              L,
                  X,
                     х.
                         Х,
                             X,
                                 н
                                     1
                                         -> [idle];
0150
      1[
           c, L,
                     L,
                                     1
                  L,
                         н,
                             Х,
                                 н
                                         -> [gr4];
0151
     ] [
           C, H, L, L, H, L,
                                     1
                                         -> [bry4];
                                 Н
```

**Bus Arbitration** 

13-66

| Figure 13–22       | . PLD | Equatic       | ons fo | or Pro | ogran | nming | the | 16R8 | PLD (Continued) |
|--------------------|-------|---------------|--------|--------|-------|-------|-----|------|-----------------|
| 0152  [            | c, I  | L, L,         | L,     | L,     | x,    | Н     | ]   | ->   | [idle];         |
| 0153  [            | c, I  | L, L,         | н,     | x,     | Х     | Н     | ]   | ->   | [gr3];          |
| 0154  [            | c, I  | Ь, Н,         | H,     | L,     | L,    | Н     | ]   | ->   | [bry3];         |
| 0155  [            | c, I  | Ь, L,         | L,     | L,     | x,    | Н     | ]   | ->   | [idle];         |
| 0156  [            | с, І  | , н,          | x,     | x,     | x,    | Н     | ]   | ->   | [gr2];          |
| 0157  [            | с, І  | Ь, Н,         | Н,     | н,     | L,    | Н     | ]   | ->   | [bry2];         |
| 0158  [            | с, І  | Ь, L,         | L,     | L,     | x,    | Н     | ]   | ->   | [idle];         |
| 0159  [            | с, Н  | H, X,         | x,     | x,     | x,    | Н     | ]   | ->   | [gr1];          |
| 0160  [            | с, Р  | н, н,         | н,     | н,     | L,    | н     | ]   | ->   | [bry1];         |
| 0161  [c,          | ,L, I | L, L,         | L,     | x,     | н,    | н     | ]   | ->   | [idle];         |
| 0162  "ve          | ector | 7             |        |        |       |       |     |      |                 |
| 0163  [            | с, Н  | H, X,         | x,     | x,     | x,    | н     | ]   | ->   | [gr1];          |
| 0164  [            | c, F  | H, X,         | x,     | x,     | н,    | н     | ]   | ->   | [gr1];          |
| 0165  [            | с, Н  | H, L,         | L,     | L,     | L,    | н     | ]   | ->   | [gr1];          |
| 0166  [            | с, Н  | H, X,         | x,     | н,     | L,    | Н     | ]   | ->   | [bry1];         |
| 0167  [            | c, F  | H, X,         | х,     | x,     | x,    | Н     | ]   | ->   | [bry1];         |
| 0168  [            | с, Н  | H, X,         | x,     | х,     | х,    | Н     | ]   | ->   | [bry1];         |
| 0169  @pa          | age   |               |        |        |       |       |     |      |                 |
| 0170  ″ve          | ector | 15            |        |        |       |       |     |      |                 |
| 0171  [            | с, І  | Ь, L,         | L,     | н,     | x,    | Η     | ]   | ->   | [gr4];          |
| 0172  [            | с, І  | L, L,         | L,     | н,     | x,    | н     | ]   | ->   | [gr4];          |
| 0173  [            | с, І  | L, L,         | L,     | н,     | x,    | н     | ]   | ->   | [gr4];          |
| 0174  [            | с, Х  | κ, x,         | x,     | н,     | н,    | н     | ]   | ->   | [gr4];          |
| 0175  [            | с, Х  | κ <b>,</b> Χ, | н,     | x,     | L,    | н     | ]   | ->   | [bry4];         |
| 0176  [            | с, Х  | к, х,         | х,     | н,     | x,    | Н     | ]   | ->   | [bry4];         |
| 0177  [            | с, Х  | κ <b>,</b> Χ, | x,     | н,     | x,    | н     | ]   | ->   | [bry4];         |
| 0178   <b>"</b> ve | ector | 21            |        |        |       |       |     |      |                 |
| 0179  [            | с, І  | Ь, L,         | н,     | L,     | x,    | Н     | ]   | ->   | [gr3];          |
| 0180  [            | с, І  | Ь, L,         | н,     | L,     | x,    | Н     | ]   | ->   | [gr3];          |
| 0181  [            | с, І  | L, L,         | н,     | L,     | н,    | Н     | ]   | ->   | [gr3];          |
| 0182  [            | c, X  | κ, x,         | н,     | x,     | н,    | н     | ]   | ->   | [gr3];          |
| 0183  [            | c, X  | к, н,         | н,     | x,     | L,    | н     | ]   | ->   | [bry3];         |
| 0184  [            | с, Х  | κ, x,         | н,     | x,     | x,    | Н     | ]   | ->   | [bry3];         |
| 0185  [            | c, X  | κ, x,         | н,     | x,     | x,    | н     | ]   | ->   | [bry3];         |
| 0186  "ve          | ector | 27            |        |        |       |       |     |      |                 |
| 0187  [            | c, I  | Ь, Н,         | L,     | L,     | x,    | Н     | ]   | ->   | [gr2];          |
| 0188  [            | c, I  | Ь, Н,         | L,     | L,     | x,    | W     | ]   | ->   | [gr2];          |
| 0189  [            | c, X  | к, н,         | x,     | x,     | н,    | н     | ]   | ->   | [gr2];          |
| 0190  [            |       | Ь, Н,         | L,     | L,     |       | н     | ]   | ->   | [gr2];          |
| 0191  [            |       | н, н,         | х,     | x,     | L,    | н     | ]   |      | [bry2];         |
| 0192  [            |       | ζ, Н,         | x,     | x,     |       | н     | j   |      | [bry2];         |
| 0193  [            |       | , н,          | x,     | X,     |       | н     | ]   |      | [bry2];         |
|                    | ector |               | •      | •      | •     | -     | -   |      |                 |
| 0195  [            |       | H, L,         | L,     | L,     | x,    | Н     | ]   | ->   | [gr1];          |

Hardware Applications

| Figure | 13–22. | PL   | D Eq | uatio | ons fo | r Pro | gram | nming | the | 16R8 | PLD (Concluded) |
|--------|--------|------|------|-------|--------|-------|------|-------|-----|------|-----------------|
| 0196   | [      | c,   | н,   | x,    | н,     | x,    | L,   | н     | ]   | ->   | [bry1];         |
| 0197   | ] [    | c,   | L,   | L,    | H,     | x,    | x,   | н     | ]   | ->   | [gr3];          |
| 0198   | ] [    | c,   | н,   | x,    | н,     | x,    | L,   | н     | ]   | ->   | [bry3];         |
| 0199   | 1[     | c,   | н,   | x,    | L,     | L,    | x,   | Н     | ]   | ->   | [gr1];          |
| 0200   | ] [    | c,   | н,   | н,    | x,     | x,    | L,   | Н     | ]   | ->   | [bry1];         |
| 0201   | [      | c,   | L,   | н,    | x,     | x,    | x,   | н     | ]   | ->   | [gr2];          |
| 0202   | [      | c,   | x,   | н,    | x,     | н,    | L,   | н     | ]   | ->   | [bry2];         |
| 0203   | ] [    | c,   | x,   | L,    | L,     | н,    | x,   | Н     | ]   | ->   | [gr4];          |
| 0204   | ] [    | c,   | x,   | Н,    | x,     | н,    | L,   | Н     | ]   | ->   | [bry4];         |
| 0205   | ] [    | c,   | L,   | н,    | x,     | L,    | x,   | н     | ]   | ->   | [gr2];          |
| 0206   | ] [    | c,   | x,   | Н,    | Н,     | х,    | L,   | Н     | ]   | ->   | [bry2];         |
| 0207   | "ve    | ecto | r 4  | 5     |        |       |      |       |     |      |                 |
| 0208   | ] [    | c,   | x,   | L,    | н,     | x,    | x,   | н     | ]   | ->   | [gr3];          |
| 0209   | ] [    | c,   | x,   | x,    | н,     | н,    | L,   | н     | ]   | ->   | [bry3];         |
| 0210   | ] [    | c,   | x,   | x,    | L,     | н,    | х,   | Н     | ]   | ->   | [gr4];          |
| 0211   | ] [    | c,   | Н,   | x,    | x,     | н,    | L,   | Н     | ]   | ->   | [bry4];         |
| 0212   | ] [    | c,   | н,   | x,    | x,     | L,    | x,   | н     | ]   | ->   | [gr1];          |
| 0213   | 1[     | c,   | Н,   | Н,    | x,     | x,    | L,   | н     | ]   | ->   | [bry1];         |
| 0214   | end    | 1    | glo  | obal  | _bu    | s_cı  | ntrl | -     |     |      |                 |

```
Bus Arbitration
```

```
Figure 13–23. PLD Equations for Programming the 16R6 PLD
0001
                c40_global_timeout
     |module
0002
     ltitle'
     |DWG NAME global arbitration
0003
0004
     |DWG #
     |COMPANY TEXAS INSTRUMENTS INCROPORATED
0005
0006 |
0007 |DATE
0008 |
0009 |
         c40u4
                   device
                                      'P16R6';
0010 |
0011 |
         "inputs
0012 |
                   Pin 1;
         h50
0013 | bg1_
                  Pin 2;
0014 |
         bg2
                  Pin 3;
0015 |
         bg3
                   Pin 4;
0016 |
         bg4_
                  Pin 5;
         timeout_ Pin 13;
0017 |
                             "output
0018 |
                   Pin 16;
         s1
0019 |
         s0
                   Pin 15;
0020 |
0021 |
0022 | "name substitution to increase readability
0023 |
         bus_active = (!bg1_ # !bg2_ # !bg3_ # !bg4_);
0024 |
0025 |"define machine state bits
0026 |"[timeout ,s1,s0];
0027 |
0028 |
             "states
0029 |
0030 |
         idle
                  = ^b111;
0031 |
         count1
                   = ^b110;
0032 |
         count2
                  = ^b101;
0033 | count3
                  = ^{b100};
0034 |
         time
                   = ^b011;
0035 |
0036 |
         outstate = [timeout_,s1,s0];
0037 |
0038 |
         C,H,L,X
                 = .C.,1,0,.X.;
0039 |
0040 |
0041 |state diagram outstate
0042 |
0043 |state idle:
0044 |if (!bus active) then idle
```

Hardware Applications

13-68

```
Figure 13–23. PLD Equations for Programming the 16R6 PLD (Continued)
0045 |
          else count1;
0046
     0047
     |state count1:
0048 |
          if (!bus_active) then idle
0049
          else count2;
     1
0050
     0051
     |state count2:
0052 |
          if (!bus active) then idle
0053 |
          else count3;
0054
     0055 |state count3:
0056 |
          if (!bus active) then idle
0057
          else time;
     0058
     0059 |state time:
                     GOTO idle;
0060 |
0061 |@page
0062 |"Test counter
0063
     |test vectors
0064 |([h50, bg1,
                     bg2_,
                            bg3_,
                                    bg4 ]
                                           -> [outstate])
0065
     1[
          c,
              Н,
                     H,
                             н,
                                    Н
                                        1
                                           -> [ idle];
0066
     ] [
          c, L,
                                        ]
                     Н,
                             Н,
                                    Н
                                           -> [count1];
0067
     1[
          с, Н,
                     H,
                             H,
                                    Н
                                        ]
                                           -> [ idle];
0068
     1[
          c, L,
                     H,
                             H,
                                    Н
                                        ]
                                           -> [count1];
0069
     1[
          c, X,
                     X,
                             X,
                                    х
                                       ]
                                           -> [count2];
0070
     1[
          с, Н,
                     Н,
                             H,
                                    Н
                                        ]
                                           -> [ idle];
0071
     1[
          c, L,
                     H,
                             H,
                                    Н
                                        ]
                                           -> [count1];
0072
     1[
          с, Х,
                     X,
                             X,
                                    Х
                                       1
                                           -> [count2];
0073
     1[
          с, Х,
                     X,
                             Х,
                                    Х
                                        1
                                           \rightarrow [count3];
0074
     1[
          с, Н,
                     H,
                             H,
                                    Н
                                        ]
                                           -> [ idle];
0075
     11
                     H,
          c, L,
                             Н,
                                    Н
                                        1
                                           -> [count1];
0076
     11
          с, Х,
                     X,
                             X,
                                    Х
                                        ]
                                           -> [count2];
0077
     1[
          c, X,
                     X,
                             x,
                                    Х
                                        ]
                                           -> [count3];
0078
      0079
     1[
          c, X,
                     X,
                             х,
                                        ]
                                    X
                                           -> [ idle];
0080
     ] [
          с, Н,
                     L,
                             н,
                                    Н
                                        ]
                                           -> [count1];
0081
     1[
          c, X,
                             X,
                                    х
                                        ]
                     х,
                                           -> [count2];
0082
     1[
          c, X,
                     X,
                             x,
                                    Х
                                        ]
                                           -> [count3];
0083
     ] [
          с, Х,
                     x,
                             X,
                                    х
                                        ]
                                           -> [time];
0084
     1[
          c, X,
                     X,
                                        ]
                             Х,
                                    х
                                           -> [ idle];
0085
     1[
          с, Н,
                     Н,
                             L,
                                    Н
                                        ]
                                           -> [count1];
0086 [[
                     X,
          c, X,
                             X,
                                    X
                                        1
                                           -> [count2];
0087
     1[
                                        1
          c, X,
                     X,
                             X,
                                    Х
                                           -> [count3];
```

0088

1[

c, X,

Х,

X,

X 1

-> [time];

| Figure | 13–23. | PL | D Equatio | ns for Pro | gramming | the | 16R6 | PLD | (Concluded) |
|--------|--------|----|-----------|------------|----------|-----|------|-----|-------------|
| 0089   | ] [    | с, | х,        | x,         | х,       | х   | ]    | ->  | [ idle];    |
| 0090   | 11     | c, | н,        | н,         | н,       | L   | ]    | ->  | [count1];   |
| 0091   | [      | c, | х,        | х,         | х,       | х   | ]    | ->  | [count2];   |
| 0092   | 11     | c, | Х,        | Х,         | Χ,       | Х   | ]    | ->  | [count3];   |
| 0093   | [      | c, | х,        | Х,         | Х,       | Х   | ]    | ->  | [time];     |
| 0094   | 1[     | с, | х,        | Х,         | Х,       | Х   | ]    | ->  | [ idle];    |
| 0095   | I      |    |           |            |          |     |      |     |             |
| 0096   | ł      |    |           |            |          |     |      |     |             |
| 0097   | 1      |    |           |            |          |     |      |     |             |
| 0098   | I      |    |           |            |          |     |      |     |             |
| 0099   | 1      |    |           |            |          |     |      |     |             |
| 0100   | lend   | 1  | c40_gl    | obal_t:    | imeout   |     |      |     |             |
| 0101   | 1      |    |           |            |          |     |      |     |             |
| 0102   | 1      |    |           |            |          |     |      |     |             |
| 0103   | 1      |    |           |            |          |     |      |     |             |
| 0104   | 1      |    |           |            |          |     |      |     |             |
| 0105   | 1      |    |           |            |          |     |      |     |             |

#### **13.6.2 Arbitration Alternatives**

If more arbitration flexibility is desired, a fixed priority mode can be implemented in the global bus controller PLD. A fixed scheme can be used in conjunction with this rotating priority mode if a fixed/rotating input is added to the GBC PLD to allow either of the two arbitration methods. One of the spare IIOF pins can be configured as a general-purpose output pin to act as the arbitration mode control pin. For example, if FIX/ROT (IIOF2) = 0, the four 'C40s have rotating priorities; if FIX/ROT = 1, the four processors have fixed priorities. To reduce state machine complexity, the rotating priorities can be preset at system reset to the same values as in the fixed arbitration mode, with the processors having priorities of 1, 2, 3, or 4, with 1 being the highest (first serviced) priority.

#### 13.6.3 Global Bus Arbitration and Transfer Timing

To illustrate the timing involved with global bus arbitration and data transfers, Figure 13–17 (page 13-47), Figure 13–24 (page 13-72), Figure 13–25 and Figure 13–26, show shared bus timings using the rotating priority arbitration configuration.

These figures represent a 'C40 requesting a shared bus access when it is not currently the bus master. Clock H1 is the output clock of the the 'C40 requesting access to the bus. Both clocks H1 and H3 have a rate of 25 MHz; however, the global bus controller (GBC) input clock is aysnchronous with respect to H1 and H3 and has a rate of 50 MHz.

Due to the arbitration logic synchronizer delays and the 35-ns SRAMs, access to the shared memory requires wait states. A new bus master's first memory access after an arbitration win takes at least five H1 cycles (the five cycles include the time period from status lines active to the end of the read or write cycle), but subsequent reads or writes take only two H1 cycles. Two-cycle memory accesses allow enough time for control signals to go active and inactive to complete read or write cycles for 35-ns memories. They also allow processors to stop driving the bus before another processor starts driving the bus after a bus arbitration contest. Also, the two-cycle memory accesses allow enough time for signal buffering between the processor bus and memory (buffer delays are less than 15 ns with commercially available parts).

In Figure 13–17 (page 13-47), a 'C40 wins an arbitration contest immediately and does one read cycle. However, it loses arbitration for the next transfer on the shared bus (busgrant\_goes inactive high) and the first-level PLD brings its busrequest\_signal inactive high to signal the GBC that it has given up the bus. The first-level PLD at the same time sends bus disable signals (BUSENABLE and CTLENABLE high) to the AE, DE, and CE pins of the 'C40 to three-state the bus. The first-level PLD three-states the bus immediately because the GBC will give another processor access to the shared bus as soon as it sees this BUSREQUEST and a time-out go inactive.

Figure 13–24 shows a successful arbitration contest followed by successive reads. The 'C40 is allowed to do successive reads on the shared bus because no other processor desires access (busgrant stays active).

Figure 13–25 illustrates an arbitration win followed by a single write. Figure 13–26 shows an aribitration win followed by successive writes and an arbitration loss. The second write is allowed to occur because the busgrant going inactive is missed by the first-level PLDs, which synchronizes on H1 rising. The first-level PLD transcends to the do\_cycle state because STRB is high and the PLD has not seen the busgrant go inactive from the synchronizer output. Even though the first-level PLD sees that the busgrant\_is taken away during the next H1/H3 cycle, it does not take away its busrequest\_until the end of the second write cycle. Then, the busrequest\_ is made inactive, and the bus is disabled.



Figure 13–24. Successful TMS320C40 Arbitration; Data Read; Data Read







### Successful 'C40 Arbitration; Consecutive Data Writes; Arbitration Win Followed by Figure 13-26.

### 13.6.4 Arbitration Protocol Limitations

This shared bus arbitration protocol uses handshaking between the GBC and the processors sharing the global bus to ensure that only one processsor is driving the bus at any given time. Nonetheless, the global bus controller should not allow another processor to become bus master until the previous master is guaranteed to release the bus completely. Since 'C40s have a bus disable ( $\overline{AE}$ ,  $\overline{DE}$ , or  $\overline{CE}$ ) time of less than 15 ns, bus turnoff time is not critical unless the GBC input clock frequency is greater than 50 MHz. However, if processors with slower turnoff times are used in a shared bus configuration with this protocol, the GBC input clock period cannot be less than the bus disable time of the slowest processor in the system. If the GBC input clock period is less than a processor's disable time, the GBC could give a new master ownership of the bus before the previous master is off the bus.

## **13.7 Reset Signal Generation Control Function**

Several aspects of 'C40 system hardware design are critical to overall system operation. One such function is reset signal generation.

The reset input controls initialization of internal 'C40 logic and also causes execution of the system initialization software. For proper system initialization, the reset signal must be applied for at least ten H1 cycles, i.e., 400 ns for a 'C40 operating at 50.00 MHz. Upon powerup, however, it can take 20 ms or more before the system oscillator reaches a stable operating state. Therefore, the powerup reset circuit should generate a low pulse on the reset line for 100 to 200 ms. Once a proper reset pulse has been applied, the processor fetches the reset vector from location zero, which contains the address of the system initialization routine. Figure 13–27 shows a circuit that will generate an appropriate powerup or push button reset signal.





The voltage on the reset pin ( $\overline{\text{RESET}}$ ) is controlled by the R<sub>1</sub>C<sub>1</sub> network. After a reset, this voltage rises exponentially according to the time constant R<sub>1</sub>C<sub>1</sub>, as shown in Figure 13–28. In Figure 13–27, the 74ALS34 is used to provide a clean  $\overline{\text{RESET}}$  signal to the 'C40.





The duration of the low pulse on the  $\overrightarrow{RESET}$  pin is approximately  $t_1$ , which is the time it takes for the capacitor  $C_1$  to be charged to 1.5 V. This is approximately the voltage at which the reset input switches from a logic 0 to a logic 1. The capacitor voltage is expressed as

$$V = V_{\rm CC} \left[ 1 - e^{-\frac{t}{r}} \right]$$
 (5)

where  $\tau = R_1C_1$  is the reset circuit time constant. Solving (5) for t results in

$$t = -R_1 C_1 ln \left[ 1 - \frac{V}{V_{cc}} \right]$$
(6)

Setting the following:

 $R_1 = 100 kΩ$   $C_1 = 4.7 μF$   $V_{CC} = 5 V$  $V = V_1 = 1.5 V$ 

results in t = 167 ms. Therefore, the reset circuit of Figure 13–27 provides a low pulse long enough to ensure the stabilization of the system oscillator upon powerup.

Note that if synchronization of multiple 'C40s is required, all processors should be provided with the same input clock and the same reset signal. After powerup, when the clock has stabilized, all processors may then be synchronized by generating a falling edge on the common reset signal. Since it is the falling edge of RESET that establishes synchronization, RESET must be high for at least ten H1 cycles initially. Following the falling edge, RESET should remain low for at least ten H1 cycles and then be driven high. This sequencing of RESET may be accomplished by using additional circuitry based on either RC time delays or counters.

## **Chapter 14**

14

# TMS320C4x Signal Descriptions and Electrical Characteristics

The sections in this chapter cover the following characteristics of theTMS320C4x:

| Sectio | n                          | Page  |
|--------|----------------------------|-------|
| 14.1   | Pinout and Pin Assignments | 14-2  |
| 14.2   | Signal Descriptions        | 14-7  |
| 14.3   | TMS320C4x Mechanical Data  | 14-11 |
| 14.4   | Electrical Specifications  | 14-12 |
| 14.5   | Signal Transition Levels   | 14-14 |
| 14.6   | Timing                     | 14-15 |

#### Note: Advance Information

Unless otherwise noted, this chapter contains advance information on new products in the sampling or preproduction phases of development. Characteristic data and other specifications are subject to change without notice.

#### 14.1 Pinout and Pin Assignments

The TMS320C40 (TMS320C4x generation) digital signal processor is available in a 325-pin grid array (PGA) package. The pinout of this package is shown in Figure 14–1. Pin assignments are listed in the following tables:

□ Table 14–1: Pins sorted by signal name (alphanumeric listing)

- □ Table 14–2: Pins sorted by pin number (location on Figure 14–1)
- □ Table 14–3: Pins sorted by function, describing each (page 14-7)

Figure 14–1. TMS320C40 Pinout (Bottom View)



| Table 14–1. | TMS320C40 Pin Assignments Sorted by Signal Name |
|-------------|-------------------------------------------------|
|-------------|-------------------------------------------------|

| Signal | Pin  | Signal | Pin  |  | Signal        | Pin  | Signal | Pin  | Signal             | Pin  | 14 |
|--------|------|--------|------|--|---------------|------|--------|------|--------------------|------|----|
| A0     | D32  | C0D6   | AN7  |  | C5D4          | AM30 | CVSS   | E35  | D31                | F32  |    |
| A1     | B32  | C0D7   | AK8  |  | C5D5          | AP32 | CVSS   | AR25 | DE                 | AA31 | 1  |
| A2     | D30  | C1D0   | AL7  |  | C5D6          | AM32 | CVSS   | AE1  | DVDD               | AR11 | 1  |
| A3     | C29  | C1D1   | AP8  |  | C5D7          | AL31 | CVSS   | AR13 | DVDD               | AR29 |    |
| A4     | B30  | C1D2   | AM8  |  | CACK0         | AN11 | CVSS   | A19  | DVDD               | A13  |    |
| A5     | F28  | C1D3   | AK12 |  | CACK1         | AN13 | CVSS   | R35  | DVDD               | A7   |    |
| A6     | F24  | C1D4   | AK10 |  | CACK2         | AM14 | CVSS   | AL1  | DVDD               | A17  |    |
| A7     | E29  | C1D5   | AN9  |  | CACK3         | AM16 | D0     | U33  | DVDD               | L35  |    |
| A8     | C27  | C1D6   | AL9  |  | CACK4         | AK32 | D1     | V32  | DVDD               | AR23 |    |
| A9     | D28  | C1D7   | AP10 |  | CACK5         | AJ31 | D2     | T34  | DVDD               | A29  |    |
| A10    | B28  | C2D0   | AM18 |  | CE0           | AA33 | D3     | U31  | DVDD               | L1   |    |
| A11    | F26  | C2D1   | AN19 |  | CE1           | V34  | D4     | R33  | DVDD               | AC1  |    |
| A12    | C25  | C2D2   | AL19 |  | CRDY0         | AP12 | D5     | P34  | DVDD               | AR17 |    |
| A13    | E27  | C2D3   | AP20 |  | CRDY1         | AP14 | D6     | T32  | DVDD               | A23  |    |
| A14    | B26  | C2D4   | AM20 |  | CRDY2         | AL15 | D7     | N33  | DVDD               | AJ1  |    |
| A15    | D26  | C2D5   | AN21 |  | CRDY3         | AL17 | D8     | R31  | DVSS               | AJ35 | 1  |
| A16    | C23  | C2D6   | AL21 |  | CRDY4         | AH30 | D9     | M34  | DVSS               | A21  |    |
| A17    | B24  | C2D7   | AP22 |  | CRDY5         | AH32 | D10    | P32  | DVSS               | A25  |    |
| A18    | E25  | C3D0   | AM22 |  | CREQ0         | AM10 | D11    | L33  | DVSS               | G35  |    |
| A19    | C21  | C3D1   | AN23 |  | CREQ1         | AM12 | D12    | N31  | DVSS               | A11  |    |
| A20    | D24  | C3D2   | AL23 |  | CREQ2         | AN15 | D13    | K34  | DVSS               | AG1  |    |
| A21    | B22  | C3D3   | AP24 |  | <b>CREQ</b> 3 | AN17 | D14    | M32  | DVSS               | AM2  |    |
| A22    | E23  | C3D4   | AM24 |  | CREQ4         | AN33 | D15    | J33  | DVSS               | R1   |    |
| A23    | C19  | C3D5   | AN25 |  | CREQ5         | AL33 | D16    | L31  | DVSS               | AR21 |    |
| A24    | D22  | C3D6   | AL25 |  | CSTRB0        | AL11 | D17    | М30  | DVSS               | AR15 |    |
| A25    | B20  | C3D7   | AP26 |  | CSTRB1        | AL13 | D18    | K32  | DVSS               | A15  |    |
| A26    | E21  | C4D0   | AN27 |  | CSTRB2        | AP16 | D19    | H34  | DVSS               | AR27 |    |
| A27    | B18  | C4D1   | AM26 |  | CSTRB3        | AP18 | D20    | J31  | DVSS               | G1   |    |
| A28    | C17  | C4D2   | AK24 |  | CSTRB4        | AM34 | D21    | G33  | DVSS               | N35  |    |
| A29    | D20  | C4D3   | AL27 |  | CSTRB5        | AK34 | D22    | K30  | DVSS               | AR9  |    |
| A30    | B16  | C4D4   | AP28 |  | CVSS          | AR19 | D23    | F34  | EMU0               | AA35 | 1  |
| ĀĒ     | AG31 | C4D5   | AK26 |  | CVSS          | AR7  | D24    | H32  | EMU1               | AD34 | 4. |
| C0D0   | AP4  | C4D6   | AN29 |  | CVSS          | N1   | D25    | E33  | GADVDD             | B2   | 1  |
| C0D1   | AL5  | C4D7   | AM28 |  | CVSS          | AL35 | D26    | D34  | GADVDD             | AR1  |    |
| C0D2   | AN5  | C5D0   | AL29 |  | CVSS          | A27  | D27    | G31  | GADV <sub>DD</sub> | U35  | ]  |
| C0D3   | AM4  | C5D1   | AP30 |  | CVSS          | A9   | D28    | C33  | GDDV <sub>DD</sub> | V2   | ]  |
| C0D4   | AP6  | C5D2   | AK28 |  | CVSS          | E1   | D29    | H30  | GDDV <sub>DD</sub> | A35  |    |
| C0D5   | AM6  | C5D3   | AN31 |  | CVSS          | J35  | D30    | E31  | GDDV <sub>DD</sub> | A1   |    |

| Table 14-1. TWISS20040 FIT Assignments Soned by Signal Name (Conclud | Table 14–1. | 20C40 Pin Assignments Sorted by Signal Name (Conci | uded) |
|----------------------------------------------------------------------|-------------|----------------------------------------------------|-------|
|----------------------------------------------------------------------|-------------|----------------------------------------------------|-------|

| 14 | Signal           | Pin  |     | Signal | Pin  |   | Signal    | Pin  | ] | Signal            | Pin  |
|----|------------------|------|-----|--------|------|---|-----------|------|---|-------------------|------|
|    | H1               | AC3  |     | LA25   | R5   |   | LD26      | B4   | 1 | STAT0             | AD32 |
|    | НЗ               | AC5  |     | LA26   | T2   |   | LD27      | F8   |   | STAT1             | AE33 |
|    | IACK             | W3   |     | LA27   | Ú3   |   | LD28      | D6   |   | STAT2             | AF34 |
|    | IIOF0            | AN3  |     | LA28   | T4   |   | LD29      | Сз   |   | STAT3             | AE31 |
|    | IIOF1            | AL3  |     | LA29   | V4   |   | LD30      | E5   |   | STRB0             | AD30 |
|    | IIOF2            | AH6  |     | LA30   | U5   |   | LD31      | F6   |   | STRB1             | AC33 |
|    | IIOF3            | AK2  |     | LADVDD | B34  |   | LDDVDD    | AR35 | 1 | SUBS              | C31  |
|    | IVSS             | AR5  |     | LADVDD | AB2  |   | LDDVDD    | AP2  |   | ТСК               | Y34  |
|    | IVSS             | AR31 |     | LADVDD | AP34 |   | LDDVDD    | U1   |   | TCLK0             | AE3  |
|    | IVSS             | AG35 |     | LAE    | AB4  |   | LDE       | AD4  |   | TCLK1             | AD2  |
|    | IVSS             | A31  |     | LCE0   | AG5  |   | LLOCK     | AA5  | ] | TDO               | AB34 |
|    | IVSS             | J1   |     | LCE1   | AF2  |   | LOCK      | W33  | 1 | TDI               | AC35 |
|    | IV <sub>SS</sub> | A5   |     | LD0    | E19  |   | LPAGE0    | AH2  | ] | TMS               | W35  |
|    | LA0              | D2   |     | LD1    | C15  |   | LPAGE1    | AG3  | ł | TRST              | AE35 |
|    | LA1              | D4   |     | LD2    | D18  |   | LRDY0     | AF6  | ] | V <sub>DD</sub> L | AN1  |
|    | LA2              | E3   |     | LD3    | B14  |   | LRDY1     | AE5  |   | V <sub>DD</sub> L | AN35 |
|    | LA3              | F4   |     | LD4    | E17  |   | LR/W0     | AH4  |   | VDDL              | C35  |
|    | LA4              | H6   |     | LD5    | D16  |   | LR/W1     | AF4  | 1 | VDDL              | C1   |
|    | LA5              | F2   |     | LD6    | C13  |   | LSTAT0    | AA3  | 1 | VSSL              | A3   |
|    | LA6              | G5   |     | LD7    | E15  |   | LSTAT1    | Y4   |   | VSSL              | AR3  |
|    | LA7              | G3   |     | LD8    | B12  |   | LSTAT2    | Y2   |   | VSSL              | AR33 |
|    | LA8              | H4   |     | LD9    | D14  | ŀ | LSTAT3    | W5   |   | V <sub>SS</sub> L | A33  |
|    | LA9              | H2   |     | LD10   | C11  |   | LSTRB0    | AJ3  |   | X1                | W1   |
|    | LA10             | K6   |     | LD11   | E13  |   | LSTRB1    | AD6  |   | X2/CLKIN          | AA1  |
|    | LA11             | M6   |     | LD12   | B10  |   | NMI       | AJ5  | ] |                   |      |
|    | LA12             | J5   |     | LD13   | D12  |   | PAGE0     | AG33 | 1 |                   |      |
|    | LA13             | J3   |     | LD14   | C9   |   | PAGE1     | AB32 |   |                   |      |
|    | LA14             | K4   |     | LD15   | E11  |   | RDY0      | Y32  | 1 |                   |      |
|    | LA15             | K2   |     | LD16   | F12  |   | RDY1      | W31  |   |                   |      |
|    | LA16             | L3   |     | LD17   | D10  |   | RESETLOC0 | AF30 | 1 |                   |      |
|    | LA17             | L5   |     | LD18   | BB   |   | RESETLOC1 | AH34 |   |                   |      |
|    | LA18             | M2   |     | LD19   | E9   |   | RESET     | AJ33 | 7 |                   |      |
|    | LA19             | M4   |     | LD20   | C7   |   | ROMEN     | AK4  | 1 |                   |      |
|    | LA20             | N3   |     | LD21   | F10  |   | R/W0      | AF32 | 1 |                   |      |
|    | LA21             | N5   |     | LD22   | B6   |   | R/W1      | AC31 |   |                   |      |
|    | LA22             | P2   |     | LD23   | D8   |   | · · · ·   |      | - |                   |      |
|    | LA23             | P4   |     | LD24   | C5   |   |           |      |   |                   |      |
|    | LA24             | R3   | с., | LD25   | E7   |   |           |      |   |                   |      |
|    |                  |      |     |        |      |   |           |      |   |                   |      |

TMS320C4x Signal Descriptions and Electrical Characteristics

| Pin  | Signal            | Pin  | Signal    |   | Pin  | Signal        | Pin  | Signal             |   |
|------|-------------------|------|-----------|---|------|---------------|------|--------------------|---|
| A0   | GDDVDD            | AD30 | STRB0     |   | AK24 | C4D2          | AM30 | C5D4               |   |
| A3   | V <sub>SS</sub> L | AD32 | STAT0     |   | AK26 | C4D5          | AM32 | C5D6               | ĺ |
| A5   | IVSS              | AD34 | EMU1      |   | AK28 | C5D2          | AM34 | CSTRB4             |   |
| A7   | DVDD              | AE1  | CVSS      |   | AK32 | CACK4         | AN1  | VDDL               |   |
| A9   | CVSS              | AE3  | TCLKO     |   | AK34 | CSTRB5        | AN3  | IIOF0              |   |
| A11  | DVSS              | AE5  | LRDY1     |   | AL1  | CVSS          | AN5  | C0D2               |   |
| A13  | DVDD              | AE31 | STAT3     |   | AL3  | IIOF1         | AN7  | C0D6               |   |
| A15  | DVSS              | AE33 | STAT1     |   | AL5  | C0D1          | AN9  | C1D5               |   |
| A17  | DVDD              | AE35 | TRST      |   | AL7  | C1D0          | AN11 | CACK0              |   |
| A19  | CVSS              | AF2  | LCE1      |   | AL9  | C1D6          | AN13 | CACK1              |   |
| A21  | DVSS              | AF4  | LR/W1     |   | AL11 | CSTRB0        | AN15 | CREQ2              |   |
| A23  | DVDD              | AF6  | LRDY0     |   | AL13 | CSTRB1        | AN17 | <b>CREQ3</b>       |   |
| A25  | DVSS              | AF30 | RESETLOC0 |   | AL15 | CRDY2         | AN19 | C2D1               |   |
| A27  | CVSS              | AF32 | R/W0      |   | AL17 | <b>CRDY</b> 3 | AN21 | C2D5               | ŀ |
| A29  | DVDD              | AF34 | STAT2     |   | AL19 | C2D2          | AN23 | C3D1               |   |
| A31  | IVSS              | AG1  | DVSS      |   | AL21 | C2D6          | AN25 | C3D5               |   |
| A33  | VSSL              | AG3  | LPAGE1    |   | AL23 | C3D2          | AN27 | C4D0               |   |
| A35  | GDDVDD            | AG5  | LCE0      |   | AL25 | C3D6          | AN29 | C4D6               |   |
| AA1  | X2/CLKIN          | AG31 | ĀĒ        |   | AL27 | C4D3          | AN31 | C5D3               | ľ |
| AA3  | LSTAT0            | AG33 | PAGEO     |   | AL29 | C5D0          | AN33 | CREQ4              | ŀ |
| AA5  | LLOCK             | AG35 | IVSS      |   | AL31 | C5D7          | AN35 | VDDL               |   |
| AA31 | DE                | AH2  | LPAGE0    |   | AL33 | CREQ5         | AP2  | LDDVDD             |   |
| AA33 | CEO               | AH4  | LR7W0     |   | AL35 | CVSS          | AP4  | C0D0               |   |
| AA35 | EMU0              | AH6  | II0F2     |   | AM2  | DVSS          | AP6  | C0D4               |   |
| AB2  | LADVDD            | AH30 | CRDY4     | l | AM4  | C0D3          | AP8  | C1D1               | l |
| AB4  | LAE               | AH32 | CRDY5     |   | AM6  | C0D5          | AP10 | C1D7               |   |
| AB32 | PAGE1             | AH34 | RESETLOC1 |   | AM8  | C1D2          | AP12 | CRDY0              |   |
| AB34 | TDO               | AJ1  | DVDD      |   | AM10 | CREQ0         | AP14 | CRDY1              |   |
| AC1  | DVDD              | AJ3  | LSTRB0    |   | AM12 | CREQ1         | AP16 | CSTRB2             |   |
| AC3  | H1                | AJ5  | NMI       |   | AM14 | CACK2         | AP18 | <b>CSTRB</b> 3     |   |
| AC5  | нз                | AJ31 | CACK5     |   | AM16 | <b>CACK</b> 3 | AP20 | C2D3               |   |
| AC31 | R/W1              | AJ33 | RESET     |   | AM18 | C2D0          | AP22 | C2D7               |   |
| AC33 | STRB1             | AJ35 | DVSS      |   | AM20 | C2D4          | AP24 | C3D3               |   |
| AC35 | TDI               | AK2  | IIOF3     |   | AM22 | C3D0          | AP26 | C3D7               |   |
| AD2  | TCLK1             | AK4  | ROMEN     |   | AM24 | C3D4          | AP28 | C4D4               |   |
| AD4  | LDE               | AK8  | C0D7      |   | AM26 | C4D1          | AP30 | C5D1               |   |
| AD6  | LSTRB1            | AK10 | C1D4      | ĺ | AM28 | C4D7          | AP32 | C5D5               |   |
|      |                   | AK12 | C1D3      |   |      |               | AP34 | LADV <sub>DD</sub> |   |

Table 14–2. TMS320C40 Pin Assignments Sorted by Pin Number

| Table 14–2. | TMS320C40 Pin Assignments Sorted by Pin Number (Concluded) |
|-------------|------------------------------------------------------------|
|             |                                                            |

| Pin  | Signal             | Pir | Signal              |   | Pin | Signal |    | Pin | Signal | Pin    | Signal |
|------|--------------------|-----|---------------------|---|-----|--------|----|-----|--------|--------|--------|
| AR1  | GADV <sub>DD</sub> | C1  | VDDL                | 1 | E1  | CVSS   | 1  | H2  | LA9    | P2     | LA22   |
| AR3  | V <sub>SS</sub> L  | СЗ  | LD29                |   | E3  | LA2    |    | H4  | LA8    | P4     | LA23   |
| AR5  | IVSS               | C5  | LD24                |   | E5  | LD30   |    | H6  | LA4    | P32    | D10    |
| AR7  | CV <sub>SS</sub>   | C7  | LD20                |   | E7  | LD25   |    | Н30 | D29    | P34    | D5     |
| AR9  | DVSS               | C9  | LD14                |   | E9  | LD19   | 1  | H32 | D24    | R1     | DVSS   |
| AR11 | DVDD               | C1- | LD10                |   | E11 | LD15   |    | H34 | D19    | R3     | LA24   |
| AR13 | CVSS               | C1: | B LD6               |   | E13 | LD11   |    | J1  | IVSS   | R5     | LA25   |
| AR15 | DVSS               | C1! | 5 LD1               |   | E15 | LD7    |    | JЗ  | LA13   | R31    | D8     |
| AR17 | DVDD               | C1: | 7 A28               |   | E17 | LD4    |    | J5  | LA12   | R33    | D4     |
| AR19 | CVSS               | C19 | A23                 |   | E19 | LD0    |    | J31 | D20    | R35    | CVSS   |
| AR21 | DV <sub>SS</sub>   | C2  | A19                 |   | E21 | A26    |    | J33 | D15    | T2     | LA26   |
| AR23 | DVDD               | C2  | 3 A16               |   | E23 | A22    |    | J35 | CVSS   | T4     | LA28   |
| AR25 | CV <sub>SS</sub>   | C2  | 5 A12               |   | E25 | A18    |    | K2  | LA15   | T32    | D6     |
| AR27 | DVSS               | C2  | 7 A8                |   | E27 | A13    | ]. | K4  | LA14   | T34    | D2     |
| AR29 | DVDD               | C29 | A3                  |   | E29 | A7     |    | K6  | LA10   | U1     | LDDVDD |
| AR31 | IVSS               | C3  | SUBS                | - | E31 | D30    | [  | K30 | D22    | U3     | LA27   |
| AR33 | V <sub>SS</sub> L  | C3  | 3 D28               |   | E33 | D25    |    | K32 | D18    | U5     | LA30   |
| AR35 | LDDVDD             | C3  | 5 V <sub>DD</sub> L |   | E35 | CVSS   |    | K34 | D13    | U31    | D3     |
| B2   | GADV <sub>DD</sub> | D2  | LA0                 | ] | F2  | LA5    | ]  | L1  | DVDD   | U33    | D0     |
| B4   | LD26               | D4  | LA1                 |   | F4  | LA3    |    | L3  | LA16   | U35    | GADVDD |
| B6   | LD22               | D6  | LD28                |   | F6  | LD31   |    | L5  | LA17   | V2     | GDDVDD |
| B8   | LD18               | D8  | LD23                |   | F8  | LD27   |    | L31 | D16    | V4     | LA29   |
| B10  | LD12               | D10 | ) LD17              |   | F10 | LD21   |    | L33 | D11    | V32    | D1     |
| B12  | LD8                | D12 | 1                   |   | F12 | LD16   |    | L35 | DVDD   | V34    | CE1    |
| B14  | LD3                | D14 | LD9                 |   | F24 | A6     | 1  | M2  | LA18   | W1     | X1     |
| B16  | A30                | D10 | LD5                 |   | F26 | A11    |    | M4  | LA19   | W3     | IACK   |
| B18  | A27                | D18 | LD2                 |   | F28 | A5     |    | M6  | LA11   | W5     | LSTAT3 |
| B20  | A25                | D20 | ) A29               |   | F32 | D31    |    | M30 | D17    | W31    | RDY1   |
| B22  | A21                | D22 |                     |   | F34 | D23    |    | M32 | D14    | W33    | LOCK   |
| B24  | A17                | D24 | A20                 |   | G1  | DVSS   | ]  | M34 | D9     | W35    | TMS    |
| B26  | A14                | D20 | 6 A15               |   | G3  | LA7    |    | N1  | CVSS   | Y2     | LSTAT2 |
| B28  | A10                | D2  | 8 A9                |   | G5  | LA6    |    | N3  | LA20   | <br>Y4 | LSTAT1 |
| B30  | A4                 | D30 | ) A2                |   | G31 | D27    |    | N5  | LA21   | Y32    | RDY0   |
| B32  | A1                 | D3  | 2 A0                |   | G33 | D21    |    | N31 | D12    | Y34    | тск    |
| B34  | LADVDD             | D34 | D26                 | J | G35 | DVSS   | J  | N33 | D7     |        |        |
|      |                    |     |                     | - |     |        | -  | N35 | DVSS   |        |        |

TMS320C4x Signal Descriptions and Electrical Characteristics

#### **14.2 Signal Descriptions**

This section gives signal descriptions for the TMS320C40 device. Table 14-3 lists each signal, the number of pins, function, and operating 14 mode(s), i.e., input, output, or high-impedance state as indicated by I, O, or Z. All pins labeled NC are not to be connected by the user. A line over a signal name (e.g., RESET) indicates that the signal is active low (true at a logic 0 level). The signals are grouped according to function.

| Signal    | Pins                                    | Type‡ | Description                                                                                      |  |  |  |  |  |  |  |
|-----------|-----------------------------------------|-------|--------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|           | Global Bus External Interface (80 pins) |       |                                                                                                  |  |  |  |  |  |  |  |
| D(31–0)   | 32                                      | I/O/Z | 32-bit data port of the global external interface                                                |  |  |  |  |  |  |  |
| DE        | 1                                       | 1     | Data bus enable signal for the global external interface                                         |  |  |  |  |  |  |  |
| A(30–0)   | 31                                      | O/Z   | 31-bit address port of the global external interface                                             |  |  |  |  |  |  |  |
| ĀĒ        | 1                                       | I     | Address bus enable signal for the global bus interface                                           |  |  |  |  |  |  |  |
| STAT(3-0) | 4                                       | 0     | Status signals for the global bus interface                                                      |  |  |  |  |  |  |  |
| LOCK      | 1                                       | 0     | Lock signal for the global bus interface                                                         |  |  |  |  |  |  |  |
| STRB0 †   | 1                                       | O/Z   | Access strobe 0 for the global bus interface                                                     |  |  |  |  |  |  |  |
| R/W0      | 1                                       | O/Z   | Read/write signal for STRB0 accesses                                                             |  |  |  |  |  |  |  |
| PAGE0     | 1                                       | O/Z   | Page signal for STRB0 accesses                                                                   |  |  |  |  |  |  |  |
| RDY0      | 1                                       | I     | Ready signal for STRB0 accesses                                                                  |  |  |  |  |  |  |  |
| CE0       | 1                                       | I     | Control enable for the $\overline{\text{STRB}}$ 0, PAGE0, and R/ $\overline{\text{W}}$ 0 signals |  |  |  |  |  |  |  |
| STRB1 †   | 1                                       | O/Z   | Access strobe 1 for the global bus interface                                                     |  |  |  |  |  |  |  |
| R/W1      | 1                                       | O/Z   | Read/write signal for STRB1 accesses                                                             |  |  |  |  |  |  |  |
| PAGE1     | 1                                       | O/Z   | Page signal for STRB1 accesses                                                                   |  |  |  |  |  |  |  |
| RDY1      | 1                                       | 1     | Ready signal for STRB1 accesses                                                                  |  |  |  |  |  |  |  |
| CE1       | 1                                       | I     | Control enable for the $\overline{\text{STRB}}$ 1, PAGE1, and R/ $\overline{\text{W}}$ 1 signals |  |  |  |  |  |  |  |

Table 14-3. TMS320C40 Signal Descriptions

<sup>†</sup> STRB0 and STRB1 and associated signals (R/W1, R/W0, PAGE0, PAGE1, etc.) are effective over the address ranges defined by the STRB ACTIVE bits, as listed in Table 7–3 on page 7-8.

 $\ddagger$  I = input, O = output, Z = high impedance.

| Signal     | Pins | Type <sup>‡</sup> | Description                                                                                         |
|------------|------|-------------------|-----------------------------------------------------------------------------------------------------|
|            |      | Lo                | cal Bus External Interface (80 pins)                                                                |
| LD(31-0)   | 32   | 1/0/Z             | 32-bit data port of the local external interface                                                    |
| LDE        | 1    | 1                 | Data bus enable signal for the local external interface                                             |
| LA(30–0)   | 31   | O/Z               | 31-bit address port of the local external interface                                                 |
| LAE        | 1    | I                 | Address bus enable signal for the local bus interface                                               |
| LSTAT(3-0) | 4    | 0                 | Status signals for the local bus interface                                                          |
| LLOCK      | 1    | 0                 | Lock signal for the local bus interface                                                             |
| LSTRB0 †   | 1    | O/Z               | Access strobe 0 for the local bus interface                                                         |
| LR/W0      | 1    | O/Z               | Read/write signal for LSTRB0 accesses                                                               |
| LPAGE0     | 1    | O/Z               | Page signal for LSTRB0 accesses                                                                     |
| LRDY0      | 1    | 1                 | Ready signal for LSTRB0 accesses                                                                    |
| LCE0       | 1    | 1                 | Control enable for the $\overline{\text{LSTRB}}$ 0, LPAGE0, and LR/ $\overline{\text{W}}$ 0 signals |
| LSTRB1 †   | 1    | O/Z               | Access strobe 1 for the local bus interface                                                         |
| LR/W1      | 1    | O/Z               | Read/write signal for LSTRB1 accesses                                                               |
| LPAGE1     | 1    | O/Z               | Page signal for LSTRB1 accesses                                                                     |
| LRDY1      | 1    | 1                 | Ready signal for LSTRB1 accesses                                                                    |
| LCE1       | 1    | I                 | Control enable for the $\overline{\text{LSTRB}}$ 1, LPAGE1, and LR/ $\overline{\text{W}}$ 1 signals |
|            |      | Con               | nmunication Port 0 Interface (12 pins)                                                              |
| C0D(7 - 0) | 8    | I/O               | Communication port 0 data bus                                                                       |
| CREQ0      | 1    | I/O               | Communication port 0 token request signal                                                           |
| CACK0      | 1    | I/O               | Communication port 0 token request acknowledge signal                                               |
| CSTRB0     | 1    | I/O               | Communication port 0 data strobe signal                                                             |
| CRDY0      | 1    | I/O               | Communication port 0 data ready signal                                                              |

#### TMS320C40 Signal Descriptions (Continued) Table 14-3.

LSTRB0 and LSTRB1 and associated signals (LR/W1, LR/W0, LPAGE0, LPAGE1, etc.) are effective over the address ranges defined by the STRB ACTIVE bits, as listed in Table 7–3 on page 7-8.
 I = input, O = output, Z = three-stated (high impedance).

| Signal        | Pins | Type‡ | Description                                           |
|---------------|------|-------|-------------------------------------------------------|
|               |      | Con   | nmunication Port 1 Interface (12 pins)                |
| C1D(7 - 0)    | 8    | 1/0   | Communication port 1 data bus                         |
| CREQ1         | 1    | I/O   | Communication port 1 token request signal             |
| CACK1         | 1    | I/O   | Communication port 1 token request acknowledge signal |
| CSTRB1        | 1    | 1/0   | Communication port 1 data strobe signal               |
| CRDY1         | 1    | 1/0   | Communication port 1 data ready signal                |
|               |      | Соп   | nmunication Port 2 Interface (12 pins)                |
| C2D(7-0)      | 8    | 1/0   | Communication port 2 data bus                         |
| CREQ2         | 1    | I/O   | Communication port 2 token request signal             |
| CACK2         | 1    | I/O   | Communication port 2 token request acknowledge signal |
| CSTRB2        | 1    | I/O   | Communication port 2 data strobe signal               |
| CRDY2         | 1    | 1/0   | Communication port 2 data ready signal                |
|               |      | Con   | nmunication Port 3 Interface (12 pins)                |
| C3D(7-0)      | 8    | I/O   | Communication port 3 data bus                         |
| <b>CREQ3</b>  | 1    | I/O   | Communication port 3 token request signal             |
| <b>CACK</b> 3 | 1    | 1/0   | Communication port 3 token request acknowledge signal |
| CSTRB3        | 1    | 1/0   | Communication port 3 data strobe signal               |
| CRDY3         | 1    | 1/0   | Communication port 3 data ready signal                |
|               |      | Con   | nmunication Port 4 Interface (12 pins)                |
| C4D(7-0)      | 8    | 1/0   | Communication port 4 data bus                         |
| CREQ4         | 1    | 1/0   | Communication port 4 token request signal             |
| CACK4         | 1    | 1/0   | Communication port 4 token request acknowledge signal |
| CSTRB4        | 1    | 1/0   | Communication port 4 data strobe signal               |
| CRDY4         | 1    | 1/0   | Communication port 4 data ready signal                |
|               |      | Con   | nmunication Port 5 Interface (12 pins)                |
| C5D(7-0)      | 8    | 1/0   | Communication port 5 data bus                         |
| CREQ5         | 1    | 1/0   | Communication port 5 token request signal             |
| CACK5         | 1    | 1/0   | Communication port 5 token request acknowledge signal |
| CSTRB5        | 1    | 1/0   | Communication port 5 data strobe signal               |
| CRDY5         | 1    | 1/0   | Communication port 5 data ready signal                |

#### Table 14–3. TMS320C40 Signal Descriptions (Continued)

 $\ddagger$  I = input, O = output, Z = three-stated (high impedance).

| Signal        | Pins | Type‡                                 | Description                                                 |  |  |  |  |
|---------------|------|---------------------------------------|-------------------------------------------------------------|--|--|--|--|
| · ·           | In   | terrupts                              | I/O Flags, Reset, Timer (12 pins)                           |  |  |  |  |
| IIOF(3 – 0)   | 4    | I/O                                   | Interrupt and I/O flags                                     |  |  |  |  |
| NMI           | 1    | l                                     | Nonmaskable interrupt. It is sensitive to a low-going edge. |  |  |  |  |
| IACK          | 1    | 0                                     | Interrupt acknowledge                                       |  |  |  |  |
| RESET         | 1    | I                                     | Reset signal                                                |  |  |  |  |
| RESETLOC(1,0) | 2    | ł                                     | Reset-vector location pins                                  |  |  |  |  |
| ROMEN         | 1    | 1                                     | On-chip ROM enable (0 = disable, 1 = enable)                |  |  |  |  |
| TCLK0         | 1    | I/O                                   | Timer 0 pin                                                 |  |  |  |  |
| TCLK1         | 1    | I/O                                   | Timer 1 pin                                                 |  |  |  |  |
|               |      |                                       | Clock and Power (4 pins)                                    |  |  |  |  |
| X1            | 1    | 0                                     | Crystal pin                                                 |  |  |  |  |
| X2/CLKIN      | 1    | 1                                     | Crystal/oscillator pin                                      |  |  |  |  |
| H1            | 1    | 0                                     | H1 clock                                                    |  |  |  |  |
| НЗ            | 1    | 0                                     | H3 clock                                                    |  |  |  |  |
|               |      | · · · · · · · · · · · · · · · · · · · | Emulation (7 pins)                                          |  |  |  |  |
| ТСК           | 1    | 1                                     | JTAG test port clock                                        |  |  |  |  |
| TDO           | 1    | O/T                                   | JTAG test port data out                                     |  |  |  |  |
| TDI           | 1    | l I                                   | JTAG test port data in                                      |  |  |  |  |
| TMS           | 1    | 1                                     | JTAG test port mode select                                  |  |  |  |  |
| TRST          | 1    | 1                                     | JTAG test port reset                                        |  |  |  |  |
| EMU0          | 1    | 1/0                                   | Emulation pin 0                                             |  |  |  |  |
| EMU1          | 1    | 1/0                                   | Emulation pin 1                                             |  |  |  |  |

Table 14–3. TMS320C40 Signal Descriptions (Continued)

<sup>‡</sup> I = input, O = output, Z = three-stated (high impedance).





#### **14.4 Electrical Specifications**

| Table 14-4. | Absolute Maximum Ratings Over Specified Temperature Range |  |
|-------------|-----------------------------------------------------------|--|
|             |                                                           |  |

| Condition/Characteristic              | Range             |
|---------------------------------------|-------------------|
| Supply voltage range, V <sub>DD</sub> | – 0.3 V to 7 V    |
| Input voltage range                   | – 0.3 V to 7 V    |
| Output voltage range                  | – 0.3V to 7 V     |
| Operating case temperature range      | 0 ° C to 85 °C    |
| Storage temperature range             | – 55 °C to 150 °C |

Notes: 1) Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only; functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" table of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

2) All voltage values are with respect to V<sub>SS</sub>.

#### Table 14–5. Recommended Operating Conditions

|                 | Parameter                                  | Min  | Nom | Max                   | Unit |
|-----------------|--------------------------------------------|------|-----|-----------------------|------|
| V <sub>DD</sub> | Supply voltages (DDV <sub>DD</sub> , etc.) | 4.75 | 5   | 5.25                  | V    |
| VSS             | Supply voltages (CVSS, etc.)               |      | 0   |                       | V    |
| VIH             | High-level input voltage                   | 2    |     | V <sub>DD</sub> + 0.3 | V    |
| VIL             | Low-level input voltage                    | -0.3 |     | 0.8                   | V    |
| ЮН              | High-level output current                  |      |     | -300                  | μA   |
| IOL             | Low-level output current                   |      |     | 2                     | mA   |
| T.              | Operating free-air temperature             | 0    |     | 85                    | °C   |
| Ѵтн             | CLKIN high-level input voltage for CLKIN   | 2.6  |     | V <sub>DD</sub> + 0.3 | V    |

Note: Note 1 for Table 14–4 also applies to this table. All inputs and output voltages are TTL compatible.

|      | Electrical Characteristic                                         | Min  | Nom(Note 1) | Max | Unit |    |
|------|-------------------------------------------------------------------|------|-------------|-----|------|----|
| VOH  | High-level output voltage ( $V_{DD} = Min, I_{OH} = Max$ )        | 2.4  | 3           |     | V    | 14 |
| VOL  | Low-level output voltage ( $V_{DD}$ = Min, $I_{OL}$ = Max)        |      | 0.3         | 0.6 | v    | 1  |
| ΙZ   | Three-state current (VDD = Max)                                   | 20   | <u></u>     | 20  | μА   | 1  |
| lj – | Input current ( $V_I = V_{SS}$ to $V_{DD}$ )                      | -10  |             | 10  | μA   | 1  |
| İΡ   | Input current ( Inputs with internal pull-ups) (See<br>Note 4)    | -400 |             | 20  | μΑ   | 1  |
| ICC  | Supply current ( $T_A = 25 \text{ °C}, V_{DD} = Max, f_X = Max$ ) |      | 350         | 850 | mA   | 1  |
| CI   | Input capacitance                                                 |      |             | 15  | pF   | 1  |
| Со   | Output capacitance                                                |      |             | 15  | pF   | 1  |

Table 14-6. Electrical Characteristics Over Specified Free-Air Temperature Range

**Notes:** 1) All nominal values are at  $V_{DD} = 5$  V,  $T_A = 25$  °C. 2)  $f_x$  is the input clock frequency. The maximum value is 50 MHz.

- 3) All input and output voltage levels are TTL compatible.
- 4) Pins with internal pull-up devices: TDI, TCK.
- 5) Pin with internal pull-down device: TRST.





 $I_{OI} = 2.0 \text{ mA} \text{ (all outputs)}$ Where:  $I_{OH} = 300 \ \mu A$  (all outputs)  $V_{Load} = 2.15 V$  $C_T = 80 \text{ pF}$  typical load circuit capacitance.

#### **14.5 Signal Transition Levels**

TTL-level outputs are driven to a minimum logic-high level of 2.4 volts and to a maximum logic-low level of 0.6 volt. Output transition times are specified as follows.

For a high-to-low transition on a TTL-compatible output signal, the level at which the output is said to be no longer high is 2.0 volts, and the level at which the output is said to be low is 1.0 volt. For a low-to-high transition, the level at which the output is said to be no longer low is 1.0 volt, and the level at which the output is said to be high is 2.0 volts.





Transition times for TTL-compatible inputs are specified as follows. For a high-to-low transition on an input signal, the level at which the input is said to be no longer high is 2.0 volts, and the level at which the input is said to be low is 0.8 volt. For a low-to-high transition on an input signal, the level at which the input is said to be no longer low is 0.8 volt, and the level at which the input is said to be no longer low is 0.8 volt, and the level at which the input is said to be no longer low is 0.8 volt, and the level at which the input is said to be no longer low is 0.8 volt, and the level at which the input is said to be no longer low is 0.8 volt, and the level at which the input is said to be high is 2.0 volts.





### 14.6 Timing



- Timing parameter table on next page -





--- Timing parameter table on next page ----

١

|       |                     |                                             | TMS  | 320C40 | TMS320 | C40-40 |      |  |
|-------|---------------------|---------------------------------------------|------|--------|--------|--------|------|--|
| No.   | Name                | Description                                 | Min  | Max    | Min    | Max    | Unit |  |
| (1)   | tf(CI)              | CLKIN fall time                             |      | 4      |        | 4      | ns   |  |
| (2)   | <sup>t</sup> w(CIL) | CLKIN low pulse duration $t_{c(CI)} = min$  | 7    |        | 8      |        | ns   |  |
| (3)   | <sup>t</sup> w(CIH) | CLKIN high pulse duration $t_{C(CI)} = min$ | 7    |        | 8      |        | ns   |  |
| (4)   | tr(CI)              | CLKIN rise time                             |      | 4      |        | 4      | ns   |  |
| (5)   | <sup>t</sup> c(CI)  | CLKIN cycle time                            | 20   |        | 25     |        | ns   |  |
| (6)   | t <sub>f(H)</sub>   | H1/H3 fall time                             |      | 3      |        | 3      | ns   |  |
| (7)   | <sup>t</sup> w(HL)  | H1/H3 low pulse duration                    | P-6† |        | P-61   |        | ns   |  |
| (8)   | tw(HH)              | H1/H3 high pulse duration                   | P-7  |        | P_7†   |        | ns   |  |
| (9)   | t <sub>r(H)</sub>   | H1/H3 rise time                             |      | 4      |        | 4      | ns   |  |
| (9.1) | td(HL-HH)           | Delay from H1(H3) low to<br>H3(H1) high     | 0    | 5      | 0      | 5      | ns   |  |
| (10)  | <sup>t</sup> c(H)   | H1/H3 cycle time                            | 40   | 485    | 50     | 500    | ns   |  |

Table 14–7. Timing Parameters for CLKIN, H1, H3 (Figure 14–6 and Figure 14–7)

 $T P = t_c(CI)$  as shown in Figure 14–6.

Figure 14–8. Memory ( $(\overline{L})STRB = 0$ ) Read



Table 14–8. Timing Parameters for a Memory (L)STRB = 0) Read/Write

|       | -                         |                                    | TMS320C40 |     | TMS320C40-40 |     |      |
|-------|---------------------------|------------------------------------|-----------|-----|--------------|-----|------|
| No.   | Name                      | Description                        | Min       | Max | Min          | Max | Unit |
| (1)   | <sup>t</sup> d(H1L–(L)SL) | H1 low to (L)STRB low              |           | 7   |              | 7   | ns   |
| (2)   | td(H1L-(L)SH)             | H1 low to (L)STRB high             |           | -7  |              | 7   | ns   |
| (3)   | <sup>t</sup> d(H1H–RWL)   | H1 high to (L)R/W low              |           | 7   |              | 7   | ns   |
| (4)   | <sup>t</sup> d(H1L–A)     | H1 low to (L)A valid               |           | 7   |              | 11  | ns   |
| (5)   | t <sub>su(D)R</sub>       | (L)D valid before H1 low (read)    | 12        |     |              | 13  | ns   |
| (6)   | th((L)D)R                 | (L)D hold time after H1 low (read) | 0         |     | 0            |     | ns   |
| (7)   | <sup>t</sup> su(L)(RDY)   | (L)RDY valid before H1 low         | 20        |     | 20           |     | ns   |
| (8)   | <sup>t</sup> h((L)RDY)    | (L)RDY hold time after H1 low      | 0         |     | 0            |     | ns   |
| (8.1) | td(H1L-S)                 | H! low to (L)STAT(3-0) valid       |           | 7   |              | 11  | ns   |

**Note:** For consecutive reads, (L)R/ $\overline{W}$  stays high and  $\overline{(L)STRB}$  stays low.

--- Table continued on next page ----



Table 14–8. Timing Parameters for a Memory ( $(\overline{L})STRB = 0$ ) Read/Write (Concluded)

|      |                            | TMS320C40 TMS320C40-40                                      |     | TMS320C40 |     | C40-40 |      |
|------|----------------------------|-------------------------------------------------------------|-----|-----------|-----|--------|------|
| No.  | Name                       | Description                                                 | Min | Max       | Min | Max    | Unit |
| (9)  | <sup>t</sup> d(H1H–(L)RWH) | H1 high to (L)R/W high (write)                              |     | 7         |     | 7      | ns   |
| (10) | <sup>t</sup> v((L)D)W      | (L)D valid after H1 low (write)                             |     | 16        |     | 16     | ns   |
| (11) | <sup>t</sup> h((L)D)W      | (L)D hold time after H1 high<br>(write)                     | 0   |           | 0   |        | ns   |
| (12) | <sup>t</sup> d(H1H–A)      | H1 high to A valid on back-to-<br>back write cycles (write) |     | 13        |     | 15     | ns   |

Note: The delay for (L)RDY to become active after the address is valid should be a maximum of 13 ns for the 'C40 and 19 ns for the 'C40-40.





| Table 41 A  |      | 15      |      |        | Time   |
|-------------|------|---------|------|--------|--------|
| Table 14–9. | 11-1 | AE, and | (rr  | -nanie | iimina |
| 10010 11 0. |      | ·       | ~~ ~ |        |        |

|      |                           |                                                                                   | TMS3 | 20C40 | TMS320 | C40-40 |      |
|------|---------------------------|-----------------------------------------------------------------------------------|------|-------|--------|--------|------|
| No.  | Name                      | Description                                                                       | Min  | Max   | Min    | Max    | Unit |
| (1)  | <sup>t</sup> d(DEH–DZ)    | Time (L)DE high to (L)D(0–31) HI–Z                                                | 0    | 15    | 0      | 15     | ns   |
| (2)  | <sup>t</sup> d(DEL–DV)    | Time $\overline{(L)DE}$ low to $(L)D(0-31)$ valid                                 | 0    | 15    | 0      | 15     | ns   |
| (3)  | <sup>t</sup> d(AEH–AZ)    | Time (L)AE high to (L)A(0-31) HI-Z                                                | 0    | 15    | 0      | 15     | ns   |
| (4)  | <sup>t</sup> d(AEL–AV)    | Time (L)AE low to (L)A(0-31) valid                                                | 0    | 15    | 0      | 15     | ns   |
| (5)  | <sup>t</sup> d(CEH–RWZ)   | Time $\overline{(L)CE}$ high to $(L)R/\overline{W}(0,1)$ HI–Z                     | 0    | 15    | 0      | 15     | ns   |
| (6)  | <sup>t</sup> d(CEL–RWV)   | Time $\overline{(L)CE}$ low to $(L)R/\overline{W}(0,1)$ valid                     | 0    | 15    | 0      | 15     | ns   |
| (7)  | <sup>t</sup> d(CEH–STRBZ) | Time $\overline{(L)CE}$ high to $(L)\overline{STRB}(0,1)$ in high impedance state | 0    | 15    | 0      | 15     | ns   |
| (8)  | <sup>t</sup> d(CEL–STRBV) | Time (L)CE low to (L)STRB(0,1) valid                                              | 0    | 15    | 0      | 15     | ns   |
| (9)  | <sup>t</sup> d(CEH–PAGEZ) | Time $\overline{(L)CE}$ high to (L)PAGE(0,1) in high impedance state              | 0    | 15    | 0      | 15     | ns   |
| (10) | <sup>t</sup> d(CEL-PAGEV) | Time (L)CE low to (L)PAGE(0,1) valid                                              | 0    | 15    | 0      | 15     | ns   |





 Table 14–10.
 Timing Parameters for (L)LOCK When Executing LDFI or LDII

|   |     |                           | TMS320C40             |     | TMS320C40 |     | C40-40 |      |
|---|-----|---------------------------|-----------------------|-----|-----------|-----|--------|------|
| N | lo. | Name                      | Description           | Min | Max       | Min | Max    | Unit |
| ( | 1)  | <sup>t</sup> d(H1L–LOCKL) | H1 low to (L)LOCK low |     | 7         |     | 11     | ns   |



Figure 14–12. Timing for (L)LOCK When Executing a STFI or STII

Table 14–11. Timing Parameters for (L)LOCK When Executing STFI or STII

|     |               |                        | TMS320C40 |     | TMS320C40 TMS320C40-40 |     | C40-40 |  |
|-----|---------------|------------------------|-----------|-----|------------------------|-----|--------|--|
| No. | Name          | Description            | Min       | Max | Min                    | Max | Unit   |  |
| (1) | td(H1L-LOCKH) | H1 low to (L)LOCK high |           | 7   |                        | 11  | ns     |  |





Table 14–12. Timing Parameters for (L)LOCK When Executing SIGI

|     |               |                        | TMS320C40 |     | TMS320 | C40-40 |      |
|-----|---------------|------------------------|-----------|-----|--------|--------|------|
| No. | Name          | Description            | Min       | Max | Min    | Max    | Unit |
| (1) | td(H1L-LOCKL) | H1 low to (L)LOCK high |           | 7   |        | 11     | ns   |
| (2) | td(H1L-LOCKH) | H1 low to (L)LOCK high |           | 7   |        | 11     |      |

TMS320C4x Signal Descriptions and Electrical Characteristics



Figure 14–14. Timing Parameters for (L)PAGE(0,1)

| Table 14–13. | Timing Parameters for (L)PAGE(0,1) During Memory Accesses to a Different Page |
|--------------|-------------------------------------------------------------------------------|
|              |                                                                               |

|     |                        |                                                     | TMS3 | 20C40 | TMS320 | C40-40 |      |
|-----|------------------------|-----------------------------------------------------|------|-------|--------|--------|------|
| No. | Name                   | Description                                         | Min  | Max   | Min    | Max    | Unit |
| (1) | <sup>t</sup> d(H1L–PH) | H1 low to PAGE high for access to<br>different page | 0    | 7     |        | 11     | ns   |
| (2) | <sup>t</sup> d(H1L-PL) | H1 low to PAGE low for access to<br>different page  | 0    | 7     |        | 11     | ns   |



Figure 14–15. Timing for Loading IIF Register (IIOF Pins) When Configured as an Output Pin

| Table 14–14. | Timing Parameters for Loading IIF Register When Configured as an Output Pin |
|--------------|-----------------------------------------------------------------------------|
|              |                                                                             |

|     |                        |                      | TMS3 | 20C40 | TMS320 |     |      |
|-----|------------------------|----------------------|------|-------|--------|-----|------|
| No. | Name                   | Description          | Min  | Max   | Min    | Max | Unit |
| (1) | <sup>t</sup> v(H1L–IF) | H1 low to IIOF valid |      | 11    |        | 12  | ns   |





Table 14–15. Timing Parameters of IIOF Changing From Output to Input Mode

|     |                          |                          | TMS320C40 |     | TMS320C40-40 |     |      |
|-----|--------------------------|--------------------------|-----------|-----|--------------|-----|------|
| No. | Name                     | Description              | Min       | Max | Min          | Max | Unit |
| (1) | <sup>t</sup> h(H1L–IF01) | IIOF hold after H1 low   |           | 11  |              | 12  | ns   |
| (2) | <sup>t</sup> su(IF)      | IIOF setup before H1 low | 8         |     | 8            |     | ns   |
| (3) | <sup>t</sup> h(IF)       | IIOF hold after H1 low   | 0         |     | 0            |     | ns   |





Table 14–16. Timing Parameters of IIOF Changing from Input to Output Mode

|     |                          |                                               | TMS320C40 TMS320C40-40 |     |     |     |      |
|-----|--------------------------|-----------------------------------------------|------------------------|-----|-----|-----|------|
| No. | Name                     | Description                                   | Min                    | Max | Min | Max | Unit |
| (1) | <sup>t</sup> d(H1L–XFIO) | H1 low to IIOF switching from input to output | ,                      | 16  |     | 16  | ns   |



- 2) L(A) includes A(30 0).
- 3) Control signals LSTRB0, LSTRB1, STRB0, STRB1, (L)STAT(3 0), (L)LOCK, (L)R/W0, and (L)R/W1 go high while (L)PAGE0, and (L)PAGE1 go low.
- 4) Asynchronously reset signals that go into high impedance after RESET goes low include TCLK0, TCLK1, IIOF(3-0), and the communication port control signals CREQx, CACKy, CSTRBy, and CRDYx (where x = 0, 1, or 2, and y = 3, 4, or 5). (At reset, ports 0, 1, and 2 become outputs, and ports 3, 4, and 5 become inputs.).
- 5) Asynchronously reset signals that go to a high logic level after RESET goes low include CREQy, CACKx, CSTRBx, and CRDYy (where x = 0, 1, or 2, and y = 3, 4, or 5).
- 6) RESET is an asynchronous input and can be asserted at any point during a clock cycle. If the specified timings are met, the exact sequence shown will occur: otherwise, an additional delay of one clock cycle may occur.

14-27

|       |                                 |                                                                       | TMS32 | 20C40 | TMS320 | C40-40    |      |
|-------|---------------------------------|-----------------------------------------------------------------------|-------|-------|--------|-----------|------|
| No.   | Name                            | Description                                                           | Min   | Max   | Min    | Max       | Unit |
| (1)   | <sup>t</sup> su(RESET)          | Setup for RESET before<br>CLKIN low                                   | 8     | Pt    | 8      | Pt        | ns   |
| (2.1) | td(CLKINH-H1H)                  | CLKIN high to H1 high                                                 | 5     | 12    | 5      | 13        | ns   |
| (2.2) | td(CLKINH-H1L)                  | CLKIN high to H1 low                                                  | 5     | 12    | 5      | 13        | ns   |
| (3)   | <sup>t</sup> su(RESETH-H1L)     | Setup for RESET high<br>before H1 low and after<br>10 H1 clock cycles | 8     |       | 8      | - <u></u> | ns   |
| (4.1) | td(CLKINH-H3L)                  | CLKIN high to H3 low                                                  | 5     | 12    | 5      | 13        | ns   |
| (4.2) | td(CLKINH-H3H)                  | CLKIN high to H3 high                                                 | 5     | 12    | 5      | 13        | ns   |
| (5)   | <sup>t</sup> dis(H1H-XD)        | H1 high to (L)D high-im-<br>pedance                                   |       | 15    |        | 15        | ns   |
| (6)   | <sup>t</sup> dis(H3H-XA)        | H3 high to (L)A<br>high-impedance                                     |       | 15    |        | 15        | ns   |
| (7)   | <sup>t</sup> d(H3H-CONTROLH)    | H3 high to control signals high (low for (L)Page)                     |       | 7     |        | 7         | ns   |
| (8)   | <sup>t</sup> d(H1H-IACKH)       | H1 high to IACK high                                                  |       | 7     |        | 7         | ns   |
| (9)   | <sup>t</sup> dis(RESETL-ASYNCH) | RESET low to asynchron-<br>ously reset signals high-<br>impedance     |       | 15    |        | 15        | ns   |
| (10)  | <sup>t</sup> d(RESETL-COMMH)    | RESET low to asynchron-<br>ously reset signals high                   |       | 10    |        | 10        | ns   |

Table 14–17. Timing Parameters for RESET (Figure 14–18)

<sup>†</sup>  $P = t_{c(cl)}$ , the CLKIN period as shown in Figure 14–6.



Figure 14–19. IOOF(3 – 0) Interrupt Response Timing

| Table 14–18. Tir | ning Parameters fo | r 100F(3 | 0) |
|------------------|--------------------|----------|----|
|------------------|--------------------|----------|----|

|     |                                      |                                                       | TMS320C40 |      | TMS320C40-40 |     |      |     |      |
|-----|--------------------------------------|-------------------------------------------------------|-----------|------|--------------|-----|------|-----|------|
| No. | Name                                 | Description                                           | Min       | Тур  | Max          | Min | Тур  | Max | Unit |
| (1) | t <sub>su(IOOF)</sub>                | IOOF(3 — 0) setup before H1<br>low                    | 11        |      |              | 12  |      |     | ns   |
| (2) | <sup>t</sup> w(IOOF)<br>(See Note 1) | Interrupt pulse width to guarantee one interrupt seen | Р         | 1.5P | <2P          | Р   | 1.5P | <2P | ns   |

- **Notes:** 1) Interrupt pulse width must be at least 1 P wide (P = one H1 period) to guarantee it will be seen. It must be less than 2 P wide to guarantee it will be responded to only once. Recommended pulse width is 1.5 P.
  - 2) IOOF is an asynchronous input and can be asserted at any point during a clock cycle. If the specified timings are met, the exact sequence shown will occur; otherwise, an additional delay of one clock cycle may occur.
  - 3) The 'C40 can accept an interrupt from the same source every two H1 clock cycles.
  - 4) For edge-triggered interrupts, only timing number (1) applies.





Table 14–19. Timing Parameters for IACK

|     |                           |                                                                       | TMS3 | MS320C40 TMS320C40-40 |     |     |      |
|-----|---------------------------|-----------------------------------------------------------------------|------|-----------------------|-----|-----|------|
| No. | Name                      | Description                                                           | Min  | Max                   | Min | Max | Unit |
| (1) | td(H1H-IACKL)             | H1 high to IACK low                                                   |      | 7                     |     | 7   | ns   |
| (2) | <sup>t</sup> d(H1H–IACKH) | H1 high to IACK high during first cycle of IACK instruction data read |      | 7                     |     | 7   | ns   |

**Note:** The IACK output is active for the entire duration of the bus cycle and is therefore extended if the bus cycle utilizes wait states.





Note: For correct operation during token exchange, the two communicating 'C40s must have CLKIN frequencies within a factor of 2 of each other (in other words, at most, one of the 'C40s can be twice as fast as the other).

Table 14–20. Communication-Port Word-Transfer Cycle Timing

|     |                        |                                                               | TMS3      | MS320C40‡ TMS320 |           | )C40-40‡         |      |
|-----|------------------------|---------------------------------------------------------------|-----------|------------------|-----------|------------------|------|
| No. | Name                   | Description                                                   | Min†      | Max†             | Min†      | Max <sup>†</sup> | Unit |
| (1) | tword                  | Word transfer period<br>(4 bytes = 1 word)                    | 1.5P + 46 | 2.5P + 202       | 1.5P + 46 | 2.5P + 202       | ns   |
| (2) | <sup>t</sup> d(RL–SL)W | CRDY low to CSTRB low<br>between back-to-back write<br>cycles | 1.5P + 7  | 2.5P + 28        | 1.5P + 7  | 2.5P + 28        | ns   |

† P is the duration of the H1 clock period with a minimum value of 40 ns ( $P \ge 40$  ns).

<sup>‡</sup> For these timing values, it is assumed that the 'C40 receiving data is ready to receive data.

14-31

#### Timing



Figure 14–22. Communication Port Byte Timing (Write and Read)

Table 14–21. Communication Port Byte Timing (Write and Read)

|     |                        |                                                     | TMS3 | 20C40 | TMS320C40-40 |     |      |
|-----|------------------------|-----------------------------------------------------|------|-------|--------------|-----|------|
| No. | Name                   | Description                                         | Min  | Max   | Min          | Max | Unit |
| (1) | <sup>t</sup> su(CD)W   | Data valid before CSTRB (write)                     | 2    |       | 2            |     | ns   |
| (2) | <sup>t</sup> d(RL–SH)W | CRDY low to CSTRB high (write)                      | 3    | 15    | 3            | 15  | ns   |
| (3) | <sup>t</sup> h(CD)W    | CD hold after CRDY low (write)                      | 2    |       | 2            |     | ns   |
| (4) | <sup>t</sup> d(RH–SL)W | CRDY high to CSTRB low for subsequent bytes (write) | 3    | 15    | 3            | 15  | ns   |
| (5) | <sup>t</sup> BYTE      | Byte period                                         | 12   | 54    | 12           | 54  | ns   |
| (6) | <sup>t</sup> d(SL–RL)R | CSTRB low to CRDY low (read)                        | 3    | 12    | 3            | 12  | ns   |
| (7) | <sup>t</sup> su(CD)R   | CD valid after CSTRB (read)                         | 0    |       | 0            |     | ns   |
| (8) | <sup>t</sup> h(CD)R    | CD held valid after CRDY low (read)                 | 0    |       | 0            |     | ns   |
| (9) | <sup>t</sup> d(SH–RH)R | CSTRB high to CRDY high (read)                      | 3    | 12    | 3            | 12  | ns   |



Figure 14–23. Communication Token Transfer Sequence From an Input to an Output Port

**Note:** Before the token exchange, <u>CREQ</u> and <u>CRDY</u> are output signals asserted by the 'C40 that is receiving data. <u>CACK</u>, <u>CSTRB</u>, and CD(7–0) are input signals asserted by the device sending data to the 'C40; these are asynchronous with respect to the H1 clock of the receiving 'C40. After token exchange, <u>CACK</u>, <u>CSTRB</u>, and CD(7–0) become output signals, and <u>CREQ</u> and <u>CRDY</u> become inputs.

- Timing parameter table on next page -

| Table 14–22. | Communication Token Transfer Sequence From an Input to an Output Port |  |
|--------------|-----------------------------------------------------------------------|--|
|              | (Figure 14–23)                                                        |  |

|       |                          |                                                                                       | TMS320C40 |                  | TMS320C40-40 |                  |      |
|-------|--------------------------|---------------------------------------------------------------------------------------|-----------|------------------|--------------|------------------|------|
| No.   | Name                     | Description                                                                           | Min†      | Max <sup>†</sup> | Min†         | Max <sup>†</sup> | Unit |
| (1)†  | <sup>t</sup> d(AL–SO)T   | CACK low to CSTRB<br>change from input to a high-<br>level output                     | 0.5P+ 6   | 1.5P+22          | 0.5P+ 6      | 1.5P+ 22         | ns   |
| (2)†  | <sup>t</sup> d(AL–RQH)T  | CACK low to start of CREQ<br>going high for token request<br>acknowledge              | P + 5     | 2P + 20          | P + 5        | 2P + 20          | ns   |
| (3)   | <sup>t</sup> d(RQH–RQI)T | Start of CREQ going high to CREQ change from output to an input                       | 0.5P – 5  | 0.5P+13          | 0.5P – 5     | 0.5P+ 13         | ns   |
| (4)   | <sup>t</sup> d(RQH–AO)T  | Start of CREQ going high to<br>CACK change from an input<br>to an output level high   | 0.5P – 5  | 0.5P+13          | 0.5P – 5     | 0.5P+13          | ns   |
| (4.1) | <sup>t</sup> d(RQH–DO)T  | Start of CREQ going high to<br>CD(7–0) change from inputs<br>driven to outputs driven | 0.5P – 5  | 0.5P+13          | 0.5P – 5     | 0.5P+13          | ns   |
| (4.2) | <sup>t</sup> d(RQH–RI)T  | Start of CREQ going high to<br>CRDY change from an out-<br>put to an input            | 0.5P – 5  | 0.5P+13          | 0.5P – 5     | 0.5P+13          | ns   |
| (5)   | <sup>t</sup> d(RQH–SL)T  | Start of CREQ going high to CSTRB low for start of word transfer out                  | 1.5P – 8  | 1.5P+ 9          | 0.5P – 8     | 1.5P+ 9          | ns   |
| (6)   | <sup>t</sup> d(RL–SL)T   | CRDY low at end of word<br>input to CSTRB low for word<br>output                      | 3.5P+12   | 5.5P+48          | 3.5P+12      | 5.5P+ 48         | ns   |

<sup>†</sup> These timing parameters result from synchronizer delays and are referenced from the falling edge of H1. The inputs (that cause the output-signal pins to change values) are sampled on H1 falling. The minimum delay occurs when the input condition occurs just before H1 falling, and the maximum delay occurs when the input condition occurs just after H1 falling.



Figure 14–24. Communication Token Transfer Sequence From an Output to an Input Port

**Note:** Before the token exchange, CACK, CSTRB, and CD(7–0) are asserted by the 'C40 sending data. CREQ and CRDY are input signals asserted by the 'C40 receiving data and are asynchronous with respect to the H1 clock of the sending 'C40. After token exchange, CREQ and CRDY become outputs, and CSTRB, CACK, and CD(7–0) become inputs.

- Timing parameter table on next page -

14

| Table 14–23. | Communication Token Transfer Sequence From an Output to an Input Port |  |
|--------------|-----------------------------------------------------------------------|--|
|              | (Figure 14–24)                                                        |  |

ē.

| <b></b> |                          |                                                                            | TMS3     | 20C40    | TMS320   | )C40-40  |      |
|---------|--------------------------|----------------------------------------------------------------------------|----------|----------|----------|----------|------|
| No.     | Name                     | Description                                                                | Min      | Max      | Min      | Max      | Unit |
| (1)†    | <sup>t</sup> d(RQL–AL)T  | CREQ low to start of CACK<br>going low for token request<br>acknowledge    | P+5      | 2P + 22  | P + 5    | 2P + 22  | ns   |
| (2)†    | <sup>t</sup> d(RĿ–AL)T   | CRDY low at end of word<br>transfer out to start of CACK<br>going low      | P+6      | 2P + 27  | P+6      | 2P + 27  | ns   |
| (3)     | <sup>t</sup> d(ALCD)I    | Start of CACK going low to<br>CD(7–0) change from<br>outputs to inputs     | 0.5P – 8 | 0.5P + 8 | 0.5P – 8 | 0.5P + 8 | ns   |
| (4)     | <sup>t</sup> d(AL–RO)T   | Start of CACK going low to CRDY change from an input to output, high level | 0.5P – 8 | 0.5P – 8 | 0.5P – 8 | 0.5P – 8 | ns   |
| (5)†    | <sup>t</sup> d(RQH–AQ)T  | CREQ high to CREQ<br>change from an input to<br>output, high level         | 4        | 22       | 4        | 22       | ns   |
| (6)†    | <sup>t</sup> d(RQH–AI)T  | CREQ high to CACK change from output to an input                           | 4        | 22       | 4        | 22       | ns   |
| (7)†    | <sup>t</sup> d(RQH–SI)T  | CREQ high to CSTRB<br>change from output to an<br>input                    | 4        | 22       | 4        | 22       | ns   |
| (8)†    | <sup>t</sup> d(RQH–RQL)T | CREQ high to CREQ low for the next token request                           | P – 4    | 2P + 8   | P – 4    | 2P + 8   | ns   |

<sup>†</sup> These timing parameters result from synchronizer delays and are referenced from the falling edge of H1. The inputs (that cause the output-signal pins to change values) are sampled on H1 falling. The minimum delay occurs when the input condition occurs just before H1 falling, and the maximum delay occurs when the input condition occurs just after H1 falling.

Figure 14–25. Timer Pin Timings



|     |                         |                          | TMS3 | 20C40 | TMS320 | C40-40 |      |
|-----|-------------------------|--------------------------|------|-------|--------|--------|------|
| No. | Name                    | Description              | Min  | Max   | Min    | Max    | Unit |
| (1) | tsu(TCLKH1L)            | TCLK setup before H1 low | 9    |       | 10     |        | ns   |
| (2) | <sup>t</sup> h(TCLKH1L) | TCLK hold after H1 low   | 0    |       | 0      |        | ns   |
| (3) | td(TCLKH1H)             | TCLK valid after H1 high |      | 7     |        | 7      | ns   |

Note: Period and polarity of valid logic level are specified by contents of internal control registers.

### Timing





| Table 14–25. | Timing | Parameters for | JTAG | Emulation |
|--------------|--------|----------------|------|-----------|
|--------------|--------|----------------|------|-----------|

|     |               |                            | TMS3 | 20C40 | TMS320 | C40-40 |      |
|-----|---------------|----------------------------|------|-------|--------|--------|------|
| No. | Name          | Description                | Min  | Max   | Min    | Max    | Unit |
| (1) | tsu(TMS-TCKH) | TMS/TDI setup to TCK high  | 10   |       | 10     |        | ns   |
| (2) | th(TMS/TDI)   | TMS/TDI hold from TCK high | 5    |       | 5      |        | ns   |
| (3) | td(TCKL-TDOV) | TCK low to TDO valid       | 0    | 15    | 0      | 15     | ns   |

## **Appendix A**

# TMS320C4x Sockets

This appendix describes sockets available to accept the TMS320C4x pin grid array (PGA). Both sockets covered in this appendix feature zero insertion force (ZIF):

a tool-activated ZIF socket (TAZ)

a handle-activated ZIF socket (HAZ).

The sockets described herein are manufactured by AMP Incorporated<sup>®</sup>.

## A.1 Tool-Activated ZIF PGA Socket (TAZ)

Figure A–1. Tool-Activated ZIF Socket



This socket requires AMP<sup>™</sup> actuator tool: 354234–1

325

**Description:** 

| part number: | 382533–9 |
|--------------|----------|
|              |          |

pin positions:

soldertail length:

0.170 in. for PC boards 0.125 in. thick (other tail lengths available)

Features:

Slightly larger than PGA device

easy package loading because of large funnel entry

**D** zero insertion force

contact wiping action during insertion ensures clean contact points

- spring-loaded cover ensures proper loading
- can be used with robotic insertion and removal

its horizontal socket forces (vs. vertical) prevent damage to device



Description:

| •                   |                                                                                                         |                               |  |  |  |
|---------------------|---------------------------------------------------------------------------------------------------------|-------------------------------|--|--|--|
| AMP part number:    | 382320-                                                                                                 | 9                             |  |  |  |
| pin positions:      | 325                                                                                                     |                               |  |  |  |
| solder tail length: | 0.170 in. for pc boards 0.125 in. thick (other lengths available)                                       |                               |  |  |  |
| Dimensions:         | nensions: Height: 0.350 inch maximum to dev<br>plane and 0.650 inch to top<br>handle in closed position |                               |  |  |  |
|                     | Width:                                                                                                  | 2.700 by 2.875 inches maximum |  |  |  |

Features:

- can be used for test and burn-in
- **u** spring contacts are normally closed
- easy package loading because of large funnel entry
- **D** zero insertion force
- contact wiping action during socket closing ensures clean contact points
- operating temperature is 160° C (burn-in capability)

Β

# **XDS510 Design Considerations**

The information in this document is assist you in meeting the design requirements of the XDS510 emulator. This information supports XDS510 Cable no. 2563988-001, rev B.

The TMS320C4x family supports emulation through a dedicated emulation port. The emulation port is a superset of the IEEE 1149.1 (JTAG) standard and can be accessed by the XDS510 emulator. For details on the JTAG protocol, refer to the IEEE 1149.1 specification.

This appendix contains the following sections:

| Sect | ion                                 | Page |
|------|-------------------------------------|------|
| B.1  | Header Signals                      | B-2  |
| B.2  | Bus Protocol                        | B-3  |
| B.3  | Cable Pod                           | B-4  |
| B.4  | Test Clock Generated in Test System | B-7  |
| B.5  | Processor Configuration             | B-8  |
|      | Emulation Timing Calculations       |      |

B

### **B.1 Header and Header Signals**

To perform emulation with the XDS510, your target system must have a 14-pin header (two 7-pin rows) with connections as shown in Figure B–1. Table B–1 describes the emulation signals.

Although you can use other headers, recommended parts include:

| Straight header, unshrouded    | DuPont Electronics <sup>™</sup> part num-<br>ber 67996–114 |
|--------------------------------|------------------------------------------------------------|
| Right-angle header, unshrouded | DuPont Electronics <sup>™</sup> part num-                  |

Right-angle header, unshrouded

DuPont Electronics<sup>™</sup> part number 68405–114

| Figure B–1. | 14-pin Header Signals and Header Dimensions |
|-------------|---------------------------------------------|
|             |                                             |

| TMS       | 1  | 2  | TRST         |
|-----------|----|----|--------------|
| TDI       | 3  | 4  | GND          |
| PD (+5 V) | 5  | 6  | No pin (key) |
| TCK_RET   | 9  | 10 | GND          |
| TCK       | 11 | 12 | GND          |
| EMU0      | 13 | 14 | FMU1         |
|           | 15 | 14 | Emo          |

### **Header Dimensions:**

Pin-to-pin spacing: 0.100 in. (X,Y) Pin width: 0.025 in., square post Pin length: 0.235 in., nominal

 Table B–1.
 14-Pin
 Header Signal Description

| XDS510<br>Signal | †XDS510<br>State | †Target<br>State | Description                                                                                                                                                     |
|------------------|------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TMS              | 0                | I                | JTAG test mode select                                                                                                                                           |
| TDI              | 0                | I                | JTAG test data input                                                                                                                                            |
| TDO              | l                | 0                | JTAG test data output                                                                                                                                           |
| тск              | ο                | I                | JTAG test clock. TCK is a 10–MHz clock source from the<br>emulation cable pod. This signal can be used to drive the<br>system test clock.                       |
| TRST             | 0                | l                | JTAG test reset                                                                                                                                                 |
| EMU0             | 1                | I/O              | Emulation pin 0                                                                                                                                                 |
| EMU1             | 1                | I/O              | Emulation pin 1                                                                                                                                                 |
| PD               | I                | ο                | Presence detect. Indicates that the emulation cable is con-<br>nected and that the target is powered up. PD should be tied<br>to +5 volts in the target system. |
| TCK_RET          | I                | 0                | JTAG test clock return. Test clock input to the XDS510 emulator. May be a buffered or unbuffered version of TCK.                                                |

 $\dagger$  I = input; O = output

### **B.2 Bus Protocol**

The IEEE 1149.1 specification covers the requirements for JTAG bus slave devices (such as the TMS320C4x family) and provides certain rules. Those rules are summarized as follows:

- The TMS/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 JTAG devices are daisy-chained together, the TDO of one device has approximately a half TCK cycle set up to the next device's TDI signal. This type of 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 JTAG bus master (XDS510) devices. Instead, it states that it expects a bus master to provide bus slave compatible timings. The XDS510 provides timings that meet the bus slave rules and also provides an optional timing mode that allows you to run the emulation at a much higher frequency for improved performance by avoiding the timing penalty dexcribed herein.

### **B.3** Cable Pod

Figure B–2 shows a portion of the XDS510 emulator cable pod. These are the functional features of the emulator pod:

- Signals TDO and TCK\_RET can be parallel-terminated inside the pod if required by the application. The default is that these signals are not terminated.
- Signal TCK is driven with a 74AS1034 device. Because of the high current drive (48 mA I<sub>OL</sub>/I<sub>OH</sub>), this signal can be parallel terminated. If TCK is tied to TCK\_RET, then you can use the parallel terminator in the pod.
- Signals TMS and TDI can be generated from the falling edge of TCK\_RET, according to the IEEE 1149.1 bus slave device timing rules. They can also be driven from the rising edge of TCK\_RET, which allows a higher TCK\_RET frequency. The default is to match the IEEE 1149.1 slave device timing rules. This is an emulator software option that can be selected when the emulator is invoked. In general, single-processor applications can benefit from the higher clock frequency. However, in multiprocessing applications, you may wish to use the IEEE 1149.1 bus slave timing mode to minimize emulation system timing constraints.
- Signals TMS and TDI are series terminated to reduce signal reflections.
- A 10–MHz test clock source is provided. You may also provide your own test clock for greater flexibility.

Figure B–2. Emulator Pod Interface



Figure B–3 and Table B–2 show the signal timings for the XDS510. Timing parameters are calculated from standard data sheet parts used in the cable pod. These timings are for reference only. Texas Instruments does not test or guarantee these timings.

The emulator pod uses TCK\_RET as it's clock source for internal synchronization. TCK is provided as an optional target system test clock source.

B-5





| Table B–2. | Emulator | Pod | Timing | Parameters |
|------------|----------|-----|--------|------------|
|            |          |     |        |            |

| No. | Reference                                          | Description                                       | Min | Max | Unit |
|-----|----------------------------------------------------|---------------------------------------------------|-----|-----|------|
| 1   | t <sub>TCKmin</sub><br>t <sub>TCKmax</sub>         | TCK_RET period                                    | 35  | 200 | ns   |
| 2   | <sup>t</sup> TCKhighmin                            | TCK_RET high pulse duration                       | 15  |     | ns   |
| 3   | <sup>t</sup> TCKlowmin                             | TCK_RET low pulse duration                        | 15  |     | ns   |
| 4   | <sup>t</sup> d(XTMXmin)<br><sup>t</sup> d(XTMXmax) | TMS/TDI valid from TCK_RET low (default timing)   | 6   | 20  | ns   |
| 5   | <sup>t</sup> d(XTMSmin)<br><sup>t</sup> d)XTMSmax) | TMS/TDI valid from TCK_RET high (optional timing) | 7   | 24  | ns   |
| 6   | t <sub>su(XTDOmin)</sub>                           | TDO setup time to TCK_RET high                    | 3   |     | ns   |
| 7   | thd(XTDOmin)                                       | TDO hold time from TCK_RET high                   | 12  |     | ns   |

It is extremely important to provide high-quality signals between the emulator and the target processor. If the distance between the emulation header and the processor is greater than 6 inches, the emulation signals should be buffered. Sections B.4 and B.5 illustrate typical connections between the target processor and the emulation header.

### **B.4 Test Clock Generated in Target System**

Figure 4 shows an application with the system test clock generated in the target system. In this application the TCK signal is left unconnected.





There are two benefits to having the target system generate the test clock:

- 1) You can set the test clock frequency to match your system requirements. The emulator provides only a single 10–MHz test clock.
- 2) You may have other devices in your system that require a test clock when the emulator is not connected.

### **B.5 Multiprocessor Configuration**



Figure B–5 shows a typical multiprocessor configuration. This is a daisychained configuration (TDO-TDI daisy-chained) that meets the minimum requirements of the IEEE 1149.1 specification. The emulation signals in this example are buffered to isolate the processors from the emulator and provide an adequate signal drive for the target system. One of the benefits of a JTAG test interface is that you can generally slow down the test clock to eliminate timing problems. Several key points to multiprocessor support are as follows:

- The processor TMS, TDI, TDO, and TCK should be buffered through the same physical package to better control timing skew.
- The input buffers for TMS, TDI, and TCK should have pullups to 5 volts. This will hold these signals at a known value when the emulator is not connected. A pullup of 4.7 kΩ or greater is suggested.
- Buffering EMU0 and EMU1 is optional but highly recommended to provide isolation. These are not critical signals and do not need to be buffered through the same physical package as TMS, TCK, TDI, and TDO. Unbuffered and buffered signals are shown in Figure B–6 and Figure B–7.

**No signal buffering.** In this situation, the distance between the header and the processor should be no more than 6 inches.





**Emulation signals buffered.** The distance between the emulation header and the processor is greater than 6 inches. The emulation signals — TMS, TDI, TDO, and TCK\_RET — are buffered through the same package.





The EMU0 and EMU1 signals must have pullups to 5 volts. The pullup resistor value should be chosen to provide a signal rise-time less than 10 μs. A 4.7 kΩ resistor is suggested for most applications. EMU0 – 1

are I/O pins on the 'C4x; however, they are only inputs to the XDS510. In general, these pins are used in multiprocessor systems to provide global run/stop operations.

It is extremely important to provide high quality signals, especially on the processor TCK and the emulator TCK\_RET signal. In some cases, this may require you to provide special PWB trace routing and use termination resistors to match the trace impedance. The emulator pod does provide optional internal parallel terminators on the TCK\_RET, and TDO. TMS and TDI provide fixed series termination.

## **B.6 Emulation Timing Calculations**

Following are a few examples on how to calculate the emulation timings in your system. For actual target timing parameters, see the appropriate device data sheets.

| Assumptions:                                                        | t <sub>su</sub> (TTMS)    | Target TMS/TDI setup to TCK high                            | 10 ns  |  |  |
|---------------------------------------------------------------------|---------------------------|-------------------------------------------------------------|--------|--|--|
|                                                                     | <sup>t</sup> h(TTMS)      | Target TMS/TDI hold from TCK high                           | 5 ns B |  |  |
|                                                                     | td(TTDO)                  | Target TDO delay from TCK low                               | 15 ns  |  |  |
|                                                                     | <sup>t</sup> d(bufmax)    | Target buffer delay maximum                                 | 10 ns  |  |  |
|                                                                     | <sup>t</sup> d(bufmin)    | Target buffer delay minimum                                 | 1 ns   |  |  |
|                                                                     | t( <sub>bufskew)</sub>    | Target buffer skew between two devices in the same package: |        |  |  |
|                                                                     |                           | $[t_{d(bufmax)} - t_{d(bufmin)}] \times 0.15$ 1             | .35 ns |  |  |
|                                                                     | <sup>t</sup> tckfactor    | Assume a 40/60 duty cycle clock                             | 0.4    |  |  |
| Given in Table B–2 (page B-6):                                      |                           |                                                             |        |  |  |
|                                                                     | <sup>t</sup> d(XTMSmax)   | XDS510 TMS/TDI delay from TCK_RET low, maximum              | 20 ns  |  |  |
|                                                                     | <sup>t</sup> d(XTMX)      | min XDS510 TMS/TDI delay from<br>TCK_RET low, minimum       | 6 ns   |  |  |
|                                                                     | <sup>t</sup> d(XTMSmax)   | XDS510 TMS/TDI delay from TCK_RET high, max                 | 24 ns  |  |  |
|                                                                     | <sup>t</sup> d(XTMXmin)   | XDS510 TMS/TDI delay from TCK_RET<br>high, minimum          | 7 ns   |  |  |
|                                                                     | t <sub>su</sub> (XTDOmin) | TDO setup time to XDS510 TCK_RET high                       | 3 ns   |  |  |
| There are two key timing paths to consider in the emulation design: |                           |                                                             |        |  |  |

the TCK\_RET/TMS/TDI (t<sub>prdtck\_TMS</sub>) path, and the TCK\_RET/TDO (t<sub>prdtck\_TDO</sub>) path.

In each case, the worst case path delay is calculated to determine the maximum system test clock frequency.

**Case 1:** Single processor, direct connection, TMS/TDI timed from TCK\_RET low (default timing).

| <sup>t</sup> prdtck_TMS | = [ <sup>t</sup> d(XTMSmax) + <sup>t</sup> su(TTMS)] / <sup>t</sup> tckfactor<br>= (20 ns + 10 ns) /0 .4<br>= 75 ns (13.3 MHz) |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| <sup>t</sup> prdtck_TDO | = [ <sup>t</sup> d(TTDO) + <sup>t</sup> su(XTDOmin)] / <sup>t</sup> tckfactor<br>= (15 ns + 3 ns) / 0.4<br>= 45 ns (22.2 MHz)  |

In this case, the TCK/TMS path is the limiting factor.

**Case 2**: Single processor, direct connection, TMS/TDI timed from TCK\_RET high (optional timing).

 $t_{prdtck}TMS = t_{d}(XTMSmax) + t_{su}(TTMS)$  = (24 ns + 10 ns) = 34 ns (29.4 MHz)  $t_{prdtck}TDO = [t_{d}(TTDO) + t_{su}(XTDOmin)] / t_{tckfactor}$  = (15 ns + 3 ns) / 0.4

= 45 ns (22.2 MHz)

In this case, the TCK/TDO path is the limiting factor. One other thing to consider in this case is the TMS/TDI hold time. The minimum hold time for the XDS510 cable pod is 7 ns, which meets the 5–ns hold time of the target device.

**Case 3:** Single/multiple processor, TMS/TDI buffered input; TCK\_RET/TDO buffered output, TMS/TDI timed from TCK\_RET high (optional timing).

 $t_{prdtck\_TMS} = t_{d}(XTMSmax) + t_{su}(TTMS) + 2 t_{d}(bufmax)$ = 24 ns + 10 ns + 2 (10) = 54 ns (18.5 MHz)  $t_{prdtck\_TDO} = t_{d}(TTDO) + t_{su}(XTDOmin) + t_{bufsk}ew$ 

<sup>t</sup>tckfactor

= (15 ns + 3 ns + 1.35 ns) / 0.4 = 58.4 ns (20.7 MHz)

In this case, the TCK/TMS path is the limiting factor. The hold time on TMS/ TDI is also reduced by the buffer skew (1.35 ns) but still meets the minimum device hold time. **Case 4:** Single/multiprocessor, TMS/TDI/TCK buffered input; TDO buffered output, TMS/TDI timed from TCK\_RET low (default timing).

| <sup>t</sup> prdtck_TMS | = | = <sup>t</sup> d(XTMSmax) + <sup>t</sup> su(TTMS) + <sup>t</sup> bufskew |  |               |   |                |
|-------------------------|---|--------------------------------------------------------------------------|--|---------------|---|----------------|
|                         |   | tickfactor                                                               |  |               |   |                |
|                         |   | (24 ns<br>88.4 ns                                                        |  |               | + | 1.35 ns) / 0.4 |
| <sup>t</sup> prdtck_TDO | - | td(TTDO) + tsu(XTDOmin) + td(bufmax)<br>tckfactor                        |  |               |   |                |
|                         |   | (15 ns<br>70 ns (1-                                                      |  | З ns<br>/IHz) | + | 10 ns) / 0.4   |

In this case, the TCK/TMS path is the limiting factor.

In a multiprocessor application, it is necessary to ensure that the EUM0–1 lines can go from a logic low level to a logic high level in less than 10  $\mu$ s. This can be calculated as follows (remember that t = 5 RC):

t<sub>rise</sub>

=  $5(R_{pullup} \times N_{devices} \times C_{load\_per\_device})$ =  $5(4.7 \text{ k}\Omega \times 16 \times 15 \text{ pF})$ =  $5.64 \mu \text{s}$  В



# Index

Note: Primary sources are in **boldface**.

## Α

A-law compression, expansion, 12-46 adaptive filters, 12-58 ADDC instruction, 12-41 addition, floating point, 4-20 address buses address reach (space), 1-5 external, 2-27 general, 1-5 address range LSTRB0.1-field specified, 7-11 STRB0,1-field specified, 7-10 addressing modes conditional branch, 2-15, 5-24 general, 2-15, 5-19 parallel, 2-15, 5-23 three operand, 2-15, 5-20 addressing types, 5-2 direct addressing, 5-4 immediate, 5-17 indirect addressing, 5-5-5-16 PC relative, 5-17 register, 5-3 ALU, 2-4 analysis module general, 1-5 registers, 3-21 ANSI C compiler, 1-9 applications hardware, 13-1 list, 1-11

software, 12-1 ARAU (auxiliary register arithmetic unit), 2-6 arithmetic logic unit (ALU), 2-4 arithmetic operations, 12-28 assembly language instructions, 11-1 categories, 11-3-11-9 interlocked operation. 11-7 load and store. 11-3 parallel operation, 11-8 program control, 11-6 three-operand, 11-6 two-operand, 11-4 condition codes, flags, 11-10 example instruction, 11-18 register syntax, 11-17 summary, 2-16-2-25, 11-3-11-9 symbols used to define, 11-14-11-17 syntax options, 11-15-11-17 auxiliary register arithmetic units (ARAUs), 2-6 auxiliary registers (AR0-7), 2-6, 3-5

# B

Bcond instruction, 12-11 BcondAF, BcondAT instructions, 6-8 benchmarks, FFT timing, 12-88 biquads, 12-53 bit manipulation, 12-28 bit-reversed addressing, 5-30, 12-31 modify example, 5-16 block diagrams communication port control register, 8-10 communication ports, 8-4, 8-5 block diagrams (Continued) CPU, 2-5 memory organization, 2-11 peripheral modules, 2-28 timers, 9-45 TMS320C40, 2-2 block moves, 12-29 block repeat, 6-2 example, 12-24 registers (RS, RE), 3-14, 12-26 block repeat registers (RS, RE), 3-14, 12-26 block size (BK) register, 3-5, 12-52 boot loader, 13-5 communication port, 13-8 external memory, 13-8 source program, 13-14 branches, 6-7, 6-9, 12-22 delaved. 6-7 BRD instruction, 12-95 bus operation arbitration, 13-48, 13-70 external, 2-27 internal. 2-26 busy-waiting example, 6-15 byte manipulation, 12-30

## С

cache, optimization of code, 12-96 cache memory, 2-10 algorithm, 3-27 architecture, 2-10, 3-25 control bits, 3-29 general, 1-6 hit, 3-27 instruction cache, 3-25 miss, 3-27 optimization of code, 12-96 size, 1-6 CALL instruction, 6-9, 12-13 CALLcond instruction, 6-9, 12-27 calls. 6-9 example code, 12-9 zero overhead, 12-11 central processing unit, 2-4

channel control register. See DMA channel control register circular addressing, 5-25 circular modify example, 5-12 communication port arbitration unit (PAU), 8-5 communication port control register, 8-5, 8-10 field descriptions, 8-10 memory map, 3-23 communication ports applications, 12-98 architecture, 2-29 benefits, 1-7 block diagram, 8-4, 8-5 control register. See communication port control register features, 8-3 general, 1-4 memory map, 3-23, 8-8 port arbitration unit (PAU), 8-12 synchronizer timing, 8-32 throughput, 1-4, 1-7 timing, 8-18, 8-32, 14-31 companding, 12-46 compiler, 1-9 computed GOTOs, 12-27 condition codes, flags, 11-12 conditional delayed branches, 6-7 conditional-branch addressing modes, 2-15, 5-24 context switching, 12-15 conversion of format 2s complement floating-point to IEEE, 4-13 extended-prec floating-point to singleprec floating-point, 4-10 floating point to integer, 4-28 IEEE single prec. std. 754, 4-11 IEEE std. 754, 4-11 IEEE to 2s complement floating-point, 4-12 IEEE to/from 'C40, 12-42 integer to floating point, 4-30

conversion of format (Continued) short floating point to extended-prec. floating point, 4-9 short floating point to single-prec. floating point, 4-9 single-prec. floating-point to extendedprec floating-point, 4-10 single-prec. 2s compl. floating-point, 4-11 counter example, 6-15 counter register (timer), 9-50 See also timers CPU architecture, 2-4 buses, 2-26 general, 1-4 instruction cycle times, 1-4 primary register file, 3-3 throughput, 1-4 CPU internal interrupt enable register (IIE), 2-8, 3-10 CPU primary register file, 3-3 CPU registers, 3-3 auxiliary (AR0-AR7), 2-6, 3-5 block repeat (RS, RE), 3-14, 12-26 block size (BK), 2-7, 3-5 data page pointer (DP), 2-7, 3-5, 5-4 DMA interrupt enable (DIE), 2-8, 3-8 bit descriptions, 3-9 extended precision (R0-R11), 2-6, 3-4 IIOF flag register (IIF), 2-8, 3-12 index (IR1, IR0), 2-7, 3-5 internal interrupt enable (IIE), 2-8, 3-10 bit descriptions, 3-11 list of, 2-7, 3-3 primary register file, 3-3 program counter (PC), 2-9, 2-26, 3-14 repeat count (RC), 2-8, 3-14, 6-2, 12-26 repeat end address (RE), 3-14, 6-2 repeat start address (RS), 3-14, 6-2 reserved bits, 3-14 stack pointer (SP), 2-8, 3-5 application, 12-13

status register (ST), 2-8, **3-5**, 11-11 bit descriptions, 3-6

## D

data buses external. 2-27 general, 1-5 transfer rate, 1-5 data page pointer (DP), 2-7, 3-5, 5-4 delayed branches, 6-7 example, 12-23 incorrectly placed, 6-6, 6-7 optimization use, 12-95 dequeues (stack), 5-33 development tools. See software development tools dimensions ('C40), 14-11 direct addressing, 5-4 direct memory access. See DMA coprocessors disabled interrupts by branch, 6-8 displacements, 5-5---5-16 division floating point, 12-33 integer, 12-33 DMA. See DMA coprocessors DMA channel control register, 9-7 AUTOINIT STATIC bit, 12-105 PRI bits, 9-14 bit definitions. 9-8 field descriptions, 9-8 START bits, 12-103 STATUS bits, 9-16 SYNC MODE bits, 12-103 TRANSFER MODE field. 9-28 DMA coprocessors architecture, 2-29 autoinitialization, 9-31, 12-105 example, 12-107 benefits, 1-8 buses, 2-26 channel address register, 9-16

DMA coprocessors (Continued) channel control register AUTOINIT STATIC bit, 12-105 PRI bits, 9-14 START bits. 9-15 STATUS bits. 9-16 SYNC MODE bits, 9-15 TRANSFER bits, 9-14 channel register map, 3-24 channel synchronization, 9-41-9-46 features, 9-2, 9-3 functional description, 9-3 general, 1-4, 2-29 index register, 9-16 interrupts, 9-40, 12-102 example of use, 12-107 link-pointer register, 9-19, 9-38 example, 12-105 memory mapped registers, 9-4 operation examples, 12-101 priorities, 9-22 priority wheel, 9-24 registers, 9-5, 9-7 split mode example, 12-104 START bits, 12-103 SYNC MODE bits, 12-103 synchronization of channels, 9-41-9-46 throughput, 1-8 transfer count register, 9-18 transfer description, 9-5, 12-103 **TRANSFER MODE field. 9-28** unified and split modes, 9-20 DMA interrupt enable register (DIE), 2-8, 3-8 double precision, fixed point, 12-41

edge-triggered interrupts, 6-23 electrical characteristics, 14-13 electrical specifications, 14-12 emulator (XDS510), 1-9 event counters. *See* timers expansion register file, 2-9, **3-15** interrupt vector table (IVT), **3-16**, 6-26 *application, 12-19* trap vector table (TVT), 3-15 extended precision number, floating-point format, 4-8 extended precision registers, 2-6, **3-4**, 12-41 floating point format, 3-4 integer format, 3-4 saving (example), 12-13 external buses (global, local), wait states, 7-15 external interrupts, 2-27

fast Fourier transforms, 12-31, 12-63 DIF (decimation in frequency), 12-64. 12-65, 12-70 DIT (decimation in time), 12-64, 12-78 timing benchmarks, 12-88 twiddle factors, 12-68 features (of TMS320C40), 1-4 FFT. See fast Fourier transforms filters adaptive, 12-58 FIR, 12-51, 12-59 IIR, 12-53, 12-54 lattice. 12-88 FIR filters, 12-51, 12-59 FIX instruction, 4-28, 12-33 FLOAT instruction, 4-30, 12-33 floating point addition, 4-20 conversion (to/from IEEE), 12-42 conversion to integer, 4-28 extended-precision format, 4-8 format conversion, 4-9 formats, 12-43 IEEE, 12-44 multiplication, 4-15 normalization, 4-20, 4-24 pop and push, 12-13 reciprocal, 4-31 register format, 3-4 rounding value, 4-26 short format, 4-6 single-precision format, 4-7 subtraction, 4-20 underflow, 4-21

flush pipeline, 12-22 formats conversion, floating-point, 4-9 See also *conversion of formats* floating point, 12-43 signed integer, 4-3 unsigned integer, 4-4 FRIEEE instruction, 12-43

## G

general addressing modes, 2-15, 5-19 global control register (timer), 9-47 global memory, 6-13, 6-17 interface, 2-27, 13-20 global memory interface. See memory interface (local, global) GOTOs, 12-27

H1/H3 timing, 14-15

## 

IACK instruction, 7-47 IACK pin, 7-47 timing, 14-30 ICFULL flag description, 12-99 enabling, 3-11 **ICRDY** flag description, 12-99 enabling, 3-11 example of use, 12-106 interrupt use, 3-9 IEEE std. 754 (conversions), 4-11 IIOF flag register (IIF), 2-8, 3-12, 12-103 **IIOF** pins boot loader use. 13-6 loading, 13-14 timing, 14-24, 14-29 IIR filters, 12-54 immediate addressing, 5-17 index registers (IR0, IR1), 2-7, 3-5, 9-16 indirect addressing, 5-5

initialization of processor, 12-3 example code, 12-4 instruction cache, 3-25 instruction register (IR), 2-26 instruction set summary, 2-16-2-25, 11-3-11-9 functional groups, 11-3 instructions, Chapter 11 integer formats short integer, 4-3 signed, 4-3 single-precision integer, 4-3 unsigned, 4-4 interfaces, 13-3 external, 13-3 memory. See memory interfaces (local, global) parallel processing, 13-37 shared bus, 13-43 interlocked instructions, 2-27, 6-13, 7-39 interlocked operations, 6-13 internal bus, 2-26 internal interrupt enable register (IIE), 2-8, 3-10 interrupt service routine, 12-14, 12-21 interrupt vector table (IVT), 3-16 application, 12-19 boot loader use, 13-7 interrupts, 2-27, 6-23 answering, 12-28 communication port, 12-100 context switching, 12-15 control bits, 6-24 DMA, 6-25, 9-40, 12-102 example, 12-107 edge/level triggered, 6-23 example, 12-28 external, 2-27 initiation condition, 6-11 NMI, 6-23, 12-14 prioritizina, 6-24 processing, 6-27 service routines, 12-14, 12-21 trap comparison, 6-11 vectors, 3-20, 6-25, 6-26

### Index

inverse of floating point, 12-36 IR filters, 12-51, **12-53** IVTP. See interrupt vector table (IVT)

# J

JTAG emulation timing, 14-38, B-3 jumps, 6-9 zero-overhead use, 12-11

LAJ instruction, 6-9, 12-11, 12-22, 12-95 LAJcond instruction, 6-9 LAT instruction, 12-22 LATcond instruction, 6-9, 6-11 lattice filter, 12-88 LB, LBU instructions, 12-30 LDFI instruction, 6-13, 7-40 timing, 14-20 LDII instruction, 6-13, 7-40 timing, 14-20 level-triggered interrupts, 6-23 LH, LHU instructions, 12-30 LMS algorithm, 12-58 local memory interface, 2-27, 13-20 See also memory interface (local, global) LOCK signal, 7-39 logical operations, 12-28 loops, 12-23-12-26 LWL, LWR instructions, 12-30

## Μ

MB, MH instructions, 12-30 mechanical data, 14-11 memory, 2-10 *See also* memory interface accesses *fetches, 10-20 loads, stores, 10-21 pipeline, 10-20 timing, 10-20* cache, 2-10, 3-25 memory (Continued) communication ports memory map, 8-8 general organization, 2-10 global, 6-13, 6-17 interfaces. See memory interface (local, global) memory interface control registers, 3-21 memory maps, 2-12 analysis module registers, 3-21 communication ports, 3-23 DMA, 9-4 DMA coprocessors, 3-24 memory interface control registers, 3-21 overall description, 2-13 peripherals, 2-14 timer registers, 3-22, **9-46** organization, 2-10, 3-18 pipeline conflicts, 10-11, 10-18 RAM, 2-10 zero wait states, 13-21 ranges, 7-10 registers. See memory interface control registers ROM, 2-10 interface to 'C40. 13-9 ROMEN pin effect, 3-18 sharing, 6-16 timing, 7-17, 10-20, 14-18 memory interface (local, global), 13-20 bus arbitration, 13-48 control registers. See memory interface control registers control signals, 7-3 features, 7-1 RAM (zero wait states), 13-21 ready generation, 7-15, 7-17, 13-27 shared bus, 13-43 shared with bus arbitration, 13-38 signals, 7-3 strobes sinale. 13-21 two banks, 13-25 timing, 7-17 wait states, 7-15, 13-27

memory interface control registers, 3-21, 7-6 address ranges, 7-10, 7-11 bit contents, 7-7 boot loader use, 13-7 example configuration, 13-46 LSTRB ACTIVE field, 13-21 page size, 7-9 PAGESIZE field, 13-21, 13-32 reset effect, 7-6 STRBx SWW field, 7-16 STRBx SWW fields, 13-28 timing, 7-17 wait states, 7-15 memory maps, 2-12-2-14, 3-18 analysis module registers, 3-21 communication ports, 3-23, 8-8 DMA, 9-4 DMA coprocessors, 3-24 memory interface control registers, 3-21 overall description, 2-13 peripherals, 2-14 timer registers, 3-22, 9-46 MPYI3 instruction, 12-42 MPYSHI3 instruction, 12-42 multiple processors, 6-13 multiplication, matrix vector, 12-61 multiplication, floating point, 4-15 multiplier, 2-4

# N

nested block repeats, 6-6 NMI, 6-23 NORM instruction, 4-24 normalization, 12-38 floating point value, 4-20, 4-24

# 0

OCEMPTY flag description, 12-99 enabling, 3-11 OCRDY flag description, 12-99 enabling, 3-11 interrupt use, 3-9 optimization (assembler code), 12-95 overflow, 4-21, 4-28

# Ρ

P flag (cache), 3-25 packing data example, 12-30 page size, 7-9, 7-13 switching, 13-32 timing, 14-23 parallel addressing modes, 2-15, 5-23 parallel instruction set optimization use, 12-95 summary, 2-23-2-25 parallel processing 'C40-to-'C40, 13-37 general, 1-3 shared bus, 13-43 PAU (port arbitration unit), 8-12 See also port aribtration unit operation, 8-12 performance, 1-6 period register (timer), 9-50 See also timers peripheral bus, 2-28 communication port, 2-29 general architecture, 2-28 map. 3-22 pin (TMS320C40) descriptions, 14-7 names, 14-2 pin states at reset, 6-18 pinouts, 14-2 pipeline, 10-1 conflicts avoiding, 12-96 branching, 10-4 memory, 10-11 memory (resolving), 10-18 registers, 10-8 flush, 12-22 memory accesses, 10-20 structure, 10-2 POPF instruction, 12-13

port arbitration unit, (PAU) 8-5, 8-12 synchronizer timing, 8-32 postdisplacement examples, 5-11 postindex examples, 5-15 predisplacement examples, 5-9 preindex examples, 5-13 primary register file (CPU), 2-6, 3-3 priority (memory) fixed, 13-70 rotating, 13-58 priority wheel (DMA), 9-24 products, 320 family, 1-2 program buses, 2-26 control, 12-9 flow, 6-1 program counter (PC), 2-9, 2-26, 3-14 programming methodology, tips, 12-94 PUSHF instruction, 12-13



queues (stack), 5-33



RAM. 2-10 zero wait states, 13-21 RCPF instruction, 4-31, 12-33, 12-36 ready generation, 7-15, 13-27 timing, 7-17 reciprocal (RCPF inst.), 4-31 reciprocal square root (RSQRF inst.), 4-33 register buses, 2-26 registers, 2-7 auxiliary (AR0-AR7), 2-6, 3-5 block repeat (RS, RE), 3-14, 12-26 block size (BK), 2-7, 3-5 counter (timer), 9-50 data page pointer (DP), 2-7, 3-5, 5-4 DMA interrupt enable (DIE), 2-8, 3-8 bit descriptions, 3-9 extended precision (R0-R11), 2-6, 3-4 saving (example), 12-13 global control (timer), 9-47

IIOF flag register (IIF), 2-8, 3-12, 6-23, 6-24 index (IR1, IR0), 3-5 internal interrupt enable (IIE), 2-8, 3-10, 6-23 bit descriptions, 3-11 optimization use, 12-96 period (timer), 9-50 pipeline conflicts, 10-8 program counter (PC), 2-9, 2-26, 3-14 repeat count (RC), 2-8, 3-14, 6-2, 12-26 repeat end address (RE), 3-14, 6-2 repeat start address (RS), 3-14, 6-2 reserved bits, 3-14 saved in context switches, 12-16 stack pointer (SP), 2-8, 3-5 application, 12-13 status register (ST), 2-8, 3-5, 11-11 bit descriptions, 3-6 repeat count register (RC), 2-8, 3-14, 6-2, 12-26 repeat end address register (RE), 3-14, 6-2 repeat mode, RPTS initialization, 6-4 repeat modes (block, single instruction), 6-2 initialization, 6-2 optimization use, 12-95 repeat start address register (RS), 3-14, 6-2 reset, 3-17, 6-18, 12-3 communication ports, 8-14 memory interface control registers, 7-6 operations performed, 6-22 pin states, 6-18 signal generation, 13-75 timing, 14-28 vector mapping, 3-17, 12-3 vectors, 6-25 RESETLOCx pins, 3-17, 12-3, 13-9 RETIcond instruction, 6-9, 6-12 RETIcondD instruction, 6-9, 12-22 **RETScond instruction**, 6-9 return from subroutine, 6-9 RND instruction, 4-26 ROM, 2-10 rounding of floating point value, 4-26

registers (Continued)

RPTB and RPTBD instructions, 6-3, 12-23, 12-63 optimization use, 12-95 RPTS instruction, 6-4 example, 12-23, 12-30 optimization use, 12-95 RSQRF instruction, 4-33, **12-38** 

## S

segment start address (SSA) register, 3-25 semaphores, 6-17 shared bus interface, 13-43 short floating-point format, 4-6 SIGI instruction, 6-13, 7-44 timing, 14-22 signal descriptions, 14-7-14-10 signal transition levels, 14-14 signal-group control, 7-38 simulator, 1-10 software control, 6-1 software development tools, 1-9 ANSI C compiler, 1-9 assembler/linker, 1-9 compiler, 1-9 general, 1-9 linker, 1-9 simulator (state-accurate), 1-10 SPOX operating system, 1-9 XDS510 emulator, 1-9, B-1 split mode (DMA), 9-20, 12-104 SPOX operating system, 1-9 square root, 12-38 stack, 5-31, 5-33 dequeues, 5-33 queues, 5-33 stack pointer (SP), 2-8, 3-5 application, 12-13 state diagram, port arbitration unit, 8-13 status register (ST), 2-8, 3-5, 11-11 bit descriptions, 3-6 STFI instruction, 6-13, 7-42 timing, 14-21

STII instruction, 6-13, 7-42 timing, 14-21 strobe settings, 7-8 strobes, 7-12 timing, 7-17 wait states, 13-21 SUBB instruction, 12-41 SUBC instruction, 12-33 subroutines, 12-11, 12-15 calls. *See* calls subtraction, floating point, 4-20 system configurations, 13-4

test load circuit, 14-13 three-operand addressing modes, 2-15, 5-20 throughput, 1-4, 1-6 communication port, 1-7 DMA, 1-8 timer global control register, 9-47 diagram, bit summary, 9-47 timer registers, 3-22 timers, 9-45-9-54 applications, 12-97 architecture, 2-29 counter register, 9-45, 9-50 global control register, 9-46, 9-47 operation nodes, 9-51 period control registers, 9-50 period register, 9-45, 9-50 timing, 14-37 timing bus control, 14-19 memory access, 7-17, 14-18 parameters, 14-15-14-26 STRB, RDY, 7-17 TLCK0,1 pins, 12-97 TMS320 family, products 1-2 **TOIEEE** instruction, 12-43 trap vector table (TVT), 3-15 boot loader use, 13-7-13-8 TRAPcond instruction, 6-9 traps, 6-9, 6-11

### Index

TSTB instruction, 12-28 TTL levels, 14-14 TVTP. *See* trap vector table (TVT) twiddle factor, 12-68, 12-78



µ-law

compression, expansion, 12-46 conversion, linear, 12-46 underflow, 4-20 unified mode (DMA), 9-20 unpacking data example, 12-31



vectors (reset, interrupts), 6-25

## W

wait states, 7-15, 7-36, 7-37, **13-20**, **13-27** bus disabled, 7-38 consecutive reads, then write, 13-23 consecutive writes, then read, 13-25 multiple waits circuitry, 13-31 requirements, 13-20 word manipulation, 12-30



XDS510 emulator, 1-9, B-1 XDS510 emulator design considerations, B-1

