# Software Differences Between the DSP56002 and the DSP56303

By Barbara Johnson

The software differences between the DSP56002 and the DSP56303 must be considered when a system based on the DSP56002 is redesigned to use the DSP56303. This application note describes these software differences in detail. For details on the hardware differences between these two DSP products, refer to the application note AN1830/D, *Hardware Differences Between the DSP56002 and the DSP56303*, which covers memory, interrupt and mode control, core, and peripherals.

This application note does not describe an application *per se*. Rather it summarizes the differences between two DSP products as a convenient reference for designers/programmers who are migrating to the DSP56303 from the DSP56002. It saves you the time that would be required to determine what these differences are.

### Contents

| Intr | oduction                     | 2  |
|------|------------------------------|----|
| Inst | ruction Pipeline             |    |
|      | ruction Cache Controller     |    |
| 3.1  | Software Control             | 4  |
| 3.2  | Instruction Cache Structure  | 4  |
| 3.3  | Burst Mode                   | 5  |
| 3.4  | Cache Visibility Via OnCE    | 5  |
| Ari  | hmetic Logic Unit            | 5  |
|      | Iress Generation Unit        |    |
| Pro  | gramming Mode                | 17 |
|      | ruction Set                  |    |
| 7.1  | Arithmetic Instructions      | 15 |
| 7.2  | Logical Instructions         | 17 |
| 7.3  | New Loop Instructions        | 19 |
| 7.4  | Move Instruction             | 20 |
| 7.5  | Program Control Instructions | 21 |



# 1 Introduction

**Figure 1** and **Figure 2** show the block diagrams of the DSP56002 and the DSP56303, respectively, in order to provide a context for the next sections, which compare various features and modules of these two DSP products.



Figure 1. DSP56002 Block Diagram





Figure 2. DSP56303 Block Diagram

# 2 Instruction Pipeline

In the DSP56002, the program control unit implements a three-stage instruction execution pipeline:

- 1. prefetch
- 2. decode
- 3. execute

Each instruction requires a minimum of three instruction cycles to move through this pipeline. There is a delay of three instruction cycles on power-up to fill the pipeline. A new instruction can begin executing immediately after the previous instruction executes. Two-word instructions require a minimum of four instruction cycles to execute—that is, three cycles for the first instruction word to move through the pipeline and execute and one more cycle for the second word to execute. A new instruction can start after two instruction cycles.

In the DSP56303, the program control unit implements a seven-stage pipeline:

- 1. prefetch-I
- 2. prefetch-II
- 3. decode
- 4. address generation-I
- 5. address generation-II
- 6. execute-I
- 7. execute-II

Each instruction requires a minimum of seven instruction cycles to move through this pipeline. There is a delay of seven instruction cycles on power-up to fill the pipeline. A new instruction can begin executing immediately after the previous instruction executes. Two-word instructions require a minimum of eight instruction cycles to execute—that is, seven cycles for the first instruction word to move through the pipeline and execute and one more cycle for the second word to execute. A new instruction can start after two instruction cycles.

# 3 Instruction Cache Controller

The instruction cache controller is not available on the DSP56000 core. On the DSP56300 core, the instruction cache stores frequently-used program instructions. When instruction words required by a program are available in the on-chip cache, an increase in throughput may result, and the time required to access them on the external bus is eliminated.

### 3.1 Software Control

On the DSP56300 core, switching between PRAM mode and cache mode is controlled via the Cache Enable CE bit in the Expanded Mode Register (EMR). If EMR[CE] is set, the cache is enabled, instructions are cached into the internal PRAM and fetched from there. If EMR[CE] is cleared, the cache is disabled, and the core fetches instructions from external or internal program memory.

# 3.2 Instruction Cache Structure

The instruction cache memory array contains 1024 x 24-bit words logically divided into eight 128-word cache sectors. The 24-bit address is divided into the following fields:

- vbit field, 7 least significant bits for the word displacement in the sector
- tag field, 17 most significant bits for the sector base address

The cache controller compares its tag field to the tag values currently stored in the tag register file. These tag values are the tag fields of the base addresses of the memory sectors currently mapped into the cache. Each word in each cache sector is associated with a cache word valid bit that specifies whether the data in



that word has been fetched from external memory and is therefore valid. There is a total 2048 valid bits arranged as 8 banks of 128 or 256 valid bits each, one bank for every sector. Of these valid bits, 1024 are not used if the instruction cache size is 1024 bytes.

### 3.3 Burst Mode

When the Burst Mode Enable (BE) bit in the Extended Chip Operating Mode Register (EOM) is set, up to four program words are fetched from external memory upon detection of an instruction cache miss. When EOM[BE] is cleared, the burst mode is disabled, and only one program word is fetched from external memory upon detection of an instruction cache miss.

### 3.4 Cache Visibility Via OnCE

When the DSP is in Debug mode, you can observe the memory sectors that are currently mapped into cache, the locked cache sectors, the Least Recently Used cache sector, and the occurrence of a hit. You can also read the valid bits of specific cache locations.

# 4 Arithmetic Logic Unit

**Table 1** summarizes the differences in the Arithmetic Logic Unit between the DSP56002 and the DSP56303.

| DSP56002                                                 | DSP56303                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| MAC Unit                                                 |                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| MAC operation is a non-pipelined single-cycle operation. | MAC operation is fully pipelined and requires two clock<br>cycles to complete. In the first clock cycle, the multiply is<br>performed and the product is stored in the pipeline register.<br>In the second clock cycle, the accumulator is added or sub-<br>tracted.     |  |  |  |  |  |
| Bit Field (                                              | Jnit (BFU)                                                                                                                                                                                                                                                               |  |  |  |  |  |
|                                                          | The BFU contains a 56-bit parallel bidirectional shifter with a 56-bit input and a 56-bit output mask generation unit and logic unit. It is used in the following operations: <ul> <li>Multiple left/right shift (arithmetic or logical) for ASL/ASR, LSL/LSR</li> </ul> |  |  |  |  |  |
| Not Available.                                           | <ul> <li>Bit field merge, insert and extract for MERGE,<br/>INSERT, EXTRACT, EXTRACTU,Count leading<br/>bits for CLB</li> </ul>                                                                                                                                          |  |  |  |  |  |
|                                                          | Fast normalization for NORMF                                                                                                                                                                                                                                             |  |  |  |  |  |
|                                                          | The addition of the BFU on the DSP56300 core has pro-<br>duced new shift and program control-relative instructions<br>(refer to <b>Section 7</b> , "Instruction Set," on page 12).                                                                                       |  |  |  |  |  |

 Table 1.
 Arithmetic Logic Unit, Comparison Between DSP56002 and DSP56303

#### Arithmetic Logic Unit

| DSP56002                                 |                                                                         |                                                             |                                                     |                                            | DSF                                                       | P56303                                                     | 3                                                           |                                         |                                                                                           |                                            |
|------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------------|
|                                          |                                                                         | otio Ma                                                     |                                                     |                                            |                                                           |                                                            | -                                                           |                                         |                                                                                           |                                            |
| Sixteen-Bit Ar                           |                                                                         |                                                             |                                                     |                                            |                                                           |                                                            |                                                             |                                         |                                                                                           |                                            |
|                                          | 17) i<br>right                                                          | in the St                                                   | tatus<br>d in 2                                     | Reg<br>24-bit                              | ister (S<br>memo                                          | R). Th                                                     | e 16-b                                                      | oit da                                  | ting the S<br>ata is<br>non-Data                                                          |                                            |
|                                          |                                                                         |                                                             |                                                     | 23–                                        | 16                                                        | 15-                                                        | -0                                                          |                                         |                                                                                           |                                            |
|                                          |                                                                         |                                                             | U                                                   | Indef                                      | ined                                                      | Data                                                       |                                                             |                                         |                                                                                           |                                            |
|                                          |                                                                         | bit posit<br>nmetic m                                       |                                                     |                                            |                                                           |                                                            | ng wor                                                      | d in                                    | Sixteen-I                                                                                 | Bit                                        |
|                                          |                                                                         | 23                                                          | :16                                                 |                                            | 15:0                                                      |                                                            | 23:16                                                       |                                         | 15:0                                                                                      |                                            |
| Not Available.                           |                                                                         | Unde                                                        | efine                                               | d                                          | Data                                                      | Ur                                                         | ndefine                                                     | ed                                      | Data                                                                                      |                                            |
|                                          | The 16-bit data is left-aligned in Data ALU input registers as follows: |                                                             |                                                     |                                            |                                                           |                                                            |                                                             |                                         |                                                                                           |                                            |
|                                          |                                                                         | 47:3                                                        | 2                                                   | 3                                          | 1:24                                                      | 2                                                          | 3:8                                                         |                                         | 7:0                                                                                       |                                            |
|                                          |                                                                         | X1/Y                                                        | 1                                                   | Unc                                        | defined                                                   | XC                                                         | )/Y0                                                        | Un                                      | defined                                                                                   |                                            |
|                                          |                                                                         | 16-bit d<br>s as foll                                       |                                                     |                                            | aligne                                                    | d in Da                                                    | ata ALI                                                     | U ac                                    | cumulato                                                                                  | or reg-                                    |
|                                          |                                                                         | 55:48                                                       | 47                                                  | :32                                        | 31:                                                       | :24                                                        | 23:                                                         | 8                                       | 7:0                                                                                       |                                            |
|                                          |                                                                         | A2/B2                                                       | A1,                                                 | /B1                                        | Unde                                                      | fined                                                      | A0/E                                                        | 30                                      | Undefin                                                                                   | ed                                         |
| Roundin                                  | g Mo                                                                    | odes                                                        |                                                     |                                            |                                                           |                                                            |                                                             |                                         |                                                                                           |                                            |
| Convergent rounding mode is implemented. | men<br>the s<br>if RM<br>gent<br>and<br>men                             | ited. To s<br>SR. If RI<br>I is clea<br>t roundir<br>rounds | selec<br>M is s<br>ared,<br>ng ro<br>up if<br>ng rc | ct Roi<br>set, to<br>conv<br>unds<br>the r | unding<br>wos con<br>ergent<br>down i<br>number<br>s down | mode,<br>mplem<br>roundi<br>if the n<br>is odd<br>all valu | set th<br>ent rou<br>ing is s<br>umber<br>I (LSB:<br>ues be | e RI<br>undi<br>selec<br>r is e<br>=1). | are imple<br>M bit (bit :<br>ng is sele<br>cted. Con<br>even (LSE<br>Twos cor<br>one-half | 21) in<br>ected;<br>iver-<br>3=0)<br>mple- |

#### Table 1. Arithmetic Logic Unit, Comparison Between DSP56002 and DSP56303 (Continued)



| DSP56002        | DSP56303                                                                                                                                                                                                                 |  |  |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Saturation Mode |                                                                                                                                                                                                                          |  |  |  |  |  |
| Not Available   | The arithmetic unit's result is limited to 48 bits by setting the SM (bit 20) in the SR. This bit provides a saturation mode for algorithms that do not recognize or cannot take advantage of the extension accumulator. |  |  |  |  |  |

Table 1. Arithmetic Logic Unit, Comparison Between DSP56002 and DSP56303 (Continued)

# 5 Address Generation Unit

**Table 2** summarizes the differences in the Address Generation Unit (AGU) between the DSP56002 and the DSP56303.

| Table 2. Address Generation Unit, Comparison of DSP56002 and DSP56303 |
|-----------------------------------------------------------------------|
|-----------------------------------------------------------------------|

| DSP56002                                                                                                                                                                                                                                                                                                                                                                                                                     | DSP56303                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| AGU Registers                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| The 24 Address Generation Unit (AGU) registers (address registers R0–R7, offset registers N0–N7, and modifier registers M0–M7) are 16 bits wide. When used as a source operand, these registers occupy the low-order portion of the 24-bit word; the high-order portion is read as zeros. When used as a destination operand, these registers receive the low-order portion of the word; the high-order portion is not used. | The 24 AGU registers are 24-bits wide.                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| Sixteen-Bit Cor                                                                                                                                                                                                                                                                                                                                                                                                              | npatibility Mode                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| Not Available                                                                                                                                                                                                                                                                                                                                                                                                                | When the Sixteen-Bit Compatibility Mode bit in the MR is<br>set, move operations to and from the LA, LC, SP, SSL, SSH,<br>EP, SZ, VBA, and SC registers clear the eight most signifi-<br>cant bits of the destination. This guarantees compatibility for<br>object code written for the DSP56000 family of DSPs. |  |  |  |  |  |

# 6 Programming Model

This section compares key registers of the DSP56002 and the DSP56303. The registers covered are as follows:

- Status Register (SR), Table 3 on page 8
- Operating Mode Register (OMR), Table 4 on page 9
- System Stack (SS), Table 5 on page 10
- Program Counter (PC), **Table 6** on page 10
- Vector Base Address Register (VBA), Table 7 on page 10
- Loop Counter Register (LC), Table 8 on page 10

- Loop Address Register (LA), **Table 9** on page 10
- Stack Extension Pointer (EP), Table 10 on page 11
- Stack Size Register (SZ), **Table 11** on page 11
- Stack Counter Register (SC), Table 12 on page 11
- Stack Pointer Register (SC), Table 13 on page 11

#### **Table 3.** Status Register, Comparison of the DSP56002 and the DSP56303

| DSP56002                                                                                                                                                                              |       |         |                                   |     |            | DSP         | 56303                                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|-----------------------------------|-----|------------|-------------|------------------------------------------------------------------------------------------------------|
| The Status Register (SR) is a 16-bit register that consists of<br>a Mode Register MR in the high-order eight bits and a Con-<br>dition Code Register CCR in the low-order eight bits. |       |         |                                   |     | EMR in the | e high-ord  | consists of an Extended Mode<br>ler eight bits, an MR in the mid-<br>CR in the low-order eight bits. |
|                                                                                                                                                                                       |       |         |                                   | EMR | 23–22      | CP1–<br>CP0 | Core Priority                                                                                        |
|                                                                                                                                                                                       |       |         |                                   |     | 21         | RM          | Rounding Mode                                                                                        |
|                                                                                                                                                                                       |       |         |                                   |     | 20         | SM          | Arithmetic Saturation Mode                                                                           |
|                                                                                                                                                                                       |       |         |                                   |     | 19         | CE          | Instruction Cache Enable                                                                             |
|                                                                                                                                                                                       |       |         |                                   |     | 18         | _           | Reserved                                                                                             |
|                                                                                                                                                                                       |       |         |                                   |     | 17         | SA          | Sixteen-Bit Arithmetic Mode                                                                          |
|                                                                                                                                                                                       |       |         |                                   |     | 16         | FV          | DO-Forever Flag                                                                                      |
|                                                                                                                                                                                       |       |         |                                   |     | 15         | LF          | DO-Loop Flag                                                                                         |
| MR                                                                                                                                                                                    | 15    | LF      | Loop Flag                         | MR  | 15         | LF          | Loop Flag                                                                                            |
|                                                                                                                                                                                       | 14    | DM      | Double Precision Multiply<br>Mode |     | 14         | DM          | Double-Precision Multiply<br>Mode                                                                    |
|                                                                                                                                                                                       | 13    | Т       | Trace Mode                        |     | 13         | SC          | Sixteen-Bit Compatibility<br>Mode                                                                    |
|                                                                                                                                                                                       | 12    | —       | Reserved                          |     | 12         | _           | Reserved                                                                                             |
|                                                                                                                                                                                       | 11-10 | S1 – S0 | Scaling Mode                      |     | 11-10      | S1 –<br>S0  | Scaling Mode                                                                                         |
|                                                                                                                                                                                       | 9–8   | I1–I0   | Interrupt Mask                    |     | 9–8        | l1 – l0     | Interrupt Mask                                                                                       |
| CCR                                                                                                                                                                                   | 7     | S       | Scaling                           | CCR | 7          | S           | Scaling                                                                                              |
|                                                                                                                                                                                       | 6     | L       | Limit                             |     | 6          | L           | Limit                                                                                                |
|                                                                                                                                                                                       | 5     | E       | Extension                         |     | 5          | E           | Extension                                                                                            |
|                                                                                                                                                                                       | 4     | U       | Unnormalized                      |     | 4          | U           | Unnormalized                                                                                         |
|                                                                                                                                                                                       | 3     | N       | Negative                          |     | 3          | N           | Negative                                                                                             |
|                                                                                                                                                                                       | 2     | Z       | Zero                              |     | 2          | Z           | Zero                                                                                                 |
|                                                                                                                                                                                       | 1     | V       | Overflow                          |     | 1          | V           | Overflow                                                                                             |
|                                                                                                                                                                                       | 0     | С       | Carry                             |     | 0          | С           | Carry                                                                                                |

| DSP56002                    |   |    |                           |                                                              |                                                       | DSF                                                               | 256303                                                                                                                                                                                  |
|-----------------------------|---|----|---------------------------|--------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| with only six bits defined. |   |    |                           | tions. The<br>Status Re<br>stack ext<br>Extended<br>Chip Ope | e upper by<br>egister (SC<br>ension. Th<br>d Chip Ope | te consist<br>CS), which<br>le two low<br>erating Mo<br>de Regist | divided into three 8-bit sec-<br>is of the System Stack Control<br>in controls and monitors the<br>er bytes consist of the<br>ode Register (EOM) and the<br>er (COM), which control the |
|                             |   |    |                           | SCS                                                          | 23–21                                                 | _                                                                 | Reserved                                                                                                                                                                                |
|                             |   |    |                           |                                                              | 20                                                    | SEN                                                               | Stack Extension Enable                                                                                                                                                                  |
|                             |   |    |                           |                                                              | 19                                                    | WRP                                                               | Extended Stack Wrap Flag                                                                                                                                                                |
|                             |   |    |                           |                                                              | 18                                                    | EOV                                                               | Extended Stack Overflow Flag                                                                                                                                                            |
|                             |   |    |                           |                                                              | 17                                                    | EUN                                                               | Extended Stack Underflow<br>Flag                                                                                                                                                        |
|                             |   |    |                           |                                                              | 16                                                    | XYS                                                               | Stack Extension Space Select                                                                                                                                                            |
|                             |   |    |                           | EOM                                                          | 15                                                    | ATE                                                               | Address Tracing Enable                                                                                                                                                                  |
|                             |   |    |                           |                                                              | 14–13                                                 | _                                                                 | Reserved                                                                                                                                                                                |
|                             |   |    |                           |                                                              | 12                                                    | BRT                                                               | Bus Release Timing                                                                                                                                                                      |
|                             |   |    |                           |                                                              | 11                                                    | TAS                                                               | TA Synchronize Select                                                                                                                                                                   |
|                             |   |    |                           |                                                              | 10                                                    | BE                                                                | Burst Mode Enable                                                                                                                                                                       |
|                             |   |    |                           |                                                              | 9–8                                                   | CDP1-<br>CDP0                                                     | Interrupt Mask                                                                                                                                                                          |
|                             |   |    |                           | СОМ                                                          | 7                                                     | MS                                                                | Memory Switch Mode                                                                                                                                                                      |
|                             | 6 | SD | Stop Delay                |                                                              | 6                                                     | SD                                                                | Stop Delay                                                                                                                                                                              |
|                             | 4 | MC | Operating Mode C          |                                                              | 5                                                     | _                                                                 | Reserved                                                                                                                                                                                |
|                             | 3 | YD | Internal Y Memory Disable |                                                              | 4                                                     | EBD                                                               | External Bus Disable                                                                                                                                                                    |
|                             | 2 | DE | Data ROM Enable           |                                                              | 3–0                                                   | MD –<br>MA                                                        | Operating Mode D–A                                                                                                                                                                      |
|                             | 1 | MB | Operating Mode B          |                                                              |                                                       |                                                                   |                                                                                                                                                                                         |
|                             | 0 | MA | Operating Mode A          |                                                              |                                                       |                                                                   |                                                                                                                                                                                         |

 Table 4.
 Operating Mode Register, Comparison of the DSP56002 and the DSP56303

| DSP56002                                                                                     | DSP56303                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| The SS accommodates up to 15 long interrupts, 7 DO loops, 15 JSRs, or combinations of these. | The SS is a separate 16-level by 48-bit internal memory<br>divided into two 24-bit wide banks: the System Stack High<br>(SSH) and the System Stack Low (SSL). If the Stack Exten-<br>sion Enable (SEN) bit in the OMR is cleared, the SS accom-<br>modates up to 15 long interrupts, 7 DO loops, 15 JSRs, or<br>combinations of these. If the SEN bit is set, the stack exten-<br>sion is enabled and the limits on the level of nesting of sub-<br>routines or DO loops can be set to any desired value. |

#### **Table 5.**System Stack, Comparison of the DSP56002 and the DSP56303

#### Table 6. Program Counter, Comparison of the DSP56002 and the DSP56303

| DSP56002                                                                                                                                  | DSP56303                     |
|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| The Program Counter (PC) is a 16-bit register that contains the address of the next location to be fetched from the program memory space. | The PC is a 24-bit register. |

#### Table 7. Vector Base Address Register, Comparison of the DSP56002 and the DSP56303

| DSP56002      | DSP56303                                                                                                                                                                                  |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Not Available | The Vector Base Address Register (VBA) is a 24-bit register that is used as a base address of the interrupt vector and interrupt vector+1. Bits 7–0 are read-only and are always cleared. |

#### **Table 8.** Loop Counter Register, Comparison of the DSP56002 and the DSP56303

| DSP56002                                                                                                                         | DSP56303                    |
|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| The Loop Counter Register (LC) is a 16-bit counter that specifies the number of times a hardware program loop is to be repeated. | The LC is a 24-bit counter. |

#### Table 9. Loop Address Register, Comparison of the DSP56002 and the DSP56303

| DSP56002                                                                                                                          | DSP56303                     |
|-----------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| The Loop Address Register (LA) is a 16-bit register that indicates the location of the last instruction word in a hard-ware loop. | The LA is a 24-bit register. |



| DSP56002      | DSP56303                                                                                                                                                                                                                           |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Not Available | The Stack Extension Pointer Register (EP) is a 24-bit regis-<br>ter that points to the stack extension in data memory when<br>the stack extension is enabled and move operations to/from<br>the on-chip hardware stack are needed. |

 Table 10.
 Stack Extension Pointer Register, Comparison of the DSP56002 and the DSP56303

#### Table 11. Stack Size Register, Comparison of the DSP56002 and the DSP56303

| DSP56002      | DSP56303                                                                                                                                                   |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Not Available | The Stack Size Register (SZ) is a 24-bit register that deter-<br>mines the number of data words allocated in memory for the<br>stack in the extended mode. |

#### Table 12. Stack Counter Register, Comparison of the DSP56002 and the DSP56303

| DSP56002 | DSP56303                                                                                                             |
|----------|----------------------------------------------------------------------------------------------------------------------|
|          | The Stack Counter Register (SC) is a 5-bit register that monitors how many entries of the hardware stack are in use. |

#### Table 13. Stack Pointer Register, Comparison of the DSP56002 and the DSP56303

| DSP56002   |     |                                                                |  |      |           | DSP56303                                       |                      |
|------------|-----|----------------------------------------------------------------|--|------|-----------|------------------------------------------------|----------------------|
|            |     | r (SP) is a 6-bit register tha<br>p of the SS and the status ( |  |      |           | register. When the e<br>f the SS is also indic |                      |
| Bit<br>No. |     | Description                                                    |  | Bit  |           | Descriptio                                     | on                   |
| 5          | UF  | Underflow Flag                                                 |  | No.  |           | Extended Mode                                  | Non-Extended<br>Mode |
| 4          | SE  | Stack Error Flag                                               |  | 23–6 | P23–      | Bits 23–6 of the Stack Pointer                 |                      |
| 3–0        | P3- | Stack Pointer                                                  |  |      | P6        |                                                | -                    |
|            | P0  |                                                                |  | 5    | UF/<br>P5 | Bit 5 of the Stack<br>Pointer                  | Underflow Flag       |
|            |     |                                                                |  | 4    | SE/<br>P4 | Bit 4 of the Stack<br>Pointer                  | Stack Error Flag     |
|            |     |                                                                |  | 3–0  | P3–<br>P0 | Bits 3–0 of the                                | Stack Pointer        |
|            |     |                                                                |  |      | 1         | I                                              |                      |

# 7

# Instruction Set

**Table 14** shows the DSP56300 instructions that are either available on the DSP56303 but not on the DSP56002 or that are enhanced on the DSP56303.

| Туре       | Instruction | Description                                                    | Status               |
|------------|-------------|----------------------------------------------------------------|----------------------|
| Arithmetic | c ADD Add   |                                                                | Enhanced on DSP56300 |
|            | ASL         | Arithmetic Shift Accumulator Left                              | Enhanced on DSP56300 |
|            | ASR         | Arithmetic Shift Accumulator Right                             | Enhanced on DSP56300 |
|            | СМР         | Compare                                                        | Enhanced on DSP56300 |
|            | CMPU        | Compare Unsigned                                               | DSP56300 only        |
|            | DMAC        | Double (Multi) Precision Multiply Accumulate with Right Shift  | DSP56300 only        |
|            | MACI        | Signed Multiply-Accumulate with Immediate<br>Operand           | DSP56300 only        |
|            | MACsu       | Mixed Multiply Accumulate (S1 signed, S2 unsigned)             | DSP56300 only        |
|            | MACuu       | Mixed Multiply Accumulate (S1 and S2 unsigned)                 | DSP56300 only        |
|            | MACRI       | Signed Multiply-Accumulate and Round with<br>Immediate Operand | DSP56300 only        |
|            | MAX         | Transfer by Signed Value                                       | DSP56300 only        |
|            | MAXM        | Transfer by Magnitude                                          | DSP56300 only        |
|            | MERGE       | Merge Two Half Words                                           | DSP56300 only        |
|            | MPYsu       | Mixed Multiply (S1 signed, S2 unsigned)                        | DSP56300 only        |
|            | MPYuu       | Mixed Multiply (S1 and S2 unsigned)                            | DSP56300 only        |
|            | MPYI        | Signed Multiply with Immediate Operand                         | DSP56300 only        |
|            | MPYRI       | Signed Multiply and Round with Immediate Oper-<br>and          | DSP56300 only        |
|            | NORMF       | Fast Accumulator Normalization                                 | DSP56300 only        |
|            | SUB         | Subtract                                                       | Enhanced on DSP56300 |

Table 14. DSP56300 Instructions



| Туре    | Instruction | Description                                                 | Status               |
|---------|-------------|-------------------------------------------------------------|----------------------|
| Logical | AND         | Logical AND                                                 | Enhanced on DSP56300 |
|         | CLB         | Count Leading Bits                                          | DSP56300 only        |
|         | EOR         | Logical Exclusive OR                                        | Enhanced on DSP56300 |
|         | EXTRACT     | Extract Bit Field                                           | DSP56300 only        |
|         | EXTRACTU    | Extract Unsigned Bit Field                                  | DSP56300 only        |
|         | INSERT      | Insert Bit Field                                            | DSP56300 only        |
|         | LSL         | Logical Shift Left                                          | Enhanced on DSP56300 |
|         | LSR         | Logical Shift Right                                         | Enhanced on DSP56300 |
|         | OR          | Logical OR                                                  | Enhanced on DSP56300 |
| Loop    | DOR         | Start PC Relative Hardware Loop                             | DSP56300 only        |
|         | BRKcc       | Exit Current Do Loop Conditionally                          | DSP56300 only        |
| Move    | LRA         | Load PC Relative Address                                    | DSP56300 only        |
| Program | IFcc        | Execute Conditionally                                       | DSP56300 only        |
| Control | IFcc.U      | Execute Conditionally and Update Condition<br>Code Register | DSP56300 only        |
|         | BRCLR       | Branch if Bit Clear                                         | DSP56300 only        |
|         | BRSET       | Branch if Bit Set                                           | DSP56300 only        |
|         | BSCLR       | Branch to Subroutine if Bit Clear                           | DSP56300 only        |
|         | BSSET       | Branch to Subroutine if Bit Set                             | DSP56300 only        |
|         | PLOCK       | Lock Instruction Cache Sector                               | DSP56300 only        |
|         | PUNLOCK     | Unlock Instruction Cache Sector                             | DSP56300 only        |
|         | PLOCKR      | Lock Instruction Cache Relative Sector                      | DSP56300 only        |
|         | PUNLOCKR    | Unlock Instruction Cache Relative Sector                    | DSP56300 only        |
|         | PFREE       | Program Cache Global Unlock                                 | DSP56300 only        |
|         | PFLUSH      | Program Cache Flush                                         | DSP56300 only        |
|         | PFLUSHUN    | Program Cache Flush Unlocked Sectors                        | DSP56300 only        |
|         | TRAP        | Software Interrupt                                          | DSP56300 only        |
|         | TRAPcc      | Conditional Software Interrupt                              | DSP56300 only        |

### 7.1 Arithmetic Instructions

**Table 15** lists the arithmetic instructions that are either available on the DSP56303 but not on the DSP56002 or enhanced on the DSP56303.

| Instruction | Description                                                                                                                                                                                                               | Valid Assembler Syntax                                                                                     |                                                                                                                                                     |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|
| ADD         | Enhanced to support the addition of a 6-bit<br>short immediate or a 24-bit long immedi-<br>ate data to the destination accumulator.                                                                                       | ADD S,D                                                                                                    | ;S is source register X0, X1, Y0, Y1, X, Y, A, B<br>;D is destination accumulator A, B                                                              |  |
|             |                                                                                                                                                                                                                           | ADD #ii,D                                                                                                  | ;#ii is 6-bit immediate short data                                                                                                                  |  |
|             |                                                                                                                                                                                                                           | ADD #iiiiii,D                                                                                              | ;#iiiiii is 24-bit immediate long data extension ;word                                                                                              |  |
| ASL/ASR     | Enhanced to support the multi-bit shifting.                                                                                                                                                                               | ASL D                                                                                                      | ;D is destination accumulator A,B                                                                                                                   |  |
|             |                                                                                                                                                                                                                           |                                                                                                            | ;#ii is 6-bit unsigned integer [0-55]<br>;denoting the shift amount<br>;S2 is source accumulator A, B                                               |  |
|             |                                                                                                                                                                                                                           | ASL S1,S2,D                                                                                                | ;S1 is control register X0, X1, Y0, Y1, A1, B1                                                                                                      |  |
| СМР         | Enhanced to support the comparison of a 6-bit short immediate data or a 24-bit long immediate data to a source accumulator.                                                                                               | CMP S1,S2                                                                                                  | ;S1 is source one register X0, X1, Y0, Y1, A, B<br>;S2 is source two accumulator A, B                                                               |  |
|             |                                                                                                                                                                                                                           | CMP #ii,S2                                                                                                 | ;#ii is 6-bit immediate short data                                                                                                                  |  |
|             | <b>CMP #iiiiii,S2</b> ;#iiiiii is 24-bit immed;extension word                                                                                                                                                             |                                                                                                            | 2;#iiiiii is 24-bit immediate long data<br>;extension word                                                                                          |  |
| CMPU        | DSP56300 only. Subtracts the source<br>operand from the source accumulator and<br>updates the condition code register. The<br>result of the operation is not stored.                                                      | CMPU S1,S2<br>;S1 is source one register X0, X1, Y0, Y1, A, B<br>;S2 is source two accumulator A, B        |                                                                                                                                                     |  |
| DMAC        | DSP56300 only. Multiplies the two signed<br>24-bit source operands and adds/sub-<br>tracts the product to/from the specified<br>56-bit destination accumulator which has<br>been previously shifted 24 bits to the right. | DMAC (+/-)S1,S2,D<br>;S1, S2 are source registers X0, Y0,<br>;X1, Y1<br>;D is destination accumulator A, B |                                                                                                                                                     |  |
| MACI        | DSP56300 only. Multiplies the two signed<br>24-bit source operands and adds/sub-<br>tracts the product to/from the specified<br>56-bit destination accumulator.                                                           | MACI (+/-)#iii                                                                                             | iiii,S,D<br>;#iiiiii is 24-bit immediate long data<br>;extension word;S is source register<br>;X0, Y0, X1, Y1<br>;D is destination accumulator A, B |  |

 Table 15.
 Arithmetic Instructions Added/Enhanced on the DSP56303 But Not on the DSP56002



| Instruction     | Description                                                                                                                                                                                                                                                                                                                                                                                                                        | Valid Assembler Syntax                                                                                                                                            |  |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MACsu/<br>MACuu | DSP56300 only. MACsu multiplies the two<br>24-bit source operands, in which one<br>source operand is unsigned and the other<br>is signed, and adds/subtracts the product<br>to/from the specified 56-bit destination<br>accumulator. MACuu multiplies the two<br>24-bit source operands, in which both<br>source operands are unsigned, and<br>adds/subtracts the product to/from the<br>specified 56-bit destination accumulator. | MACsu (+/-)S1,S2,D<br>;S1, S2 are source registers X0, X1,<br>;Y0, Y1<br>; D is destination accumulator A, B                                                      |  |  |
| MACRI           | DSP56300 only. Multiplies the two signed<br>24-bit source operands and adds/sub-<br>tracts the product to/from the specified<br>56-bit destination accumulator.                                                                                                                                                                                                                                                                    | MACRI (+/-)#iiiiii,S,D<br>;#iiiiii is 24-bit immediate long data<br>;extension word<br>;S is source register X0, Y0, X1, Y1<br>;D is destination accumulator A, B |  |  |
| MAX             | DSP56300 only. Subtracts the signed<br>value of the source accumulator from the<br>signed value of the destination accumula-<br>tor. If the difference is negative or zero, the<br>source accumulator is transferred to the<br>destination accumulator. Otherwise, the<br>destination accumulator remains<br>unchanged.                                                                                                            | MAX A,B ;A, B are source accumulators                                                                                                                             |  |  |
| MAXM            | DSP56300 only. Subtracts the magnitude<br>of the source accumulator from the magni-<br>tude of the destination accumulator. If the<br>difference is negative or zero, the source<br>accumulator is transferred to the destina-<br>tion accumulator. Otherwise, the destina-<br>tion accumulator remains unchanged.                                                                                                                 | <b>MAXM A,B</b> ;A, B are source accumulators                                                                                                                     |  |  |
| MERGE           | DSP56300 only. Concatenates the con-<br>tents of bits 11–0 of the source register to<br>the contents of bits 35–24 of the destina-<br>tion accumulator. In 16-bit arithmetic<br>mode, the contents of bits 15–8 of the<br>source register are concatenated to the<br>contents of bits 39–32 of the destination<br>accumulator. The result is placed in bits<br>47–32 of the destination accumulator.                               | MERGE S,D ;S is source register X0, X1, Y0, Y1, A1, B1<br>;D is destination accumulator A, B                                                                      |  |  |
| MPYsu/<br>MPYuu | DSP56300 only. MPYsu multiplies the two<br>24-bit source operands, in which one<br>source operand is unsigned and the other<br>is signed, and stores the product in the<br>specified 56-bit destination accumulator.<br>MPYuu multiplies the two 24-bit source<br>operands, in which both source operands<br>are unsigned, and stores the product in<br>the specified 56-bit destination accumula-<br>tor.                         | MPYsu (+/-)S1,S2,D<br>;S1, S2 are source registers X0, X1, Y0,<br>;Y1<br>;D is destination accumulator A, B                                                       |  |  |

Table 15. Arithmetic Instructions Added/Enhanced on the DSP56303 But Not on the DSP56002 (Continued)

#### Instruction Set

| Instruction | Description                                                                                                                                                                                                                                                                                                                                                                      | Valid Assembler Syntax                                                                                                                                            |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| MPYI        | DSP56300 only. Multiplies the immediate<br>24-bit source operand with the 24-bit<br>source operand and stores the resulting<br>product in the specified 56-bit destination<br>accumulator.                                                                                                                                                                                       | MPYI (+/-)#iiiiii,S,D<br>;#iiiiii is 24-bit immediate long data<br>;extension word<br>;S is source register X0, Y0, X1, Y1<br>;D is destination accumulator A, B  |  |
| MPYRI       | DSP56300 only. Multiplies the two signed<br>24-bit source operands, rounds the result<br>using either convergent or twos comple-<br>ment rounding, and stores the result in the<br>specified 56-bit destination accumulator.                                                                                                                                                     | MPYRI (+/-)#iiiiii,S,D<br>;#iiiiii is 24-bit immediate long data<br>;extension word<br>;S is source register X0, Y0, X1, Y1<br>;D is destination accumulator A, B |  |
| NORMF       | DSP56300 only. Arithmetically shifts the destination accumulator either left or right as specified by the source operand sign and value. If the source operand is negative, then the accumulator is left shifted, and if the source operand is positive, then it is right shifted. It can be used to bring the destination accumulator's leading one or zero to bit location 46. | NORMF S,D ;S is source register X0, Y0, X1, Y1, A1, B1<br>;D is destination accumulator A, B                                                                      |  |
| SUB         | Enhanced to support the subtraction of a<br>6-bit short immediate or a 24-bit long<br>immediate data from the destination                                                                                                                                                                                                                                                        | <b>SUB S,D</b> ;S is source register X0, X1, Y0, Y1, X, Y, A, B<br>;D is destination accumulator A, B                                                             |  |
|             | accumulator.                                                                                                                                                                                                                                                                                                                                                                     | SUB #ii,D;#ii is 6-bit immediate short dataSUB #iiiiii,D;#iiiiii is 24-bit immediate long data<br>;extension word                                                 |  |

Table 15. Arithmetic Instructions Added/Enhanced on the DSP56303 But Not on the DSP56002 (Continued)

# 7.2 Logical Instructions

**Table 16** lists the logical instructions that are either available on the DSP56303 but not on the DSP56002 or that are enhanced on the DSP56303.

| Table 16. | Logical Instructions Added/Enhanced on the DSP56303 But Not on the DSP56002 |
|-----------|-----------------------------------------------------------------------------|
|-----------|-----------------------------------------------------------------------------|

| Instruction | Description                                                                                                                    | Valid Assembler Syntax |                                                                                  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------|------------------------|----------------------------------------------------------------------------------|--|
| AND         | Enhanced to support the logical AND<br>operation between a 6-bit short immediate<br>data or a 24-bit long immediate data and a | AND S,D                | ;S is source input register X0, X1, Y0, Y1<br>;D is destination accumulator A, B |  |
|             | source accumulator.                                                                                                            | AND #ii,D              | ;#ii is 6-bit immediate short data                                               |  |
|             |                                                                                                                                | AND #iiiiii,D          | ;#iiiiii is 24-bit immediate long<br>;data extension word                        |  |

| Instruction          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       | Valid Assembler Syntax                                                                                                                                                                |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLB                  | DSP56300 only. Counts the leading zeros<br>or ones according to bit 55 of the source<br>accumulator. If bit 55 is zero, then bits<br>47–24 of the destination accumulator are<br>loaded with 9 minus the number of con-<br>secutive leading zeros in bits 55–0 of the<br>source accumulator. If bit 55 is one, then<br>bits 47–24 of the destination accumulator<br>is loaded with 9 minus the number of con-<br>secutive leading ones in bits 55–0 of the<br>source accumulator.                                                                  | CLB S,D                               | ;S is source accumulator A, B<br>;D is destination accumulator A, B                                                                                                                   |
| EOR                  | Enhanced to support the logical Exclusive<br>OR operation between a 6-bit short imme-<br>diate data or a 24-bit long immediate data<br>and a source accumulator.                                                                                                                                                                                                                                                                                                                                                                                   | EOR S,D<br>EOR #ii,D<br>EOR #iiiiii,D | ;S is source input register X0, X1, Y0, Y1<br>;D is destination accumulator A, B<br>;#ii is 6-bit immediate short data<br>;#iiiii is 24-bit immediate long data<br>;extension word    |
| EXTRACT/<br>EXTRACTU | DSP56300 only. Extracts a bit-field from<br>source accumulator S2, while the instruc-<br>tion EXTRACTU extracts an unsigned<br>bit-field from source accumulator S2. The<br>bit-field width is specified by bits 17–12 in<br>S1 register or in immediate control word<br>#CO. The offset from the least significant<br>bit is specified by bits 5–0 in S1 or in #CO.<br>In 16-bit arithmetic mode, the offset field is<br>located in bits 13–8 of the control register<br>and the width field is located in bits 21–16<br>of the control register. | EXTRACT S                             | S1 is control register X0, X1,<br>;Y0, Y1, A1, B1<br>;S2 is source accumulator A, B<br>;D is destination accumulator A, B                                                             |
| INSERT               | DSP56300 only. Inserts a bit-field into the destination accumulator. The bit-field width is specified by bits 17–12 in S1 register and begins at the least significant bit of the S2 register. The bit-field is inserted into the destination accumulator with an offset according to bits 5–0 in S1 register. S1 can be an immediate control word #CO. In 16-bit arithmetic mode, the offset field is located in bits 13–8 of the control register and the width field is located in bits 21–16 of the control register.                          | INSERT S1,S                           | <b>52,D</b><br>;S1 is control register X0, X1, Y0, Y1, A1, B1<br>;S2 is source accumulator A, B<br>;D is destination accumulator A, B<br><b>0,S2,D</b> ;#CO is control word extension |
| LSL/LSR              | Enhanced to support the multi-bit shifting.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | LSL D                                 | ;D is destination accumulator A, B                                                                                                                                                    |
|                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | LSL #ii,D                             | ;#ii is 5-bit unsigned integer [0-23] denoting the ;shift amount                                                                                                                      |
|                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | LSL S,D                               | ;S is control register X0, X1, Y0, Y1, A1, B1                                                                                                                                         |

Table 16. Logical Instructions Added/Enhanced on the DSP56303 But Not on the DSP56002 (Continued)

| Instruction | Description                                                                                                                         | Valid Assembler Syntax |                                                                                  |  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------------------------------------------------------------------------------|--|
| OR          | Enhanced to support the logical inclusive<br>OR operation between a 6-bit short imme-<br>diate data or a 24-bit long immediate data | OR S,D                 | ;S is source input register X0, X1, Y0, Y1<br>;D is destination accumulator A, B |  |
|             | and a source accumulator.                                                                                                           | OR #ii,D               | ;#ii is 6-bit immediate short data                                               |  |
|             |                                                                                                                                     | OR #iiiiii,D           | ;#iiiiii is 24-bit immediate long data<br>;extension word                        |  |

 Table 16.
 Logical Instructions Added/Enhanced on the DSP56303 But Not on the DSP56002 (Continued)

### 7.3 New Loop Instructions

**Table 17** lists the loop instructions that are either available on the DSP56303 but not on the DSP56002 or enhanced on the DSP56303.

Table 17. Loop Instructions Added/Enhanced on the DSP56303 But Not on the DSP56002

| Instruction | Description                                                                                                                                             | Valid Assembler Syntax                                                                                                                           |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| DOR         | DSP56300 only. Initiates the beginning of a PC-relative hardware program loop.                                                                          | DOR [X or Y]:ea,label<br>;ea is effective address<br>;label is 24-bit address displacement in 24-bit<br>;extension word<br>DOR [X or Y]:aa,label |
|             |                                                                                                                                                         | ;aa is absolute address<br>DOR #iii,label<br>;#iii is immediate short data<br>DOR S,label ;S is source register                                  |
| DOR         | DSD56200 only Paging a bardware DO                                                                                                                      |                                                                                                                                                  |
| FOREVER     | DSP56300 only. Begins a hardware DO<br>loop that is to be repeated forever and<br>whose range of execution is terminated by<br>the destination operand. |                                                                                                                                                  |



| Instruction | Description                                                                                                                                                                     |             | Valid Assembler Syntax |                              |                           |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------|------------------------------|---------------------------|--|
| BRKcc       | DSP56300 only.Conditionally exits the cur-<br>rent hardware DO loop before the current<br>loop counter equals one. It also terminates<br>the DO FOREVER or DOR FOREVER<br>loop. | The<br>low: |                        | is that the term "cc" can s  | pecify are listed as fol- |  |
|             | loop.                                                                                                                                                                           |             |                        | cc Mnemonic                  | Condition                 |  |
|             |                                                                                                                                                                                 |             | CC(HS)                 | carry clear (higher or same) | C = 0                     |  |
|             |                                                                                                                                                                                 |             | CS(LO)                 | carry set (lower)            | C = 1                     |  |
|             |                                                                                                                                                                                 |             | EC                     | extension clear              | E = 0                     |  |
|             |                                                                                                                                                                                 |             | EQ                     | equal                        | Z = 1                     |  |
|             |                                                                                                                                                                                 |             | ES                     | extension set                | E = 1                     |  |
|             |                                                                                                                                                                                 |             | GE                     | greater than or equal        | N eor V = $0$             |  |
|             |                                                                                                                                                                                 |             | GT                     | greater than                 | Z or (N eor V) = $0$      |  |
|             |                                                                                                                                                                                 |             | LC                     | limit clear                  | L = 0                     |  |
|             |                                                                                                                                                                                 |             | LE                     | less than or equal           | Z or (N eor V) = 1        |  |
|             |                                                                                                                                                                                 |             | LS                     | limit set                    | L = 1                     |  |
|             |                                                                                                                                                                                 |             | LT                     | less than                    | N eor V = 1               |  |
|             |                                                                                                                                                                                 |             | МІ                     | minus                        | N = 1                     |  |
|             |                                                                                                                                                                                 |             | NE                     | not equal                    | Z = 0                     |  |
|             |                                                                                                                                                                                 |             | NR                     | normalized                   | Z or (U and E) = 1        |  |
|             |                                                                                                                                                                                 |             | PL                     | plus                         | N=0                       |  |
|             |                                                                                                                                                                                 |             | NN                     | not normalized               | Z or (U and E) = 0        |  |

Table 17. Loop Instructions Added/Enhanced on the DSP56303 But Not on the DSP56002

### 7.4 Move Instruction

Table 18 lists the move instruction that is available on the DSP56303 but not on the DSP56002.

| Instru | uction | Description                                                   |            | Valid Assembler Syntax                                                                                                                 |
|--------|--------|---------------------------------------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------|
| LRA    |        | DSP56300 only. Adds the PC to the speci-<br>fied displacement | LRA Rn,D   | ;Rn is address register R0–R7<br>;D is destination address register X0, X1, Y0,<br>;Y1, A0, B0,<br>;A2, B2, A1, B1, A, B, R0:R7, N0–N7 |
|        |        |                                                               | LRA xxxx,D | ;xxxx is 24-bit PC long displacement                                                                                                   |

 Table 18.
 Move Instruction Added on the DSP56303 But Not on the DSP56002

# 7.5 Program Control Instructions

**Table 19** lists the program control instructions that are available on the DSP56303 but not on the DSP56002.

| Instruction | Description                                                                                                                                                                                                                                                                                                                                   | Valid Assembler Syntax |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| IFcc        | DSP56300 only. Executes and stores the result of the specified Data ALU operation if the specified condition is true. If the specified condition is false, no destination is altered. The instructions that can conditionally be executed by using this instruction are shown in <b>Table 17</b> .                                            | IFFcc                  |
| IFcc.U      | DSP56300 only. Executes and stores the result of the specified Data ALU operation if the specified condition is true and updates the condition code register with the status information generated by the Data ALU operation. If the specified condition is false, no destination is altered and the condition code register is not affected. | IFFcc.U                |



| Instruction | Description                                                                                                                                                                                                                                                   | Valid Assembler Syntax                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BRCLR       | DSP56300 only. Tests the nth bit in the<br>source operand. If the tested bit is cleared,<br>program execution continues at location<br>PC+displacement. If the tested bit is set,<br>the PC is incremented and program exe-<br>cution continues sequentially. | BRCLR #n,[X or Y]:ea,xxxx<br>;#n is bit number [0-23]<br>;ea is effective address (see the following table)<br>;xxxx is 24-bit PC relative displacement<br>BRCLR #n,[X or Y]:aa,xxxx;aa is absolute address [0-63]<br>BRCLR #n,[X or Y]:pp,xxxx<br>;pp is I/O short address [64<br>;addresses: \$FFFFC0-\$FFFFFF]                                                                                                                                        |
|             |                                                                                                                                                                                                                                                               | BRCLR #n,[X or Y]:qq,xxxx<br>;qq is I/O short address [64<br>;addresses: \$FFFF80-\$FFFFBF]                                                                                                                                                                                                                                                                                                                                                              |
|             |                                                                                                                                                                                                                                                               | BRCLR #n,S,xxxx<br>;S is all in-chip registers                                                                                                                                                                                                                                                                                                                                                                                                           |
|             |                                                                                                                                                                                                                                                               | Effective Addressing Mode                                                                                                                                                                                                                                                                                                                                                                                                                                |
|             |                                                                                                                                                                                                                                                               | (Rn)-Nn                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|             |                                                                                                                                                                                                                                                               | (Rn)+Nn                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|             |                                                                                                                                                                                                                                                               | (Rn)                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|             |                                                                                                                                                                                                                                                               | (Rn)+                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|             |                                                                                                                                                                                                                                                               | (Rn)                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|             |                                                                                                                                                                                                                                                               | (Rn+Nn)                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|             |                                                                                                                                                                                                                                                               | -(Rn)                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| BRSET       | DSP56300 only. Tests the nth bit in the<br>source operand. If the tested bit is set,<br>program execution continues at location<br>PC+displacement. If the tested bit is<br>cleared, the PC is incremented and pro-<br>gram execution continues sequentially. | BRSET #n,[X or Y]:ea,xxxx<br>;#n is bit number [0-23]<br>;ea is effective address (see Table 17).<br>;xxxx is 24-bit PC relative displacement<br>BRSET #n,[X or Y]:aa,xxxx;aa is absolute address [0-63]<br>BRSET #n,[X or Y]:pp,xxxx<br>;pp is I/O short address [64<br>;addresses: \$FFFFC0-\$FFFFFF]<br>BRSET #n,[X or Y]:qq,xxxx<br>;[q is I/O short address<br>;[64 addresses: \$FFFF80-\$FFFFBF]<br>BRSET #n,S,xxxx<br>;S is all in-chip registers |

 Table 19.
 Program Control Instructions Added/Enhanced on the DSP56303 But Not on the DSP56002

| Instruction       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Valid Assembler Syntax                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BSCLR             | DSP56300 only. Tests the nth bit in the<br>source operand. If the tested bit is cleared,<br>the address of the instruction immediately<br>following the BSCLR instruction and the<br>status register are pushed onto the stack.<br>Program execution then continues at loca-<br>tion PC+displacement. If the tested bit is<br>set, the PC is incremented and program<br>execution continues sequentially.                                                                                                                                                                                              | BSCLR #n,[X or Y]:ea,xxxx<br>;#n is bit number [0-23]<br>; ea is effective address (see Table 17)<br>; xxxx is 24-bit PC relative displacement<br>BSCLR #n,[X or Y]:aa,xxxx<br>;aa is absolute address [0-63]<br>BSCLR #n,[X or Y]:pp,xxxx<br>;pp is I/O short address [64<br>;addresses: \$FFFFC0-\$FFFFF]<br>BSCLR #n,[X or Y]:qq,xxxx<br>;qq is I/O short address<br>;[64 addresses: \$FFFF80-\$FFFFBF]<br>BSCLR #n,S,xxxx<br>;S is all in-chip registers |
| BSSET             | DSP56300 only. Tests the nth bit in the<br>source operand. If the tested bit is set, the<br>address of the instruction immediately fol-<br>lowing the BSSET instruction and the sta-<br>tus register are pushed onto the stack.<br>Program execution then continues at loca-<br>tion PC+displacement. If the tested bit is<br>cleared, the PC is incremented and pro-<br>gram execution continues sequentially.                                                                                                                                                                                        | BSSET #n,[X or Y]:ea,xxxx<br>;#n is bit number [0-23]<br>;ea is effective address (see Table 17)<br>;xxxx is 24-bit PC relative displacement<br>BSSET #n,[X or Y]:aa,xxxx<br>;aa is absolute address [0-63]<br>BSSET #n,[X or Y]:pp,xxxx<br>;pp is I/O short address<br>;[64 addresses: \$FFFFC0-\$FFFFFF]<br>BSSET #n,[X or Y]:qq,xxxx<br>;qq is I/O short address<br>;[64 addresses: \$FFFF80-\$FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF                            |
| PLOCK/<br>PUNLOCK | DSP56300 only. PLOCK locks the cache<br>sector to which the specified effective<br>address belongs. If the sum does not<br>belong to any cache sector, it loads the 17<br>most significant bits of the sum into the<br>least recently used cache sector tag, and<br>then locks that cache sector. PUNLOCK<br>unlocks the cache sector to which the<br>specified effective address belongs. If the<br>sum does not belong to any cache sector,<br>and is therefore definitely unlocked, PUN-<br>LOCK loads the least recently used cache<br>sector tag with the 17 most significant bits<br>of the sum. | PLOCK ea ;ea is effective address                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### Table 19. Program Control Instructions Added/Enhanced on the DSP56303 But Not on the DSP56002

| Instruction         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Valid Assembler Syntax                                                  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| PLOCKR/<br>PUNLOCKR | DSP56300 only. PLOCKR locks the cache<br>sector to which the sum PC + specified<br>displacement belongs. If the sum does not<br>belong to any cache sector, then it loads<br>the 17 most significant bits of the sum into<br>the least recently used cache sector tag,<br>and then locks that cache sector. PUN-<br>LOCKR unlocks the cache sector to which<br>the sum PC + specified displacement<br>belongs. If the sum does not belong to any<br>cache sector, and is therefore definitely<br>unlocked, PUNLOCKR loads the least<br>recently used cache sector tag with the 17<br>most significant bits of the sum. | PLOCKR xxxx<br>;xxxx is twos complement 24-bit integer<br>;displacement |
| PFREE               | DSP56300 only. Unlocks all the locked cache sectors in the instruction cache.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                         |
| PFLUSH/<br>PFLUSHUN | DSP56300 only. PFLUSH flushes the<br>whole instruction cache, unlocks the<br>cache sectors, and sets the LRU stack and<br>tag registers to their default values.<br>PFLUSHUN flushes the instruction cache<br>which is unlocked, sets the LRU stack to<br>its default value and sets the unlocked tag<br>registers to their default values.                                                                                                                                                                                                                                                                            |                                                                         |
| TRAP/<br>TRAPcc     | TRAP suspends normal instruction execu-<br>tion and begins TRAP exception process-<br>ing. TRAPcc suspends normal instruction<br>execution and software exception process-<br>ing is initiated if the specified condition is<br>true. If the specified condition is false,<br>instruction execution continues with the<br>next instruction.                                                                                                                                                                                                                                                                            |                                                                         |

| Table 19. Program Control Instructions Added/Enhanced on the DSP56303 But Not o | on the DSP56002 |
|---------------------------------------------------------------------------------|-----------------|
|---------------------------------------------------------------------------------|-----------------|

OnCE and Mfax are registered trademarks of Motorola, Inc.

Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Motorola data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Motorola does not convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the design or manufacture of the part. Motorola and **W** are registered trademarks of Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer.

How to reach us:

#### USA/Europe/Locations Not Listed:

Motorola Literature Distribution P.O. Box 5405 Denver, Colorado 80217 1 (800) 441-2447 1 (303) 675-2140

#### Motorola Fax Back System (Mfax<sup>™</sup>):

RMFAX0@email.sps.mot.com TOUCHTONE (602) 244-6609 USA and Canada ONLY: 1-800-774-184 http://sps.motorola.com/mfax/



#### Asia/Pacific:

Motorola Semiconductors H.K. Ltd. 8B Tai Ping Industrial Park 51 Ting Kok Road Tai Po, N.T., Hong Kong 852-26629298

Technical Resource Center: 1 (800) 521-6274

DSP Helpline dsphelp@dsp.sps.mot.com

#### Japan:

Nippon Motorola Ltd. SPD, Strategic Planning Office141 4-32-1, Nishi-Gotanda 3-14-2 Tatsumi Koto-Ku Shinagawa-ku, Tokyo, Japan 81-3-5487-8488

Customer Focus Center: 1-800-521-6274

Internet:

http://www.mot.com/SPS/DSP/