# TMS320 DSP DESIGNER'S NOTEBOOK TMS320C5x Interrupts and the Pipeline

APPLICATION BRIEF: SPRA231

Mansoor Chishtie Digital Signal Processing Products Semiconductor Group

*Texas Instruments June 1993* 



#### **IMPORTANT NOTICE**

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

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

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

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

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

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

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

Copyright © 1997, Texas Instruments Incorporated

#### TRADEMARKS

TI is a trademark of Texas Instruments Incorporated.

Other brands and names are the property of their respective owners.

#### CONTACT INFORMATION

| US TMS320 HOTLINE | (281) 274-2320 |
|-------------------|----------------|
| US TMS320 FAX     | (281) 274-2324 |
| US TMS320 BBS     | (281) 274-2323 |
| US TMS320 email   | dsph@ti.com    |

## Contents

| Abstract       | 7 |
|----------------|---|
| Design Problem | 8 |
| Solution       | 8 |
| Condion        | v |

## TMS320C5x Interrupts and the Pipeline

#### Abstract

This document discusses interrupt handling and the effect of interrupts on the pipeline. If an interrupt is pending and is subsequently enabled by a CLRC instruction, where would it be taken and what happens when it returns from the ISR?

## **Design Problem**

ſĿ

Given the following situation:

```
; an int is enabled and pending
CLRC INTM
RETD
LAR AR1,#2
MAR *,AR1
```

If an interrupt is pending and is subsequently enabled by a CLRC instruction, where would it be taken and what happens when it returns from the ISR?

### Solution

A delayed-instruction and the next two instruction words (in the two delay slots) are uninterruptible. If the delayed instruction happens to be a return-delayed then 'C5x will execute the two instructions following that, execute return and then take the interrupt trap.

Since clrc intm does not enable interrupts until the next instruction is executed, which happens to be a return-delayed, any pending interrupt will be taken AFTER executing the return and the two delayed instructions:

CLRC INTM ;these 4 instructions uninterruptible RETD LAR AR1,#2 MAR \*,AR1 ;interrupt taken after executing this ;instruction

calling\_prog: ;<-ISR will return here</pre>