# Contents

Preface ....................................................................................................................................... 5  
1 Introduction ........................................................................................................................ 7  
2 Analog-to-Digital Converter (ADC) .................................................................................. 10  
3 Clock Generator ................................................................................................................ 10  
  3.1 Introduction to the DSP Clock Generator .................................................................... 10  
  3.2 Operational Flow of the DSP Clock Generator ............................................................ 10  
  3.3 Bypass Mode ............................................................................................................... 12  
  3.4 Lock Mode .................................................................................................................. 13  
  3.5 Idle (Low-Power) Mode .............................................................................................. 14  
  3.6 The CLKOUT Pin and the Associated Clock Divider ................................................... 14  
  3.7 DSP Reset Conditions of the DSP Clock Generator .................................................... 15  
  3.8 Clock Mode Register (CLKMD) .................................................................................. 16  
4 Direct Memory Access (DMA) Controller ....................................................................... 18  
5 External memory Interface (EMIF) .................................................................................... 18  
6 General-Purpose I/O Port .................................................................................................. 18  
7 Host Port Interface (HPI) ................................................................................................... 18  
8 Idle Configurations ............................................................................................................. 18  
  8.1 Idle Domains ............................................................................................................. 19  
  8.2 Idle Configuration Process ....................................................................................... 20  
  8.3 Valid Idle Configurations ........................................................................................... 20  
  8.4 To Change Idle Configurations (Key Conditions) ...................................................... 21  
  8.5 Interrupt Handling When the CPU Is Reactivated ...................................................... 22  
  8.6 Effect of a DSP Reset on the Idle Domains ............................................................... 22  
  8.7 Idle Registers ............................................................................................................ 23  
9 Instruction Cache ................................................................................................................ 25  
10 Inter-Integrated Circuit (I2C) Module ............................................................................. 25  
11 Multichannel Buffered Serial Port (McBSP) ................................................................ 25  
12 Real-Time Clock (RTC) .................................................................................................. 25  
13 System Control Registers ............................................................................................... 25  
14 Timer (General-Purpose) ................................................................................................ 25  
15 Universal Asynchronous Receiver/Transmitter (UART) .............................................. 25  
16 Universal Serial Bus (USB) Module .............................................................................. 25  
17 Watchdog Timer ............................................................................................................. 25  
18 Serial Peripheral Interface (SPI) .................................................................................... 26  
19 Liquid Crystal Display Controller (LCDC) ................................................................. 26  
20 Inter-IC Sound (I2S) Peripheral ..................................................................................... 26  
21 MultiMedia Card (MMC) / SD Card Controller ............................................................. 26
List of Figures

1  Operational Flow of the DSP Clock Generator .......................................................... 11
2  Dividing the CPU Clock for the CLKOUT Pin .......................................................... 14
3  Clock Mode Register (CLKMD) ................................................................................ 16
4  Idle Configuration Process ...................................................................................... 20
5  Idle Configuration Register (ICR) ............................................................................. 23
6  Idle Status Register (ISTR) ...................................................................................... 24

List of Tables

1  TMS320C55x DSP Peripherals (5501–5515) ............................................................... 8
2  TMS320C55x DSP Peripherals (5532–5535) ............................................................... 9
3  Operational States ..................................................................................................... 12
4  CLKMD Bits Used in the Bypass Mode ................................................................... 12
5  CLKMD Bits Used in the Lock Mode ........................................................................ 13
6  Examples of Selecting a Lock Mode Frequency ....................................................... 13
7  Method Used for Reacquiring the Phase Lock .......................................................... 14
8  Effect of CLKDIV Bits on CLKOUT Frequency ....................................................... 14
9  Reset Values of CLKMD Bits and The Effects ......................................................... 15
10 Clock Mode Register (CLKMD) Field Descriptions ............................................... 16
11 Idle Domains in the DSP ........................................................................................ 19
12 Changing Idle Configurations ................................................................................. 21
13 CPU Response After Reactivation .......................................................................... 22
14 Idle Configuration Register (ICR) Field Descriptions ........................................... 23
15 Idle Status Register (ISTR) Field Descriptions ..................................................... 24
About This Manual

This manual is for the peripherals that are on the digital signal processors (DSPs) in the TMS320C55x™ (C55x™) DSP generation.

This manual is in transition. Most peripheral information has been revised and moved from chapters in this manual to separate documents. These separate documents are referenced in Chapter 1. The peripheral information that is still in this manual is being revised and will be in separate documents in the future. When the revisions are complete, this manual is to remain as an overview that points to all of the separate documents. In some cases, information has been moved from this manual to the device-specific data manuals.
1 Introduction

Table 1 lists the peripherals of the TMS320C55x (C55x) DSP generation and indicates how many copies of each peripheral are on the specific C55x devices. On a given device, some peripherals may share pins, making the peripherals’ use mutually exclusive; see the device-specific data manual for details.

For a detailed description of a peripheral, see the chapter or document listed in the last column of the table. If a peripheral has its own reference guide, the table shows the literature number (SPRUxxx) for that reference guide. If you are viewing the table online, you can click the literature number to view or download a portable document format (PDF) file. Otherwise, you can find the PDF files on the Internet at http://www.ti.com. Tip: Enter the literature number in the search box provided at http://www.ti.com.

All information about general-purpose I/O pins and system control registers has been moved from this document to the device-specific data manuals.
Table 1. TMS320C55x DSP Peripherals (5501–5515)

<table>
<thead>
<tr>
<th>Peripheral</th>
<th>5501</th>
<th>5502</th>
<th>5503</th>
<th>5504</th>
<th>5505</th>
<th>5506</th>
<th>5507</th>
<th>5509/5509A</th>
<th>5510A</th>
<th>5515</th>
<th>5514</th>
<th>For Details, See...</th>
</tr>
</thead>
<tbody>
<tr>
<td>Analog-to-digital converter (ADC)</td>
<td>1</td>
<td>1</td>
<td></td>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SPRU586</td>
<td></td>
</tr>
<tr>
<td>Clock generator with PLL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td>Section 3 and the device-specific data manual.</td>
<td></td>
</tr>
<tr>
<td>Direct memory access (DMA) controller</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td>SPRU587</td>
<td></td>
</tr>
<tr>
<td>External memory interface (EMIF)</td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SPRU613</td>
<td></td>
</tr>
<tr>
<td>Host port interface (HPI)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SPRU588</td>
<td></td>
</tr>
<tr>
<td>Instruction cache</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td>SPRU576</td>
<td></td>
</tr>
<tr>
<td>Inter-integrated circuit (I2C) module</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td>SPRU146</td>
<td></td>
</tr>
<tr>
<td>Multichannel buffered serial port (McBSP)</td>
<td>2</td>
<td>3</td>
<td>3</td>
<td>1</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>3</td>
<td>1</td>
<td></td>
<td>SPRU592</td>
<td></td>
</tr>
<tr>
<td>MultiMediaCard / SD card controller</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SPRU593</td>
<td></td>
</tr>
<tr>
<td>Power management / Idle configurations</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td>Section 8 and device-specific data manual.</td>
<td></td>
</tr>
<tr>
<td>Real-time clock (RTC)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td>SPRU594</td>
<td></td>
</tr>
<tr>
<td>Timer, general-purpose</td>
<td></td>
<td></td>
<td></td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td></td>
<td>SPRU595</td>
<td></td>
</tr>
<tr>
<td>Timer, watchdog</td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td>SPRU618</td>
<td></td>
</tr>
<tr>
<td>Universal Asynchronous Receiver/Transmitter (UART)</td>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>SPRU597</td>
<td></td>
</tr>
</tbody>
</table>
### Table 1. TMS320C55x DSP Peripherals (5501–5515) (continued)

<table>
<thead>
<tr>
<th>Peripheral</th>
<th>5501</th>
<th>5502</th>
<th>5503</th>
<th>5504</th>
<th>5505</th>
<th>5506</th>
<th>5507</th>
<th>5509/5509A</th>
<th>5510A</th>
<th>5515</th>
<th>5514</th>
<th>For Details, See...</th>
</tr>
</thead>
<tbody>
<tr>
<td>Universal Serial Bus (USB) module</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td>SPRU596</td>
</tr>
<tr>
<td>Serial Peripheral Interface (SPI)</td>
<td>1</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td>SPRUFO0</td>
</tr>
<tr>
<td>Liquid Crystal Display Controller (LCDC)</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td>SPRUFO3</td>
</tr>
<tr>
<td>Inter-IC Sound (I2S) Peripheral</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>SPRUFP3</td>
</tr>
</tbody>
</table>

### Table 2. TMS320C55x DSP Peripherals (5532–5535)

<table>
<thead>
<tr>
<th>Peripheral</th>
<th>5532</th>
<th>5533</th>
<th>5534</th>
<th>5535</th>
<th>For Details, See...</th>
</tr>
</thead>
<tbody>
<tr>
<td>Analog-to-digital converter (ADC)</td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>Clock generator with PLL</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>Direct memory access (DMA) controller</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td></td>
</tr>
<tr>
<td>External memory interface (EMIF)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Host port interface (HPI)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Instruction cache</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>Inter-integrated circuit (I2C) module</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Multichannel buffered serial port (McBSP)</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td></td>
</tr>
<tr>
<td>MultiMediaCard / SD card controller</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Power management / Idle configurations</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>Real-time clock (RTC)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Timer, general-purpose</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Timer, watchdog</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>Universal Asynchronous Receiver/Transmitter (UART)</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>Universal Serial Bus (USB) module</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Serial Peripheral Interface (SPI)</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>Liquid Crystal Display Controller (LCDC)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Inter-IC Sound (I2S) Peripheral</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td>4</td>
<td></td>
</tr>
</tbody>
</table>
Analog-to-Digital Converter (ADC)

The ADC is described in the TMS320VC5507/5509 DSP Analog-to-Digital Converter (ADC) Reference Guide (SPRU586), and the TMS320C5515/05/VC05 Successive Approximation (SAR) Analog/Digital Converter (ADC) User’s Guide (SPRUFPI).

Clock Generator

This chapter describes the clock generator that is in TMS320VC5509, TMS320VC5509A, and TMS320VC5510 DSPs. The clock generator for the C5515 is described in the TMS320C5515 DSP System User’s Guide (SPRXFX5). The clock generator for the C5514 is described in the TMS320C5514 DSP System User’s Guide (SPRXFX6). The clock generator for the C5505 is described in the TMS320C5505 DSP System User’s Guide (SPRUGH5). The clock generator for the C5504 is described in the TMS320C5504 DSP System User’s Guide (SPRUGH6). The clock generator described here accepts an input clock at the CLKin pin and enables you to modify that signal internally to produce an output clock with the desired frequency. The clock generator passes this output clock (the CPU clock) to the CPU, to peripherals, and to other modules inside the C55x. DSP. The CPU clock is also passed through a programmable clock divider to the CLKOUT pin. Check the device-specific data manual for additional clock-generation information.

NOTE: For information about clock generation in other devices, see Table 1.

3.1 Introduction to the DSP Clock Generator

The DSP clock generator supplies the DSP with a clock signal that is based on an input clock signal connected at the CLKin pin. Included in the clock generator is a digital phase-lock loop (PLL), which can be enabled or disabled. You can configure the clock generator to create a CPU clock signal that has the desired frequency.

The clock generator has a clock mode register, CLKMD (see Section 3.8), for controlling and monitoring the activity of the clock generator. For example, you can write to the PLL ENABLE bit in CLKMD to toggle between the two main modes of operation:

- In the bypass mode (see Section 3.3), the PLL is bypassed, and the frequency of the output clock signal is equal to the frequency of the input clock signal divided by 1, 2, or 4. Because the PLL is disabled, this mode can be used to save power.
- In the lock mode (see Section 3.4), the input frequency can be both multiplied and divided to produce the desired output frequency, and the output clock signal is phase-locked to the input clock signal. The lock mode is entered if the PLL ENABLE bit of the clock mode register is set and the phase-locking sequence is complete. (During the phase-locking sequence, the clock generator is kept in the bypass mode.)

The clock generator also has an idle mode (see Section 3.5) for power conservation. You place the clock generator into its idle mode by turning off the CLKGEN idle domain. For information on turning on and off idle domains, see Section 8, Idle Configurations.

The output of the clock generator or a divided down version of that output can be seen on the CLKOUT pin. For details, see Section 3.6, The CLKOUT Pin and the Associated Clock Divider.

3.2 Operational Flow of the DSP Clock Generator

Figure 1 and Table 3 describe the operational states (A-F) of the DSP clock generator. The clock mode register (CLKMD) is loaded by software or by a DSP reset. If the write to CLKMD enables the PLL, the PLL begins its phase-locking sequence (state A). If the write disables the PLL, the clock generator enters its bypass mode (state D).
Figure 1. Operational Flow of the DSP Clock Generator

DSP reset

PLL disabled

Load CLKMD with a new value

PLL enabled

A
Locking the Phase (Bypass Mode)

Write to CLKMD

B
Lock Mode

Write to CLKMD

C
Idle Mode Entered

Write to CLKMD

D
Bypass Mode

Write to CLKMD

E
Idle Mode

Idle Mode Entered

Idle Mode

Phase Lock Lost and IOB = 1

Idle Mode Entered

Idle Mode

Idle Mode Entered

Idle Mode

Idle Mode

Idle Mode

Idle Mode Entered

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mode

 Idle Mod
Table 3. Operational States

<table>
<thead>
<tr>
<th>State</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td><strong>Locking the phase.</strong> The clock generator enters the bypass mode, and the PLL locks the phase of the output clock signal to that of the input clock signal. Once the phase is locked and the output signal is at the frequency defined by the PLL MULT bits and the PLL DIV bits of CLKMD, the clock generator enters its lock mode (state B). You can reconfigure the clock generator by writing to CLKMD.</td>
</tr>
<tr>
<td>B</td>
<td><strong>Lock mode.</strong> In the lock mode, the PLL is generating an output signal with the selected frequency. The output signal is phase-locked to the input signal. If the PLL loses the lock and the IOB bit of CLKMD is 1, the clock generator returns to the bypass mode and reacquires the lock (state A); if the IOB bit is 0, the clock generator does not reacquire the lock. An idle instruction can place the clock generator into its idle mode (state C). To change to the bypass mode or to reconfigure the clock generator in other ways, you can write to CLKMD.</td>
</tr>
<tr>
<td>C</td>
<td><strong>Idle mode (entered from the lock mode).</strong> An idle instruction has placed the clock generator into its idle mode. If the idle mode is properly exited, the clock generator starts again and reacquires the phase lock (state A). The method used to reacquire the lock depends on the IAI bit of CLKMD.</td>
</tr>
<tr>
<td>D</td>
<td><strong>Bypass mode.</strong> The PLL is disabled, and the clock generator is in the bypass mode. The divider within the clock generator produces an output clock signal at the frequency defined by the BYPASS DIV bits of CLKMD. An idle instruction can place the clock generator into its idle mode (state E). To change to the lock mode or to reconfigure the clock generator in other ways, you can write to CLKMD.</td>
</tr>
<tr>
<td>E</td>
<td><strong>Idle mode (entered from the bypass mode).</strong> An idle instruction has placed the clock generator into its idle mode. If the idle mode is properly exited, the clock generator starts again in the bypass mode.</td>
</tr>
</tbody>
</table>

3.3 **Bypass Mode**

When the DSP clock generator is in the bypass mode and the phase-lock loop (PLL) is disabled, the frequency of the output clock signal is equal to the frequency of the input clock signal divided by 1, 2, or 4.

3.3.1 **Entering and Exiting the Bypass Mode**

To enter the bypass mode, write a 0 to the PLL ENABLE bit in the clock mode register (CLKMD). The PLL will be disabled.

To exit the bypass mode, write a 1 to the PLL ENABLE bit. The PLL will start up and enter its phase-locking sequence. After the PLL is generating the configured output frequency and the phase of the output clock signal is locked to the phase of the input clock signal, the clock generator enters the lock mode. Until then, the clock generator stays in the bypass mode.

If the clock generator is in the lock mode and the PLL must reacquire its phase lock (IOB = 1), the clock generator enters the bypass mode until the phase is locked again.

3.3.2 **CLKMD Bits Used in the Bypass Mode**

Table 4 describes the bits of the clock mode register (CLKMD) that are used in the bypass mode. The reserved bits in CLKMD (Rsvd and TEST) should not be used in either the bypass mode or the lock mode. For a detailed description of CLKMD, see Section 3.8.

Table 4. CLKMD Bits Used in the Bypass Mode

<table>
<thead>
<tr>
<th>CLKMD Bit Field</th>
<th>Role in the Bypass Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>PLL ENABLE</td>
<td>Allows you to switch to the lock mode.</td>
</tr>
<tr>
<td>BYPASS DIV</td>
<td>Determines how the input clock frequency is divided (if at all) to produce the output clock frequency.</td>
</tr>
<tr>
<td>LOCK</td>
<td>Is 0 in the bypass mode.</td>
</tr>
</tbody>
</table>
3.3.3 Setting the Output Frequency for the Bypass Mode

The output frequency is determined by the input frequency and the value in the BYPASS DIV bits. Load BYPASS DIV as required to divide the input frequency by 1, 2, or 4.

3.4 Lock Mode

In the lock mode, the input frequency can be both multiplied and divided to produce the desired output frequency, and the output clock signal is phase locked to the input clock signal.

3.4.1 Entering and Exiting the Lock Mode

To enter the lock mode, write a 1 to the PLL ENABLE bit in the clock mode register (CLKMD). The PLL will start up and will enter its phase-locking sequence. After the PLL is generating the configured output frequency and the phase of the output clock signal is locked to the phase of the input clock signal, the clock generator enters the lock mode. Until then, the clock generator stays in the bypass mode.

If the clock generator is in the lock mode and the PLL must reacquire its phase lock (IOB = 1 in CLKMD), the clock generator will enter the bypass mode until the phase is locked again.

To exit the lock mode (enter the bypass mode), write a 0 to the PLL ENABLE bit. The PLL will be disabled.

3.4.2 CLKMD Bits Used in the Lock Mode

Table 5 describes the bits of the clock mode register (CLKMD) that are used in the lock mode. The reserved bits (Rsvd and TEST) in CLKMD should not be used in either the lock mode or the bypass mode. For a detailed description of CLKMD, see Section 3.8.

<table>
<thead>
<tr>
<th>CLKMD Bit Field(s)</th>
<th>Role in the Lock Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>PLL ENABLE</td>
<td>Allows you to switch to the lock mode.</td>
</tr>
<tr>
<td>PLL MULT and PLL DIV</td>
<td>Determine how the input clock frequency is modified (if at all) to produce the output clock frequency.</td>
</tr>
<tr>
<td>IAI</td>
<td>Determines whether the PLL restarts the phase-locking sequence when the clock generator exits its idle mode.</td>
</tr>
<tr>
<td>BREAKLN</td>
<td>Indicates when the phase lock has been broken.</td>
</tr>
<tr>
<td>IOB</td>
<td>Determines whether the PLL will reacquire a lost phase lock.</td>
</tr>
<tr>
<td>LOCK</td>
<td>Is 1 in the lock mode.</td>
</tr>
</tbody>
</table>

3.4.3 Setting the Output Frequency for the Lock Mode

The input frequency is multiplied by the PLL MULT value of CLKMD and is divided according to the PLL DIV value of CLKMD. PLL MULT can be a value from 2 to 31. PLL DIV can be a value from 0 (divide by 1) to 3 (divide by 4). The output frequency can be calculated with the following equation:

\[
\text{Output frequency} = \frac{\text{PLL MULT}}{\text{PLL DIV} + 1} \times \text{Input frequency}
\]

Table 6 shows some examples of using PLL MULT and PLL DIV to select an output frequency.

<table>
<thead>
<tr>
<th>PLL MULT</th>
<th>PLL DIV</th>
<th>Output Frequency</th>
</tr>
</thead>
<tbody>
<tr>
<td>31</td>
<td>0 (divide by 1)</td>
<td>31 \times \text{Input frequency (maximum frequency)}</td>
</tr>
<tr>
<td>10</td>
<td>1 (divide by 2)</td>
<td>5 \times \text{Input frequency}</td>
</tr>
<tr>
<td>2</td>
<td>2 (divide by 3)</td>
<td>2/3 \times \text{Input frequency}</td>
</tr>
<tr>
<td>2</td>
<td>3 (divide by 4)</td>
<td>1/2 \times \text{Input frequency (minimum frequency)}</td>
</tr>
</tbody>
</table>
3.4.4 Lock Time

The lock time is dependent on the multiply and divide factors chosen as well as the operating frequency. A good rule of thumb is to estimate 100µs for the lock time.

3.5 Idle (Low-Power) Mode

To save power, you can put the DSP clock generator into its idle mode by loading an idle configuration that turns off the CLKGEND idle domain. When the clock generator is idle, the output clock is stopped and held high. For more details, see Section 8, Idle Configurations.

When the clock generator exits its idle mode, the reaction of the clock generator depends on several factors. If the clock generator was in its bypass mode before the idle instruction was executed, the PLL returns to the bypass mode. If the clock generator was in its lock mode before the idle instruction was executed, the clock generator switches to its bypass mode, reacquires the phase lock, and then returns to the lock mode. The method used for reacquiring the phase lock depends on the IAI bit of CLKMD:

<table>
<thead>
<tr>
<th>IAI</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>The PLL does not restart the phase-locking sequence. Instead, the PLL reacquires the phase lock using the same lock settings that were in use just before the idle mode was entered.</td>
</tr>
<tr>
<td>1</td>
<td>The PLL restarts the phase-locking sequence. This option is recommended if the input clock has or may have changed while the clock generator was idle.</td>
</tr>
</tbody>
</table>

3.6 The CLKOUT Pin and the Associated Clock Divider

The DSP clock generator generates the CPU clock that is supplied to the CPU, to peripherals, and to other modules inside the DSP. As shown in Figure 2, the CPU clock is also passed to a clock divider that supplies a signal (CLKOUT) to the CLKOUT pin. The frequency of CLKOUT depends on the CLKDIV bits of the system register, SYSR (see Table 8). Consult the device-specific data manual to determine whether this clock divider feature is available on a particular C55x DSP.

<table>
<thead>
<tr>
<th>CLKDIV</th>
<th>Frequency of CLKOUT</th>
</tr>
</thead>
<tbody>
<tr>
<td>000b</td>
<td>1/1 x CPU clock frequency</td>
</tr>
<tr>
<td>001b</td>
<td>1/2 x CPU clock frequency</td>
</tr>
<tr>
<td>010b</td>
<td>1/4 x CPU clock frequency</td>
</tr>
<tr>
<td>011b</td>
<td>1/6 x CPU clock frequency</td>
</tr>
<tr>
<td>100b</td>
<td>1/8 x CPU clock frequency</td>
</tr>
<tr>
<td>101b</td>
<td>1/10 x CPU clock frequency</td>
</tr>
<tr>
<td>110b</td>
<td>1/12 x CPU clock frequency</td>
</tr>
<tr>
<td>111b</td>
<td>1/14 x CPU clock frequency</td>
</tr>
</tbody>
</table>
3.7 **DSP Reset Conditions of the DSP Clock Generator**

The following sections describe the operation of the DSP clock generator when the DSP is held in its reset state and when the DSP is removed from its reset state.

### 3.7.1 Clock Generator During Reset

The DSP can make use of the output clock signal during reset. While the DSP reset signal is held low:

- The clock generator is in the bypass mode.
- The output clock frequency is determined by the level of the signal on the CLKMD input pin:

<table>
<thead>
<tr>
<th>CLKMD Signal</th>
<th>Output Frequency</th>
</tr>
</thead>
<tbody>
<tr>
<td>Low</td>
<td>Input frequency</td>
</tr>
<tr>
<td>High</td>
<td>1/2 x Input frequency</td>
</tr>
</tbody>
</table>

### 3.7.2 Clock Generator After Reset

On the rising edge of the DSP reset signal (when reset is deasserted), the clock mode register is loaded with a value determined by the level on the CLKMD pin:

<table>
<thead>
<tr>
<th>CLKMD Signal</th>
<th>Clock Mode Register Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Low</td>
<td>2002h</td>
</tr>
<tr>
<td>High</td>
<td>2006h</td>
</tr>
</tbody>
</table>

**Table 9** summarizes the effects of this load to the clock mode register.

**Table 9. Reset Values of CLKMD Bits and The Effects**

<table>
<thead>
<tr>
<th>Reset Value</th>
<th>Effect</th>
</tr>
</thead>
<tbody>
<tr>
<td>IAI = 0</td>
<td>Only applicable in the lock mode. Initialize-after-idle is not selected. After the idle mode is exited, the PLL reacquires the phase lock using the same lock settings that were in use just before the idle mode was entered (the phase-locking sequence is not restarted).</td>
</tr>
<tr>
<td>IOB= 1</td>
<td>Only applicable in the lock mode. Initialize-on-break is selected. Any time the PLL loses its phase lock, the clock generator switches to its bypass mode and starts a new phase-locking sequence.</td>
</tr>
<tr>
<td>PLL MULT= 00000b</td>
<td>Only applicable in the lock mode. The output frequency is equal to the input frequency.</td>
</tr>
<tr>
<td>PLL ENABLE = 0</td>
<td>The PLL is disabled. The clock generator is in its bypass mode.</td>
</tr>
<tr>
<td>If CLKMD signal is low</td>
<td>If CLKMD signal is low</td>
</tr>
<tr>
<td>BYPASS DIV= 00b</td>
<td>Output frequency = Input frequency</td>
</tr>
<tr>
<td>If CLKMD signal is high</td>
<td>If CLKMD signal is high</td>
</tr>
<tr>
<td>BYPASS DIV= 01b</td>
<td>Output frequency = 1/2 x Input frequency</td>
</tr>
<tr>
<td>BREAKLN = 1</td>
<td>The break-lock indicator is reset.</td>
</tr>
<tr>
<td>LOCK = 0</td>
<td>The lock-mode indicator reflects the fact that the clock generator is in the bypass mode.</td>
</tr>
</tbody>
</table>
3.8 Clock Mode Register (CLKMD)

You control the DSP clock generator with the clock mode register, CLKMD. Figure 3 and Table 10 describe the contents of CLKMD, which is accessible in I/O space. After the DSP reset signal becomes inactive, the CLKMD register is initialized with a predetermined value dependent only upon the state of the CLKMD input pin (the difference is in the BYPASS DIV bits):

<table>
<thead>
<tr>
<th>CLKMD Signal Level at Reset</th>
<th>CLKMD Register Reset Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>Low</td>
<td>2002h</td>
</tr>
<tr>
<td>High</td>
<td>2006h</td>
</tr>
</tbody>
</table>

Figure 3. Clock Mode Register (CLKMD)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15</td>
<td>Reserved</td>
<td>0</td>
<td>Reserved. This bit is not available for use. This bit is always 0.</td>
</tr>
<tr>
<td>14</td>
<td>IAI</td>
<td></td>
<td>Initialize after idle bit. IAI determines how the PLL reacquires the phase lock after the clock generator exits its idle mode (when the CLKGEN idle domain is reactivated):</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0</td>
<td>The PLL does not restart the phase-locking sequence. Instead the PLL reacquires the lock using the same lock settings that were in use just before the idle mode was entered.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>The PLL restarts the phase-locking sequence. This option is recommended if the input clock has or may have changed while the clock generator was idle.</td>
</tr>
<tr>
<td>13</td>
<td>IOB</td>
<td></td>
<td>Initialize on break bit. IOB determines whether the clock generator initializes the PLL phase-locking sequence whenever the phase lock is broken. If the PLL indicates a break in the phase lock:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>0</td>
<td>The clock generator does not interrupt the PLL. The clock generator stays in the lock mode, and the PLL continues to output the current clock signal.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>The clock generator switches to its bypass mode and restarts the PLL phase-locking sequence.</td>
</tr>
<tr>
<td>12</td>
<td>TEST</td>
<td>0-1</td>
<td>This reserved test bit is cleared during a DSP reset and your program must keep it 0 for proper operation of the clock generator. Make sure that whenever your program modifies CLKMD, it writes a 0 to bit 12.</td>
</tr>
<tr>
<td>11-7</td>
<td>PLLMULT</td>
<td>0-1Fh</td>
<td>PLL multiply value. When the PLL is enabled (PLL ENABLE = 1), the frequency of the input clock signal is multiplied according to the value in PLL MULT. PLL MULT can be a value from 2 to 31. The input clock is multiplied by the unsigned integer in PLL MULT and is divided according to the value in the PLL DIV bits.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The maximum frequency for the PLL output clock signal is 31 times the frequency of the input clock signal. To obtain this maximum frequency, load PLL MULT with 31 (multiply by 31), and load PLL DIV with 0 (divide by 1).</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>The minimum frequency for the output clock signal is 1/2 the frequency of the input clock signal. To obtain this minimum frequency, load PLL MULT with 2 (multiply by 2) and load PLL DIV with 3 (divide by 4).</td>
</tr>
</tbody>
</table>
### Table 10. Clock Mode Register (CLKMD) Field Descriptions (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>6-5</td>
<td>PLLDIV</td>
<td>0</td>
<td>No division/divide by 1. The input frequency is not divided.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1h</td>
<td>Divide by 2. The input frequency is divided by 2.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2h</td>
<td>Divide by 3. The input frequency is divided by 3.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>3h</td>
<td>Divide by 4. The input frequency is divided by 4.</td>
</tr>
<tr>
<td>4</td>
<td>PLLENABLE</td>
<td>0</td>
<td>Disable the PLL (enter the bypass mode).</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>Enable the PLL and, when the correct output clock signal is generated, enter the lock mode.</td>
</tr>
<tr>
<td>3-2</td>
<td>BYPASSDIV</td>
<td>0</td>
<td>No division/divide by 1. The frequency of the output clock signal is the same as the frequency of the input clock signal.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1h</td>
<td>Divide by 2. The frequency of the output clock signal is 1/2 the frequency of the input clock signal.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>2h</td>
<td>Divide by 4. The frequency of the output clock signal is 1/4 the frequency of the input clock signal.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>3h</td>
<td>The frequency of the output clock signal is 1/4 the frequency of the input clock signal.</td>
</tr>
<tr>
<td>1</td>
<td>BREAKLN</td>
<td>0</td>
<td>The PLL has broken the phase lock.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>The phase lock is restored, or a write to CLKMD has occurred.</td>
</tr>
<tr>
<td>0</td>
<td>LOCK</td>
<td>0</td>
<td>No division/divide by 1. The clock generator is in the bypass mode. The output clock signal has the frequency determined by the BYPASS DIV bits, or the PLL is in the process of getting a phase lock.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>The clock generator is in the lock mode. The PLL has a phase lock, and the output clock has the frequency determined by the PLL MULT bits and the PLL DIV bits.</td>
</tr>
</tbody>
</table>
4 Direct Memory Access (DMA) Controller


5 External memory Interface (EMIF)

For the EMIF information that applies to your C55x device, see the corresponding device-specific reference guide:
- TMS320VC5501/5502 DSP External Memory Interface (EMIF) Reference Guide (SPRU621),
- TMS320VC5503/5507/5509 DSP External Memory Interface (EMIF) Reference Guide (SPRU670), or
- TMS320VC5510 DSP External Memory Interface (EMIF) Reference Guide (SPRU590),
- TMS320C5515/14/05/04 DSP External Memory Interface (EMIF) User's Guide (SPRUGU6).

6 General-Purpose I/O Port

For information on the C5515/14/05/04/VC05/VC04 general-purpose I/O (GPIO) ports, see the TMS320C5515/14/05/04/VC05/VC04 DSP General-Purpose Input/Output User's Guide (SPRUFO4). For information on the GPIO ports on other devices, see the device-specific data manuals.

7 Host Port Interface (HPI)

For the HPI information that applies to your C55x device, see the corresponding device-specific reference guide:
- TMS320VC5501/5502 DSP Host Port Interface (HPI) Reference Guide (SPRU620),
- TMS320VC5503/5507/5509 DSP Host Port Interface (HPI) Reference Guide (SPRU619), or
- TMS320VC5510 DSP Host Port Interface (HPI) Reference Guide (SPRU588).

The name “enhanced host port interface (EHPI)” has been reduced to “host port interface (HPI)” to align with a new peripheral naming convention.

8 Idle Configurations

The TMS320C55x DSP is divided into the idle domains described in this chapter. To minimize power consumption, you can choose which domains are active and which domains are idle at any given time. The current state of all domains is collectively called the idle configuration.

---

NOTE:

1. Check the device-specific data manual for additional information about deactivating and reactivating idle domains of the DSP.
8.1 Idle Domains

The DSP is divided into the idle domains described in Table 11. You can control which of these idle domains are active and which are idle at any given time, as described in Section 8.2.

NOTE:

1. The peripheral bus controller and the host port interface (HPI) on the DSP are not part of any idle domain. The only way to turn these modules off is to put the clock generator into its idle mode (make the CLKGEN domain idle).

2. The internal memory blocks (SARAM and DARAM) and the external memory are shared by two domains (CPU and DMA). When both domains are idle, memory accesses are disabled.

Table 11. Idle Domains in the DSP

<table>
<thead>
<tr>
<th>DOMAIN</th>
<th>Contents of the Domain</th>
<th>Configurability</th>
</tr>
</thead>
<tbody>
<tr>
<td>CPU</td>
<td>CPU and CPU buses</td>
<td>When the idle instruction is executed, the CPU remains active or becomes idle, depending on the chosen idle configuration. Regardless of this domain’s state before a DSP reset, it is active after a DSP reset.</td>
</tr>
<tr>
<td>DMA</td>
<td>DMA controller and DMA buses</td>
<td>When the idle instruction is executed, the DMA (direct memory access) controller remains active or becomes idle, depending on the chosen idle configuration. Regardless of this domain’s state before a DSP reset, it is active after a DSP reset.</td>
</tr>
<tr>
<td>CASHE</td>
<td>Instruction cache</td>
<td>When the idle instruction is executed, the instruction cache remains active or becomes idle, depending on the chosen idle configuration. Regardless of this domain’s state before a DSP reset, it is active after a DSP reset.</td>
</tr>
<tr>
<td>PERIPH</td>
<td>Timers, serial ports, and other peripherals</td>
<td>Each of the peripherals in this domain has an idle enable bit that determines whether the peripheral can be placed in its idle mode when the idle instruction is executed. If the PERIPH domain is configured to be idle and an idle enable bit is 1, the corresponding peripheral is placed in its idle mode. Regardless of this domain’s state before a DSP reset, it is active after a DSP reset.</td>
</tr>
<tr>
<td>CLKGEN</td>
<td>Clock generator, including the phase-lock loop (PLL) circuitry</td>
<td>When the idle instruction is executed, the clock generator remains active or becomes idle, depending on the chosen idle configuration. When the clock generator is in its idle mode, no clocking is available for the CPU or the DMA controller. If the clock generator is configured to be idle and the CPU, the DMA controller, or the cache is configured to be active, a bus error interrupt request is sent to the CPU. If properly enabled, the interrupt will force the CLKGEN domain to be reactivated. Peripherals that do not depend on the DSP clock signal are not affected by the state of the CLKGEN domain. Regardless of this domain’s state before a DSP reset, it is active after a DSP reset.</td>
</tr>
<tr>
<td>EMIF</td>
<td>External memory interface (EMIF)</td>
<td>When the idle instruction is executed, the EMIF is disabled or enabled, depending on the chosen idle configuration. Regardless of this domain’s state before a DSP reset, it is active after a DSP reset.</td>
</tr>
</tbody>
</table>
8.2 Idle Configuration Process

The idle configuration indicates which idle domains will be idle, and which idle domains will be active, the next time the idle instruction is executed. The basic steps to the idle configuration process are:

1. Define a new idle configuration by writing to the bits in the idle configuration register (ICR). Make sure that you use a valid idle configuration (see Section 8.3).
2. Apply the new idle configuration by executing the idle instruction. The effects are shown in Figure 4. The content of ICR is copied to the idle status register (ISTR). The bits of ISTR are then propagated through the system to enable or disable each of the chosen domains.

The idle instruction cannot be executed in parallel with another instruction.

NOTE: If you intend to switch among multiple idle configurations, make sure that your system has the means to change from one idle configuration to the next. For important considerations, see Section 8.4.

Figure 4. Idle Configuration Process

8.3 Valid Idle Configurations

Not all of the values that you can write to the idle configuration register (ICR) provide valid idle configurations. The valid configurations are limited by dependencies within the system. For example, when the CLKGEN domain is idle (the DSP clock generator is disabled), the DMA controller, the CPU, and any peripherals that do not have their own external clocks cannot operate.
8.4 To Change Idle Configurations (Key Conditions)

Before you use the idle instruction, make sure that there is a method for the DSP to change the idle configuration afterward. Table 12 summarizes the methods available under three key conditions. The table also describes the effects on the idle registers: the idle status register (ISTR) and the idle configuration register (ICR). For more details about these idle registers, see Section 8.7.

Table 12. Changing Idle Configurations

<table>
<thead>
<tr>
<th>Condition</th>
<th>Available Methods for Changing Idle Configuration</th>
<th>ISTR After Change</th>
<th>ICR After Change</th>
</tr>
</thead>
<tbody>
<tr>
<td>1. CLKGEN domain is active CPU domain is active (see Section 8.4.1)</td>
<td>A. Write a new configuration to the idle configuration register (ICR), and then execute the idle instruction.</td>
<td>A. Modified by the idle instruction; contains a copy of the new ICR value.</td>
<td>A. Contains the new value that was loaded by the program.</td>
</tr>
<tr>
<td></td>
<td>B. Initiate a DSP hardware reset.</td>
<td>B. Cleared (all 0s).</td>
<td>B. Cleared (all 0s)</td>
</tr>
<tr>
<td>2. CLKGEN domain is active CPU domain is idle (see Section 8.4.2)</td>
<td>A. Use an unmasked hardware interrupt or the nonmaskable hardware interrupt called NMI_.</td>
<td>A. CLKGENIS and CPUIS bits are 0. No other bits were modified.</td>
<td>A. Not modified.</td>
</tr>
<tr>
<td></td>
<td>B. Initiate a DSP hardware reset.</td>
<td>B. Cleared (all 0s).</td>
<td>B. Cleared (all 0s)</td>
</tr>
<tr>
<td>3. CLKGEN domain is idle (see Section 8.4.3)</td>
<td>A. Use an unmasked hardware interrupt or the nonmaskable hardware interrupt called NMI_.</td>
<td>A. CLKGENIS and CPUIS bits are 0. No other bits were modified.</td>
<td>A. Not modified.</td>
</tr>
<tr>
<td></td>
<td>B. Initiate a DSP hardware reset.</td>
<td>B. Cleared (all 0s).</td>
<td>B. Cleared (all 0s)</td>
</tr>
</tbody>
</table>

8.4.1 Condition 1: CLKGEN and CPU Domains Active

When the CLKGEN domain is active (the DSP clock generator is enabled) and the CPU domain is active (the DSP CPU is running), program flow continues. In this case, there are two methods of changing idle configurations:

- Write a new idle configuration to the idle configuration register (ICR), and then execute the idle instruction. The idle instruction copies the content of the ICR to the idle status register (ISTR), and the ISTR bit values are propagated to the idle domains. After the domains change states, the value in ISTR matches the value in ICR.
- Initiate a DSP hardware reset at the DSP reset pin. When the DSP resets, all domains are made active.

8.4.2 Condition 2: CLKGEN Domain Active, CPU Domain Idle

When the CPU domain is idle, program flow is halted. It is not possible to write a new value to the idle configuration register (ICR) or to execute the idle instruction. Two other methods are available for changing the idle configuration:

- Use an unmasked interrupt or the nonmaskable interrupt called NMI_. The interrupt clears the CLKGENIS and CPUIS bits of the idle status register (ISTR). The change to CPUIS reactivates the CPU domain, and the change to CLKGENIS ensures that the CLKGEN domain is also active. The content of the idle configuration register (ICR) is not modified. To learn how the CPU responds to the interrupt, see Section 8.5.
- Initiate a DSP hardware reset at the DSP reset pin. When the DSP resets, all domains are made active.

Once program flow has begun again, you can reactivate or deactivate other domains by writing a new idle configuration to ICR and then executing the idle instruction.
Idle Configurations

8.4.3 **Condition 3: CLKGEN Domain Idle**

When the CLKGEN domain is idle (the DSP clock generator is disabled), no internal clocks are active, including the CPU clock. With the CPU halted, it is not possible to write a new value to the idle configuration register (ICR) or to execute the idle instruction. Two other methods are available for waking the DSP:

- Use an unmasked interrupt or the nonmaskable interrupt called NMI_. The interrupt clears the CLKGENIS and CPUIS bits of the idle status register (ISTR). The change to CPUIS reactivates the CPU domain, and the change to CLKGENIS ensures that the CLKGEN domain is also active. The content of the idle configuration register (ICR) is not modified. To learn how the CPU responds to the interrupt, see Section 8.5.

- Initiate a DSP hardware reset at the DSP reset pin. When the DSP resets, all domains are made active.

Once program flow has begun again, you can reactivate or deactivate other domains by writing a new idle configuration to ICR and then executing the idle instruction.

8.5 **Interrupt Handling When the CPU Is Reactivated**

If the CPU has been halted by an idle configuration, it can be reactivated by a nonmaskable interrupt (NMI_ or RESET_) or by a maskable interrupt that is enabled in an interrupt enable register (IER0 or IER1). A maskable interrupt request will also set the corresponding interrupt flag bit in an interrupt flag register (IFR0 or IFR1). Table 13 summarizes how the CPU responds after being reactivated by maskable and nonmaskable interrupts. INTM is the global interrupt mask bit in status register ST1_55.

<table>
<thead>
<tr>
<th>Interrupt</th>
<th>CPU Response After Reactivation</th>
</tr>
</thead>
<tbody>
<tr>
<td>A maskable</td>
<td>If INTM = 0: The CPU executes the interrupt service routine, executes the instruction that</td>
</tr>
<tr>
<td>interrupt</td>
<td>follows the idle instruction, and continues from there.</td>
</tr>
<tr>
<td></td>
<td>If INTM = 1: The CPU executes the instruction that follows the idle instruction and then</td>
</tr>
<tr>
<td></td>
<td>continues from there. The interrupt service routine cannot be executed until the interrupt</td>
</tr>
<tr>
<td></td>
<td>has been enabled by INTM.</td>
</tr>
<tr>
<td>NMI_ (nonmaskable)</td>
<td>The CPU executes the interrupt service routine, executes the instruction that follows the</td>
</tr>
<tr>
<td></td>
<td>idle instruction and then continues from there.</td>
</tr>
<tr>
<td>RESET_ (nonmaskable)</td>
<td>The DSP is reset. (During a DSP reset, all idle domains are made active.)</td>
</tr>
</tbody>
</table>

8.6 **Effect of a DSP Reset on the Idle Domains**

Driving the DSP reset signal low starts a DSP reset. During a DSP reset, all idle domains are made active.
8.7 Idle Registers

Two registers provide the means for you to individually configure and monitor each of the idle domains: the idle configuration register (ICR) and the idle status register (ISTR). These registers (see Figure 5 and Figure 6) are part of the peripheral bus controller and are accessible to the CPU. Table 14 describes the read/write bits of ICR, and Table 15 describes the read-only bits of ISTR.

ICR lets you configure how each idle domain will respond the next time the idle instruction is executed. When you execute the idle instruction, the content of ICR is copied to ISTR. Then the ISTR values are propagated to the idle domains. Making the clock generator idle (CLKGENI = 1) provides the lowest level of power consumption in the DSP by stopping all the system clocks.

Table 14. Idle Configuration Register (ICR) Field Descriptions

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>16-6</td>
<td>Reserved</td>
<td>0</td>
<td>Reserved. These bits are read-only bits and return 0s when read.</td>
</tr>
<tr>
<td>5</td>
<td>EMIFI</td>
<td>0</td>
<td>EMIF-domain idle configuration bit. EMIFI determines whether the external memory interface (EMIF) will be idle after the next execution of the idle instruction: &lt;br&gt; 0: EMIF will be active. &lt;br&gt; 1: EMIF will be idle.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>CLKGENI</td>
<td>0</td>
<td>CLKGEN-domain idle configuration bit. CLKGENI determines whether the DSP clock generator will be idle after the next execution of the idle instruction: &lt;br&gt; 0: Clock generator will be active. &lt;br&gt; 1: Clock generator will be idle. &lt;br&gt; <strong>Note:</strong> For a proper power-down, when you set CLKGEN = 1, make sure you also set CPU = 1, DMAI = 1, and CACHEI = 1. If you do not, a bus error interrupt (BERRINT) request is sent to the CPU.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>PERI</td>
<td>0</td>
<td>PERIPH-domain idle configuration bit. Peripherals that are in the PERIPH domain each have an idle enable bit. PERI, in conjunction with the idle enable bits, determines which of the peripherals in the domain will be idle after the next execution of the idle instruction: &lt;br&gt; 0: All peripherals in the domain will be active. &lt;br&gt; 1: For each peripheral in the domain: If the idle enable bit is 1, the peripheral will be in its idle mode. If the idle enable bit is 0, the peripheral will be active.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>CACHEI</td>
<td>0</td>
<td>CACHE-domain idle configuration bit. CACHEI determines whether the cache will be idle after the next execution of the idle instruction: &lt;br&gt; 0: Cache will be active. &lt;br&gt; 1: Cache will be idle.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>DMAI</td>
<td>0</td>
<td>DMA-domain idle configuration bit. DMAI determines whether the DMA controller will be idle after the next execution of the idle instruction: &lt;br&gt; 0: DMA controller will be active. &lt;br&gt; 1: DMA controller will be idle.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>CPU</td>
<td>0</td>
<td>CPU-domain idle configuration bit. CPU determines whether the DSP CPU will be idle after the next execution of the idle instruction: &lt;br&gt; 0: CPU will be active. &lt;br&gt; 1: CPU will be active.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>
### Figure 6. Idle Status Register (ISTR)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Field</th>
<th>Value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-6</td>
<td>Reserved</td>
<td>0</td>
<td>Reserved. These bits are read-only bits and return 0s when read.</td>
</tr>
<tr>
<td>5</td>
<td>EMIFIS</td>
<td>0</td>
<td>EMIF-domain idle status bit. EMIFIS is a copy of EMIFI made during the execution of the idle instruction. EMIFIS reflects the current idle status of the external memory interface (EMIF):</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>EMIF is idle.</td>
</tr>
<tr>
<td>4</td>
<td>CLKGENIS</td>
<td>0</td>
<td>CLKGEN-domain idle status bit. CLKGENIS is a copy of CLKGENI made during the execution of the idle instruction. CLKGENIS reflects the current idle status of the DSP clock generator:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>Clock generator is idle.</td>
</tr>
<tr>
<td>3</td>
<td>PERIS</td>
<td>0</td>
<td>PERIPH-domain idle status bit. PERIS is a copy of PERI made during the execution of the idle instruction. PERIS reflects the current idle status of the peripherals in the PERIPH domain:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>For each peripheral in the domain: If the idle enable bit is 1, the peripheral is idle. If the idle enable bit is 0, the peripheral is active.</td>
</tr>
<tr>
<td>2</td>
<td>CACHEIS</td>
<td>0</td>
<td>CACHE-domain idle status bit. CACHEIS is a copy of CACHEI made during the execution of the idle instruction. CACHEIS reflects the current idle status of the cache:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>Cache is idle.</td>
</tr>
<tr>
<td>1</td>
<td>DMAIS</td>
<td>0</td>
<td>DMA-domain idle status bit. DMAIS is a copy of DMAI made during the execution of the idle instruction. DMAIS reflects the current idle status of the DMA controller:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>DMA controller is idle.</td>
</tr>
<tr>
<td>0</td>
<td>CPUIS</td>
<td>0</td>
<td>CPU-domain idle status bit. CPUIS is a copy of CPUI made during the execution of the idle instruction. CPUIS reflects the current idle status of the DSP CPU:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
<td>CPU is idle.</td>
</tr>
</tbody>
</table>
9 Instruction Cache
The instruction cache that is in TMS320VC5501 and TMS320VC5502 DSPs is described in the TMS320VC5501/5502 DSP Instruction Cache Reference Guide (SPRU630). The instruction cache that is in TMS320VC5510 DSPs is described in the TMS320VC5510 DSP Instruction Cache Reference Guide (SPRU576).

10 Inter-Integrated Circuit (I2C) Module
For more information about the I2C module, see the TMS320VC5501/5502/5503/5507/5509 DSP Inter-Integrated Circuit (I2C) Module Reference Guide (SPRU146) and the TMS320C5515/14/05/04/VC05/VC04 DSP Inter-Integrated Circuit (I2C) Peripheral User's Guide (SPRUFO1).

11 Multichannel Buffered Serial Port (McBSP)
For more information about the McBSP, see the TMS320VC5501/5502/5503/5507/5509/5510 DSP Multichannel Buffered Serial Port (McBSP) Reference Guide (SPRU592).

12 Real-Time Clock (RTC)
For more information about the RTC, see the TMS320VC5503/5507/5509 DSP Real-Time Clock (RTC) Reference Guide (SPRU594) and the TMS320C5515/14/05/04/VC05/VC04 DSP Real-Time Clock (RTC) User's Guide (SPRUFX2).

13 System Control Registers
For more information on the C5515 system control registers, see the TMS320C5515 DSP System User's Guide (SPRUFX5). For more information on the C5514 system control registers, see the TMS320C5514 DSP System User's Guide (SPRUFX6). For more information on the C5505 system control registers, see the TMS320C5505 DSP System User's Guide (SPRUGH5). For more information on the C5504 system control registers, see the TMS320C5504 DSP System User's Guide (SPRUGH6). System control register information for other devices has been moved to the device-specific data manuals.

14 Timer (General-Purpose)
The general-purpose timer is described in the TMS320VC5501/5502 DSP Timers Reference Guide (SPRU618), the TMS320VC5503/5507/5509/5510 DSP Timers Reference Guide (SPRU595), and the TMS320C5515/14/05/04/VC05/VC04 DSP Timer/Watchdog Timer User's Guide (SPRUFO2).

15 Universal Asynchronous Receiver/Transmitter (UART)
UART information is in the TMS320VC5501/5502 DSP Universal Asynchronous Receiver/Transmitter (UART) Reference Guide (SPRU597) and the TMS320C5515/14/05/04/VC05/VC04 DSP Universal Asynchronous Receiver/Transmitter (UART) User's Guide (SPRUFO5).

16 Universal Serial Bus (USB) Module
For more information about the USB module, see the TMS320VC5507/5509 DSP Universal Serial Bus (USB) Module Reference Guide (SPRU596), and the TMS320C5515/14/05/04 DSP Universal Serial Bus 2.0 (USB) Controller User's Guide (SPRUGH9).

17 Watchdog Timer
The watchdog timer is described in the TMS320VC5501/5502 DSP Timers Reference Guide (SPRU618), the TMS320VC5503/5507/5509/5510 DSP Timers Reference Guide (SPRU595), and the TMS320C5515/14/05/04/VC05/VC04 DSP Timer/Watchdog Timer User's Guide (SPRUFO2).
18 Serial Peripheral Interface (SPI)

For more information about the serial peripheral interface (SPI), see the TMS320C5515/14/05/04/VC05/VC04 DSP Serial Peripheral Interface (SPI) User's Guide (SPRUF03).

19 Liquid Crystal Display Controller (LCDC)

For more information about the liquid crystal display controller (LCDC), see the TMS320C5515/05/VC05 DSP Liquid Crystal Display Controller (LCDC) User's Guide (SPRUP3).

20 Inter-IC Sound (I2S) Peripheral

For more information about the inter-IC sound (I2S) peripheral, see the TMS320C5515/14/05/04 DSP Inter-IC Sound (I2S) User's Guide (SPRUFX4).

21 MultiMedia Card (MMC) / SD Card Controller

For more information about the multimedia card/SD card controller, see the TMS320VC5509 DSP MultiMediaCard / SD Card Controller Reference Guide (SPRUS93) and TMS320C5515/14/05/04/VC05/VC04 DSP Multimedia Card (MMC)/Secure Digital (SD) Card Controller Reference Guide (SPRUF06).
IMPORTANT NOTICE

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI’s terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed.

TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe physical injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade or enhanced plastic is solely at Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications.

TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use. TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any damages arising out of the use of TI products in such applications.

Following are URLs where you can obtain information on other Texas Instruments products and application solutions:

<table>
<thead>
<tr>
<th>Products</th>
<th>Applications</th>
</tr>
</thead>
<tbody>
<tr>
<td>Audio</td>
<td>Communications and Telecom</td>
</tr>
<tr>
<td>Amplifiers</td>
<td>Computers and Peripherals</td>
</tr>
<tr>
<td>Data Converters</td>
<td>Consumer Electronics</td>
</tr>
<tr>
<td>DLP® Products</td>
<td>Energy and Lighting</td>
</tr>
<tr>
<td>DSP</td>
<td>Industrial</td>
</tr>
<tr>
<td>Clocks and Timers</td>
<td>Medical</td>
</tr>
<tr>
<td>Interface</td>
<td>Security</td>
</tr>
<tr>
<td>Logic</td>
<td>Space, Avionics and Defense</td>
</tr>
<tr>
<td>Power Mgmt</td>
<td>Transportation and Automotive</td>
</tr>
<tr>
<td>Microcontrollers</td>
<td>Video and Imaging</td>
</tr>
<tr>
<td>RFID</td>
<td></td>
</tr>
<tr>
<td>OMAP Mobile Processors</td>
<td></td>
</tr>
<tr>
<td>Wireless Connectivity</td>
<td></td>
</tr>
</tbody>
</table>

TI E2E Community Home Page
e2e.ti.com

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265
Copyright © 2011, Texas Instruments Incorporated